Merge tag 'for-5.13-rc6-tag' of git://git.kernel.org/pub/scm/linux/kernel/git/kdave...
[linux-2.6-microblaze.git] / arch / arm / boot / dts / r8a7742-iwg21d-q7-dbcm-ca.dts
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 = &ether;
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 &ether {
61         pinctrl-0 = <&ether_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