1 /* SPDX-License-Identifier: GPL-2.0 */
3 * Device Tree Source for the R-Car E3 (R8A77990) SoC
5 * Copyright (C) 2018 Renesas Electronics Corp.
8 #include <dt-bindings/clock/r8a77990-cpg-mssr.h>
9 #include <dt-bindings/interrupt-controller/arm-gic.h>
10 #include <dt-bindings/power/r8a77990-sysc.h>
13 compatible = "renesas,r8a77990";
22 compatible = "arm,cortex-a53", "arm,armv8";
25 power-domains = <&sysc R8A77990_PD_CA53_CPU0>;
26 next-level-cache = <&L2_CA53>;
27 enable-method = "psci";
31 compatible = "arm,cortex-a53", "arm,armv8";
34 power-domains = <&sysc R8A77990_PD_CA53_CPU1>;
35 next-level-cache = <&L2_CA53>;
36 enable-method = "psci";
39 L2_CA53: cache-controller-0 {
41 power-domains = <&sysc R8A77990_PD_CA53_SCU>;
48 compatible = "fixed-clock";
50 /* This value must be overridden by the board */
51 clock-frequency = <0>;
55 compatible = "arm,cortex-a53-pmu";
56 interrupts-extended = <&gic GIC_SPI 84 IRQ_TYPE_LEVEL_HIGH>,
57 <&gic GIC_SPI 85 IRQ_TYPE_LEVEL_HIGH>;
58 interrupt-affinity = <&a53_0>, <&a53_1>;
62 compatible = "arm,psci-1.0", "arm,psci-0.2";
66 /* External SCIF clock - to be overridden by boards that provide it */
68 compatible = "fixed-clock";
70 clock-frequency = <0>;
74 compatible = "simple-bus";
75 interrupt-parent = <&gic>;
80 rwdt: watchdog@e6020000 {
81 compatible = "renesas,r8a77990-wdt",
82 "renesas,rcar-gen3-wdt";
83 reg = <0 0xe6020000 0 0x0c>;
84 clocks = <&cpg CPG_MOD 402>;
85 power-domains = <&sysc R8A77990_PD_ALWAYS_ON>;
90 gpio0: gpio@e6050000 {
91 compatible = "renesas,gpio-r8a77990",
92 "renesas,rcar-gen3-gpio";
93 reg = <0 0xe6050000 0 0x50>;
94 interrupts = <GIC_SPI 4 IRQ_TYPE_LEVEL_HIGH>;
97 gpio-ranges = <&pfc 0 0 18>;
98 #interrupt-cells = <2>;
100 clocks = <&cpg CPG_MOD 912>;
101 power-domains = <&sysc R8A77990_PD_ALWAYS_ON>;
105 gpio1: gpio@e6051000 {
106 compatible = "renesas,gpio-r8a77990",
107 "renesas,rcar-gen3-gpio";
108 reg = <0 0xe6051000 0 0x50>;
109 interrupts = <GIC_SPI 5 IRQ_TYPE_LEVEL_HIGH>;
112 gpio-ranges = <&pfc 0 32 23>;
113 #interrupt-cells = <2>;
114 interrupt-controller;
115 clocks = <&cpg CPG_MOD 911>;
116 power-domains = <&sysc R8A77990_PD_ALWAYS_ON>;
120 gpio2: gpio@e6052000 {
121 compatible = "renesas,gpio-r8a77990",
122 "renesas,rcar-gen3-gpio";
123 reg = <0 0xe6052000 0 0x50>;
124 interrupts = <GIC_SPI 6 IRQ_TYPE_LEVEL_HIGH>;
127 gpio-ranges = <&pfc 0 64 26>;
128 #interrupt-cells = <2>;
129 interrupt-controller;
130 clocks = <&cpg CPG_MOD 910>;
131 power-domains = <&sysc R8A77990_PD_ALWAYS_ON>;
135 gpio3: gpio@e6053000 {
136 compatible = "renesas,gpio-r8a77990",
137 "renesas,rcar-gen3-gpio";
138 reg = <0 0xe6053000 0 0x50>;
139 interrupts = <GIC_SPI 7 IRQ_TYPE_LEVEL_HIGH>;
142 gpio-ranges = <&pfc 0 96 16>;
143 #interrupt-cells = <2>;
144 interrupt-controller;
145 clocks = <&cpg CPG_MOD 909>;
146 power-domains = <&sysc R8A77990_PD_ALWAYS_ON>;
150 gpio4: gpio@e6054000 {
151 compatible = "renesas,gpio-r8a77990",
152 "renesas,rcar-gen3-gpio";
153 reg = <0 0xe6054000 0 0x50>;
154 interrupts = <GIC_SPI 8 IRQ_TYPE_LEVEL_HIGH>;
157 gpio-ranges = <&pfc 0 128 11>;
158 #interrupt-cells = <2>;
159 interrupt-controller;
160 clocks = <&cpg CPG_MOD 908>;
161 power-domains = <&sysc R8A77990_PD_ALWAYS_ON>;
165 gpio5: gpio@e6055000 {
166 compatible = "renesas,gpio-r8a77990",
167 "renesas,rcar-gen3-gpio";
168 reg = <0 0xe6055000 0 0x50>;
169 interrupts = <GIC_SPI 9 IRQ_TYPE_LEVEL_HIGH>;
172 gpio-ranges = <&pfc 0 160 20>;
173 #interrupt-cells = <2>;
174 interrupt-controller;
175 clocks = <&cpg CPG_MOD 907>;
176 power-domains = <&sysc R8A77990_PD_ALWAYS_ON>;
180 gpio6: gpio@e6055400 {
181 compatible = "renesas,gpio-r8a77990",
182 "renesas,rcar-gen3-gpio";
183 reg = <0 0xe6055400 0 0x50>;
184 interrupts = <GIC_SPI 10 IRQ_TYPE_LEVEL_HIGH>;
187 gpio-ranges = <&pfc 0 192 18>;
188 #interrupt-cells = <2>;
189 interrupt-controller;
190 clocks = <&cpg CPG_MOD 906>;
191 power-domains = <&sysc R8A77990_PD_ALWAYS_ON>;
195 pfc: pin-controller@e6060000 {
196 compatible = "renesas,pfc-r8a77990";
197 reg = <0 0xe6060000 0 0x508>;
200 cpg: clock-controller@e6150000 {
201 compatible = "renesas,r8a77990-cpg-mssr";
202 reg = <0 0xe6150000 0 0x1000>;
203 clocks = <&extal_clk>;
204 clock-names = "extal";
206 #power-domain-cells = <0>;
210 rst: reset-controller@e6160000 {
211 compatible = "renesas,r8a77990-rst";
212 reg = <0 0xe6160000 0 0x0200>;
215 sysc: system-controller@e6180000 {
216 compatible = "renesas,r8a77990-sysc";
217 reg = <0 0xe6180000 0 0x0400>;
218 #power-domain-cells = <1>;
221 ipmmu_ds0: mmu@e6740000 {
222 compatible = "renesas,ipmmu-r8a77990";
223 reg = <0 0xe6740000 0 0x1000>;
224 renesas,ipmmu-main = <&ipmmu_mm 0>;
225 power-domains = <&sysc R8A77990_PD_ALWAYS_ON>;
229 ipmmu_ds1: mmu@e7740000 {
230 compatible = "renesas,ipmmu-r8a77990";
231 reg = <0 0xe7740000 0 0x1000>;
232 renesas,ipmmu-main = <&ipmmu_mm 1>;
233 power-domains = <&sysc R8A77990_PD_ALWAYS_ON>;
237 ipmmu_hc: mmu@e6570000 {
238 compatible = "renesas,ipmmu-r8a77990";
239 reg = <0 0xe6570000 0 0x1000>;
240 renesas,ipmmu-main = <&ipmmu_mm 2>;
241 power-domains = <&sysc R8A77990_PD_ALWAYS_ON>;
245 ipmmu_mm: mmu@e67b0000 {
246 compatible = "renesas,ipmmu-r8a77990";
247 reg = <0 0xe67b0000 0 0x1000>;
248 interrupts = <GIC_SPI 196 IRQ_TYPE_LEVEL_HIGH>,
249 <GIC_SPI 197 IRQ_TYPE_LEVEL_HIGH>;
250 power-domains = <&sysc R8A77990_PD_ALWAYS_ON>;
254 ipmmu_mp: mmu@ec670000 {
255 compatible = "renesas,ipmmu-r8a77990";
256 reg = <0 0xec670000 0 0x1000>;
257 renesas,ipmmu-main = <&ipmmu_mm 4>;
258 power-domains = <&sysc R8A77990_PD_ALWAYS_ON>;
262 ipmmu_pv0: mmu@fd800000 {
263 compatible = "renesas,ipmmu-r8a77990";
264 reg = <0 0xfd800000 0 0x1000>;
265 renesas,ipmmu-main = <&ipmmu_mm 6>;
266 power-domains = <&sysc R8A77990_PD_ALWAYS_ON>;
270 ipmmu_rt: mmu@ffc80000 {
271 compatible = "renesas,ipmmu-r8a77990";
272 reg = <0 0xffc80000 0 0x1000>;
273 renesas,ipmmu-main = <&ipmmu_mm 10>;
274 power-domains = <&sysc R8A77990_PD_ALWAYS_ON>;
278 ipmmu_vc0: mmu@fe6b0000 {
279 compatible = "renesas,ipmmu-r8a77990";
280 reg = <0 0xfe6b0000 0 0x1000>;
281 renesas,ipmmu-main = <&ipmmu_mm 12>;
282 power-domains = <&sysc R8A77990_PD_A3VC>;
286 ipmmu_vi0: mmu@febd0000 {
287 compatible = "renesas,ipmmu-r8a77990";
288 reg = <0 0xfebd0000 0 0x1000>;
289 renesas,ipmmu-main = <&ipmmu_mm 14>;
290 power-domains = <&sysc R8A77990_PD_ALWAYS_ON>;
294 ipmmu_vp0: mmu@fe990000 {
295 compatible = "renesas,ipmmu-r8a77990";
296 reg = <0 0xfe990000 0 0x1000>;
297 renesas,ipmmu-main = <&ipmmu_mm 16>;
298 power-domains = <&sysc R8A77990_PD_ALWAYS_ON>;
302 avb: ethernet@e6800000 {
303 compatible = "renesas,etheravb-r8a77990",
304 "renesas,etheravb-rcar-gen3";
305 reg = <0 0xe6800000 0 0x800>;
306 interrupts = <GIC_SPI 39 IRQ_TYPE_LEVEL_HIGH>,
307 <GIC_SPI 40 IRQ_TYPE_LEVEL_HIGH>,
308 <GIC_SPI 41 IRQ_TYPE_LEVEL_HIGH>,
309 <GIC_SPI 42 IRQ_TYPE_LEVEL_HIGH>,
310 <GIC_SPI 43 IRQ_TYPE_LEVEL_HIGH>,
311 <GIC_SPI 44 IRQ_TYPE_LEVEL_HIGH>,
312 <GIC_SPI 45 IRQ_TYPE_LEVEL_HIGH>,
313 <GIC_SPI 46 IRQ_TYPE_LEVEL_HIGH>,
314 <GIC_SPI 47 IRQ_TYPE_LEVEL_HIGH>,
315 <GIC_SPI 48 IRQ_TYPE_LEVEL_HIGH>,
316 <GIC_SPI 49 IRQ_TYPE_LEVEL_HIGH>,
317 <GIC_SPI 50 IRQ_TYPE_LEVEL_HIGH>,
318 <GIC_SPI 51 IRQ_TYPE_LEVEL_HIGH>,
319 <GIC_SPI 52 IRQ_TYPE_LEVEL_HIGH>,
320 <GIC_SPI 53 IRQ_TYPE_LEVEL_HIGH>,
321 <GIC_SPI 54 IRQ_TYPE_LEVEL_HIGH>,
322 <GIC_SPI 55 IRQ_TYPE_LEVEL_HIGH>,
323 <GIC_SPI 56 IRQ_TYPE_LEVEL_HIGH>,
324 <GIC_SPI 57 IRQ_TYPE_LEVEL_HIGH>,
325 <GIC_SPI 58 IRQ_TYPE_LEVEL_HIGH>,
326 <GIC_SPI 59 IRQ_TYPE_LEVEL_HIGH>,
327 <GIC_SPI 60 IRQ_TYPE_LEVEL_HIGH>,
328 <GIC_SPI 61 IRQ_TYPE_LEVEL_HIGH>,
329 <GIC_SPI 62 IRQ_TYPE_LEVEL_HIGH>,
330 <GIC_SPI 63 IRQ_TYPE_LEVEL_HIGH>;
331 interrupt-names = "ch0", "ch1", "ch2", "ch3",
332 "ch4", "ch5", "ch6", "ch7",
333 "ch8", "ch9", "ch10", "ch11",
334 "ch12", "ch13", "ch14", "ch15",
335 "ch16", "ch17", "ch18", "ch19",
336 "ch20", "ch21", "ch22", "ch23",
338 clocks = <&cpg CPG_MOD 812>;
339 power-domains = <&sysc R8A77990_PD_ALWAYS_ON>;
342 #address-cells = <1>;
348 compatible = "renesas,pwm-r8a77990", "renesas,pwm-rcar";
349 reg = <0 0xe6e30000 0 0x8>;
350 clocks = <&cpg CPG_MOD 523>;
351 power-domains = <&sysc R8A77990_PD_ALWAYS_ON>;
358 compatible = "renesas,pwm-r8a77990", "renesas,pwm-rcar";
359 reg = <0 0xe6e31000 0 0x8>;
360 clocks = <&cpg CPG_MOD 523>;
361 power-domains = <&sysc R8A77990_PD_ALWAYS_ON>;
368 compatible = "renesas,pwm-r8a77990", "renesas,pwm-rcar";
369 reg = <0 0xe6e32000 0 0x8>;
370 clocks = <&cpg CPG_MOD 523>;
371 power-domains = <&sysc R8A77990_PD_ALWAYS_ON>;
378 compatible = "renesas,pwm-r8a77990", "renesas,pwm-rcar";
379 reg = <0 0xe6e33000 0 0x8>;
380 clocks = <&cpg CPG_MOD 523>;
381 power-domains = <&sysc R8A77990_PD_ALWAYS_ON>;
388 compatible = "renesas,pwm-r8a77990", "renesas,pwm-rcar";
389 reg = <0 0xe6e34000 0 0x8>;
390 clocks = <&cpg CPG_MOD 523>;
391 power-domains = <&sysc R8A77990_PD_ALWAYS_ON>;
398 compatible = "renesas,pwm-r8a77990", "renesas,pwm-rcar";
399 reg = <0 0xe6e35000 0 0x8>;
400 clocks = <&cpg CPG_MOD 523>;
401 power-domains = <&sysc R8A77990_PD_ALWAYS_ON>;
408 compatible = "renesas,pwm-r8a77990", "renesas,pwm-rcar";
409 reg = <0 0xe6e36000 0 0x8>;
410 clocks = <&cpg CPG_MOD 523>;
411 power-domains = <&sysc R8A77990_PD_ALWAYS_ON>;
417 scif2: serial@e6e88000 {
418 compatible = "renesas,scif-r8a77990",
419 "renesas,rcar-gen3-scif", "renesas,scif";
420 reg = <0 0xe6e88000 0 64>;
421 interrupts = <GIC_SPI 164 IRQ_TYPE_LEVEL_HIGH>;
422 clocks = <&cpg CPG_MOD 310>,
423 <&cpg CPG_CORE R8A77990_CLK_S3D1C>,
425 clock-names = "fck", "brg_int", "scif_clk";
427 power-domains = <&sysc R8A77990_PD_ALWAYS_ON>;
432 xhci0: usb@ee000000 {
433 compatible = "renesas,xhci-r8a77990",
434 "renesas,rcar-gen3-xhci";
435 reg = <0 0xee000000 0 0xc00>;
436 interrupts = <GIC_SPI 102 IRQ_TYPE_LEVEL_HIGH>;
437 clocks = <&cpg CPG_MOD 328>;
438 power-domains = <&sysc R8A77990_PD_ALWAYS_ON>;
443 ohci0: usb@ee080000 {
444 compatible = "generic-ohci";
445 reg = <0 0xee080000 0 0x100>;
446 interrupts = <GIC_SPI 108 IRQ_TYPE_LEVEL_HIGH>;
447 clocks = <&cpg CPG_MOD 703>;
450 power-domains = <&sysc R8A77990_PD_ALWAYS_ON>;
455 ehci0: usb@ee080100 {
456 compatible = "generic-ehci";
457 reg = <0 0xee080100 0 0x100>;
458 interrupts = <GIC_SPI 108 IRQ_TYPE_LEVEL_HIGH>;
459 clocks = <&cpg CPG_MOD 703>;
462 companion = <&ohci0>;
463 power-domains = <&sysc R8A77990_PD_ALWAYS_ON>;
468 usb2_phy0: usb-phy@ee080200 {
469 compatible = "renesas,usb2-phy-r8a77990",
470 "renesas,rcar-gen3-usb2-phy";
471 reg = <0 0xee080200 0 0x700>;
472 interrupts = <GIC_SPI 108 IRQ_TYPE_LEVEL_HIGH>;
473 clocks = <&cpg CPG_MOD 703>;
474 power-domains = <&sysc R8A77990_PD_ALWAYS_ON>;
480 gic: interrupt-controller@f1010000 {
481 compatible = "arm,gic-400";
482 #interrupt-cells = <3>;
483 #address-cells = <0>;
484 interrupt-controller;
485 reg = <0x0 0xf1010000 0 0x1000>,
486 <0x0 0xf1020000 0 0x20000>,
487 <0x0 0xf1040000 0 0x20000>,
488 <0x0 0xf1060000 0 0x20000>;
489 interrupts = <GIC_PPI 9
490 (GIC_CPU_MASK_SIMPLE(2) | IRQ_TYPE_LEVEL_HIGH)>;
491 clocks = <&cpg CPG_MOD 408>;
493 power-domains = <&sysc R8A77990_PD_ALWAYS_ON>;
497 prr: chipid@fff00044 {
498 compatible = "renesas,prr";
499 reg = <0 0xfff00044 0 4>;
504 compatible = "arm,armv8-timer";
505 interrupts-extended = <&gic GIC_PPI 13 (GIC_CPU_MASK_SIMPLE(2) | IRQ_TYPE_LEVEL_LOW)>,
506 <&gic GIC_PPI 14 (GIC_CPU_MASK_SIMPLE(2) | IRQ_TYPE_LEVEL_LOW)>,
507 <&gic GIC_PPI 11 (GIC_CPU_MASK_SIMPLE(2) | IRQ_TYPE_LEVEL_LOW)>,
508 <&gic GIC_PPI 10 (GIC_CPU_MASK_SIMPLE(2) | IRQ_TYPE_LEVEL_LOW)>;