From 35e6eb1cef070987ef69fb04e61a2ce900c32204 Mon Sep 17 00:00:00 2001 From: V Sowmya Date: Thu, 16 Mar 2017 20:25:26 +0530 Subject: mb/google/poppy: Add camera support Add camera related support * Enable the SA Imaging Unit and CIO2 devices. * Enable TPS68470 PMIC and populate related ACPI objects. * Enable OV cameras and populate related ACPI objects. * Enable Dongwoon AF DAC and populate related ACPI objects. BUG=b:36580624 BRANCH=none TEST=Build and boot poppy. Dump and verify that ACPI tables have the required entries for all the camera devices. Change-Id: Ifbe878bb6b25fc976e935fee16c4d59fadd47fe2 Signed-off-by: Sowmya V Signed-off-by: Rizwan Qureshi Reviewed-on: https://review.coreboot.org/18969 Tested-by: build bot (Jenkins) Reviewed-by: Furquan Shaikh Reviewed-by: Sumeet R Pawnikar --- src/mainboard/google/poppy/Kconfig | 1 + src/mainboard/google/poppy/devicetree.cb | 138 ++++++++++++++++++++++++++++++- 2 files changed, 136 insertions(+), 3 deletions(-) (limited to 'src/mainboard/google') diff --git a/src/mainboard/google/poppy/Kconfig b/src/mainboard/google/poppy/Kconfig index 0626a3260b..bc0c9cb483 100644 --- a/src/mainboard/google/poppy/Kconfig +++ b/src/mainboard/google/poppy/Kconfig @@ -4,6 +4,7 @@ config BOARD_SPECIFIC_OPTIONS def_bool y select BOARD_ID_AUTO select BOARD_ROMSIZE_KB_16384 + select DRIVERS_INTEL_MIPI_CAMERA select DRIVERS_I2C_GENERIC select DRIVERS_I2C_HID select EC_GOOGLE_CHROMEEC diff --git a/src/mainboard/google/poppy/devicetree.cb b/src/mainboard/google/poppy/devicetree.cb index c714d0b75a..d232028544 100644 --- a/src/mainboard/google/poppy/devicetree.cb +++ b/src/mainboard/google/poppy/devicetree.cb @@ -38,7 +38,8 @@ chip soc/intel/skylake register "XdciEnable" = "0" register "SsicPortEnable" = "0" register "SmbusEnable" = "1" - register "Cio2Enable" = "0" + register "Cio2Enable" = "1" + register "SaImguEnable" = "1" register "ScsEmmcEnabled" = "1" register "ScsEmmcHs400Enabled" = "1" register "ScsSdCardEnabled" = "2" @@ -207,7 +208,84 @@ chip soc/intel/skylake end end # I2C #0 device pci 15.1 on end # I2C #1 - device pci 15.2 on end # I2C #2 + device pci 15.2 on + chip drivers/intel/mipi_camera + register "acpi_hid" = ""INT3472"" + register "acpi_name" = ""PMIC"" + register "chip_name" = ""TPS68470 PMIC"" + register "device_type" = "INTEL_ACPI_CAMERA_PMIC" + device i2c 4d on end + end + chip drivers/intel/mipi_camera + register "acpi_hid" = ""OVTID850"" + register "acpi_name" = ""CAM0"" + register "chip_name" = ""OV 13850 Camera"" + register "device_type" = "INTEL_ACPI_CAMERA_SENSOR" + + # Camera SSDB buffer + register "ssdb.sensor_card_sku" = "0x50" + register "ssdb.link_used" = "0x00" + register "ssdb.lanes_used" = "0x04" + register "ssdb.rom_type" = "0x08" + register "ssdb.vcm_type" = "0x03" + register "ssdb.platform" = "0x09" + register "ssdb.flash_support" = "0x02" + register "ssdb.privacy_led" = "0x01" + register "ssdb.degree" = "0x00" + register "ssdb.mipi_define" = "0x01" + register "ssdb.mclk" = "0x016E3600" + + # Sensor PWDB entries + register "num_pwdb_entries" = "5" + + register "pwdb[0].name" = ""VSIO"" + register "pwdb[0].value" = "1800600" + register "pwdb[0].entry_type" = "INTEL_ACPI_CAMERA_REGULATOR" + register "pwdb[0].delay_usec" = "0" + + register "pwdb[1].name" = ""tps68470-a"" + register "pwdb[1].value" = "19200000" + register "pwdb[1].entry_type" = "INTEL_ACPI_CAMERA_CLK" + register "pwdb[1].delay_usec" = "0" + + register "pwdb[2].name" = ""ANA"" + register "pwdb[2].value" = "2815200" + register "pwdb[2].entry_type" = "INTEL_ACPI_CAMERA_REGULATOR" + register "pwdb[2].delay_usec" = "3000" + + register "pwdb[3].name" = ""s_resetn"" + register "pwdb[3].value" = "1" + register "pwdb[3].entry_type" = "INTEL_ACPI_CAMERA_GPIO" + register "pwdb[3].delay_usec" = "0" + + register "pwdb[4].name" = ""CORE"" + register "pwdb[4].value" = "1200000" + register "pwdb[4].entry_type" = "INTEL_ACPI_CAMERA_REGULATOR" + register "pwdb[4].delay_usec" = "3000" + + device i2c 10 on end + end + chip drivers/intel/mipi_camera + register "acpi_hid" = ""DW9714"" + register "acpi_name" = ""VCM0"" + register "chip_name" = ""Dongwoon AF DAC"" + register "device_type" = "INTEL_ACPI_CAMERA_VCM" + + # VCM PWDB entries + register "num_pwdb_entries" = "2" + register "pwdb[0].name" = ""VSIO"" + register "pwdb[0].value" = "1800600" + register "pwdb[0].entry_type" = "INTEL_ACPI_CAMERA_REGULATOR" + register "pwdb[0].delay_usec" = "0" + + register "pwdb[1].name" = ""VCM"" + register "pwdb[1].value" = "2815200" + register "pwdb[1].entry_type" = "INTEL_ACPI_CAMERA_REGULATOR" + register "pwdb[1].delay_usec" = "3000" + + device i2c 0xc on end + end + end # I2C #2 device pci 15.3 on chip drivers/i2c/hid register "generic.hid" = ""WCOM50C1"" @@ -248,7 +326,61 @@ chip soc/intel/skylake device i2c 13 on end end end # I2C #5 - device pci 19.2 on end # I2C #4 + device pci 19.2 on + chip drivers/intel/mipi_camera + register "acpi_hid" = ""INT3479"" + register "acpi_name" = ""CAM1"" + register "chip_name" = ""OV 5670 Camera"" + register "device_type" = "INTEL_ACPI_CAMERA_SENSOR" + + # Camera SSDB buffer + register "ssdb.sensor_card_sku" = "0x50" + register "ssdb.link_used" = "0x01" + register "ssdb.lanes_used" = "0x02" + register "ssdb.rom_type" = "0x08" + register "ssdb.vcm_type" = "0x03" + register "ssdb.platform" = "0x09" + register "ssdb.flash_support" = "0x02" + register "ssdb.privacy_led" = "0x01" + register "ssdb.mipi_define" = "0x01" + register "ssdb.mclk" = "0x016E3600" + + # Sensor PWDB entries + register "num_pwdb_entries" = "6" + + register "pwdb[0].name" = ""VSIO"" + register "pwdb[0].value" = "1800600" + register "pwdb[0].entry_type" = "INTEL_ACPI_CAMERA_REGULATOR" + register "pwdb[0].delay_usec" = "0" + + register "pwdb[1].name" = ""AUX2"" + register "pwdb[1].value" = "1800600" + register "pwdb[1].entry_type" = "INTEL_ACPI_CAMERA_REGULATOR" + register "pwdb[1].delay_usec" = "0" + + register "pwdb[2].name" = ""tps68470-b"" + register "pwdb[2].value" = "19200000" + register "pwdb[2].entry_type" = "INTEL_ACPI_CAMERA_CLK" + register "pwdb[2].delay_usec" = "0" + + register "pwdb[3].name" = ""gpio.4"" + register "pwdb[3].value" = "1" + register "pwdb[3].entry_type" = "INTEL_ACPI_CAMERA_GPIO" + register "pwdb[3].delay_usec" = "3000" + + register "pwdb[4].name" = ""gpio.5"" + register "pwdb[4].value" = "1" + register "pwdb[4].entry_type" = "INTEL_ACPI_CAMERA_GPIO" + register "pwdb[4].delay_usec" = "0" + + register "pwdb[5].name" = ""AUX1"" + register "pwdb[5].value" = "1213200" + register "pwdb[5].entry_type" = "INTEL_ACPI_CAMERA_REGULATOR" + register "pwdb[5].delay_usec" = "3000" + + device i2c 10 on end + end + end # I2C #4 device pci 1c.0 on chip drivers/intel/wifi register "wake" = "GPE0_PCI_EXP" -- cgit v1.2.3