388 lines
		
	
	
		
			8.6 KiB
		
	
	
	
		
			Plaintext
		
	
	
	
	
	
			
		
		
	
	
			388 lines
		
	
	
		
			8.6 KiB
		
	
	
	
		
			Plaintext
		
	
	
	
	
	
| // SPDX-License-Identifier: (GPL-2.0+ OR MIT)
 | |
| /*
 | |
|  * Copyright (c) 2023 Rockchip Electronics Co., Ltd.
 | |
|  *
 | |
|  */
 | |
| 
 | |
| &csi2_dphy_hw {
 | |
| 	status = "okay";
 | |
| };
 | |
| 
 | |
| &csi2_dphy0 {
 | |
| 	status = "okay";
 | |
| 
 | |
| 	ports {
 | |
| 		#address-cells = <1>;
 | |
| 		#size-cells = <0>;
 | |
| 
 | |
| 		port@0 {
 | |
| 			reg = <0>;
 | |
| 			#address-cells = <1>;
 | |
| 			#size-cells = <0>;
 | |
| 
 | |
| 			csi_dphy_input0: endpoint@0 {
 | |
| 				reg = <0>;
 | |
| 				remote-endpoint = <&sc530ai_out>;
 | |
| 				data-lanes = <1 2>;
 | |
| 			};
 | |
| 			csi_dphy_input1: endpoint@1 {
 | |
| 				reg = <1>;
 | |
| 				remote-endpoint = <&sc3336_out>;
 | |
| 				data-lanes = <1 2>;
 | |
| 			};
 | |
| 			csi_dphy_input2: endpoint@2 {
 | |
| 				reg = <2>;
 | |
| 				remote-endpoint = <&sc4336_out>;
 | |
| 				data-lanes = <1 2>;
 | |
| 			};
 | |
| 			csi_dphy_input3: endpoint@3 {
 | |
| 				reg = <3>;
 | |
| 				remote-endpoint = <&os04a10_out>;
 | |
| 				data-lanes = <1 2>;
 | |
| 			};
 | |
| 			csi_dphy_input4: endpoint@4 {
 | |
| 				reg = <4>;
 | |
| 				remote-endpoint = <&jx_k17_out>;
 | |
| 				data-lanes = <1 2>;
 | |
| 			};
 | |
| 			csi_dphy_input5: endpoint@5 {
 | |
| 				reg = <5>;
 | |
| 				remote-endpoint = <&sc3338_out>;
 | |
| 				data-lanes = <1 2>;
 | |
| 			};
 | |
| 			csi_dphy_input6: endpoint@6 {
 | |
| 				reg = <6>;
 | |
| 				remote-endpoint = <&imx415_out>;
 | |
| 				data-lanes = <1 2>;
 | |
| 			};
 | |
| 			csi_dphy_input7: endpoint@7 {
 | |
| 				reg = <7>;
 | |
| 				remote-endpoint = <&sc450ai_out>;
 | |
| 				data-lanes = <1 2>;
 | |
| 			};
 | |
| 			csi_dphy_input8: endpoint@8 {
 | |
| 				reg = <8>;
 | |
| 				remote-endpoint = <&sc401ai_out>;
 | |
| 				data-lanes = <1 2>;
 | |
| 			};
 | |
| 			csi_dphy_input9: endpoint@9 {
 | |
| 				reg = <9>;
 | |
| 				remote-endpoint = <&sc200ai_out>;
 | |
| 				data-lanes = <1 2>;
 | |
| 			};
 | |
| 		};
 | |
| 
 | |
| 		port@1 {
 | |
| 			reg = <1>;
 | |
| 			#address-cells = <1>;
 | |
| 			#size-cells = <0>;
 | |
| 
 | |
| 			csi_dphy_output: endpoint@0 {
 | |
| 				reg = <0>;
 | |
| 				remote-endpoint = <&mipi_csi2_input>;
 | |
| 			};
 | |
| 		};
 | |
| 	};
 | |
| };
 | |
| 
 | |
| &i2c4 {
 | |
| 	status = "okay";
 | |
| 	clock-frequency = <400000>;
 | |
| 	pinctrl-names = "default";
 | |
| 	pinctrl-0 = <&i2c4m2_xfer>;
 | |
| 
 | |
| 	sc530ai: sc530ai@30 {
 | |
| 		compatible = "smartsens,sc530ai";
 | |
| 		status = "okay";
 | |
| 		reg = <0x30>;
 | |
| 		clocks = <&cru MCLK_REF_MIPI0>;
 | |
| 		clock-names = "xvclk";
 | |
| 		reset-gpios = <&gpio3 RK_PC5 GPIO_ACTIVE_HIGH>;
 | |
| 		pwdn-gpios = <&gpio3 RK_PD2 GPIO_ACTIVE_HIGH>;
 | |
| 		pinctrl-names = "default";
 | |
| 		pinctrl-0 = <&mipi_refclk_out0>;
 | |
| 		rockchip,camera-module-index = <0>;
 | |
| 		rockchip,camera-module-facing = "back";
 | |
| 		rockchip,camera-module-name = "CMK-OT2115-PC1";
 | |
| 		rockchip,camera-module-lens-name = "30IRC-F16";
 | |
| 		port {
 | |
| 			sc530ai_out: endpoint {
 | |
| 				remote-endpoint = <&csi_dphy_input0>;
 | |
| 				data-lanes = <1 2>;
 | |
| 			};
 | |
| 		};
 | |
| 	};
 | |
| 
 | |
| 	sc3336: sc3336@30 {
 | |
| 		compatible = "smartsens,sc3336";
 | |
| 		status = "okay";
 | |
| 		reg = <0x30>;
 | |
| 		clocks = <&cru MCLK_REF_MIPI0>;
 | |
| 		clock-names = "xvclk";
 | |
| 		reset-gpios = <&gpio3 RK_PC5 GPIO_ACTIVE_HIGH>;
 | |
| 		pwdn-gpios = <&gpio3 RK_PD2 GPIO_ACTIVE_HIGH>;
 | |
| 		pinctrl-names = "default";
 | |
| 		pinctrl-0 = <&mipi_refclk_out0>;
 | |
| 		rockchip,camera-module-index = <0>;
 | |
| 		rockchip,camera-module-facing = "back";
 | |
| 		rockchip,camera-module-name = "CMK-OT2119-PC1";
 | |
| 		rockchip,camera-module-lens-name = "30IRC-F16";
 | |
| 		port {
 | |
| 			sc3336_out: endpoint {
 | |
| 				remote-endpoint = <&csi_dphy_input1>;
 | |
| 				data-lanes = <1 2>;
 | |
| 			};
 | |
| 		};
 | |
| 	};
 | |
| 
 | |
| 	sc3338: sc3338@30 {
 | |
| 		compatible = "smartsens,sc3338";
 | |
| 		status = "okay";
 | |
| 		reg = <0x30>;
 | |
| 		clocks = <&cru MCLK_REF_MIPI0>;
 | |
| 		clock-names = "xvclk";
 | |
| 		reset-gpios = <&gpio3 RK_PC5 GPIO_ACTIVE_HIGH>;
 | |
| 		pwdn-gpios = <&gpio3 RK_PD2 GPIO_ACTIVE_HIGH>;
 | |
| 		pinctrl-names = "default";
 | |
| 		pinctrl-0 = <&mipi_refclk_out0>;
 | |
| 		rockchip,camera-module-index = <0>;
 | |
| 		rockchip,camera-module-facing = "back";
 | |
| 		rockchip,camera-module-name = "FKO1";
 | |
| 		rockchip,camera-module-lens-name = "30IRC-F16";
 | |
| 		port {
 | |
| 			sc3338_out: endpoint {
 | |
| 				remote-endpoint = <&csi_dphy_input5>;
 | |
| 				data-lanes = <1 2>;
 | |
| 			};
 | |
| 		};
 | |
| 	};
 | |
| 
 | |
| 	sc4336: sc4336@30 {
 | |
| 		compatible = "smartsens,sc4336";
 | |
| 		status = "okay";
 | |
| 		reg = <0x30>;
 | |
| 		clocks = <&cru MCLK_REF_MIPI0>;
 | |
| 		clock-names = "xvclk";
 | |
| 		reset-gpios = <&gpio3 RK_PC5 GPIO_ACTIVE_HIGH>;
 | |
| 		pwdn-gpios = <&gpio3 RK_PD2 GPIO_ACTIVE_HIGH>;
 | |
| 		pinctrl-names = "default";
 | |
| 		pinctrl-0 = <&mipi_refclk_out0>;
 | |
| 		rockchip,camera-module-index = <0>;
 | |
| 		rockchip,camera-module-facing = "back";
 | |
| 		rockchip,camera-module-name = "OT01";
 | |
| 		rockchip,camera-module-lens-name = "40IRC_F16";
 | |
| 		port {
 | |
| 			sc4336_out: endpoint {
 | |
| 				remote-endpoint = <&csi_dphy_input2>;
 | |
| 				data-lanes = <1 2>;
 | |
| 			};
 | |
| 		};
 | |
| 	};
 | |
| 
 | |
| 	os04a10: os04a10@36 {
 | |
| 		compatible = "ovti,os04a10";
 | |
| 		status = "okay";
 | |
| 		reg = <0x36>;
 | |
| 		clocks = <&cru MCLK_REF_MIPI0>;
 | |
| 		clock-names = "xvclk";
 | |
| 		reset-gpios = <&gpio3 RK_PC5 GPIO_ACTIVE_LOW>;
 | |
| 		pwdn-gpios = <&gpio3 RK_PD2 GPIO_ACTIVE_HIGH>;
 | |
| 		pinctrl-names = "default";
 | |
| 		pinctrl-0 = <&mipi_refclk_out0>;
 | |
| 		rockchip,camera-module-index = <0>;
 | |
| 		rockchip,camera-module-facing = "back";
 | |
| 		rockchip,camera-module-name = "CMK-OT1607-PV1";
 | |
| 		rockchip,camera-module-lens-name = "50IRC-F16";
 | |
| 		port {
 | |
| 			os04a10_out: endpoint {
 | |
| 				remote-endpoint = <&csi_dphy_input3>;
 | |
| 				data-lanes = <1 2>;
 | |
| 			};
 | |
| 		};
 | |
| 	};
 | |
| 
 | |
| 	jx_k17: jx_k17@40 {
 | |
| 		compatible = "soi,jx_k17";
 | |
| 		status = "okay";
 | |
| 		reg = <0x40>;
 | |
| 		clocks = <&cru MCLK_REF_MIPI0>;
 | |
| 		clock-names = "xvclk";
 | |
| 		reset-gpios = <&gpio3 RK_PC5 GPIO_ACTIVE_HIGH>;
 | |
| 		pwdn-gpios = <&gpio3 RK_PC6 GPIO_ACTIVE_HIGH>;
 | |
| 		pinctrl-names = "default";
 | |
| 		pinctrl-0 = <&mipi_refclk_out0>;
 | |
| 		rockchip,camera-module-index = <0>;
 | |
| 		rockchip,camera-module-facing = "back";
 | |
| 		rockchip,camera-module-name = "T3801-A";
 | |
| 		rockchip,camera-module-lens-name = "22IRC-5M-F18";
 | |
| 		port {
 | |
| 			jx_k17_out: endpoint {
 | |
| 				remote-endpoint = <&csi_dphy_input4>;
 | |
| 				data-lanes = <1 2>;
 | |
| 			};
 | |
| 		};
 | |
| 	};
 | |
| 
 | |
| 	imx415: imx415@1a {
 | |
| 		compatible = "sony,imx415";
 | |
| 		status = "okay";
 | |
| 		reg = <0x1a>;
 | |
| 		clocks = <&cru MCLK_REF_MIPI0>;
 | |
| 		clock-names = "xvclk";
 | |
| 		reset-gpios = <&gpio3 RK_PC5 GPIO_ACTIVE_LOW>;
 | |
| 		pwdn-gpios = <&gpio3 RK_PD2 GPIO_ACTIVE_HIGH>;
 | |
| 		pinctrl-names = "default";
 | |
| 		pinctrl-0 = <&mipi_refclk_out0>;
 | |
| 		rockchip,camera-module-index = <0>;
 | |
| 		rockchip,camera-module-facing = "back";
 | |
| 		rockchip,camera-module-name = "CMK-OT2022-PX1";
 | |
| 		rockchip,camera-module-lens-name = "IR0147-36IRC-8M-F20";
 | |
| 		port {
 | |
| 			imx415_out: endpoint {
 | |
| 				remote-endpoint = <&csi_dphy_input6>;
 | |
| 				data-lanes = <1 2>;
 | |
| 			};
 | |
| 		};
 | |
| 	};
 | |
| 
 | |
| 	sc450ai: sc450ai@30 {
 | |
| 		compatible = "smartsens,sc450ai";
 | |
| 		status = "okay";
 | |
| 		reg = <0x30>;
 | |
| 		clocks = <&cru MCLK_REF_MIPI0>;
 | |
| 		clock-names = "xvclk";
 | |
| 		reset-gpios = <&gpio3 RK_PC5 GPIO_ACTIVE_HIGH>;
 | |
| 		pwdn-gpios = <&gpio3 RK_PC6 GPIO_ACTIVE_HIGH>;
 | |
| 		pinctrl-names = "default";
 | |
| 		pinctrl-0 = <&mipi_refclk_out0>;
 | |
| 		rockchip,camera-module-index = <0>;
 | |
| 		rockchip,camera-module-facing = "back";
 | |
| 		rockchip,camera-module-name = "CMK-OT2119-PC1";
 | |
| 		rockchip,camera-module-lens-name = "30IRC-F16";
 | |
| 		port {
 | |
| 			sc450ai_out: endpoint {
 | |
| 				remote-endpoint = <&csi_dphy_input7>;
 | |
| 				data-lanes = <1 2>;
 | |
| 			};
 | |
| 		};
 | |
| 	};
 | |
| 
 | |
| 	sc401ai: sc401ai@30 {
 | |
| 		compatible = "smartsens,sc401ai";
 | |
| 		status = "okay";
 | |
| 		reg = <0x30>;
 | |
| 		clocks = <&cru MCLK_REF_MIPI0>;
 | |
| 		clock-names = "xvclk";
 | |
| 		reset-gpios = <&gpio3 RK_PC5 GPIO_ACTIVE_HIGH>;
 | |
| 		pwdn-gpios = <&gpio3 RK_PD2 GPIO_ACTIVE_HIGH>;
 | |
| 		pinctrl-names = "default";
 | |
| 		pinctrl-0 = <&mipi_refclk_out0>;
 | |
| 		rockchip,camera-module-index = <0>;
 | |
| 		rockchip,camera-module-facing = "back";
 | |
| 		rockchip,camera-module-name = "CMK-OT2115-PC1";
 | |
| 		rockchip,camera-module-lens-name = "30IRC-F16";
 | |
| 		port {
 | |
| 			sc401ai_out: endpoint {
 | |
| 				remote-endpoint = <&csi_dphy_input8>;
 | |
| 				data-lanes = <1 2>;
 | |
| 			};
 | |
| 		};
 | |
| 	};
 | |
| 
 | |
| 	sc200ai: sc200ai@30 {
 | |
| 		compatible = "smartsens,sc200ai";
 | |
| 		status = "okay";
 | |
| 		reg = <0x30>;
 | |
| 		clocks = <&cru MCLK_REF_MIPI0>;
 | |
| 		clock-names = "xvclk";
 | |
| 		reset-gpios = <&gpio3 RK_PC5 GPIO_ACTIVE_HIGH>;
 | |
| 		pwdn-gpios = <&gpio3 RK_PD2 GPIO_ACTIVE_HIGH>;
 | |
| 		pinctrl-names = "default";
 | |
| 		pinctrl-0 = <&mipi_refclk_out0>;
 | |
| 		rockchip,camera-module-index = <0>;
 | |
| 		rockchip,camera-module-facing = "back";
 | |
| 		rockchip,camera-module-name = "CMK-OT2115-PC1";
 | |
| 		rockchip,camera-module-lens-name = "30IRC-F16";
 | |
| 		port {
 | |
| 			sc200ai_out: endpoint {
 | |
| 				remote-endpoint = <&csi_dphy_input9>;
 | |
| 				data-lanes = <1 2>;
 | |
| 			};
 | |
| 		};
 | |
| 	};
 | |
| };
 | |
| 
 | |
| &mipi0_csi2 {
 | |
| 	status = "okay";
 | |
| 
 | |
| 	ports {
 | |
| 		#address-cells = <1>;
 | |
| 		#size-cells = <0>;
 | |
| 
 | |
| 		port@0 {
 | |
| 			reg = <0>;
 | |
| 			#address-cells = <1>;
 | |
| 			#size-cells = <0>;
 | |
| 
 | |
| 			mipi_csi2_input: endpoint@1 {
 | |
| 				reg = <1>;
 | |
| 				remote-endpoint = <&csi_dphy_output>;
 | |
| 			};
 | |
| 		};
 | |
| 
 | |
| 		port@1 {
 | |
| 			reg = <1>;
 | |
| 			#address-cells = <1>;
 | |
| 			#size-cells = <0>;
 | |
| 
 | |
| 			mipi_csi2_output: endpoint@0 {
 | |
| 				reg = <0>;
 | |
| 				remote-endpoint = <&cif_mipi_in>;
 | |
| 			};
 | |
| 		};
 | |
| 	};
 | |
| };
 | |
| 
 | |
| &rkcif {
 | |
| 	status = "okay";
 | |
| };
 | |
| 
 | |
| &rkcif_mipi_lvds {
 | |
| 	status = "okay";
 | |
| 
 | |
| 	pinctrl-names = "default";
 | |
| 	pinctrl-0 = <&mipi_pins>;
 | |
| 	port {
 | |
| 		/* MIPI CSI-2 endpoint */
 | |
| 		cif_mipi_in: endpoint {
 | |
| 			remote-endpoint = <&mipi_csi2_output>;
 | |
| 		};
 | |
| 	};
 | |
| };
 | |
| 
 | |
| &rkcif_mipi_lvds_sditf {
 | |
| 	status = "okay";
 | |
| 
 | |
| 	port {
 | |
| 		/* MIPI CSI-2 endpoint */
 | |
| 		mipi_lvds_sditf: endpoint {
 | |
| 			remote-endpoint = <&isp_in>;
 | |
| 		};
 | |
| 	};
 | |
| };
 | |
| 
 | |
| &rkisp {
 | |
| 	status = "okay";
 | |
| };
 | |
| 
 | |
| &rkisp_vir0 {
 | |
| 	status = "okay";
 | |
| 
 | |
| 	port@0 {
 | |
| 		isp_in: endpoint {
 | |
| 			remote-endpoint = <&mipi_lvds_sditf>;
 | |
| 		};
 | |
| 	};
 | |
| };
 | |
| 
 |