Stephen Warren | 7a86527 | 2012-04-04 09:27:47 -0600 | [diff] [blame] | 1 | == Introduction == |
| 2 | |
| 3 | Hardware modules that control pin multiplexing or configuration parameters |
| 4 | such as pull-up/down, tri-state, drive-strength etc are designated as pin |
| 5 | controllers. Each pin controller must be represented as a node in device tree, |
| 6 | just like any other hardware module. |
| 7 | |
| 8 | Hardware modules whose signals are affected by pin configuration are |
| 9 | designated client devices. Again, each client device must be represented as a |
| 10 | node in device tree, just like any other hardware module. |
| 11 | |
| 12 | For a client device to operate correctly, certain pin controllers must |
| 13 | set up certain specific pin configurations. Some client devices need a |
| 14 | single static pin configuration, e.g. set up during initialization. Others |
| 15 | need to reconfigure pins at run-time, for example to tri-state pins when the |
| 16 | device is inactive. Hence, each client device can define a set of named |
| 17 | states. The number and names of those states is defined by the client device's |
| 18 | own binding. |
| 19 | |
| 20 | The common pinctrl bindings defined in this file provide an infrastructure |
| 21 | for client device device tree nodes to map those state names to the pin |
| 22 | configuration used by those states. |
| 23 | |
| 24 | Note that pin controllers themselves may also be client devices of themselves. |
| 25 | For example, a pin controller may set up its own "active" state when the |
| 26 | driver loads. This would allow representing a board's static pin configuration |
| 27 | in a single place, rather than splitting it across multiple client device |
| 28 | nodes. The decision to do this or not somewhat rests with the author of |
| 29 | individual board device tree files, and any requirements imposed by the |
| 30 | bindings for the individual client devices in use by that board, i.e. whether |
| 31 | they require certain specific named states for dynamic pin configuration. |
| 32 | |
| 33 | == Pinctrl client devices == |
| 34 | |
| 35 | For each client device individually, every pin state is assigned an integer |
| 36 | ID. These numbers start at 0, and are contiguous. For each state ID, a unique |
| 37 | property exists to define the pin configuration. Each state may also be |
| 38 | assigned a name. When names are used, another property exists to map from |
| 39 | those names to the integer IDs. |
| 40 | |
Baruch Siach | f5efed8 | 2015-03-09 21:56:39 +0200 | [diff] [blame] | 41 | Each client device's own binding determines the set of states that must be |
Stephen Warren | 7a86527 | 2012-04-04 09:27:47 -0600 | [diff] [blame] | 42 | defined in its device tree node, and whether to define the set of state |
| 43 | IDs that must be provided, or whether to define the set of state names that |
| 44 | must be provided. |
| 45 | |
| 46 | Required properties: |
| 47 | pinctrl-0: List of phandles, each pointing at a pin configuration |
| 48 | node. These referenced pin configuration nodes must be child |
| 49 | nodes of the pin controller that they configure. Multiple |
| 50 | entries may exist in this list so that multiple pin |
| 51 | controllers may be configured, or so that a state may be built |
| 52 | from multiple nodes for a single pin controller, each |
| 53 | contributing part of the overall configuration. See the next |
| 54 | section of this document for details of the format of these |
| 55 | pin configuration nodes. |
| 56 | |
| 57 | In some cases, it may be useful to define a state, but for it |
| 58 | to be empty. This may be required when a common IP block is |
| 59 | used in an SoC either without a pin controller, or where the |
| 60 | pin controller does not affect the HW module in question. If |
| 61 | the binding for that IP block requires certain pin states to |
| 62 | exist, they must still be defined, but may be left empty. |
| 63 | |
| 64 | Optional properties: |
| 65 | pinctrl-1: List of phandles, each pointing at a pin configuration |
| 66 | node within a pin controller. |
| 67 | ... |
| 68 | pinctrl-n: List of phandles, each pointing at a pin configuration |
| 69 | node within a pin controller. |
| 70 | pinctrl-names: The list of names to assign states. List entry 0 defines the |
| 71 | name for integer state ID 0, list entry 1 for state ID 1, and |
| 72 | so on. |
| 73 | |
| 74 | For example: |
| 75 | |
| 76 | /* For a client device requiring named states */ |
| 77 | device { |
| 78 | pinctrl-names = "active", "idle"; |
| 79 | pinctrl-0 = <&state_0_node_a>; |
| 80 | pinctrl-1 = <&state_1_node_a &state_1_node_b>; |
| 81 | }; |
| 82 | |
| 83 | /* For the same device if using state IDs */ |
| 84 | device { |
| 85 | pinctrl-0 = <&state_0_node_a>; |
| 86 | pinctrl-1 = <&state_1_node_a &state_1_node_b>; |
| 87 | }; |
| 88 | |
| 89 | /* |
| 90 | * For an IP block whose binding supports pin configuration, |
| 91 | * but in use on an SoC that doesn't have any pin control hardware |
| 92 | */ |
| 93 | device { |
| 94 | pinctrl-names = "active", "idle"; |
| 95 | pinctrl-0 = <>; |
| 96 | pinctrl-1 = <>; |
| 97 | }; |
| 98 | |
| 99 | == Pin controller devices == |
Tony Lindgren | 42124bc | 2016-11-03 09:35:47 -0700 | [diff] [blame] | 100 | Required properties: See the pin controller driver specific documentation |
| 101 | |
| 102 | Optional properties: |
| 103 | #pinctrl-cells: Number of pin control cells in addition to the index within the |
| 104 | pin controller device instance |
Stephen Warren | 7a86527 | 2012-04-04 09:27:47 -0600 | [diff] [blame] | 105 | |
| 106 | Pin controller devices should contain the pin configuration nodes that client |
| 107 | devices reference. |
| 108 | |
| 109 | For example: |
| 110 | |
| 111 | pincontroller { |
| 112 | ... /* Standard DT properties for the device itself elided */ |
| 113 | |
| 114 | state_0_node_a { |
| 115 | ... |
| 116 | }; |
| 117 | state_1_node_a { |
| 118 | ... |
| 119 | }; |
| 120 | state_1_node_b { |
| 121 | ... |
| 122 | }; |
| 123 | } |
| 124 | |
| 125 | The contents of each of those pin configuration child nodes is defined |
| 126 | entirely by the binding for the individual pin controller device. There |
Tony Lindgren | 42124bc | 2016-11-03 09:35:47 -0700 | [diff] [blame] | 127 | exists no common standard for this content. The pinctrl framework only |
| 128 | provides generic helper bindings that the pin controller driver can use. |
Stephen Warren | 7a86527 | 2012-04-04 09:27:47 -0600 | [diff] [blame] | 129 | |
| 130 | The pin configuration nodes need not be direct children of the pin controller |
| 131 | device; they may be grandchildren, for example. Whether this is legal, and |
| 132 | whether there is any interaction between the child and intermediate parent |
| 133 | nodes, is again defined entirely by the binding for the individual pin |
| 134 | controller device. |
Heiko Stübner | 7db9af4 | 2013-06-10 21:40:29 +0200 | [diff] [blame] | 135 | |
Linus Walleij | 90d0993 | 2014-09-29 17:13:40 +0200 | [diff] [blame] | 136 | == Generic pin multiplexing node content == |
| 137 | |
| 138 | pin multiplexing nodes: |
| 139 | |
| 140 | function - the mux function to select |
| 141 | groups - the list of groups to select with this function |
Andrew Bresticker | cec6565 | 2015-03-30 16:16:54 -0700 | [diff] [blame] | 142 | (either this or "pins" must be specified) |
| 143 | pins - the list of pins to select with this function (either |
| 144 | this or "groups" must be specified) |
Linus Walleij | 90d0993 | 2014-09-29 17:13:40 +0200 | [diff] [blame] | 145 | |
| 146 | Example: |
| 147 | |
| 148 | state_0_node_a { |
Baruch Siach | 5757bfe | 2015-03-15 08:55:15 +0200 | [diff] [blame] | 149 | uart0 { |
| 150 | function = "uart0"; |
| 151 | groups = "u0rxtx", "u0rtscts"; |
| 152 | }; |
Linus Walleij | 90d0993 | 2014-09-29 17:13:40 +0200 | [diff] [blame] | 153 | }; |
| 154 | state_1_node_a { |
Baruch Siach | 5757bfe | 2015-03-15 08:55:15 +0200 | [diff] [blame] | 155 | spi0 { |
| 156 | function = "spi0"; |
| 157 | groups = "spi0pins"; |
| 158 | }; |
Linus Walleij | 90d0993 | 2014-09-29 17:13:40 +0200 | [diff] [blame] | 159 | }; |
Andrew Bresticker | cec6565 | 2015-03-30 16:16:54 -0700 | [diff] [blame] | 160 | state_2_node_a { |
| 161 | function = "i2c0"; |
| 162 | pins = "mfio29", "mfio30"; |
| 163 | }; |
Linus Walleij | 90d0993 | 2014-09-29 17:13:40 +0200 | [diff] [blame] | 164 | |
Jacopo Mondi | 8d5e7c5 | 2017-04-06 12:35:55 +0200 | [diff] [blame] | 165 | Optionally an alternative binding can be used if more suitable depending on the |
| 166 | pin controller hardware. For hardware where there is a large number of identical |
Tony Lindgren | 42124bc | 2016-11-03 09:35:47 -0700 | [diff] [blame] | 167 | pin controller instances, naming each pin and function can easily become |
| 168 | unmaintainable. This is especially the case if the same controller is used for |
| 169 | different pins and functions depending on the SoC revision and packaging. |
| 170 | |
| 171 | For cases like this, the pin controller driver may use pinctrl-pin-array helper |
| 172 | binding with a hardware based index and a number of pin configuration values: |
| 173 | |
| 174 | pincontroller { |
| 175 | ... /* Standard DT properties for the device itself elided */ |
| 176 | #pinctrl-cells = <2>; |
| 177 | |
| 178 | state_0_node_a { |
| 179 | pinctrl-pin-array = < |
| 180 | 0 A_DELAY_PS(0) G_DELAY_PS(120) |
| 181 | 4 A_DELAY_PS(0) G_DELAY_PS(360) |
| 182 | ... |
| 183 | >; |
| 184 | }; |
| 185 | ... |
| 186 | }; |
| 187 | |
| 188 | Above #pinctrl-cells specifies the number of value cells in addition to the |
| 189 | index of the registers. This is similar to the interrupts-extended binding with |
| 190 | one exception. There is no need to specify the phandle for each entry as that |
| 191 | is already known as the defined pins are always children of the pin controller |
| 192 | node. Further having the phandle pointing to another pin controller would not |
| 193 | currently work as the pinctrl framework uses named modes to group pins for each |
| 194 | pin control device. |
| 195 | |
| 196 | The index for pinctrl-pin-array must relate to the hardware for the pinctrl |
| 197 | registers, and must not be a virtual index of pin instances. The reason for |
| 198 | this is to avoid mapping of the index in the dts files and the pin controller |
| 199 | driver as it can change. |
| 200 | |
Jacopo Mondi | 8d5e7c5 | 2017-04-06 12:35:55 +0200 | [diff] [blame] | 201 | For hardware where pin multiplexing configurations have to be specified for |
| 202 | each single pin the number of required sub-nodes containing "pin" and |
| 203 | "function" properties can quickly escalate and become hard to write and |
| 204 | maintain. |
| 205 | |
| 206 | For cases like this, the pin controller driver may use the pinmux helper |
| 207 | property, where the pin identifier is packed with mux configuration settings |
| 208 | in a single integer. |
| 209 | |
| 210 | The pinmux property accepts an array of integers, each of them describing |
| 211 | a single pin multiplexing configuration. |
| 212 | |
| 213 | pincontroller { |
| 214 | state_0_node_a { |
| 215 | pinmux = <PIN_ID_AND_MUX>, <PIN_ID_AND_MUX>, ...; |
| 216 | }; |
| 217 | }; |
| 218 | |
| 219 | Each individual pin controller driver bindings documentation shall specify |
| 220 | how those values (pin IDs and pin multiplexing configuration) are defined and |
| 221 | assembled together. |
| 222 | |
Stephen Warren | bcd0c8c | 2013-08-05 15:55:59 -0600 | [diff] [blame] | 223 | == Generic pin configuration node content == |
Heiko Stübner | 7db9af4 | 2013-06-10 21:40:29 +0200 | [diff] [blame] | 224 | |
Stephen Warren | bcd0c8c | 2013-08-05 15:55:59 -0600 | [diff] [blame] | 225 | Many data items that are represented in a pin configuration node are common |
| 226 | and generic. Pin control bindings should use the properties defined below |
| 227 | where they are applicable; not all of these properties are relevant or useful |
| 228 | for all hardware or binding structures. Each individual binding document |
| 229 | should state which of these generic properties, if any, are used, and the |
| 230 | structure of the DT nodes that contain these properties. |
Heiko Stübner | 7db9af4 | 2013-06-10 21:40:29 +0200 | [diff] [blame] | 231 | |
Stephen Warren | bcd0c8c | 2013-08-05 15:55:59 -0600 | [diff] [blame] | 232 | Supported generic properties are: |
Heiko Stübner | 7db9af4 | 2013-06-10 21:40:29 +0200 | [diff] [blame] | 233 | |
Stephen Warren | 87311d0 | 2013-08-06 11:10:32 -0600 | [diff] [blame] | 234 | pins - the list of pins that properties in the node |
Jacopo Mondi | 8d5e7c5 | 2017-04-06 12:35:55 +0200 | [diff] [blame] | 235 | apply to (either this, "group" or "pinmux" has to be |
Linus Walleij | 2cdef8f | 2014-10-02 09:41:46 +0200 | [diff] [blame] | 236 | specified) |
| 237 | group - the group to apply the properties to, if the driver |
| 238 | supports configuration of whole groups rather than |
Jacopo Mondi | 8d5e7c5 | 2017-04-06 12:35:55 +0200 | [diff] [blame] | 239 | individual pins (either this, "pins" or "pinmux" has |
| 240 | to be specified) |
| 241 | pinmux - the list of numeric pin ids and their mux settings |
| 242 | that properties in the node apply to (either this, |
| 243 | "pins" or "groups" have to be specified) |
Heiko Stübner | 7db9af4 | 2013-06-10 21:40:29 +0200 | [diff] [blame] | 244 | bias-disable - disable any pin bias |
| 245 | bias-high-impedance - high impedance mode ("third-state", "floating") |
| 246 | bias-bus-hold - latch weakly |
| 247 | bias-pull-up - pull up the pin |
| 248 | bias-pull-down - pull down the pin |
| 249 | bias-pull-pin-default - use pin-default pull state |
| 250 | drive-push-pull - drive actively high and low |
| 251 | drive-open-drain - drive with open drain |
| 252 | drive-open-source - drive with open source |
| 253 | drive-strength - sink or source at most X mA |
Sherman Yin | 8ba3f4d | 2013-12-11 10:37:17 -0800 | [diff] [blame] | 254 | input-enable - enable input on pin (no effect on output) |
| 255 | input-disable - disable input on pin (no effect on output) |
Heiko Stübner | 7db9af4 | 2013-06-10 21:40:29 +0200 | [diff] [blame] | 256 | input-schmitt-enable - enable schmitt-trigger mode |
| 257 | input-schmitt-disable - disable schmitt-trigger mode |
Heiko Stübner | 7db9af4 | 2013-06-10 21:40:29 +0200 | [diff] [blame] | 258 | input-debounce - debounce mode with debound time X |
Ivan T. Ivanov | ca6c551 | 2014-05-27 09:27:36 +0300 | [diff] [blame] | 259 | power-source - select between different power supplies |
Heiko Stübner | 9ee1f7d | 2013-06-14 17:42:49 +0200 | [diff] [blame] | 260 | low-power-enable - enable low power mode |
| 261 | low-power-disable - disable low power mode |
Heiko Stübner | 7db9af4 | 2013-06-10 21:40:29 +0200 | [diff] [blame] | 262 | output-low - set the pin to output mode with low level |
| 263 | output-high - set the pin to output mode with high level |
Sherman Yin | 8ba3f4d | 2013-12-11 10:37:17 -0800 | [diff] [blame] | 264 | slew-rate - set the slew rate |
Heiko Stübner | 7db9af4 | 2013-06-10 21:40:29 +0200 | [diff] [blame] | 265 | |
Linus Walleij | 90d0993 | 2014-09-29 17:13:40 +0200 | [diff] [blame] | 266 | For example: |
| 267 | |
| 268 | state_0_node_a { |
Baruch Siach | 5757bfe | 2015-03-15 08:55:15 +0200 | [diff] [blame] | 269 | cts_rxd { |
| 270 | pins = "GPIO0_AJ5", "GPIO2_AH4"; /* CTS+RXD */ |
| 271 | bias-pull-up; |
| 272 | }; |
Linus Walleij | 90d0993 | 2014-09-29 17:13:40 +0200 | [diff] [blame] | 273 | }; |
| 274 | state_1_node_a { |
Baruch Siach | 5757bfe | 2015-03-15 08:55:15 +0200 | [diff] [blame] | 275 | rts_txd { |
| 276 | pins = "GPIO1_AJ3", "GPIO3_AH3"; /* RTS+TXD */ |
| 277 | output-high; |
| 278 | }; |
Linus Walleij | 90d0993 | 2014-09-29 17:13:40 +0200 | [diff] [blame] | 279 | }; |
Linus Walleij | 2cdef8f | 2014-10-02 09:41:46 +0200 | [diff] [blame] | 280 | state_2_node_a { |
Baruch Siach | 5757bfe | 2015-03-15 08:55:15 +0200 | [diff] [blame] | 281 | foo { |
| 282 | group = "foo-group"; |
| 283 | bias-pull-up; |
| 284 | }; |
Linus Walleij | 2cdef8f | 2014-10-02 09:41:46 +0200 | [diff] [blame] | 285 | }; |
Jacopo Mondi | 8d5e7c5 | 2017-04-06 12:35:55 +0200 | [diff] [blame] | 286 | state_3_node_a { |
| 287 | mux { |
| 288 | pinmux = <GPIOx_PINm_MUXn>, <GPIOx_PINj_MUXk)>; |
| 289 | input-enable; |
| 290 | }; |
| 291 | }; |
Linus Walleij | 90d0993 | 2014-09-29 17:13:40 +0200 | [diff] [blame] | 292 | |
Stephen Warren | bcd0c8c | 2013-08-05 15:55:59 -0600 | [diff] [blame] | 293 | Some of the generic properties take arguments. For those that do, the |
| 294 | arguments are described below. |
Heiko Stübner | 9ee1f7d | 2013-06-14 17:42:49 +0200 | [diff] [blame] | 295 | |
Stephen Warren | 87311d0 | 2013-08-06 11:10:32 -0600 | [diff] [blame] | 296 | - pins takes a list of pin names or IDs as a required argument. The specific |
| 297 | binding for the hardware defines: |
| 298 | - Whether the entries are integers or strings, and their meaning. |
| 299 | |
Jacopo Mondi | 8d5e7c5 | 2017-04-06 12:35:55 +0200 | [diff] [blame] | 300 | - pinmux takes a list of pin IDs and mux settings as required argument. The |
| 301 | specific bindings for the hardware defines: |
| 302 | - How pin IDs and mux settings are defined and assembled together in a single |
| 303 | integer. |
| 304 | |
Heiko Stübner | 70637a6 | 2013-06-25 14:55:42 +0200 | [diff] [blame] | 305 | - bias-pull-up, -down and -pin-default take as optional argument on hardware |
| 306 | supporting it the pull strength in Ohm. bias-disable will disable the pull. |
Heiko Stübner | 9ee1f7d | 2013-06-14 17:42:49 +0200 | [diff] [blame] | 307 | |
| 308 | - drive-strength takes as argument the target strength in mA. |
| 309 | |
Heiko Stübner | 256aeb6 | 2013-06-25 14:56:11 +0200 | [diff] [blame] | 310 | - input-debounce takes the debounce time in usec as argument |
| 311 | or 0 to disable debouncing |
Heiko Stübner | 9ee1f7d | 2013-06-14 17:42:49 +0200 | [diff] [blame] | 312 | |
Heiko Stübner | 7db9af4 | 2013-06-10 21:40:29 +0200 | [diff] [blame] | 313 | More in-depth documentation on these parameters can be found in |
Yingjoe Chen | ee76a9a | 2014-11-03 10:28:11 +0800 | [diff] [blame] | 314 | <include/linux/pinctrl/pinconf-generic.h> |