2 * at91sam9263.dtsi - Device Tree Include file for AT91SAM9263 family SoC
4 * Copyright (C) 2012 Jean-Christophe PLAGNIOL-VILLARD <plagnioj@jcrosoft.com>
6 * Licensed under GPLv2 only.
9 /include/ "skeleton.dtsi"
12 model = "Atmel AT91SAM9263 family SoC";
13 compatible = "atmel,at91sam9263";
14 interrupt-parent = <&aic>;
31 compatible = "arm,arm926ejs";
36 reg = <0x20000000 0x08000000>;
40 compatible = "simple-bus";
46 compatible = "simple-bus";
51 aic: interrupt-controller@fffff000 {
52 #interrupt-cells = <3>;
53 compatible = "atmel,at91rm9200-aic";
55 reg = <0xfffff000 0x200>;
56 atmel,external-irqs = <30 31>;
60 compatible = "atmel,at91rm9200-pmc";
61 reg = <0xfffffc00 0x100>;
65 compatible = "atmel,at91sam9260-sdramc";
66 reg = <0xffffe200 0x200
71 compatible = "atmel,at91sam9260-pit";
72 reg = <0xfffffd30 0xf>;
76 tcb0: timer@fff7c000 {
77 compatible = "atmel,at91rm9200-tcb";
78 reg = <0xfff7c000 0x100>;
79 interrupts = <19 4 0>;
83 compatible = "atmel,at91sam9260-rstc";
84 reg = <0xfffffd00 0x10>;
88 compatible = "atmel,at91sam9260-shdwc";
89 reg = <0xfffffd10 0x10>;
95 compatible = "atmel,at91rm9200-pinctrl", "simple-bus";
96 ranges = <0xfffff200 0xfffff200 0xa00>;
100 0xfffffffb 0xffffe07f /* pioA */
101 0x0007ffff 0x39072fff /* pioB */
102 0xffffffff 0x3ffffff8 /* pioC */
103 0xfffffbff 0xffffffff /* pioD */
104 0xffe00fff 0xfbfcff00 /* pioE */
107 /* shared pinctrl settings */
109 pinctrl_dbgu: dbgu-0 {
111 <2 30 0x1 0x0 /* PC30 periph A */
112 2 31 0x1 0x1>; /* PC31 periph with pullup */
117 pinctrl_usart0: usart0-0 {
119 <0 26 0x1 0x1 /* PA26 periph A with pullup */
120 0 27 0x1 0x0>; /* PA27 periph A */
123 pinctrl_usart0_rts: usart0_rts-0 {
125 <0 28 0x1 0x0>; /* PA28 periph A */
128 pinctrl_usart0_cts: usart0_cts-0 {
130 <0 29 0x1 0x0>; /* PA29 periph A */
135 pinctrl_usart1: usart1-0 {
137 <3 0 0x1 0x1 /* PD0 periph A with pullup */
138 3 1 0x1 0x0>; /* PD1 periph A */
141 pinctrl_usart1_rts: usart1_rts-0 {
143 <3 7 0x2 0x0>; /* PD7 periph B */
146 pinctrl_usart1_cts: usart1_cts-0 {
148 <3 8 0x2 0x0>; /* PD8 periph B */
153 pinctrl_usart2: usart2-0 {
155 <3 2 0x1 0x1 /* PD2 periph A with pullup */
156 3 3 0x1 0x0>; /* PD3 periph A */
159 pinctrl_usart2_rts: usart2_rts-0 {
161 <3 5 0x2 0x0>; /* PD5 periph B */
164 pinctrl_usart2_cts: usart2_cts-0 {
166 <4 6 0x2 0x0>; /* PD6 periph B */
171 pinctrl_nand: nand-0 {
173 <0 22 0x0 0x1 /* PA22 gpio RDY pin pull_up*/
174 3 15 0x0 0x1>; /* PD15 gpio enable pin pull_up */
179 pinctrl_macb_rmii: macb_rmii-0 {
181 <2 25 0x2 0x0 /* PC25 periph B */
182 4 21 0x1 0x0 /* PE21 periph A */
183 4 23 0x1 0x0 /* PE23 periph A */
184 4 24 0x1 0x0 /* PE24 periph A */
185 4 25 0x1 0x0 /* PE25 periph A */
186 4 26 0x1 0x0 /* PE26 periph A */
187 4 27 0x1 0x0 /* PE27 periph A */
188 4 28 0x1 0x0 /* PE28 periph A */
189 4 29 0x1 0x0 /* PE29 periph A */
190 4 30 0x1 0x0>; /* PE30 periph A */
193 pinctrl_macb_rmii_mii: macb_rmii_mii-0 {
195 <2 20 0x2 0x0 /* PC20 periph B */
196 2 21 0x2 0x0 /* PC21 periph B */
197 2 22 0x2 0x0 /* PC22 periph B */
198 2 23 0x2 0x0 /* PC23 periph B */
199 2 24 0x2 0x0 /* PC24 periph B */
200 2 25 0x2 0x0 /* PC25 periph B */
201 2 27 0x2 0x0 /* PC27 periph B */
202 4 22 0x2 0x0>; /* PE22 periph B */
207 pinctrl_mmc0_clk: mmc0_clk-0 {
209 <0 12 0x1 0x0>; /* PA12 periph A */
212 pinctrl_mmc0_slot0_cmd_dat0: mmc0_slot0_cmd_dat0-0 {
214 <0 1 0x1 0x1 /* PA1 periph A with pullup */
215 0 0 0x1 0x1>; /* PA0 periph A with pullup */
218 pinctrl_mmc0_slot0_dat1_3: mmc0_slot0_dat1_3-0 {
220 <0 3 0x1 0x1 /* PA3 periph A with pullup */
221 0 4 0x1 0x1 /* PA4 periph A with pullup */
222 0 5 0x1 0x1>; /* PA5 periph A with pullup */
225 pinctrl_mmc0_slot1_cmd_dat0: mmc0_slot1_cmd_dat0-0 {
227 <0 16 0x1 0x1 /* PA16 periph A with pullup */
228 0 17 0x1 0x1>; /* PA17 periph A with pullup */
231 pinctrl_mmc0_slot1_dat1_3: mmc0_slot1_dat1_3-0 {
233 <0 18 0x1 0x1 /* PA18 periph A with pullup */
234 0 19 0x1 0x1 /* PA19 periph A with pullup */
235 0 20 0x1 0x1>; /* PA20 periph A with pullup */
240 pinctrl_mmc1_clk: mmc1_clk-0 {
242 <0 6 0x1 0x0>; /* PA6 periph A */
245 pinctrl_mmc1_slot0_cmd_dat0: mmc1_slot0_cmd_dat0-0 {
247 <0 7 0x1 0x1 /* PA7 periph A with pullup */
248 0 8 0x1 0x1>; /* PA8 periph A with pullup */
251 pinctrl_mmc1_slot0_dat1_3: mmc1_slot0_dat1_3-0 {
253 <0 9 0x1 0x1 /* PA9 periph A with pullup */
254 0 10 0x1 0x1 /* PA10 periph A with pullup */
255 0 11 0x1 0x1>; /* PA11 periph A with pullup */
258 pinctrl_mmc1_slot1_cmd_dat0: mmc1_slot1_cmd_dat0-0 {
260 <0 21 0x1 0x1 /* PA21 periph A with pullup */
261 0 22 0x1 0x1>; /* PA22 periph A with pullup */
264 pinctrl_mmc1_slot1_dat1_3: mmc1_slot1_dat1_3-0 {
266 <0 23 0x1 0x1 /* PA23 periph A with pullup */
267 0 24 0x1 0x1 /* PA24 periph A with pullup */
268 0 25 0x1 0x1>; /* PA25 periph A with pullup */
272 pioA: gpio@fffff200 {
273 compatible = "atmel,at91rm9200-gpio";
274 reg = <0xfffff200 0x200>;
275 interrupts = <2 4 1>;
278 interrupt-controller;
279 #interrupt-cells = <2>;
282 pioB: gpio@fffff400 {
283 compatible = "atmel,at91rm9200-gpio";
284 reg = <0xfffff400 0x200>;
285 interrupts = <3 4 1>;
288 interrupt-controller;
289 #interrupt-cells = <2>;
292 pioC: gpio@fffff600 {
293 compatible = "atmel,at91rm9200-gpio";
294 reg = <0xfffff600 0x200>;
295 interrupts = <4 4 1>;
298 interrupt-controller;
299 #interrupt-cells = <2>;
302 pioD: gpio@fffff800 {
303 compatible = "atmel,at91rm9200-gpio";
304 reg = <0xfffff800 0x200>;
305 interrupts = <4 4 1>;
308 interrupt-controller;
309 #interrupt-cells = <2>;
312 pioE: gpio@fffffa00 {
313 compatible = "atmel,at91rm9200-gpio";
314 reg = <0xfffffa00 0x200>;
315 interrupts = <4 4 1>;
318 interrupt-controller;
319 #interrupt-cells = <2>;
323 dbgu: serial@ffffee00 {
324 compatible = "atmel,at91sam9260-usart";
325 reg = <0xffffee00 0x200>;
326 interrupts = <1 4 7>;
327 pinctrl-names = "default";
328 pinctrl-0 = <&pinctrl_dbgu>;
332 usart0: serial@fff8c000 {
333 compatible = "atmel,at91sam9260-usart";
334 reg = <0xfff8c000 0x200>;
335 interrupts = <7 4 5>;
338 pinctrl-names = "default";
339 pinctrl-0 = <&pinctrl_usart0>;
343 usart1: serial@fff90000 {
344 compatible = "atmel,at91sam9260-usart";
345 reg = <0xfff90000 0x200>;
346 interrupts = <8 4 5>;
349 pinctrl-names = "default";
350 pinctrl-0 = <&pinctrl_usart1>;
354 usart2: serial@fff94000 {
355 compatible = "atmel,at91sam9260-usart";
356 reg = <0xfff94000 0x200>;
357 interrupts = <9 4 5>;
360 pinctrl-names = "default";
361 pinctrl-0 = <&pinctrl_usart2>;
365 macb0: ethernet@fffbc000 {
366 compatible = "cdns,at32ap7000-macb", "cdns,macb";
367 reg = <0xfffbc000 0x100>;
368 interrupts = <21 4 3>;
369 pinctrl-names = "default";
370 pinctrl-0 = <&pinctrl_macb_rmii>;
374 usb1: gadget@fff78000 {
375 compatible = "atmel,at91rm9200-udc";
376 reg = <0xfff78000 0x4000>;
377 interrupts = <24 4 2>;
382 compatible = "atmel,at91sam9263-i2c";
383 reg = <0xfff88000 0x100>;
384 interrupts = <13 4 6>;
385 #address-cells = <1>;
391 compatible = "atmel,hsmci";
392 reg = <0xfff80000 0x600>;
393 interrupts = <10 4 0>;
394 #address-cells = <1>;
400 compatible = "atmel,hsmci";
401 reg = <0xfff84000 0x600>;
402 interrupts = <11 4 0>;
403 #address-cells = <1>;
409 nand0: nand@40000000 {
410 compatible = "atmel,at91rm9200-nand";
411 #address-cells = <1>;
413 reg = <0x40000000 0x10000000
416 atmel,nand-addr-offset = <21>;
417 atmel,nand-cmd-offset = <22>;
418 pinctrl-names = "default";
419 pinctrl-0 = <&pinctrl_nand>;
427 usb0: ohci@00a00000 {
428 compatible = "atmel,at91rm9200-ohci", "usb-ohci";
429 reg = <0x00a00000 0x100000>;
430 interrupts = <29 4 2>;
436 compatible = "i2c-gpio";
437 gpios = <&pioB 4 0 /* sda */
440 i2c-gpio,sda-open-drain;
441 i2c-gpio,scl-open-drain;
442 i2c-gpio,delay-us = <2>; /* ~100 kHz */
443 #address-cells = <1>;