~ [ source navigation ] ~ [ diff markup ] ~ [ identifier search ] ~

TOMOYO Linux Cross Reference
Linux/Documentation/devicetree/bindings/pinctrl/sunplus,sp7021-pinctrl.yaml

Version: ~ [ linux-6.12-rc7 ] ~ [ linux-6.11.7 ] ~ [ linux-6.10.14 ] ~ [ linux-6.9.12 ] ~ [ linux-6.8.12 ] ~ [ linux-6.7.12 ] ~ [ linux-6.6.60 ] ~ [ linux-6.5.13 ] ~ [ linux-6.4.16 ] ~ [ linux-6.3.13 ] ~ [ linux-6.2.16 ] ~ [ linux-6.1.116 ] ~ [ linux-6.0.19 ] ~ [ linux-5.19.17 ] ~ [ linux-5.18.19 ] ~ [ linux-5.17.15 ] ~ [ linux-5.16.20 ] ~ [ linux-5.15.171 ] ~ [ linux-5.14.21 ] ~ [ linux-5.13.19 ] ~ [ linux-5.12.19 ] ~ [ linux-5.11.22 ] ~ [ linux-5.10.229 ] ~ [ linux-5.9.16 ] ~ [ linux-5.8.18 ] ~ [ linux-5.7.19 ] ~ [ linux-5.6.19 ] ~ [ linux-5.5.19 ] ~ [ linux-5.4.285 ] ~ [ linux-5.3.18 ] ~ [ linux-5.2.21 ] ~ [ linux-5.1.21 ] ~ [ linux-5.0.21 ] ~ [ linux-4.20.17 ] ~ [ linux-4.19.323 ] ~ [ linux-4.18.20 ] ~ [ linux-4.17.19 ] ~ [ linux-4.16.18 ] ~ [ linux-4.15.18 ] ~ [ linux-4.14.336 ] ~ [ linux-4.13.16 ] ~ [ linux-4.12.14 ] ~ [ linux-4.11.12 ] ~ [ linux-4.10.17 ] ~ [ linux-4.9.337 ] ~ [ linux-4.4.302 ] ~ [ linux-3.10.108 ] ~ [ linux-2.6.32.71 ] ~ [ linux-2.6.0 ] ~ [ linux-2.4.37.11 ] ~ [ unix-v6-master ] ~ [ ccs-tools-1.8.12 ] ~ [ policy-sample ] ~
Architecture: ~ [ i386 ] ~ [ alpha ] ~ [ m68k ] ~ [ mips ] ~ [ ppc ] ~ [ sparc ] ~ [ sparc64 ] ~

  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
  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 allOf:
292   - $ref: pinctrl.yaml#
293 
294 examples:
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 ...

~ [ source navigation ] ~ [ diff markup ] ~ [ identifier search ] ~

kernel.org | git.kernel.org | LWN.net | Project Home | SVN repository | Mail admin

Linux® is a registered trademark of Linus Torvalds in the United States and other countries.
TOMOYO® is a registered trademark of NTT DATA CORPORATION.

sflogo.php