blob: 005d95a9e4d6a01990c2b94a0f9dd149169d0703 [file] [log] [blame]
Tom Rini53633a82024-02-29 12:33:36 -05001# SPDX-License-Identifier: (GPL-2.0 OR BSD-2-Clause)
2%YAML 1.2
3---
4$id: http://devicetree.org/schemas/pinctrl/intel,pinctrl-keembay.yaml#
5$schema: http://devicetree.org/meta-schemas/core.yaml#
6
7title: Intel Keem Bay pin controller
8
9maintainers:
10 - Lakshmi Sowjanya D <lakshmi.sowjanya.d@intel.com>
11
12description: |
13 Intel Keem Bay SoC integrates a pin controller which enables control
14 of pin directions, input/output values and configuration
15 for a total of 80 pins.
16
17properties:
18 compatible:
19 const: intel,keembay-pinctrl
20
21 reg:
22 maxItems: 2
23
24 gpio-controller: true
25
26 '#gpio-cells':
27 const: 2
28
29 ngpios:
30 description: The number of GPIOs exposed.
31 const: 80
32
33 interrupts:
34 description:
35 Specifies the interrupt lines to be used by the controller.
36 Each interrupt line is shared by upto 4 GPIO lines.
37 maxItems: 8
38
39 interrupt-controller: true
40
41 '#interrupt-cells':
42 const: 2
43
44patternProperties:
45 '^gpio@[0-9a-f]*$':
46 type: object
47 additionalProperties: false
48
49 description:
50 Child nodes can be specified to contain pin configuration information,
51 which can then be utilized by pinctrl client devices.
52 The following properties are supported.
53
54 properties:
55 pins:
56 description: |
57 The name(s) of the pins to be configured in the child node.
58 Supported pin names are "GPIO0" up to "GPIO79".
59
60 bias-disable: true
61
62 bias-pull-down: true
63
64 bias-pull-up: true
65
66 drive-strength:
67 description: IO pads drive strength in milli Ampere.
68 enum: [2, 4, 8, 12]
69
70 bias-bus-hold:
71 type: boolean
72
73 input-schmitt-enable:
74 type: boolean
75
76 slew-rate:
77 description: GPIO slew rate control.
78 0 - Fast(~100MHz)
79 1 - Slow(~50MHz)
80 enum: [0, 1]
81
82additionalProperties: false
83
84required:
85 - compatible
86 - reg
87 - gpio-controller
88 - ngpios
89 - '#gpio-cells'
90 - interrupts
91 - interrupt-controller
92 - '#interrupt-cells'
93
94examples:
95 - |
96 #include <dt-bindings/interrupt-controller/arm-gic.h>
97 #include <dt-bindings/interrupt-controller/irq.h>
98 // Example 1
99 gpio@0 {
100 compatible = "intel,keembay-pinctrl";
101 reg = <0x600b0000 0x88>,
102 <0x600b0190 0x1ac>;
103 gpio-controller;
104 ngpios = <0x50>;
105 #gpio-cells = <0x2>;
106 interrupts = <GIC_SPI 94 IRQ_TYPE_LEVEL_HIGH>,
107 <GIC_SPI 95 IRQ_TYPE_LEVEL_HIGH>,
108 <GIC_SPI 96 IRQ_TYPE_LEVEL_HIGH>,
109 <GIC_SPI 97 IRQ_TYPE_LEVEL_HIGH>,
110 <GIC_SPI 98 IRQ_TYPE_LEVEL_HIGH>,
111 <GIC_SPI 99 IRQ_TYPE_LEVEL_HIGH>,
112 <GIC_SPI 100 IRQ_TYPE_LEVEL_HIGH>,
113 <GIC_SPI 101 IRQ_TYPE_LEVEL_HIGH>;
114 interrupt-controller;
115 #interrupt-cells = <2>;
116 };
117
118 // Example 2
119 gpio@1 {
120 compatible = "intel,keembay-pinctrl";
121 reg = <0x600c0000 0x88>,
122 <0x600c0190 0x1ac>;
123 gpio-controller;
124 ngpios = <0x50>;
125 #gpio-cells = <0x2>;
126 interrupts = <GIC_SPI 94 IRQ_TYPE_LEVEL_HIGH>,
127 <GIC_SPI 95 IRQ_TYPE_LEVEL_HIGH>,
128 <GIC_SPI 96 IRQ_TYPE_LEVEL_HIGH>,
129 <GIC_SPI 97 IRQ_TYPE_LEVEL_HIGH>,
130 <GIC_SPI 98 IRQ_TYPE_LEVEL_HIGH>,
131 <GIC_SPI 99 IRQ_TYPE_LEVEL_HIGH>,
132 <GIC_SPI 100 IRQ_TYPE_LEVEL_HIGH>,
133 <GIC_SPI 101 IRQ_TYPE_LEVEL_HIGH>;
134 interrupt-controller;
135 #interrupt-cells = <2>;
136 };