235 lines
4.0 KiB
Plaintext

/dts-v1/;
/plugin/;
#include <dt-bindings/clock/rk3588-cru.h>
#include <dt-bindings/power/rk3588-power.h>
#include <dt-bindings/gpio/gpio.h>
#include <dt-bindings/pinctrl/rockchip.h>
/ {
fragment@0 {
target = <&mipi_dcphy0>;
__overlay__ {
status = "okay";
};
};
fragment@1 {
target = <&csi2_dcphy0>;
__overlay__ {
status = "okay";
ports {
#address-cells = <1>;
#size-cells = <0>;
port@0 {
reg = <0>;
#address-cells = <1>;
#size-cells = <0>;
mipi_in_dcphy0: endpoint@1 {
reg = <1>;
remote-endpoint = <&imx415b_out0>;
data-lanes = <1 2 3 4>;
};
};
port@1 {
reg = <1>;
#address-cells = <1>;
#size-cells = <0>;
csidcphy0_out: endpoint@0 {
reg = <0>;
remote-endpoint = <&mipi0_csi2_input>;
};
};
};
};
};
fragment@2 {
target = <&mipi0_csi2>;
__overlay__ {
status = "okay";
ports {
#address-cells = <1>;
#size-cells = <0>;
port@0 {
reg = <0>;
#address-cells = <1>;
#size-cells = <0>;
mipi0_csi2_input: endpoint@1 {
reg = <1>;
remote-endpoint = <&csidcphy0_out>;
};
};
port@1 {
reg = <1>;
#address-cells = <1>;
#size-cells = <0>;
mipi0_csi2_output: endpoint@0 {
reg = <0>;
remote-endpoint = <&cif_mipi_in0>;
};
};
};
};
};
fragment@3 {
target = <&rkcif_mipi_lvds>;
__overlay__ {
status = "okay";
port {
cif_mipi_in0: endpoint {
remote-endpoint = <&mipi0_csi2_output>;
};
};
};
};
fragment@4 {
target = <&rkcif_mipi_lvds_sditf>;
__overlay__ {
status = "okay";
port {
mipi_lvds_sditf: endpoint {
remote-endpoint = <&isp0_vir0>;
};
};
};
};
fragment@5 {
target = <&rkisp0_vir0>;
__overlay__ {
status = "okay";
port {
#address-cells = <1>;
#size-cells = <0>;
isp0_vir0: endpoint@0 {
reg = <0>;
remote-endpoint = <&mipi_lvds_sditf>;
};
};
};
};
fragment@6 {
target = <&i2c4>;
__overlay__ {
status = "okay";
pinctrl-names = "default";
pinctrl-0 = <&i2c4m3_xfer>;
dw9714b: dw9714b@c {
compatible = "dongwoon,dw9714";
status = "okay";
reg = <0x0c>;
pinctrl-names = "focusb_gpios";
pinctrl-0 = <&focusb_gpio>;
focus-gpios = <&gpio1 RK_PA0 GPIO_ACTIVE_HIGH>;
rockchip,vcm-start-current = <20>;
rockchip,vcm-rated-current = <76>;
rockchip,vcm-step-mode = <0>;
rockchip,camera-module-index = <0>;
rockchip,camera-module-facing = "back";
};
imx415b: imx415b@1a {
compatible = "sony,imx415";
status = "okay";
reg = <0x1a>;
clocks = <&cru CLK_MIPI_CAMARAOUT_M1>;
clock-names = "xvclk";
power-domains = <&power RK3588_PD_VI>;
pinctrl-names = "default", "camb_gpios";
pinctrl-0 = <&mipim1_camera1_clk>, <&camb_gpio>;
rockchip,grf = <&sys_grf>;
reset-gpios = <&gpio1 RK_PB2 GPIO_ACTIVE_LOW>;
pwdn-gpios = <&gpio1 RK_PB3 GPIO_ACTIVE_HIGH>;
rockchip,camera-module-index = <0>;
rockchip,camera-module-facing = "back";
rockchip,camera-module-name = "CMK-OT2022-PX1";
rockchip,camera-module-lens-name = "IR0147-50IRC-8M-F20";
lens-focus = <&dw9714b>;
port {
imx415b_out0: endpoint {
remote-endpoint = <&mipi_in_dcphy0>;
data-lanes = <1 2 3 4>;
};
};
};
};
};
fragment@7 {
target = <&pinctrl>;
__overlay__ {
cam2 {
camb_gpio: camb-gpio {
rockchip,pins =
<1 RK_PB2 RK_FUNC_GPIO &pcfg_pull_none>,
<1 RK_PB3 RK_FUNC_GPIO &pcfg_pull_none>;
};
focusb_gpio: focusb-gpio {
rockchip,pins =
<1 RK_PA0 RK_FUNC_GPIO &pcfg_pull_none>;
};
};
};
};
fragment@8 {
target = <&rkcif>;
__overlay__ {
status = "okay";
};
};
fragment@9 {
target = <&rkcif_mmu>;
__overlay__ {
status = "okay";
};
};
fragment@10 {
target = <&rkisp0>;
__overlay__ {
status = "okay";
};
};
fragment@11 {
target = <&isp0_mmu>;
__overlay__ {
status = "okay";
};
};
};