blob: 3139a99fa97178dbe54092518cdde9095a448892 [file] [log] [blame]
Ken Ma3e6c4c32018-03-26 15:56:05 +08001* Marvell Armada 37xx SoC pin and GPIO controller
2
3Each Armada 37xx SoC comes with two pin and GPIO controllers, one for the
4South Bridge and the other for the North Bridge.
5
6GPIO and pin controller:
7------------------------
8
9Main node:
10
11Refer to pinctrl-bindings.txt in this directory for details of the
12common pinctrl bindings used by client devices, including the meaning
13of the phrase "pin configuration node".
14
15Required properties for pinctrl driver:
16
17- compatible: "marvell,armada3710-sb-pinctrl", "syscon, "simple-mfd"
18 for the South Bridge
19 "marvell,armada3710-nb-pinctrl", "syscon, "simple-mfd"
20 for the North Bridge
21- reg: The first set of registers is for pinctrl/GPIO and the second
22 set is for the interrupt controller
23- interrupts: list of interrupts used by the GPIO
24
25Available groups and functions for the North Bridge:
26
27group: jtag
28 - pins 20-24
29 - functions jtag, gpio
30
31group sdio0
32 - pins 8-10
33 - functions sdio, gpio
34
35group emmc_nb
36 - pins 27-35
37 - functions emmc, gpio
38
39group pwm0
40 - pin 11 (GPIO1-11)
Marek Behún9eaf20b2021-07-23 19:57:11 +020041 - functions pwm, led, gpio
Ken Ma3e6c4c32018-03-26 15:56:05 +080042
43group pwm1
44 - pin 12
Marek Behún9eaf20b2021-07-23 19:57:11 +020045 - functions pwm, led, gpio
Ken Ma3e6c4c32018-03-26 15:56:05 +080046
47group pwm2
48 - pin 13
Marek Behún9eaf20b2021-07-23 19:57:11 +020049 - functions pwm, led, gpio
Ken Ma3e6c4c32018-03-26 15:56:05 +080050
51group pwm3
52 - pin 14
Marek Behún9eaf20b2021-07-23 19:57:11 +020053 - functions pwm, led, gpio
Ken Ma3e6c4c32018-03-26 15:56:05 +080054
55group pmic1
56 - pin 7
57 - functions pmic, gpio
58
59group pmic0
60 - pin 6
61 - functions pmic, gpio
62
63group i2c2
64 - pins 2-3
65 - functions i2c, gpio
66
67group i2c1
68 - pins 0-1
69 - functions i2c, gpio
70
71group spi_cs1
72 - pin 17
73 - functions spi, gpio
74
75group spi_cs2
76 - pin 18
77 - functions spi, gpio
78
79group spi_cs3
80 - pin 19
81 - functions spi, gpio
82
83group onewire
84 - pin 4
85 - functions onewire, gpio
86
87group uart1
88 - pins 25-26
89 - functions uart, gpio
90
91group spi_quad
92 - pins 15-16
93 - functions spi, gpio
94
95group uart_2
96 - pins 9-10
97 - functions uart, gpio
98
99Available groups and functions for the South Bridge:
100
101group usb32_drvvbus0
102 - pin 36
103 - functions drvbus, gpio
104
105group usb2_drvvbus1
106 - pin 37
107 - functions drvbus, gpio
108
109group sdio_sb
110 - pins 60-65
111 - functions sdio, gpio
112
113group rgmii
114 - pins 42-53
115 - functions mii, gpio
116
117group pcie1
118 - pins 39-41
119 - functions pcie, gpio
120
121group smi
122 - pins 54-55
123 - functions smi, gpio
124
125group ptp
126 - pins 56-58
127 - functions ptp, gpio
128
129group ptp_clk
130 - pin 57
131 - functions ptp, mii
132
133group ptp_trig
134 - pin 58
135 - functions ptp, mii
136
137group mii_col
138 - pin 59
139 - functions mii, mii_err
140
141GPIO subnode:
142
143Please refer to gpio.txt in "gpio" directory for details of gpio-ranges property
144and the common GPIO bindings used by client devices.
145
146Required properties for the GPIO driver under the gpio subnode:
147- interrupts: List of interrupt specifiers for the controllers interrupt.
148- gpio-controller: Marks the device node as a GPIO controller.
149- #gpio-cells: Should be 2. The first cell is the GPIO number and the
150 second cell specifies GPIO flags, as defined in
151 <dt-bindings/gpio/gpio.h>. Only the GPIO_ACTIVE_HIGH and
152 GPIO_ACTIVE_LOW flags are supported.
153- gpio-ranges: Range of pins managed by the GPIO controller.
154
155Example:
156pinctrl_sb: pinctrl-sb@18800 {
157 compatible = "marvell,armada3710-sb-pinctrl",
158 "syscon", "simple-mfd";
159 reg = <0x18800 0x100>, <0x18C00 0x20>;
160 gpiosb: gpiosb {
161 #gpio-cells = <2>;
162 gpio-ranges = <&pinctrl_sb 0 0 30>;
163 gpio-controller;
164 interrupts =
165 <GIC_SPI 160 IRQ_TYPE_LEVEL_HIGH>,
166 <GIC_SPI 159 IRQ_TYPE_LEVEL_HIGH>,
167 <GIC_SPI 158 IRQ_TYPE_LEVEL_HIGH>,
168 <GIC_SPI 157 IRQ_TYPE_LEVEL_HIGH>,
169 <GIC_SPI 156 IRQ_TYPE_LEVEL_HIGH>;
170 };
171
172 rgmii_pins: mii-pins {
173 groups = "rgmii";
174 function = "mii";
175 };
176
177 sdio_pins: sdio-pins {
178 groups = "sdio_sb";
179 function = "sdio";
180 };
181
182 pcie_pins: pcie-pins {
183 groups = "pcie1";
184 function = "pcie";
185 };
186};