xref: /linux/Documentation/devicetree/bindings/pinctrl/awinic,aw9523-pinctrl.yaml (revision eb01fe7abbe2d0b38824d2a93fdb4cc3eaf2ccc1)
1# SPDX-License-Identifier: (GPL-2.0-only OR BSD-2-Clause)
2%YAML 1.2
3---
4$id: http://devicetree.org/schemas/pinctrl/awinic,aw9523-pinctrl.yaml#
5$schema: http://devicetree.org/meta-schemas/core.yaml#
6
7title: Awinic AW9523/AW9523B I2C GPIO Expander
8
9maintainers:
10  - AngeloGioacchino Del Regno <angelogioacchino.delregno@somainline.org>
11
12description: |
13  The Awinic AW9523/AW9523B I2C GPIO Expander featuring 16 multi-function
14  I/O, 256 steps PWM mode and interrupt support.
15
16properties:
17  compatible:
18    const: awinic,aw9523-pinctrl
19
20  reg:
21    maxItems: 1
22
23  '#gpio-cells':
24    description: |
25      Specifying the pin number and flags, as defined in
26      include/dt-bindings/gpio/gpio.h
27    const: 2
28
29  gpio-controller: true
30
31  gpio-ranges:
32    maxItems: 1
33
34  interrupt-controller: true
35
36  interrupts:
37    maxItems: 1
38    description: Specifies the INTN pin IRQ.
39
40  '#interrupt-cells':
41    description:
42      Specifies the PIN numbers and Flags, as defined in defined in
43      include/dt-bindings/interrupt-controller/irq.h
44    const: 2
45
46  reset-gpios:
47    maxItems: 1
48
49# PIN CONFIGURATION NODES
50patternProperties:
51  '-pins$':
52    type: object
53    description:
54      Pinctrl node's client devices use subnodes for desired pin configuration.
55      Client device subnodes use below standard properties.
56    $ref: /schemas/pinctrl/pincfg-node.yaml
57
58    properties:
59      pins:
60        description:
61          List of gpio pins affected by the properties specified in
62          this subnode.
63        items:
64          pattern: "^gpio([0-9]|1[0-5])$"
65        minItems: 1
66        maxItems: 16
67
68      function:
69        description:
70          Specify the alternative function to be configured for the
71          specified pins.
72
73        enum: [ gpio, pwm ]
74
75      bias-disable: true
76      bias-pull-down: true
77      bias-pull-up: true
78      drive-open-drain: true
79      drive-push-pull: true
80      input-enable: true
81      input-disable: true
82      output-high: true
83      output-low: true
84
85    required:
86      - pins
87      - function
88
89    additionalProperties: false
90
91required:
92  - compatible
93  - reg
94  - gpio-controller
95  - '#gpio-cells'
96  - gpio-ranges
97
98additionalProperties: false
99
100examples:
101  # Example configuration to drive pins for a keyboard matrix
102  - |
103    #include <dt-bindings/gpio/gpio.h>
104    #include <dt-bindings/interrupt-controller/irq.h>
105
106    i2c {
107        #address-cells = <1>;
108        #size-cells = <0>;
109
110        aw9523: gpio-expander@58 {
111                compatible = "awinic,aw9523-pinctrl";
112                reg = <0x58>;
113                interrupt-parent = <&tlmm>;
114                interrupts = <50 IRQ_TYPE_EDGE_FALLING>;
115                gpio-controller;
116                #gpio-cells = <2>;
117                gpio-ranges = <&tlmm 0 0 16>;
118                interrupt-controller;
119                #interrupt-cells = <2>;
120                reset-gpios = <&tlmm 51 GPIO_ACTIVE_HIGH>;
121
122                keyboard-matrix-col-pins {
123                        pins = "gpio8", "gpio9", "gpio10", "gpio11",
124                               "gpio12", "gpio13", "gpio14", "gpio15";
125                        function = "gpio";
126                        input-disable;
127                        output-low;
128                };
129
130                keyboard-matrix-row-pins {
131                        pins = "gpio0", "gpio1", "gpio2", "gpio3",
132                               "gpio4", "gpio5", "gpio6", "gpio7";
133                        function = "gpio";
134                        bias-pull-up;
135                        drive-open-drain;
136                        input-enable;
137                };
138        };
139    };
140