1
0
mirror of https://github.com/physwizz/a155-U-u1.git synced 2025-09-05 12:50:27 +00:00
Files
a155-U-u1/kernel-5.10/arch/arm64/boot/dts/mediatek/cust_mt6873_camera.dtsi
physwizz 99537be4e2 first
2024-03-11 06:53:12 +11:00

634 lines
15 KiB
Plaintext

// SPDX-License-Identifier: GPL-2.0
/* Copyright (c) 2020 MediaTek Inc. */
/* CAMERA GPIO standardization */
&pio {
camera_pins_cam0_rst_0: cam0@0 {
pins_cmd_dat {
pinmux = <PINMUX_GPIO144__FUNC_GPIO144>;
slew-rate = <1>;
output-low;
};
};
camera_pins_cam0_rst_1: cam0@1 {
pins_cmd_dat {
pinmux = <PINMUX_GPIO144__FUNC_GPIO144>;
slew-rate = <1>;
output-high;
};
};
camera_pins_cam0_pnd_0: cam0@2 {
pins_cmd_dat {
pinmux = <PINMUX_GPIO147__FUNC_GPIO147>;
slew-rate = <1>;
output-low;
};
};
camera_pins_cam0_pnd_1: cam0@3 {
pins_cmd_dat {
pinmux = <PINMUX_GPIO147__FUNC_GPIO147>;
slew-rate = <1>;
output-high;
};
};
camera_pins_cam1_rst_0: cam1@0 {
pins_cmd_dat {
pinmux = <PINMUX_GPIO134__FUNC_GPIO134>;
slew-rate = <1>;
output-low;
};
};
camera_pins_cam1_rst_1: cam1@1 {
pins_cmd_dat {
pinmux = <PINMUX_GPIO134__FUNC_GPIO134>;
slew-rate = <1>;
output-high;
};
};
camera_pins_cam1_pnd_0: cam1@2 {
pins_cmd_dat {
pinmux = <PINMUX_GPIO133__FUNC_GPIO133>;
slew-rate = <1>;
output-low;
};
};
camera_pins_cam1_pnd_1: cam1@3 {
pins_cmd_dat {
pinmux = <PINMUX_GPIO133__FUNC_GPIO133>;
slew-rate = <1>;
output-high;
};
};
camera_pins_cam2_rst_0: cam2@0 {
pins_cmd_dat {
pinmux = <PINMUX_GPIO143__FUNC_GPIO143>;
slew-rate = <1>;
output-low;
};
};
camera_pins_cam2_rst_1: cam2@1 {
pins_cmd_dat {
pinmux = <PINMUX_GPIO143__FUNC_GPIO143>;
slew-rate = <1>;
output-high;
};
};
camera_pins_cam2_pnd_0: cam2@2 {
pins_cmd_dat {
pinmux = <PINMUX_GPIO146__FUNC_GPIO146>;
slew-rate = <1>;
output-low;
};
};
camera_pins_cam2_pnd_1: cam2@3 {
pins_cmd_dat {
pinmux = <PINMUX_GPIO146__FUNC_GPIO146>;
slew-rate = <1>;
output-high;
};
};
camera_pins_cam4_rst_0: cam4@0 {
pins_cmd_dat {
pinmux = <PINMUX_GPIO145__FUNC_GPIO145>;
slew-rate = <1>;
output-low;
};
};
camera_pins_cam4_rst_1: cam4@1 {
pins_cmd_dat {
pinmux = <PINMUX_GPIO145__FUNC_GPIO145>;
slew-rate = <1>;
output-high;
};
};
camera_pins_cam4_pnd_0: cam4@2 {
pins_cmd_dat {
pinmux = <PINMUX_GPIO148__FUNC_GPIO148>;
slew-rate = <1>;
output-low;
};
};
camera_pins_cam4_pnd_1: cam4@3 {
pins_cmd_dat {
pinmux = <PINMUX_GPIO148__FUNC_GPIO148>;
slew-rate = <1>;
output-high;
};
};
camera_pins_cam0_vcamd_0: cam0@vcam0 {
pins_cmd_dat {
pinmux = <PINMUX_GPIO138__FUNC_GPIO138>;
slew-rate = <1>;
output-low;
};
};
camera_pins_cam0_vcamd_1: cam0@vcam1 {
pins_cmd_dat {
pinmux = <PINMUX_GPIO138__FUNC_GPIO138>;
slew-rate = <1>;
output-high;
};
};
camera_pins_cam0_vcama_0: cam0@vcam2 {
pins_cmd_dat {
pinmux = <PINMUX_GPIO5__FUNC_GPIO5>;
slew-rate = <1>;
output-low;
};
};
camera_pins_cam0_vcama_1: cam0@vcam3 {
pins_cmd_dat {
pinmux = <PINMUX_GPIO5__FUNC_GPIO5>;
slew-rate = <1>;
output-high;
};
};
camera_pins_cam1_vcamd_0: cam1@vcam0 {
pins_cmd_dat {
pinmux = <PINMUX_GPIO8__FUNC_GPIO8>;
slew-rate = <1>;
output-low;
};
};
camera_pins_cam1_vcamd_1: cam1@vcam1 {
pins_cmd_dat {
pinmux = <PINMUX_GPIO8__FUNC_GPIO8>;
slew-rate = <1>;
output-high;
};
};
camera_pins_cam1_vcama_0: cam1@vcam2 {
pins_cmd_dat {
pinmux = <PINMUX_GPIO9__FUNC_GPIO9>;
slew-rate = <1>;
output-low;
};
};
camera_pins_cam1_vcama_1: cam1@vcam3 {
pins_cmd_dat {
pinmux = <PINMUX_GPIO9__FUNC_GPIO9>;
slew-rate = <1>;
output-high;
};
};
camera_pins_cam2_vcamd_0: cam2@vcam0 {
pins_cmd_dat {
pinmux = <PINMUX_GPIO135__FUNC_GPIO135>;
slew-rate = <1>;
output-low;
};
};
camera_pins_cam2_vcamd_1: cam2@vcam1 {
pins_cmd_dat {
pinmux = <PINMUX_GPIO135__FUNC_GPIO135>;
slew-rate = <1>;
output-high;
};
};
camera_pins_cam2_vcama_0: cam2@vcam2 {
pins_cmd_dat {
pinmux = <PINMUX_GPIO137__FUNC_GPIO137>;
slew-rate = <1>;
output-low;
};
};
camera_pins_cam2_vcama_1: cam2@vcam3 {
pins_cmd_dat {
pinmux = <PINMUX_GPIO137__FUNC_GPIO137>;
slew-rate = <1>;
output-high;
};
};
camera_pins_cam4_vcamd_0: cam4@vcam0 {
pins_cmd_dat {
pinmux = <PINMUX_GPIO6__FUNC_GPIO6>;
slew-rate = <1>;
output-low;
};
};
camera_pins_cam4_vcamd_1: cam4@vcam1 {
pins_cmd_dat {
pinmux = <PINMUX_GPIO6__FUNC_GPIO6>;
slew-rate = <1>;
output-high;
};
};
camera_pins_cam4_vcama_0: cam4@vcam2 {
pins_cmd_dat {
pinmux = <PINMUX_GPIO7__FUNC_GPIO7>;
slew-rate = <1>;
output-low;
};
};
camera_pins_cam4_vcama_1: cam4@vcam3 {
pins_cmd_dat {
pinmux = <PINMUX_GPIO7__FUNC_GPIO7>;
slew-rate = <1>;
output-high;
};
};
camera_pins_cam0_mclk_off: camera_pins_cam0_mclk_off {
pins_cmd_dat {
pinmux = <PINMUX_GPIO150__FUNC_GPIO150>;
drive-strength = <1>;
};
};
camera_pins_cam0_mclk_2ma: camera_pins_cam0_mclk_2ma {
pins_cmd_dat {
pinmux = <PINMUX_GPIO150__FUNC_CMMCLK1>;
drive-strength = <0>;
};
};
camera_pins_cam0_mclk_4ma: camera_pins_cam0_mclk_4ma {
pins_cmd_dat {
pinmux = <PINMUX_GPIO150__FUNC_CMMCLK1>;
drive-strength = <1>;
};
};
camera_pins_cam0_mclk_6ma: camera_pins_cam0_mclk_6ma {
pins_cmd_dat {
pinmux = <PINMUX_GPIO150__FUNC_CMMCLK1>;
drive-strength = <2>;
};
};
camera_pins_cam0_mclk_8ma: camera_pins_cam0_mclk_8ma {
pins_cmd_dat {
pinmux = <PINMUX_GPIO150__FUNC_CMMCLK1>;
drive-strength = <3>;
};
};
camera_pins_cam1_mclk_off: camera_pins_cam1_mclk_off {
pins_cmd_dat {
pinmux = <PINMUX_GPIO136__FUNC_GPIO136>;
drive-strength = <1>;
};
};
camera_pins_cam1_mclk_2ma: camera_pins_cam1_mclk_2ma {
pins_cmd_dat {
pinmux = <PINMUX_GPIO136__FUNC_CMMCLK3>;
drive-strength = <0>;
};
};
camera_pins_cam1_mclk_4ma: camera_pins_cam1_mclk_4ma {
pins_cmd_dat {
pinmux = <PINMUX_GPIO136__FUNC_CMMCLK3>;
drive-strength = <1>;
};
};
camera_pins_cam1_mclk_6ma: camera_pins_cam1_mclk_6ma {
pins_cmd_dat {
pinmux = <PINMUX_GPIO136__FUNC_CMMCLK3>;
drive-strength = <2>;
};
};
camera_pins_cam1_mclk_8ma: camera_pins_cam1_mclk_8ma {
pins_cmd_dat {
pinmux = <PINMUX_GPIO136__FUNC_CMMCLK3>;
drive-strength = <3>;
};
};
camera_pins_cam2_mclk_off: camera_pins_cam2_mclk_off {
pins_cmd_dat {
pinmux = <PINMUX_GPIO149__FUNC_GPIO149>;
drive-strength = <1>;
};
};
camera_pins_cam2_mclk_2ma: camera_pins_cam2_mclk_2ma {
pins_cmd_dat {
pinmux = <PINMUX_GPIO149__FUNC_CMMCLK0>;
drive-strength = <0>;
};
};
camera_pins_cam2_mclk_4ma: camera_pins_cam2_mclk_4ma {
pins_cmd_dat {
pinmux = <PINMUX_GPIO149__FUNC_CMMCLK0>;
drive-strength = <1>;
};
};
camera_pins_cam2_mclk_6ma: camera_pins_cam2_mclk_6ma {
pins_cmd_dat {
pinmux = <PINMUX_GPIO149__FUNC_CMMCLK0>;
drive-strength = <2>;
};
};
camera_pins_cam2_mclk_8ma: camera_pins_cam2_mclk_8ma {
pins_cmd_dat {
pinmux = <PINMUX_GPIO149__FUNC_CMMCLK0>;
drive-strength = <3>;
};
};
camera_pins_cam4_mclk_off: camera_pins_cam4_mclk_off {
pins_cmd_dat {
pinmux = <PINMUX_GPIO151__FUNC_GPIO151>;
drive-strength = <1>;
};
};
camera_pins_cam4_mclk_2ma: camera_pins_cam4_mclk_2ma {
pins_cmd_dat {
pinmux = <PINMUX_GPIO151__FUNC_CMMCLK2>;
drive-strength = <0>;
};
};
camera_pins_cam4_mclk_4ma: camera_pins_cam4_mclk_4ma {
pins_cmd_dat {
pinmux = <PINMUX_GPIO151__FUNC_CMMCLK2>;
drive-strength = <1>;
};
};
camera_pins_cam4_mclk_6ma: camera_pins_cam4_mclk_6ma {
pins_cmd_dat {
pinmux = <PINMUX_GPIO151__FUNC_CMMCLK2>;
drive-strength = <2>;
};
};
camera_pins_cam4_mclk_8ma: camera_pins_cam4_mclk_8ma {
pins_cmd_dat {
pinmux = <PINMUX_GPIO151__FUNC_CMMCLK2>;
drive-strength = <3>;
};
};
camera_pins_cam_mipi_switch_en_1: mipi_en@1 {
pins_cmd_dat {
pinmux = <PINMUX_GPIO170__FUNC_GPIO170>;
slew-rate = <1>;
output-high;
};
};
camera_pins_cam_mipi_switch_en_0: mipi_en@0 {
pins_cmd_dat {
pinmux = <PINMUX_GPIO170__FUNC_GPIO170>;
slew-rate = <1>;
output-low;
};
};
camera_pins_cam_mipi_switch_sel_1: mipi_sel@1 {
pins_cmd_dat {
pinmux = <PINMUX_GPIO171__FUNC_GPIO171>;
slew-rate = <1>;
output-high;
};
};
camera_pins_cam_mipi_switch_sel_0: mipi_sel@0 {
pins_cmd_dat {
pinmux = <PINMUX_GPIO171__FUNC_GPIO171>;
slew-rate = <1>;
output-low;
};
};
camera_pins_default: camdefault {
};
};
&kd_camera_hw1 {
pinctrl-names = "default",
"cam0_rst0", "cam0_rst1",
"cam0_pnd0", "cam0_pnd1",
"cam1_rst0", "cam1_rst1",
"cam1_pnd0", "cam1_pnd1",
"cam2_rst0", "cam2_rst1",
"cam2_pnd0", "cam2_pnd1",
"cam4_rst0", "cam4_rst1",
"cam4_pnd0", "cam4_pnd1",
"cam0_ldo_vcamd_0", "cam0_ldo_vcamd_1",
"cam0_ldo_vcama_0", "cam0_ldo_vcama_1",
"cam1_ldo_vcamd_0", "cam1_ldo_vcamd_1",
"cam1_ldo_vcama_0", "cam1_ldo_vcama_1",
"cam2_ldo_vcamd_0", "cam2_ldo_vcamd_1",
"cam2_ldo_vcama_0", "cam2_ldo_vcama_1",
"cam4_ldo_vcamd_0", "cam4_ldo_vcamd_1",
"cam4_ldo_vcama_0", "cam4_ldo_vcama_1",
"cam0_mclk_off",
"cam0_mclk_2mA", "cam0_mclk_4mA",
"cam0_mclk_6mA", "cam0_mclk_8mA",
"cam1_mclk_off",
"cam1_mclk_2mA", "cam1_mclk_4mA",
"cam1_mclk_6mA", "cam1_mclk_8mA",
"cam2_mclk_off",
"cam2_mclk_2mA", "cam2_mclk_4mA",
"cam2_mclk_6mA", "cam2_mclk_8mA",
"cam4_mclk_off",
"cam4_mclk_2mA", "cam4_mclk_4mA",
"cam4_mclk_6mA", "cam4_mclk_8mA",
"cam_mipi_switch_en_1", "cam_mipi_switch_en_0",
"cam_mipi_switch_sel_1", "cam_mipi_switch_sel_0";
pinctrl-0 = <&camera_pins_default>;
pinctrl-1 = <&camera_pins_cam0_rst_0>;
pinctrl-2 = <&camera_pins_cam0_rst_1>;
pinctrl-3 = <&camera_pins_cam0_pnd_0>;
pinctrl-4 = <&camera_pins_cam0_pnd_1>;
pinctrl-5 = <&camera_pins_cam1_rst_0>;
pinctrl-6 = <&camera_pins_cam1_rst_1>;
pinctrl-7 = <&camera_pins_cam1_pnd_0>;
pinctrl-8 = <&camera_pins_cam1_pnd_1>;
pinctrl-9 = <&camera_pins_cam2_rst_0>;
pinctrl-10 = <&camera_pins_cam2_rst_1>;
pinctrl-11 = <&camera_pins_cam2_pnd_0>;
pinctrl-12 = <&camera_pins_cam2_pnd_1>;
pinctrl-13 = <&camera_pins_cam4_rst_0>;
pinctrl-14 = <&camera_pins_cam4_rst_1>;
pinctrl-15 = <&camera_pins_cam4_pnd_0>;
pinctrl-16 = <&camera_pins_cam4_pnd_1>;
pinctrl-17 = <&camera_pins_cam0_vcamd_0>;
pinctrl-18 = <&camera_pins_cam0_vcamd_1>;
pinctrl-19 = <&camera_pins_cam0_vcama_0>;
pinctrl-20 = <&camera_pins_cam0_vcama_1>;
pinctrl-21 = <&camera_pins_cam1_vcamd_0>;
pinctrl-22 = <&camera_pins_cam1_vcamd_1>;
pinctrl-23 = <&camera_pins_cam1_vcama_0>;
pinctrl-24 = <&camera_pins_cam1_vcama_1>;
pinctrl-25 = <&camera_pins_cam2_vcamd_0>;
pinctrl-26 = <&camera_pins_cam2_vcamd_1>;
pinctrl-27 = <&camera_pins_cam2_vcama_0>;
pinctrl-28 = <&camera_pins_cam2_vcama_1>;
pinctrl-29 = <&camera_pins_cam4_vcamd_0>;
pinctrl-30 = <&camera_pins_cam4_vcamd_1>;
pinctrl-31 = <&camera_pins_cam4_vcama_0>;
pinctrl-32 = <&camera_pins_cam4_vcama_1>;
pinctrl-33 = <&camera_pins_cam0_mclk_off>;
pinctrl-34 = <&camera_pins_cam0_mclk_2ma>;
pinctrl-35 = <&camera_pins_cam0_mclk_4ma>;
pinctrl-36 = <&camera_pins_cam0_mclk_6ma>;
pinctrl-37 = <&camera_pins_cam0_mclk_8ma>;
pinctrl-38 = <&camera_pins_cam1_mclk_off>;
pinctrl-39 = <&camera_pins_cam1_mclk_2ma>;
pinctrl-40 = <&camera_pins_cam1_mclk_4ma>;
pinctrl-41 = <&camera_pins_cam1_mclk_6ma>;
pinctrl-42 = <&camera_pins_cam1_mclk_8ma>;
pinctrl-43 = <&camera_pins_cam2_mclk_off>;
pinctrl-44 = <&camera_pins_cam2_mclk_2ma>;
pinctrl-45 = <&camera_pins_cam2_mclk_4ma>;
pinctrl-46 = <&camera_pins_cam2_mclk_6ma>;
pinctrl-47 = <&camera_pins_cam2_mclk_8ma>;
pinctrl-48 = <&camera_pins_cam4_mclk_off>;
pinctrl-49 = <&camera_pins_cam4_mclk_2ma>;
pinctrl-50 = <&camera_pins_cam4_mclk_4ma>;
pinctrl-51 = <&camera_pins_cam4_mclk_6ma>;
pinctrl-52 = <&camera_pins_cam4_mclk_8ma>;
pinctrl-53 = <&camera_pins_cam_mipi_switch_en_1>;
pinctrl-54 = <&camera_pins_cam_mipi_switch_en_0>;
pinctrl-55 = <&camera_pins_cam_mipi_switch_sel_1>;
pinctrl-56 = <&camera_pins_cam_mipi_switch_sel_0>;
cam0_vcamio-supply = <&mt6359p_vcamio_reg>;
cam1_vcamio-supply = <&mt6359p_vcamio_reg>;
cam2_vcamio-supply = <&mt6359p_vcamio_reg>;
cam4_vcamio-supply = <&mt6359p_vcamio_reg>;
status = "okay";
};
/* CAMERA GPIO end */
/* CAMERA EEPROM */
&i2c2 {
status = "okay";
clock-frequency = <400000>;
#address-cells = <1>;
#size-cells = <0>;
mtk_camera_eeprom2:camera_eeprom2@50 {
compatible = "mediatek,camera_eeprom";
reg = <0x50>;
status = "okay";
};
camera_main_two_mtk:camera_main_two@10 {
compatible = "mediatek,camera_main_two";
#thermal-sensor-cells = <0>;
reg = <0x10>;
status = "okay";
};
};
&i2c4 {
status = "okay";
clock-frequency = <400000>;
#address-cells = <1>;
#size-cells = <0>;
mtk_camera_eeprom1:camera_eeprom1@51 {
compatible = "mediatek,camera_eeprom";
reg = <0x51>;
status = "okay";
};
camera_sub_mtk:camera_sub@1a {
compatible = "mediatek,camera_sub";
#thermal-sensor-cells = <0>;
reg = <0x1a>;
status = "okay";
};
};
&i2c8 {
status = "okay";
clock-frequency = <400000>;
#address-cells = <1>;
#size-cells = <0>;
mtk_camera_eeprom0:camera_eeprom0@50 {
compatible = "mediatek,camera_eeprom";
reg = <0x50>;
status = "okay";
};
camera_main_mtk:camera_main@1a {
compatible = "mediatek,camera_main";
#thermal-sensor-cells = <0>;
reg = <0x1a>;
status = "okay";
};
};
&i2c9 {
status = "okay";
clock-frequency = <400000>;
#address-cells = <1>;
#size-cells = <0>;
mtk_camera_eeprom4:camera_eeprom4@51 {
compatible = "mediatek,camera_eeprom";
reg = <0x51>;
status = "okay";
};
camera_main_three_mtk:camera_main_three@10 {
compatible = "mediatek,camera_main_three";
#thermal-sensor-cells = <0>;
reg = <0x10>;
status = "okay";
};
};
/* CAMERA EEPROM end */
/* CAMERA AF */
&i2c2 {
camera_main_two_af_mtk:camera_main_two_af@0c {
compatible = "mediatek,camera_main_two_af";
reg = <0x0c>;
status = "okay";
};
};
&i2c8 {
camera_main_af_mtk:camera_main_af@72 {
compatible = "mediatek,camera_main_af";
reg = <0x72>;
status = "okay";
};
};
&i2c9 {
camera_main_three_af_mtk:camera_main_three_af@0c {
compatible = "mediatek,camera_main_three_af";
reg = <0x0c>;
status = "okay";
};
};
/* CAMERA AF end */
/* CAMERA TZ config */
&thermal_zones {
camera_main: camera_main {
polling-delay = <1000>; /* milliseconds */
polling-delay-passive = <0>; /* milliseconds */
thermal-sensors = <&camera_main_mtk>;
trips {
cam_main_crit: cam_main_crit@0 {
temperature = <120000>;
hysteresis = <2000>;
type = "critical";
};
};
};
camera_sub: camera_sub {
polling-delay = <1000>; /* milliseconds */
polling-delay-passive = <0>; /* milliseconds */
thermal-sensors = <&camera_sub_mtk>;
trips {
cam_sub_crit: cam_sub_crit@0 {
temperature = <120000>;
hysteresis = <2000>;
type = "critical";
};
};
};
camera_main2: camera_main2 {
polling-delay = <1000>; /* milliseconds */
polling-delay-passive = <0>; /* milliseconds */
thermal-sensors = <&camera_main_two_mtk>;
trips {
cam_main2_crit: cam_main2_crit@0 {
temperature = <120000>;
hysteresis = <2000>;
type = "critical";
};
};
};
camera_main3: camera_main3 {
polling-delay = <1000>; /* milliseconds */
polling-delay-passive = <0>; /* milliseconds */
thermal-sensors = <&camera_main_three_mtk>;
trips {
cam_main3_crit: cam_main3_crit@0 {
temperature = <120000>;
hysteresis = <2000>;
type = "critical";
};
};
};
};
/* CAMERA TZ config end */