diff options
24 files changed, 1410 insertions, 142 deletions
diff --git a/Documentation/devicetree/bindings/arm/atmel-at91.txt b/Documentation/devicetree/bindings/arm/atmel-at91.txt index d187e9f7cf1c..1196290082d1 100644 --- a/Documentation/devicetree/bindings/arm/atmel-at91.txt +++ b/Documentation/devicetree/bindings/arm/atmel-at91.txt | |||
@@ -7,6 +7,12 @@ PIT Timer required properties: | |||
7 | - interrupts: Should contain interrupt for the PIT which is the IRQ line | 7 | - interrupts: Should contain interrupt for the PIT which is the IRQ line |
8 | shared across all System Controller members. | 8 | shared across all System Controller members. |
9 | 9 | ||
10 | System Timer (ST) required properties: | ||
11 | - compatible: Should be "atmel,at91rm9200-st" | ||
12 | - reg: Should contain registers location and length | ||
13 | - interrupts: Should contain interrupt for the ST which is the IRQ line | ||
14 | shared across all System Controller members. | ||
15 | |||
10 | TC/TCLIB Timer required properties: | 16 | TC/TCLIB Timer required properties: |
11 | - compatible: Should be "atmel,<chip>-tcb". | 17 | - compatible: Should be "atmel,<chip>-tcb". |
12 | <chip> can be "at91rm9200" or "at91sam9x5" | 18 | <chip> can be "at91rm9200" or "at91sam9x5" |
diff --git a/Documentation/devicetree/bindings/pinctrl/atmel,at91-pinctrl.txt b/Documentation/devicetree/bindings/pinctrl/atmel,at91-pinctrl.txt index 20a987e55a28..3a268127b054 100644 --- a/Documentation/devicetree/bindings/pinctrl/atmel,at91-pinctrl.txt +++ b/Documentation/devicetree/bindings/pinctrl/atmel,at91-pinctrl.txt | |||
@@ -84,8 +84,13 @@ Required properties for pin configuration node: | |||
84 | The PERIPH 0 means gpio. | 84 | The PERIPH 0 means gpio. |
85 | 85 | ||
86 | Bits used for CONFIG: | 86 | Bits used for CONFIG: |
87 | PULL_UP(1 << 0): indicate this pin need a pull up. | 87 | PULL_UP (1 << 0): indicate this pin need a pull up. |
88 | MULTIDRIVE(1 << 1): indicate this pin need to be configured as multidrive. | 88 | MULTIDRIVE (1 << 1): indicate this pin need to be configured as multidrive. |
89 | DEGLITCH (1 << 2): indicate this pin need deglitch. | ||
90 | PULL_DOWN (1 << 3): indicate this pin need a pull down. | ||
91 | DIS_SCHMIT (1 << 4): indicate this pin need to disable schmit trigger. | ||
92 | DEBOUNCE (1 << 16): indicate this pin need debounce. | ||
93 | DEBOUNCE_VAL (0x3fff << 17): debounce val. | ||
89 | 94 | ||
90 | NOTE: | 95 | NOTE: |
91 | Some requirements for using atmel,at91rm9200-pinctrl binding: | 96 | Some requirements for using atmel,at91rm9200-pinctrl binding: |
diff --git a/arch/arm/boot/dts/Makefile b/arch/arm/boot/dts/Makefile index 4ffed9ae7292..fb5b07737ca7 100644 --- a/arch/arm/boot/dts/Makefile +++ b/arch/arm/boot/dts/Makefile | |||
@@ -1,7 +1,10 @@ | |||
1 | ifeq ($(CONFIG_OF),y) | 1 | ifeq ($(CONFIG_OF),y) |
2 | 2 | ||
3 | # Keep at91 dtb files sorted alphabetically for each SoC | 3 | # Keep at91 dtb files sorted alphabetically for each SoC |
4 | # rm9200 | ||
5 | dtb-$(CONFIG_ARCH_AT91) += at91rm9200ek.dtb | ||
4 | # sam9260 | 6 | # sam9260 |
7 | dtb-$(CONFIG_ARCH_AT91) += animeo_ip.dtb | ||
5 | dtb-$(CONFIG_ARCH_AT91) += aks-cdu.dtb | 8 | dtb-$(CONFIG_ARCH_AT91) += aks-cdu.dtb |
6 | dtb-$(CONFIG_ARCH_AT91) += ethernut5.dtb | 9 | dtb-$(CONFIG_ARCH_AT91) += ethernut5.dtb |
7 | dtb-$(CONFIG_ARCH_AT91) += evk-pro3.dtb | 10 | dtb-$(CONFIG_ARCH_AT91) += evk-pro3.dtb |
@@ -19,6 +22,7 @@ dtb-$(CONFIG_ARCH_AT91) += tny_a9g20.dtb | |||
19 | dtb-$(CONFIG_ARCH_AT91) += usb_a9g20.dtb | 22 | dtb-$(CONFIG_ARCH_AT91) += usb_a9g20.dtb |
20 | # sam9g45 | 23 | # sam9g45 |
21 | dtb-$(CONFIG_ARCH_AT91) += at91sam9m10g45ek.dtb | 24 | dtb-$(CONFIG_ARCH_AT91) += at91sam9m10g45ek.dtb |
25 | dtb-$(CONFIG_ARCH_AT91) += pm9g45.dtb | ||
22 | # sam9n12 | 26 | # sam9n12 |
23 | dtb-$(CONFIG_ARCH_AT91) += at91sam9n12ek.dtb | 27 | dtb-$(CONFIG_ARCH_AT91) += at91sam9n12ek.dtb |
24 | # sam9x5 | 28 | # sam9x5 |
diff --git a/arch/arm/boot/dts/animeo_ip.dts b/arch/arm/boot/dts/animeo_ip.dts new file mode 100644 index 000000000000..518baedaae05 --- /dev/null +++ b/arch/arm/boot/dts/animeo_ip.dts | |||
@@ -0,0 +1,166 @@ | |||
1 | /* | ||
2 | * animeo_ip.dts - Device Tree file for Somfy Animeo IP Boards | ||
3 | * | ||
4 | * Copyright (C) 2011-2012 Jean-Christophe PLAGNIOL-VILLARD <plagnioj@jcrosoft.com> | ||
5 | * | ||
6 | * Licensed under GPLv2 only. | ||
7 | */ | ||
8 | |||
9 | /dts-v1/; | ||
10 | /include/ "at91sam9260.dtsi" | ||
11 | |||
12 | / { | ||
13 | model = "Somfy Animeo IP"; | ||
14 | compatible = "somfy,animeo-ip", "atmel,at91sam9260", "atmel,at91sam9"; | ||
15 | |||
16 | aliases { | ||
17 | serial0 = &usart1; | ||
18 | serial1 = &usart2; | ||
19 | serial2 = &usart0; | ||
20 | serial3 = &dbgu; | ||
21 | serial4 = &usart3; | ||
22 | serial5 = &uart0; | ||
23 | serial6 = &uart1; | ||
24 | }; | ||
25 | |||
26 | chosen { | ||
27 | linux,stdout-path = &usart2; | ||
28 | }; | ||
29 | |||
30 | memory { | ||
31 | reg = <0x20000000 0x4000000>; | ||
32 | }; | ||
33 | |||
34 | clocks { | ||
35 | #address-cells = <1>; | ||
36 | #size-cells = <1>; | ||
37 | ranges; | ||
38 | |||
39 | main_clock: clock@0 { | ||
40 | compatible = "atmel,osc", "fixed-clock"; | ||
41 | clock-frequency = <18432000>; | ||
42 | }; | ||
43 | }; | ||
44 | |||
45 | ahb { | ||
46 | apb { | ||
47 | usart0: serial@fffb0000 { | ||
48 | pinctrl-0 = <&pinctrl_usart0 &pinctrl_usart0_rts>; | ||
49 | linux,rs485-enabled-at-boot-time; | ||
50 | status = "okay"; | ||
51 | }; | ||
52 | |||
53 | usart1: serial@fffb4000 { | ||
54 | pinctrl-0 = <&pinctrl_usart1 &pinctrl_usart1_rts>; | ||
55 | linux,rs485-enabled-at-boot-time; | ||
56 | status = "okay"; | ||
57 | }; | ||
58 | |||
59 | usart2: serial@fffb8000 { | ||
60 | pinctrl-0 = <&pinctrl_usart2>; | ||
61 | status = "okay"; | ||
62 | }; | ||
63 | |||
64 | macb0: ethernet@fffc4000 { | ||
65 | pinctrl-0 = <&pinctrl_macb_rmii &pinctrl_macb_rmii_mii>; | ||
66 | phy-mode = "mii"; | ||
67 | status = "okay"; | ||
68 | }; | ||
69 | }; | ||
70 | |||
71 | nand0: nand@40000000 { | ||
72 | nand-bus-width = <8>; | ||
73 | nand-ecc-mode = "soft"; | ||
74 | nand-on-flash-bbt; | ||
75 | status = "okay"; | ||
76 | |||
77 | at91bootstrap@0 { | ||
78 | label = "at91bootstrap"; | ||
79 | reg = <0x0 0x8000>; | ||
80 | }; | ||
81 | |||
82 | barebox@8000 { | ||
83 | label = "barebox"; | ||
84 | reg = <0x8000 0x40000>; | ||
85 | }; | ||
86 | |||
87 | bareboxenv@48000 { | ||
88 | label = "bareboxenv"; | ||
89 | reg = <0x48000 0x8000>; | ||
90 | }; | ||
91 | |||
92 | user_block@0x50000 { | ||
93 | label = "user_block"; | ||
94 | reg = <0x50000 0xb0000>; | ||
95 | }; | ||
96 | |||
97 | kernel@100000 { | ||
98 | label = "kernel"; | ||
99 | reg = <0x100000 0x1b0000>; | ||
100 | }; | ||
101 | |||
102 | root@2b0000 { | ||
103 | label = "root"; | ||
104 | reg = <0x2b0000 0x1D50000>; | ||
105 | }; | ||
106 | }; | ||
107 | |||
108 | usb0: ohci@00500000 { | ||
109 | num-ports = <2>; | ||
110 | atmel,vbus-gpio = <&pioB 15 1>; | ||
111 | status = "okay"; | ||
112 | }; | ||
113 | }; | ||
114 | |||
115 | leds { | ||
116 | compatible = "gpio-leds"; | ||
117 | |||
118 | power_green { | ||
119 | label = "power_green"; | ||
120 | gpios = <&pioC 17 0>; | ||
121 | linux,default-trigger = "heartbeat"; | ||
122 | }; | ||
123 | |||
124 | power_red { | ||
125 | label = "power_red"; | ||
126 | gpios = <&pioA 2 0>; | ||
127 | }; | ||
128 | |||
129 | tx_green { | ||
130 | label = "tx_green"; | ||
131 | gpios = <&pioC 19 0>; | ||
132 | }; | ||
133 | |||
134 | tx_red { | ||
135 | label = "tx_red"; | ||
136 | gpios = <&pioC 18 0>; | ||
137 | }; | ||
138 | }; | ||
139 | |||
140 | gpio_keys { | ||
141 | compatible = "gpio-keys"; | ||
142 | #address-cells = <1>; | ||
143 | #size-cells = <0>; | ||
144 | |||
145 | keyswitch_in { | ||
146 | label = "keyswitch_in"; | ||
147 | gpios = <&pioB 1 0>; | ||
148 | linux,code = <28>; | ||
149 | gpio-key,wakeup; | ||
150 | }; | ||
151 | |||
152 | error_in { | ||
153 | label = "error_in"; | ||
154 | gpios = <&pioB 2 0>; | ||
155 | linux,code = <29>; | ||
156 | gpio-key,wakeup; | ||
157 | }; | ||
158 | |||
159 | btn { | ||
160 | label = "btn"; | ||
161 | gpios = <&pioC 23 0>; | ||
162 | linux,code = <31>; | ||
163 | gpio-key,wakeup; | ||
164 | }; | ||
165 | }; | ||
166 | }; | ||
diff --git a/arch/arm/boot/dts/at91rm9200.dtsi b/arch/arm/boot/dts/at91rm9200.dtsi new file mode 100644 index 000000000000..e154f242c680 --- /dev/null +++ b/arch/arm/boot/dts/at91rm9200.dtsi | |||
@@ -0,0 +1,349 @@ | |||
1 | /* | ||
2 | * at91rm9200.dtsi - Device Tree Include file for AT91RM9200 family SoC | ||
3 | * | ||
4 | * Copyright (C) 2011 Atmel, | ||
5 | * 2011 Nicolas Ferre <nicolas.ferre@atmel.com>, | ||
6 | * 2012 Joachim Eastwood <manabian@gmail.com> | ||
7 | * | ||
8 | * Based on at91sam9260.dtsi | ||
9 | * | ||
10 | * Licensed under GPLv2 or later. | ||
11 | */ | ||
12 | |||
13 | /include/ "skeleton.dtsi" | ||
14 | |||
15 | / { | ||
16 | model = "Atmel AT91RM9200 family SoC"; | ||
17 | compatible = "atmel,at91rm9200"; | ||
18 | interrupt-parent = <&aic>; | ||
19 | |||
20 | aliases { | ||
21 | serial0 = &dbgu; | ||
22 | serial1 = &usart0; | ||
23 | serial2 = &usart1; | ||
24 | serial3 = &usart2; | ||
25 | serial4 = &usart3; | ||
26 | gpio0 = &pioA; | ||
27 | gpio1 = &pioB; | ||
28 | gpio2 = &pioC; | ||
29 | gpio3 = &pioD; | ||
30 | tcb0 = &tcb0; | ||
31 | tcb1 = &tcb1; | ||
32 | }; | ||
33 | cpus { | ||
34 | cpu@0 { | ||
35 | compatible = "arm,arm920t"; | ||
36 | }; | ||
37 | }; | ||
38 | |||
39 | memory { | ||
40 | reg = <0x20000000 0x04000000>; | ||
41 | }; | ||
42 | |||
43 | ahb { | ||
44 | compatible = "simple-bus"; | ||
45 | #address-cells = <1>; | ||
46 | #size-cells = <1>; | ||
47 | ranges; | ||
48 | |||
49 | apb { | ||
50 | compatible = "simple-bus"; | ||
51 | #address-cells = <1>; | ||
52 | #size-cells = <1>; | ||
53 | ranges; | ||
54 | |||
55 | aic: interrupt-controller@fffff000 { | ||
56 | #interrupt-cells = <3>; | ||
57 | compatible = "atmel,at91rm9200-aic"; | ||
58 | interrupt-controller; | ||
59 | reg = <0xfffff000 0x200>; | ||
60 | atmel,external-irqs = <25 26 27 28 29 30 31>; | ||
61 | }; | ||
62 | |||
63 | ramc0: ramc@ffffff00 { | ||
64 | compatible = "atmel,at91rm9200-sdramc"; | ||
65 | reg = <0xffffff00 0x100>; | ||
66 | }; | ||
67 | |||
68 | pmc: pmc@fffffc00 { | ||
69 | compatible = "atmel,at91rm9200-pmc"; | ||
70 | reg = <0xfffffc00 0x100>; | ||
71 | }; | ||
72 | |||
73 | st: timer@fffffd00 { | ||
74 | compatible = "atmel,at91rm9200-st"; | ||
75 | reg = <0xfffffd00 0x100>; | ||
76 | interrupts = <1 4 7>; | ||
77 | }; | ||
78 | |||
79 | tcb0: timer@fffa0000 { | ||
80 | compatible = "atmel,at91rm9200-tcb"; | ||
81 | reg = <0xfffa0000 0x100>; | ||
82 | interrupts = <17 4 0 18 4 0 19 4 0>; | ||
83 | }; | ||
84 | |||
85 | tcb1: timer@fffa4000 { | ||
86 | compatible = "atmel,at91rm9200-tcb"; | ||
87 | reg = <0xfffa4000 0x100>; | ||
88 | interrupts = <20 4 0 21 4 0 22 4 0>; | ||
89 | }; | ||
90 | |||
91 | pinctrl@fffff400 { | ||
92 | #address-cells = <1>; | ||
93 | #size-cells = <1>; | ||
94 | compatible = "atmel,at91rm9200-pinctrl", "simple-bus"; | ||
95 | ranges = <0xfffff400 0xfffff400 0x800>; | ||
96 | |||
97 | atmel,mux-mask = < | ||
98 | /* A B */ | ||
99 | 0xffffffff 0xffffffff /* pioA */ | ||
100 | 0xffffffff 0x083fffff /* pioB */ | ||
101 | 0xffff3fff 0x00000000 /* pioC */ | ||
102 | 0x03ff87ff 0x0fffff80 /* pioD */ | ||
103 | >; | ||
104 | |||
105 | /* shared pinctrl settings */ | ||
106 | dbgu { | ||
107 | pinctrl_dbgu: dbgu-0 { | ||
108 | atmel,pins = | ||
109 | <0 30 0x1 0x0 /* PA30 periph A */ | ||
110 | 0 31 0x1 0x1>; /* PA31 periph with pullup */ | ||
111 | }; | ||
112 | }; | ||
113 | |||
114 | uart0 { | ||
115 | pinctrl_uart0: uart0-0 { | ||
116 | atmel,pins = | ||
117 | <0 17 0x1 0x0 /* PA17 periph A */ | ||
118 | 0 18 0x1 0x0>; /* PA18 periph A */ | ||
119 | }; | ||
120 | |||
121 | pinctrl_uart0_rts: uart0_rts-0 { | ||
122 | atmel,pins = | ||
123 | <0 20 0x1 0x0>; /* PA20 periph A */ | ||
124 | }; | ||
125 | |||
126 | pinctrl_uart0_cts: uart0_cts-0 { | ||
127 | atmel,pins = | ||
128 | <0 21 0x1 0x0>; /* PA21 periph A */ | ||
129 | }; | ||
130 | }; | ||
131 | |||
132 | uart1 { | ||
133 | pinctrl_uart1: uart1-0 { | ||
134 | atmel,pins = | ||
135 | <1 20 0x1 0x1 /* PB20 periph A with pullup */ | ||
136 | 1 21 0x1 0x0>; /* PB21 periph A */ | ||
137 | }; | ||
138 | |||
139 | pinctrl_uart1_rts: uart1_rts-0 { | ||
140 | atmel,pins = | ||
141 | <1 24 0x1 0x0>; /* PB24 periph A */ | ||
142 | }; | ||
143 | |||
144 | pinctrl_uart1_cts: uart1_cts-0 { | ||
145 | atmel,pins = | ||
146 | <1 26 0x1 0x0>; /* PB26 periph A */ | ||
147 | }; | ||
148 | |||
149 | pinctrl_uart1_dtr_dsr: uart1_dtr_dsr-0 { | ||
150 | atmel,pins = | ||
151 | <1 19 0x1 0x0 /* PB19 periph A */ | ||
152 | 1 25 0x1 0x0>; /* PB25 periph A */ | ||
153 | }; | ||
154 | |||
155 | pinctrl_uart1_dcd: uart1_dcd-0 { | ||
156 | atmel,pins = | ||
157 | <1 23 0x1 0x0>; /* PB23 periph A */ | ||
158 | }; | ||
159 | |||
160 | pinctrl_uart1_ri: uart1_ri-0 { | ||
161 | atmel,pins = | ||
162 | <1 18 0x1 0x0>; /* PB18 periph A */ | ||
163 | }; | ||
164 | }; | ||
165 | |||
166 | uart2 { | ||
167 | pinctrl_uart2: uart2-0 { | ||
168 | atmel,pins = | ||
169 | <0 22 0x1 0x0 /* PA22 periph A */ | ||
170 | 0 23 0x1 0x1>; /* PA23 periph A with pullup */ | ||
171 | }; | ||
172 | |||
173 | pinctrl_uart2_rts: uart2_rts-0 { | ||
174 | atmel,pins = | ||
175 | <0 30 0x2 0x0>; /* PA30 periph B */ | ||
176 | }; | ||
177 | |||
178 | pinctrl_uart2_cts: uart2_cts-0 { | ||
179 | atmel,pins = | ||
180 | <0 31 0x2 0x0>; /* PA31 periph B */ | ||
181 | }; | ||
182 | }; | ||
183 | |||
184 | uart3 { | ||
185 | pinctrl_uart3: uart3-0 { | ||
186 | atmel,pins = | ||
187 | <0 5 0x2 0x1 /* PA5 periph B with pullup */ | ||
188 | 0 6 0x2 0x0>; /* PA6 periph B */ | ||
189 | }; | ||
190 | |||
191 | pinctrl_uart3_rts: uart3_rts-0 { | ||
192 | atmel,pins = | ||
193 | <1 0 0x2 0x0>; /* PB0 periph B */ | ||
194 | }; | ||
195 | |||
196 | pinctrl_uart3_cts: uart3_cts-0 { | ||
197 | atmel,pins = | ||
198 | <1 1 0x2 0x0>; /* PB1 periph B */ | ||
199 | }; | ||
200 | }; | ||
201 | |||
202 | nand { | ||
203 | pinctrl_nand: nand-0 { | ||
204 | atmel,pins = | ||
205 | <2 2 0x0 0x1 /* PC2 gpio RDY pin pull_up */ | ||
206 | 1 1 0x0 0x1>; /* PB1 gpio CD pin pull_up */ | ||
207 | }; | ||
208 | }; | ||
209 | |||
210 | pioA: gpio@fffff400 { | ||
211 | compatible = "atmel,at91rm9200-gpio"; | ||
212 | reg = <0xfffff400 0x200>; | ||
213 | interrupts = <2 4 1>; | ||
214 | #gpio-cells = <2>; | ||
215 | gpio-controller; | ||
216 | interrupt-controller; | ||
217 | #interrupt-cells = <2>; | ||
218 | }; | ||
219 | |||
220 | pioB: gpio@fffff600 { | ||
221 | compatible = "atmel,at91rm9200-gpio"; | ||
222 | reg = <0xfffff600 0x200>; | ||
223 | interrupts = <3 4 1>; | ||
224 | #gpio-cells = <2>; | ||
225 | gpio-controller; | ||
226 | interrupt-controller; | ||
227 | #interrupt-cells = <2>; | ||
228 | }; | ||
229 | |||
230 | pioC: gpio@fffff800 { | ||
231 | compatible = "atmel,at91rm9200-gpio"; | ||
232 | reg = <0xfffff800 0x200>; | ||
233 | interrupts = <4 4 1>; | ||
234 | #gpio-cells = <2>; | ||
235 | gpio-controller; | ||
236 | interrupt-controller; | ||
237 | #interrupt-cells = <2>; | ||
238 | }; | ||
239 | |||
240 | pioD: gpio@fffffa00 { | ||
241 | compatible = "atmel,at91rm9200-gpio"; | ||
242 | reg = <0xfffffa00 0x200>; | ||
243 | interrupts = <5 4 1>; | ||
244 | #gpio-cells = <2>; | ||
245 | gpio-controller; | ||
246 | interrupt-controller; | ||
247 | #interrupt-cells = <2>; | ||
248 | }; | ||
249 | }; | ||
250 | |||
251 | dbgu: serial@fffff200 { | ||
252 | compatible = "atmel,at91rm9200-usart"; | ||
253 | reg = <0xfffff200 0x200>; | ||
254 | interrupts = <1 4 7>; | ||
255 | pinctrl-names = "default"; | ||
256 | pinctrl-0 = <&pinctrl_dbgu>; | ||
257 | status = "disabled"; | ||
258 | }; | ||
259 | |||
260 | usart0: serial@fffc0000 { | ||
261 | compatible = "atmel,at91rm9200-usart"; | ||
262 | reg = <0xfffc0000 0x200>; | ||
263 | interrupts = <6 4 5>; | ||
264 | atmel,use-dma-rx; | ||
265 | atmel,use-dma-tx; | ||
266 | pinctrl-names = "default"; | ||
267 | pinctrl-0 = <&pinctrl_uart0>; | ||
268 | status = "disabled"; | ||
269 | }; | ||
270 | |||
271 | usart1: serial@fffc4000 { | ||
272 | compatible = "atmel,at91rm9200-usart"; | ||
273 | reg = <0xfffc4000 0x200>; | ||
274 | interrupts = <7 4 5>; | ||
275 | atmel,use-dma-rx; | ||
276 | atmel,use-dma-tx; | ||
277 | pinctrl-names = "default"; | ||
278 | pinctrl-0 = <&pinctrl_uart1>; | ||
279 | status = "disabled"; | ||
280 | }; | ||
281 | |||
282 | usart2: serial@fffc8000 { | ||
283 | compatible = "atmel,at91rm9200-usart"; | ||
284 | reg = <0xfffc8000 0x200>; | ||
285 | interrupts = <8 4 5>; | ||
286 | atmel,use-dma-rx; | ||
287 | atmel,use-dma-tx; | ||
288 | pinctrl-names = "default"; | ||
289 | pinctrl-0 = <&pinctrl_uart2>; | ||
290 | status = "disabled"; | ||
291 | }; | ||
292 | |||
293 | usart3: serial@fffcc000 { | ||
294 | compatible = "atmel,at91rm9200-usart"; | ||
295 | reg = <0xfffcc000 0x200>; | ||
296 | interrupts = <23 4 5>; | ||
297 | atmel,use-dma-rx; | ||
298 | atmel,use-dma-tx; | ||
299 | pinctrl-names = "default"; | ||
300 | pinctrl-0 = <&pinctrl_uart3>; | ||
301 | status = "disabled"; | ||
302 | }; | ||
303 | |||
304 | usb1: gadget@fffb0000 { | ||
305 | compatible = "atmel,at91rm9200-udc"; | ||
306 | reg = <0xfffb0000 0x4000>; | ||
307 | interrupts = <11 4 2>; | ||
308 | status = "disabled"; | ||
309 | }; | ||
310 | }; | ||
311 | |||
312 | nand0: nand@40000000 { | ||
313 | compatible = "atmel,at91rm9200-nand"; | ||
314 | #address-cells = <1>; | ||
315 | #size-cells = <1>; | ||
316 | reg = <0x40000000 0x10000000>; | ||
317 | atmel,nand-addr-offset = <21>; | ||
318 | atmel,nand-cmd-offset = <22>; | ||
319 | pinctrl-names = "default"; | ||
320 | pinctrl-0 = <&pinctrl_nand>; | ||
321 | nand-ecc-mode = "soft"; | ||
322 | gpios = <&pioC 2 0 | ||
323 | 0 | ||
324 | &pioB 1 0 | ||
325 | >; | ||
326 | status = "disabled"; | ||
327 | }; | ||
328 | |||
329 | usb0: ohci@00300000 { | ||
330 | compatible = "atmel,at91rm9200-ohci", "usb-ohci"; | ||
331 | reg = <0x00300000 0x100000>; | ||
332 | interrupts = <23 4 2>; | ||
333 | status = "disabled"; | ||
334 | }; | ||
335 | }; | ||
336 | |||
337 | i2c@0 { | ||
338 | compatible = "i2c-gpio"; | ||
339 | gpios = <&pioA 23 0 /* sda */ | ||
340 | &pioA 24 0 /* scl */ | ||
341 | >; | ||
342 | i2c-gpio,sda-open-drain; | ||
343 | i2c-gpio,scl-open-drain; | ||
344 | i2c-gpio,delay-us = <2>; /* ~100 kHz */ | ||
345 | #address-cells = <1>; | ||
346 | #size-cells = <0>; | ||
347 | status = "disabled"; | ||
348 | }; | ||
349 | }; | ||
diff --git a/arch/arm/boot/dts/at91rm9200ek.dts b/arch/arm/boot/dts/at91rm9200ek.dts new file mode 100644 index 000000000000..8aa48931e0a2 --- /dev/null +++ b/arch/arm/boot/dts/at91rm9200ek.dts | |||
@@ -0,0 +1,79 @@ | |||
1 | /* | ||
2 | * at91rm9200ek.dts - Device Tree file for Atmel AT91RM9200 evaluation kit | ||
3 | * | ||
4 | * Copyright (C) 2012 Joachim Eastwood <manabian@gmail.com> | ||
5 | * | ||
6 | * Licensed under GPLv2 only | ||
7 | */ | ||
8 | /dts-v1/; | ||
9 | /include/ "at91rm9200.dtsi" | ||
10 | |||
11 | / { | ||
12 | model = "Atmel AT91RM9200 evaluation kit"; | ||
13 | compatible = "atmel,at91rm9200ek", "atmel,at91rm9200"; | ||
14 | |||
15 | memory { | ||
16 | reg = <0x20000000 0x4000000>; | ||
17 | }; | ||
18 | |||
19 | clocks { | ||
20 | #address-cells = <1>; | ||
21 | #size-cells = <1>; | ||
22 | ranges; | ||
23 | |||
24 | main_clock: clock@0 { | ||
25 | compatible = "atmel,osc", "fixed-clock"; | ||
26 | clock-frequency = <18432000>; | ||
27 | }; | ||
28 | }; | ||
29 | |||
30 | ahb { | ||
31 | apb { | ||
32 | dbgu: serial@fffff200 { | ||
33 | status = "okay"; | ||
34 | }; | ||
35 | |||
36 | usart1: serial@fffc4000 { | ||
37 | pinctrl-0 = | ||
38 | <&pinctrl_uart1 | ||
39 | &pinctrl_uart1_rts | ||
40 | &pinctrl_uart1_cts | ||
41 | &pinctrl_uart1_dtr_dsr | ||
42 | &pinctrl_uart1_dcd | ||
43 | &pinctrl_uart1_ri>; | ||
44 | status = "okay"; | ||
45 | }; | ||
46 | |||
47 | usb1: gadget@fffb0000 { | ||
48 | atmel,vbus-gpio = <&pioD 4 0>; | ||
49 | status = "okay"; | ||
50 | }; | ||
51 | }; | ||
52 | |||
53 | usb0: ohci@00300000 { | ||
54 | num-ports = <2>; | ||
55 | status = "okay"; | ||
56 | }; | ||
57 | }; | ||
58 | |||
59 | leds { | ||
60 | compatible = "gpio-leds"; | ||
61 | |||
62 | ds2 { | ||
63 | label = "green"; | ||
64 | gpios = <&pioB 0 0x1>; | ||
65 | linux,default-trigger = "mmc0"; | ||
66 | }; | ||
67 | |||
68 | ds4 { | ||
69 | label = "yellow"; | ||
70 | gpios = <&pioB 1 0x1>; | ||
71 | linux,default-trigger = "heartbeat"; | ||
72 | }; | ||
73 | |||
74 | ds6 { | ||
75 | label = "red"; | ||
76 | gpios = <&pioB 2 0x1>; | ||
77 | }; | ||
78 | }; | ||
79 | }; | ||
diff --git a/arch/arm/boot/dts/at91sam9260.dtsi b/arch/arm/boot/dts/at91sam9260.dtsi index 9a24ffbb7231..a5d94606e15d 100644 --- a/arch/arm/boot/dts/at91sam9260.dtsi +++ b/arch/arm/boot/dts/at91sam9260.dtsi | |||
@@ -21,8 +21,8 @@ | |||
21 | serial2 = &usart1; | 21 | serial2 = &usart1; |
22 | serial3 = &usart2; | 22 | serial3 = &usart2; |
23 | serial4 = &usart3; | 23 | serial4 = &usart3; |
24 | serial5 = &usart4; | 24 | serial5 = &uart0; |
25 | serial6 = &usart5; | 25 | serial6 = &uart1; |
26 | gpio0 = &pioA; | 26 | gpio0 = &pioA; |
27 | gpio1 = &pioB; | 27 | gpio1 = &pioB; |
28 | gpio2 = &pioC; | 28 | gpio2 = &pioC; |
@@ -120,88 +120,104 @@ | |||
120 | }; | 120 | }; |
121 | }; | 121 | }; |
122 | 122 | ||
123 | uart0 { | 123 | usart0 { |
124 | pinctrl_uart0: uart0-0 { | 124 | pinctrl_usart0: usart0-0 { |
125 | atmel,pins = | 125 | atmel,pins = |
126 | <1 4 0x1 0x0 /* PB4 periph A */ | 126 | <1 4 0x1 0x0 /* PB4 periph A */ |
127 | 1 5 0x1 0x0>; /* PB5 periph A */ | 127 | 1 5 0x1 0x0>; /* PB5 periph A */ |
128 | }; | 128 | }; |
129 | 129 | ||
130 | pinctrl_uart0_rts_cts: uart0_rts_cts-0 { | 130 | pinctrl_usart0_rts: usart0_rts-0 { |
131 | atmel,pins = | ||
132 | <1 26 0x1 0x0>; /* PB26 periph A */ | ||
133 | }; | ||
134 | |||
135 | pinctrl_usart0_cts: usart0_cts-0 { | ||
131 | atmel,pins = | 136 | atmel,pins = |
132 | <1 26 0x1 0x0 /* PB26 periph A */ | 137 | <1 27 0x1 0x0>; /* PB27 periph A */ |
133 | 1 27 0x1 0x0>; /* PB27 periph A */ | ||
134 | }; | 138 | }; |
135 | 139 | ||
136 | pinctrl_uart0_dtr_dsr: uart0_dtr_dsr-0 { | 140 | pinctrl_usart0_dtr_dsr: usart0_dtr_dsr-0 { |
137 | atmel,pins = | 141 | atmel,pins = |
138 | <1 24 0x1 0x0 /* PB24 periph A */ | 142 | <1 24 0x1 0x0 /* PB24 periph A */ |
139 | 1 22 0x1 0x0>; /* PB22 periph A */ | 143 | 1 22 0x1 0x0>; /* PB22 periph A */ |
140 | }; | 144 | }; |
141 | 145 | ||
142 | pinctrl_uart0_dcd: uart0_dcd-0 { | 146 | pinctrl_usart0_dcd: usart0_dcd-0 { |
143 | atmel,pins = | 147 | atmel,pins = |
144 | <1 23 0x1 0x0>; /* PB23 periph A */ | 148 | <1 23 0x1 0x0>; /* PB23 periph A */ |
145 | }; | 149 | }; |
146 | 150 | ||
147 | pinctrl_uart0_ri: uart0_ri-0 { | 151 | pinctrl_usart0_ri: usart0_ri-0 { |
148 | atmel,pins = | 152 | atmel,pins = |
149 | <1 25 0x1 0x0>; /* PB25 periph A */ | 153 | <1 25 0x1 0x0>; /* PB25 periph A */ |
150 | }; | 154 | }; |
151 | }; | 155 | }; |
152 | 156 | ||
153 | uart1 { | 157 | usart1 { |
154 | pinctrl_uart1: uart1-0 { | 158 | pinctrl_usart1: usart1-0 { |
155 | atmel,pins = | 159 | atmel,pins = |
156 | <2 6 0x1 0x1 /* PB6 periph A with pullup */ | 160 | <2 6 0x1 0x1 /* PB6 periph A with pullup */ |
157 | 2 7 0x1 0x0>; /* PB7 periph A */ | 161 | 2 7 0x1 0x0>; /* PB7 periph A */ |
158 | }; | 162 | }; |
159 | 163 | ||
160 | pinctrl_uart1_rts_cts: uart1_rts_cts-0 { | 164 | pinctrl_usart1_rts: usart1_rts-0 { |
165 | atmel,pins = | ||
166 | <1 28 0x1 0x0>; /* PB28 periph A */ | ||
167 | }; | ||
168 | |||
169 | pinctrl_usart1_cts: usart1_cts-0 { | ||
161 | atmel,pins = | 170 | atmel,pins = |
162 | <1 28 0x1 0x0 /* PB28 periph A */ | 171 | <1 29 0x1 0x0>; /* PB29 periph A */ |
163 | 1 29 0x1 0x0>; /* PB29 periph A */ | ||
164 | }; | 172 | }; |
165 | }; | 173 | }; |
166 | 174 | ||
167 | uart2 { | 175 | usart2 { |
168 | pinctrl_uart2: uart2-0 { | 176 | pinctrl_usart2: usart2-0 { |
169 | atmel,pins = | 177 | atmel,pins = |
170 | <1 8 0x1 0x1 /* PB8 periph A with pullup */ | 178 | <1 8 0x1 0x1 /* PB8 periph A with pullup */ |
171 | 1 9 0x1 0x0>; /* PB9 periph A */ | 179 | 1 9 0x1 0x0>; /* PB9 periph A */ |
172 | }; | 180 | }; |
173 | 181 | ||
174 | pinctrl_uart2_rts_cts: uart2_rts_cts-0 { | 182 | pinctrl_usart2_rts: usart2_rts-0 { |
175 | atmel,pins = | 183 | atmel,pins = |
176 | <0 4 0x1 0x0 /* PA4 periph A */ | 184 | <0 4 0x1 0x0>; /* PA4 periph A */ |
177 | 0 5 0x1 0x0>; /* PA5 periph A */ | 185 | }; |
186 | |||
187 | pinctrl_usart2_cts: usart2_cts-0 { | ||
188 | atmel,pins = | ||
189 | <0 5 0x1 0x0>; /* PA5 periph A */ | ||
178 | }; | 190 | }; |
179 | }; | 191 | }; |
180 | 192 | ||
181 | uart3 { | 193 | usart3 { |
182 | pinctrl_uart3: uart3-0 { | 194 | pinctrl_usart3: usart3-0 { |
183 | atmel,pins = | 195 | atmel,pins = |
184 | <2 10 0x1 0x1 /* PB10 periph A with pullup */ | 196 | <2 10 0x1 0x1 /* PB10 periph A with pullup */ |
185 | 2 11 0x1 0x0>; /* PB11 periph A */ | 197 | 2 11 0x1 0x0>; /* PB11 periph A */ |
186 | }; | 198 | }; |
187 | 199 | ||
188 | pinctrl_uart3_rts_cts: uart3_rts_cts-0 { | 200 | pinctrl_usart3_rts: usart3_rts-0 { |
189 | atmel,pins = | 201 | atmel,pins = |
190 | <3 8 0x2 0x0 /* PB8 periph B */ | 202 | <3 8 0x2 0x0>; /* PB8 periph B */ |
191 | 3 10 0x2 0x0>; /* PB10 periph B */ | 203 | }; |
204 | |||
205 | pinctrl_usart3_cts: usart3_cts-0 { | ||
206 | atmel,pins = | ||
207 | <3 10 0x2 0x0>; /* PB10 periph B */ | ||
192 | }; | 208 | }; |
193 | }; | 209 | }; |
194 | 210 | ||
195 | uart4 { | 211 | uart0 { |
196 | pinctrl_uart4: uart4-0 { | 212 | pinctrl_uart0: uart0-0 { |
197 | atmel,pins = | 213 | atmel,pins = |
198 | <0 31 0x2 0x1 /* PA31 periph B with pullup */ | 214 | <0 31 0x2 0x1 /* PA31 periph B with pullup */ |
199 | 0 30 0x2 0x0>; /* PA30 periph B */ | 215 | 0 30 0x2 0x0>; /* PA30 periph B */ |
200 | }; | 216 | }; |
201 | }; | 217 | }; |
202 | 218 | ||
203 | uart5 { | 219 | uart1 { |
204 | pinctrl_uart5: uart5-0 { | 220 | pinctrl_uart1: uart1-0 { |
205 | atmel,pins = | 221 | atmel,pins = |
206 | <2 12 0x1 0x1 /* PB12 periph A with pullup */ | 222 | <2 12 0x1 0x1 /* PB12 periph A with pullup */ |
207 | 2 13 0x1 0x0>; /* PB13 periph A */ | 223 | 2 13 0x1 0x0>; /* PB13 periph A */ |
@@ -216,6 +232,46 @@ | |||
216 | }; | 232 | }; |
217 | }; | 233 | }; |
218 | 234 | ||
235 | macb { | ||
236 | pinctrl_macb_rmii: macb_rmii-0 { | ||
237 | atmel,pins = | ||
238 | <0 12 0x1 0x0 /* PA12 periph A */ | ||
239 | 0 13 0x1 0x0 /* PA13 periph A */ | ||
240 | 0 14 0x1 0x0 /* PA14 periph A */ | ||
241 | 0 15 0x1 0x0 /* PA15 periph A */ | ||
242 | 0 16 0x1 0x0 /* PA16 periph A */ | ||
243 | 0 17 0x1 0x0 /* PA17 periph A */ | ||
244 | 0 18 0x1 0x0 /* PA18 periph A */ | ||
245 | 0 19 0x1 0x0 /* PA19 periph A */ | ||
246 | 0 20 0x1 0x0 /* PA20 periph A */ | ||
247 | 0 21 0x1 0x0>; /* PA21 periph A */ | ||
248 | }; | ||
249 | |||
250 | pinctrl_macb_rmii_mii: macb_rmii_mii-0 { | ||
251 | atmel,pins = | ||
252 | <0 22 0x2 0x0 /* PA22 periph B */ | ||
253 | 0 23 0x2 0x0 /* PA23 periph B */ | ||
254 | 0 24 0x2 0x0 /* PA24 periph B */ | ||
255 | 0 25 0x2 0x0 /* PA25 periph B */ | ||
256 | 0 26 0x2 0x0 /* PA26 periph B */ | ||
257 | 0 27 0x2 0x0 /* PA27 periph B */ | ||
258 | 0 28 0x2 0x0 /* PA28 periph B */ | ||
259 | 0 29 0x2 0x0>; /* PA29 periph B */ | ||
260 | }; | ||
261 | |||
262 | pinctrl_macb_rmii_mii_alt: macb_rmii_mii-1 { | ||
263 | atmel,pins = | ||
264 | <0 10 0x2 0x0 /* PA10 periph B */ | ||
265 | 0 11 0x2 0x0 /* PA11 periph B */ | ||
266 | 0 24 0x2 0x0 /* PA24 periph B */ | ||
267 | 0 25 0x2 0x0 /* PA25 periph B */ | ||
268 | 0 26 0x2 0x0 /* PA26 periph B */ | ||
269 | 0 27 0x2 0x0 /* PA27 periph B */ | ||
270 | 0 28 0x2 0x0 /* PA28 periph B */ | ||
271 | 0 29 0x2 0x0>; /* PA29 periph B */ | ||
272 | }; | ||
273 | }; | ||
274 | |||
219 | pioA: gpio@fffff400 { | 275 | pioA: gpio@fffff400 { |
220 | compatible = "atmel,at91rm9200-gpio"; | 276 | compatible = "atmel,at91rm9200-gpio"; |
221 | reg = <0xfffff400 0x200>; | 277 | reg = <0xfffff400 0x200>; |
@@ -263,7 +319,7 @@ | |||
263 | atmel,use-dma-rx; | 319 | atmel,use-dma-rx; |
264 | atmel,use-dma-tx; | 320 | atmel,use-dma-tx; |
265 | pinctrl-names = "default"; | 321 | pinctrl-names = "default"; |
266 | pinctrl-0 = <&pinctrl_uart0>; | 322 | pinctrl-0 = <&pinctrl_usart0>; |
267 | status = "disabled"; | 323 | status = "disabled"; |
268 | }; | 324 | }; |
269 | 325 | ||
@@ -274,7 +330,7 @@ | |||
274 | atmel,use-dma-rx; | 330 | atmel,use-dma-rx; |
275 | atmel,use-dma-tx; | 331 | atmel,use-dma-tx; |
276 | pinctrl-names = "default"; | 332 | pinctrl-names = "default"; |
277 | pinctrl-0 = <&pinctrl_uart1>; | 333 | pinctrl-0 = <&pinctrl_usart1>; |
278 | status = "disabled"; | 334 | status = "disabled"; |
279 | }; | 335 | }; |
280 | 336 | ||
@@ -285,7 +341,7 @@ | |||
285 | atmel,use-dma-rx; | 341 | atmel,use-dma-rx; |
286 | atmel,use-dma-tx; | 342 | atmel,use-dma-tx; |
287 | pinctrl-names = "default"; | 343 | pinctrl-names = "default"; |
288 | pinctrl-0 = <&pinctrl_uart2>; | 344 | pinctrl-0 = <&pinctrl_usart2>; |
289 | status = "disabled"; | 345 | status = "disabled"; |
290 | }; | 346 | }; |
291 | 347 | ||
@@ -296,29 +352,29 @@ | |||
296 | atmel,use-dma-rx; | 352 | atmel,use-dma-rx; |
297 | atmel,use-dma-tx; | 353 | atmel,use-dma-tx; |
298 | pinctrl-names = "default"; | 354 | pinctrl-names = "default"; |
299 | pinctrl-0 = <&pinctrl_uart3>; | 355 | pinctrl-0 = <&pinctrl_usart3>; |
300 | status = "disabled"; | 356 | status = "disabled"; |
301 | }; | 357 | }; |
302 | 358 | ||
303 | usart4: serial@fffd4000 { | 359 | uart0: serial@fffd4000 { |
304 | compatible = "atmel,at91sam9260-usart"; | 360 | compatible = "atmel,at91sam9260-usart"; |
305 | reg = <0xfffd4000 0x200>; | 361 | reg = <0xfffd4000 0x200>; |
306 | interrupts = <24 4 5>; | 362 | interrupts = <24 4 5>; |
307 | atmel,use-dma-rx; | 363 | atmel,use-dma-rx; |
308 | atmel,use-dma-tx; | 364 | atmel,use-dma-tx; |
309 | pinctrl-names = "default"; | 365 | pinctrl-names = "default"; |
310 | pinctrl-0 = <&pinctrl_uart4>; | 366 | pinctrl-0 = <&pinctrl_uart0>; |
311 | status = "disabled"; | 367 | status = "disabled"; |
312 | }; | 368 | }; |
313 | 369 | ||
314 | usart5: serial@fffd8000 { | 370 | uart1: serial@fffd8000 { |
315 | compatible = "atmel,at91sam9260-usart"; | 371 | compatible = "atmel,at91sam9260-usart"; |
316 | reg = <0xfffd8000 0x200>; | 372 | reg = <0xfffd8000 0x200>; |
317 | interrupts = <25 4 5>; | 373 | interrupts = <25 4 5>; |
318 | atmel,use-dma-rx; | 374 | atmel,use-dma-rx; |
319 | atmel,use-dma-tx; | 375 | atmel,use-dma-tx; |
320 | pinctrl-names = "default"; | 376 | pinctrl-names = "default"; |
321 | pinctrl-0 = <&pinctrl_uart5>; | 377 | pinctrl-0 = <&pinctrl_uart1>; |
322 | status = "disabled"; | 378 | status = "disabled"; |
323 | }; | 379 | }; |
324 | 380 | ||
@@ -326,6 +382,8 @@ | |||
326 | compatible = "cdns,at32ap7000-macb", "cdns,macb"; | 382 | compatible = "cdns,at32ap7000-macb", "cdns,macb"; |
327 | reg = <0xfffc4000 0x100>; | 383 | reg = <0xfffc4000 0x100>; |
328 | interrupts = <21 4 3>; | 384 | interrupts = <21 4 3>; |
385 | pinctrl-names = "default"; | ||
386 | pinctrl-0 = <&pinctrl_macb_rmii>; | ||
329 | status = "disabled"; | 387 | status = "disabled"; |
330 | }; | 388 | }; |
331 | 389 | ||
diff --git a/arch/arm/boot/dts/at91sam9263.dtsi b/arch/arm/boot/dts/at91sam9263.dtsi index 251ccec430a4..a14aa3d1f015 100644 --- a/arch/arm/boot/dts/at91sam9263.dtsi +++ b/arch/arm/boot/dts/at91sam9263.dtsi | |||
@@ -113,45 +113,57 @@ | |||
113 | }; | 113 | }; |
114 | }; | 114 | }; |
115 | 115 | ||
116 | uart0 { | 116 | usart0 { |
117 | pinctrl_uart0: uart0-0 { | 117 | pinctrl_usart0: usart0-0 { |
118 | atmel,pins = | 118 | atmel,pins = |
119 | <0 26 0x1 0x1 /* PA26 periph A with pullup */ | 119 | <0 26 0x1 0x1 /* PA26 periph A with pullup */ |
120 | 0 27 0x1 0x0>; /* PA27 periph A */ | 120 | 0 27 0x1 0x0>; /* PA27 periph A */ |
121 | }; | 121 | }; |
122 | 122 | ||
123 | pinctrl_uart0_rts_cts: uart0_rts_cts-0 { | 123 | pinctrl_usart0_rts: usart0_rts-0 { |
124 | atmel,pins = | 124 | atmel,pins = |
125 | <0 28 0x1 0x0 /* PA28 periph A */ | 125 | <0 28 0x1 0x0>; /* PA28 periph A */ |
126 | 0 29 0x1 0x0>; /* PA29 periph A */ | 126 | }; |
127 | |||
128 | pinctrl_usart0_cts: usart0_cts-0 { | ||
129 | atmel,pins = | ||
130 | <0 29 0x1 0x0>; /* PA29 periph A */ | ||
127 | }; | 131 | }; |
128 | }; | 132 | }; |
129 | 133 | ||
130 | uart1 { | 134 | usart1 { |
131 | pinctrl_uart1: uart1-0 { | 135 | pinctrl_usart1: usart1-0 { |
132 | atmel,pins = | 136 | atmel,pins = |
133 | <3 0 0x1 0x1 /* PD0 periph A with pullup */ | 137 | <3 0 0x1 0x1 /* PD0 periph A with pullup */ |
134 | 3 1 0x1 0x0>; /* PD1 periph A */ | 138 | 3 1 0x1 0x0>; /* PD1 periph A */ |
135 | }; | 139 | }; |
136 | 140 | ||
137 | pinctrl_uart1_rts_cts: uart1_rts_cts-0 { | 141 | pinctrl_usart1_rts: usart1_rts-0 { |
138 | atmel,pins = | 142 | atmel,pins = |
139 | <3 7 0x2 0x0 /* PD7 periph B */ | 143 | <3 7 0x2 0x0>; /* PD7 periph B */ |
140 | 3 8 0x2 0x0>; /* PD8 periph B */ | 144 | }; |
145 | |||
146 | pinctrl_usart1_cts: usart1_cts-0 { | ||
147 | atmel,pins = | ||
148 | <3 8 0x2 0x0>; /* PD8 periph B */ | ||
141 | }; | 149 | }; |
142 | }; | 150 | }; |
143 | 151 | ||
144 | uart2 { | 152 | usart2 { |
145 | pinctrl_uart2: uart2-0 { | 153 | pinctrl_usart2: usart2-0 { |
146 | atmel,pins = | 154 | atmel,pins = |
147 | <3 2 0x1 0x1 /* PD2 periph A with pullup */ | 155 | <3 2 0x1 0x1 /* PD2 periph A with pullup */ |
148 | 3 3 0x1 0x0>; /* PD3 periph A */ | 156 | 3 3 0x1 0x0>; /* PD3 periph A */ |
149 | }; | 157 | }; |
150 | 158 | ||
151 | pinctrl_uart2_rts_cts: uart2_rts_cts-0 { | 159 | pinctrl_usart2_rts: usart2_rts-0 { |
160 | atmel,pins = | ||
161 | <3 5 0x2 0x0>; /* PD5 periph B */ | ||
162 | }; | ||
163 | |||
164 | pinctrl_usart2_cts: usart2_cts-0 { | ||
152 | atmel,pins = | 165 | atmel,pins = |
153 | <3 5 0x2 0x0 /* PD5 periph B */ | 166 | <4 6 0x2 0x0>; /* PD6 periph B */ |
154 | 4 6 0x2 0x0>; /* PD6 periph B */ | ||
155 | }; | 167 | }; |
156 | }; | 168 | }; |
157 | 169 | ||
@@ -163,6 +175,34 @@ | |||
163 | }; | 175 | }; |
164 | }; | 176 | }; |
165 | 177 | ||
178 | macb { | ||
179 | pinctrl_macb_rmii: macb_rmii-0 { | ||
180 | atmel,pins = | ||
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 */ | ||
191 | }; | ||
192 | |||
193 | pinctrl_macb_rmii_mii: macb_rmii_mii-0 { | ||
194 | atmel,pins = | ||
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 */ | ||
203 | }; | ||
204 | }; | ||
205 | |||
166 | pioA: gpio@fffff200 { | 206 | pioA: gpio@fffff200 { |
167 | compatible = "atmel,at91rm9200-gpio"; | 207 | compatible = "atmel,at91rm9200-gpio"; |
168 | reg = <0xfffff200 0x200>; | 208 | reg = <0xfffff200 0x200>; |
@@ -230,7 +270,7 @@ | |||
230 | atmel,use-dma-rx; | 270 | atmel,use-dma-rx; |
231 | atmel,use-dma-tx; | 271 | atmel,use-dma-tx; |
232 | pinctrl-names = "default"; | 272 | pinctrl-names = "default"; |
233 | pinctrl-0 = <&pinctrl_uart0>; | 273 | pinctrl-0 = <&pinctrl_usart0>; |
234 | status = "disabled"; | 274 | status = "disabled"; |
235 | }; | 275 | }; |
236 | 276 | ||
@@ -241,7 +281,7 @@ | |||
241 | atmel,use-dma-rx; | 281 | atmel,use-dma-rx; |
242 | atmel,use-dma-tx; | 282 | atmel,use-dma-tx; |
243 | pinctrl-names = "default"; | 283 | pinctrl-names = "default"; |
244 | pinctrl-0 = <&pinctrl_uart1>; | 284 | pinctrl-0 = <&pinctrl_usart1>; |
245 | status = "disabled"; | 285 | status = "disabled"; |
246 | }; | 286 | }; |
247 | 287 | ||
@@ -252,7 +292,7 @@ | |||
252 | atmel,use-dma-rx; | 292 | atmel,use-dma-rx; |
253 | atmel,use-dma-tx; | 293 | atmel,use-dma-tx; |
254 | pinctrl-names = "default"; | 294 | pinctrl-names = "default"; |
255 | pinctrl-0 = <&pinctrl_uart2>; | 295 | pinctrl-0 = <&pinctrl_usart2>; |
256 | status = "disabled"; | 296 | status = "disabled"; |
257 | }; | 297 | }; |
258 | 298 | ||
@@ -260,6 +300,8 @@ | |||
260 | compatible = "cdns,at32ap7000-macb", "cdns,macb"; | 300 | compatible = "cdns,at32ap7000-macb", "cdns,macb"; |
261 | reg = <0xfffbc000 0x100>; | 301 | reg = <0xfffbc000 0x100>; |
262 | interrupts = <21 4 3>; | 302 | interrupts = <21 4 3>; |
303 | pinctrl-names = "default"; | ||
304 | pinctrl-0 = <&pinctrl_macb_rmii>; | ||
263 | status = "disabled"; | 305 | status = "disabled"; |
264 | }; | 306 | }; |
265 | 307 | ||
diff --git a/arch/arm/boot/dts/at91sam9263ek.dts b/arch/arm/boot/dts/at91sam9263ek.dts index 7cfe9d521f12..e6a57a37156d 100644 --- a/arch/arm/boot/dts/at91sam9263ek.dts +++ b/arch/arm/boot/dts/at91sam9263ek.dts | |||
@@ -38,7 +38,10 @@ | |||
38 | }; | 38 | }; |
39 | 39 | ||
40 | usart0: serial@fff8c000 { | 40 | usart0: serial@fff8c000 { |
41 | pinctrl-0 = <&pinctrl_uart0 &pinctrl_uart0_rts_cts>; | 41 | pinctrl-0 = < |
42 | &pinctrl_usart0 | ||
43 | &pinctrl_usart0_rts | ||
44 | &pinctrl_usart0_cts>; | ||
42 | status = "okay"; | 45 | status = "okay"; |
43 | }; | 46 | }; |
44 | 47 | ||
diff --git a/arch/arm/boot/dts/at91sam9g20ek_common.dtsi b/arch/arm/boot/dts/at91sam9g20ek_common.dtsi index 689323d8e64c..63a0e5ddd0a1 100644 --- a/arch/arm/boot/dts/at91sam9g20ek_common.dtsi +++ b/arch/arm/boot/dts/at91sam9g20ek_common.dtsi | |||
@@ -36,11 +36,12 @@ | |||
36 | 36 | ||
37 | usart0: serial@fffb0000 { | 37 | usart0: serial@fffb0000 { |
38 | pinctrl-0 = | 38 | pinctrl-0 = |
39 | <&pinctrl_uart0 | 39 | <&pinctrl_usart0 |
40 | &pinctrl_uart0_rts_cts | 40 | &pinctrl_usart0_rts |
41 | &pinctrl_uart0_dtr_dsr | 41 | &pinctrl_usart0_cts |
42 | &pinctrl_uart0_dcd | 42 | &pinctrl_usart0_dtr_dsr |
43 | &pinctrl_uart0_ri>; | 43 | &pinctrl_usart0_dcd |
44 | &pinctrl_usart0_ri>; | ||
44 | status = "okay"; | 45 | status = "okay"; |
45 | }; | 46 | }; |
46 | 47 | ||
diff --git a/arch/arm/boot/dts/at91sam9g45.dtsi b/arch/arm/boot/dts/at91sam9g45.dtsi index c340f6635d81..dc9a4ee28bc8 100644 --- a/arch/arm/boot/dts/at91sam9g45.dtsi +++ b/arch/arm/boot/dts/at91sam9g45.dtsi | |||
@@ -132,59 +132,75 @@ | |||
132 | }; | 132 | }; |
133 | }; | 133 | }; |
134 | 134 | ||
135 | uart0 { | 135 | usart0 { |
136 | pinctrl_uart0: uart0-0 { | 136 | pinctrl_usart0: usart0-0 { |
137 | atmel,pins = | 137 | atmel,pins = |
138 | <1 19 0x1 0x1 /* PB19 periph A with pullup */ | 138 | <1 19 0x1 0x1 /* PB19 periph A with pullup */ |
139 | 1 18 0x1 0x0>; /* PB18 periph A */ | 139 | 1 18 0x1 0x0>; /* PB18 periph A */ |
140 | }; | 140 | }; |
141 | 141 | ||
142 | pinctrl_uart0_rts_cts: uart0_rts_cts-0 { | 142 | pinctrl_usart0_rts: usart0_rts-0 { |
143 | atmel,pins = | 143 | atmel,pins = |
144 | <1 17 0x2 0x0 /* PB17 periph B */ | 144 | <1 17 0x2 0x0>; /* PB17 periph B */ |
145 | 1 15 0x2 0x0>; /* PB15 periph B */ | 145 | }; |
146 | |||
147 | pinctrl_usart0_cts: usart0_cts-0 { | ||
148 | atmel,pins = | ||
149 | <1 15 0x2 0x0>; /* PB15 periph B */ | ||
146 | }; | 150 | }; |
147 | }; | 151 | }; |
148 | 152 | ||
149 | uart1 { | 153 | uart1 { |
150 | pinctrl_uart1: uart1-0 { | 154 | pinctrl_usart1: usart1-0 { |
151 | atmel,pins = | 155 | atmel,pins = |
152 | <1 4 0x1 0x1 /* PB4 periph A with pullup */ | 156 | <1 4 0x1 0x1 /* PB4 periph A with pullup */ |
153 | 1 5 0x1 0x0>; /* PB5 periph A */ | 157 | 1 5 0x1 0x0>; /* PB5 periph A */ |
154 | }; | 158 | }; |
155 | 159 | ||
156 | pinctrl_uart1_rts_cts: uart1_rts_cts-0 { | 160 | pinctrl_usart1_rts: usart1_rts-0 { |
161 | atmel,pins = | ||
162 | <3 16 0x1 0x0>; /* PD16 periph A */ | ||
163 | }; | ||
164 | |||
165 | pinctrl_usart1_cts: usart1_cts-0 { | ||
157 | atmel,pins = | 166 | atmel,pins = |
158 | <3 16 0x1 0x0 /* PD16 periph A */ | 167 | <3 17 0x1 0x0>; /* PD17 periph A */ |
159 | 3 17 0x1 0x0>; /* PD17 periph A */ | ||
160 | }; | 168 | }; |
161 | }; | 169 | }; |
162 | 170 | ||
163 | uart2 { | 171 | usart2 { |
164 | pinctrl_uart2: uart2-0 { | 172 | pinctrl_usart2: usart2-0 { |
165 | atmel,pins = | 173 | atmel,pins = |
166 | <1 6 0x1 0x1 /* PB6 periph A with pullup */ | 174 | <1 6 0x1 0x1 /* PB6 periph A with pullup */ |
167 | 1 7 0x1 0x0>; /* PB7 periph A */ | 175 | 1 7 0x1 0x0>; /* PB7 periph A */ |
168 | }; | 176 | }; |
169 | 177 | ||
170 | pinctrl_uart2_rts_cts: uart2_rts_cts-0 { | 178 | pinctrl_usart2_rts: usart2_rts-0 { |
171 | atmel,pins = | 179 | atmel,pins = |
172 | <2 9 0x2 0x0 /* PC9 periph B */ | 180 | <2 9 0x2 0x0>; /* PC9 periph B */ |
173 | 2 11 0x2 0x0>; /* PC11 periph B */ | 181 | }; |
182 | |||
183 | pinctrl_usart2_cts: usart2_cts-0 { | ||
184 | atmel,pins = | ||
185 | <2 11 0x2 0x0>; /* PC11 periph B */ | ||
174 | }; | 186 | }; |
175 | }; | 187 | }; |
176 | 188 | ||
177 | uart3 { | 189 | usart3 { |
178 | pinctrl_uart3: uart3-0 { | 190 | pinctrl_usart3: usart3-0 { |
179 | atmel,pins = | 191 | atmel,pins = |
180 | <1 8 0x1 0x1 /* PB9 periph A with pullup */ | 192 | <1 8 0x1 0x1 /* PB9 periph A with pullup */ |
181 | 1 9 0x1 0x0>; /* PB8 periph A */ | 193 | 1 9 0x1 0x0>; /* PB8 periph A */ |
182 | }; | 194 | }; |
183 | 195 | ||
184 | pinctrl_uart3_rts_cts: uart3_rts_cts-0 { | 196 | pinctrl_usart3_rts: usart3_rts-0 { |
197 | atmel,pins = | ||
198 | <0 23 0x2 0x0>; /* PA23 periph B */ | ||
199 | }; | ||
200 | |||
201 | pinctrl_usart3_cts: usart3_cts-0 { | ||
185 | atmel,pins = | 202 | atmel,pins = |
186 | <0 23 0x2 0x0 /* PA23 periph B */ | 203 | <0 24 0x2 0x0>; /* PA24 periph B */ |
187 | 0 24 0x2 0x0>; /* PA24 periph B */ | ||
188 | }; | 204 | }; |
189 | }; | 205 | }; |
190 | 206 | ||
@@ -196,6 +212,34 @@ | |||
196 | }; | 212 | }; |
197 | }; | 213 | }; |
198 | 214 | ||
215 | macb { | ||
216 | pinctrl_macb_rmii: macb_rmii-0 { | ||
217 | atmel,pins = | ||
218 | <0 10 0x1 0x0 /* PA10 periph A */ | ||
219 | 0 11 0x1 0x0 /* PA11 periph A */ | ||
220 | 0 12 0x1 0x0 /* PA12 periph A */ | ||
221 | 0 13 0x1 0x0 /* PA13 periph A */ | ||
222 | 0 14 0x1 0x0 /* PA14 periph A */ | ||
223 | 0 15 0x1 0x0 /* PA15 periph A */ | ||
224 | 0 16 0x1 0x0 /* PA16 periph A */ | ||
225 | 0 17 0x1 0x0 /* PA17 periph A */ | ||
226 | 0 18 0x1 0x0 /* PA18 periph A */ | ||
227 | 0 19 0x1 0x0>; /* PA19 periph A */ | ||
228 | }; | ||
229 | |||
230 | pinctrl_macb_rmii_mii: macb_rmii_mii-0 { | ||
231 | atmel,pins = | ||
232 | <0 6 0x2 0x0 /* PA6 periph B */ | ||
233 | 0 7 0x2 0x0 /* PA7 periph B */ | ||
234 | 0 8 0x2 0x0 /* PA8 periph B */ | ||
235 | 0 9 0x2 0x0 /* PA9 periph B */ | ||
236 | 0 27 0x2 0x0 /* PA27 periph B */ | ||
237 | 0 28 0x2 0x0 /* PA28 periph B */ | ||
238 | 0 29 0x2 0x0 /* PA29 periph B */ | ||
239 | 0 30 0x2 0x0>; /* PA30 periph B */ | ||
240 | }; | ||
241 | }; | ||
242 | |||
199 | pioA: gpio@fffff200 { | 243 | pioA: gpio@fffff200 { |
200 | compatible = "atmel,at91rm9200-gpio"; | 244 | compatible = "atmel,at91rm9200-gpio"; |
201 | reg = <0xfffff200 0x200>; | 245 | reg = <0xfffff200 0x200>; |
@@ -263,7 +307,7 @@ | |||
263 | atmel,use-dma-rx; | 307 | atmel,use-dma-rx; |
264 | atmel,use-dma-tx; | 308 | atmel,use-dma-tx; |
265 | pinctrl-names = "default"; | 309 | pinctrl-names = "default"; |
266 | pinctrl-0 = <&pinctrl_uart0>; | 310 | pinctrl-0 = <&pinctrl_usart0>; |
267 | status = "disabled"; | 311 | status = "disabled"; |
268 | }; | 312 | }; |
269 | 313 | ||
@@ -274,7 +318,7 @@ | |||
274 | atmel,use-dma-rx; | 318 | atmel,use-dma-rx; |
275 | atmel,use-dma-tx; | 319 | atmel,use-dma-tx; |
276 | pinctrl-names = "default"; | 320 | pinctrl-names = "default"; |
277 | pinctrl-0 = <&pinctrl_uart1>; | 321 | pinctrl-0 = <&pinctrl_usart1>; |
278 | status = "disabled"; | 322 | status = "disabled"; |
279 | }; | 323 | }; |
280 | 324 | ||
@@ -285,7 +329,7 @@ | |||
285 | atmel,use-dma-rx; | 329 | atmel,use-dma-rx; |
286 | atmel,use-dma-tx; | 330 | atmel,use-dma-tx; |
287 | pinctrl-names = "default"; | 331 | pinctrl-names = "default"; |
288 | pinctrl-0 = <&pinctrl_uart2>; | 332 | pinctrl-0 = <&pinctrl_usart2>; |
289 | status = "disabled"; | 333 | status = "disabled"; |
290 | }; | 334 | }; |
291 | 335 | ||
@@ -296,7 +340,7 @@ | |||
296 | atmel,use-dma-rx; | 340 | atmel,use-dma-rx; |
297 | atmel,use-dma-tx; | 341 | atmel,use-dma-tx; |
298 | pinctrl-names = "default"; | 342 | pinctrl-names = "default"; |
299 | pinctrl-0 = <&pinctrl_uart3>; | 343 | pinctrl-0 = <&pinctrl_usart3>; |
300 | status = "disabled"; | 344 | status = "disabled"; |
301 | }; | 345 | }; |
302 | 346 | ||
@@ -304,6 +348,8 @@ | |||
304 | compatible = "cdns,at32ap7000-macb", "cdns,macb"; | 348 | compatible = "cdns,at32ap7000-macb", "cdns,macb"; |
305 | reg = <0xfffbc000 0x100>; | 349 | reg = <0xfffbc000 0x100>; |
306 | interrupts = <25 4 3>; | 350 | interrupts = <25 4 3>; |
351 | pinctrl-names = "default"; | ||
352 | pinctrl-0 = <&pinctrl_macb_rmii>; | ||
307 | status = "disabled"; | 353 | status = "disabled"; |
308 | }; | 354 | }; |
309 | 355 | ||
diff --git a/arch/arm/boot/dts/at91sam9m10g45ek.dts b/arch/arm/boot/dts/at91sam9m10g45ek.dts index 6aa28b941907..afd586720b15 100644 --- a/arch/arm/boot/dts/at91sam9m10g45ek.dts +++ b/arch/arm/boot/dts/at91sam9m10g45ek.dts | |||
@@ -39,7 +39,10 @@ | |||
39 | }; | 39 | }; |
40 | 40 | ||
41 | usart1: serial@fff90000 { | 41 | usart1: serial@fff90000 { |
42 | pinctrl-0 = <&pinctrl_uart0 &pinctrl_uart1_rts_cts>; | 42 | pinctrl-0 = |
43 | <&pinctrl_usart1 | ||
44 | &pinctrl_usart1_rts | ||
45 | &pinctrl_usart1_cts>; | ||
43 | status = "okay"; | 46 | status = "okay"; |
44 | }; | 47 | }; |
45 | 48 | ||
diff --git a/arch/arm/boot/dts/at91sam9n12.dtsi b/arch/arm/boot/dts/at91sam9n12.dtsi index 7b644c5b0bed..1667937bb2e2 100644 --- a/arch/arm/boot/dts/at91sam9n12.dtsi +++ b/arch/arm/boot/dts/at91sam9n12.dtsi | |||
@@ -125,66 +125,78 @@ | |||
125 | }; | 125 | }; |
126 | }; | 126 | }; |
127 | 127 | ||
128 | uart0 { | 128 | usart0 { |
129 | pinctrl_uart0: uart0-0 { | 129 | pinctrl_usart0: usart0-0 { |
130 | atmel,pins = | 130 | atmel,pins = |
131 | <0 1 0x1 0x1 /* PA1 periph A with pullup */ | 131 | <0 1 0x1 0x1 /* PA1 periph A with pullup */ |
132 | 0 0 0x1 0x0>; /* PA0 periph A */ | 132 | 0 0 0x1 0x0>; /* PA0 periph A */ |
133 | }; | 133 | }; |
134 | 134 | ||
135 | pinctrl_uart0_rts_cts: uart0_rts_cts-0 { | 135 | pinctrl_usart0_rts: usart0_rts-0 { |
136 | atmel,pins = | ||
137 | <0 2 0x1 0x0>; /* PA2 periph A */ | ||
138 | }; | ||
139 | |||
140 | pinctrl_usart0_cts: usart0_cts-0 { | ||
136 | atmel,pins = | 141 | atmel,pins = |
137 | <0 2 0x1 0x0 /* PA2 periph A */ | 142 | <0 3 0x1 0x0>; /* PA3 periph A */ |
138 | 0 3 0x1 0x0>; /* PA3 periph A */ | ||
139 | }; | 143 | }; |
140 | }; | 144 | }; |
141 | 145 | ||
142 | uart1 { | 146 | usart1 { |
143 | pinctrl_uart1: uart1-0 { | 147 | pinctrl_usart1: usart1-0 { |
144 | atmel,pins = | 148 | atmel,pins = |
145 | <0 6 0x1 0x1 /* PA6 periph A with pullup */ | 149 | <0 6 0x1 0x1 /* PA6 periph A with pullup */ |
146 | 0 5 0x1 0x0>; /* PA5 periph A */ | 150 | 0 5 0x1 0x0>; /* PA5 periph A */ |
147 | }; | 151 | }; |
148 | }; | 152 | }; |
149 | 153 | ||
150 | uart2 { | 154 | usart2 { |
151 | pinctrl_uart2: uart2-0 { | 155 | pinctrl_usart2: usart2-0 { |
152 | atmel,pins = | 156 | atmel,pins = |
153 | <0 8 0x1 0x1 /* PA8 periph A with pullup */ | 157 | <0 8 0x1 0x1 /* PA8 periph A with pullup */ |
154 | 0 7 0x1 0x0>; /* PA7 periph A */ | 158 | 0 7 0x1 0x0>; /* PA7 periph A */ |
155 | }; | 159 | }; |
156 | 160 | ||
157 | pinctrl_uart2_rts_cts: uart2_rts_cts-0 { | 161 | pinctrl_usart2_rts: usart2_rts-0 { |
158 | atmel,pins = | 162 | atmel,pins = |
159 | <1 0 0x2 0x0 /* PB0 periph B */ | 163 | <1 0 0x2 0x0>; /* PB0 periph B */ |
160 | 1 1 0x2 0x0>; /* PB1 periph B */ | 164 | }; |
165 | |||
166 | pinctrl_usart2_cts: usart2_cts-0 { | ||
167 | atmel,pins = | ||
168 | <1 1 0x2 0x0>; /* PB1 periph B */ | ||
161 | }; | 169 | }; |
162 | }; | 170 | }; |
163 | 171 | ||
164 | uart3 { | 172 | usart3 { |
165 | pinctrl_uart3: uart3-0 { | 173 | pinctrl_usart3: usart3-0 { |
166 | atmel,pins = | 174 | atmel,pins = |
167 | <2 23 0x2 0x1 /* PC23 periph B with pullup */ | 175 | <2 23 0x2 0x1 /* PC23 periph B with pullup */ |
168 | 2 22 0x2 0x0>; /* PC22 periph B */ | 176 | 2 22 0x2 0x0>; /* PC22 periph B */ |
169 | }; | 177 | }; |
170 | 178 | ||
171 | pinctrl_uart3_rts_cts: uart3_rts_cts-0 { | 179 | pinctrl_usart3_rts: usart3_rts-0 { |
180 | atmel,pins = | ||
181 | <2 24 0x2 0x0>; /* PC24 periph B */ | ||
182 | }; | ||
183 | |||
184 | pinctrl_usart3_cts: usart3_cts-0 { | ||
172 | atmel,pins = | 185 | atmel,pins = |
173 | <2 24 0x2 0x0 /* PC24 periph B */ | 186 | <2 25 0x2 0x0>; /* PC25 periph B */ |
174 | 2 25 0x2 0x0>; /* PC25 periph B */ | ||
175 | }; | 187 | }; |
176 | }; | 188 | }; |
177 | 189 | ||
178 | usart0 { | 190 | uart0 { |
179 | pinctrl_usart0: usart0-0 { | 191 | pinctrl_uart0: uart0-0 { |
180 | atmel,pins = | 192 | atmel,pins = |
181 | <2 9 0x3 0x1 /* PC9 periph C with pullup */ | 193 | <2 9 0x3 0x1 /* PC9 periph C with pullup */ |
182 | 2 8 0x3 0x0>; /* PC8 periph C */ | 194 | 2 8 0x3 0x0>; /* PC8 periph C */ |
183 | }; | 195 | }; |
184 | }; | 196 | }; |
185 | 197 | ||
186 | usart1 { | 198 | uart1 { |
187 | pinctrl_usart1: usart1-0 { | 199 | pinctrl_uart1: uart1-0 { |
188 | atmel,pins = | 200 | atmel,pins = |
189 | <2 16 0x3 0x1 /* PC17 periph C with pullup */ | 201 | <2 16 0x3 0x1 /* PC17 periph C with pullup */ |
190 | 2 17 0x3 0x0>; /* PC16 periph C */ | 202 | 2 17 0x3 0x0>; /* PC16 periph C */ |
@@ -256,7 +268,7 @@ | |||
256 | atmel,use-dma-rx; | 268 | atmel,use-dma-rx; |
257 | atmel,use-dma-tx; | 269 | atmel,use-dma-tx; |
258 | pinctrl-names = "default"; | 270 | pinctrl-names = "default"; |
259 | pinctrl-0 = <&pinctrl_uart0>; | 271 | pinctrl-0 = <&pinctrl_usart0>; |
260 | status = "disabled"; | 272 | status = "disabled"; |
261 | }; | 273 | }; |
262 | 274 | ||
@@ -267,7 +279,7 @@ | |||
267 | atmel,use-dma-rx; | 279 | atmel,use-dma-rx; |
268 | atmel,use-dma-tx; | 280 | atmel,use-dma-tx; |
269 | pinctrl-names = "default"; | 281 | pinctrl-names = "default"; |
270 | pinctrl-0 = <&pinctrl_uart1>; | 282 | pinctrl-0 = <&pinctrl_usart1>; |
271 | status = "disabled"; | 283 | status = "disabled"; |
272 | }; | 284 | }; |
273 | 285 | ||
@@ -278,7 +290,7 @@ | |||
278 | atmel,use-dma-rx; | 290 | atmel,use-dma-rx; |
279 | atmel,use-dma-tx; | 291 | atmel,use-dma-tx; |
280 | pinctrl-names = "default"; | 292 | pinctrl-names = "default"; |
281 | pinctrl-0 = <&pinctrl_uart2>; | 293 | pinctrl-0 = <&pinctrl_usart2>; |
282 | status = "disabled"; | 294 | status = "disabled"; |
283 | }; | 295 | }; |
284 | 296 | ||
@@ -289,7 +301,7 @@ | |||
289 | atmel,use-dma-rx; | 301 | atmel,use-dma-rx; |
290 | atmel,use-dma-tx; | 302 | atmel,use-dma-tx; |
291 | pinctrl-names = "default"; | 303 | pinctrl-names = "default"; |
292 | pinctrl-0 = <&pinctrl_uart3>; | 304 | pinctrl-0 = <&pinctrl_usart3>; |
293 | status = "disabled"; | 305 | status = "disabled"; |
294 | }; | 306 | }; |
295 | 307 | ||
diff --git a/arch/arm/boot/dts/at91sam9x25.dtsi b/arch/arm/boot/dts/at91sam9x25.dtsi index 956c65f7c39f..54eb33ba6d22 100644 --- a/arch/arm/boot/dts/at91sam9x25.dtsi +++ b/arch/arm/boot/dts/at91sam9x25.dtsi | |||
@@ -22,6 +22,27 @@ | |||
22 | 0x80000000 0xfffd0000 0xb83fffff /* pioC */ | 22 | 0x80000000 0xfffd0000 0xb83fffff /* pioC */ |
23 | 0x003fffff 0x003f8000 0x00000000 /* pioD */ | 23 | 0x003fffff 0x003f8000 0x00000000 /* pioD */ |
24 | >; | 24 | >; |
25 | |||
26 | macb1 { | ||
27 | pinctrl_macb1_rmii: macb1_rmii-0 { | ||
28 | atmel,pins = | ||
29 | <2 16 0x2 0x0 /* PC16 periph B */ | ||
30 | 2 18 0x2 0x0 /* PC18 periph B */ | ||
31 | 2 19 0x2 0x0 /* PC19 periph B */ | ||
32 | 2 20 0x2 0x0 /* PC20 periph B */ | ||
33 | 2 21 0x2 0x0 /* PC21 periph B */ | ||
34 | 2 27 0x2 0x0 /* PC27 periph B */ | ||
35 | 2 28 0x2 0x0 /* PC28 periph B */ | ||
36 | 2 29 0x2 0x0 /* PC29 periph B */ | ||
37 | 2 30 0x2 0x0 /* PC30 periph B */ | ||
38 | 2 31 0x2 0x0>; /* PC31 periph B */ | ||
39 | }; | ||
40 | }; | ||
41 | }; | ||
42 | |||
43 | macb1: ethernet@f8030000 { | ||
44 | pinctrl-names = "default"; | ||
45 | pinctrl-0 = <&pinctrl_macb1_rmii>; | ||
25 | }; | 46 | }; |
26 | }; | 47 | }; |
27 | }; | 48 | }; |
diff --git a/arch/arm/boot/dts/at91sam9x5.dtsi b/arch/arm/boot/dts/at91sam9x5.dtsi index 6a40b777ea4c..3642ab1eeaf6 100644 --- a/arch/arm/boot/dts/at91sam9x5.dtsi +++ b/arch/arm/boot/dts/at91sam9x5.dtsi | |||
@@ -126,72 +126,88 @@ | |||
126 | }; | 126 | }; |
127 | }; | 127 | }; |
128 | 128 | ||
129 | uart0 { | 129 | usart0 { |
130 | pinctrl_uart0: uart0-0 { | 130 | pinctrl_usart0: usart0-0 { |
131 | atmel,pins = | 131 | atmel,pins = |
132 | <0 0 0x1 0x1 /* PA0 periph A with pullup */ | 132 | <0 0 0x1 0x1 /* PA0 periph A with pullup */ |
133 | 0 1 0x1 0x0>; /* PA1 periph A */ | 133 | 0 1 0x1 0x0>; /* PA1 periph A */ |
134 | }; | 134 | }; |
135 | 135 | ||
136 | pinctrl_uart0_rts_cts: uart0_rts_cts-0 { | 136 | pinctrl_usart0_rts: usart0_rts-0 { |
137 | atmel,pins = | 137 | atmel,pins = |
138 | <0 2 0x1 0x0 /* PA2 periph A */ | 138 | <0 2 0x1 0x0>; /* PA2 periph A */ |
139 | 0 3 0x1 0x0>; /* PA3 periph A */ | 139 | }; |
140 | |||
141 | pinctrl_usart0_cts: usart0_cts-0 { | ||
142 | atmel,pins = | ||
143 | <0 3 0x1 0x0>; /* PA3 periph A */ | ||
140 | }; | 144 | }; |
141 | }; | 145 | }; |
142 | 146 | ||
143 | uart1 { | 147 | usart1 { |
144 | pinctrl_uart1: uart1-0 { | 148 | pinctrl_usart1: usart1-0 { |
145 | atmel,pins = | 149 | atmel,pins = |
146 | <0 5 0x1 0x1 /* PA5 periph A with pullup */ | 150 | <0 5 0x1 0x1 /* PA5 periph A with pullup */ |
147 | 0 6 0x1 0x0>; /* PA6 periph A */ | 151 | 0 6 0x1 0x0>; /* PA6 periph A */ |
148 | }; | 152 | }; |
149 | 153 | ||
150 | pinctrl_uart1_rts_cts: uart1_rts_cts-0 { | 154 | pinctrl_usart1_rts: usart1_rts-0 { |
155 | atmel,pins = | ||
156 | <3 27 0x3 0x0>; /* PC27 periph C */ | ||
157 | }; | ||
158 | |||
159 | pinctrl_usart1_cts: usart1_cts-0 { | ||
151 | atmel,pins = | 160 | atmel,pins = |
152 | <3 27 0x3 0x0 /* PC27 periph C */ | 161 | <3 28 0x3 0x0>; /* PC28 periph C */ |
153 | 3 28 0x3 0x0>; /* PC28 periph C */ | ||
154 | }; | 162 | }; |
155 | }; | 163 | }; |
156 | 164 | ||
157 | uart2 { | 165 | usart2 { |
158 | pinctrl_uart2: uart2-0 { | 166 | pinctrl_usart2: usart2-0 { |
159 | atmel,pins = | 167 | atmel,pins = |
160 | <0 7 0x1 0x1 /* PA7 periph A with pullup */ | 168 | <0 7 0x1 0x1 /* PA7 periph A with pullup */ |
161 | 0 8 0x1 0x0>; /* PA8 periph A */ | 169 | 0 8 0x1 0x0>; /* PA8 periph A */ |
162 | }; | 170 | }; |
163 | 171 | ||
164 | pinctrl_uart2_rts_cts: uart2_rts_cts-0 { | 172 | pinctrl_uart2_rts: uart2_rts-0 { |
165 | atmel,pins = | 173 | atmel,pins = |
166 | <0 0 0x2 0x0 /* PB0 periph B */ | 174 | <0 0 0x2 0x0>; /* PB0 periph B */ |
167 | 0 1 0x2 0x0>; /* PB1 periph B */ | 175 | }; |
176 | |||
177 | pinctrl_uart2_cts: uart2_cts-0 { | ||
178 | atmel,pins = | ||
179 | <0 1 0x2 0x0>; /* PB1 periph B */ | ||
168 | }; | 180 | }; |
169 | }; | 181 | }; |
170 | 182 | ||
171 | uart3 { | 183 | usart3 { |
172 | pinctrl_uart3: uart3-0 { | 184 | pinctrl_uart3: usart3-0 { |
173 | atmel,pins = | 185 | atmel,pins = |
174 | <3 23 0x2 0x1 /* PC22 periph B with pullup */ | 186 | <3 23 0x2 0x1 /* PC22 periph B with pullup */ |
175 | 3 23 0x2 0x0>; /* PC23 periph B */ | 187 | 3 23 0x2 0x0>; /* PC23 periph B */ |
176 | }; | 188 | }; |
177 | 189 | ||
178 | pinctrl_uart3_rts_cts: uart3_rts_cts-0 { | 190 | pinctrl_usart3_rts: usart3_rts-0 { |
191 | atmel,pins = | ||
192 | <3 24 0x2 0x0>; /* PC24 periph B */ | ||
193 | }; | ||
194 | |||
195 | pinctrl_usart3_cts: usart3_cts-0 { | ||
179 | atmel,pins = | 196 | atmel,pins = |
180 | <3 24 0x2 0x0 /* PC24 periph B */ | 197 | <3 25 0x2 0x0>; /* PC25 periph B */ |
181 | 3 25 0x2 0x0>; /* PC25 periph B */ | ||
182 | }; | 198 | }; |
183 | }; | 199 | }; |
184 | 200 | ||
185 | usart0 { | 201 | uart0 { |
186 | pinctrl_usart0: usart0-0 { | 202 | pinctrl_uart0: uart0-0 { |
187 | atmel,pins = | 203 | atmel,pins = |
188 | <3 8 0x3 0x0 /* PC8 periph C */ | 204 | <3 8 0x3 0x0 /* PC8 periph C */ |
189 | 3 9 0x3 0x1>; /* PC9 periph C with pullup */ | 205 | 3 9 0x3 0x1>; /* PC9 periph C with pullup */ |
190 | }; | 206 | }; |
191 | }; | 207 | }; |
192 | 208 | ||
193 | usart1 { | 209 | uart1 { |
194 | pinctrl_usart1: usart1-0 { | 210 | pinctrl_uart1: uart1-0 { |
195 | atmel,pins = | 211 | atmel,pins = |
196 | <3 16 0x3 0x0 /* PC16 periph C */ | 212 | <3 16 0x3 0x0 /* PC16 periph C */ |
197 | 3 17 0x3 0x1>; /* PC17 periph C with pullup */ | 213 | 3 17 0x3 0x1>; /* PC17 periph C with pullup */ |
@@ -206,6 +222,34 @@ | |||
206 | }; | 222 | }; |
207 | }; | 223 | }; |
208 | 224 | ||
225 | macb0 { | ||
226 | pinctrl_macb0_rmii: macb0_rmii-0 { | ||
227 | atmel,pins = | ||
228 | <1 0 0x1 0x0 /* PB0 periph A */ | ||
229 | 1 1 0x1 0x0 /* PB1 periph A */ | ||
230 | 1 2 0x1 0x0 /* PB2 periph A */ | ||
231 | 1 3 0x1 0x0 /* PB3 periph A */ | ||
232 | 1 4 0x1 0x0 /* PB4 periph A */ | ||
233 | 1 5 0x1 0x0 /* PB5 periph A */ | ||
234 | 1 6 0x1 0x0 /* PB6 periph A */ | ||
235 | 1 7 0x1 0x0 /* PB7 periph A */ | ||
236 | 1 9 0x1 0x0 /* PB9 periph A */ | ||
237 | 1 10 0x1 0x0>; /* PB10 periph A */ | ||
238 | }; | ||
239 | |||
240 | pinctrl_macb0_rmii_mii: macb0_rmii_mii-0 { | ||
241 | atmel,pins = | ||
242 | <1 8 0x1 0x0 /* PA8 periph A */ | ||
243 | 1 11 0x1 0x0 /* PA11 periph A */ | ||
244 | 1 12 0x1 0x0 /* PA12 periph A */ | ||
245 | 1 13 0x1 0x0 /* PA13 periph A */ | ||
246 | 1 14 0x1 0x0 /* PA14 periph A */ | ||
247 | 1 15 0x1 0x0 /* PA15 periph A */ | ||
248 | 1 16 0x1 0x0 /* PA16 periph A */ | ||
249 | 1 17 0x1 0x0>; /* PA17 periph A */ | ||
250 | }; | ||
251 | }; | ||
252 | |||
209 | pioA: gpio@fffff400 { | 253 | pioA: gpio@fffff400 { |
210 | compatible = "atmel,at91sam9x5-gpio", "atmel,at91rm9200-gpio"; | 254 | compatible = "atmel,at91sam9x5-gpio", "atmel,at91rm9200-gpio"; |
211 | reg = <0xfffff400 0x200>; | 255 | reg = <0xfffff400 0x200>; |
@@ -265,7 +309,7 @@ | |||
265 | atmel,use-dma-rx; | 309 | atmel,use-dma-rx; |
266 | atmel,use-dma-tx; | 310 | atmel,use-dma-tx; |
267 | pinctrl-names = "default"; | 311 | pinctrl-names = "default"; |
268 | pinctrl-0 = <&pinctrl_uart0>; | 312 | pinctrl-0 = <&pinctrl_usart0>; |
269 | status = "disabled"; | 313 | status = "disabled"; |
270 | }; | 314 | }; |
271 | 315 | ||
@@ -276,7 +320,7 @@ | |||
276 | atmel,use-dma-rx; | 320 | atmel,use-dma-rx; |
277 | atmel,use-dma-tx; | 321 | atmel,use-dma-tx; |
278 | pinctrl-names = "default"; | 322 | pinctrl-names = "default"; |
279 | pinctrl-0 = <&pinctrl_uart1>; | 323 | pinctrl-0 = <&pinctrl_usart1>; |
280 | status = "disabled"; | 324 | status = "disabled"; |
281 | }; | 325 | }; |
282 | 326 | ||
@@ -287,7 +331,7 @@ | |||
287 | atmel,use-dma-rx; | 331 | atmel,use-dma-rx; |
288 | atmel,use-dma-tx; | 332 | atmel,use-dma-tx; |
289 | pinctrl-names = "default"; | 333 | pinctrl-names = "default"; |
290 | pinctrl-0 = <&pinctrl_uart2>; | 334 | pinctrl-0 = <&pinctrl_usart2>; |
291 | status = "disabled"; | 335 | status = "disabled"; |
292 | }; | 336 | }; |
293 | 337 | ||
@@ -295,6 +339,8 @@ | |||
295 | compatible = "cdns,at32ap7000-macb", "cdns,macb"; | 339 | compatible = "cdns,at32ap7000-macb", "cdns,macb"; |
296 | reg = <0xf802c000 0x100>; | 340 | reg = <0xf802c000 0x100>; |
297 | interrupts = <24 4 3>; | 341 | interrupts = <24 4 3>; |
342 | pinctrl-names = "default"; | ||
343 | pinctrl-0 = <&pinctrl_macb0_rmii>; | ||
298 | status = "disabled"; | 344 | status = "disabled"; |
299 | }; | 345 | }; |
300 | 346 | ||
diff --git a/arch/arm/boot/dts/pm9g45.dts b/arch/arm/boot/dts/pm9g45.dts new file mode 100644 index 000000000000..b0c258dd19ed --- /dev/null +++ b/arch/arm/boot/dts/pm9g45.dts | |||
@@ -0,0 +1,144 @@ | |||
1 | /* | ||
2 | * pm9g45.dts - Device Tree file for Ronetix pm9g45 board | ||
3 | * | ||
4 | * Copyright (C) 2012 Jean-Christophe PLAGNIOL-VILLARD <plagnioj@jcrosoft.com> | ||
5 | * | ||
6 | * Licensed under GPLv2. | ||
7 | */ | ||
8 | /dts-v1/; | ||
9 | /include/ "at91sam9g45.dtsi" | ||
10 | |||
11 | / { | ||
12 | model = "Ronetix pm9g45"; | ||
13 | compatible = "ronetix,pm9g45", "atmel,at91sam9g45", "atmel,at91sam9"; | ||
14 | |||
15 | chosen { | ||
16 | bootargs = "console=ttyS0,115200"; | ||
17 | }; | ||
18 | |||
19 | memory { | ||
20 | reg = <0x70000000 0x8000000>; | ||
21 | }; | ||
22 | |||
23 | clocks { | ||
24 | #address-cells = <1>; | ||
25 | #size-cells = <1>; | ||
26 | ranges; | ||
27 | |||
28 | main_clock: clock@0 { | ||
29 | compatible = "atmel,osc", "fixed-clock"; | ||
30 | clock-frequency = <12000000>; | ||
31 | }; | ||
32 | }; | ||
33 | |||
34 | ahb { | ||
35 | apb { | ||
36 | dbgu: serial@ffffee00 { | ||
37 | status = "okay"; | ||
38 | }; | ||
39 | |||
40 | pinctrl@fffff200 { | ||
41 | |||
42 | board { | ||
43 | pinctrl_board_nand: nand0-board { | ||
44 | atmel,pins = | ||
45 | <3 3 0x0 0x1 /* PD3 gpio RDY pin pull_up*/ | ||
46 | 2 14 0x0 0x1>; /* PC14 gpio enable pin pull_up */ | ||
47 | }; | ||
48 | }; | ||
49 | }; | ||
50 | |||
51 | macb0: ethernet@fffbc000 { | ||
52 | phy-mode = "rmii"; | ||
53 | status = "okay"; | ||
54 | }; | ||
55 | }; | ||
56 | |||
57 | nand0: nand@40000000 { | ||
58 | nand-bus-width = <8>; | ||
59 | nand-ecc-mode = "soft"; | ||
60 | nand-on-flash-bbt; | ||
61 | pinctrl-0 = <&pinctrl_board_nand>; | ||
62 | |||
63 | gpios = <&pioD 3 0 | ||
64 | &pioC 14 0 | ||
65 | 0 | ||
66 | >; | ||
67 | |||
68 | status = "okay"; | ||
69 | |||
70 | at91bootstrap@0 { | ||
71 | label = "at91bootstrap"; | ||
72 | reg = <0x0 0x20000>; | ||
73 | }; | ||
74 | |||
75 | barebox@20000 { | ||
76 | label = "barebox"; | ||
77 | reg = <0x20000 0x40000>; | ||
78 | }; | ||
79 | |||
80 | bareboxenv@60000 { | ||
81 | label = "bareboxenv"; | ||
82 | reg = <0x60000 0x1A0000>; | ||
83 | }; | ||
84 | |||
85 | kernel@200000 { | ||
86 | label = "bareboxenv2"; | ||
87 | reg = <0x200000 0x300000>; | ||
88 | }; | ||
89 | |||
90 | kernel@500000 { | ||
91 | label = "root"; | ||
92 | reg = <0x500000 0x400000>; | ||
93 | }; | ||
94 | |||
95 | data@900000 { | ||
96 | label = "data"; | ||
97 | reg = <0x900000 0x8340000>; | ||
98 | }; | ||
99 | }; | ||
100 | |||
101 | usb0: ohci@00700000 { | ||
102 | status = "okay"; | ||
103 | num-ports = <2>; | ||
104 | }; | ||
105 | |||
106 | usb1: ehci@00800000 { | ||
107 | status = "okay"; | ||
108 | }; | ||
109 | }; | ||
110 | |||
111 | leds { | ||
112 | compatible = "gpio-leds"; | ||
113 | |||
114 | led0 { | ||
115 | label = "led0"; | ||
116 | gpios = <&pioD 0 1>; | ||
117 | linux,default-trigger = "nand-disk"; | ||
118 | }; | ||
119 | |||
120 | led1 { | ||
121 | label = "led1"; | ||
122 | gpios = <&pioD 31 0>; | ||
123 | linux,default-trigger = "heartbeat"; | ||
124 | }; | ||
125 | }; | ||
126 | |||
127 | gpio_keys { | ||
128 | compatible = "gpio-keys"; | ||
129 | #address-cells = <1>; | ||
130 | #size-cells = <0>; | ||
131 | |||
132 | right { | ||
133 | label = "SW4"; | ||
134 | gpios = <&pioE 7 1>; | ||
135 | linux,code = <106>; | ||
136 | }; | ||
137 | |||
138 | up { | ||
139 | label = "SW3"; | ||
140 | gpios = <&pioE 8 1>; | ||
141 | linux,code = <103>; | ||
142 | }; | ||
143 | }; | ||
144 | }; | ||
diff --git a/arch/arm/mach-at91/Kconfig b/arch/arm/mach-at91/Kconfig index 043624219b55..e34c1bdb804d 100644 --- a/arch/arm/mach-at91/Kconfig +++ b/arch/arm/mach-at91/Kconfig | |||
@@ -494,8 +494,17 @@ endif | |||
494 | 494 | ||
495 | comment "Generic Board Type" | 495 | comment "Generic Board Type" |
496 | 496 | ||
497 | config MACH_AT91RM9200_DT | ||
498 | bool "Atmel AT91RM9200 Evaluation Kits with device-tree support" | ||
499 | depends on SOC_AT91RM9200 | ||
500 | select USE_OF | ||
501 | help | ||
502 | Select this if you want to experiment device-tree with | ||
503 | an Atmel RM9200 Evaluation Kit. | ||
504 | |||
497 | config MACH_AT91SAM_DT | 505 | config MACH_AT91SAM_DT |
498 | bool "Atmel AT91SAM Evaluation Kits with device-tree support" | 506 | bool "Atmel AT91SAM Evaluation Kits with device-tree support" |
507 | depends on SOC_AT91SAM9 | ||
499 | select USE_OF | 508 | select USE_OF |
500 | help | 509 | help |
501 | Select this if you want to experiment device-tree with | 510 | Select this if you want to experiment device-tree with |
diff --git a/arch/arm/mach-at91/Makefile b/arch/arm/mach-at91/Makefile index 3bb7a51efc9d..b38a1dcb79b8 100644 --- a/arch/arm/mach-at91/Makefile +++ b/arch/arm/mach-at91/Makefile | |||
@@ -88,6 +88,7 @@ obj-$(CONFIG_MACH_SNAPPER_9260) += board-snapper9260.o | |||
88 | obj-$(CONFIG_MACH_AT91SAM9M10G45EK) += board-sam9m10g45ek.o | 88 | obj-$(CONFIG_MACH_AT91SAM9M10G45EK) += board-sam9m10g45ek.o |
89 | 89 | ||
90 | # AT91SAM board with device-tree | 90 | # AT91SAM board with device-tree |
91 | obj-$(CONFIG_MACH_AT91RM9200_DT) += board-rm9200-dt.o | ||
91 | obj-$(CONFIG_MACH_AT91SAM_DT) += board-dt.o | 92 | obj-$(CONFIG_MACH_AT91SAM_DT) += board-dt.o |
92 | 93 | ||
93 | # AT91X40 board-specific support | 94 | # AT91X40 board-specific support |
diff --git a/arch/arm/mach-at91/at91rm9200.c b/arch/arm/mach-at91/at91rm9200.c index a3e4710d7352..6cceb42a4c33 100644 --- a/arch/arm/mach-at91/at91rm9200.c +++ b/arch/arm/mach-at91/at91rm9200.c | |||
@@ -194,6 +194,24 @@ static struct clk_lookup periph_clocks_lookups[] = { | |||
194 | CLKDEV_CON_ID("pioB", &pioB_clk), | 194 | CLKDEV_CON_ID("pioB", &pioB_clk), |
195 | CLKDEV_CON_ID("pioC", &pioC_clk), | 195 | CLKDEV_CON_ID("pioC", &pioC_clk), |
196 | CLKDEV_CON_ID("pioD", &pioD_clk), | 196 | CLKDEV_CON_ID("pioD", &pioD_clk), |
197 | /* usart lookup table for DT entries */ | ||
198 | CLKDEV_CON_DEV_ID("usart", "fffff200.serial", &mck), | ||
199 | CLKDEV_CON_DEV_ID("usart", "fffc0000.serial", &usart0_clk), | ||
200 | CLKDEV_CON_DEV_ID("usart", "fffc4000.serial", &usart1_clk), | ||
201 | CLKDEV_CON_DEV_ID("usart", "fffc8000.serial", &usart2_clk), | ||
202 | CLKDEV_CON_DEV_ID("usart", "fffcc000.serial", &usart3_clk), | ||
203 | /* tc lookup table for DT entries */ | ||
204 | CLKDEV_CON_DEV_ID("t0_clk", "fffa0000.timer", &tc0_clk), | ||
205 | CLKDEV_CON_DEV_ID("t1_clk", "fffa0000.timer", &tc1_clk), | ||
206 | CLKDEV_CON_DEV_ID("t2_clk", "fffa0000.timer", &tc2_clk), | ||
207 | CLKDEV_CON_DEV_ID("t0_clk", "fffa4000.timer", &tc3_clk), | ||
208 | CLKDEV_CON_DEV_ID("t1_clk", "fffa4000.timer", &tc4_clk), | ||
209 | CLKDEV_CON_DEV_ID("t2_clk", "fffa4000.timer", &tc5_clk), | ||
210 | CLKDEV_CON_DEV_ID("hclk", "300000.ohci", &ohci_clk), | ||
211 | CLKDEV_CON_DEV_ID(NULL, "fffff400.gpio", &pioA_clk), | ||
212 | CLKDEV_CON_DEV_ID(NULL, "fffff600.gpio", &pioB_clk), | ||
213 | CLKDEV_CON_DEV_ID(NULL, "fffff800.gpio", &pioC_clk), | ||
214 | CLKDEV_CON_DEV_ID(NULL, "fffffa00.gpio", &pioD_clk), | ||
197 | }; | 215 | }; |
198 | 216 | ||
199 | static struct clk_lookup usart_clocks_lookups[] = { | 217 | static struct clk_lookup usart_clocks_lookups[] = { |
diff --git a/arch/arm/mach-at91/at91rm9200_time.c b/arch/arm/mach-at91/at91rm9200_time.c index aaa443b48c91..cafe98836c8a 100644 --- a/arch/arm/mach-at91/at91rm9200_time.c +++ b/arch/arm/mach-at91/at91rm9200_time.c | |||
@@ -24,6 +24,9 @@ | |||
24 | #include <linux/irq.h> | 24 | #include <linux/irq.h> |
25 | #include <linux/clockchips.h> | 25 | #include <linux/clockchips.h> |
26 | #include <linux/export.h> | 26 | #include <linux/export.h> |
27 | #include <linux/of.h> | ||
28 | #include <linux/of_address.h> | ||
29 | #include <linux/of_irq.h> | ||
27 | 30 | ||
28 | #include <asm/mach/time.h> | 31 | #include <asm/mach/time.h> |
29 | 32 | ||
@@ -91,7 +94,8 @@ static irqreturn_t at91rm9200_timer_interrupt(int irq, void *dev_id) | |||
91 | static struct irqaction at91rm9200_timer_irq = { | 94 | static struct irqaction at91rm9200_timer_irq = { |
92 | .name = "at91_tick", | 95 | .name = "at91_tick", |
93 | .flags = IRQF_SHARED | IRQF_DISABLED | IRQF_TIMER | IRQF_IRQPOLL, | 96 | .flags = IRQF_SHARED | IRQF_DISABLED | IRQF_TIMER | IRQF_IRQPOLL, |
94 | .handler = at91rm9200_timer_interrupt | 97 | .handler = at91rm9200_timer_interrupt, |
98 | .irq = NR_IRQS_LEGACY + AT91_ID_SYS, | ||
95 | }; | 99 | }; |
96 | 100 | ||
97 | static cycle_t read_clk32k(struct clocksource *cs) | 101 | static cycle_t read_clk32k(struct clocksource *cs) |
@@ -179,8 +183,60 @@ static struct clock_event_device clkevt = { | |||
179 | void __iomem *at91_st_base; | 183 | void __iomem *at91_st_base; |
180 | EXPORT_SYMBOL_GPL(at91_st_base); | 184 | EXPORT_SYMBOL_GPL(at91_st_base); |
181 | 185 | ||
186 | #ifdef CONFIG_OF | ||
187 | static struct of_device_id at91rm9200_st_timer_ids[] = { | ||
188 | { .compatible = "atmel,at91rm9200-st" }, | ||
189 | { /* sentinel */ } | ||
190 | }; | ||
191 | |||
192 | static int __init of_at91rm9200_st_init(void) | ||
193 | { | ||
194 | struct device_node *np; | ||
195 | int ret; | ||
196 | |||
197 | np = of_find_matching_node(NULL, at91rm9200_st_timer_ids); | ||
198 | if (!np) | ||
199 | goto err; | ||
200 | |||
201 | at91_st_base = of_iomap(np, 0); | ||
202 | if (!at91_st_base) | ||
203 | goto node_err; | ||
204 | |||
205 | /* Get the interrupts property */ | ||
206 | ret = irq_of_parse_and_map(np, 0); | ||
207 | if (!ret) | ||
208 | goto ioremap_err; | ||
209 | at91rm9200_timer_irq.irq = ret; | ||
210 | |||
211 | of_node_put(np); | ||
212 | |||
213 | return 0; | ||
214 | |||
215 | ioremap_err: | ||
216 | iounmap(at91_st_base); | ||
217 | node_err: | ||
218 | of_node_put(np); | ||
219 | err: | ||
220 | return -EINVAL; | ||
221 | } | ||
222 | #else | ||
223 | static int __init of_at91rm9200_st_init(void) | ||
224 | { | ||
225 | return -EINVAL; | ||
226 | } | ||
227 | #endif | ||
228 | |||
182 | void __init at91rm9200_ioremap_st(u32 addr) | 229 | void __init at91rm9200_ioremap_st(u32 addr) |
183 | { | 230 | { |
231 | #ifdef CONFIG_OF | ||
232 | struct device_node *np; | ||
233 | |||
234 | np = of_find_matching_node(NULL, at91rm9200_st_timer_ids); | ||
235 | if (np) { | ||
236 | of_node_put(np); | ||
237 | return; | ||
238 | } | ||
239 | #endif | ||
184 | at91_st_base = ioremap(addr, 256); | 240 | at91_st_base = ioremap(addr, 256); |
185 | if (!at91_st_base) | 241 | if (!at91_st_base) |
186 | panic("Impossible to ioremap ST\n"); | 242 | panic("Impossible to ioremap ST\n"); |
@@ -191,13 +247,16 @@ void __init at91rm9200_ioremap_st(u32 addr) | |||
191 | */ | 247 | */ |
192 | void __init at91rm9200_timer_init(void) | 248 | void __init at91rm9200_timer_init(void) |
193 | { | 249 | { |
250 | /* For device tree enabled device: initialize here */ | ||
251 | of_at91rm9200_st_init(); | ||
252 | |||
194 | /* Disable all timer interrupts, and clear any pending ones */ | 253 | /* Disable all timer interrupts, and clear any pending ones */ |
195 | at91_st_write(AT91_ST_IDR, | 254 | at91_st_write(AT91_ST_IDR, |
196 | AT91_ST_PITS | AT91_ST_WDOVF | AT91_ST_RTTINC | AT91_ST_ALMS); | 255 | AT91_ST_PITS | AT91_ST_WDOVF | AT91_ST_RTTINC | AT91_ST_ALMS); |
197 | at91_st_read(AT91_ST_SR); | 256 | at91_st_read(AT91_ST_SR); |
198 | 257 | ||
199 | /* Make IRQs happen for the system timer */ | 258 | /* Make IRQs happen for the system timer */ |
200 | setup_irq(NR_IRQS_LEGACY + AT91_ID_SYS, &at91rm9200_timer_irq); | 259 | setup_irq(at91rm9200_timer_irq.irq, &at91rm9200_timer_irq); |
201 | 260 | ||
202 | /* The 32KiHz "Slow Clock" (tick every 30517.58 nanoseconds) is used | 261 | /* The 32KiHz "Slow Clock" (tick every 30517.58 nanoseconds) is used |
203 | * directly for the clocksource and all clockevents, after adjusting | 262 | * directly for the clocksource and all clockevents, after adjusting |
diff --git a/arch/arm/mach-at91/board-rm9200-dt.c b/arch/arm/mach-at91/board-rm9200-dt.c new file mode 100644 index 000000000000..5f9ce3da3fde --- /dev/null +++ b/arch/arm/mach-at91/board-rm9200-dt.c | |||
@@ -0,0 +1,57 @@ | |||
1 | /* | ||
2 | * Setup code for AT91RM9200 Evaluation Kits with Device Tree support | ||
3 | * | ||
4 | * Copyright (C) 2011 Atmel, | ||
5 | * 2011 Nicolas Ferre <nicolas.ferre@atmel.com> | ||
6 | * 2012 Joachim Eastwood <manabian@gmail.com> | ||
7 | * | ||
8 | * Licensed under GPLv2 or later. | ||
9 | */ | ||
10 | |||
11 | #include <linux/types.h> | ||
12 | #include <linux/init.h> | ||
13 | #include <linux/module.h> | ||
14 | #include <linux/gpio.h> | ||
15 | #include <linux/of.h> | ||
16 | #include <linux/of_irq.h> | ||
17 | #include <linux/of_platform.h> | ||
18 | |||
19 | #include <asm/setup.h> | ||
20 | #include <asm/irq.h> | ||
21 | #include <asm/mach/arch.h> | ||
22 | #include <asm/mach/map.h> | ||
23 | #include <asm/mach/irq.h> | ||
24 | |||
25 | #include "at91_aic.h" | ||
26 | #include "generic.h" | ||
27 | |||
28 | |||
29 | static const struct of_device_id irq_of_match[] __initconst = { | ||
30 | { .compatible = "atmel,at91rm9200-aic", .data = at91_aic_of_init }, | ||
31 | { /*sentinel*/ } | ||
32 | }; | ||
33 | |||
34 | static void __init at91rm9200_dt_init_irq(void) | ||
35 | { | ||
36 | of_irq_init(irq_of_match); | ||
37 | } | ||
38 | |||
39 | static void __init at91rm9200_dt_device_init(void) | ||
40 | { | ||
41 | of_platform_populate(NULL, of_default_bus_match_table, NULL, NULL); | ||
42 | } | ||
43 | |||
44 | static const char *at91rm9200_dt_board_compat[] __initdata = { | ||
45 | "atmel,at91rm9200", | ||
46 | NULL | ||
47 | }; | ||
48 | |||
49 | DT_MACHINE_START(at91rm9200_dt, "Atmel AT91RM9200 (Device Tree)") | ||
50 | .timer = &at91rm9200_timer, | ||
51 | .map_io = at91_map_io, | ||
52 | .handle_irq = at91_aic_handle_irq, | ||
53 | .init_early = at91rm9200_dt_initialize, | ||
54 | .init_irq = at91rm9200_dt_init_irq, | ||
55 | .init_machine = at91rm9200_dt_device_init, | ||
56 | .dt_compat = at91rm9200_dt_board_compat, | ||
57 | MACHINE_END | ||
diff --git a/arch/arm/mach-at91/generic.h b/arch/arm/mach-at91/generic.h index b62f560e6c75..fc593d615e7d 100644 --- a/arch/arm/mach-at91/generic.h +++ b/arch/arm/mach-at91/generic.h | |||
@@ -20,6 +20,7 @@ extern void __init at91_init_sram(int bank, unsigned long base, | |||
20 | extern void __init at91rm9200_set_type(int type); | 20 | extern void __init at91rm9200_set_type(int type); |
21 | extern void __init at91_initialize(unsigned long main_clock); | 21 | extern void __init at91_initialize(unsigned long main_clock); |
22 | extern void __init at91x40_initialize(unsigned long main_clock); | 22 | extern void __init at91x40_initialize(unsigned long main_clock); |
23 | extern void __init at91rm9200_dt_initialize(void); | ||
23 | extern void __init at91_dt_initialize(void); | 24 | extern void __init at91_dt_initialize(void); |
24 | 25 | ||
25 | /* Interrupts */ | 26 | /* Interrupts */ |
diff --git a/arch/arm/mach-at91/setup.c b/arch/arm/mach-at91/setup.c index 80f4bfd913b3..19cdd0b5b391 100644 --- a/arch/arm/mach-at91/setup.c +++ b/arch/arm/mach-at91/setup.c | |||
@@ -339,6 +339,7 @@ static void at91_dt_rstc(void) | |||
339 | } | 339 | } |
340 | 340 | ||
341 | static struct of_device_id ramc_ids[] = { | 341 | static struct of_device_id ramc_ids[] = { |
342 | { .compatible = "atmel,at91rm9200-sdramc" }, | ||
342 | { .compatible = "atmel,at91sam9260-sdramc" }, | 343 | { .compatible = "atmel,at91sam9260-sdramc" }, |
343 | { .compatible = "atmel,at91sam9g45-ddramc" }, | 344 | { .compatible = "atmel,at91sam9g45-ddramc" }, |
344 | { /*sentinel*/ } | 345 | { /*sentinel*/ } |
@@ -437,6 +438,19 @@ end: | |||
437 | of_node_put(np); | 438 | of_node_put(np); |
438 | } | 439 | } |
439 | 440 | ||
441 | void __init at91rm9200_dt_initialize(void) | ||
442 | { | ||
443 | at91_dt_ramc(); | ||
444 | |||
445 | /* Init clock subsystem */ | ||
446 | at91_dt_clock_init(); | ||
447 | |||
448 | /* Register the processor-specific clocks */ | ||
449 | at91_boot_soc.register_clocks(); | ||
450 | |||
451 | at91_boot_soc.init(); | ||
452 | } | ||
453 | |||
440 | void __init at91_dt_initialize(void) | 454 | void __init at91_dt_initialize(void) |
441 | { | 455 | { |
442 | at91_dt_rstc(); | 456 | at91_dt_rstc(); |
diff --git a/drivers/pinctrl/pinctrl-at91.c b/drivers/pinctrl/pinctrl-at91.c index b9e2cbd2ea7b..0d7e6c3c33a7 100644 --- a/drivers/pinctrl/pinctrl-at91.c +++ b/drivers/pinctrl/pinctrl-at91.c | |||
@@ -59,6 +59,12 @@ static int gpio_banks; | |||
59 | 59 | ||
60 | #define PULL_UP (1 << 0) | 60 | #define PULL_UP (1 << 0) |
61 | #define MULTI_DRIVE (1 << 1) | 61 | #define MULTI_DRIVE (1 << 1) |
62 | #define DEGLITCH (1 << 2) | ||
63 | #define PULL_DOWN (1 << 3) | ||
64 | #define DIS_SCHMIT (1 << 4) | ||
65 | #define DEBOUNCE (1 << 16) | ||
66 | #define DEBOUNCE_VAL_SHIFT 17 | ||
67 | #define DEBOUNCE_VAL (0x3fff << DEBOUNCE_VAL_SHIFT) | ||
62 | 68 | ||
63 | /** | 69 | /** |
64 | * struct at91_pmx_func - describes AT91 pinmux functions | 70 | * struct at91_pmx_func - describes AT91 pinmux functions |
@@ -122,6 +128,14 @@ struct at91_pin_group { | |||
122 | * @mux_B_periph: mux as periph B | 128 | * @mux_B_periph: mux as periph B |
123 | * @mux_C_periph: mux as periph C | 129 | * @mux_C_periph: mux as periph C |
124 | * @mux_D_periph: mux as periph D | 130 | * @mux_D_periph: mux as periph D |
131 | * @get_deglitch: get deglitch status | ||
132 | * @set_deglitch: enable/disable deglitch | ||
133 | * @get_debounce: get debounce status | ||
134 | * @set_debounce: enable/disable debounce | ||
135 | * @get_pulldown: get pulldown status | ||
136 | * @set_pulldown: enable/disable pulldown | ||
137 | * @get_schmitt_trig: get schmitt trigger status | ||
138 | * @disable_schmitt_trig: disable schmitt trigger | ||
125 | * @irq_type: return irq type | 139 | * @irq_type: return irq type |
126 | */ | 140 | */ |
127 | struct at91_pinctrl_mux_ops { | 141 | struct at91_pinctrl_mux_ops { |
@@ -130,6 +144,14 @@ struct at91_pinctrl_mux_ops { | |||
130 | void (*mux_B_periph)(void __iomem *pio, unsigned mask); | 144 | void (*mux_B_periph)(void __iomem *pio, unsigned mask); |
131 | void (*mux_C_periph)(void __iomem *pio, unsigned mask); | 145 | void (*mux_C_periph)(void __iomem *pio, unsigned mask); |
132 | void (*mux_D_periph)(void __iomem *pio, unsigned mask); | 146 | void (*mux_D_periph)(void __iomem *pio, unsigned mask); |
147 | bool (*get_deglitch)(void __iomem *pio, unsigned pin); | ||
148 | void (*set_deglitch)(void __iomem *pio, unsigned mask, bool in_on); | ||
149 | bool (*get_debounce)(void __iomem *pio, unsigned pin, u32 *div); | ||
150 | void (*set_debounce)(void __iomem *pio, unsigned mask, bool in_on, u32 div); | ||
151 | bool (*get_pulldown)(void __iomem *pio, unsigned pin); | ||
152 | void (*set_pulldown)(void __iomem *pio, unsigned mask, bool in_on); | ||
153 | bool (*get_schmitt_trig)(void __iomem *pio, unsigned pin); | ||
154 | void (*disable_schmitt_trig)(void __iomem *pio, unsigned mask); | ||
133 | /* irq */ | 155 | /* irq */ |
134 | int (*irq_type)(struct irq_data *d, unsigned type); | 156 | int (*irq_type)(struct irq_data *d, unsigned type); |
135 | }; | 157 | }; |
@@ -386,10 +408,68 @@ static enum at91_mux at91_mux_get_periph(void __iomem *pio, unsigned mask) | |||
386 | return select + 1; | 408 | return select + 1; |
387 | } | 409 | } |
388 | 410 | ||
411 | static bool at91_mux_get_deglitch(void __iomem *pio, unsigned pin) | ||
412 | { | ||
413 | return (__raw_readl(pio + PIO_IFSR) >> pin) & 0x1; | ||
414 | } | ||
415 | |||
416 | static void at91_mux_set_deglitch(void __iomem *pio, unsigned mask, bool is_on) | ||
417 | { | ||
418 | __raw_writel(mask, pio + (is_on ? PIO_IFER : PIO_IFDR)); | ||
419 | } | ||
420 | |||
421 | static void at91_mux_pio3_set_deglitch(void __iomem *pio, unsigned mask, bool is_on) | ||
422 | { | ||
423 | if (is_on) | ||
424 | __raw_writel(mask, pio + PIO_IFSCDR); | ||
425 | at91_mux_set_deglitch(pio, mask, is_on); | ||
426 | } | ||
427 | |||
428 | static bool at91_mux_pio3_get_debounce(void __iomem *pio, unsigned pin, u32 *div) | ||
429 | { | ||
430 | *div = __raw_readl(pio + PIO_SCDR); | ||
431 | |||
432 | return (__raw_readl(pio + PIO_IFSCSR) >> pin) & 0x1; | ||
433 | } | ||
434 | |||
435 | static void at91_mux_pio3_set_debounce(void __iomem *pio, unsigned mask, | ||
436 | bool is_on, u32 div) | ||
437 | { | ||
438 | if (is_on) { | ||
439 | __raw_writel(mask, pio + PIO_IFSCER); | ||
440 | __raw_writel(div & PIO_SCDR_DIV, pio + PIO_SCDR); | ||
441 | __raw_writel(mask, pio + PIO_IFER); | ||
442 | } else { | ||
443 | __raw_writel(mask, pio + PIO_IFDR); | ||
444 | } | ||
445 | } | ||
446 | |||
447 | static bool at91_mux_pio3_get_pulldown(void __iomem *pio, unsigned pin) | ||
448 | { | ||
449 | return (__raw_readl(pio + PIO_PPDSR) >> pin) & 0x1; | ||
450 | } | ||
451 | |||
452 | static void at91_mux_pio3_set_pulldown(void __iomem *pio, unsigned mask, bool is_on) | ||
453 | { | ||
454 | __raw_writel(mask, pio + (is_on ? PIO_PPDER : PIO_PPDDR)); | ||
455 | } | ||
456 | |||
457 | static void at91_mux_pio3_disable_schmitt_trig(void __iomem *pio, unsigned mask) | ||
458 | { | ||
459 | __raw_writel(__raw_readl(pio + PIO_SCHMITT) | mask, pio + PIO_SCHMITT); | ||
460 | } | ||
461 | |||
462 | static bool at91_mux_pio3_get_schmitt_trig(void __iomem *pio, unsigned pin) | ||
463 | { | ||
464 | return (__raw_readl(pio + PIO_SCHMITT) >> pin) & 0x1; | ||
465 | } | ||
466 | |||
389 | static struct at91_pinctrl_mux_ops at91rm9200_ops = { | 467 | static struct at91_pinctrl_mux_ops at91rm9200_ops = { |
390 | .get_periph = at91_mux_get_periph, | 468 | .get_periph = at91_mux_get_periph, |
391 | .mux_A_periph = at91_mux_set_A_periph, | 469 | .mux_A_periph = at91_mux_set_A_periph, |
392 | .mux_B_periph = at91_mux_set_B_periph, | 470 | .mux_B_periph = at91_mux_set_B_periph, |
471 | .get_deglitch = at91_mux_get_deglitch, | ||
472 | .set_deglitch = at91_mux_set_deglitch, | ||
393 | .irq_type = gpio_irq_type, | 473 | .irq_type = gpio_irq_type, |
394 | }; | 474 | }; |
395 | 475 | ||
@@ -399,6 +479,14 @@ static struct at91_pinctrl_mux_ops at91sam9x5_ops = { | |||
399 | .mux_B_periph = at91_mux_pio3_set_B_periph, | 479 | .mux_B_periph = at91_mux_pio3_set_B_periph, |
400 | .mux_C_periph = at91_mux_pio3_set_C_periph, | 480 | .mux_C_periph = at91_mux_pio3_set_C_periph, |
401 | .mux_D_periph = at91_mux_pio3_set_D_periph, | 481 | .mux_D_periph = at91_mux_pio3_set_D_periph, |
482 | .get_deglitch = at91_mux_get_deglitch, | ||
483 | .set_deglitch = at91_mux_pio3_set_deglitch, | ||
484 | .get_debounce = at91_mux_pio3_get_debounce, | ||
485 | .set_debounce = at91_mux_pio3_set_debounce, | ||
486 | .get_pulldown = at91_mux_pio3_get_pulldown, | ||
487 | .set_pulldown = at91_mux_pio3_set_pulldown, | ||
488 | .get_schmitt_trig = at91_mux_pio3_get_schmitt_trig, | ||
489 | .disable_schmitt_trig = at91_mux_pio3_disable_schmitt_trig, | ||
402 | .irq_type = alt_gpio_irq_type, | 490 | .irq_type = alt_gpio_irq_type, |
403 | }; | 491 | }; |
404 | 492 | ||
@@ -624,6 +712,7 @@ static int at91_pinconf_get(struct pinctrl_dev *pctldev, | |||
624 | struct at91_pinctrl *info = pinctrl_dev_get_drvdata(pctldev); | 712 | struct at91_pinctrl *info = pinctrl_dev_get_drvdata(pctldev); |
625 | void __iomem *pio; | 713 | void __iomem *pio; |
626 | unsigned pin; | 714 | unsigned pin; |
715 | int div; | ||
627 | 716 | ||
628 | dev_dbg(info->dev, "%s:%d, pin_id=%d, config=0x%lx", __func__, __LINE__, pin_id, *config); | 717 | dev_dbg(info->dev, "%s:%d, pin_id=%d, config=0x%lx", __func__, __LINE__, pin_id, *config); |
629 | pio = pin_to_controller(info, pin_to_bank(pin_id)); | 718 | pio = pin_to_controller(info, pin_to_bank(pin_id)); |
@@ -635,6 +724,15 @@ static int at91_pinconf_get(struct pinctrl_dev *pctldev, | |||
635 | if (at91_mux_get_pullup(pio, pin)) | 724 | if (at91_mux_get_pullup(pio, pin)) |
636 | *config |= PULL_UP; | 725 | *config |= PULL_UP; |
637 | 726 | ||
727 | if (info->ops->get_deglitch && info->ops->get_deglitch(pio, pin)) | ||
728 | *config |= DEGLITCH; | ||
729 | if (info->ops->get_debounce && info->ops->get_debounce(pio, pin, &div)) | ||
730 | *config |= DEBOUNCE | (div << DEBOUNCE_VAL_SHIFT); | ||
731 | if (info->ops->get_pulldown && info->ops->get_pulldown(pio, pin)) | ||
732 | *config |= PULL_DOWN; | ||
733 | if (info->ops->get_schmitt_trig && info->ops->get_schmitt_trig(pio, pin)) | ||
734 | *config |= DIS_SCHMIT; | ||
735 | |||
638 | return 0; | 736 | return 0; |
639 | } | 737 | } |
640 | 738 | ||
@@ -649,8 +747,21 @@ static int at91_pinconf_set(struct pinctrl_dev *pctldev, | |||
649 | pio = pin_to_controller(info, pin_to_bank(pin_id)); | 747 | pio = pin_to_controller(info, pin_to_bank(pin_id)); |
650 | mask = pin_to_mask(pin_id % MAX_NB_GPIO_PER_BANK); | 748 | mask = pin_to_mask(pin_id % MAX_NB_GPIO_PER_BANK); |
651 | 749 | ||
750 | if (config & PULL_UP && config & PULL_DOWN) | ||
751 | return -EINVAL; | ||
752 | |||
652 | at91_mux_set_pullup(pio, mask, config & PULL_UP); | 753 | at91_mux_set_pullup(pio, mask, config & PULL_UP); |
653 | at91_mux_set_multidrive(pio, mask, config & MULTI_DRIVE); | 754 | at91_mux_set_multidrive(pio, mask, config & MULTI_DRIVE); |
755 | if (info->ops->set_deglitch) | ||
756 | info->ops->set_deglitch(pio, mask, config & DEGLITCH); | ||
757 | if (info->ops->set_debounce) | ||
758 | info->ops->set_debounce(pio, mask, config & DEBOUNCE, | ||
759 | (config & DEBOUNCE_VAL) >> DEBOUNCE_VAL_SHIFT); | ||
760 | if (info->ops->set_pulldown) | ||
761 | info->ops->set_pulldown(pio, mask, config & PULL_DOWN); | ||
762 | if (info->ops->disable_schmitt_trig && config & DIS_SCHMIT) | ||
763 | info->ops->disable_schmitt_trig(pio, mask); | ||
764 | |||
654 | return 0; | 765 | return 0; |
655 | } | 766 | } |
656 | 767 | ||
@@ -1364,9 +1475,10 @@ static int __devinit at91_gpio_probe(struct platform_device *pdev) | |||
1364 | struct gpio_chip *chip; | 1475 | struct gpio_chip *chip; |
1365 | struct pinctrl_gpio_range *range; | 1476 | struct pinctrl_gpio_range *range; |
1366 | int ret = 0; | 1477 | int ret = 0; |
1367 | int irq; | 1478 | int irq, i; |
1368 | int alias_idx = of_alias_get_id(np, "gpio"); | 1479 | int alias_idx = of_alias_get_id(np, "gpio"); |
1369 | uint32_t ngpio; | 1480 | uint32_t ngpio; |
1481 | char **names; | ||
1370 | 1482 | ||
1371 | BUG_ON(alias_idx >= ARRAY_SIZE(gpio_chips)); | 1483 | BUG_ON(alias_idx >= ARRAY_SIZE(gpio_chips)); |
1372 | if (gpio_chips[alias_idx]) { | 1484 | if (gpio_chips[alias_idx]) { |
@@ -1436,6 +1548,18 @@ static int __devinit at91_gpio_probe(struct platform_device *pdev) | |||
1436 | chip->ngpio = ngpio; | 1548 | chip->ngpio = ngpio; |
1437 | } | 1549 | } |
1438 | 1550 | ||
1551 | names = devm_kzalloc(&pdev->dev, sizeof(char*) * chip->ngpio, GFP_KERNEL); | ||
1552 | |||
1553 | if (!names) { | ||
1554 | ret = -ENOMEM; | ||
1555 | goto clk_err; | ||
1556 | } | ||
1557 | |||
1558 | for (i = 0; i < chip->ngpio; i++) | ||
1559 | names[i] = kasprintf(GFP_KERNEL, "pio%c%d", alias_idx + 'A', i); | ||
1560 | |||
1561 | chip->names = (const char*const*)names; | ||
1562 | |||
1439 | range = &at91_chip->range; | 1563 | range = &at91_chip->range; |
1440 | range->name = chip->label; | 1564 | range->name = chip->label; |
1441 | range->id = alias_idx; | 1565 | range->id = alias_idx; |