Loading...
Note: File does not exist in v4.6.
1// SPDX-License-Identifier: GPL-2.0
2/*
3 * Device Tree Source for the iWave-RZ/G1H Qseven board development
4 * platform with camera daughter board
5 *
6 * Copyright (C) 2020 Renesas Electronics Corp.
7 */
8
9/dts-v1/;
10#include "r8a7742-iwg21d-q7.dts"
11
12/ {
13 model = "iWave Systems RZ/G1H Qseven development platform with camera add-on";
14 compatible = "iwave,g21d", "iwave,g21m", "renesas,r8a7742";
15
16 aliases {
17 serial0 = &scif0;
18 serial1 = &scif1;
19 serial3 = &scifb1;
20 serial5 = &hscif0;
21 ethernet1 = ðer;
22 };
23
24 mclk_cam1: mclk-cam1 {
25 compatible = "fixed-clock";
26 #clock-cells = <0>;
27 clock-frequency = <26000000>;
28 };
29
30 mclk_cam2: mclk-cam2 {
31 compatible = "fixed-clock";
32 #clock-cells = <0>;
33 clock-frequency = <26000000>;
34 };
35
36 mclk_cam3: mclk-cam3 {
37 compatible = "fixed-clock";
38 #clock-cells = <0>;
39 clock-frequency = <26000000>;
40 };
41
42 mclk_cam4: mclk-cam4 {
43 compatible = "fixed-clock";
44 #clock-cells = <0>;
45 clock-frequency = <26000000>;
46 };
47};
48
49&avb {
50 /* Pins shared with VIN0, keep status disabled */
51 status = "disabled";
52};
53
54&can0 {
55 pinctrl-0 = <&can0_pins>;
56 pinctrl-names = "default";
57 status = "okay";
58};
59
60ðer {
61 pinctrl-0 = <ðer_pins>;
62 pinctrl-names = "default";
63
64 phy-handle = <&phy1>;
65 renesas,ether-link-active-low;
66 status = "okay";
67
68 phy1: ethernet-phy@1 {
69 reg = <1>;
70 micrel,led-mode = <1>;
71 };
72};
73
74&gpio0 {
75 /* Disable hogging GP0_18 to output LOW */
76 /delete-node/ qspi_en;
77
78 /* Hog GP0_18 to output HIGH to enable VIN2 */
79 vin2_en {
80 gpio-hog;
81 gpios = <18 GPIO_ACTIVE_HIGH>;
82 output-high;
83 line-name = "VIN2_EN";
84 };
85};
86
87&hscif0 {
88 pinctrl-0 = <&hscif0_pins>;
89 pinctrl-names = "default";
90 uart-has-rtscts;
91 status = "okay";
92};
93
94&i2c1 {
95 pinctrl-0 = <&i2c1_pins>;
96 pinctrl-names = "default";
97
98 /* status set to "okay" when needed by camera configuration below */
99 clock-frequency = <400000>;
100};
101
102&i2c3 {
103 pinctrl-0 = <&i2c3_pins>;
104 pinctrl-names = "default";
105
106 /* status set to "okay" when needed by camera configuration below */
107 clock-frequency = <400000>;
108};
109
110&pfc {
111 can0_pins: can0 {
112 groups = "can0_data_d";
113 function = "can0";
114 };
115
116 ether_pins: ether {
117 groups = "eth_mdio", "eth_rmii";
118 function = "eth";
119 };
120
121 hscif0_pins: hscif0 {
122 groups = "hscif0_data", "hscif0_ctrl";
123 function = "hscif0";
124 };
125
126 i2c1_pins: i2c1 {
127 groups = "i2c1_c";
128 function = "i2c1";
129 };
130
131 i2c3_pins: i2c3 {
132 groups = "i2c3";
133 function = "i2c3";
134 };
135
136 scif0_pins: scif0 {
137 groups = "scif0_data";
138 function = "scif0";
139 };
140
141 scif1_pins: scif1 {
142 groups = "scif1_data";
143 function = "scif1";
144 };
145
146 scifb1_pins: scifb1 {
147 groups = "scifb1_data";
148 function = "scifb1";
149 };
150
151 vin0_8bit_pins: vin0 {
152 groups = "vin0_data8", "vin0_clk", "vin0_sync";
153 function = "vin0";
154 };
155
156 vin1_8bit_pins: vin1 {
157 groups = "vin1_data8_b", "vin1_clk_b", "vin1_sync_b";
158 function = "vin1";
159 };
160
161 vin2_pins: vin2 {
162 groups = "vin2_g8", "vin2_clk";
163 function = "vin2";
164 };
165
166 vin3_pins: vin3 {
167 groups = "vin3_data8", "vin3_clk", "vin3_sync";
168 function = "vin3";
169 };
170};
171
172&qspi {
173 /* Pins shared with VIN2, keep status disabled */
174 status = "disabled";
175};
176
177&scif0 {
178 pinctrl-0 = <&scif0_pins>;
179 pinctrl-names = "default";
180 status = "okay";
181};
182
183&scif1 {
184 pinctrl-0 = <&scif1_pins>;
185 pinctrl-names = "default";
186 status = "okay";
187};
188
189&scifb1 {
190 pinctrl-0 = <&scifb1_pins>;
191 pinctrl-names = "default";
192 status = "okay";
193
194 rts-gpios = <&gpio4 21 GPIO_ACTIVE_LOW>;
195 cts-gpios = <&gpio4 17 GPIO_ACTIVE_LOW>;
196};
197
198/*
199 * Below configuration ties VINx endpoints to ov5640/ov7725 camera endpoints
200 *
201 * (un)comment the #include statements to change configuration
202 */
203
204/* 8bit CMOS Camera 1 (J13) */
205#define CAM_PARENT_I2C i2c0
206#define MCLK_CAM mclk_cam1
207#define CAM_EP cam0ep
208#define VIN_EP vin0ep
209#undef CAM_ENABLED
210#include "r8a7742-iwg21d-q7-dbcm-ov5640-single.dtsi"
211//#include "r8a7742-iwg21d-q7-dbcm-ov7725-single.dtsi"
212
213#ifdef CAM_ENABLED
214&vin0 {
215 /*
216 * Set SW2 switch on the SOM to 'ON'
217 * Set SW1 switch on camera board to 'OFF' as we are using 8bit mode
218 */
219 status = "okay";
220 pinctrl-0 = <&vin0_8bit_pins>;
221 pinctrl-names = "default";
222
223 port {
224 vin0ep: endpoint {
225 remote-endpoint = <&cam0ep>;
226 bus-width = <8>;
227 bus-type = <6>;
228 };
229 };
230};
231#endif /* CAM_ENABLED */
232
233#undef CAM_PARENT_I2C
234#undef MCLK_CAM
235#undef CAM_EP
236#undef VIN_EP
237
238/* 8bit CMOS Camera 2 (J14) */
239#define CAM_PARENT_I2C i2c1
240#define MCLK_CAM mclk_cam2
241#define CAM_EP cam1ep
242#define VIN_EP vin1ep
243#undef CAM_ENABLED
244#include "r8a7742-iwg21d-q7-dbcm-ov5640-single.dtsi"
245//#include "r8a7742-iwg21d-q7-dbcm-ov7725-single.dtsi"
246
247#ifdef CAM_ENABLED
248&vin1 {
249 /* Set SW1 switch on the SOM to 'ON' */
250 status = "okay";
251 pinctrl-0 = <&vin1_8bit_pins>;
252 pinctrl-names = "default";
253
254 port {
255 vin1ep: endpoint {
256 remote-endpoint = <&cam1ep>;
257 bus-width = <8>;
258 bus-type = <6>;
259 };
260 };
261};
262
263#endif /* CAM_ENABLED */
264
265#undef CAM_PARENT_I2C
266#undef MCLK_CAM
267#undef CAM_EP
268#undef VIN_EP
269
270/* 8bit CMOS Camera 3 (J12) */
271#define CAM_PARENT_I2C i2c2
272#define MCLK_CAM mclk_cam3
273#define CAM_EP cam2ep
274#define VIN_EP vin2ep
275#undef CAM_ENABLED
276#include "r8a7742-iwg21d-q7-dbcm-ov5640-single.dtsi"
277//#include "r8a7742-iwg21d-q7-dbcm-ov7725-single.dtsi"
278
279#ifdef CAM_ENABLED
280&vin2 {
281 status = "okay";
282 pinctrl-0 = <&vin2_pins>;
283 pinctrl-names = "default";
284
285 port {
286 vin2ep: endpoint {
287 remote-endpoint = <&cam2ep>;
288 bus-width = <8>;
289 data-shift = <8>;
290 bus-type = <6>;
291 };
292 };
293};
294#endif /* CAM_ENABLED */
295
296#undef CAM_PARENT_I2C
297#undef MCLK_CAM
298#undef CAM_EP
299#undef VIN_EP
300
301/* 8bit CMOS Camera 4 (J11) */
302#define CAM_PARENT_I2C i2c3
303#define MCLK_CAM mclk_cam4
304#define CAM_EP cam3ep
305#define VIN_EP vin3ep
306#undef CAM_ENABLED
307#include "r8a7742-iwg21d-q7-dbcm-ov5640-single.dtsi"
308//#include "r8a7742-iwg21d-q7-dbcm-ov7725-single.dtsi"
309
310#ifdef CAM_ENABLED
311&vin3 {
312 status = "okay";
313 pinctrl-0 = <&vin3_pins>;
314 pinctrl-names = "default";
315
316 port {
317 vin3ep: endpoint {
318 remote-endpoint = <&cam3ep>;
319 bus-width = <8>;
320 bus-type = <6>;
321 };
322 };
323};
324#endif /* CAM_ENABLED */
325
326#undef CAM_PARENT_I2C
327#undef MCLK_CAM
328#undef CAM_EP
329#undef VIN_EP