xref: /linux/Documentation/devicetree/bindings/pinctrl/rockchip,pinctrl.yaml (revision c94cd9508b1335b949fd13ebd269313c65492df0)
1# SPDX-License-Identifier: GPL-2.0
2%YAML 1.2
3---
4$id: http://devicetree.org/schemas/pinctrl/rockchip,pinctrl.yaml#
5$schema: http://devicetree.org/meta-schemas/core.yaml#
6
7title: Rockchip Pinmux Controller
8
9maintainers:
10  - Heiko Stuebner <heiko@sntech.de>
11
12description: |
13  The Rockchip Pinmux Controller enables the IC to share one PAD
14  to several functional blocks. The sharing is done by multiplexing
15  the PAD input/output signals. For each PAD there are several muxing
16  options with option 0 being used as a GPIO.
17
18  Please refer to pinctrl-bindings.txt in this directory for details of the
19  common pinctrl bindings used by client devices, including the meaning of the
20  phrase "pin configuration node".
21
22  The Rockchip pin configuration node is a node of a group of pins which can be
23  used for a specific device or function. This node represents both mux and
24  config of the pins in that group. The 'pins' selects the function mode
25  (also named pin mode) this pin can work on and the 'config' configures
26  various pad settings such as pull-up, etc.
27
28  The pins are grouped into up to 9 individual pin banks which need to be
29  defined as gpio sub-nodes of the pinmux controller.
30
31properties:
32  compatible:
33    enum:
34      - rockchip,px30-pinctrl
35      - rockchip,rk2928-pinctrl
36      - rockchip,rk3036-pinctrl
37      - rockchip,rk3066a-pinctrl
38      - rockchip,rk3066b-pinctrl
39      - rockchip,rk3128-pinctrl
40      - rockchip,rk3188-pinctrl
41      - rockchip,rk3228-pinctrl
42      - rockchip,rk3288-pinctrl
43      - rockchip,rk3308-pinctrl
44      - rockchip,rk3328-pinctrl
45      - rockchip,rk3368-pinctrl
46      - rockchip,rk3399-pinctrl
47      - rockchip,rk3568-pinctrl
48      - rockchip,rk3576-pinctrl
49      - rockchip,rk3588-pinctrl
50      - rockchip,rv1108-pinctrl
51      - rockchip,rv1126-pinctrl
52
53  rockchip,grf:
54    $ref: /schemas/types.yaml#/definitions/phandle
55    description:
56      The phandle of the syscon node for the GRF registers.
57
58  rockchip,pmu:
59    $ref: /schemas/types.yaml#/definitions/phandle
60    description:
61      The phandle of the syscon node for the PMU registers,
62      as some SoCs carry parts of the iomux controller registers there.
63      Required for at least rk3188 and rk3288. On the rk3368 this should
64      point to the PMUGRF syscon.
65
66  "#address-cells":
67    enum: [1, 2]
68
69  "#size-cells":
70    enum: [1, 2]
71
72  ranges: true
73
74allOf:
75  - $ref: pinctrl.yaml#
76
77required:
78  - compatible
79  - rockchip,grf
80
81patternProperties:
82  "gpio@[0-9a-f]+$":
83    type: object
84
85    $ref: /schemas/gpio/rockchip,gpio-bank.yaml#
86    deprecated: true
87
88    unevaluatedProperties: false
89
90  "pcfg-[a-z0-9-]+$":
91    type: object
92    properties:
93      bias-disable: true
94
95      bias-pull-down: true
96
97      bias-pull-pin-default: true
98
99      bias-pull-up: true
100
101      drive-strength:
102        minimum: 0
103        maximum: 20
104
105      input-enable: true
106
107      input-schmitt-enable: true
108
109      output-high: true
110
111      output-low: true
112
113    additionalProperties: false
114
115additionalProperties:
116  type: object
117  additionalProperties:
118    type: object
119    additionalProperties: false
120
121    properties:
122      rockchip,pins:
123        $ref: /schemas/types.yaml#/definitions/uint32-matrix
124        minItems: 1
125        items:
126          items:
127            - minimum: 0
128              maximum: 8
129              description:
130                Pin bank.
131            - minimum: 0
132              maximum: 31
133              description:
134                Pin bank index.
135            - minimum: 0
136              maximum: 13
137              description:
138                Mux 0 means GPIO and mux 1 to N means
139                the specific device function.
140            - description:
141                The phandle of a node contains the generic pinconfig options
142                to use as described in pinctrl-bindings.txt.
143
144examples:
145  - |
146    #include <dt-bindings/interrupt-controller/arm-gic.h>
147    #include <dt-bindings/pinctrl/rockchip.h>
148
149    pinctrl: pinctrl {
150      compatible = "rockchip,rk3066a-pinctrl";
151      rockchip,grf = <&grf>;
152
153      #address-cells = <1>;
154      #size-cells = <1>;
155      ranges;
156
157      gpio0: gpio@20034000 {
158        compatible = "rockchip,gpio-bank";
159        reg = <0x20034000 0x100>;
160        interrupts = <GIC_SPI 54 IRQ_TYPE_LEVEL_HIGH>;
161        clocks = <&clk_gates8 9>;
162
163        gpio-controller;
164        #gpio-cells = <2>;
165
166        interrupt-controller;
167        #interrupt-cells = <2>;
168      };
169
170      pcfg_pull_default: pcfg-pull-default {
171        bias-pull-pin-default;
172      };
173
174      uart2 {
175        uart2_xfer: uart2-xfer {
176          rockchip,pins = <1 RK_PB0 1 &pcfg_pull_default>,
177                          <1 RK_PB1 1 &pcfg_pull_default>;
178        };
179      };
180    };
181
182    uart2: serial@20064000 {
183      compatible = "snps,dw-apb-uart";
184      reg = <0x20064000 0x400>;
185      interrupts = <GIC_SPI 36 IRQ_TYPE_LEVEL_HIGH>;
186      clocks = <&mux_uart2>;
187      pinctrl-0 = <&uart2_xfer>;
188      pinctrl-names = "default";
189      reg-io-width = <1>;
190      reg-shift = <2>;
191    };
192