Merge tag 'pci-v5.18-changes-2' of git://git.kernel.org/pub/scm/linux/kernel/git...
[sfrench/cifs-2.6.git] / Documentation / devicetree / bindings / pinctrl / sunplus,sp7021-pinctrl.yaml
1 # 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
8 title: Sunplus SP7021 Pin Controller Device Tree Bindings
9
10 maintainers:
11   - Dvorkin Dmitry <dvorkin@tibbo.com>
12   - Wells Lu <wellslutw@gmail.com>
13
14 description: |
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
74 properties:
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
103 patternProperties:
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
280 required:
281   - compatible
282   - reg
283   - reg-names
284   - "#gpio-cells"
285   - gpio-controller
286   - clocks
287   - resets
288
289 additionalProperties: false
290
291 examples:
292   - |
293     #include <dt-bindings/pinctrl/sppctl-sp7021.h>
294
295     pinctl@9c000100 {
296         compatible = "sunplus,sp7021-pctl";
297         reg = <0x9c000100 0x100>, <0x9c000300 0x100>,
298               <0x9c0032e4 0x1c>, <0x9c000080 0x20>;
299         reg-names = "moon2", "gpioxt", "first", "moon1";
300         gpio-controller;
301         #gpio-cells = <2>;
302         clocks = <&clkc 0x83>;
303         resets = <&rstc 0x73>;
304
305         uart0-pins {
306             function = "UA0";
307             groups = "UA0";
308         };
309
310         spinand0-pins {
311             function = "SPI_NAND";
312             groups = "SPI_NAND";
313         };
314
315         uart1-pins {
316             sunplus,pins = <
317                 SPPCTL_IOPAD(11, SPPCTL_PCTL_G_PMUX, MUXF_UA1_TX, 0)
318                 SPPCTL_IOPAD(10, SPPCTL_PCTL_G_PMUX, MUXF_UA1_RX, 0)
319             >;
320         };
321
322         uart2-pins {
323             sunplus,pins = <
324                 SPPCTL_IOPAD(20, SPPCTL_PCTL_G_PMUX, MUXF_UA1_TX, 0)
325                 SPPCTL_IOPAD(21, SPPCTL_PCTL_G_PMUX, MUXF_UA1_RX, 0)
326                 SPPCTL_IOPAD(22, SPPCTL_PCTL_G_PMUX, MUXF_UA1_RTS, 0)
327                 SPPCTL_IOPAD(23, SPPCTL_PCTL_G_PMUX, MUXF_UA1_CTS, 0)
328             >;
329         };
330
331         emmc-pins {
332             function = "CARD0_EMMC";
333             groups = "CARD0_EMMC";
334         };
335
336         sdcard-pins {
337             function = "SD_CARD";
338             groups = "SD_CARD";
339             sunplus,pins = < SPPCTL_IOPAD(91, SPPCTL_PCTL_G_GPIO, 0, 0) >;
340         };
341
342         hdmi_A_tx1-pins {
343             function = "HDMI_TX";
344             groups = "HDMI_TX1";
345         };
346         hdmi_A_tx2-pins {
347             function = "HDMI_TX";
348             groups = "HDMI_TX2";
349         };
350         hdmi_A_tx3-pins {
351             function = "HDMI_TX";
352             groups = "HDMI_TX3";
353         };
354
355         ethernet-pins {
356             sunplus,pins = <
357                 SPPCTL_IOPAD(49,SPPCTL_PCTL_G_PMUX,MUXF_L2SW_CLK_OUT,0)
358                 SPPCTL_IOPAD(44,SPPCTL_PCTL_G_PMUX,MUXF_L2SW_MAC_SMI_MDC,0)
359                 SPPCTL_IOPAD(43,SPPCTL_PCTL_G_PMUX,MUXF_L2SW_MAC_SMI_MDIO,0)
360                 SPPCTL_IOPAD(52,SPPCTL_PCTL_G_PMUX,MUXF_L2SW_P0_MAC_RMII_TXEN,0)
361                 SPPCTL_IOPAD(50,SPPCTL_PCTL_G_PMUX,MUXF_L2SW_P0_MAC_RMII_TXD0,0)
362                 SPPCTL_IOPAD(51,SPPCTL_PCTL_G_PMUX,MUXF_L2SW_P0_MAC_RMII_TXD1,0)
363                 SPPCTL_IOPAD(46,SPPCTL_PCTL_G_PMUX,MUXF_L2SW_P0_MAC_RMII_CRSDV,0)
364                 SPPCTL_IOPAD(47,SPPCTL_PCTL_G_PMUX,MUXF_L2SW_P0_MAC_RMII_RXD0,0)
365                 SPPCTL_IOPAD(48,SPPCTL_PCTL_G_PMUX,MUXF_L2SW_P0_MAC_RMII_RXD1,0)
366             >;
367             sunplus,zerofunc = <
368                 MUXF_L2SW_LED_FLASH0
369                 MUXF_L2SW_LED_ON0
370                 MUXF_L2SW_P0_MAC_RMII_RXER
371             >;
372         };
373     };
374 ...