blob: b4a6c3b43ee933403b854b509600edf3bcaf46ac [file] [log] [blame]
Magnus Dammeccf0602013-03-26 10:34:24 +09001/*
2 * Device Tree Source for the r8a73a4 SoC
3 *
4 * Copyright (C) 2013 Renesas Solutions Corp.
5 * Copyright (C) 2013 Magnus Damm
6 *
7 * This file is licensed under the terms of the GNU General Public License
8 * version 2. This program is licensed "as is" without any warranty of any
9 * kind, whether express or implied.
10 */
11
Laurent Pinchart5f75e732013-11-19 03:18:25 +010012#include <dt-bindings/interrupt-controller/arm-gic.h>
13#include <dt-bindings/interrupt-controller/irq.h>
14
Magnus Dammeccf0602013-03-26 10:34:24 +090015/ {
16 compatible = "renesas,r8a73a4";
17 interrupt-parent = <&gic>;
Takashi Yoshii26a0d2d2013-03-29 16:45:56 +090018 #address-cells = <2>;
19 #size-cells = <2>;
Magnus Dammeccf0602013-03-26 10:34:24 +090020
21 cpus {
22 #address-cells = <1>;
23 #size-cells = <0>;
24
25 cpu0: cpu@0 {
26 device_type = "cpu";
27 compatible = "arm,cortex-a15";
28 reg = <0>;
29 clock-frequency = <1500000000>;
30 };
31 };
32
33 gic: interrupt-controller@f1001000 {
34 compatible = "arm,cortex-a15-gic";
35 #interrupt-cells = <3>;
36 #address-cells = <0>;
37 interrupt-controller;
Takashi Yoshii26a0d2d2013-03-29 16:45:56 +090038 reg = <0 0xf1001000 0 0x1000>,
39 <0 0xf1002000 0 0x1000>,
40 <0 0xf1004000 0 0x2000>,
41 <0 0xf1006000 0 0x2000>;
Laurent Pinchart5f75e732013-11-19 03:18:25 +010042 interrupts = <1 9 (GIC_CPU_MASK_SIMPLE(4) | IRQ_TYPE_LEVEL_HIGH)>;
Magnus Dammeccf0602013-03-26 10:34:24 +090043 };
44
45 timer {
46 compatible = "arm,armv7-timer";
Laurent Pinchart5f75e732013-11-19 03:18:25 +010047 interrupts = <1 13 (GIC_CPU_MASK_SIMPLE(4) | IRQ_TYPE_LEVEL_LOW)>,
48 <1 14 (GIC_CPU_MASK_SIMPLE(4) | IRQ_TYPE_LEVEL_LOW)>,
49 <1 11 (GIC_CPU_MASK_SIMPLE(4) | IRQ_TYPE_LEVEL_LOW)>,
50 <1 10 (GIC_CPU_MASK_SIMPLE(4) | IRQ_TYPE_LEVEL_LOW)>;
Magnus Dammeccf0602013-03-26 10:34:24 +090051 };
Magnus Damm984ca292013-03-26 10:34:42 +090052
53 irqc0: interrupt-controller@e61c0000 {
54 compatible = "renesas,irqc";
55 #interrupt-cells = <2>;
56 interrupt-controller;
Takashi Yoshii26a0d2d2013-03-29 16:45:56 +090057 reg = <0 0xe61c0000 0 0x200>;
Magnus Damm984ca292013-03-26 10:34:42 +090058 interrupt-parent = <&gic>;
Laurent Pinchart5f75e732013-11-19 03:18:25 +010059 interrupts = <0 0 IRQ_TYPE_LEVEL_HIGH>,
60 <0 1 IRQ_TYPE_LEVEL_HIGH>,
61 <0 2 IRQ_TYPE_LEVEL_HIGH>,
62 <0 3 IRQ_TYPE_LEVEL_HIGH>,
63 <0 4 IRQ_TYPE_LEVEL_HIGH>,
64 <0 5 IRQ_TYPE_LEVEL_HIGH>,
65 <0 6 IRQ_TYPE_LEVEL_HIGH>,
66 <0 7 IRQ_TYPE_LEVEL_HIGH>,
67 <0 8 IRQ_TYPE_LEVEL_HIGH>,
68 <0 9 IRQ_TYPE_LEVEL_HIGH>,
69 <0 10 IRQ_TYPE_LEVEL_HIGH>,
70 <0 11 IRQ_TYPE_LEVEL_HIGH>,
71 <0 12 IRQ_TYPE_LEVEL_HIGH>,
72 <0 13 IRQ_TYPE_LEVEL_HIGH>,
73 <0 14 IRQ_TYPE_LEVEL_HIGH>,
74 <0 15 IRQ_TYPE_LEVEL_HIGH>,
75 <0 16 IRQ_TYPE_LEVEL_HIGH>,
76 <0 17 IRQ_TYPE_LEVEL_HIGH>,
77 <0 18 IRQ_TYPE_LEVEL_HIGH>,
78 <0 19 IRQ_TYPE_LEVEL_HIGH>,
79 <0 20 IRQ_TYPE_LEVEL_HIGH>,
80 <0 21 IRQ_TYPE_LEVEL_HIGH>,
81 <0 22 IRQ_TYPE_LEVEL_HIGH>,
82 <0 23 IRQ_TYPE_LEVEL_HIGH>,
83 <0 24 IRQ_TYPE_LEVEL_HIGH>,
84 <0 25 IRQ_TYPE_LEVEL_HIGH>,
85 <0 26 IRQ_TYPE_LEVEL_HIGH>,
86 <0 27 IRQ_TYPE_LEVEL_HIGH>,
87 <0 28 IRQ_TYPE_LEVEL_HIGH>,
88 <0 29 IRQ_TYPE_LEVEL_HIGH>,
89 <0 30 IRQ_TYPE_LEVEL_HIGH>,
90 <0 31 IRQ_TYPE_LEVEL_HIGH>;
Magnus Damm984ca292013-03-26 10:34:42 +090091 };
92
93 irqc1: interrupt-controller@e61c0200 {
94 compatible = "renesas,irqc";
95 #interrupt-cells = <2>;
96 interrupt-controller;
Takashi Yoshii26a0d2d2013-03-29 16:45:56 +090097 reg = <0 0xe61c0200 0 0x200>;
Magnus Damm984ca292013-03-26 10:34:42 +090098 interrupt-parent = <&gic>;
Laurent Pinchart5f75e732013-11-19 03:18:25 +010099 interrupts = <0 32 IRQ_TYPE_LEVEL_HIGH>,
100 <0 33 IRQ_TYPE_LEVEL_HIGH>,
101 <0 34 IRQ_TYPE_LEVEL_HIGH>,
102 <0 35 IRQ_TYPE_LEVEL_HIGH>,
103 <0 36 IRQ_TYPE_LEVEL_HIGH>,
104 <0 37 IRQ_TYPE_LEVEL_HIGH>,
105 <0 38 IRQ_TYPE_LEVEL_HIGH>,
106 <0 39 IRQ_TYPE_LEVEL_HIGH>,
107 <0 40 IRQ_TYPE_LEVEL_HIGH>,
108 <0 41 IRQ_TYPE_LEVEL_HIGH>,
109 <0 42 IRQ_TYPE_LEVEL_HIGH>,
110 <0 43 IRQ_TYPE_LEVEL_HIGH>,
111 <0 44 IRQ_TYPE_LEVEL_HIGH>,
112 <0 45 IRQ_TYPE_LEVEL_HIGH>,
113 <0 46 IRQ_TYPE_LEVEL_HIGH>,
114 <0 47 IRQ_TYPE_LEVEL_HIGH>,
115 <0 48 IRQ_TYPE_LEVEL_HIGH>,
116 <0 49 IRQ_TYPE_LEVEL_HIGH>,
117 <0 50 IRQ_TYPE_LEVEL_HIGH>,
118 <0 51 IRQ_TYPE_LEVEL_HIGH>,
119 <0 52 IRQ_TYPE_LEVEL_HIGH>,
120 <0 53 IRQ_TYPE_LEVEL_HIGH>,
121 <0 54 IRQ_TYPE_LEVEL_HIGH>,
122 <0 55 IRQ_TYPE_LEVEL_HIGH>,
123 <0 56 IRQ_TYPE_LEVEL_HIGH>,
124 <0 57 IRQ_TYPE_LEVEL_HIGH>;
Magnus Damm984ca292013-03-26 10:34:42 +0900125 };
126
Guennadi Liakhovetski734e2ce2013-09-26 19:30:03 +0200127 dmac: dma-multiplexer@0 {
128 compatible = "renesas,shdma-mux";
129 #dma-cells = <1>;
130 dma-channels = <20>;
131 dma-requests = <256>;
132 #address-cells = <2>;
133 #size-cells = <2>;
134 ranges;
135
136 dma0: dma-controller@e6700020 {
137 compatible = "renesas,shdma-r8a73a4";
138 reg = <0 0xe6700020 0 0x89e0>;
139 interrupt-parent = <&gic>;
140 interrupts = <0 220 4
141 0 200 4
142 0 201 4
143 0 202 4
144 0 203 4
145 0 204 4
146 0 205 4
147 0 206 4
148 0 207 4
149 0 208 4
150 0 209 4
151 0 210 4
152 0 211 4
153 0 212 4
154 0 213 4
155 0 214 4
156 0 215 4
157 0 216 4
158 0 217 4
159 0 218 4
160 0 219 4>;
161 interrupt-names = "error",
162 "ch0", "ch1", "ch2", "ch3",
163 "ch4", "ch5", "ch6", "ch7",
164 "ch8", "ch9", "ch10", "ch11",
165 "ch12", "ch13", "ch14", "ch15",
166 "ch16", "ch17", "ch18", "ch19";
167 };
168 };
169
Kuninori Morimotoc91cf2f2013-03-25 23:18:15 -0700170 thermal@e61f0000 {
171 compatible = "renesas,rcar-thermal";
Takashi Yoshii26a0d2d2013-03-29 16:45:56 +0900172 reg = <0 0xe61f0000 0 0x14>, <0 0xe61f0100 0 0x38>,
173 <0 0xe61f0200 0 0x38>, <0 0xe61f0300 0 0x38>;
Kuninori Morimotoc91cf2f2013-03-25 23:18:15 -0700174 interrupt-parent = <&gic>;
Laurent Pinchart5f75e732013-11-19 03:18:25 +0100175 interrupts = <0 69 IRQ_TYPE_LEVEL_HIGH>;
Kuninori Morimotoc91cf2f2013-03-25 23:18:15 -0700176 };
Guennadi Liakhovetskif98c1062013-06-27 11:47:57 +0200177
178 i2c0: i2c@e6500000 {
179 #address-cells = <1>;
180 #size-cells = <0>;
181 compatible = "renesas,rmobile-iic";
182 reg = <0 0xe6500000 0 0x428>;
183 interrupt-parent = <&gic>;
184 interrupts = <0 174 0x4>;
Guennadi Liakhovetskieda3a4f2013-09-26 13:06:01 +0200185 status = "disabled";
Guennadi Liakhovetskif98c1062013-06-27 11:47:57 +0200186 };
187
188 i2c1: i2c@e6510000 {
189 #address-cells = <1>;
190 #size-cells = <0>;
191 compatible = "renesas,rmobile-iic";
192 reg = <0 0xe6510000 0 0x428>;
193 interrupt-parent = <&gic>;
194 interrupts = <0 175 0x4>;
Guennadi Liakhovetskieda3a4f2013-09-26 13:06:01 +0200195 status = "disabled";
Guennadi Liakhovetskif98c1062013-06-27 11:47:57 +0200196 };
197
198 i2c2: i2c@e6520000 {
199 #address-cells = <1>;
200 #size-cells = <0>;
201 compatible = "renesas,rmobile-iic";
202 reg = <0 0xe6520000 0 0x428>;
203 interrupt-parent = <&gic>;
204 interrupts = <0 176 0x4>;
Guennadi Liakhovetskieda3a4f2013-09-26 13:06:01 +0200205 status = "disabled";
Guennadi Liakhovetskif98c1062013-06-27 11:47:57 +0200206 };
207
208 i2c3: i2c@e6530000 {
209 #address-cells = <1>;
210 #size-cells = <0>;
211 compatible = "renesas,rmobile-iic";
212 reg = <0 0xe6530000 0 0x428>;
213 interrupt-parent = <&gic>;
214 interrupts = <0 177 0x4>;
Guennadi Liakhovetskieda3a4f2013-09-26 13:06:01 +0200215 status = "disabled";
Guennadi Liakhovetskif98c1062013-06-27 11:47:57 +0200216 };
217
218 i2c4: i2c@e6540000 {
219 #address-cells = <1>;
220 #size-cells = <0>;
221 compatible = "renesas,rmobile-iic";
222 reg = <0 0xe6540000 0 0x428>;
223 interrupt-parent = <&gic>;
Laurent Pinchart5f75e732013-11-19 03:18:25 +0100224 interrupts = <0 178 IRQ_TYPE_LEVEL_HIGH>;
Guennadi Liakhovetskieda3a4f2013-09-26 13:06:01 +0200225 status = "disabled";
Guennadi Liakhovetskif98c1062013-06-27 11:47:57 +0200226 };
227
228 i2c5: i2c@e60b0000 {
229 #address-cells = <1>;
230 #size-cells = <0>;
231 compatible = "renesas,rmobile-iic";
232 reg = <0 0xe60b0000 0 0x428>;
233 interrupt-parent = <&gic>;
Laurent Pinchart5f75e732013-11-19 03:18:25 +0100234 interrupts = <0 179 IRQ_TYPE_LEVEL_HIGH>;
Guennadi Liakhovetskieda3a4f2013-09-26 13:06:01 +0200235 status = "disabled";
Guennadi Liakhovetskif98c1062013-06-27 11:47:57 +0200236 };
237
238 i2c6: i2c@e6550000 {
239 #address-cells = <1>;
240 #size-cells = <0>;
241 compatible = "renesas,rmobile-iic";
242 reg = <0 0xe6550000 0 0x428>;
243 interrupt-parent = <&gic>;
Laurent Pinchart5f75e732013-11-19 03:18:25 +0100244 interrupts = <0 184 IRQ_TYPE_LEVEL_HIGH>;
Guennadi Liakhovetskieda3a4f2013-09-26 13:06:01 +0200245 status = "disabled";
Guennadi Liakhovetskif98c1062013-06-27 11:47:57 +0200246 };
247
248 i2c7: i2c@e6560000 {
249 #address-cells = <1>;
250 #size-cells = <0>;
251 compatible = "renesas,rmobile-iic";
252 reg = <0 0xe6560000 0 0x428>;
253 interrupt-parent = <&gic>;
Laurent Pinchart5f75e732013-11-19 03:18:25 +0100254 interrupts = <0 185 IRQ_TYPE_LEVEL_HIGH>;
Guennadi Liakhovetskieda3a4f2013-09-26 13:06:01 +0200255 status = "disabled";
Guennadi Liakhovetskif98c1062013-06-27 11:47:57 +0200256 };
257
258 i2c8: i2c@e6570000 {
259 #address-cells = <1>;
260 #size-cells = <0>;
261 compatible = "renesas,rmobile-iic";
262 reg = <0 0xe6570000 0 0x428>;
263 interrupt-parent = <&gic>;
Laurent Pinchart5f75e732013-11-19 03:18:25 +0100264 interrupts = <0 173 IRQ_TYPE_LEVEL_HIGH>;
Guennadi Liakhovetskieda3a4f2013-09-26 13:06:01 +0200265 status = "disabled";
Guennadi Liakhovetskif98c1062013-06-27 11:47:57 +0200266 };
Guennadi Liakhovetski369ee2d2013-07-08 17:54:45 +0200267
Kuninori Morimoto43304a52013-10-21 19:35:31 -0700268 mmcif0: mmc@ee200000 {
Guennadi Liakhovetski369ee2d2013-07-08 17:54:45 +0200269 compatible = "renesas,sh-mmcif";
270 reg = <0 0xee200000 0 0x80>;
271 interrupt-parent = <&gic>;
Laurent Pinchart5f75e732013-11-19 03:18:25 +0100272 interrupts = <0 169 IRQ_TYPE_LEVEL_HIGH>;
Guennadi Liakhovetski369ee2d2013-07-08 17:54:45 +0200273 reg-io-width = <4>;
274 status = "disabled";
275 };
276
Kuninori Morimoto43304a52013-10-21 19:35:31 -0700277 mmcif1: mmc@ee220000 {
Guennadi Liakhovetski369ee2d2013-07-08 17:54:45 +0200278 compatible = "renesas,sh-mmcif";
279 reg = <0 0xee220000 0 0x80>;
280 interrupt-parent = <&gic>;
Laurent Pinchart5f75e732013-11-19 03:18:25 +0100281 interrupts = <0 170 IRQ_TYPE_LEVEL_HIGH>;
Guennadi Liakhovetski369ee2d2013-07-08 17:54:45 +0200282 reg-io-width = <4>;
283 status = "disabled";
284 };
285
Laurent Pinchart803d3192013-05-09 15:05:57 +0200286 pfc: pfc@e6050000 {
287 compatible = "renesas,pfc-r8a73a4";
288 reg = <0 0xe6050000 0 0x9000>;
289 gpio-controller;
290 #gpio-cells = <2>;
291 };
Olof Johansson55689bf2013-08-14 00:24:05 -0700292
Kuninori Morimoto43304a52013-10-21 19:35:31 -0700293 sdhi0: sd@ee100000 {
Guennadi Liakhovetskidf1d0582013-08-29 17:14:49 +0200294 compatible = "renesas,sdhi-r8a73a4";
Guennadi Liakhovetski369ee2d2013-07-08 17:54:45 +0200295 reg = <0 0xee100000 0 0x100>;
296 interrupt-parent = <&gic>;
Laurent Pinchart5f75e732013-11-19 03:18:25 +0100297 interrupts = <0 165 IRQ_TYPE_LEVEL_HIGH>;
Guennadi Liakhovetski369ee2d2013-07-08 17:54:45 +0200298 cap-sd-highspeed;
299 status = "disabled";
300 };
301
Kuninori Morimoto43304a52013-10-21 19:35:31 -0700302 sdhi1: sd@ee120000 {
Guennadi Liakhovetskidf1d0582013-08-29 17:14:49 +0200303 compatible = "renesas,sdhi-r8a73a4";
Guennadi Liakhovetski369ee2d2013-07-08 17:54:45 +0200304 reg = <0 0xee120000 0 0x100>;
305 interrupt-parent = <&gic>;
Laurent Pinchart5f75e732013-11-19 03:18:25 +0100306 interrupts = <0 166 IRQ_TYPE_LEVEL_HIGH>;
Guennadi Liakhovetski369ee2d2013-07-08 17:54:45 +0200307 cap-sd-highspeed;
308 status = "disabled";
309 };
310
Kuninori Morimoto43304a52013-10-21 19:35:31 -0700311 sdhi2: sd@ee140000 {
Guennadi Liakhovetskidf1d0582013-08-29 17:14:49 +0200312 compatible = "renesas,sdhi-r8a73a4";
Guennadi Liakhovetski369ee2d2013-07-08 17:54:45 +0200313 reg = <0 0xee140000 0 0x100>;
314 interrupt-parent = <&gic>;
Laurent Pinchart5f75e732013-11-19 03:18:25 +0100315 interrupts = <0 167 IRQ_TYPE_LEVEL_HIGH>;
Guennadi Liakhovetski369ee2d2013-07-08 17:54:45 +0200316 cap-sd-highspeed;
317 status = "disabled";
318 };
Magnus Dammeccf0602013-03-26 10:34:24 +0900319};