blob: 4409c47239b9824099174f7fd3033b4d7d3fbdd8 [file] [log] [blame]
Tom Rini53633a82024-02-29 12:33:36 -05001// SPDX-License-Identifier: (GPL-2.0-only OR BSD-2-Clause)
2/*
3 * Device Tree Source for the RZ/{G2L,V2L} SMARC SOM common parts
4 *
5 * Copyright (C) 2021 Renesas Electronics Corp.
6 */
7
8#include <dt-bindings/gpio/gpio.h>
9#include <dt-bindings/interrupt-controller/irqc-rzg2l.h>
10#include <dt-bindings/pinctrl/rzg2l-pinctrl.h>
11
12/* SW1[2] should be at position 2/OFF to enable 64 GB eMMC */
13#define EMMC 1
14
15/*
16 * To enable uSD card on CN3,
17 * SW1[2] should be at position 3/ON.
18 * Disable eMMC by setting "#define EMMC 0" above.
19 */
20#define SDHI (!EMMC)
21
22/ {
23 aliases {
24 ethernet0 = &eth0;
25 ethernet1 = &eth1;
26 };
27
28 chosen {
29 bootargs = "ignore_loglevel rw root=/dev/nfs ip=on";
30 };
31
32 memory@48000000 {
33 device_type = "memory";
34 /* first 128MB is reserved for secure area. */
35 reg = <0x0 0x48000000 0x0 0x78000000>;
36 };
37
38 reg_1p8v: regulator-1p8v {
39 compatible = "regulator-fixed";
40 regulator-name = "fixed-1.8V";
41 regulator-min-microvolt = <1800000>;
42 regulator-max-microvolt = <1800000>;
43 regulator-boot-on;
44 regulator-always-on;
45 };
46
47 reg_3p3v: regulator-3p3v {
48 compatible = "regulator-fixed";
49 regulator-name = "fixed-3.3V";
50 regulator-min-microvolt = <3300000>;
51 regulator-max-microvolt = <3300000>;
52 regulator-boot-on;
53 regulator-always-on;
54 };
55
56 reg_1p1v: regulator-vdd-core {
57 compatible = "regulator-fixed";
58 regulator-name = "fixed-1.1V";
59 regulator-min-microvolt = <1100000>;
60 regulator-max-microvolt = <1100000>;
61 regulator-boot-on;
62 regulator-always-on;
63 };
64
65 vccq_sdhi0: regulator-vccq-sdhi0 {
66 compatible = "regulator-gpio";
67
68 regulator-name = "SDHI0 VccQ";
69 regulator-min-microvolt = <1800000>;
70 regulator-max-microvolt = <3300000>;
71 states = <3300000 1>, <1800000 0>;
72 regulator-boot-on;
73 gpios = <&pinctrl RZG2L_GPIO(39, 0) GPIO_ACTIVE_HIGH>;
74 regulator-always-on;
75 };
76
77 /* 32.768kHz crystal */
78 x2: x2-clock {
79 compatible = "fixed-clock";
80 #clock-cells = <0>;
81 clock-frequency = <32768>;
82 };
83};
84
85&adc {
86 pinctrl-0 = <&adc_pins>;
87 pinctrl-names = "default";
88 status = "okay";
89
90 /delete-node/ channel@6;
91 /delete-node/ channel@7;
92};
93
94&eth0 {
95 pinctrl-0 = <&eth0_pins>;
96 pinctrl-names = "default";
97 phy-handle = <&phy0>;
98 phy-mode = "rgmii-id";
99 status = "okay";
100
101 phy0: ethernet-phy@7 {
102 compatible = "ethernet-phy-id0022.1640",
103 "ethernet-phy-ieee802.3-c22";
104 reg = <7>;
105 interrupt-parent = <&irqc>;
106 interrupts = <RZG2L_IRQ2 IRQ_TYPE_LEVEL_LOW>;
107 rxc-skew-psec = <2400>;
108 txc-skew-psec = <2400>;
109 rxdv-skew-psec = <0>;
110 txen-skew-psec = <0>;
111 rxd0-skew-psec = <0>;
112 rxd1-skew-psec = <0>;
113 rxd2-skew-psec = <0>;
114 rxd3-skew-psec = <0>;
115 txd0-skew-psec = <0>;
116 txd1-skew-psec = <0>;
117 txd2-skew-psec = <0>;
118 txd3-skew-psec = <0>;
119 };
120};
121
122&eth1 {
123 pinctrl-0 = <&eth1_pins>;
124 pinctrl-names = "default";
125 phy-handle = <&phy1>;
126 phy-mode = "rgmii-id";
127 status = "okay";
128
129 phy1: ethernet-phy@7 {
130 compatible = "ethernet-phy-id0022.1640",
131 "ethernet-phy-ieee802.3-c22";
132 reg = <7>;
133 interrupt-parent = <&irqc>;
134 interrupts = <RZG2L_IRQ3 IRQ_TYPE_LEVEL_LOW>;
135 rxc-skew-psec = <2400>;
136 txc-skew-psec = <2400>;
137 rxdv-skew-psec = <0>;
138 txen-skew-psec = <0>;
139 rxd0-skew-psec = <0>;
140 rxd1-skew-psec = <0>;
141 rxd2-skew-psec = <0>;
142 rxd3-skew-psec = <0>;
143 txd0-skew-psec = <0>;
144 txd1-skew-psec = <0>;
145 txd2-skew-psec = <0>;
146 txd3-skew-psec = <0>;
147 };
148};
149
150&extal_clk {
151 clock-frequency = <24000000>;
152};
153
154&gpu {
155 mali-supply = <&reg_1p1v>;
156};
157
158&i2c3 {
159 raa215300: pmic@12 {
160 compatible = "renesas,raa215300";
161 reg = <0x12>, <0x6f>;
162 reg-names = "main", "rtc";
163
164 clocks = <&x2>;
165 clock-names = "xin";
166 };
167};
168
169&ostm1 {
170 status = "okay";
171};
172
173&ostm2 {
174 status = "okay";
175};
176
177&pinctrl {
178 adc_pins: adc {
179 pinmux = <RZG2L_PORT_PINMUX(9, 0, 2)>; /* ADC_TRG */
180 };
181
182 eth0_pins: eth0 {
183 pinmux = <RZG2L_PORT_PINMUX(28, 1, 1)>, /* ET0_LINKSTA */
184 <RZG2L_PORT_PINMUX(27, 1, 1)>, /* ET0_MDC */
185 <RZG2L_PORT_PINMUX(28, 0, 1)>, /* ET0_MDIO */
186 <RZG2L_PORT_PINMUX(20, 0, 1)>, /* ET0_TXC */
187 <RZG2L_PORT_PINMUX(20, 1, 1)>, /* ET0_TX_CTL */
188 <RZG2L_PORT_PINMUX(20, 2, 1)>, /* ET0_TXD0 */
189 <RZG2L_PORT_PINMUX(21, 0, 1)>, /* ET0_TXD1 */
190 <RZG2L_PORT_PINMUX(21, 1, 1)>, /* ET0_TXD2 */
191 <RZG2L_PORT_PINMUX(22, 0, 1)>, /* ET0_TXD3 */
192 <RZG2L_PORT_PINMUX(24, 0, 1)>, /* ET0_RXC */
193 <RZG2L_PORT_PINMUX(24, 1, 1)>, /* ET0_RX_CTL */
194 <RZG2L_PORT_PINMUX(25, 0, 1)>, /* ET0_RXD0 */
195 <RZG2L_PORT_PINMUX(25, 1, 1)>, /* ET0_RXD1 */
196 <RZG2L_PORT_PINMUX(26, 0, 1)>, /* ET0_RXD2 */
197 <RZG2L_PORT_PINMUX(26, 1, 1)>, /* ET0_RXD3 */
198 <RZG2L_PORT_PINMUX(1, 0, 1)>; /* IRQ2 */
199 };
200
201 eth1_pins: eth1 {
202 pinmux = <RZG2L_PORT_PINMUX(37, 2, 1)>, /* ET1_LINKSTA */
203 <RZG2L_PORT_PINMUX(37, 0, 1)>, /* ET1_MDC */
204 <RZG2L_PORT_PINMUX(37, 1, 1)>, /* ET1_MDIO */
205 <RZG2L_PORT_PINMUX(29, 0, 1)>, /* ET1_TXC */
206 <RZG2L_PORT_PINMUX(29, 1, 1)>, /* ET1_TX_CTL */
207 <RZG2L_PORT_PINMUX(30, 0, 1)>, /* ET1_TXD0 */
208 <RZG2L_PORT_PINMUX(30, 1, 1)>, /* ET1_TXD1 */
209 <RZG2L_PORT_PINMUX(31, 0, 1)>, /* ET1_TXD2 */
210 <RZG2L_PORT_PINMUX(31, 1, 1)>, /* ET1_TXD3 */
211 <RZG2L_PORT_PINMUX(33, 1, 1)>, /* ET1_RXC */
212 <RZG2L_PORT_PINMUX(34, 0, 1)>, /* ET1_RX_CTL */
213 <RZG2L_PORT_PINMUX(34, 1, 1)>, /* ET1_RXD0 */
214 <RZG2L_PORT_PINMUX(35, 0, 1)>, /* ET1_RXD1 */
215 <RZG2L_PORT_PINMUX(35, 1, 1)>, /* ET1_RXD2 */
216 <RZG2L_PORT_PINMUX(36, 0, 1)>, /* ET1_RXD3 */
217 <RZG2L_PORT_PINMUX(1, 1, 1)>; /* IRQ3 */
218 };
219
220 gpio-sd0-pwr-en-hog {
221 gpio-hog;
222 gpios = <RZG2L_GPIO(4, 1) GPIO_ACTIVE_HIGH>;
223 output-high;
224 line-name = "gpio_sd0_pwr_en";
225 };
226
227 qspi0_pins: qspi0 {
228 qspi0-data {
229 pins = "QSPI0_IO0", "QSPI0_IO1", "QSPI0_IO2", "QSPI0_IO3";
230 power-source = <1800>;
231 };
232
233 qspi0-ctrl {
234 pins = "QSPI0_SPCLK", "QSPI0_SSL", "QSPI_RESET#";
235 power-source = <1800>;
236 };
237 };
238
239 /*
240 * SD0 device selection is XOR between GPIO_SD0_DEV_SEL and SW1[2]
241 * The below switch logic can be used to select the device between
242 * eMMC and microSD, after setting GPIO_SD0_DEV_SEL to high in DT.
243 * SW1[2] should be at position 2/OFF to enable 64 GB eMMC
244 * SW1[2] should be at position 3/ON to enable uSD card CN3
245 */
246 sd0-dev-sel-hog {
247 gpio-hog;
248 gpios = <RZG2L_GPIO(41, 1) GPIO_ACTIVE_HIGH>;
249 output-high;
250 line-name = "sd0_dev_sel";
251 };
252
253 sdhi0_emmc_pins: sd0emmc {
254 sd0_emmc_data {
255 pins = "SD0_DATA0", "SD0_DATA1", "SD0_DATA2", "SD0_DATA3",
256 "SD0_DATA4", "SD0_DATA5", "SD0_DATA6", "SD0_DATA7";
257 power-source = <1800>;
258 };
259
260 sd0_emmc_ctrl {
261 pins = "SD0_CLK", "SD0_CMD";
262 power-source = <1800>;
263 };
264
265 sd0_emmc_rst {
266 pins = "SD0_RST#";
267 power-source = <1800>;
268 };
269 };
270
271 sdhi0_pins: sd0 {
272 sd0_data {
273 pins = "SD0_DATA0", "SD0_DATA1", "SD0_DATA2", "SD0_DATA3";
274 power-source = <3300>;
275 };
276
277 sd0_ctrl {
278 pins = "SD0_CLK", "SD0_CMD";
279 power-source = <3300>;
280 };
281
282 sd0_mux {
283 pinmux = <RZG2L_PORT_PINMUX(47, 0, 2)>; /* SD0_CD */
284 };
285 };
286
287 sdhi0_pins_uhs: sd0_uhs {
288 sd0_data_uhs {
289 pins = "SD0_DATA0", "SD0_DATA1", "SD0_DATA2", "SD0_DATA3";
290 power-source = <1800>;
291 };
292
293 sd0_ctrl_uhs {
294 pins = "SD0_CLK", "SD0_CMD";
295 power-source = <1800>;
296 };
297
298 sd0_mux_uhs {
299 pinmux = <RZG2L_PORT_PINMUX(47, 0, 2)>; /* SD0_CD */
300 };
301 };
302};
303
304&sbc {
305 pinctrl-0 = <&qspi0_pins>;
306 pinctrl-names = "default";
307 status = "okay";
308
309 flash@0 {
310 compatible = "micron,mt25qu512a", "jedec,spi-nor";
311 reg = <0>;
312 m25p,fast-read;
313 spi-max-frequency = <50000000>;
314 spi-rx-bus-width = <4>;
Tom Rini93743d22024-04-01 09:08:13 -0400315 spi-tx-bus-width = <4>;
Tom Rini53633a82024-02-29 12:33:36 -0500316
317 partitions {
318 compatible = "fixed-partitions";
319 #address-cells = <1>;
320 #size-cells = <1>;
321
322 boot@0 {
323 reg = <0x00000000 0x2000000>;
324 read-only;
325 };
326 user@2000000 {
327 reg = <0x2000000 0x2000000>;
328 };
329 };
330 };
331};
332
333#if SDHI
334&sdhi0 {
335 pinctrl-0 = <&sdhi0_pins>;
336 pinctrl-1 = <&sdhi0_pins_uhs>;
337 pinctrl-names = "default", "state_uhs";
338
339 vmmc-supply = <&reg_3p3v>;
340 vqmmc-supply = <&vccq_sdhi0>;
341 bus-width = <4>;
342 sd-uhs-sdr50;
343 sd-uhs-sdr104;
344 status = "okay";
345};
346#endif
347
348#if EMMC
349&sdhi0 {
350 pinctrl-0 = <&sdhi0_emmc_pins>;
351 pinctrl-1 = <&sdhi0_emmc_pins>;
352 pinctrl-names = "default", "state_uhs";
353
354 vmmc-supply = <&reg_3p3v>;
355 vqmmc-supply = <&reg_1p8v>;
356 bus-width = <8>;
357 mmc-hs200-1_8v;
358 non-removable;
359 fixed-emmc-driver-type = <1>;
360 status = "okay";
361};
362#endif
363
364&wdt0 {
365 status = "okay";
366 timeout-sec = <60>;
367};
368
369&wdt1 {
370 status = "okay";
371 timeout-sec = <60>;
372};