blob: 051fc16f37063fe18a5957943f0e97b9e830336a [file] [log] [blame]
Srinivas Kandagatla15969b42013-06-25 12:15:23 +01001
2/*
3 * Copyright (C) 2013 STMicroelectronics Limited.
4 * Author: Srinivas Kandagatla <srinivas.kandagatla@st.com>
5 *
6 * This program is free software; you can redistribute it and/or modify
7 * it under the terms of the GNU General Public License version 2 as
8 * publishhed by the Free Software Foundation.
9 */
10#include "st-pincfg.h"
Srinivas Kandagatlabdda8b02014-01-08 12:47:52 +000011#include <dt-bindings/interrupt-controller/arm-gic.h>
Srinivas Kandagatla15969b42013-06-25 12:15:23 +010012/ {
13
14 aliases {
Lee Jonesdc62bfd2014-05-27 14:53:00 +020015 gpio0 = &pio0;
16 gpio1 = &pio1;
17 gpio2 = &pio2;
18 gpio3 = &pio3;
19 gpio4 = &pio4;
20 gpio5 = &pio40;
21 gpio6 = &pio5;
22 gpio7 = &pio6;
23 gpio8 = &pio7;
24 gpio9 = &pio8;
25 gpio10 = &pio9;
26 gpio11 = &pio10;
27 gpio12 = &pio11;
28 gpio13 = &pio12;
29 gpio14 = &pio30;
30 gpio15 = &pio31;
31 gpio16 = &pio13;
32 gpio17 = &pio14;
33 gpio18 = &pio15;
34 gpio19 = &pio16;
35 gpio20 = &pio17;
36 gpio21 = &pio18;
37 gpio22 = &pio100;
38 gpio23 = &pio101;
39 gpio24 = &pio102;
40 gpio25 = &pio103;
41 gpio26 = &pio104;
42 gpio27 = &pio105;
43 gpio28 = &pio106;
44 gpio29 = &pio107;
Srinivas Kandagatla15969b42013-06-25 12:15:23 +010045 };
46
47 soc {
48 pin-controller-sbc {
49 #address-cells = <1>;
50 #size-cells = <1>;
51 compatible = "st,stih416-sbc-pinctrl";
52 st,syscfg = <&syscfg_sbc>;
Srinivas Kandagatlabdda8b02014-01-08 12:47:52 +000053 reg = <0xfe61f080 0x4>;
54 reg-names = "irqmux";
55 interrupts = <GIC_SPI 182 IRQ_TYPE_LEVEL_HIGH>;
Geert Uytterhoevenae107d02014-04-22 20:40:25 +020056 interrupt-names = "irqmux";
Srinivas Kandagatla15969b42013-06-25 12:15:23 +010057 ranges = <0 0xfe610000 0x6000>;
58
Lee Jonesdc62bfd2014-05-27 14:53:00 +020059 pio0: gpio@fe610000 {
Srinivas Kandagatla15969b42013-06-25 12:15:23 +010060 gpio-controller;
61 #gpio-cells = <1>;
Srinivas Kandagatlabdda8b02014-01-08 12:47:52 +000062 interrupt-controller;
63 #interrupt-cells = <2>;
Srinivas Kandagatla15969b42013-06-25 12:15:23 +010064 reg = <0 0x100>;
65 st,bank-name = "PIO0";
66 };
Lee Jonesdc62bfd2014-05-27 14:53:00 +020067 pio1: gpio@fe611000 {
Srinivas Kandagatla15969b42013-06-25 12:15:23 +010068 gpio-controller;
69 #gpio-cells = <1>;
Srinivas Kandagatlabdda8b02014-01-08 12:47:52 +000070 interrupt-controller;
71 #interrupt-cells = <2>;
Srinivas Kandagatla15969b42013-06-25 12:15:23 +010072 reg = <0x1000 0x100>;
73 st,bank-name = "PIO1";
74 };
Lee Jonesdc62bfd2014-05-27 14:53:00 +020075 pio2: gpio@fe612000 {
Srinivas Kandagatla15969b42013-06-25 12:15:23 +010076 gpio-controller;
77 #gpio-cells = <1>;
Srinivas Kandagatlabdda8b02014-01-08 12:47:52 +000078 interrupt-controller;
79 #interrupt-cells = <2>;
Srinivas Kandagatla15969b42013-06-25 12:15:23 +010080 reg = <0x2000 0x100>;
81 st,bank-name = "PIO2";
82 };
Lee Jonesdc62bfd2014-05-27 14:53:00 +020083 pio3: gpio@fe613000 {
Srinivas Kandagatla15969b42013-06-25 12:15:23 +010084 gpio-controller;
85 #gpio-cells = <1>;
Srinivas Kandagatlabdda8b02014-01-08 12:47:52 +000086 interrupt-controller;
87 #interrupt-cells = <2>;
Srinivas Kandagatla15969b42013-06-25 12:15:23 +010088 reg = <0x3000 0x100>;
89 st,bank-name = "PIO3";
90 };
Lee Jonesdc62bfd2014-05-27 14:53:00 +020091 pio4: gpio@fe614000 {
Srinivas Kandagatla15969b42013-06-25 12:15:23 +010092 gpio-controller;
93 #gpio-cells = <1>;
Srinivas Kandagatlabdda8b02014-01-08 12:47:52 +000094 interrupt-controller;
95 #interrupt-cells = <2>;
Srinivas Kandagatla15969b42013-06-25 12:15:23 +010096 reg = <0x4000 0x100>;
97 st,bank-name = "PIO4";
98 };
Lee Jonesdc62bfd2014-05-27 14:53:00 +020099 pio40: gpio@fe615000 {
Srinivas Kandagatla15969b42013-06-25 12:15:23 +0100100 gpio-controller;
101 #gpio-cells = <1>;
Srinivas Kandagatlabdda8b02014-01-08 12:47:52 +0000102 interrupt-controller;
103 #interrupt-cells = <2>;
Srinivas Kandagatla15969b42013-06-25 12:15:23 +0100104 reg = <0x5000 0x100>;
105 st,bank-name = "PIO40";
106 st,retime-pin-mask = <0x7f>;
107 };
108
Srinivas Kandagatlae0637352013-11-11 13:20:44 +0000109 rc{
110 pinctrl_ir: ir0 {
111 st,pins {
Lee Jonesdc62bfd2014-05-27 14:53:00 +0200112 ir = <&pio4 0 ALT2 IN>;
Srinivas Kandagatlae0637352013-11-11 13:20:44 +0000113 };
114 };
115 };
Srinivas Kandagatla15969b42013-06-25 12:15:23 +0100116 sbc_serial1 {
117 pinctrl_sbc_serial1: sbc_serial1 {
118 st,pins {
Lee Jonesdc62bfd2014-05-27 14:53:00 +0200119 tx = <&pio2 6 ALT3 OUT>;
120 rx = <&pio2 7 ALT3 IN>;
Srinivas Kandagatla15969b42013-06-25 12:15:23 +0100121 };
122 };
123 };
Maxime COQUELINf53e99a2013-11-06 09:25:13 +0100124
Gabriel FERNANDEZ948d8ff2014-04-11 17:07:00 +0200125 keyscan {
126 pinctrl_keyscan: keyscan {
127 st,pins {
Lee Jonesdc62bfd2014-05-27 14:53:00 +0200128 keyin0 = <&pio0 2 ALT2 IN>;
129 keyin1 = <&pio0 3 ALT2 IN>;
130 keyin2 = <&pio0 4 ALT2 IN>;
131 keyin3 = <&pio2 6 ALT2 IN>;
Gabriel FERNANDEZ948d8ff2014-04-11 17:07:00 +0200132
Lee Jonesdc62bfd2014-05-27 14:53:00 +0200133 keyout0 = <&pio1 6 ALT2 OUT>;
134 keyout1 = <&pio1 7 ALT2 OUT>;
135 keyout2 = <&pio0 6 ALT2 OUT>;
136 keyout3 = <&pio2 7 ALT2 OUT>;
Gabriel FERNANDEZ948d8ff2014-04-11 17:07:00 +0200137 };
138 };
139 };
140
Maxime COQUELINf53e99a2013-11-06 09:25:13 +0100141 sbc_i2c0 {
142 pinctrl_sbc_i2c0_default: sbc_i2c0-default {
143 st,pins {
Lee Jonesdc62bfd2014-05-27 14:53:00 +0200144 sda = <&pio4 6 ALT1 BIDIR>;
145 scl = <&pio4 5 ALT1 BIDIR>;
Maxime COQUELINf53e99a2013-11-06 09:25:13 +0100146 };
147 };
148 };
149
Peter Griffin401a5262014-11-17 17:47:00 +0100150 usb {
151 pinctrl_usb3: usb3 {
152 st,pins {
153 oc-detect = <&pio40 0 ALT1 IN>;
154 pwr-enable = <&pio40 1 ALT1 OUT>;
155 };
156 };
157 };
158
Maxime COQUELINf53e99a2013-11-06 09:25:13 +0100159 sbc_i2c1 {
160 pinctrl_sbc_i2c1_default: sbc_i2c1-default {
161 st,pins {
Lee Jonesdc62bfd2014-05-27 14:53:00 +0200162 sda = <&pio3 2 ALT2 BIDIR>;
163 scl = <&pio3 1 ALT2 BIDIR>;
Maxime COQUELINf53e99a2013-11-06 09:25:13 +0100164 };
165 };
166 };
Srinivas Kandagatlad25ea582014-01-29 16:20:12 +0000167
168 gmac1 {
169 pinctrl_mii1: mii1 {
170 st,pins {
Lee Jonesdc62bfd2014-05-27 14:53:00 +0200171 txd0 = <&pio0 0 ALT1 OUT SE_NICLK_IO 0 CLK_A>;
172 txd1 = <&pio0 1 ALT1 OUT SE_NICLK_IO 0 CLK_A>;
173 txd2 = <&pio0 2 ALT1 OUT SE_NICLK_IO 0 CLK_A>;
174 txd3 = <&pio0 3 ALT1 OUT SE_NICLK_IO 0 CLK_A>;
175 txer = <&pio0 4 ALT1 OUT SE_NICLK_IO 0 CLK_A>;
176 txen = <&pio0 5 ALT1 OUT SE_NICLK_IO 0 CLK_A>;
177 txclk = <&pio0 6 ALT1 IN NICLK 0 CLK_A>;
178 col = <&pio0 7 ALT1 IN BYPASS 1000>;
Srinivas Kandagatlad25ea582014-01-29 16:20:12 +0000179
Lee Jonesdc62bfd2014-05-27 14:53:00 +0200180 mdio = <&pio1 0 ALT1 OUT BYPASS 1500>;
181 mdc = <&pio1 1 ALT1 OUT NICLK 0 CLK_A>;
182 crs = <&pio1 2 ALT1 IN BYPASS 1000>;
183 mdint = <&pio1 3 ALT1 IN BYPASS 0>;
184 rxd0 = <&pio1 4 ALT1 IN SE_NICLK_IO 0 CLK_A>;
185 rxd1 = <&pio1 5 ALT1 IN SE_NICLK_IO 0 CLK_A>;
186 rxd2 = <&pio1 6 ALT1 IN SE_NICLK_IO 0 CLK_A>;
187 rxd3 = <&pio1 7 ALT1 IN SE_NICLK_IO 0 CLK_A>;
Srinivas Kandagatlad25ea582014-01-29 16:20:12 +0000188
Lee Jonesdc62bfd2014-05-27 14:53:00 +0200189 rxdv = <&pio2 0 ALT1 IN SE_NICLK_IO 0 CLK_A>;
190 rx_er = <&pio2 1 ALT1 IN SE_NICLK_IO 0 CLK_A>;
191 rxclk = <&pio2 2 ALT1 IN NICLK 0 CLK_A>;
192 phyclk = <&pio2 3 ALT1 OUT NICLK 0 CLK_A>;
Srinivas Kandagatlad25ea582014-01-29 16:20:12 +0000193 };
194 };
195 pinctrl_rgmii1: rgmii1-0 {
196 st,pins {
Lee Jonesdc62bfd2014-05-27 14:53:00 +0200197 txd0 = <&pio0 0 ALT1 OUT DE_IO 500 CLK_A>;
198 txd1 = <&pio0 1 ALT1 OUT DE_IO 500 CLK_A>;
199 txd2 = <&pio0 2 ALT1 OUT DE_IO 500 CLK_A>;
200 txd3 = <&pio0 3 ALT1 OUT DE_IO 500 CLK_A>;
201 txen = <&pio0 5 ALT1 OUT DE_IO 0 CLK_A>;
202 txclk = <&pio0 6 ALT1 IN NICLK 0 CLK_A>;
Srinivas Kandagatlad25ea582014-01-29 16:20:12 +0000203
Lee Jonesdc62bfd2014-05-27 14:53:00 +0200204 mdio = <&pio1 0 ALT1 OUT BYPASS 0>;
205 mdc = <&pio1 1 ALT1 OUT NICLK 0 CLK_A>;
206 rxd0 = <&pio1 4 ALT1 IN DE_IO 500 CLK_A>;
207 rxd1 = <&pio1 5 ALT1 IN DE_IO 500 CLK_A>;
208 rxd2 = <&pio1 6 ALT1 IN DE_IO 500 CLK_A>;
209 rxd3 = <&pio1 7 ALT1 IN DE_IO 500 CLK_A>;
Srinivas Kandagatlad25ea582014-01-29 16:20:12 +0000210
Lee Jonesdc62bfd2014-05-27 14:53:00 +0200211 rxdv = <&pio2 0 ALT1 IN DE_IO 500 CLK_A>;
212 rxclk = <&pio2 2 ALT1 IN NICLK 0 CLK_A>;
213 phyclk = <&pio2 3 ALT4 OUT NICLK 0 CLK_B>;
Srinivas Kandagatlad25ea582014-01-29 16:20:12 +0000214
Lee Jonesdc62bfd2014-05-27 14:53:00 +0200215 clk125= <&pio3 7 ALT4 IN NICLK 0 CLK_A>;
Srinivas Kandagatlad25ea582014-01-29 16:20:12 +0000216 };
217 };
218 };
Lee Jones9723bac2015-05-12 14:51:00 +0200219
220 pwm1 {
221 pinctrl_pwm1_chan0_default: pwm1-0-default {
222 st,pins {
223 pwm-out = <&pio3 0 ALT1 OUT>;
224 };
225 };
226 pinctrl_pwm1_chan1_default: pwm1-1-default {
227 st,pins {
228 pwm-out = <&pio4 4 ALT1 OUT>;
229 };
230 };
231 pinctrl_pwm1_chan2_default: pwm1-2-default {
232 st,pins {
233 pwm-out = <&pio4 6 ALT3 OUT>;
234 };
235 };
236 pinctrl_pwm1_chan3_default: pwm1-3-default {
237 st,pins {
238 pwm-out = <&pio4 7 ALT3 OUT>;
239 };
240 };
241 };
Srinivas Kandagatla15969b42013-06-25 12:15:23 +0100242 };
243
244 pin-controller-front {
245 #address-cells = <1>;
246 #size-cells = <1>;
247 compatible = "st,stih416-front-pinctrl";
248 st,syscfg = <&syscfg_front>;
Srinivas Kandagatlabdda8b02014-01-08 12:47:52 +0000249 reg = <0xfee0f080 0x4>;
250 reg-names = "irqmux";
251 interrupts = <GIC_SPI 183 IRQ_TYPE_LEVEL_HIGH>;
Geert Uytterhoevenae107d02014-04-22 20:40:25 +0200252 interrupt-names = "irqmux";
Srinivas Kandagatla15969b42013-06-25 12:15:23 +0100253 ranges = <0 0xfee00000 0x10000>;
254
Lee Jonesdc62bfd2014-05-27 14:53:00 +0200255 pio5: gpio@fee00000 {
Srinivas Kandagatla15969b42013-06-25 12:15:23 +0100256 gpio-controller;
257 #gpio-cells = <1>;
Srinivas Kandagatlabdda8b02014-01-08 12:47:52 +0000258 interrupt-controller;
259 #interrupt-cells = <2>;
Srinivas Kandagatla15969b42013-06-25 12:15:23 +0100260 reg = <0 0x100>;
261 st,bank-name = "PIO5";
262 };
Lee Jonesdc62bfd2014-05-27 14:53:00 +0200263 pio6: gpio@fee01000 {
Srinivas Kandagatla15969b42013-06-25 12:15:23 +0100264 gpio-controller;
265 #gpio-cells = <1>;
Srinivas Kandagatlabdda8b02014-01-08 12:47:52 +0000266 interrupt-controller;
267 #interrupt-cells = <2>;
Srinivas Kandagatla15969b42013-06-25 12:15:23 +0100268 reg = <0x1000 0x100>;
269 st,bank-name = "PIO6";
270 };
Lee Jonesdc62bfd2014-05-27 14:53:00 +0200271 pio7: gpio@fee02000 {
Srinivas Kandagatla15969b42013-06-25 12:15:23 +0100272 gpio-controller;
273 #gpio-cells = <1>;
Srinivas Kandagatlabdda8b02014-01-08 12:47:52 +0000274 interrupt-controller;
275 #interrupt-cells = <2>;
Srinivas Kandagatla15969b42013-06-25 12:15:23 +0100276 reg = <0x2000 0x100>;
277 st,bank-name = "PIO7";
278 };
Lee Jonesdc62bfd2014-05-27 14:53:00 +0200279 pio8: gpio@fee03000 {
Srinivas Kandagatla15969b42013-06-25 12:15:23 +0100280 gpio-controller;
281 #gpio-cells = <1>;
Srinivas Kandagatlabdda8b02014-01-08 12:47:52 +0000282 interrupt-controller;
283 #interrupt-cells = <2>;
Srinivas Kandagatla15969b42013-06-25 12:15:23 +0100284 reg = <0x3000 0x100>;
285 st,bank-name = "PIO8";
286 };
Lee Jonesdc62bfd2014-05-27 14:53:00 +0200287 pio9: gpio@fee04000 {
Srinivas Kandagatla15969b42013-06-25 12:15:23 +0100288 gpio-controller;
289 #gpio-cells = <1>;
Srinivas Kandagatlabdda8b02014-01-08 12:47:52 +0000290 interrupt-controller;
291 #interrupt-cells = <2>;
Srinivas Kandagatla15969b42013-06-25 12:15:23 +0100292 reg = <0x4000 0x100>;
293 st,bank-name = "PIO9";
294 };
Lee Jonesdc62bfd2014-05-27 14:53:00 +0200295 pio10: gpio@fee05000 {
Srinivas Kandagatla15969b42013-06-25 12:15:23 +0100296 gpio-controller;
297 #gpio-cells = <1>;
Srinivas Kandagatlabdda8b02014-01-08 12:47:52 +0000298 interrupt-controller;
299 #interrupt-cells = <2>;
Srinivas Kandagatla15969b42013-06-25 12:15:23 +0100300 reg = <0x5000 0x100>;
301 st,bank-name = "PIO10";
302 };
Lee Jonesdc62bfd2014-05-27 14:53:00 +0200303 pio11: gpio@fee06000 {
Srinivas Kandagatla15969b42013-06-25 12:15:23 +0100304 gpio-controller;
305 #gpio-cells = <1>;
Srinivas Kandagatlabdda8b02014-01-08 12:47:52 +0000306 interrupt-controller;
307 #interrupt-cells = <2>;
Srinivas Kandagatla15969b42013-06-25 12:15:23 +0100308 reg = <0x6000 0x100>;
309 st,bank-name = "PIO11";
310 };
Lee Jonesdc62bfd2014-05-27 14:53:00 +0200311 pio12: gpio@fee07000 {
Srinivas Kandagatla15969b42013-06-25 12:15:23 +0100312 gpio-controller;
313 #gpio-cells = <1>;
Srinivas Kandagatlabdda8b02014-01-08 12:47:52 +0000314 interrupt-controller;
315 #interrupt-cells = <2>;
Srinivas Kandagatla15969b42013-06-25 12:15:23 +0100316 reg = <0x7000 0x100>;
317 st,bank-name = "PIO12";
318 };
Lee Jonesdc62bfd2014-05-27 14:53:00 +0200319 pio30: gpio@fee08000 {
Srinivas Kandagatla15969b42013-06-25 12:15:23 +0100320 gpio-controller;
321 #gpio-cells = <1>;
Srinivas Kandagatlabdda8b02014-01-08 12:47:52 +0000322 interrupt-controller;
323 #interrupt-cells = <2>;
Srinivas Kandagatla15969b42013-06-25 12:15:23 +0100324 reg = <0x8000 0x100>;
325 st,bank-name = "PIO30";
326 };
Lee Jonesdc62bfd2014-05-27 14:53:00 +0200327 pio31: gpio@fee09000 {
Srinivas Kandagatla15969b42013-06-25 12:15:23 +0100328 gpio-controller;
329 #gpio-cells = <1>;
Srinivas Kandagatlabdda8b02014-01-08 12:47:52 +0000330 interrupt-controller;
331 #interrupt-cells = <2>;
Srinivas Kandagatla15969b42013-06-25 12:15:23 +0100332 reg = <0x9000 0x100>;
333 st,bank-name = "PIO31";
334 };
Srinivas Kandagatla334ab912013-07-09 08:26:24 +0100335
Lee Jones9723bac2015-05-12 14:51:00 +0200336 pwm0 {
337 pinctrl_pwm0_chan0_default: pwm0-0-default {
338 st,pins {
339 pwm-out = <&pio9 7 ALT2 OUT>;
340 };
341 };
342 };
343
Srinivas Kandagatla334ab912013-07-09 08:26:24 +0100344 serial2-oe {
345 pinctrl_serial2_oe: serial2-1 {
346 st,pins {
Lee Jonesdc62bfd2014-05-27 14:53:00 +0200347 output-enable = <&pio11 3 ALT2 OUT>;
Srinivas Kandagatla334ab912013-07-09 08:26:24 +0100348 };
349 };
350 };
351
Maxime COQUELINf53e99a2013-11-06 09:25:13 +0100352 i2c0 {
353 pinctrl_i2c0_default: i2c0-default {
354 st,pins {
Lee Jonesdc62bfd2014-05-27 14:53:00 +0200355 sda = <&pio9 3 ALT1 BIDIR>;
356 scl = <&pio9 2 ALT1 BIDIR>;
Maxime COQUELINf53e99a2013-11-06 09:25:13 +0100357 };
358 };
359 };
360
Peter Griffin401a5262014-11-17 17:47:00 +0100361 usb {
362 pinctrl_usb0: usb0 {
363 st,pins {
364 oc-detect = <&pio9 4 ALT1 IN>;
365 pwr-enable = <&pio9 5 ALT1 OUT>;
366 };
367 };
368 };
369
370
Maxime COQUELINf53e99a2013-11-06 09:25:13 +0100371 i2c1 {
372 pinctrl_i2c1_default: i2c1-default {
373 st,pins {
Lee Jonesdc62bfd2014-05-27 14:53:00 +0200374 sda = <&pio12 1 ALT1 BIDIR>;
375 scl = <&pio12 0 ALT1 BIDIR>;
Maxime COQUELINf53e99a2013-11-06 09:25:13 +0100376 };
377 };
378 };
Lee Jones77f8d9b2014-03-21 11:33:07 +0000379
380 fsm {
381 pinctrl_fsm: fsm {
382 st,pins {
Lee Jonesdc62bfd2014-05-27 14:53:00 +0200383 spi-fsm-clk = <&pio12 2 ALT1 OUT>;
384 spi-fsm-cs = <&pio12 3 ALT1 OUT>;
385 spi-fsm-mosi = <&pio12 4 ALT1 OUT>;
386 spi-fsm-miso = <&pio12 5 ALT1 IN>;
387 spi-fsm-hol = <&pio12 6 ALT1 OUT>;
388 spi-fsm-wp = <&pio12 7 ALT1 OUT>;
Lee Jones77f8d9b2014-03-21 11:33:07 +0000389 };
390 };
391 };
Srinivas Kandagatla15969b42013-06-25 12:15:23 +0100392 };
393
394 pin-controller-rear {
395 #address-cells = <1>;
396 #size-cells = <1>;
397 compatible = "st,stih416-rear-pinctrl";
398 st,syscfg = <&syscfg_rear>;
Srinivas Kandagatlabdda8b02014-01-08 12:47:52 +0000399 reg = <0xfe82f080 0x4>;
400 reg-names = "irqmux";
401 interrupts = <GIC_SPI 184 IRQ_TYPE_LEVEL_HIGH>;
Geert Uytterhoevenae107d02014-04-22 20:40:25 +0200402 interrupt-names = "irqmux";
Srinivas Kandagatla15969b42013-06-25 12:15:23 +0100403 ranges = <0 0xfe820000 0x6000>;
404
Lee Jonesdc62bfd2014-05-27 14:53:00 +0200405 pio13: gpio@fe820000 {
Srinivas Kandagatla15969b42013-06-25 12:15:23 +0100406 gpio-controller;
407 #gpio-cells = <1>;
Srinivas Kandagatlabdda8b02014-01-08 12:47:52 +0000408 interrupt-controller;
409 #interrupt-cells = <2>;
Srinivas Kandagatla15969b42013-06-25 12:15:23 +0100410 reg = <0 0x100>;
411 st,bank-name = "PIO13";
412 };
Lee Jonesdc62bfd2014-05-27 14:53:00 +0200413 pio14: gpio@fe821000 {
Srinivas Kandagatla15969b42013-06-25 12:15:23 +0100414 gpio-controller;
415 #gpio-cells = <1>;
Srinivas Kandagatlabdda8b02014-01-08 12:47:52 +0000416 interrupt-controller;
417 #interrupt-cells = <2>;
Srinivas Kandagatla15969b42013-06-25 12:15:23 +0100418 reg = <0x1000 0x100>;
419 st,bank-name = "PIO14";
420 };
Lee Jonesdc62bfd2014-05-27 14:53:00 +0200421 pio15: gpio@fe822000 {
Srinivas Kandagatla15969b42013-06-25 12:15:23 +0100422 gpio-controller;
423 #gpio-cells = <1>;
Srinivas Kandagatlabdda8b02014-01-08 12:47:52 +0000424 interrupt-controller;
425 #interrupt-cells = <2>;
Srinivas Kandagatla15969b42013-06-25 12:15:23 +0100426 reg = <0x2000 0x100>;
427 st,bank-name = "PIO15";
428 };
Lee Jonesdc62bfd2014-05-27 14:53:00 +0200429 pio16: gpio@fe823000 {
Srinivas Kandagatla15969b42013-06-25 12:15:23 +0100430 gpio-controller;
431 #gpio-cells = <1>;
Srinivas Kandagatlabdda8b02014-01-08 12:47:52 +0000432 interrupt-controller;
433 #interrupt-cells = <2>;
Srinivas Kandagatla15969b42013-06-25 12:15:23 +0100434 reg = <0x3000 0x100>;
435 st,bank-name = "PIO16";
436 };
Lee Jonesdc62bfd2014-05-27 14:53:00 +0200437 pio17: gpio@fe824000 {
Srinivas Kandagatla15969b42013-06-25 12:15:23 +0100438 gpio-controller;
439 #gpio-cells = <1>;
Srinivas Kandagatlabdda8b02014-01-08 12:47:52 +0000440 interrupt-controller;
441 #interrupt-cells = <2>;
Srinivas Kandagatla15969b42013-06-25 12:15:23 +0100442 reg = <0x4000 0x100>;
443 st,bank-name = "PIO17";
444 };
Lee Jonesdc62bfd2014-05-27 14:53:00 +0200445 pio18: gpio@fe825000 {
Srinivas Kandagatla15969b42013-06-25 12:15:23 +0100446 gpio-controller;
447 #gpio-cells = <1>;
Srinivas Kandagatlabdda8b02014-01-08 12:47:52 +0000448 interrupt-controller;
449 #interrupt-cells = <2>;
Srinivas Kandagatla15969b42013-06-25 12:15:23 +0100450 reg = <0x5000 0x100>;
451 st,bank-name = "PIO18";
452 st,retime-pin-mask = <0xf>;
453 };
454
455 serial2 {
456 pinctrl_serial2: serial2-0 {
457 st,pins {
Lee Jonesdc62bfd2014-05-27 14:53:00 +0200458 tx = <&pio17 4 ALT2 OUT>;
459 rx = <&pio17 5 ALT2 IN>;
Srinivas Kandagatla15969b42013-06-25 12:15:23 +0100460 };
461 };
462 };
Srinivas Kandagatlad25ea582014-01-29 16:20:12 +0000463
464 gmac0 {
465 pinctrl_mii0: mii0 {
466 st,pins {
Lee Jonesdc62bfd2014-05-27 14:53:00 +0200467 mdint = <&pio13 6 ALT2 IN BYPASS 0>;
468 txen = <&pio13 7 ALT2 OUT SE_NICLK_IO 0 CLK_A>;
469 txd0 = <&pio14 0 ALT2 OUT SE_NICLK_IO 0 CLK_A>;
470 txd1 = <&pio14 1 ALT2 OUT SE_NICLK_IO 0 CLK_A>;
471 txd2 = <&pio14 2 ALT2 OUT SE_NICLK_IO 0 CLK_B>;
472 txd3 = <&pio14 3 ALT2 OUT SE_NICLK_IO 0 CLK_B>;
Srinivas Kandagatlad25ea582014-01-29 16:20:12 +0000473
Lee Jonesdc62bfd2014-05-27 14:53:00 +0200474 txclk = <&pio15 0 ALT2 IN NICLK 0 CLK_A>;
475 txer = <&pio15 1 ALT2 OUT SE_NICLK_IO 0 CLK_A>;
476 crs = <&pio15 2 ALT2 IN BYPASS 1000>;
477 col = <&pio15 3 ALT2 IN BYPASS 1000>;
478 mdio= <&pio15 4 ALT2 OUT BYPASS 1500>;
479 mdc = <&pio15 5 ALT2 OUT NICLK 0 CLK_B>;
Srinivas Kandagatlad25ea582014-01-29 16:20:12 +0000480
Lee Jonesdc62bfd2014-05-27 14:53:00 +0200481 rxd0 = <&pio16 0 ALT2 IN SE_NICLK_IO 0 CLK_A>;
482 rxd1 = <&pio16 1 ALT2 IN SE_NICLK_IO 0 CLK_A>;
483 rxd2 = <&pio16 2 ALT2 IN SE_NICLK_IO 0 CLK_A>;
484 rxd3 = <&pio16 3 ALT2 IN SE_NICLK_IO 0 CLK_A>;
485 rxdv = <&pio15 6 ALT2 IN SE_NICLK_IO 0 CLK_A>;
486 rx_er = <&pio15 7 ALT2 IN SE_NICLK_IO 0 CLK_A>;
487 rxclk = <&pio17 0 ALT2 IN NICLK 0 CLK_A>;
488 phyclk = <&pio13 5 ALT2 OUT NICLK 0 CLK_B>;
Srinivas Kandagatlad25ea582014-01-29 16:20:12 +0000489 };
490 };
491
492 pinctrl_gmii0: gmii0 {
493 st,pins {
494 };
495 };
496 pinctrl_rgmii0: rgmii0 {
497 st,pins {
Lee Jonesdc62bfd2014-05-27 14:53:00 +0200498 phyclk = <&pio13 5 ALT4 OUT NICLK 0 CLK_B>;
499 txen = <&pio13 7 ALT2 OUT DE_IO 0 CLK_A>;
500 txd0 = <&pio14 0 ALT2 OUT DE_IO 500 CLK_A>;
501 txd1 = <&pio14 1 ALT2 OUT DE_IO 500 CLK_A>;
502 txd2 = <&pio14 2 ALT2 OUT DE_IO 500 CLK_B>;
503 txd3 = <&pio14 3 ALT2 OUT DE_IO 500 CLK_B>;
504 txclk = <&pio15 0 ALT2 IN NICLK 0 CLK_A>;
Srinivas Kandagatlad25ea582014-01-29 16:20:12 +0000505
Lee Jonesdc62bfd2014-05-27 14:53:00 +0200506 mdio = <&pio15 4 ALT2 OUT BYPASS 0>;
507 mdc = <&pio15 5 ALT2 OUT NICLK 0 CLK_B>;
Srinivas Kandagatlad25ea582014-01-29 16:20:12 +0000508
Lee Jonesdc62bfd2014-05-27 14:53:00 +0200509 rxdv = <&pio15 6 ALT2 IN DE_IO 500 CLK_A>;
510 rxd0 =<&pio16 0 ALT2 IN DE_IO 500 CLK_A>;
511 rxd1 =<&pio16 1 ALT2 IN DE_IO 500 CLK_A>;
512 rxd2 =<&pio16 2 ALT2 IN DE_IO 500 CLK_A>;
513 rxd3 =<&pio16 3 ALT2 IN DE_IO 500 CLK_A>;
514 rxclk =<&pio17 0 ALT2 IN NICLK 0 CLK_A>;
Srinivas Kandagatlad25ea582014-01-29 16:20:12 +0000515
Lee Jonesdc62bfd2014-05-27 14:53:00 +0200516 clk125=<&pio17 6 ALT1 IN NICLK 0 CLK_A>;
Srinivas Kandagatlad25ea582014-01-29 16:20:12 +0000517 };
518 };
519 };
Peter Griffin8106d212014-07-09 17:07:00 +0200520
521 mmc0 {
522 pinctrl_mmc0: mmc0 {
523 st,pins {
524 mmcclk = <&pio13 4 ALT4 BIDIR_PU NICLK 0 CLK_B>;
525 data0 = <&pio14 4 ALT4 BIDIR_PU BYPASS 0>;
526 data1 = <&pio14 5 ALT4 BIDIR_PU BYPASS 0>;
527 data2 = <&pio14 6 ALT4 BIDIR_PU BYPASS 0>;
528 data3 = <&pio14 7 ALT4 BIDIR_PU BYPASS 0>;
529 cmd = <&pio15 1 ALT4 BIDIR_PU BYPASS 0>;
530 wp = <&pio15 3 ALT4 IN>;
531 data4 = <&pio16 4 ALT4 BIDIR_PU BYPASS 0>;
532 data5 = <&pio16 5 ALT4 BIDIR_PU BYPASS 0>;
533 data6 = <&pio16 6 ALT4 BIDIR_PU BYPASS 0>;
534 data7 = <&pio16 7 ALT4 BIDIR_PU BYPASS 0>;
535 pwr = <&pio17 1 ALT4 OUT>;
536 cd = <&pio17 2 ALT4 IN>;
537 led = <&pio17 3 ALT4 OUT>;
538 };
539 };
540 };
541 mmc1 {
542 pinctrl_mmc1: mmc1 {
543 st,pins {
544 mmcclk = <&pio15 0 ALT3 BIDIR_PU NICLK 0 CLK_B>;
545 data0 = <&pio13 7 ALT3 BIDIR_PU BYPASS 0>;
546 data1 = <&pio14 1 ALT3 BIDIR_PU BYPASS 0>;
547 data2 = <&pio14 2 ALT3 BIDIR_PU BYPASS 0>;
548 data3 = <&pio14 3 ALT3 BIDIR_PU BYPASS 0>;
549 cmd = <&pio15 4 ALT3 BIDIR_PU BYPASS 0>;
550 data4 = <&pio15 6 ALT3 BIDIR_PU BYPASS 0>;
551 data5 = <&pio15 7 ALT3 BIDIR_PU BYPASS 0>;
552 data6 = <&pio16 0 ALT3 BIDIR_PU BYPASS 0>;
553 data7 = <&pio16 1 ALT3 BIDIR_PU BYPASS 0>;
554 pwr = <&pio16 2 ALT3 OUT>;
555 nreset = <&pio13 6 ALT3 OUT>;
556 };
557 };
558 };
Peter Griffin401a5262014-11-17 17:47:00 +0100559
560 usb {
561 pinctrl_usb1: usb1 {
562 st,pins {
563 oc-detect = <&pio18 0 ALT1 IN>;
564 pwr-enable = <&pio18 1 ALT1 OUT>;
565 };
566 };
567 pinctrl_usb2: usb2 {
568 st,pins {
569 oc-detect = <&pio18 2 ALT1 IN>;
570 pwr-enable = <&pio18 3 ALT1 OUT>;
571 };
572 };
573 };
Lee Jones9723bac2015-05-12 14:51:00 +0200574
575 pwm0 {
576 pinctrl_pwm0_chan1_default: pwm0-1-default {
577 st,pins {
578 pwm-out = <&pio13 2 ALT2 OUT>;
579 };
580 };
581 pinctrl_pwm0_chan2_default: pwm0-2-default {
582 st,pins {
583 pwm-out = <&pio15 2 ALT4 OUT>;
584 };
585 };
586 pinctrl_pwm0_chan3_default: pwm0-3-default {
587 st,pins {
588 pwm-out = <&pio17 4 ALT1 OUT>;
589 };
590 };
591 };
592
Srinivas Kandagatla15969b42013-06-25 12:15:23 +0100593 };
594
595 pin-controller-fvdp-fe {
596 #address-cells = <1>;
597 #size-cells = <1>;
598 compatible = "st,stih416-fvdp-fe-pinctrl";
599 st,syscfg = <&syscfg_fvdp_fe>;
Srinivas Kandagatlabdda8b02014-01-08 12:47:52 +0000600 reg = <0xfd6bf080 0x4>;
601 reg-names = "irqmux";
602 interrupts = <GIC_SPI 113 IRQ_TYPE_LEVEL_HIGH>;
Geert Uytterhoevenae107d02014-04-22 20:40:25 +0200603 interrupt-names = "irqmux";
Srinivas Kandagatla15969b42013-06-25 12:15:23 +0100604 ranges = <0 0xfd6b0000 0x3000>;
605
Lee Jonesdc62bfd2014-05-27 14:53:00 +0200606 pio100: gpio@fd6b0000 {
Srinivas Kandagatla15969b42013-06-25 12:15:23 +0100607 gpio-controller;
608 #gpio-cells = <1>;
Srinivas Kandagatlabdda8b02014-01-08 12:47:52 +0000609 interrupt-controller;
610 #interrupt-cells = <2>;
Srinivas Kandagatla15969b42013-06-25 12:15:23 +0100611 reg = <0 0x100>;
612 st,bank-name = "PIO100";
613 };
Lee Jonesdc62bfd2014-05-27 14:53:00 +0200614 pio101: gpio@fd6b1000 {
Srinivas Kandagatla15969b42013-06-25 12:15:23 +0100615 gpio-controller;
616 #gpio-cells = <1>;
Srinivas Kandagatlabdda8b02014-01-08 12:47:52 +0000617 interrupt-controller;
618 #interrupt-cells = <2>;
Srinivas Kandagatla15969b42013-06-25 12:15:23 +0100619 reg = <0x1000 0x100>;
620 st,bank-name = "PIO101";
621 };
Lee Jonesdc62bfd2014-05-27 14:53:00 +0200622 pio102: gpio@fd6b2000 {
Srinivas Kandagatla15969b42013-06-25 12:15:23 +0100623 gpio-controller;
624 #gpio-cells = <1>;
Srinivas Kandagatlabdda8b02014-01-08 12:47:52 +0000625 interrupt-controller;
626 #interrupt-cells = <2>;
Srinivas Kandagatla15969b42013-06-25 12:15:23 +0100627 reg = <0x2000 0x100>;
628 st,bank-name = "PIO102";
629 };
630 };
631
632 pin-controller-fvdp-lite {
633 #address-cells = <1>;
634 #size-cells = <1>;
635 compatible = "st,stih416-fvdp-lite-pinctrl";
636 st,syscfg = <&syscfg_fvdp_lite>;
Srinivas Kandagatlabdda8b02014-01-08 12:47:52 +0000637 reg = <0xfd33f080 0x4>;
638 reg-names = "irqmux";
639 interrupts = <GIC_SPI 114 IRQ_TYPE_LEVEL_HIGH>;
Geert Uytterhoevenae107d02014-04-22 20:40:25 +0200640 interrupt-names = "irqmux";
Srinivas Kandagatla15969b42013-06-25 12:15:23 +0100641 ranges = <0 0xfd330000 0x5000>;
642
Lee Jonesdc62bfd2014-05-27 14:53:00 +0200643 pio103: gpio@fd330000 {
Srinivas Kandagatla15969b42013-06-25 12:15:23 +0100644 gpio-controller;
645 #gpio-cells = <1>;
Srinivas Kandagatlabdda8b02014-01-08 12:47:52 +0000646 interrupt-controller;
647 #interrupt-cells = <2>;
Srinivas Kandagatla15969b42013-06-25 12:15:23 +0100648 reg = <0 0x100>;
649 st,bank-name = "PIO103";
650 };
Lee Jonesdc62bfd2014-05-27 14:53:00 +0200651 pio104: gpio@fd331000 {
Srinivas Kandagatla15969b42013-06-25 12:15:23 +0100652 gpio-controller;
653 #gpio-cells = <1>;
Srinivas Kandagatlabdda8b02014-01-08 12:47:52 +0000654 interrupt-controller;
655 #interrupt-cells = <2>;
Srinivas Kandagatla15969b42013-06-25 12:15:23 +0100656 reg = <0x1000 0x100>;
657 st,bank-name = "PIO104";
658 };
Lee Jonesdc62bfd2014-05-27 14:53:00 +0200659 pio105: gpio@fd332000 {
Srinivas Kandagatla15969b42013-06-25 12:15:23 +0100660 gpio-controller;
661 #gpio-cells = <1>;
Srinivas Kandagatlabdda8b02014-01-08 12:47:52 +0000662 interrupt-controller;
663 #interrupt-cells = <2>;
Srinivas Kandagatla15969b42013-06-25 12:15:23 +0100664 reg = <0x2000 0x100>;
665 st,bank-name = "PIO105";
666 };
Lee Jonesdc62bfd2014-05-27 14:53:00 +0200667 pio106: gpio@fd333000 {
Srinivas Kandagatla15969b42013-06-25 12:15:23 +0100668 gpio-controller;
669 #gpio-cells = <1>;
Srinivas Kandagatlabdda8b02014-01-08 12:47:52 +0000670 interrupt-controller;
671 #interrupt-cells = <2>;
Srinivas Kandagatla15969b42013-06-25 12:15:23 +0100672 reg = <0x3000 0x100>;
673 st,bank-name = "PIO106";
674 };
675
Lee Jonesdc62bfd2014-05-27 14:53:00 +0200676 pio107: gpio@fd334000 {
Srinivas Kandagatla15969b42013-06-25 12:15:23 +0100677 gpio-controller;
678 #gpio-cells = <1>;
Srinivas Kandagatlabdda8b02014-01-08 12:47:52 +0000679 interrupt-controller;
680 #interrupt-cells = <2>;
Srinivas Kandagatla15969b42013-06-25 12:15:23 +0100681 reg = <0x4000 0x100>;
682 st,bank-name = "PIO107";
683 st,retime-pin-mask = <0xf>;
684 };
685 };
686 };
687};