344c2f4fa8819a351b13fb14c2a4011944272fef
[openwrt/staging/wigyori.git] / target / linux / lantiq / files / arch / mips / boot / dts / ar9.dtsi
1 #include <dt-bindings/gpio/gpio.h>
2
3 / {
4 #address-cells = <1>;
5 #size-cells = <1>;
6 compatible = "lantiq,xway", "lantiq,ar9";
7
8 aliases {
9 serial0 = &asc1;
10 };
11
12 chosen {
13 stdout-path = "serial0:115200n8";
14 };
15
16 cpus {
17 #address-cells = <1>;
18 #size-cells = <0>;
19
20 cpu@0 {
21 compatible = "mips,mips34K";
22 reg = <0>;
23 };
24 };
25
26 reboot {
27 compatible = "syscon-reboot";
28
29 regmap = <&rcu0>;
30 offset = <0x10>;
31 mask = <0x40000000>;
32 };
33
34 biu@1f800000 {
35 #address-cells = <1>;
36 #size-cells = <1>;
37 compatible = "lantiq,biu", "simple-bus";
38 reg = <0x1f800000 0x800000>;
39 ranges = <0x0 0x1f800000 0x7fffff>;
40
41 icu0: icu@80200 {
42 #interrupt-cells = <1>;
43 interrupt-controller;
44 compatible = "lantiq,icu";
45 reg = <0x80200 0x28
46 0x80228 0x28
47 0x80250 0x28
48 0x80278 0x28
49 0x802a0 0x28>;
50 };
51
52 watchdog@803f0 {
53 compatible = "lantiq,xrx100-wdt", "lantiq,xrx100-wdt";
54 reg = <0x803f0 0x10>;
55
56 regmap = <&rcu0>;
57 };
58 };
59
60 sram@1f000000 {
61 #address-cells = <1>;
62 #size-cells = <1>;
63 compatible = "lantiq,sram", "simple-bus";
64 reg = <0x1f000000 0x800000>;
65 ranges = <0x0 0x1f000000 0x7fffff>;
66
67 eiu0: eiu@101000 {
68 #interrupt-cells = <1>;
69 interrupt-controller;
70 compatible = "lantiq,eiu-xway";
71 reg = <0x101000 0x1000>;
72 interrupt-parent = <&icu0>;
73 lantiq,eiu-irqs = <166 135 66 40 41 42>;
74 };
75
76 pmu0: pmu@102000 {
77 compatible = "lantiq,pmu-xway";
78 reg = <0x102000 0x1000>;
79 };
80
81 cgu0: cgu@103000 {
82 compatible = "lantiq,cgu-xway";
83 reg = <0x103000 0x1000>;
84 #clock-cells = <1>;
85 };
86
87 rcu0: rcu@203000 {
88 #address-cells = <1>;
89 #size-cells = <1>;
90 compatible = "lantiq,xrx100-rcu", "simple-mfd", "syscon";
91 reg = <0x203000 0x1000>;
92 ranges = <0x0 0x203000 0x100>;
93 big-endian;
94
95 reset: reset-controller@10 {
96 compatible = "lantiq,xrx100-reset", "lantiq,danube-reset";
97 reg = <0x10 4>, <0x14 4>;
98
99 #reset-cells = <2>;
100 };
101
102 usb_phy0: usb2-phy@18 {
103 compatible = "lantiq,xrx100-usb2-phy";
104 reg = <0x18 4>;
105 status = "disabled";
106
107 resets = <&reset 4 4>;
108 reset-names = "ctrl";
109 #phy-cells = <0>;
110 };
111
112 usb_phy1: usb2-phy@34 {
113 compatible = "lantiq,xrx100-usb2-phy";
114 reg = <0x34 4>;
115 status = "disabled";
116
117 resets = <&reset 28 28>;
118 reset-names = "ctrl";
119 #phy-cells = <0>;
120 };
121 };
122 };
123
124 fpi@10000000 {
125 #address-cells = <1>;
126 #size-cells = <1>;
127 compatible = "lantiq,fpi", "simple-bus";
128 ranges = <0x0 0x10000000 0xeefffff>;
129 reg = <0x10000000 0xef00000>;
130
131 localbus: localbus@0 {
132 #address-cells = <2>;
133 #size-cells = <1>;
134 ranges = <0 0 0x0 0x3ffffff /* addrsel0 */
135 1 0 0x4000000 0x4000010>; /* addsel1 */
136 compatible = "lantiq,localbus", "simple-bus";
137 };
138
139 gptu@e100a00 {
140 compatible = "lantiq,gptu-xway";
141 reg = <0xe100a00 0x100>;
142 interrupt-parent = <&icu0>;
143 interrupts = <126 127 128 129 130 131>;
144 };
145
146 asc0: serial@e100400 {
147 compatible = "lantiq,asc";
148 reg = <0xe100400 0x400>;
149 interrupt-parent = <&icu0>;
150 interrupts = <104 105 106>;
151 status = "disabled";
152 };
153
154 spi: spi@e100800 {
155 compatible = "lantiq,xrx100-spi";
156 reg = <0xe100800 0x100>;
157 interrupt-parent = <&icu0>;
158 interrupts = <22 23 24>;
159 interrupt-names = "spi_rx", "spi_tx", "spi_err",
160 "spi_frm";
161 #address-cells = <1>;
162 #size-cells = <0>;
163 pinctrl-names = "default";
164 pinctrl-0 = <&spi_pins>, <&spi_cs4_pins>;
165 status = "disabled";
166 };
167
168 gpio: pinmux@e100b10 {
169 compatible = "lantiq,xrx100-pinctrl";
170 #gpio-cells = <2>;
171 gpio-controller;
172 reg = <0xe100b10 0xa0>;
173
174 mdio_pins: mdio {
175 mux {
176 lantiq,groups = "mdio";
177 lantiq,function = "mdio";
178 };
179 };
180
181 nand_pins: nand {
182 mux-0 {
183 lantiq,groups = "nand cle", "nand ale",
184 "nand rd";
185 lantiq,function = "ebu";
186 lantiq,output = <1>;
187 lantiq,open-drain = <0>;
188 lantiq,pull = <0>;
189 };
190 mux-1 {
191 lantiq,groups = "nand rdy";
192 lantiq,function = "ebu";
193 lantiq,output = <0>;
194 lantiq,pull = <2>;
195 };
196 };
197
198 nand_cs1_pins: nand-cs1 {
199 mux {
200 lantiq,groups = "nand cs1";
201 lantiq,function = "ebu";
202 lantiq,open-drain = <0>;
203 lantiq,pull = <0>;
204 };
205 };
206
207 pci_gnt1_pins: pci-gnt1 {
208 lantiq,groups = "gnt1";
209 lantiq,function = "pci";
210 lantiq,output = <1>;
211 lantiq,open-drain = <0>;
212 lantiq,pull = <0>;
213 };
214
215 pci_gnt2_pins: pci-gnt2 {
216 lantiq,groups = "gnt2";
217 lantiq,function = "pci";
218 lantiq,output = <1>;
219 lantiq,open-drain = <0>;
220 lantiq,pull = <0>;
221 };
222
223 pci_gnt3_pins: pci-gnt3 {
224 lantiq,groups = "gnt3";
225 lantiq,function = "pci";
226 lantiq,output = <1>;
227 lantiq,open-drain = <0>;
228 lantiq,pull = <0>;
229 };
230
231 pci_gnt4_pins: pci-gnt4 {
232 lantiq,groups = "gnt4";
233 lantiq,function = "pci";
234 lantiq,output = <1>;
235 lantiq,open-drain = <0>;
236 lantiq,pull = <0>;
237 };
238
239 pci_req1_pins: pci-req1 {
240 lantiq,groups = "req1";
241 lantiq,function = "pci";
242 lantiq,output = <0>;
243 lantiq,open-drain = <1>;
244 lantiq,pull = <2>;
245 };
246
247 pci_req2_pins: pci-req2 {
248 lantiq,groups = "req2";
249 lantiq,function = "pci";
250 lantiq,output = <0>;
251 lantiq,open-drain = <1>;
252 lantiq,pull = <2>;
253 };
254
255 pci_req3_pins: pci-req3 {
256 lantiq,groups = "req3";
257 lantiq,function = "pci";
258 lantiq,output = <0>;
259 lantiq,open-drain = <1>;
260 lantiq,pull = <2>;
261 };
262
263 pci_req4_pins: pci-req4 {
264 lantiq,groups = "req4";
265 lantiq,function = "pci";
266 lantiq,output = <0>;
267 lantiq,open-drain = <1>;
268 lantiq,pull = <2>;
269 };
270
271 spi_pins: spi {
272 mux-0 {
273 lantiq,groups = "spi_di";
274 lantiq,function = "spi";
275 };
276 mux-1 {
277 lantiq,groups = "spi_do", "spi_clk";
278 lantiq,function = "spi";
279 lantiq,output = <1>;
280 };
281 };
282
283 spi_cs4_pins: spi-cs4 {
284 mux {
285 lantiq,groups = "spi_cs4";
286 lantiq,function = "spi";
287 lantiq,output = <1>;
288 };
289 };
290
291 stp_pins: stp {
292 lantiq,groups = "stp";
293 lantiq,function = "stp";
294 lantiq,pull = <0>;
295 lantiq,open-drain = <0>;
296 lantiq,output = <1>;
297 };
298 };
299
300 stp: stp@e100bb0 {
301 #gpio-cells = <2>;
302 compatible = "lantiq,gpio-stp-xway";
303 gpio-controller;
304 reg = <0xe100bb0 0x40>;
305
306 pinctrl-0 = <&stp_pins>;
307 pinctrl-names = "default";
308
309 status = "disabled";
310 };
311
312 asc1: serial@e100c00 {
313 compatible = "lantiq,asc";
314 reg = <0xe100c00 0x400>;
315 interrupt-parent = <&icu0>;
316 interrupts = <112 113 114>;
317 };
318
319 usb0: usb@e101000 {
320 compatible = "lantiq,arx100-usb";
321 reg = <0xe101000 0x1000
322 0xe120000 0x3f000>;
323 interrupt-parent = <&icu0>;
324 interrupts = <62 91>;
325 dr_mode = "host";
326 phys = <&usb_phy0>;
327 phy-names = "usb2-phy";
328 status = "disabled";
329 };
330
331 usb1: usb@e106000 {
332 compatible = "lantiq,arx100-usb";
333 reg = <0xe106000 0x1000
334 0xe1e0000 0x3f000>;
335 interrupt-parent = <&icu0>;
336 interrupts = <91>;
337 dr_mode = "host";
338 phys = <&usb_phy1>;
339 phy-names = "usb2-phy";
340 status = "disabled";
341 };
342
343 deu@e103100 {
344 compatible = "lantiq,deu-arx100";
345 reg = <0xe103100 0xf00>;
346 };
347
348 dma0: dma@e104100 {
349 compatible = "lantiq,dma-xway";
350 reg = <0xe104100 0x800>;
351 };
352
353 ebu0: ebu@e105300 {
354 compatible = "lantiq,ebu-xway";
355 reg = <0xe105300 0x100>;
356 };
357
358 mei@e116000 {
359 compatible = "lantiq,mei-xway";
360 reg = <0xe116000 0x9c>;
361 interrupt-parent = <&icu0>;
362 interrupts = <63>;
363 };
364
365 gsw: etop@e180000 {
366 compatible = "lantiq,etop-xway";
367 reg = <0xe180000 0x40000
368 0xe108000 0x200>;
369 interrupt-parent = <&icu0>;
370 interrupts = <73 72>;
371 mac-address = [ 00 11 22 33 44 55 ];
372 pinctrl-0 = <&mdio_pins>;
373 pinctrl-names = "default";
374 };
375
376 ppe@e234000 {
377 compatible = "lantiq,ppe-arx100";
378 reg = <0xe234000 0x3ffd>;
379 interrupt-parent = <&icu0>;
380 interrupts = <96>;
381 };
382
383 pci0: pci@e105400 {
384 status = "disabled";
385 #address-cells = <3>;
386 #size-cells = <2>;
387 #interrupt-cells = <1>;
388 compatible = "lantiq,pci-xway";
389 bus-range = <0x0 0x0>;
390 ranges = <0x2000000 0 0x8000000 0x8000000 0 0x2000000 /* pci memory */
391 0x1000000 0 0x00000000 0xae00000 0 0x200000>; /* io space */
392 reg = <0x7000000 0x8000 /* config space */
393 0xe105400 0x400>; /* pci bridge */
394 lantiq,bus-clock = <33333333>;
395 interrupt-map-mask = <0xf800 0x0 0x0 0x7>;
396 interrupt-map = <0x7000 0 0 1 &icu0 30 1>;
397 req-mask = <0x1>;
398 };
399 };
400
401 adsl {
402 compatible = "lantiq,adsl-arx100";
403 };
404 };