Merge tag 'gpio-v4.20-1' of git://git.kernel.org/pub/scm/linux/kernel/git/linusw...
[sfrench/cifs-2.6.git] / Documentation / devicetree / bindings / pinctrl / renesas,rzn1-pinctrl.txt
1 Renesas RZ/N1 SoC Pinctrl node description.
2
3 Pin controller node
4 -------------------
5 Required properties:
6 - compatible: SoC-specific compatible string "renesas,<soc-specific>-pinctrl"
7   followed by "renesas,rzn1-pinctrl" as fallback. The SoC-specific compatible
8   strings must be one of:
9         "renesas,r9a06g032-pinctrl" for RZ/N1D
10         "renesas,r9a06g033-pinctrl" for RZ/N1S
11 - reg: Address base and length of the memory area where the pin controller
12   hardware is mapped to.
13 - clocks: phandle for the clock, see the description of clock-names below.
14 - clock-names: Contains the name of the clock:
15     "bus", the bus clock, sometimes described as pclk, for register accesses.
16
17 Example:
18         pinctrl: pin-controller@40067000 {
19             compatible = "renesas,r9a06g032-pinctrl", "renesas,rzn1-pinctrl";
20             reg = <0x40067000 0x1000>, <0x51000000 0x480>;
21             clocks = <&sysctrl R9A06G032_HCLK_PINCONFIG>;
22             clock-names = "bus";
23         };
24
25 Sub-nodes
26 ---------
27
28 The child nodes of the pin controller node describe a pin multiplexing
29 function.
30
31 - Pin multiplexing sub-nodes:
32   A pin multiplexing sub-node describes how to configure a set of
33   (or a single) pin in some desired alternate function mode.
34   A single sub-node may define several pin configurations.
35   Please refer to pinctrl-bindings.txt to get to know more on generic
36   pin properties usage.
37
38   The allowed generic formats for a pin multiplexing sub-node are the
39   following ones:
40
41   node-1 {
42       pinmux = <PIN_ID_AND_MUX>, <PIN_ID_AND_MUX>, ... ;
43       GENERIC_PINCONFIG;
44   };
45
46   node-2 {
47       sub-node-1 {
48           pinmux = <PIN_ID_AND_MUX>, <PIN_ID_AND_MUX>, ... ;
49           GENERIC_PINCONFIG;
50       };
51
52       sub-node-2 {
53           pinmux = <PIN_ID_AND_MUX>, <PIN_ID_AND_MUX>, ... ;
54           GENERIC_PINCONFIG;
55       };
56
57       ...
58
59       sub-node-n {
60           pinmux = <PIN_ID_AND_MUX>, <PIN_ID_AND_MUX>, ... ;
61           GENERIC_PINCONFIG;
62       };
63   };
64
65   node-3 {
66       pinmux = <PIN_ID_AND_MUX>, <PIN_ID_AND_MUX>, ... ;
67       GENERIC_PINCONFIG;
68
69       sub-node-1 {
70           pinmux = <PIN_ID_AND_MUX>, <PIN_ID_AND_MUX>, ... ;
71           GENERIC_PINCONFIG;
72       };
73
74       ...
75
76       sub-node-n {
77           pinmux = <PIN_ID_AND_MUX>, <PIN_ID_AND_MUX>, ... ;
78           GENERIC_PINCONFIG;
79       };
80   };
81
82   Use the latter two formats when pins part of the same logical group need to
83   have different generic pin configuration flags applied. Note that the generic
84   pinconfig in node-3 does not apply to the sub-nodes.
85
86   Client sub-nodes shall refer to pin multiplexing sub-nodes using the phandle
87   of the most external one.
88
89   Eg.
90
91   client-1 {
92       ...
93       pinctrl-0 = <&node-1>;
94       ...
95   };
96
97   client-2 {
98       ...
99       pinctrl-0 = <&node-2>;
100       ...
101   };
102
103   Required properties:
104     - pinmux:
105       integer array representing pin number and pin multiplexing configuration.
106       When a pin has to be configured in alternate function mode, use this
107       property to identify the pin by its global index, and provide its
108       alternate function configuration number along with it.
109       When multiple pins are required to be configured as part of the same
110       alternate function they shall be specified as members of the same
111       argument list of a single "pinmux" property.
112       Integers values in the "pinmux" argument list are assembled as:
113       (PIN | MUX_FUNC << 8)
114       where PIN directly corresponds to the pl_gpio pin number and MUX_FUNC is
115       one of the alternate function identifiers defined in:
116       <include/dt-bindings/pinctrl/rzn1-pinctrl.h>
117       These identifiers collapse the IO Multiplex Configuration Level 1 and
118       Level 2 numbers that are detailed in the hardware reference manual into a
119       single number. The identifiers for Level 2 are simply offset by 10.
120       Additional identifiers are provided to specify the MDIO source peripheral.
121
122   Optional generic pinconf properties:
123     - bias-disable              - disable any pin bias
124     - bias-pull-up              - pull up the pin with 50 KOhm
125     - bias-pull-down            - pull down the pin with 50 KOhm
126     - bias-high-impedance       - high impedance mode
127     - drive-strength            - sink or source at most 4, 6, 8 or 12 mA
128
129   Example:
130   A serial communication interface with a TX output pin and an RX input pin.
131
132   &pinctrl {
133         pins_uart0: pins_uart0 {
134                 pinmux = <
135                         RZN1_PINMUX(103, RZN1_FUNC_UART0_I)     /* UART0_TXD */
136                         RZN1_PINMUX(104, RZN1_FUNC_UART0_I)     /* UART0_RXD */
137                 >;
138         };
139   };
140
141   Example 2:
142   Here we set the pull up on the RXD pin of the UART.
143
144   &pinctrl {
145         pins_uart0: pins_uart0 {
146                 pinmux = <RZN1_PINMUX(103, RZN1_FUNC_UART0_I)>; /* TXD */
147
148                 pins_uart6_rx {
149                         pinmux = <RZN1_PINMUX(104, RZN1_FUNC_UART0_I)>; /* RXD */
150                         bias-pull-up;
151                 };
152         };
153   };