Loading arch/arm64/boot/dts/qcom/sdmmagpie-camera-sensor-idp.dtsi 0 → 100644 +349 −0 Original line number Diff line number Diff line /* * Copyright (c) 2018, The Linux Foundation. All rights reserved. * * This program is free software; you can redistribute it and/or modify * it under the terms of the GNU General Public License version 2 and * only version 2 as published by the Free Software Foundation. * * This program is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU General Public License for more details. */ #include <dt-bindings/clock/qcom,camcc-sdmmagpie.h> &soc { led_flash_rear: qcom,camera-flash@0 { cell-index = <0>; reg = <0x00 0x00>; compatible = "qcom,camera-flash"; flash-source = <&pm6150l_flash0 &pm6150l_flash1>; torch-source = <&pm6150l_torch0 &pm6150l_torch1>; switch-source = <&pm6150l_switch2 &pm6150l_switch2>; status = "ok"; }; led_flash_rear_aux: qcom,camera-flash@1 { cell-index = <1>; reg = <0x01 0x00>; compatible = "qcom,camera-flash"; flash-source = <&pm6150l_flash0 &pm6150l_flash1>; torch-source = <&pm6150l_torch0 &pm6150l_torch1>; switch-source = <&pm6150l_switch2 &pm6150l_switch2>; status = "ok"; }; }; &cam_cci0 { qcom,cam-res-mgr { compatible = "qcom,cam-res-mgr"; status = "ok"; }; actuator_rear: qcom,actuator@0 { cell-index = <0>; reg = <0x0>; compatible = "qcom,actuator"; cci-master = <0>; cam_vaf-supply = <&pm8009_s2>; regulator-names = "cam_vaf"; rgltr-cntrl-support; rgltr-min-voltage = <2900000>; rgltr-max-voltage = <2900000>; rgltr-load-current = <100000>; }; actuator_rear_aux: qcom,actuator@1 { cell-index = <1>; reg = <0x1>; compatible = "qcom,actuator"; cci-master = <1>; cam_vaf-supply = <&pm8009_s2>; regulator-names = "cam_vaf"; rgltr-cntrl-support; rgltr-min-voltage = <2900000>; rgltr-max-voltage = <2900000>; rgltr-load-current = <100000>; }; eeprom_rear: qcom,eeprom@0 { cell-index = <0>; reg = <0>; compatible = "qcom,eeprom"; actuator-src = <&actuator_rear>; cam_vio-supply = <&pm8009_l7>; cam_vana-supply = <&pm8009_l5>; cam_vdig-supply = <&pm8009_l4>; cam_clk-supply = <&titan_top_gdsc>; regulator-names = "cam_vio", "cam_vana", "cam_vdig", "cam_clk"; rgltr-cntrl-support; rgltr-min-voltage = <1800000 2850000 1100000 0>; rgltr-max-voltage = <1800000 2850000 1100000 0>; rgltr-load-current = <0 80000 105000 0>; gpio-no-mux = <0>; pinctrl-names = "cam_default", "cam_suspend"; pinctrl-0 = <&cam_sensor_mclk0_active &cam_sensor_rear_active>; pinctrl-1 = <&cam_sensor_mclk0_suspend &cam_sensor_rear_suspend>; gpios = <&tlmm 13 0>, <&pm8009_gpios 1 0>; gpio-reset = <1>; gpio-req-tbl-num = <0 1>; gpio-req-tbl-flags = <1 0>; gpio-req-tbl-label = "CAMIF_MCLK0", "CAM_RESET0"; sensor-mode = <0>; cci-master = <0>; status = "ok"; clocks = <&clock_camcc CAM_CC_MCLK0_CLK>; clock-names = "cam_clk"; clock-cntl-level = "turbo"; clock-rates = <24000000>; }; eeprom_rear_aux: qcom,eeprom@1 { cell-index = <1>; reg = <0x1>; compatible = "qcom,eeprom"; actuator-src = <&actuator_rear_aux>; cam_vio-supply = <&pm8009_l7>; cam_vana-supply = <&pm8009_l6>; cam_vdig-supply = <&pm8009_l4>; cam_clk-supply = <&titan_top_gdsc>; regulator-names = "cam_vio", "cam_vana", "cam_vdig", "cam_clk"; rgltr-cntrl-support; rgltr-min-voltage = <1800000 2800000 1200000 0>; rgltr-max-voltage = <1800000 2800000 1200000 0>; rgltr-load-current = <105000 0 80000 0>; gpio-no-mux = <0>; pinctrl-names = "cam_default", "cam_suspend"; pinctrl-0 = <&cam_sensor_mclk1_active &cam_sensor_rear2_active>; pinctrl-1 = <&cam_sensor_mclk1_suspend &cam_sensor_rear2_suspend>; gpios = <&tlmm 14 0>, <&pm8009_gpios 2 0>; gpio-reset = <1>; gpio-req-tbl-num = <0 1>; gpio-req-tbl-flags = <1 0>; gpio-req-tbl-label = "CAMIF_MCLK1", "CAM_RESET1"; sensor-position = <0>; sensor-mode = <0>; cci-master = <1>; status = "ok"; clock-names = "cam_clk"; clock-cntl-level = "turbo"; clock-rates = <24000000>; }; eeprom_front: qcom,eeprom@2 { cell-index = <2>; reg = <0x2>; compatible = "qcom,eeprom"; cam_vio-supply = <&pm8009_l7>; cam_vana-supply = <&pm8009_l6>; cam_vdig-supply = <&pm8009_l2>; cam_clk-supply = <&titan_top_gdsc>; regulator-names = "cam_vio", "cam_vana", "cam_vdig", "cam_clk"; rgltr-cntrl-support; rgltr-min-voltage = <1800000 2800000 1040000 0>; rgltr-max-voltage = <1800000 2800000 1040000 0>; rgltr-load-current = <0 80000 105000 0 0>; gpio-no-mux = <0>; pinctrl-names = "cam_default", "cam_suspend"; pinctrl-0 = <&cam_sensor_mclk2_active &cam_sensor_front_active>; pinctrl-1 = <&cam_sensor_mclk2_suspend &cam_sensor_front_suspend>; gpios = <&tlmm 15 0>, <&pm8009_gpios 4 0>; gpio-reset = <1>; gpio-req-tbl-num = <0 1>; gpio-req-tbl-flags = <1 0>; gpio-req-tbl-label = "CAMIF_MCLK2", "CAM_RESET2"; sensor-mode = <0>; cci-master = <1>; status = "ok"; clocks = <&clock_camcc CAM_CC_MCLK2_CLK>; clock-names = "cam_clk"; clock-cntl-level = "turbo"; clock-rates = <24000000>; }; qcom,cam-sensor@0 { cell-index = <0>; compatible = "qcom,cam-sensor"; reg = <0x0>; csiphy-sd-index = <0>; sensor-position-roll = <270>; sensor-position-pitch = <0>; sensor-position-yaw = <180>; led-flash-src = <&led_flash_rear>; eeprom-src = <&eeprom_rear>; actuator-src = <&actuator_rear>; cam_vio-supply = <&pm8009_l7>; cam_vana-supply = <&pm8009_l5>; cam_vdig-supply = <&pm8009_l4>; cam_clk-supply = <&titan_top_gdsc>; regulator-names = "cam_vio", "cam_vana", "cam_vdig", "cam_clk"; rgltr-cntrl-support; rgltr-min-voltage = <1800000 2850000 1100000 0>; rgltr-max-voltage = <1800000 2850000 1100000 0>; rgltr-load-current = <0 80000 105000 0>; gpio-no-mux = <0>; pinctrl-names = "cam_default", "cam_suspend"; pinctrl-0 = <&cam_sensor_mclk0_active &cam_sensor_rear_active>; pinctrl-1 = <&cam_sensor_mclk0_suspend &cam_sensor_rear_suspend>; gpios = <&tlmm 13 0>, <&pm8009_gpios 1 0>; gpio-reset = <1>; gpio-req-tbl-num = <0 1>; gpio-req-tbl-flags = <1 0>; gpio-req-tbl-label = "CAMIF_MCLK0", "CAM_RESET0"; sensor-mode = <0>; cci-master = <0>; status = "ok"; clocks = <&clock_camcc CAM_CC_MCLK0_CLK>; clock-names = "cam_clk"; clock-cntl-level = "turbo"; clock-rates = <24000000>; }; qcom,cam-sensor@1 { cell-index = <1>; compatible = "qcom,cam-sensor"; reg = <0x1>; csiphy-sd-index = <1>; sensor-position-roll = <270>; sensor-position-pitch = <0>; sensor-position-yaw = <180>; led-flash-src = <&led_flash_rear_aux>; eeprom-src = <&eeprom_rear_aux>; actuator-src = <&actuator_rear_aux>; cam_vio-supply = <&pm8009_l7>; cam_vana-supply = <&pm8009_l6>; cam_vdig-supply = <&pm8009_l4>; cam_clk-supply = <&titan_top_gdsc>; regulator-names = "cam_vio", "cam_vana", "cam_vdig", "cam_clk"; rgltr-cntrl-support; rgltr-min-voltage = <1800000 2800000 1200000 0>; rgltr-max-voltage = <1800000 2800000 1200000 0>; rgltr-load-current = <0 80000 105000 0>; gpio-no-mux = <0>; pinctrl-names = "cam_default", "cam_suspend"; pinctrl-0 = <&cam_sensor_mclk1_active &cam_sensor_rear2_active>; pinctrl-1 = <&cam_sensor_mclk1_suspend &cam_sensor_rear2_suspend>; gpios = <&tlmm 14 0>, <&pm8009_gpios 2 0>; gpio-reset = <1>; gpio-req-tbl-num = <0 1>; gpio-req-tbl-flags = <1 0>; gpio-req-tbl-label = "CAMIF_MCLK1", "CAM_RESET1"; sensor-mode = <0>; cci-master = <1>; status = "ok"; clocks = <&clock_camcc CAM_CC_MCLK1_CLK>; clock-names = "cam_clk"; clock-cntl-level = "turbo"; clock-rates = <24000000>; }; qcom,cam-sensor@2 { cell-index = <2>; compatible = "qcom,cam-sensor"; reg = <0x02>; csiphy-sd-index = <2>; sensor-position-roll = <270>; sensor-position-pitch = <0>; sensor-position-yaw = <0>; eeprom-src = <&eeprom_front>; cam_vio-supply = <&pm8009_l7>; cam_vana-supply = <&pm8009_l6>; cam_vdig-supply = <&pm8009_l2>; cam_clk-supply = <&titan_top_gdsc>; regulator-names = "cam_vio", "cam_vana", "cam_vdig", "cam_clk"; rgltr-cntrl-support; rgltr-min-voltage = <1800000 2800000 1040000 0>; rgltr-max-voltage = <1800000 2800000 1040000 0>; rgltr-load-current = <0 80000 105000 0>; gpio-no-mux = <0>; pinctrl-names = "cam_default", "cam_suspend"; pinctrl-0 = <&cam_sensor_mclk2_active &cam_sensor_front_active>; pinctrl-1 = <&cam_sensor_mclk2_suspend &cam_sensor_front_suspend>; gpios = <&tlmm 15 0>, <&pm8009_gpios 4 0>; gpio-reset = <1>; gpio-req-tbl-num = <0 1>; gpio-req-tbl-flags = <1 0>; gpio-req-tbl-label = "CAMIF_MCLK2", "CAM_RESET2"; sensor-mode = <0>; cci-device = <1>; cci-master = <0>; status = "ok"; clocks = <&clock_camcc CAM_CC_MCLK2_CLK>; clock-names = "cam_clk"; clock-cntl-level = "turbo"; clock-rates = <24000000>; }; }; &pm8009_gpios { cam_sensor_rear_active: cam_sensor_rear_active { pins = "gpio1"; function = "normal"; power-source = <0>; bias-disable; }; cam_sensor_rear_suspend: cam_sensor_rear_suspend { pins = "gpio1"; function = "normal"; power-source = <0>; bias-pull-down; }; cam_sensor_rear2_active: cam_sensor_rear2_active { pins = "gpio2"; function = "normal"; power-source = <0>; bias-disable; }; cam_sensor_rear2_suspend: cam_sensor_rear2_suspend { pins = "gpio2"; function = "normal"; power-source = <0>; bias-pull-down; }; cam_sensor_front_active: cam_sensor_front_active { pins = "gpio4"; function = "normal"; power-source = <0>; bias-disable; }; cam_sensor_front_suspend: cam_sensor_front_suspend { pins = "gpio4"; function = "normal"; power-source = <0>; bias-pull-down; }; }; arch/arm64/boot/dts/qcom/sdmmagpie-camera.dtsi +303 −0 Original line number Diff line number Diff line Loading @@ -17,6 +17,309 @@ status = "ok"; }; cam_csiphy0: qcom,csiphy@ace0000 { cell-index = <0>; compatible = "qcom,csiphy-v1.2", "qcom,csiphy"; reg = <0x0ace0000 0x2000>; reg-names = "csiphy"; reg-cam-base = <0xe0000>; interrupts = <0 477 0>; interrupt-names = "csiphy"; regulator-names = "gdscr", "refgen"; gdscr-supply = <&titan_top_gdsc>; refgen-supply = <&refgen>; csi-vdd-voltage = <1200000>; mipi-csi-vdd-supply = <&pm6150l_l3>; clocks = <&clock_camcc CAM_CC_CPHY_RX_CLK_SRC>, <&clock_camcc CAM_CC_CSIPHY0_CLK>, <&clock_camcc CAM_CC_CSI0PHYTIMER_CLK_SRC>, <&clock_camcc CAM_CC_CSI0PHYTIMER_CLK>; clock-names = "cphy_rx_clk_src", "csiphy0_clk", "csi0phytimer_clk_src", "csi0phytimer_clk"; src-clock-name = "csi0phytimer_clk_src"; clock-cntl-level = "svs_l1", "turbo"; clock-rates = <400000000 0 300000000 0>, <400000000 0 300000000 0>; status = "ok"; }; cam_csiphy1: qcom,csiphy@ace2000{ cell-index = <1>; compatible = "qcom,csiphy-v1.2", "qcom,csiphy"; reg = <0xace2000 0x2000>; reg-names = "csiphy"; reg-cam-base = <0xe2000>; interrupts = <0 478 0>; interrupt-names = "csiphy"; regulator-names = "gdscr", "refgen"; gdscr-supply = <&titan_top_gdsc>; refgen-supply = <&refgen>; csi-vdd-voltage = <1200000>; mipi-csi-vdd-supply = <&pm6150l_l3>; clocks = <&clock_camcc CAM_CC_CPHY_RX_CLK_SRC>, <&clock_camcc CAM_CC_CSIPHY1_CLK>, <&clock_camcc CAM_CC_CSI1PHYTIMER_CLK_SRC>, <&clock_camcc CAM_CC_CSI1PHYTIMER_CLK>; clock-names = "cphy_rx_clk_src", "csiphy1_clk", "csi1phytimer_clk_src", "csi1phytimer_clk"; src-clock-name = "csi1phytimer_clk_src"; clock-cntl-level = "svs_l1", "turbo"; clock-rates = <400000000 0 300000000 0>, <400000000 0 300000000 0>; status = "ok"; }; cam_csiphy2: qcom,csiphy@ace4000 { cell-index = <2>; compatible = "qcom,csiphy-v1.2", "qcom,csiphy"; reg = <0xace4000 0x2000>; reg-names = "csiphy"; reg-cam-base = <0xe4000>; interrupts = <0 479 0>; interrupt-names = "csiphy"; regulator-names = "gdscr", "refgen"; gdscr-supply = <&titan_top_gdsc>; refgen-supply = <&refgen>; csi-vdd-voltage = <1200000>; mipi-csi-vdd-supply = <&pm6150l_l3>; clocks = <&clock_camcc CAM_CC_CPHY_RX_CLK_SRC>, <&clock_camcc CAM_CC_CSIPHY2_CLK>, <&clock_camcc CAM_CC_CSI2PHYTIMER_CLK_SRC>, <&clock_camcc CAM_CC_CSI2PHYTIMER_CLK>; clock-names = "cphy_rx_clk_src", "csiphy2_clk", "csi2phytimer_clk_src", "csi2phytimer_clk"; src-clock-name = "csi2phytimer_clk_src"; clock-cntl-level = "svs_l1", "turbo"; clock-rates = <400000000 0 300000000 0>, <400000000 0 300000000 0>; status = "ok"; }; cam_csiphy3: qcom,csiphy@ace6000 { cell-index = <3>; compatible = "qcom,csiphy-v1.2", "qcom,csiphy"; reg = <0xace6000 0x2000>; reg-names = "csiphy"; reg-cam-base = <0xe6000>; interrupts = <0 607 0>; interrupt-names = "csiphy"; regulator-names = "gdscr", "refgen"; gdscr-supply = <&titan_top_gdsc>; refgen-supply = <&refgen>; csi-vdd-voltage = <1200000>; mipi-csi-vdd-supply = <&pm6150l_l3>; clocks = <&clock_camcc CAM_CC_CPHY_RX_CLK_SRC>, <&clock_camcc CAM_CC_CSIPHY2_CLK>, <&clock_camcc CAM_CC_CSI2PHYTIMER_CLK_SRC>, <&clock_camcc CAM_CC_CSI2PHYTIMER_CLK>; clock-names = "cphy_rx_clk_src", "csiphy3_clk", "csi3phytimer_clk_src", "csi3phytimer_clk"; src-clock-name = "csi3phytimer_clk_src"; clock-cntl-level = "svs_l1", "turbo"; clock-rates = <400000000 0 300000000 0>, <400000000 0 300000000 0>; status = "ok"; }; cam_cci0: qcom,cci@ac4a000 { cell-index = <0>; compatible = "qcom,cci"; #address-cells = <1>; #size-cells = <0>; reg = <0xac4a000 0x1000>; reg-names = "cci"; reg-cam-base = <0x4a000>; interrupt-names = "cci"; interrupts = <0 460 0>; status = "ok"; gdscr-supply = <&titan_top_gdsc>; regulator-names = "gdscr"; clocks = <&clock_camcc CAM_CC_CCI_0_CLK>, <&clock_camcc CAM_CC_CCI_0_CLK_SRC>; clock-names = "cci_0_clk", "cci_0_clk_src"; src-clock-name = "cci_0_clk_src"; clock-cntl-level = "lowsvs"; clock-rates = <0 37500000>; pinctrl-names = "cam_default", "cam_suspend"; pinctrl-0 = <&cci0_active &cci1_active>; pinctrl-1 = <&cci0_suspend &cci1_suspend>; gpios = <&tlmm 17 0>, <&tlmm 18 0>, <&tlmm 19 0>, <&tlmm 20 0>; gpio-req-tbl-num = <0 1 2 3>; gpio-req-tbl-flags = <1 1 1 1>; gpio-req-tbl-label = "CCI_I2C_DATA0", "CCI_I2C_CLK0", "CCI_I2C_DATA1", "CCI_I2C_CLK1"; i2c_freq_100Khz_cci0: qcom,i2c_standard_mode { hw-thigh = <201>; hw-tlow = <174>; hw-tsu-sto = <204>; hw-tsu-sta = <231>; hw-thd-dat = <22>; hw-thd-sta = <162>; hw-tbuf = <227>; hw-scl-stretch-en = <0>; hw-trdhld = <6>; hw-tsp = <3>; cci-clk-src = <37500000>; status = "ok"; }; i2c_freq_400Khz_cci0: qcom,i2c_fast_mode { hw-thigh = <38>; hw-tlow = <56>; hw-tsu-sto = <40>; hw-tsu-sta = <40>; hw-thd-dat = <22>; hw-thd-sta = <35>; hw-tbuf = <62>; hw-scl-stretch-en = <0>; hw-trdhld = <6>; hw-tsp = <3>; cci-clk-src = <37500000>; status = "ok"; }; i2c_freq_custom_cci0: qcom,i2c_custom_mode { hw-thigh = <38>; hw-tlow = <56>; hw-tsu-sto = <40>; hw-tsu-sta = <40>; hw-thd-dat = <22>; hw-thd-sta = <35>; hw-tbuf = <62>; hw-scl-stretch-en = <1>; hw-trdhld = <6>; hw-tsp = <3>; cci-clk-src = <37500000>; status = "ok"; }; i2c_freq_1Mhz_cci0: qcom,i2c_fast_plus_mode { hw-thigh = <16>; hw-tlow = <22>; hw-tsu-sto = <17>; hw-tsu-sta = <18>; hw-thd-dat = <16>; hw-thd-sta = <15>; hw-tbuf = <24>; hw-scl-stretch-en = <0>; hw-trdhld = <3>; hw-tsp = <3>; cci-clk-src = <37500000>; status = "ok"; }; }; cam_cci1: qcom,cci@ac4b000 { cell-index = <1>; compatible = "qcom,cci"; #address-cells = <1>; #size-cells = <0>; reg = <0xac4b000 0x1000>; reg-names = "cci"; reg-cam-base = <0x4b000>; interrupt-names = "cci"; interrupts = <0 461 0>; status = "ok"; gdscr-supply = <&titan_top_gdsc>; regulator-names = "gdscr"; clocks = <&clock_camcc CAM_CC_CCI_1_CLK>, <&clock_camcc CAM_CC_CCI_1_CLK_SRC>; clock-names = "cci_clk", "cci_1_clk_src"; src-clock-name = "cci_1_clk_src"; clock-cntl-level = "lowsvs"; clock-rates = <0 37500000>; pinctrl-names = "cam_default", "cam_suspend"; pinctrl-0 = <&cci2_active>; pinctrl-1 = <&cci2_suspend>; gpios = <&tlmm 27 0>, <&tlmm 28 0>; gpio-req-tbl-num = <0 1>; gpio-req-tbl-flags = <1 1>; gpio-req-tbl-label = "CCI_I2C_DATA2", "CCI_I2C_CLK2"; i2c_freq_100Khz_cci1: qcom,i2c_standard_mode { hw-thigh = <201>; hw-tlow = <174>; hw-tsu-sto = <204>; hw-tsu-sta = <231>; hw-thd-dat = <22>; hw-thd-sta = <162>; hw-tbuf = <227>; hw-scl-stretch-en = <0>; hw-trdhld = <6>; hw-tsp = <3>; cci-clk-src = <37500000>; status = "ok"; }; i2c_freq_400Khz_cci1: qcom,i2c_fast_mode { hw-thigh = <38>; hw-tlow = <56>; hw-tsu-sto = <40>; hw-tsu-sta = <40>; hw-thd-dat = <22>; hw-thd-sta = <35>; hw-tbuf = <62>; hw-scl-stretch-en = <0>; hw-trdhld = <6>; hw-tsp = <3>; cci-clk-src = <37500000>; status = "ok"; }; i2c_freq_custom_cci1: qcom,i2c_custom_mode { hw-thigh = <38>; hw-tlow = <56>; hw-tsu-sto = <40>; hw-tsu-sta = <40>; hw-thd-dat = <22>; hw-thd-sta = <35>; hw-tbuf = <62>; hw-scl-stretch-en = <1>; hw-trdhld = <6>; hw-tsp = <3>; cci-clk-src = <37500000>; status = "ok"; }; i2c_freq_1Mhz_cci1: qcom,i2c_fast_plus_mode { hw-thigh = <16>; hw-tlow = <22>; hw-tsu-sto = <17>; hw-tsu-sta = <18>; hw-thd-dat = <16>; hw-thd-sta = <15>; hw-tbuf = <24>; hw-scl-stretch-en = <0>; hw-trdhld = <3>; hw-tsp = <3>; cci-clk-src = <37500000>; status = "ok"; }; }; qcom,cam_smmu { compatible = "qcom,msm-cam-smmu"; status = "ok"; Loading arch/arm64/boot/dts/qcom/sdmmagpie-idp-overlay.dts +1 −0 Original line number Diff line number Diff line Loading @@ -14,6 +14,7 @@ /plugin/; #include <dt-bindings/interrupt-controller/arm-gic.h> #include <dt-bindings/clock/qcom,camcc-sdmmagpie.h> #include "sdmmagpie-idp.dtsi" #include "sdmmagpie-audio-overlay.dtsi" Loading arch/arm64/boot/dts/qcom/sdmmagpie-idp.dtsi +1 −0 Original line number Diff line number Diff line Loading @@ -16,6 +16,7 @@ #include <dt-bindings/iio/qcom,spmi-vadc.h> #include <dt-bindings/input/input.h> #include "sdmmagpie-sde-display.dtsi" #include "sdmmagpie-camera-sensor-idp.dtsi" &soc { }; Loading arch/arm64/boot/dts/qcom/sdmmagpie-pinctrl.dtsi +196 −0 Original line number Diff line number Diff line Loading @@ -1045,6 +1045,202 @@ }; }; cci0_active: cci0_active { mux { /* CLK, DATA */ pins = "gpio17","gpio18"; // Only 2 function = "cci_i2c"; }; config { pins = "gpio17","gpio18"; bias-pull-up; /* PULL UP*/ drive-strength = <2>; /* 2 MA */ }; }; cci0_suspend: cci0_suspend { mux { /* CLK, DATA */ pins = "gpio17","gpio18"; function = "cci_i2c"; }; config { pins = "gpio17","gpio18"; bias-pull-down; /* PULL DOWN */ drive-strength = <2>; /* 2 MA */ }; }; cci1_active: cci1_active { mux { /* CLK, DATA */ pins = "gpio19","gpio20"; function = "cci_i2c"; }; config { pins = "gpio19","gpio20"; bias-pull-up; /* PULL UP*/ drive-strength = <2>; /* 2 MA */ }; }; cci1_suspend: cci1_suspend { mux { /* CLK, DATA */ pins = "gpio19","gpio20"; function = "cci_i2c"; }; config { pins = "gpio19","gpio20"; bias-pull-down; /* PULL DOWN */ drive-strength = <2>; /* 2 MA */ }; }; cci2_active: cci2_active { mux { /* CLK, DATA */ pins = "gpio27","gpio28"; function = "cci_i2c"; }; config { pins = "gpio27","gpio28"; bias-pull-up; /* PULL UP*/ drive-strength = <2>; /* 2 MA */ }; }; cci2_suspend: cci2_suspend { mux { /* CLK, DATA */ pins = "gpio27","gpio28"; function = "cci_i2c"; }; config { pins = "gpio27","gpio28"; bias-pull-down; /* PULL DOWN */ drive-strength = <2>; /* 2 MA */ }; }; cam_sensor_mclk0_active: cam_sensor_mclk0_active { /* MCLK0 */ mux { pins = "gpio13"; function = "cam_mclk"; }; config { pins = "gpio13"; bias-disable; /* No PULL */ drive-strength = <2>; /* 2 MA */ }; }; cam_sensor_mclk0_suspend: cam_sensor_mclk0_suspend { /* MCLK0 */ mux { pins = "gpio13"; function = "cam_mclk"; }; config { pins = "gpio13"; bias-pull-down; /* PULL DOWN */ drive-strength = <2>; /* 2 MA */ }; }; cam_sensor_mclk1_active: cam_sensor_mclk1_active { /* MCLK1 */ mux { pins = "gpio14"; function = "cam_mclk"; }; config { pins = "gpio14"; bias-disable; /* No PULL */ drive-strength = <2>; /* 2 MA */ }; }; cam_sensor_mclk1_suspend: cam_sensor_mclk1_suspend { /* MCLK1 */ mux { pins = "gpio14"; function = "cam_mclk"; }; config { pins = "gpio14"; bias-pull-down; /* PULL DOWN */ drive-strength = <2>; /* 2 MA */ }; }; cam_sensor_mclk2_active: cam_sensor_mclk2_active { /* MCLK2 */ mux { pins = "gpio15"; function = "cam_mclk"; }; config { pins = "gpio15"; bias-disable; /* No PULL */ drive-strength = <2>; /* 2 MA */ }; }; cam_sensor_mclk2_suspend: cam_sensor_mclk2_suspend { /* MCLK2 */ mux { pins = "gpio15"; function = "cam_mclk"; }; config { pins = "gpio15"; bias-pull-down; /* PULL DOWN */ drive-strength = <2>; /* 2 MA */ }; }; cam_sensor_mclk3_active: cam_sensor_mclk3_active { /* MCLK3 */ mux { pins = "gpio16"; function = "cam_mclk"; }; config { pins = "gpio16"; bias-disable; /* No PULL */ drive-strength = <2>; /* 2 MA */ }; }; cam_sensor_mclk3_suspend: cam_sensor_mclk3_suspend { /* MCLK3 */ mux { pins = "gpio16"; function = "cam_mclk"; }; config { pins = "gpio16"; bias-pull-down; /* PULL DOWN */ drive-strength = <2>; /* 2 MA */ }; }; /* SDC pin type */ sdc1_clk_on: sdc1_clk_on { config { Loading Loading
arch/arm64/boot/dts/qcom/sdmmagpie-camera-sensor-idp.dtsi 0 → 100644 +349 −0 Original line number Diff line number Diff line /* * Copyright (c) 2018, The Linux Foundation. All rights reserved. * * This program is free software; you can redistribute it and/or modify * it under the terms of the GNU General Public License version 2 and * only version 2 as published by the Free Software Foundation. * * This program is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU General Public License for more details. */ #include <dt-bindings/clock/qcom,camcc-sdmmagpie.h> &soc { led_flash_rear: qcom,camera-flash@0 { cell-index = <0>; reg = <0x00 0x00>; compatible = "qcom,camera-flash"; flash-source = <&pm6150l_flash0 &pm6150l_flash1>; torch-source = <&pm6150l_torch0 &pm6150l_torch1>; switch-source = <&pm6150l_switch2 &pm6150l_switch2>; status = "ok"; }; led_flash_rear_aux: qcom,camera-flash@1 { cell-index = <1>; reg = <0x01 0x00>; compatible = "qcom,camera-flash"; flash-source = <&pm6150l_flash0 &pm6150l_flash1>; torch-source = <&pm6150l_torch0 &pm6150l_torch1>; switch-source = <&pm6150l_switch2 &pm6150l_switch2>; status = "ok"; }; }; &cam_cci0 { qcom,cam-res-mgr { compatible = "qcom,cam-res-mgr"; status = "ok"; }; actuator_rear: qcom,actuator@0 { cell-index = <0>; reg = <0x0>; compatible = "qcom,actuator"; cci-master = <0>; cam_vaf-supply = <&pm8009_s2>; regulator-names = "cam_vaf"; rgltr-cntrl-support; rgltr-min-voltage = <2900000>; rgltr-max-voltage = <2900000>; rgltr-load-current = <100000>; }; actuator_rear_aux: qcom,actuator@1 { cell-index = <1>; reg = <0x1>; compatible = "qcom,actuator"; cci-master = <1>; cam_vaf-supply = <&pm8009_s2>; regulator-names = "cam_vaf"; rgltr-cntrl-support; rgltr-min-voltage = <2900000>; rgltr-max-voltage = <2900000>; rgltr-load-current = <100000>; }; eeprom_rear: qcom,eeprom@0 { cell-index = <0>; reg = <0>; compatible = "qcom,eeprom"; actuator-src = <&actuator_rear>; cam_vio-supply = <&pm8009_l7>; cam_vana-supply = <&pm8009_l5>; cam_vdig-supply = <&pm8009_l4>; cam_clk-supply = <&titan_top_gdsc>; regulator-names = "cam_vio", "cam_vana", "cam_vdig", "cam_clk"; rgltr-cntrl-support; rgltr-min-voltage = <1800000 2850000 1100000 0>; rgltr-max-voltage = <1800000 2850000 1100000 0>; rgltr-load-current = <0 80000 105000 0>; gpio-no-mux = <0>; pinctrl-names = "cam_default", "cam_suspend"; pinctrl-0 = <&cam_sensor_mclk0_active &cam_sensor_rear_active>; pinctrl-1 = <&cam_sensor_mclk0_suspend &cam_sensor_rear_suspend>; gpios = <&tlmm 13 0>, <&pm8009_gpios 1 0>; gpio-reset = <1>; gpio-req-tbl-num = <0 1>; gpio-req-tbl-flags = <1 0>; gpio-req-tbl-label = "CAMIF_MCLK0", "CAM_RESET0"; sensor-mode = <0>; cci-master = <0>; status = "ok"; clocks = <&clock_camcc CAM_CC_MCLK0_CLK>; clock-names = "cam_clk"; clock-cntl-level = "turbo"; clock-rates = <24000000>; }; eeprom_rear_aux: qcom,eeprom@1 { cell-index = <1>; reg = <0x1>; compatible = "qcom,eeprom"; actuator-src = <&actuator_rear_aux>; cam_vio-supply = <&pm8009_l7>; cam_vana-supply = <&pm8009_l6>; cam_vdig-supply = <&pm8009_l4>; cam_clk-supply = <&titan_top_gdsc>; regulator-names = "cam_vio", "cam_vana", "cam_vdig", "cam_clk"; rgltr-cntrl-support; rgltr-min-voltage = <1800000 2800000 1200000 0>; rgltr-max-voltage = <1800000 2800000 1200000 0>; rgltr-load-current = <105000 0 80000 0>; gpio-no-mux = <0>; pinctrl-names = "cam_default", "cam_suspend"; pinctrl-0 = <&cam_sensor_mclk1_active &cam_sensor_rear2_active>; pinctrl-1 = <&cam_sensor_mclk1_suspend &cam_sensor_rear2_suspend>; gpios = <&tlmm 14 0>, <&pm8009_gpios 2 0>; gpio-reset = <1>; gpio-req-tbl-num = <0 1>; gpio-req-tbl-flags = <1 0>; gpio-req-tbl-label = "CAMIF_MCLK1", "CAM_RESET1"; sensor-position = <0>; sensor-mode = <0>; cci-master = <1>; status = "ok"; clock-names = "cam_clk"; clock-cntl-level = "turbo"; clock-rates = <24000000>; }; eeprom_front: qcom,eeprom@2 { cell-index = <2>; reg = <0x2>; compatible = "qcom,eeprom"; cam_vio-supply = <&pm8009_l7>; cam_vana-supply = <&pm8009_l6>; cam_vdig-supply = <&pm8009_l2>; cam_clk-supply = <&titan_top_gdsc>; regulator-names = "cam_vio", "cam_vana", "cam_vdig", "cam_clk"; rgltr-cntrl-support; rgltr-min-voltage = <1800000 2800000 1040000 0>; rgltr-max-voltage = <1800000 2800000 1040000 0>; rgltr-load-current = <0 80000 105000 0 0>; gpio-no-mux = <0>; pinctrl-names = "cam_default", "cam_suspend"; pinctrl-0 = <&cam_sensor_mclk2_active &cam_sensor_front_active>; pinctrl-1 = <&cam_sensor_mclk2_suspend &cam_sensor_front_suspend>; gpios = <&tlmm 15 0>, <&pm8009_gpios 4 0>; gpio-reset = <1>; gpio-req-tbl-num = <0 1>; gpio-req-tbl-flags = <1 0>; gpio-req-tbl-label = "CAMIF_MCLK2", "CAM_RESET2"; sensor-mode = <0>; cci-master = <1>; status = "ok"; clocks = <&clock_camcc CAM_CC_MCLK2_CLK>; clock-names = "cam_clk"; clock-cntl-level = "turbo"; clock-rates = <24000000>; }; qcom,cam-sensor@0 { cell-index = <0>; compatible = "qcom,cam-sensor"; reg = <0x0>; csiphy-sd-index = <0>; sensor-position-roll = <270>; sensor-position-pitch = <0>; sensor-position-yaw = <180>; led-flash-src = <&led_flash_rear>; eeprom-src = <&eeprom_rear>; actuator-src = <&actuator_rear>; cam_vio-supply = <&pm8009_l7>; cam_vana-supply = <&pm8009_l5>; cam_vdig-supply = <&pm8009_l4>; cam_clk-supply = <&titan_top_gdsc>; regulator-names = "cam_vio", "cam_vana", "cam_vdig", "cam_clk"; rgltr-cntrl-support; rgltr-min-voltage = <1800000 2850000 1100000 0>; rgltr-max-voltage = <1800000 2850000 1100000 0>; rgltr-load-current = <0 80000 105000 0>; gpio-no-mux = <0>; pinctrl-names = "cam_default", "cam_suspend"; pinctrl-0 = <&cam_sensor_mclk0_active &cam_sensor_rear_active>; pinctrl-1 = <&cam_sensor_mclk0_suspend &cam_sensor_rear_suspend>; gpios = <&tlmm 13 0>, <&pm8009_gpios 1 0>; gpio-reset = <1>; gpio-req-tbl-num = <0 1>; gpio-req-tbl-flags = <1 0>; gpio-req-tbl-label = "CAMIF_MCLK0", "CAM_RESET0"; sensor-mode = <0>; cci-master = <0>; status = "ok"; clocks = <&clock_camcc CAM_CC_MCLK0_CLK>; clock-names = "cam_clk"; clock-cntl-level = "turbo"; clock-rates = <24000000>; }; qcom,cam-sensor@1 { cell-index = <1>; compatible = "qcom,cam-sensor"; reg = <0x1>; csiphy-sd-index = <1>; sensor-position-roll = <270>; sensor-position-pitch = <0>; sensor-position-yaw = <180>; led-flash-src = <&led_flash_rear_aux>; eeprom-src = <&eeprom_rear_aux>; actuator-src = <&actuator_rear_aux>; cam_vio-supply = <&pm8009_l7>; cam_vana-supply = <&pm8009_l6>; cam_vdig-supply = <&pm8009_l4>; cam_clk-supply = <&titan_top_gdsc>; regulator-names = "cam_vio", "cam_vana", "cam_vdig", "cam_clk"; rgltr-cntrl-support; rgltr-min-voltage = <1800000 2800000 1200000 0>; rgltr-max-voltage = <1800000 2800000 1200000 0>; rgltr-load-current = <0 80000 105000 0>; gpio-no-mux = <0>; pinctrl-names = "cam_default", "cam_suspend"; pinctrl-0 = <&cam_sensor_mclk1_active &cam_sensor_rear2_active>; pinctrl-1 = <&cam_sensor_mclk1_suspend &cam_sensor_rear2_suspend>; gpios = <&tlmm 14 0>, <&pm8009_gpios 2 0>; gpio-reset = <1>; gpio-req-tbl-num = <0 1>; gpio-req-tbl-flags = <1 0>; gpio-req-tbl-label = "CAMIF_MCLK1", "CAM_RESET1"; sensor-mode = <0>; cci-master = <1>; status = "ok"; clocks = <&clock_camcc CAM_CC_MCLK1_CLK>; clock-names = "cam_clk"; clock-cntl-level = "turbo"; clock-rates = <24000000>; }; qcom,cam-sensor@2 { cell-index = <2>; compatible = "qcom,cam-sensor"; reg = <0x02>; csiphy-sd-index = <2>; sensor-position-roll = <270>; sensor-position-pitch = <0>; sensor-position-yaw = <0>; eeprom-src = <&eeprom_front>; cam_vio-supply = <&pm8009_l7>; cam_vana-supply = <&pm8009_l6>; cam_vdig-supply = <&pm8009_l2>; cam_clk-supply = <&titan_top_gdsc>; regulator-names = "cam_vio", "cam_vana", "cam_vdig", "cam_clk"; rgltr-cntrl-support; rgltr-min-voltage = <1800000 2800000 1040000 0>; rgltr-max-voltage = <1800000 2800000 1040000 0>; rgltr-load-current = <0 80000 105000 0>; gpio-no-mux = <0>; pinctrl-names = "cam_default", "cam_suspend"; pinctrl-0 = <&cam_sensor_mclk2_active &cam_sensor_front_active>; pinctrl-1 = <&cam_sensor_mclk2_suspend &cam_sensor_front_suspend>; gpios = <&tlmm 15 0>, <&pm8009_gpios 4 0>; gpio-reset = <1>; gpio-req-tbl-num = <0 1>; gpio-req-tbl-flags = <1 0>; gpio-req-tbl-label = "CAMIF_MCLK2", "CAM_RESET2"; sensor-mode = <0>; cci-device = <1>; cci-master = <0>; status = "ok"; clocks = <&clock_camcc CAM_CC_MCLK2_CLK>; clock-names = "cam_clk"; clock-cntl-level = "turbo"; clock-rates = <24000000>; }; }; &pm8009_gpios { cam_sensor_rear_active: cam_sensor_rear_active { pins = "gpio1"; function = "normal"; power-source = <0>; bias-disable; }; cam_sensor_rear_suspend: cam_sensor_rear_suspend { pins = "gpio1"; function = "normal"; power-source = <0>; bias-pull-down; }; cam_sensor_rear2_active: cam_sensor_rear2_active { pins = "gpio2"; function = "normal"; power-source = <0>; bias-disable; }; cam_sensor_rear2_suspend: cam_sensor_rear2_suspend { pins = "gpio2"; function = "normal"; power-source = <0>; bias-pull-down; }; cam_sensor_front_active: cam_sensor_front_active { pins = "gpio4"; function = "normal"; power-source = <0>; bias-disable; }; cam_sensor_front_suspend: cam_sensor_front_suspend { pins = "gpio4"; function = "normal"; power-source = <0>; bias-pull-down; }; };
arch/arm64/boot/dts/qcom/sdmmagpie-camera.dtsi +303 −0 Original line number Diff line number Diff line Loading @@ -17,6 +17,309 @@ status = "ok"; }; cam_csiphy0: qcom,csiphy@ace0000 { cell-index = <0>; compatible = "qcom,csiphy-v1.2", "qcom,csiphy"; reg = <0x0ace0000 0x2000>; reg-names = "csiphy"; reg-cam-base = <0xe0000>; interrupts = <0 477 0>; interrupt-names = "csiphy"; regulator-names = "gdscr", "refgen"; gdscr-supply = <&titan_top_gdsc>; refgen-supply = <&refgen>; csi-vdd-voltage = <1200000>; mipi-csi-vdd-supply = <&pm6150l_l3>; clocks = <&clock_camcc CAM_CC_CPHY_RX_CLK_SRC>, <&clock_camcc CAM_CC_CSIPHY0_CLK>, <&clock_camcc CAM_CC_CSI0PHYTIMER_CLK_SRC>, <&clock_camcc CAM_CC_CSI0PHYTIMER_CLK>; clock-names = "cphy_rx_clk_src", "csiphy0_clk", "csi0phytimer_clk_src", "csi0phytimer_clk"; src-clock-name = "csi0phytimer_clk_src"; clock-cntl-level = "svs_l1", "turbo"; clock-rates = <400000000 0 300000000 0>, <400000000 0 300000000 0>; status = "ok"; }; cam_csiphy1: qcom,csiphy@ace2000{ cell-index = <1>; compatible = "qcom,csiphy-v1.2", "qcom,csiphy"; reg = <0xace2000 0x2000>; reg-names = "csiphy"; reg-cam-base = <0xe2000>; interrupts = <0 478 0>; interrupt-names = "csiphy"; regulator-names = "gdscr", "refgen"; gdscr-supply = <&titan_top_gdsc>; refgen-supply = <&refgen>; csi-vdd-voltage = <1200000>; mipi-csi-vdd-supply = <&pm6150l_l3>; clocks = <&clock_camcc CAM_CC_CPHY_RX_CLK_SRC>, <&clock_camcc CAM_CC_CSIPHY1_CLK>, <&clock_camcc CAM_CC_CSI1PHYTIMER_CLK_SRC>, <&clock_camcc CAM_CC_CSI1PHYTIMER_CLK>; clock-names = "cphy_rx_clk_src", "csiphy1_clk", "csi1phytimer_clk_src", "csi1phytimer_clk"; src-clock-name = "csi1phytimer_clk_src"; clock-cntl-level = "svs_l1", "turbo"; clock-rates = <400000000 0 300000000 0>, <400000000 0 300000000 0>; status = "ok"; }; cam_csiphy2: qcom,csiphy@ace4000 { cell-index = <2>; compatible = "qcom,csiphy-v1.2", "qcom,csiphy"; reg = <0xace4000 0x2000>; reg-names = "csiphy"; reg-cam-base = <0xe4000>; interrupts = <0 479 0>; interrupt-names = "csiphy"; regulator-names = "gdscr", "refgen"; gdscr-supply = <&titan_top_gdsc>; refgen-supply = <&refgen>; csi-vdd-voltage = <1200000>; mipi-csi-vdd-supply = <&pm6150l_l3>; clocks = <&clock_camcc CAM_CC_CPHY_RX_CLK_SRC>, <&clock_camcc CAM_CC_CSIPHY2_CLK>, <&clock_camcc CAM_CC_CSI2PHYTIMER_CLK_SRC>, <&clock_camcc CAM_CC_CSI2PHYTIMER_CLK>; clock-names = "cphy_rx_clk_src", "csiphy2_clk", "csi2phytimer_clk_src", "csi2phytimer_clk"; src-clock-name = "csi2phytimer_clk_src"; clock-cntl-level = "svs_l1", "turbo"; clock-rates = <400000000 0 300000000 0>, <400000000 0 300000000 0>; status = "ok"; }; cam_csiphy3: qcom,csiphy@ace6000 { cell-index = <3>; compatible = "qcom,csiphy-v1.2", "qcom,csiphy"; reg = <0xace6000 0x2000>; reg-names = "csiphy"; reg-cam-base = <0xe6000>; interrupts = <0 607 0>; interrupt-names = "csiphy"; regulator-names = "gdscr", "refgen"; gdscr-supply = <&titan_top_gdsc>; refgen-supply = <&refgen>; csi-vdd-voltage = <1200000>; mipi-csi-vdd-supply = <&pm6150l_l3>; clocks = <&clock_camcc CAM_CC_CPHY_RX_CLK_SRC>, <&clock_camcc CAM_CC_CSIPHY2_CLK>, <&clock_camcc CAM_CC_CSI2PHYTIMER_CLK_SRC>, <&clock_camcc CAM_CC_CSI2PHYTIMER_CLK>; clock-names = "cphy_rx_clk_src", "csiphy3_clk", "csi3phytimer_clk_src", "csi3phytimer_clk"; src-clock-name = "csi3phytimer_clk_src"; clock-cntl-level = "svs_l1", "turbo"; clock-rates = <400000000 0 300000000 0>, <400000000 0 300000000 0>; status = "ok"; }; cam_cci0: qcom,cci@ac4a000 { cell-index = <0>; compatible = "qcom,cci"; #address-cells = <1>; #size-cells = <0>; reg = <0xac4a000 0x1000>; reg-names = "cci"; reg-cam-base = <0x4a000>; interrupt-names = "cci"; interrupts = <0 460 0>; status = "ok"; gdscr-supply = <&titan_top_gdsc>; regulator-names = "gdscr"; clocks = <&clock_camcc CAM_CC_CCI_0_CLK>, <&clock_camcc CAM_CC_CCI_0_CLK_SRC>; clock-names = "cci_0_clk", "cci_0_clk_src"; src-clock-name = "cci_0_clk_src"; clock-cntl-level = "lowsvs"; clock-rates = <0 37500000>; pinctrl-names = "cam_default", "cam_suspend"; pinctrl-0 = <&cci0_active &cci1_active>; pinctrl-1 = <&cci0_suspend &cci1_suspend>; gpios = <&tlmm 17 0>, <&tlmm 18 0>, <&tlmm 19 0>, <&tlmm 20 0>; gpio-req-tbl-num = <0 1 2 3>; gpio-req-tbl-flags = <1 1 1 1>; gpio-req-tbl-label = "CCI_I2C_DATA0", "CCI_I2C_CLK0", "CCI_I2C_DATA1", "CCI_I2C_CLK1"; i2c_freq_100Khz_cci0: qcom,i2c_standard_mode { hw-thigh = <201>; hw-tlow = <174>; hw-tsu-sto = <204>; hw-tsu-sta = <231>; hw-thd-dat = <22>; hw-thd-sta = <162>; hw-tbuf = <227>; hw-scl-stretch-en = <0>; hw-trdhld = <6>; hw-tsp = <3>; cci-clk-src = <37500000>; status = "ok"; }; i2c_freq_400Khz_cci0: qcom,i2c_fast_mode { hw-thigh = <38>; hw-tlow = <56>; hw-tsu-sto = <40>; hw-tsu-sta = <40>; hw-thd-dat = <22>; hw-thd-sta = <35>; hw-tbuf = <62>; hw-scl-stretch-en = <0>; hw-trdhld = <6>; hw-tsp = <3>; cci-clk-src = <37500000>; status = "ok"; }; i2c_freq_custom_cci0: qcom,i2c_custom_mode { hw-thigh = <38>; hw-tlow = <56>; hw-tsu-sto = <40>; hw-tsu-sta = <40>; hw-thd-dat = <22>; hw-thd-sta = <35>; hw-tbuf = <62>; hw-scl-stretch-en = <1>; hw-trdhld = <6>; hw-tsp = <3>; cci-clk-src = <37500000>; status = "ok"; }; i2c_freq_1Mhz_cci0: qcom,i2c_fast_plus_mode { hw-thigh = <16>; hw-tlow = <22>; hw-tsu-sto = <17>; hw-tsu-sta = <18>; hw-thd-dat = <16>; hw-thd-sta = <15>; hw-tbuf = <24>; hw-scl-stretch-en = <0>; hw-trdhld = <3>; hw-tsp = <3>; cci-clk-src = <37500000>; status = "ok"; }; }; cam_cci1: qcom,cci@ac4b000 { cell-index = <1>; compatible = "qcom,cci"; #address-cells = <1>; #size-cells = <0>; reg = <0xac4b000 0x1000>; reg-names = "cci"; reg-cam-base = <0x4b000>; interrupt-names = "cci"; interrupts = <0 461 0>; status = "ok"; gdscr-supply = <&titan_top_gdsc>; regulator-names = "gdscr"; clocks = <&clock_camcc CAM_CC_CCI_1_CLK>, <&clock_camcc CAM_CC_CCI_1_CLK_SRC>; clock-names = "cci_clk", "cci_1_clk_src"; src-clock-name = "cci_1_clk_src"; clock-cntl-level = "lowsvs"; clock-rates = <0 37500000>; pinctrl-names = "cam_default", "cam_suspend"; pinctrl-0 = <&cci2_active>; pinctrl-1 = <&cci2_suspend>; gpios = <&tlmm 27 0>, <&tlmm 28 0>; gpio-req-tbl-num = <0 1>; gpio-req-tbl-flags = <1 1>; gpio-req-tbl-label = "CCI_I2C_DATA2", "CCI_I2C_CLK2"; i2c_freq_100Khz_cci1: qcom,i2c_standard_mode { hw-thigh = <201>; hw-tlow = <174>; hw-tsu-sto = <204>; hw-tsu-sta = <231>; hw-thd-dat = <22>; hw-thd-sta = <162>; hw-tbuf = <227>; hw-scl-stretch-en = <0>; hw-trdhld = <6>; hw-tsp = <3>; cci-clk-src = <37500000>; status = "ok"; }; i2c_freq_400Khz_cci1: qcom,i2c_fast_mode { hw-thigh = <38>; hw-tlow = <56>; hw-tsu-sto = <40>; hw-tsu-sta = <40>; hw-thd-dat = <22>; hw-thd-sta = <35>; hw-tbuf = <62>; hw-scl-stretch-en = <0>; hw-trdhld = <6>; hw-tsp = <3>; cci-clk-src = <37500000>; status = "ok"; }; i2c_freq_custom_cci1: qcom,i2c_custom_mode { hw-thigh = <38>; hw-tlow = <56>; hw-tsu-sto = <40>; hw-tsu-sta = <40>; hw-thd-dat = <22>; hw-thd-sta = <35>; hw-tbuf = <62>; hw-scl-stretch-en = <1>; hw-trdhld = <6>; hw-tsp = <3>; cci-clk-src = <37500000>; status = "ok"; }; i2c_freq_1Mhz_cci1: qcom,i2c_fast_plus_mode { hw-thigh = <16>; hw-tlow = <22>; hw-tsu-sto = <17>; hw-tsu-sta = <18>; hw-thd-dat = <16>; hw-thd-sta = <15>; hw-tbuf = <24>; hw-scl-stretch-en = <0>; hw-trdhld = <3>; hw-tsp = <3>; cci-clk-src = <37500000>; status = "ok"; }; }; qcom,cam_smmu { compatible = "qcom,msm-cam-smmu"; status = "ok"; Loading
arch/arm64/boot/dts/qcom/sdmmagpie-idp-overlay.dts +1 −0 Original line number Diff line number Diff line Loading @@ -14,6 +14,7 @@ /plugin/; #include <dt-bindings/interrupt-controller/arm-gic.h> #include <dt-bindings/clock/qcom,camcc-sdmmagpie.h> #include "sdmmagpie-idp.dtsi" #include "sdmmagpie-audio-overlay.dtsi" Loading
arch/arm64/boot/dts/qcom/sdmmagpie-idp.dtsi +1 −0 Original line number Diff line number Diff line Loading @@ -16,6 +16,7 @@ #include <dt-bindings/iio/qcom,spmi-vadc.h> #include <dt-bindings/input/input.h> #include "sdmmagpie-sde-display.dtsi" #include "sdmmagpie-camera-sensor-idp.dtsi" &soc { }; Loading
arch/arm64/boot/dts/qcom/sdmmagpie-pinctrl.dtsi +196 −0 Original line number Diff line number Diff line Loading @@ -1045,6 +1045,202 @@ }; }; cci0_active: cci0_active { mux { /* CLK, DATA */ pins = "gpio17","gpio18"; // Only 2 function = "cci_i2c"; }; config { pins = "gpio17","gpio18"; bias-pull-up; /* PULL UP*/ drive-strength = <2>; /* 2 MA */ }; }; cci0_suspend: cci0_suspend { mux { /* CLK, DATA */ pins = "gpio17","gpio18"; function = "cci_i2c"; }; config { pins = "gpio17","gpio18"; bias-pull-down; /* PULL DOWN */ drive-strength = <2>; /* 2 MA */ }; }; cci1_active: cci1_active { mux { /* CLK, DATA */ pins = "gpio19","gpio20"; function = "cci_i2c"; }; config { pins = "gpio19","gpio20"; bias-pull-up; /* PULL UP*/ drive-strength = <2>; /* 2 MA */ }; }; cci1_suspend: cci1_suspend { mux { /* CLK, DATA */ pins = "gpio19","gpio20"; function = "cci_i2c"; }; config { pins = "gpio19","gpio20"; bias-pull-down; /* PULL DOWN */ drive-strength = <2>; /* 2 MA */ }; }; cci2_active: cci2_active { mux { /* CLK, DATA */ pins = "gpio27","gpio28"; function = "cci_i2c"; }; config { pins = "gpio27","gpio28"; bias-pull-up; /* PULL UP*/ drive-strength = <2>; /* 2 MA */ }; }; cci2_suspend: cci2_suspend { mux { /* CLK, DATA */ pins = "gpio27","gpio28"; function = "cci_i2c"; }; config { pins = "gpio27","gpio28"; bias-pull-down; /* PULL DOWN */ drive-strength = <2>; /* 2 MA */ }; }; cam_sensor_mclk0_active: cam_sensor_mclk0_active { /* MCLK0 */ mux { pins = "gpio13"; function = "cam_mclk"; }; config { pins = "gpio13"; bias-disable; /* No PULL */ drive-strength = <2>; /* 2 MA */ }; }; cam_sensor_mclk0_suspend: cam_sensor_mclk0_suspend { /* MCLK0 */ mux { pins = "gpio13"; function = "cam_mclk"; }; config { pins = "gpio13"; bias-pull-down; /* PULL DOWN */ drive-strength = <2>; /* 2 MA */ }; }; cam_sensor_mclk1_active: cam_sensor_mclk1_active { /* MCLK1 */ mux { pins = "gpio14"; function = "cam_mclk"; }; config { pins = "gpio14"; bias-disable; /* No PULL */ drive-strength = <2>; /* 2 MA */ }; }; cam_sensor_mclk1_suspend: cam_sensor_mclk1_suspend { /* MCLK1 */ mux { pins = "gpio14"; function = "cam_mclk"; }; config { pins = "gpio14"; bias-pull-down; /* PULL DOWN */ drive-strength = <2>; /* 2 MA */ }; }; cam_sensor_mclk2_active: cam_sensor_mclk2_active { /* MCLK2 */ mux { pins = "gpio15"; function = "cam_mclk"; }; config { pins = "gpio15"; bias-disable; /* No PULL */ drive-strength = <2>; /* 2 MA */ }; }; cam_sensor_mclk2_suspend: cam_sensor_mclk2_suspend { /* MCLK2 */ mux { pins = "gpio15"; function = "cam_mclk"; }; config { pins = "gpio15"; bias-pull-down; /* PULL DOWN */ drive-strength = <2>; /* 2 MA */ }; }; cam_sensor_mclk3_active: cam_sensor_mclk3_active { /* MCLK3 */ mux { pins = "gpio16"; function = "cam_mclk"; }; config { pins = "gpio16"; bias-disable; /* No PULL */ drive-strength = <2>; /* 2 MA */ }; }; cam_sensor_mclk3_suspend: cam_sensor_mclk3_suspend { /* MCLK3 */ mux { pins = "gpio16"; function = "cam_mclk"; }; config { pins = "gpio16"; bias-pull-down; /* PULL DOWN */ drive-strength = <2>; /* 2 MA */ }; }; /* SDC pin type */ sdc1_clk_on: sdc1_clk_on { config { Loading