blob: 94b868c7ceb19eae3228209e4140eb904dff8196 [file] [log] [blame]
Tom Rini53633a82024-02-29 12:33:36 -05001# SPDX-License-Identifier: (GPL-2.0-only OR BSD-2-Clause)
2# Copyright (C) Sunplus Co., Ltd.
3%YAML 1.2
4---
5$id: http://devicetree.org/schemas/pinctrl/sunplus,sp7021-pinctrl.yaml#
6$schema: http://devicetree.org/meta-schemas/core.yaml#
7
8title: Sunplus SP7021 Pin Controller
9
10maintainers:
11 - Dvorkin Dmitry <dvorkin@tibbo.com>
12 - Wells Lu <wellslutw@gmail.com>
13
14description: |
15 The Sunplus SP7021 pin controller is used to control SoC pins. Please
16 refer to pinctrl-bindings.txt in this directory for details of the common
17 pinctrl bindings used by client devices.
18
19 SP7021 has 99 digital GPIO pins which are numbered from GPIO 0 to 98. All
20 are multiplexed with some special function pins. SP7021 has 3 types of
21 special function pins:
22
23 (1) function-group pins:
24 Ex 1 (SPI-NOR flash):
25 If control-field SPI_FLASH_SEL is set to 1, GPIO 83, 84, 86 and 87
26 will be pins of SPI-NOR flash. If it is set to 2, GPIO 76, 78, 79
27 and 81 will be pins of SPI-NOR flash.
28
29 Ex 2 (UART_0):
30 If control-bit UA0_SEL is set to 1, GPIO 88 and 89 will be TX and
31 RX pins of UART_0 (UART channel 0).
32
33 Ex 3 (eMMC):
34 If control-bit EMMC_SEL is set to 1, GPIO 72, 73, 74, 75, 76, 77,
35 78, 79, 80, 81 will be pins of an eMMC device.
36
37 Properties "function" and "groups" are used to select function-group
38 pins.
39
40 (2) fully pin-mux (like phone exchange mux) pins:
41 GPIO 8 to 71 are 'fully pin-mux' pins. Any pins of peripherals of
42 SP7021 (ex: UART_1, UART_2, UART_3, UART_4, I2C_0, I2C_1, and etc.)
43 can be routed to any pins of fully pin-mux pins.
44
45 Ex 1 (UART channel 1):
46 If control-field UA1_TX_SEL is set to 3, TX pin of UART_1 will be
47 routed to GPIO 10 (3 - 1 + 8 = 10).
48 If control-field UA1_RX_SEL is set to 4, RX pin of UART_1 will be
49 routed to GPIO 11 (4 - 1 + 8 = 11).
50 If control-field UA1_RTS_SEL is set to 5, RTS pin of UART_1 will
51 be routed to GPIO 12 (5 - 1 + 8 = 12).
52 If control-field UA1_CTS_SEL is set to 6, CTS pin of UART_1 will
53 be routed to GPIO 13 (6 - 1 + 8 = 13).
54
55 Ex 2 (I2C channel 0):
56 If control-field I2C0_CLK_SEL is set to 20, CLK pin of I2C_0 will
57 be routed to GPIO 27 (20 - 1 + 8 = 27).
58 If control-field I2C0_DATA_SEL is set to 21, DATA pin of I2C_0
59 will be routed to GPIO 28 (21 - 1 + 9 = 28).
60
61 Totally, SP7021 has 120 peripheral pins. The peripheral pins can be
62 routed to any of 64 'fully pin-mux' pins.
63
64 (3) I/O processor pins
65 SP7021 has a built-in I/O processor.
66 Any GPIO pins (GPIO 0 to 98) can be set to pins of I/O processor.
67
68 Vendor property "sunplus,pins" is used to select "fully pin-mux" pins,
69 "I/O processor pins" and "digital GPIO" pins.
70
71 The device node of pin controller of Sunplus SP7021 has following
72 properties.
73
74properties:
75 compatible:
76 const: sunplus,sp7021-pctl
77
78 gpio-controller: true
79
80 '#gpio-cells':
81 const: 2
82
83 reg:
84 items:
85 - description: the MOON2 registers
86 - description: the GPIOXT registers
87 - description: the FIRST registers
88 - description: the MOON1 registers
89
90 reg-names:
91 items:
92 - const: moon2
93 - const: gpioxt
94 - const: first
95 - const: moon1
96
97 clocks:
98 maxItems: 1
99
100 resets:
101 maxItems: 1
102
103patternProperties:
104 '-pins$':
105 type: object
106 description: |
107 A pinctrl node should contain at least one subnodes representing the
108 pins or function-pins group available on the machine. Each subnode
109 will list the pins it needs, and how they should be configured.
110
111 Pinctrl node's client devices use subnodes for desired pin
112 configuration. Client device subnodes use below standard properties.
113 $ref: pinmux-node.yaml#
114
115 properties:
116 sunplus,pins:
117 description: |
118 Define 'sunplus,pins' which are used by pinctrl node's client
119 device.
120
121 It consists of one or more integers which represents the config
122 setting for corresponding pin. Each integer defines a individual
123 pin in which:
124
125 Bit 32~24: defines GPIO number. Its range is 0 ~ 98.
126 Bit 23~16: defines types: (1) fully pin-mux pins
127 (2) IO processor pins
128 (3) digital GPIO pins
129 Bit 15~8: defines pins of peripherals (which are defined in
130 'include/dt-binging/pinctrl/sppctl.h').
131 Bit 7~0: defines types or initial-state of digital GPIO pins.
132
133 Please use macro SPPCTL_IOPAD to define the integers for pins.
134
135 $ref: /schemas/types.yaml#/definitions/uint32-array
136
137 function:
138 description: |
139 Define pin-function which is used by pinctrl node's client device.
140 The name should be one of string in the following enumeration.
141 $ref: /schemas/types.yaml#/definitions/string
142 enum: [ SPI_FLASH, SPI_FLASH_4BIT, SPI_NAND, CARD0_EMMC, SD_CARD,
143 UA0, FPGA_IFX, HDMI_TX, LCDIF, USB0_OTG, USB1_OTG ]
144
145 groups:
146 description: |
147 Define pin-group in a specified pin-function.
148 The name should be one of string in the following enumeration.
149 $ref: /schemas/types.yaml#/definitions/string
150 enum: [ SPI_FLASH1, SPI_FLASH2, SPI_FLASH_4BIT1, SPI_FLASH_4BIT2,
151 SPI_NAND, CARD0_EMMC, SD_CARD, UA0, FPGA_IFX, HDMI_TX1,
152 HDMI_TX2, HDMI_TX3, LCDIF, USB0_OTG, USB1_OTG ]
153
154 sunplus,zerofunc:
155 description: |
156 This is a vendor specific property. It is used to disable pins
157 which are not used by pinctrl node's client device.
158 Some pins may be enabled by boot-loader. We can use this
159 property to disable them.
160 $ref: /schemas/types.yaml#/definitions/uint32-array
161
162 additionalProperties: false
163
164 allOf:
165 - if:
166 properties:
167 function:
168 enum:
169 - SPI_FLASH
170 then:
171 properties:
172 groups:
173 enum:
174 - SPI_FLASH1
175 - SPI_FLASH2
176 - if:
177 properties:
178 function:
179 enum:
180 - SPI_FLASH_4BIT
181 then:
182 properties:
183 groups:
184 enum:
185 - SPI_FLASH_4BIT1
186 - SPI_FLASH_4BIT2
187 - if:
188 properties:
189 function:
190 enum:
191 - SPI_NAND
192 then:
193 properties:
194 groups:
195 enum:
196 - SPI_NAND
197 - if:
198 properties:
199 function:
200 enum:
201 - CARD0_EMMC
202 then:
203 properties:
204 groups:
205 enum:
206 - CARD0_EMMC
207 - if:
208 properties:
209 function:
210 enum:
211 - SD_CARD
212 then:
213 properties:
214 groups:
215 enum:
216 - SD_CARD
217 - if:
218 properties:
219 function:
220 enum:
221 - UA0
222 then:
223 properties:
224 groups:
225 enum:
226 - UA0
227 - if:
228 properties:
229 function:
230 enum:
231 - FPGA_IFX
232 then:
233 properties:
234 groups:
235 enum:
236 - FPGA_IFX
237 - if:
238 properties:
239 function:
240 enum:
241 - HDMI_TX
242 then:
243 properties:
244 groups:
245 enum:
246 - HDMI_TX1
247 - HDMI_TX2
248 - HDMI_TX3
249 - if:
250 properties:
251 function:
252 enum:
253 - LCDIF
254 then:
255 properties:
256 groups:
257 enum:
258 - LCDIF
259 - if:
260 properties:
261 function:
262 enum:
263 - USB0_OTG
264 then:
265 properties:
266 groups:
267 enum:
268 - USB0_OTG
269 - if:
270 properties:
271 function:
272 enum:
273 - USB1_OTG
274 then:
275 properties:
276 groups:
277 enum:
278 - USB1_OTG
279
280required:
281 - compatible
282 - reg
283 - reg-names
284 - "#gpio-cells"
285 - gpio-controller
286 - clocks
287 - resets
288
289additionalProperties: false
290
291allOf:
292 - $ref: pinctrl.yaml#
293
294examples:
295 - |
296 #include <dt-bindings/pinctrl/sppctl-sp7021.h>
297
298 pinctrl@9c000100 {
299 compatible = "sunplus,sp7021-pctl";
300 reg = <0x9c000100 0x100>, <0x9c000300 0x100>,
301 <0x9c0032e4 0x1c>, <0x9c000080 0x20>;
302 reg-names = "moon2", "gpioxt", "first", "moon1";
303 gpio-controller;
304 #gpio-cells = <2>;
305 clocks = <&clkc 0x83>;
306 resets = <&rstc 0x73>;
307
308 uart0-pins {
309 function = "UA0";
310 groups = "UA0";
311 };
312
313 spinand0-pins {
314 function = "SPI_NAND";
315 groups = "SPI_NAND";
316 };
317
318 uart1-pins {
319 sunplus,pins = <
320 SPPCTL_IOPAD(11, SPPCTL_PCTL_G_PMUX, MUXF_UA1_TX, 0)
321 SPPCTL_IOPAD(10, SPPCTL_PCTL_G_PMUX, MUXF_UA1_RX, 0)
322 >;
323 };
324
325 uart2-pins {
326 sunplus,pins = <
327 SPPCTL_IOPAD(20, SPPCTL_PCTL_G_PMUX, MUXF_UA1_TX, 0)
328 SPPCTL_IOPAD(21, SPPCTL_PCTL_G_PMUX, MUXF_UA1_RX, 0)
329 SPPCTL_IOPAD(22, SPPCTL_PCTL_G_PMUX, MUXF_UA1_RTS, 0)
330 SPPCTL_IOPAD(23, SPPCTL_PCTL_G_PMUX, MUXF_UA1_CTS, 0)
331 >;
332 };
333
334 emmc-pins {
335 function = "CARD0_EMMC";
336 groups = "CARD0_EMMC";
337 };
338
339 sdcard-pins {
340 function = "SD_CARD";
341 groups = "SD_CARD";
342 sunplus,pins = < SPPCTL_IOPAD(91, SPPCTL_PCTL_G_GPIO, 0, 0) >;
343 };
344
345 hdmi_A_tx1-pins {
346 function = "HDMI_TX";
347 groups = "HDMI_TX1";
348 };
349 hdmi_A_tx2-pins {
350 function = "HDMI_TX";
351 groups = "HDMI_TX2";
352 };
353 hdmi_A_tx3-pins {
354 function = "HDMI_TX";
355 groups = "HDMI_TX3";
356 };
357
358 ethernet-pins {
359 sunplus,pins = <
360 SPPCTL_IOPAD(49,SPPCTL_PCTL_G_PMUX,MUXF_L2SW_CLK_OUT,0)
361 SPPCTL_IOPAD(44,SPPCTL_PCTL_G_PMUX,MUXF_L2SW_MAC_SMI_MDC,0)
362 SPPCTL_IOPAD(43,SPPCTL_PCTL_G_PMUX,MUXF_L2SW_MAC_SMI_MDIO,0)
363 SPPCTL_IOPAD(52,SPPCTL_PCTL_G_PMUX,MUXF_L2SW_P0_MAC_RMII_TXEN,0)
364 SPPCTL_IOPAD(50,SPPCTL_PCTL_G_PMUX,MUXF_L2SW_P0_MAC_RMII_TXD0,0)
365 SPPCTL_IOPAD(51,SPPCTL_PCTL_G_PMUX,MUXF_L2SW_P0_MAC_RMII_TXD1,0)
366 SPPCTL_IOPAD(46,SPPCTL_PCTL_G_PMUX,MUXF_L2SW_P0_MAC_RMII_CRSDV,0)
367 SPPCTL_IOPAD(47,SPPCTL_PCTL_G_PMUX,MUXF_L2SW_P0_MAC_RMII_RXD0,0)
368 SPPCTL_IOPAD(48,SPPCTL_PCTL_G_PMUX,MUXF_L2SW_P0_MAC_RMII_RXD1,0)
369 >;
370 sunplus,zerofunc = <
371 MUXF_L2SW_LED_FLASH0
372 MUXF_L2SW_LED_ON0
373 MUXF_L2SW_P0_MAC_RMII_RXER
374 >;
375 };
376 };
377...