xref: /freebsd/sys/contrib/device-tree/Bindings/pinctrl/marvell,armada-37xx-pinctrl.txt (revision d5b0e70f7e04d971691517ce1304d86a1e367e2e)
1* Marvell Armada 37xx SoC pin and gpio controller
2
3Each Armada 37xx SoC come with two pin and gpio controller one for the
4south bridge and the other for the north bridge.
5
6Inside this set of register the gpio latch allows exposing some
7configuration of the SoC and especially the clock frequency of the
8xtal. Hence, this node is a represent as syscon allowing sharing the
9register between multiple hardware block.
10
11GPIO and pin controller:
12------------------------
13
14Main node:
15
16Refer to pinctrl-bindings.txt in this directory for details of the
17common pinctrl bindings used by client devices, including the meaning
18of the phrase "pin configuration node".
19
20Required properties for pinctrl driver:
21
22- compatible:	"marvell,armada3710-sb-pinctrl", "syscon, "simple-mfd"
23		for the south bridge
24		"marvell,armada3710-nb-pinctrl", "syscon, "simple-mfd"
25		for the north bridge
26- reg: The first set of register are for pinctrl/gpio and the second
27  set for the interrupt controller
28- interrupts: list of the interrupt use by the gpio
29
30Available groups and functions for the North bridge:
31
32group: jtag
33 - pins 20-24
34 - functions jtag, gpio
35
36group sdio0
37 - pins 8-10
38 - functions sdio, gpio
39
40group emmc_nb
41 - pins 27-35
42 - functions emmc, gpio
43
44group pwm0
45 - pin 11 (GPIO1-11)
46 - functions pwm, led, gpio
47
48group pwm1
49 - pin 12
50 - functions pwm, led, gpio
51
52group pwm2
53 - pin 13
54 - functions pwm, led, gpio
55
56group pwm3
57 - pin 14
58 - functions pwm, led, gpio
59
60group pmic1
61 - pin 7
62 - functions pmic, gpio
63
64group pmic0
65 - pin 6
66 - functions pmic, gpio
67
68group i2c2
69 - pins 2-3
70 - functions i2c, gpio
71
72group i2c1
73 - pins 0-1
74 - functions i2c, gpio
75
76group spi_cs1
77 - pin 17
78 - functions spi, gpio
79
80group spi_cs2
81 - pin 18
82 - functions spi, gpio
83
84group spi_cs3
85 - pin 19
86 - functions spi, gpio
87
88group onewire
89 - pin 4
90 - functions onewire, gpio
91
92group uart1
93 - pins 25-26
94 - functions uart, gpio
95
96group spi_quad
97 - pins 15-16
98 - functions spi, gpio
99
100group uart2
101 - pins 9-10 and 18-19
102 - functions uart, gpio
103
104Available groups and functions for the South bridge:
105
106group usb32_drvvbus0
107 - pin 36
108 - functions drvbus, gpio
109
110group usb2_drvvbus1
111 - pin 37
112 - functions drvbus, gpio
113
114group sdio_sb
115 - pins 60-65
116 - functions sdio, gpio
117
118group rgmii
119 - pins 42-53
120 - functions mii, gpio
121
122group pcie1
123 - pins 39
124 - functions pcie, gpio
125
126group pcie1_clkreq
127 - pins 40
128 - functions pcie, gpio
129
130group pcie1_wakeup
131 - pins 41
132 - functions pcie, gpio
133
134group smi
135 - pins 54-55
136 - functions smi, gpio
137
138group ptp
139 - pins 56
140 - functions ptp, gpio
141
142group ptp_clk
143 - pin 57
144 - functions ptp, mii
145
146group ptp_trig
147 - pin 58
148 - functions ptp, mii
149
150group mii_col
151 - pin 59
152 - functions mii, mii_err
153
154GPIO subnode:
155
156Please refer to gpio.txt in this directory for details of gpio-ranges property
157and the common GPIO bindings used by client devices.
158
159Required properties for gpio driver under the gpio subnode:
160- interrupts: List of interrupt specifier for the controllers interrupt.
161- gpio-controller: Marks the device node as a gpio controller.
162- #gpio-cells: Should be 2. The first cell is the GPIO number and the
163   second cell specifies GPIO flags, as defined in
164   <dt-bindings/gpio/gpio.h>. Only the GPIO_ACTIVE_HIGH and
165   GPIO_ACTIVE_LOW flags are supported.
166- gpio-ranges: Range of pins managed by the GPIO controller.
167
168Xtal Clock bindings for Marvell Armada 37xx SoCs
169------------------------------------------------
170
171see Documentation/devicetree/bindings/clock/armada3700-xtal-clock.txt
172
173
174Example:
175pinctrl_sb: pinctrl-sb@18800 {
176	compatible = "marvell,armada3710-sb-pinctrl", "syscon", "simple-mfd";
177	reg = <0x18800 0x100>, <0x18C00 0x20>;
178	gpio {
179		#gpio-cells = <2>;
180		gpio-ranges = <&pinctrl_sb 0 0 29>;
181		gpio-controller;
182		interrupts =
183		<GIC_SPI 160 IRQ_TYPE_LEVEL_HIGH>,
184		<GIC_SPI 159 IRQ_TYPE_LEVEL_HIGH>,
185		<GIC_SPI 158 IRQ_TYPE_LEVEL_HIGH>,
186		<GIC_SPI 157 IRQ_TYPE_LEVEL_HIGH>,
187		<GIC_SPI 156 IRQ_TYPE_LEVEL_HIGH>;
188	};
189
190	rgmii_pins: mii-pins {
191		groups = "rgmii";
192		function = "mii";
193	};
194
195};
196