3 * Copyright (C) 2013 STMicroelectronics Limited.
4 * Author: Srinivas Kandagatla <srinivas.kandagatla@st.com>
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.
10 #include "st-pincfg.h"
11 #include <dt-bindings/interrupt-controller/arm-gic.h>
51 compatible = "st,stih416-sbc-pinctrl";
52 st,syscfg = <&syscfg_sbc>;
53 reg = <0xfe61f080 0x4>;
55 interrupts = <GIC_SPI 182 IRQ_TYPE_LEVEL_HIGH>;
56 interrupt-names = "irqmux";
57 ranges = <0 0xfe610000 0x6000>;
63 #interrupt-cells = <2>;
65 st,bank-name = "PIO0";
71 #interrupt-cells = <2>;
73 st,bank-name = "PIO1";
79 #interrupt-cells = <2>;
81 st,bank-name = "PIO2";
87 #interrupt-cells = <2>;
89 st,bank-name = "PIO3";
95 #interrupt-cells = <2>;
97 st,bank-name = "PIO4";
99 pio40: gpio@fe615000 {
102 interrupt-controller;
103 #interrupt-cells = <2>;
104 reg = <0x5000 0x100>;
105 st,bank-name = "PIO40";
106 st,retime-pin-mask = <0x7f>;
112 ir = <&pio4 0 ALT2 IN>;
117 pinctrl_sbc_serial1: sbc_serial1 {
119 tx = <&pio2 6 ALT3 OUT>;
120 rx = <&pio2 7 ALT3 IN>;
126 pinctrl_keyscan: keyscan {
128 keyin0 = <&pio0 2 ALT2 IN>;
129 keyin1 = <&pio0 3 ALT2 IN>;
130 keyin2 = <&pio0 4 ALT2 IN>;
131 keyin3 = <&pio2 6 ALT2 IN>;
133 keyout0 = <&pio1 6 ALT2 OUT>;
134 keyout1 = <&pio1 7 ALT2 OUT>;
135 keyout2 = <&pio0 6 ALT2 OUT>;
136 keyout3 = <&pio2 7 ALT2 OUT>;
142 pinctrl_sbc_i2c0_default: sbc_i2c0-default {
144 sda = <&pio4 6 ALT1 BIDIR>;
145 scl = <&pio4 5 ALT1 BIDIR>;
153 oc-detect = <&pio40 0 ALT1 IN>;
154 pwr-enable = <&pio40 1 ALT1 OUT>;
160 pinctrl_sbc_i2c1_default: sbc_i2c1-default {
162 sda = <&pio3 2 ALT2 BIDIR>;
163 scl = <&pio3 1 ALT2 BIDIR>;
171 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>;
180 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>;
189 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>;
195 pinctrl_rgmii1: rgmii1-0 {
197 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>;
204 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>;
211 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>;
215 clk125= <&pio3 7 ALT4 IN NICLK 0 CLK_A>;
221 pin-controller-front {
222 #address-cells = <1>;
224 compatible = "st,stih416-front-pinctrl";
225 st,syscfg = <&syscfg_front>;
226 reg = <0xfee0f080 0x4>;
227 reg-names = "irqmux";
228 interrupts = <GIC_SPI 183 IRQ_TYPE_LEVEL_HIGH>;
229 interrupt-names = "irqmux";
230 ranges = <0 0xfee00000 0x10000>;
232 pio5: gpio@fee00000 {
235 interrupt-controller;
236 #interrupt-cells = <2>;
238 st,bank-name = "PIO5";
240 pio6: gpio@fee01000 {
243 interrupt-controller;
244 #interrupt-cells = <2>;
245 reg = <0x1000 0x100>;
246 st,bank-name = "PIO6";
248 pio7: gpio@fee02000 {
251 interrupt-controller;
252 #interrupt-cells = <2>;
253 reg = <0x2000 0x100>;
254 st,bank-name = "PIO7";
256 pio8: gpio@fee03000 {
259 interrupt-controller;
260 #interrupt-cells = <2>;
261 reg = <0x3000 0x100>;
262 st,bank-name = "PIO8";
264 pio9: gpio@fee04000 {
267 interrupt-controller;
268 #interrupt-cells = <2>;
269 reg = <0x4000 0x100>;
270 st,bank-name = "PIO9";
272 pio10: gpio@fee05000 {
275 interrupt-controller;
276 #interrupt-cells = <2>;
277 reg = <0x5000 0x100>;
278 st,bank-name = "PIO10";
280 pio11: gpio@fee06000 {
283 interrupt-controller;
284 #interrupt-cells = <2>;
285 reg = <0x6000 0x100>;
286 st,bank-name = "PIO11";
288 pio12: gpio@fee07000 {
291 interrupt-controller;
292 #interrupt-cells = <2>;
293 reg = <0x7000 0x100>;
294 st,bank-name = "PIO12";
296 pio30: gpio@fee08000 {
299 interrupt-controller;
300 #interrupt-cells = <2>;
301 reg = <0x8000 0x100>;
302 st,bank-name = "PIO30";
304 pio31: gpio@fee09000 {
307 interrupt-controller;
308 #interrupt-cells = <2>;
309 reg = <0x9000 0x100>;
310 st,bank-name = "PIO31";
314 pinctrl_serial2_oe: serial2-1 {
316 output-enable = <&pio11 3 ALT2 OUT>;
322 pinctrl_i2c0_default: i2c0-default {
324 sda = <&pio9 3 ALT1 BIDIR>;
325 scl = <&pio9 2 ALT1 BIDIR>;
333 oc-detect = <&pio9 4 ALT1 IN>;
334 pwr-enable = <&pio9 5 ALT1 OUT>;
341 pinctrl_i2c1_default: i2c1-default {
343 sda = <&pio12 1 ALT1 BIDIR>;
344 scl = <&pio12 0 ALT1 BIDIR>;
352 spi-fsm-clk = <&pio12 2 ALT1 OUT>;
353 spi-fsm-cs = <&pio12 3 ALT1 OUT>;
354 spi-fsm-mosi = <&pio12 4 ALT1 OUT>;
355 spi-fsm-miso = <&pio12 5 ALT1 IN>;
356 spi-fsm-hol = <&pio12 6 ALT1 OUT>;
357 spi-fsm-wp = <&pio12 7 ALT1 OUT>;
363 pin-controller-rear {
364 #address-cells = <1>;
366 compatible = "st,stih416-rear-pinctrl";
367 st,syscfg = <&syscfg_rear>;
368 reg = <0xfe82f080 0x4>;
369 reg-names = "irqmux";
370 interrupts = <GIC_SPI 184 IRQ_TYPE_LEVEL_HIGH>;
371 interrupt-names = "irqmux";
372 ranges = <0 0xfe820000 0x6000>;
374 pio13: gpio@fe820000 {
377 interrupt-controller;
378 #interrupt-cells = <2>;
380 st,bank-name = "PIO13";
382 pio14: gpio@fe821000 {
385 interrupt-controller;
386 #interrupt-cells = <2>;
387 reg = <0x1000 0x100>;
388 st,bank-name = "PIO14";
390 pio15: gpio@fe822000 {
393 interrupt-controller;
394 #interrupt-cells = <2>;
395 reg = <0x2000 0x100>;
396 st,bank-name = "PIO15";
398 pio16: gpio@fe823000 {
401 interrupt-controller;
402 #interrupt-cells = <2>;
403 reg = <0x3000 0x100>;
404 st,bank-name = "PIO16";
406 pio17: gpio@fe824000 {
409 interrupt-controller;
410 #interrupt-cells = <2>;
411 reg = <0x4000 0x100>;
412 st,bank-name = "PIO17";
414 pio18: gpio@fe825000 {
417 interrupt-controller;
418 #interrupt-cells = <2>;
419 reg = <0x5000 0x100>;
420 st,bank-name = "PIO18";
421 st,retime-pin-mask = <0xf>;
425 pinctrl_serial2: serial2-0 {
427 tx = <&pio17 4 ALT2 OUT>;
428 rx = <&pio17 5 ALT2 IN>;
436 mdint = <&pio13 6 ALT2 IN BYPASS 0>;
437 txen = <&pio13 7 ALT2 OUT SE_NICLK_IO 0 CLK_A>;
438 txd0 = <&pio14 0 ALT2 OUT SE_NICLK_IO 0 CLK_A>;
439 txd1 = <&pio14 1 ALT2 OUT SE_NICLK_IO 0 CLK_A>;
440 txd2 = <&pio14 2 ALT2 OUT SE_NICLK_IO 0 CLK_B>;
441 txd3 = <&pio14 3 ALT2 OUT SE_NICLK_IO 0 CLK_B>;
443 txclk = <&pio15 0 ALT2 IN NICLK 0 CLK_A>;
444 txer = <&pio15 1 ALT2 OUT SE_NICLK_IO 0 CLK_A>;
445 crs = <&pio15 2 ALT2 IN BYPASS 1000>;
446 col = <&pio15 3 ALT2 IN BYPASS 1000>;
447 mdio= <&pio15 4 ALT2 OUT BYPASS 1500>;
448 mdc = <&pio15 5 ALT2 OUT NICLK 0 CLK_B>;
450 rxd0 = <&pio16 0 ALT2 IN SE_NICLK_IO 0 CLK_A>;
451 rxd1 = <&pio16 1 ALT2 IN SE_NICLK_IO 0 CLK_A>;
452 rxd2 = <&pio16 2 ALT2 IN SE_NICLK_IO 0 CLK_A>;
453 rxd3 = <&pio16 3 ALT2 IN SE_NICLK_IO 0 CLK_A>;
454 rxdv = <&pio15 6 ALT2 IN SE_NICLK_IO 0 CLK_A>;
455 rx_er = <&pio15 7 ALT2 IN SE_NICLK_IO 0 CLK_A>;
456 rxclk = <&pio17 0 ALT2 IN NICLK 0 CLK_A>;
457 phyclk = <&pio13 5 ALT2 OUT NICLK 0 CLK_B>;
461 pinctrl_gmii0: gmii0 {
465 pinctrl_rgmii0: rgmii0 {
467 phyclk = <&pio13 5 ALT4 OUT NICLK 0 CLK_B>;
468 txen = <&pio13 7 ALT2 OUT DE_IO 0 CLK_A>;
469 txd0 = <&pio14 0 ALT2 OUT DE_IO 500 CLK_A>;
470 txd1 = <&pio14 1 ALT2 OUT DE_IO 500 CLK_A>;
471 txd2 = <&pio14 2 ALT2 OUT DE_IO 500 CLK_B>;
472 txd3 = <&pio14 3 ALT2 OUT DE_IO 500 CLK_B>;
473 txclk = <&pio15 0 ALT2 IN NICLK 0 CLK_A>;
475 mdio = <&pio15 4 ALT2 OUT BYPASS 0>;
476 mdc = <&pio15 5 ALT2 OUT NICLK 0 CLK_B>;
478 rxdv = <&pio15 6 ALT2 IN DE_IO 500 CLK_A>;
479 rxd0 =<&pio16 0 ALT2 IN DE_IO 500 CLK_A>;
480 rxd1 =<&pio16 1 ALT2 IN DE_IO 500 CLK_A>;
481 rxd2 =<&pio16 2 ALT2 IN DE_IO 500 CLK_A>;
482 rxd3 =<&pio16 3 ALT2 IN DE_IO 500 CLK_A>;
483 rxclk =<&pio17 0 ALT2 IN NICLK 0 CLK_A>;
485 clk125=<&pio17 6 ALT1 IN NICLK 0 CLK_A>;
493 mmcclk = <&pio13 4 ALT4 BIDIR_PU NICLK 0 CLK_B>;
494 data0 = <&pio14 4 ALT4 BIDIR_PU BYPASS 0>;
495 data1 = <&pio14 5 ALT4 BIDIR_PU BYPASS 0>;
496 data2 = <&pio14 6 ALT4 BIDIR_PU BYPASS 0>;
497 data3 = <&pio14 7 ALT4 BIDIR_PU BYPASS 0>;
498 cmd = <&pio15 1 ALT4 BIDIR_PU BYPASS 0>;
499 wp = <&pio15 3 ALT4 IN>;
500 data4 = <&pio16 4 ALT4 BIDIR_PU BYPASS 0>;
501 data5 = <&pio16 5 ALT4 BIDIR_PU BYPASS 0>;
502 data6 = <&pio16 6 ALT4 BIDIR_PU BYPASS 0>;
503 data7 = <&pio16 7 ALT4 BIDIR_PU BYPASS 0>;
504 pwr = <&pio17 1 ALT4 OUT>;
505 cd = <&pio17 2 ALT4 IN>;
506 led = <&pio17 3 ALT4 OUT>;
513 mmcclk = <&pio15 0 ALT3 BIDIR_PU NICLK 0 CLK_B>;
514 data0 = <&pio13 7 ALT3 BIDIR_PU BYPASS 0>;
515 data1 = <&pio14 1 ALT3 BIDIR_PU BYPASS 0>;
516 data2 = <&pio14 2 ALT3 BIDIR_PU BYPASS 0>;
517 data3 = <&pio14 3 ALT3 BIDIR_PU BYPASS 0>;
518 cmd = <&pio15 4 ALT3 BIDIR_PU BYPASS 0>;
519 data4 = <&pio15 6 ALT3 BIDIR_PU BYPASS 0>;
520 data5 = <&pio15 7 ALT3 BIDIR_PU BYPASS 0>;
521 data6 = <&pio16 0 ALT3 BIDIR_PU BYPASS 0>;
522 data7 = <&pio16 1 ALT3 BIDIR_PU BYPASS 0>;
523 pwr = <&pio16 2 ALT3 OUT>;
524 nreset = <&pio13 6 ALT3 OUT>;
532 oc-detect = <&pio18 0 ALT1 IN>;
533 pwr-enable = <&pio18 1 ALT1 OUT>;
538 oc-detect = <&pio18 2 ALT1 IN>;
539 pwr-enable = <&pio18 3 ALT1 OUT>;
545 pin-controller-fvdp-fe {
546 #address-cells = <1>;
548 compatible = "st,stih416-fvdp-fe-pinctrl";
549 st,syscfg = <&syscfg_fvdp_fe>;
550 reg = <0xfd6bf080 0x4>;
551 reg-names = "irqmux";
552 interrupts = <GIC_SPI 113 IRQ_TYPE_LEVEL_HIGH>;
553 interrupt-names = "irqmux";
554 ranges = <0 0xfd6b0000 0x3000>;
556 pio100: gpio@fd6b0000 {
559 interrupt-controller;
560 #interrupt-cells = <2>;
562 st,bank-name = "PIO100";
564 pio101: gpio@fd6b1000 {
567 interrupt-controller;
568 #interrupt-cells = <2>;
569 reg = <0x1000 0x100>;
570 st,bank-name = "PIO101";
572 pio102: gpio@fd6b2000 {
575 interrupt-controller;
576 #interrupt-cells = <2>;
577 reg = <0x2000 0x100>;
578 st,bank-name = "PIO102";
582 pin-controller-fvdp-lite {
583 #address-cells = <1>;
585 compatible = "st,stih416-fvdp-lite-pinctrl";
586 st,syscfg = <&syscfg_fvdp_lite>;
587 reg = <0xfd33f080 0x4>;
588 reg-names = "irqmux";
589 interrupts = <GIC_SPI 114 IRQ_TYPE_LEVEL_HIGH>;
590 interrupt-names = "irqmux";
591 ranges = <0 0xfd330000 0x5000>;
593 pio103: gpio@fd330000 {
596 interrupt-controller;
597 #interrupt-cells = <2>;
599 st,bank-name = "PIO103";
601 pio104: gpio@fd331000 {
604 interrupt-controller;
605 #interrupt-cells = <2>;
606 reg = <0x1000 0x100>;
607 st,bank-name = "PIO104";
609 pio105: gpio@fd332000 {
612 interrupt-controller;
613 #interrupt-cells = <2>;
614 reg = <0x2000 0x100>;
615 st,bank-name = "PIO105";
617 pio106: gpio@fd333000 {
620 interrupt-controller;
621 #interrupt-cells = <2>;
622 reg = <0x3000 0x100>;
623 st,bank-name = "PIO106";
626 pio107: gpio@fd334000 {
629 interrupt-controller;
630 #interrupt-cells = <2>;
631 reg = <0x4000 0x100>;
632 st,bank-name = "PIO107";
633 st,retime-pin-mask = <0xf>;