]>
Commit | Line | Data |
---|---|---|
c328666d | 1 | /* |
0e26f26f AF |
2 | * Copyright (c) 2016 Andreas Färber |
3 | * | |
c328666d NA |
4 | * Copyright (c) 2016 BayLibre, SAS. |
5 | * Author: Neil Armstrong <narmstrong@baylibre.com> | |
6 | * | |
7 | * Copyright (c) 2016 Endless Computers, Inc. | |
8 | * Author: Carlo Caione <carlo@endlessm.com> | |
9 | * | |
c328666d NA |
10 | * This file is dual-licensed: you can use it either under the terms |
11 | * of the GPL or the X11 license, at your option. Note that this dual | |
12 | * licensing only applies to this file, and not this project as a | |
13 | * whole. | |
14 | * | |
15 | * a) This library is free software; you can redistribute it and/or | |
16 | * modify it under the terms of the GNU General Public License as | |
17 | * published by the Free Software Foundation; either version 2 of the | |
18 | * License, or (at your option) any later version. | |
19 | * | |
20 | * This library is distributed in the hope that it will be useful, | |
21 | * but WITHOUT ANY WARRANTY; without even the implied warranty of | |
22 | * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the | |
23 | * GNU General Public License for more details. | |
24 | * | |
25 | * Or, alternatively, | |
26 | * | |
27 | * b) Permission is hereby granted, free of charge, to any person | |
28 | * obtaining a copy of this software and associated documentation | |
29 | * files (the "Software"), to deal in the Software without | |
30 | * restriction, including without limitation the rights to use, | |
31 | * copy, modify, merge, publish, distribute, sublicense, and/or | |
32 | * sell copies of the Software, and to permit persons to whom the | |
33 | * Software is furnished to do so, subject to the following | |
34 | * conditions: | |
35 | * | |
36 | * The above copyright notice and this permission notice shall be | |
37 | * included in all copies or substantial portions of the Software. | |
38 | * | |
39 | * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, | |
40 | * EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES | |
41 | * OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND | |
42 | * NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT | |
43 | * HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, | |
44 | * WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING | |
45 | * FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR | |
46 | * OTHER DEALINGS IN THE SOFTWARE. | |
47 | */ | |
48 | ||
49 | #include <dt-bindings/gpio/gpio.h> | |
50 | #include <dt-bindings/interrupt-controller/irq.h> | |
51 | #include <dt-bindings/interrupt-controller/arm-gic.h> | |
52 | ||
53 | / { | |
54 | interrupt-parent = <&gic>; | |
55 | #address-cells = <2>; | |
56 | #size-cells = <2>; | |
57 | ||
bba8e3f4 NA |
58 | reserved-memory { |
59 | #address-cells = <2>; | |
60 | #size-cells = <2>; | |
61 | ranges; | |
62 | ||
63 | /* 16 MiB reserved for Hardware ROM Firmware */ | |
64 | hwrom_reserved: hwrom@0 { | |
65 | reg = <0x0 0x0 0x0 0x1000000>; | |
66 | no-map; | |
67 | }; | |
68 | ||
69 | /* 2 MiB reserved for ARM Trusted Firmware (BL31) */ | |
70 | secmon_reserved: secmon@10000000 { | |
71 | reg = <0x0 0x10000000 0x0 0x200000>; | |
72 | no-map; | |
73 | }; | |
74 | }; | |
75 | ||
c328666d NA |
76 | cpus { |
77 | #address-cells = <0x2>; | |
78 | #size-cells = <0x0>; | |
79 | ||
80 | cpu0: cpu@0 { | |
81 | device_type = "cpu"; | |
82 | compatible = "arm,cortex-a53", "arm,armv8"; | |
83 | reg = <0x0 0x0>; | |
84 | enable-method = "psci"; | |
214ec523 | 85 | next-level-cache = <&l2>; |
47961f13 | 86 | clocks = <&scpi_dvfs 0>; |
c328666d NA |
87 | }; |
88 | ||
89 | cpu1: cpu@1 { | |
90 | device_type = "cpu"; | |
91 | compatible = "arm,cortex-a53", "arm,armv8"; | |
92 | reg = <0x0 0x1>; | |
93 | enable-method = "psci"; | |
214ec523 | 94 | next-level-cache = <&l2>; |
47961f13 | 95 | clocks = <&scpi_dvfs 0>; |
c328666d NA |
96 | }; |
97 | ||
98 | cpu2: cpu@2 { | |
99 | device_type = "cpu"; | |
100 | compatible = "arm,cortex-a53", "arm,armv8"; | |
101 | reg = <0x0 0x2>; | |
102 | enable-method = "psci"; | |
214ec523 | 103 | next-level-cache = <&l2>; |
47961f13 | 104 | clocks = <&scpi_dvfs 0>; |
c328666d NA |
105 | }; |
106 | ||
107 | cpu3: cpu@3 { | |
108 | device_type = "cpu"; | |
109 | compatible = "arm,cortex-a53", "arm,armv8"; | |
110 | reg = <0x0 0x3>; | |
111 | enable-method = "psci"; | |
214ec523 | 112 | next-level-cache = <&l2>; |
47961f13 | 113 | clocks = <&scpi_dvfs 0>; |
214ec523 NA |
114 | }; |
115 | ||
116 | l2: l2-cache0 { | |
117 | compatible = "cache"; | |
c328666d NA |
118 | }; |
119 | }; | |
120 | ||
121 | arm-pmu { | |
122 | compatible = "arm,cortex-a53-pmu"; | |
123 | interrupts = <GIC_SPI 137 IRQ_TYPE_LEVEL_HIGH>, | |
124 | <GIC_SPI 138 IRQ_TYPE_LEVEL_HIGH>, | |
125 | <GIC_SPI 153 IRQ_TYPE_LEVEL_HIGH>, | |
126 | <GIC_SPI 154 IRQ_TYPE_LEVEL_HIGH>; | |
127 | interrupt-affinity = <&cpu0>, <&cpu1>, <&cpu2>, <&cpu3>; | |
128 | }; | |
129 | ||
130 | psci { | |
131 | compatible = "arm,psci-0.2"; | |
132 | method = "smc"; | |
133 | }; | |
134 | ||
135 | timer { | |
136 | compatible = "arm,armv8-timer"; | |
137 | interrupts = <GIC_PPI 13 | |
138 | (GIC_CPU_MASK_RAW(0xff) | IRQ_TYPE_LEVEL_LOW)>, | |
139 | <GIC_PPI 14 | |
140 | (GIC_CPU_MASK_RAW(0xff) | IRQ_TYPE_LEVEL_LOW)>, | |
141 | <GIC_PPI 11 | |
142 | (GIC_CPU_MASK_RAW(0xff) | IRQ_TYPE_LEVEL_LOW)>, | |
143 | <GIC_PPI 10 | |
144 | (GIC_CPU_MASK_RAW(0xff) | IRQ_TYPE_LEVEL_LOW)>; | |
145 | }; | |
146 | ||
147 | xtal: xtal-clk { | |
148 | compatible = "fixed-clock"; | |
149 | clock-frequency = <24000000>; | |
150 | clock-output-names = "xtal"; | |
151 | #clock-cells = <0>; | |
152 | }; | |
153 | ||
998a9c8a NA |
154 | firmware { |
155 | sm: secure-monitor { | |
156 | compatible = "amlogic,meson-gx-sm", "amlogic,meson-gxbb-sm"; | |
157 | }; | |
158 | }; | |
159 | ||
160 | efuse: efuse { | |
161 | compatible = "amlogic,meson-gx-efuse", "amlogic,meson-gxbb-efuse"; | |
162 | #address-cells = <1>; | |
163 | #size-cells = <1>; | |
164 | ||
165 | sn: sn@14 { | |
166 | reg = <0x14 0x10>; | |
167 | }; | |
168 | ||
169 | eth_mac: eth_mac@34 { | |
170 | reg = <0x34 0x10>; | |
171 | }; | |
172 | ||
173 | bid: bid@46 { | |
174 | reg = <0x46 0x30>; | |
175 | }; | |
176 | }; | |
177 | ||
47961f13 MB |
178 | scpi { |
179 | compatible = "amlogic,meson-gxbb-scpi", "arm,scpi-pre-1.0"; | |
180 | mboxes = <&mailbox 1 &mailbox 2>; | |
181 | shmem = <&cpu_scp_lpri &cpu_scp_hpri>; | |
182 | ||
183 | scpi_clocks: clocks { | |
184 | compatible = "arm,scpi-clocks"; | |
185 | ||
186 | scpi_dvfs: scpi_clocks@0 { | |
187 | compatible = "arm,scpi-dvfs-clocks"; | |
188 | #clock-cells = <1>; | |
189 | clock-indices = <0>; | |
190 | clock-output-names = "vcpu"; | |
191 | }; | |
192 | }; | |
193 | ||
194 | scpi_sensors: sensors { | |
195 | compatible = "arm,scpi-sensors"; | |
196 | #thermal-sensor-cells = <1>; | |
197 | }; | |
198 | }; | |
199 | ||
c328666d NA |
200 | soc { |
201 | compatible = "simple-bus"; | |
202 | #address-cells = <2>; | |
203 | #size-cells = <2>; | |
204 | ranges; | |
205 | ||
206 | cbus: cbus@c1100000 { | |
207 | compatible = "simple-bus"; | |
208 | reg = <0x0 0xc1100000 0x0 0x100000>; | |
209 | #address-cells = <2>; | |
210 | #size-cells = <2>; | |
211 | ranges = <0x0 0x0 0x0 0xc1100000 0x0 0x100000>; | |
212 | ||
998a9c8a NA |
213 | reset: reset-controller@4404 { |
214 | compatible = "amlogic,meson-gx-reset", "amlogic,meson-gxbb-reset"; | |
215 | reg = <0x0 0x04404 0x0 0x20>; | |
216 | #reset-cells = <1>; | |
217 | }; | |
218 | ||
c328666d NA |
219 | uart_A: serial@84c0 { |
220 | compatible = "amlogic,meson-uart"; | |
221 | reg = <0x0 0x84c0 0x0 0x14>; | |
222 | interrupts = <GIC_SPI 26 IRQ_TYPE_EDGE_RISING>; | |
223 | clocks = <&xtal>; | |
224 | status = "disabled"; | |
225 | }; | |
998a9c8a NA |
226 | |
227 | uart_B: serial@84dc { | |
228 | compatible = "amlogic,meson-uart"; | |
229 | reg = <0x0 0x84dc 0x0 0x14>; | |
230 | interrupts = <GIC_SPI 75 IRQ_TYPE_EDGE_RISING>; | |
231 | clocks = <&xtal>; | |
232 | status = "disabled"; | |
233 | }; | |
234 | ||
235 | i2c_A: i2c@8500 { | |
236 | compatible = "amlogic,meson-gxbb-i2c"; | |
237 | reg = <0x0 0x08500 0x0 0x20>; | |
238 | interrupts = <GIC_SPI 21 IRQ_TYPE_EDGE_RISING>; | |
239 | #address-cells = <1>; | |
240 | #size-cells = <0>; | |
241 | status = "disabled"; | |
242 | }; | |
243 | ||
244 | pwm_ab: pwm@8550 { | |
245 | compatible = "amlogic,meson-gx-pwm", "amlogic,meson-gxbb-pwm"; | |
246 | reg = <0x0 0x08550 0x0 0x10>; | |
247 | #pwm-cells = <3>; | |
248 | status = "disabled"; | |
249 | }; | |
250 | ||
251 | pwm_cd: pwm@8650 { | |
252 | compatible = "amlogic,meson-gx-pwm", "amlogic,meson-gxbb-pwm"; | |
253 | reg = <0x0 0x08650 0x0 0x10>; | |
254 | #pwm-cells = <3>; | |
255 | status = "disabled"; | |
256 | }; | |
257 | ||
bd80ef5e MB |
258 | saradc: adc@8680 { |
259 | compatible = "amlogic,meson-saradc"; | |
260 | reg = <0x0 0x8680 0x0 0x34>; | |
261 | #io-channel-cells = <1>; | |
262 | interrupts = <GIC_SPI 73 IRQ_TYPE_EDGE_RISING>; | |
263 | status = "disabled"; | |
264 | }; | |
265 | ||
998a9c8a NA |
266 | pwm_ef: pwm@86c0 { |
267 | compatible = "amlogic,meson-gx-pwm", "amlogic,meson-gxbb-pwm"; | |
268 | reg = <0x0 0x086c0 0x0 0x10>; | |
269 | #pwm-cells = <3>; | |
270 | status = "disabled"; | |
271 | }; | |
272 | ||
273 | uart_C: serial@8700 { | |
274 | compatible = "amlogic,meson-uart"; | |
275 | reg = <0x0 0x8700 0x0 0x14>; | |
276 | interrupts = <GIC_SPI 93 IRQ_TYPE_EDGE_RISING>; | |
277 | clocks = <&xtal>; | |
278 | status = "disabled"; | |
279 | }; | |
280 | ||
281 | i2c_B: i2c@87c0 { | |
282 | compatible = "amlogic,meson-gxbb-i2c"; | |
283 | reg = <0x0 0x087c0 0x0 0x20>; | |
284 | interrupts = <GIC_SPI 214 IRQ_TYPE_EDGE_RISING>; | |
285 | #address-cells = <1>; | |
286 | #size-cells = <0>; | |
287 | status = "disabled"; | |
288 | }; | |
289 | ||
290 | i2c_C: i2c@87e0 { | |
291 | compatible = "amlogic,meson-gxbb-i2c"; | |
292 | reg = <0x0 0x087e0 0x0 0x20>; | |
293 | interrupts = <GIC_SPI 215 IRQ_TYPE_EDGE_RISING>; | |
294 | #address-cells = <1>; | |
295 | #size-cells = <0>; | |
296 | status = "disabled"; | |
297 | }; | |
298 | ||
299 | watchdog@98d0 { | |
300 | compatible = "amlogic,meson-gx-wdt", "amlogic,meson-gxbb-wdt"; | |
301 | reg = <0x0 0x098d0 0x0 0x10>; | |
302 | clocks = <&xtal>; | |
303 | }; | |
c328666d NA |
304 | }; |
305 | ||
306 | gic: interrupt-controller@c4301000 { | |
307 | compatible = "arm,gic-400"; | |
308 | reg = <0x0 0xc4301000 0 0x1000>, | |
309 | <0x0 0xc4302000 0 0x2000>, | |
310 | <0x0 0xc4304000 0 0x2000>, | |
311 | <0x0 0xc4306000 0 0x2000>; | |
312 | interrupt-controller; | |
313 | interrupts = <GIC_PPI 9 | |
314 | (GIC_CPU_MASK_SIMPLE(8) | IRQ_TYPE_LEVEL_HIGH)>; | |
315 | #interrupt-cells = <3>; | |
316 | #address-cells = <0>; | |
317 | }; | |
318 | ||
47961f13 MB |
319 | sram: sram@c8000000 { |
320 | compatible = "amlogic,meson-gxbb-sram", "mmio-sram"; | |
321 | reg = <0x0 0xc8000000 0x0 0x14000>; | |
322 | ||
323 | #address-cells = <1>; | |
324 | #size-cells = <1>; | |
325 | ranges = <0 0x0 0xc8000000 0x14000>; | |
326 | ||
327 | cpu_scp_lpri: scp-shmem@0 { | |
328 | compatible = "amlogic,meson-gxbb-scp-shmem"; | |
329 | reg = <0x13000 0x400>; | |
330 | }; | |
331 | ||
332 | cpu_scp_hpri: scp-shmem@200 { | |
333 | compatible = "amlogic,meson-gxbb-scp-shmem"; | |
334 | reg = <0x13400 0x400>; | |
335 | }; | |
336 | }; | |
337 | ||
c328666d NA |
338 | aobus: aobus@c8100000 { |
339 | compatible = "simple-bus"; | |
340 | reg = <0x0 0xc8100000 0x0 0x100000>; | |
341 | #address-cells = <2>; | |
342 | #size-cells = <2>; | |
343 | ranges = <0x0 0x0 0x0 0xc8100000 0x0 0x100000>; | |
344 | ||
345 | uart_AO: serial@4c0 { | |
346 | compatible = "amlogic,meson-uart"; | |
347 | reg = <0x0 0x004c0 0x0 0x14>; | |
348 | interrupts = <GIC_SPI 193 IRQ_TYPE_EDGE_RISING>; | |
349 | clocks = <&xtal>; | |
350 | status = "disabled"; | |
351 | }; | |
998a9c8a | 352 | |
890a96a2 MB |
353 | uart_AO_B: serial@4e0 { |
354 | compatible = "amlogic,meson-uart"; | |
355 | reg = <0x0 0x004e0 0x0 0x14>; | |
356 | interrupts = <GIC_SPI 197 IRQ_TYPE_EDGE_RISING>; | |
357 | clocks = <&xtal>; | |
358 | status = "disabled"; | |
359 | }; | |
360 | ||
e4851224 MB |
361 | pwm_AO_ab: pwm@550 { |
362 | compatible = "amlogic,meson-gx-pwm", "amlogic,meson-gxbb-pwm"; | |
363 | reg = <0x0 0x00550 0x0 0x10>; | |
364 | #pwm-cells = <3>; | |
365 | status = "disabled"; | |
366 | }; | |
367 | ||
998a9c8a NA |
368 | ir: ir@580 { |
369 | compatible = "amlogic,meson-gxbb-ir"; | |
370 | reg = <0x0 0x00580 0x0 0x40>; | |
371 | interrupts = <GIC_SPI 196 IRQ_TYPE_EDGE_RISING>; | |
372 | status = "disabled"; | |
373 | }; | |
c328666d NA |
374 | }; |
375 | ||
376 | periphs: periphs@c8834000 { | |
377 | compatible = "simple-bus"; | |
378 | reg = <0x0 0xc8834000 0x0 0x2000>; | |
379 | #address-cells = <2>; | |
380 | #size-cells = <2>; | |
381 | ranges = <0x0 0x0 0x0 0xc8834000 0x0 0x2000>; | |
998a9c8a NA |
382 | |
383 | rng { | |
384 | compatible = "amlogic,meson-rng"; | |
385 | reg = <0x0 0x0 0x0 0x4>; | |
386 | }; | |
c328666d NA |
387 | }; |
388 | ||
389 | ||
390 | hiubus: hiubus@c883c000 { | |
391 | compatible = "simple-bus"; | |
392 | reg = <0x0 0xc883c000 0x0 0x2000>; | |
393 | #address-cells = <2>; | |
394 | #size-cells = <2>; | |
395 | ranges = <0x0 0x0 0x0 0xc883c000 0x0 0x2000>; | |
998a9c8a NA |
396 | |
397 | mailbox: mailbox@404 { | |
398 | compatible = "amlogic,meson-gx-mhu", "amlogic,meson-gxbb-mhu"; | |
399 | reg = <0 0x404 0 0x4c>; | |
400 | interrupts = <0 208 IRQ_TYPE_EDGE_RISING>, | |
401 | <0 209 IRQ_TYPE_EDGE_RISING>, | |
402 | <0 210 IRQ_TYPE_EDGE_RISING>; | |
403 | #mbox-cells = <1>; | |
404 | }; | |
405 | }; | |
406 | ||
407 | ethmac: ethernet@c9410000 { | |
408 | compatible = "amlogic,meson-gx-dwmac", "amlogic,meson-gxbb-dwmac", "snps,dwmac"; | |
409 | reg = <0x0 0xc9410000 0x0 0x10000 | |
410 | 0x0 0xc8834540 0x0 0x4>; | |
411 | interrupts = <0 8 1>; | |
412 | interrupt-names = "macirq"; | |
413 | phy-mode = "rgmii"; | |
414 | status = "disabled"; | |
c328666d NA |
415 | }; |
416 | ||
417 | apb: apb@d0000000 { | |
418 | compatible = "simple-bus"; | |
419 | reg = <0x0 0xd0000000 0x0 0x200000>; | |
420 | #address-cells = <2>; | |
421 | #size-cells = <2>; | |
422 | ranges = <0x0 0x0 0x0 0xd0000000 0x0 0x200000>; | |
ef8d2ffe KH |
423 | |
424 | sd_emmc_a: mmc@70000 { | |
425 | compatible = "amlogic,meson-gx-mmc", "amlogic,meson-gxbb-mmc"; | |
426 | reg = <0x0 0x70000 0x0 0x2000>; | |
427 | interrupts = <GIC_SPI 216 IRQ_TYPE_EDGE_RISING>; | |
428 | status = "disabled"; | |
429 | }; | |
430 | ||
431 | sd_emmc_b: mmc@72000 { | |
432 | compatible = "amlogic,meson-gx-mmc", "amlogic,meson-gxbb-mmc"; | |
433 | reg = <0x0 0x72000 0x0 0x2000>; | |
434 | interrupts = <GIC_SPI 217 IRQ_TYPE_EDGE_RISING>; | |
435 | status = "disabled"; | |
436 | }; | |
437 | ||
438 | sd_emmc_c: mmc@74000 { | |
439 | compatible = "amlogic,meson-gx-mmc", "amlogic,meson-gxbb-mmc"; | |
440 | reg = <0x0 0x74000 0x0 0x2000>; | |
441 | interrupts = <GIC_SPI 218 IRQ_TYPE_EDGE_RISING>; | |
442 | status = "disabled"; | |
443 | }; | |
c328666d | 444 | }; |
fafdbdf7 NA |
445 | |
446 | vpu: vpu@d0100000 { | |
447 | compatible = "amlogic,meson-gx-vpu"; | |
448 | reg = <0x0 0xd0100000 0x0 0x100000>, | |
449 | <0x0 0xc883c000 0x0 0x1000>, | |
450 | <0x0 0xc8838000 0x0 0x1000>; | |
451 | reg-names = "vpu", "hhi", "dmc"; | |
452 | interrupts = <GIC_SPI 3 IRQ_TYPE_EDGE_RISING>; | |
453 | #address-cells = <1>; | |
454 | #size-cells = <0>; | |
455 | ||
456 | /* CVBS VDAC output port */ | |
457 | cvbs_vdac_port: port@0 { | |
458 | reg = <0>; | |
459 | }; | |
460 | }; | |
c328666d NA |
461 | }; |
462 | }; |