summaryrefslogtreecommitdiff
path: root/arch/arm64/boot/dts/freescale/imx8mm-venice-gw73xx-0x-imx219.dts
blob: f3ece4b7fbbded54ccd68e43f66a449d7e1e4a7c (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
// SPDX-License-Identifier: (GPL-2.0+ OR MIT)
/*
 * Copyright 2022 Gateworks Corporation
 */

#include <dt-bindings/gpio/gpio.h>

#include "imx8mm-pinfunc.h"

/dts-v1/;
/plugin/;

&{/} {
	compatible = "gw,imx8mm-gw73xx-0x", "fsl,imx8mm";

	reg_cam: regulator-cam {
		pinctrl-names = "default";
		pinctrl-0 = <&pinctrl_reg_cam>;
		compatible = "regulator-fixed";
		regulator-name = "reg_cam";
		gpio = <&gpio1 1 GPIO_ACTIVE_HIGH>;
		enable-active-high;
		regulator-min-microvolt = <1800000>;
		regulator-max-microvolt = <1800000>;
	};

	cam24m: cam24m {
		compatible = "fixed-clock";
		#clock-cells = <0>;
		clock-frequency = <24000000>;
		clock-output-names = "cam24m";
	};
};

&csi {
	status = "okay";
};

&i2c3 {
	#address-cells = <1>;
	#size-cells = <0>;

	imx219: sensor@10 {
		compatible = "sony,imx219";
		reg = <0x10>;
		clocks = <&cam24m>;
		VDIG-supply = <&reg_cam>;

		port {
			/* MIPI CSI-2 bus endpoint */
			imx219_to_mipi_csi2: endpoint {
				remote-endpoint = <&imx8mm_mipi_csi_in>;
				clock-lanes = <0>;
				data-lanes = <1 2>;
				link-frequencies = /bits/ 64 <456000000>;
			};
		};
	};
};

&mipi_csi {
	status = "okay";

	ports {
		#address-cells = <1>;
		#size-cells = <0>;

		port@0 {
			reg = <0>;

			imx8mm_mipi_csi_in: endpoint {
				remote-endpoint = <&imx219_to_mipi_csi2>;
				data-lanes = <1 2>;
			};
		};

		port@1 {
			reg = <1>;

			imx8mm_mipi_csi_out: endpoint {
				remote-endpoint = <&csi_in>;
			};
		};
	};
};

&iomuxc {
	pinctrl_reg_cam: regcamgrp {
		fsl,pins = <
			MX8MM_IOMUXC_GPIO1_IO01_GPIO1_IO1	0x41
		>;
	};
};