blob: 6d2d5e106890c67019e02b11331f62d8d189fc79 [file] [log] [blame]
Yoshihiro Shimodaac05eba2018-04-11 18:37:41 +09001/* SPDX-License-Identifier: GPL-2.0 */
2/*
3 * Device Tree Source for the r8a77990 SoC
4 *
5 * Copyright (C) 2018 Renesas Electronics Corp.
6 */
7
8#include <dt-bindings/clock/renesas-cpg-mssr.h>
9#include <dt-bindings/interrupt-controller/arm-gic.h>
10
11/ {
12 compatible = "renesas,r8a77990";
13 #address-cells = <2>;
14 #size-cells = <2>;
15
16 cpus {
17 #address-cells = <1>;
18 #size-cells = <0>;
19
20 /* 1 core only at this point */
21 a53_0: cpu@0 {
22 compatible = "arm,cortex-a53", "arm,armv8";
23 reg = <0x0>;
24 device_type = "cpu";
25 power-domains = <&sysc 5>;
26 next-level-cache = <&L2_CA53>;
27 enable-method = "psci";
28 };
29
Marek Vasut9e763fc2018-05-31 18:30:17 +020030 L2_CA53: cache-controller-0 {
Yoshihiro Shimodaac05eba2018-04-11 18:37:41 +090031 compatible = "cache";
Yoshihiro Shimodaac05eba2018-04-11 18:37:41 +090032 power-domains = <&sysc 21>;
33 cache-unified;
34 cache-level = <2>;
35 };
36 };
37
38 extal_clk: extal {
39 compatible = "fixed-clock";
40 #clock-cells = <0>;
41 /* This value must be overridden by the board */
42 clock-frequency = <0>;
43 };
44
Marek Vasut9e763fc2018-05-31 18:30:17 +020045 pmu_a53 {
46 compatible = "arm,cortex-a53-pmu";
47 interrupts-extended = <&gic GIC_SPI 84 IRQ_TYPE_LEVEL_HIGH>;
48 interrupt-affinity = <&a53_0>;
49 };
50
Yoshihiro Shimodaac05eba2018-04-11 18:37:41 +090051 psci {
Marek Vasut9e763fc2018-05-31 18:30:17 +020052 compatible = "arm,psci-1.0", "arm,psci-0.2";
Yoshihiro Shimodaac05eba2018-04-11 18:37:41 +090053 method = "smc";
54 };
55
56 soc: soc {
57 compatible = "simple-bus";
58 interrupt-parent = <&gic>;
59 #address-cells = <2>;
60 #size-cells = <2>;
61 ranges;
62
Marek Vasut9e763fc2018-05-31 18:30:17 +020063 gpio0: gpio@e6050000 {
64 compatible = "renesas,gpio-r8a77990",
65 "renesas,rcar-gen3-gpio";
66 reg = <0 0xe6050000 0 0x50>;
67 interrupts = <GIC_SPI 4 IRQ_TYPE_LEVEL_HIGH>;
68 #gpio-cells = <2>;
69 gpio-controller;
70 gpio-ranges = <&pfc 0 0 18>;
71 #interrupt-cells = <2>;
Yoshihiro Shimodaac05eba2018-04-11 18:37:41 +090072 interrupt-controller;
Marek Vasut9e763fc2018-05-31 18:30:17 +020073 clocks = <&cpg CPG_MOD 912>;
Yoshihiro Shimodaac05eba2018-04-11 18:37:41 +090074 power-domains = <&sysc 32>;
Marek Vasut9e763fc2018-05-31 18:30:17 +020075 resets = <&cpg 912>;
76 };
77
78 gpio1: gpio@e6051000 {
79 compatible = "renesas,gpio-r8a77990",
80 "renesas,rcar-gen3-gpio";
81 reg = <0 0xe6051000 0 0x50>;
82 interrupts = <GIC_SPI 5 IRQ_TYPE_LEVEL_HIGH>;
83 #gpio-cells = <2>;
84 gpio-controller;
85 gpio-ranges = <&pfc 0 32 23>;
86 #interrupt-cells = <2>;
87 interrupt-controller;
88 clocks = <&cpg CPG_MOD 911>;
89 power-domains = <&sysc 32>;
90 resets = <&cpg 911>;
91 };
92
93 gpio2: gpio@e6052000 {
94 compatible = "renesas,gpio-r8a77990",
95 "renesas,rcar-gen3-gpio";
96 reg = <0 0xe6052000 0 0x50>;
97 interrupts = <GIC_SPI 6 IRQ_TYPE_LEVEL_HIGH>;
98 #gpio-cells = <2>;
99 gpio-controller;
100 gpio-ranges = <&pfc 0 64 26>;
101 #interrupt-cells = <2>;
102 interrupt-controller;
103 clocks = <&cpg CPG_MOD 910>;
104 power-domains = <&sysc 32>;
105 resets = <&cpg 910>;
106 };
107
108 gpio3: gpio@e6053000 {
109 compatible = "renesas,gpio-r8a77990",
110 "renesas,rcar-gen3-gpio";
111 reg = <0 0xe6053000 0 0x50>;
112 interrupts = <GIC_SPI 7 IRQ_TYPE_LEVEL_HIGH>;
113 #gpio-cells = <2>;
114 gpio-controller;
115 gpio-ranges = <&pfc 0 96 16>;
116 #interrupt-cells = <2>;
117 interrupt-controller;
118 clocks = <&cpg CPG_MOD 909>;
119 power-domains = <&sysc 32>;
120 resets = <&cpg 909>;
121 };
122
123 gpio4: gpio@e6054000 {
124 compatible = "renesas,gpio-r8a77990",
125 "renesas,rcar-gen3-gpio";
126 reg = <0 0xe6054000 0 0x50>;
127 interrupts = <GIC_SPI 8 IRQ_TYPE_LEVEL_HIGH>;
128 #gpio-cells = <2>;
129 gpio-controller;
130 gpio-ranges = <&pfc 0 128 11>;
131 #interrupt-cells = <2>;
132 interrupt-controller;
133 clocks = <&cpg CPG_MOD 908>;
134 power-domains = <&sysc 32>;
135 resets = <&cpg 908>;
136 };
137
138 gpio5: gpio@e6055000 {
139 compatible = "renesas,gpio-r8a77990",
140 "renesas,rcar-gen3-gpio";
141 reg = <0 0xe6055000 0 0x50>;
142 interrupts = <GIC_SPI 9 IRQ_TYPE_LEVEL_HIGH>;
143 #gpio-cells = <2>;
144 gpio-controller;
145 gpio-ranges = <&pfc 0 160 20>;
146 #interrupt-cells = <2>;
147 interrupt-controller;
148 clocks = <&cpg CPG_MOD 907>;
149 power-domains = <&sysc 32>;
150 resets = <&cpg 907>;
Yoshihiro Shimodaac05eba2018-04-11 18:37:41 +0900151 };
152
Marek Vasut9e763fc2018-05-31 18:30:17 +0200153 gpio6: gpio@e6055400 {
154 compatible = "renesas,gpio-r8a77990",
155 "renesas,rcar-gen3-gpio";
156 reg = <0 0xe6055400 0 0x50>;
157 interrupts = <GIC_SPI 10 IRQ_TYPE_LEVEL_HIGH>;
158 #gpio-cells = <2>;
159 gpio-controller;
160 gpio-ranges = <&pfc 0 192 18>;
161 #interrupt-cells = <2>;
162 interrupt-controller;
163 clocks = <&cpg CPG_MOD 906>;
164 power-domains = <&sysc 32>;
165 resets = <&cpg 906>;
Yoshihiro Shimodaac05eba2018-04-11 18:37:41 +0900166 };
167
Marek Vasut9e763fc2018-05-31 18:30:17 +0200168 pfc: pin-controller@e6060000 {
169 compatible = "renesas,pfc-r8a77990";
170 reg = <0 0xe6060000 0 0x508>;
Yoshihiro Shimodaac05eba2018-04-11 18:37:41 +0900171 };
172
173 cpg: clock-controller@e6150000 {
174 compatible = "renesas,r8a77990-cpg-mssr";
175 reg = <0 0xe6150000 0 0x1000>;
176 clocks = <&extal_clk>;
177 clock-names = "extal";
178 #clock-cells = <2>;
179 #power-domain-cells = <0>;
180 #reset-cells = <1>;
181 };
182
183 rst: reset-controller@e6160000 {
184 compatible = "renesas,r8a77990-rst";
185 reg = <0 0xe6160000 0 0x0200>;
186 };
187
Marek Vasut66cc5602018-05-31 19:56:36 +0200188 sdhi0: sd@ee100000 {
189 compatible = "renesas,sdhi-r8a77990";
190 reg = <0 0xee100000 0 0x2000>;
191 clocks = <&cpg CPG_MOD 314>;
192 max-frequency = <200000000>;
193 status = "disabled";
194 };
195
196 sdhi1: sd@ee120000 {
197 compatible = "renesas,sdhi-r8a77990";
198 reg = <0 0xee120000 0 0x2000>;
199 clocks = <&cpg CPG_MOD 313>;
200 max-frequency = <200000000>;
201 status = "disabled";
202 };
203
204 sdhi3: sd@ee160000 {
205 compatible = "renesas,sdhi-r8a77990";
206 reg = <0 0xee160000 0 0x2000>;
207 clocks = <&cpg CPG_MOD 311>;
208 max-frequency = <200000000>;
209 status = "disabled";
210 };
211
Yoshihiro Shimodaac05eba2018-04-11 18:37:41 +0900212 sysc: system-controller@e6180000 {
213 compatible = "renesas,r8a77990-sysc";
214 reg = <0 0xe6180000 0 0x0400>;
215 #power-domain-cells = <1>;
216 };
217
Marek Vasut9e763fc2018-05-31 18:30:17 +0200218 avb: ethernet@e6800000 {
219 compatible = "renesas,etheravb-r8a77990",
220 "renesas,etheravb-rcar-gen3";
221 reg = <0 0xe6800000 0 0x800>, <0 0xe6a00000 0 0x10000>;
222 interrupts = <GIC_SPI 39 IRQ_TYPE_LEVEL_HIGH>,
223 <GIC_SPI 40 IRQ_TYPE_LEVEL_HIGH>,
224 <GIC_SPI 41 IRQ_TYPE_LEVEL_HIGH>,
225 <GIC_SPI 42 IRQ_TYPE_LEVEL_HIGH>,
226 <GIC_SPI 43 IRQ_TYPE_LEVEL_HIGH>,
227 <GIC_SPI 44 IRQ_TYPE_LEVEL_HIGH>,
228 <GIC_SPI 45 IRQ_TYPE_LEVEL_HIGH>,
229 <GIC_SPI 46 IRQ_TYPE_LEVEL_HIGH>,
230 <GIC_SPI 47 IRQ_TYPE_LEVEL_HIGH>,
231 <GIC_SPI 48 IRQ_TYPE_LEVEL_HIGH>,
232 <GIC_SPI 49 IRQ_TYPE_LEVEL_HIGH>,
233 <GIC_SPI 50 IRQ_TYPE_LEVEL_HIGH>,
234 <GIC_SPI 51 IRQ_TYPE_LEVEL_HIGH>,
235 <GIC_SPI 52 IRQ_TYPE_LEVEL_HIGH>,
236 <GIC_SPI 53 IRQ_TYPE_LEVEL_HIGH>,
237 <GIC_SPI 54 IRQ_TYPE_LEVEL_HIGH>,
238 <GIC_SPI 55 IRQ_TYPE_LEVEL_HIGH>,
239 <GIC_SPI 56 IRQ_TYPE_LEVEL_HIGH>,
240 <GIC_SPI 57 IRQ_TYPE_LEVEL_HIGH>,
241 <GIC_SPI 58 IRQ_TYPE_LEVEL_HIGH>,
242 <GIC_SPI 59 IRQ_TYPE_LEVEL_HIGH>,
243 <GIC_SPI 60 IRQ_TYPE_LEVEL_HIGH>,
244 <GIC_SPI 61 IRQ_TYPE_LEVEL_HIGH>,
245 <GIC_SPI 62 IRQ_TYPE_LEVEL_HIGH>,
246 <GIC_SPI 63 IRQ_TYPE_LEVEL_HIGH>;
247 interrupt-names = "ch0", "ch1", "ch2", "ch3",
248 "ch4", "ch5", "ch6", "ch7",
249 "ch8", "ch9", "ch10", "ch11",
250 "ch12", "ch13", "ch14", "ch15",
251 "ch16", "ch17", "ch18", "ch19",
252 "ch20", "ch21", "ch22", "ch23",
253 "ch24";
254 clocks = <&cpg CPG_MOD 812>;
255 power-domains = <&sysc 32>;
256 resets = <&cpg 812>;
257 phy-mode = "rgmii";
258 #address-cells = <1>;
259 #size-cells = <0>;
260 status = "disabled";
261 };
262
Yoshihiro Shimodaac05eba2018-04-11 18:37:41 +0900263 scif2: serial@e6e88000 {
264 compatible = "renesas,scif-r8a77990",
265 "renesas,rcar-gen3-scif", "renesas,scif";
266 reg = <0 0xe6e88000 0 64>;
267 interrupts = <GIC_SPI 164 IRQ_TYPE_LEVEL_HIGH>;
268 clocks = <&cpg CPG_MOD 310>;
269 clock-names = "fck";
270 power-domains = <&sysc 32>;
271 resets = <&cpg 310>;
272 status = "disabled";
273 };
Marek Vasut9e763fc2018-05-31 18:30:17 +0200274
275 gic: interrupt-controller@f1010000 {
276 compatible = "arm,gic-400";
277 #interrupt-cells = <3>;
278 #address-cells = <0>;
279 interrupt-controller;
280 reg = <0x0 0xf1010000 0 0x1000>,
281 <0x0 0xf1020000 0 0x20000>,
282 <0x0 0xf1040000 0 0x20000>,
283 <0x0 0xf1060000 0 0x20000>;
284 interrupts = <GIC_PPI 9
285 (GIC_CPU_MASK_SIMPLE(1) | IRQ_TYPE_LEVEL_HIGH)>;
286 clocks = <&cpg CPG_MOD 408>;
287 clock-names = "clk";
288 power-domains = <&sysc 32>;
289 resets = <&cpg 408>;
290 };
291
292 prr: chipid@fff00044 {
293 compatible = "renesas,prr";
294 reg = <0 0xfff00044 0 4>;
295 };
Marek Vasut5b828542018-06-13 21:15:54 +0200296
297 rpc: rpc@0xee200000 {
298 compatible = "renesas,rpc-r8a77990", "renesas,rpc";
299 reg = <0 0xee200000 0 0x100>, <0 0x08000000 0 0>;
300 clocks = <&cpg CPG_MOD 917>;
301 bank-width = <2>;
302 status = "disabled";
303 };
Marek Vasut9e763fc2018-05-31 18:30:17 +0200304 };
305
306 timer {
307 compatible = "arm,armv8-timer";
308 interrupts-extended = <&gic GIC_PPI 13 (GIC_CPU_MASK_SIMPLE(1) | IRQ_TYPE_LEVEL_LOW)>,
309 <&gic GIC_PPI 14 (GIC_CPU_MASK_SIMPLE(1) | IRQ_TYPE_LEVEL_LOW)>,
310 <&gic GIC_PPI 11 (GIC_CPU_MASK_SIMPLE(1) | IRQ_TYPE_LEVEL_LOW)>,
311 <&gic GIC_PPI 10 (GIC_CPU_MASK_SIMPLE(1) | IRQ_TYPE_LEVEL_LOW)>;
Yoshihiro Shimodaac05eba2018-04-11 18:37:41 +0900312 };
313};