1# SPDX-License-Identifier: (GPL-2.0-only OR BSD-2-Clause)
2%YAML 1.2
3---
4$id: http://devicetree.org/schemas/pinctrl/mediatek,mt7986-pinctrl.yaml#
5$schema: http://devicetree.org/meta-schemas/core.yaml#
6
7title: MediaTek MT7986 Pin Controller
8
9maintainers:
10  - Sean Wang <sean.wang@kernel.org>
11
12description:
13  The MediaTek's MT7986 Pin controller is used to control SoC pins.
14
15properties:
16  compatible:
17    enum:
18      - mediatek,mt7986a-pinctrl
19      - mediatek,mt7986b-pinctrl
20
21  reg:
22    minItems: 8
23    maxItems: 8
24
25  reg-names:
26    items:
27      - const: gpio
28      - const: iocfg_rt
29      - const: iocfg_rb
30      - const: iocfg_lt
31      - const: iocfg_lb
32      - const: iocfg_tr
33      - const: iocfg_tl
34      - const: eint
35
36  gpio-controller: true
37
38  "#gpio-cells":
39    const: 2
40    description:
41      Number of cells in GPIO specifier. Since the generic GPIO binding is used,
42      the amount of cells must be specified as 2. See the below mentioned gpio
43      binding representation for description of particular cells.
44
45  gpio-ranges:
46    minItems: 1
47    maxItems: 5
48    description:
49      GPIO valid number range.
50
51  interrupt-controller: true
52
53  interrupts:
54    maxItems: 1
55
56  "#interrupt-cells":
57    const: 2
58
59allOf:
60  - $ref: pinctrl.yaml#
61
62required:
63  - compatible
64  - reg
65  - reg-names
66  - gpio-controller
67  - "#gpio-cells"
68
69patternProperties:
70  '-pins$':
71    type: object
72    additionalProperties: false
73
74    patternProperties:
75      '^.*mux.*$':
76        type: object
77        additionalProperties: false
78        description: |
79          pinmux configuration nodes.
80
81          The following table shows the effective values of "group", "function"
82          properties and chip pinout pins
83
84          groups            function    pins (in pin#)
85          ---------------------------------------------------------------------
86          "watchdog"        "watchdog"  0
87          "wifi_led"        "led"       1, 2
88          "i2c"             "i2c"       3, 4
89          "uart1_0"         "uart"      7, 8, 9, 10
90          "uart1_rx_tx"     "uart"      42, 43
91          "uart1_cts_rts"   "uart"      44, 45
92          "pcie_clk"        "pcie"      9
93          "pcie_wake"       "pcie"      10
94          "spi1_0"          "spi"       11, 12, 13, 14
95          "pwm1_1"          "pwm"       20,
96          "pwm0"            "pwm"       21,
97          "pwm1_0"          "pwm"       22,
98          "snfi"            "flash"     23, 24, 25, 26, 27, 28
99          "spi1_2"          "spi"       29, 30, 31, 32
100          "emmc_45"         "emmc"      22, 23, 24, 25, 26, 27, 28, 29, 30, 31,
101                                        32
102
103          "spi1_1"          "spi"       23, 24, 25, 26
104          "uart1_2_rx_tx"   "uart"      29, 30
105          "uart1_2_cts_rts" "uart"      31, 32
106          "uart1_1"         "uart"      23, 24, 25, 26
107          "uart2_0_rx_tx"   "uart"      29, 30
108          "uart2_0_cts_rts" "uart"      31, 32
109          "spi0"            "spi"       33, 34, 35, 36
110          "spi0_wp_hold"    "spi"       37, 38
111          "uart1_3_rx_tx"   "uart"      35, 36
112          "uart1_3_cts_rts" "uart"      37, 38
113          "uart2_1"         "uart"      33, 34, 35, 36
114          "spi1_3"          "spi"       33, 34, 35, 36
115          "uart0"           "uart"      39, 40
116          "pcie_pereset"    "pcie"      41
117          "uart1"           "uart"      42, 43, 44, 45
118          "uart2"           "uart"      46, 47, 48, 49
119          "emmc_51"         "emmc"      50, 51, 52, 53, 54, 55, 56, 57, 58, 59,
120                                        60, 61
121
122          "pcm"             "audio"     62, 63, 64, 65
123          "i2s"             "audio"     62, 63, 64, 65
124          "switch_int"      "eth"       66
125          "mdc_mdio"        "eth"       67
126          "wf_2g"           "wifi"      74, 75, 76, 77, 78, 79, 80, 81, 82, 83
127          "wf_5g"           "wifi"      91, 92, 93, 94, 95, 96, 97, 98, 99, 100
128          "wf_dbdc"         "wifi"      74, 75, 76, 77, 78, 79, 80, 81, 82, 83,
129                                        84, 85
130
131        $ref: /schemas/pinctrl/pinmux-node.yaml
132        properties:
133          function:
134            description:
135              A string containing the name of the function to mux to the group.
136              There is no "audio", "pcie" functions on mt7986b, you can only use
137              those functions on mt7986a.
138            enum: [audio, emmc, eth, i2c, led, flash, pcie, pwm, spi, uart,
139                   watchdog, wifi]
140          groups:
141            description:
142              An array of strings. Each string contains the name of a group.
143              There is no "pcie_pereset", "uart1", "uart2" "emmc_51", "pcm", and
144              "i2s" groups on mt7986b, you can only use those groups on mt7986a.
145        required:
146          - function
147          - groups
148
149        allOf:
150          - if:
151              properties:
152                function:
153                  const: audio
154            then:
155              properties:
156                groups:
157                  enum: [pcm, i2s]
158          - if:
159              properties:
160                function:
161                  const: emmc
162            then:
163              properties:
164                groups:
165                  enum: [emmc_45, emmc_51]
166          - if:
167              properties:
168                function:
169                  const: eth
170            then:
171              properties:
172                groups:
173                  enum: [switch_int, mdc_mdio]
174          - if:
175              properties:
176                function:
177                  const: i2c
178            then:
179              properties:
180                groups:
181                  enum: [i2c]
182          - if:
183              properties:
184                function:
185                  const: led
186            then:
187              properties:
188                groups:
189                  enum: [wifi_led]
190          - if:
191              properties:
192                function:
193                  const: flash
194            then:
195              properties:
196                groups:
197                  enum: [snfi]
198          - if:
199              properties:
200                function:
201                  const: pcie
202            then:
203              properties:
204                groups:
205                  items:
206                    enum: [pcie_clk, pcie_wake, pcie_pereset]
207                  maxItems: 3
208          - if:
209              properties:
210                function:
211                  const: pwm
212            then:
213              properties:
214                groups:
215                  items:
216                    enum: [pwm0, pwm1_0, pwm1_1]
217                  maxItems: 2
218          - if:
219              properties:
220                function:
221                  const: spi
222            then:
223              properties:
224                groups:
225                  items:
226                    enum: [spi0, spi0_wp_hold, spi1_0, spi1_1, spi1_2, spi1_3]
227                  maxItems: 2
228          - if:
229              properties:
230                function:
231                  const: uart
232            then:
233              properties:
234                groups:
235                  items:
236                    enum: [uart1_0, uart1_rx_tx, uart1_cts_rts, uart1_1,
237                           uart1_2_rx_tx, uart1_2_cts_rts, uart1_3_rx_tx,
238                           uart1_3_cts_rts, uart2_0_rx_tx, uart2_0_cts_rts,
239                           uart2_1, uart0, uart1, uart2]
240                  maxItems: 2
241          - if:
242              properties:
243                function:
244                  const: watchdog
245            then:
246              properties:
247                groups:
248                  enum: [watchdog]
249          - if:
250              properties:
251                function:
252                  const: wifi
253            then:
254              properties:
255                groups:
256                  items:
257                    enum: [wf_2g, wf_5g, wf_dbdc]
258                  maxItems: 3
259      '^.*conf.*$':
260        type: object
261        additionalProperties: false
262        description:
263          pinconf configuration nodes.
264        $ref: /schemas/pinctrl/pincfg-node.yaml
265
266        properties:
267          pins:
268            description:
269              An array of strings. Each string contains the name of a pin. There
270              is no PIN 41 to PIN 65 above on mt7686b, you can only use those
271              pins on mt7986a.
272            items:
273              enum: [SYS_WATCHDOG, WF2G_LED, WF5G_LED, I2C_SCL, I2C_SDA, GPIO_0,
274                     GPIO_1, GPIO_2, GPIO_3, GPIO_4, GPIO_5, GPIO_6, GPIO_7,
275                     GPIO_8, GPIO_9, GPIO_10, GPIO_11, GPIO_12, GPIO_13,
276                     GPIO_14, GPIO_15, PWM0, PWM1, SPI0_CLK, SPI0_MOSI,
277                     SPI0_MISO, SPI0_CS, SPI0_HOLD, SPI0_WP, SPI1_CLK,
278                     SPI1_MOSI, SPI1_MISO, SPI1_CS, SPI2_CLK, SPI2_MOSI,
279                     SPI2_MISO, SPI2_CS, SPI2_HOLD, SPI2_WP, UART0_RXD,
280                     UART0_TXD, PCIE_PERESET_N, UART1_RXD, UART1_TXD, UART1_CTS,
281                     UART1_RTS, UART2_RXD, UART2_TXD, UART2_CTS, UART2_RTS,
282                     EMMC_DATA_0, EMMC_DATA_1, EMMC_DATA_2, EMMC_DATA_3,
283                     EMMC_DATA_4, EMMC_DATA_5, EMMC_DATA_6, EMMC_DATA_7,
284                     EMMC_CMD, EMMC_CK, EMMC_DSL, EMMC_RSTB, PCM_DTX, PCM_DRX,
285                     PCM_CLK, PCM_FS, MT7531_INT, SMI_MDC, SMI_MDIO,
286                     WF0_DIG_RESETB, WF0_CBA_RESETB, WF0_XO_REQ, WF0_TOP_CLK,
287                     WF0_TOP_DATA, WF0_HB1, WF0_HB2, WF0_HB3, WF0_HB4, WF0_HB0,
288                     WF0_HB0_B, WF0_HB5, WF0_HB6, WF0_HB7, WF0_HB8, WF0_HB9,
289                     WF0_HB10, WF1_DIG_RESETB, WF1_CBA_RESETB, WF1_XO_REQ,
290                     WF1_TOP_CLK, WF1_TOP_DATA, WF1_HB1, WF1_HB2, WF1_HB3,
291                     WF1_HB4, WF1_HB0, WF1_HB0_B, WF1_HB5, WF1_HB6, WF1_HB7,
292                     WF1_HB8]
293            maxItems: 101
294
295          bias-disable: true
296
297          bias-pull-up:
298            oneOf:
299              - type: boolean
300                description: normal pull up.
301              - enum: [100, 101, 102, 103]
302                description:
303                  PUPD/R1/R0 pull down type. See MTK_PUPD_SET_R1R0 defines in
304                  dt-bindings/pinctrl/mt65xx.h.
305
306          bias-pull-down:
307            oneOf:
308              - type: boolean
309                description: normal pull down.
310              - enum: [100, 101, 102, 103]
311                description:
312                  PUPD/R1/R0 pull down type. See MTK_PUPD_SET_R1R0 defines in
313                  dt-bindings/pinctrl/mt65xx.h.
314
315          input-enable: true
316
317          input-disable: true
318
319          output-enable: true
320
321          output-low: true
322
323          output-high: true
324
325          input-schmitt-enable: true
326
327          input-schmitt-disable: true
328
329          drive-strength:
330            enum: [2, 4, 6, 8, 10, 12, 14, 16]
331
332          mediatek,pull-up-adv:
333            description: |
334              Valid arguments for 'mediatek,pull-up-adv' are '0', '1', '2', '3'
335              Pull up setings for 2 pull resistors, R0 and R1. Valid arguments
336              are described as below:
337              0: (R1, R0) = (0, 0) which means R1 disabled and R0 disabled.
338              1: (R1, R0) = (0, 1) which means R1 disabled and R0 enabled.
339              2: (R1, R0) = (1, 0) which means R1 enabled and R0 disabled.
340              3: (R1, R0) = (1, 1) which means R1 enabled and R0 enabled.
341            $ref: /schemas/types.yaml#/definitions/uint32
342            enum: [0, 1, 2, 3]
343
344          mediatek,pull-down-adv:
345            description: |
346              Valid arguments for 'mediatek,pull-up-adv' are '0', '1', '2', '3'
347              Pull down setings for 2 pull resistors, R0 and R1. Valid arguments
348              are described as below:
349              0: (R1, R0) = (0, 0) which means R1 disabled and R0 disabled.
350              1: (R1, R0) = (0, 1) which means R1 disabled and R0 enabled.
351              2: (R1, R0) = (1, 0) which means R1 enabled and R0 disabled.
352              3: (R1, R0) = (1, 1) which means R1 enabled and R0 enabled.
353            $ref: /schemas/types.yaml#/definitions/uint32
354            enum: [0, 1, 2, 3]
355
356        required:
357          - pins
358
359additionalProperties: false
360
361examples:
362  - |
363    #include <dt-bindings/interrupt-controller/irq.h>
364    #include <dt-bindings/interrupt-controller/arm-gic.h>
365    #include <dt-bindings/pinctrl/mt65xx.h>
366
367    soc {
368      #address-cells = <2>;
369      #size-cells = <2>;
370      pio: pinctrl@1001f000 {
371        compatible = "mediatek,mt7986a-pinctrl";
372        reg = <0 0x1001f000 0 0x1000>,
373              <0 0x11c30000 0 0x1000>,
374              <0 0x11c40000 0 0x1000>,
375              <0 0x11e20000 0 0x1000>,
376              <0 0x11e30000 0 0x1000>,
377              <0 0x11f00000 0 0x1000>,
378              <0 0x11f10000 0 0x1000>,
379              <0 0x1000b000 0 0x1000>;
380        reg-names = "gpio", "iocfg_rt", "iocfg_rb", "iocfg_lt",
381                    "iocfg_lb", "iocfg_tr", "iocfg_tl", "eint";
382        gpio-controller;
383        #gpio-cells = <2>;
384        gpio-ranges = <&pio 0 0 100>;
385        interrupt-controller;
386        interrupts = <GIC_SPI 225 IRQ_TYPE_LEVEL_HIGH>;
387        interrupt-parent = <&gic>;
388        #interrupt-cells = <2>;
389
390        pcie_pins: pcie-pins {
391          mux {
392            function = "pcie";
393            groups = "pcie_clk", "pcie_wake", "pcie_pereset";
394          };
395        };
396
397        pwm_pins: pwm-pins {
398          mux {
399            function = "pwm";
400            groups = "pwm0", "pwm1_0";
401          };
402        };
403
404        spi0_pins: spi0-pins {
405          mux {
406            function = "spi";
407            groups = "spi0", "spi0_wp_hold";
408          };
409        };
410
411        uart1_pins: uart1-pins {
412          mux {
413            function = "uart";
414            groups = "uart1";
415          };
416        };
417
418        uart1_3_pins: uart1-3-pins {
419          mux {
420            function = "uart";
421            groups = "uart1_3_rx_tx", "uart1_3_cts_rts";
422          };
423        };
424
425        uart2_pins: uart2-pins {
426          mux {
427            function = "uart";
428            groups = "uart2";
429          };
430        };
431
432        mmc0_pins_default: mmc0-pins {
433          mux {
434            function = "emmc";
435            groups = "emmc_51";
436          };
437          conf-cmd-dat {
438            pins = "EMMC_DATA_0", "EMMC_DATA_1", "EMMC_DATA_2",
439                   "EMMC_DATA_3", "EMMC_DATA_4", "EMMC_DATA_5",
440                   "EMMC_DATA_6", "EMMC_DATA_7", "EMMC_CMD";
441            input-enable;
442            drive-strength = <4>;
443            bias-pull-up = <MTK_PUPD_SET_R1R0_01>; /* pull-up 10K */
444          };
445          conf-clk {
446            pins = "EMMC_CK";
447            drive-strength = <6>;
448            bias-pull-down = <MTK_PUPD_SET_R1R0_10>; /* pull-down 50K */
449          };
450          conf-ds {
451            pins = "EMMC_DSL";
452            bias-pull-down = <MTK_PUPD_SET_R1R0_10>; /* pull-down 50K */
453          };
454          conf-rst {
455            pins = "EMMC_RSTB";
456            drive-strength = <4>;
457            bias-pull-up = <MTK_PUPD_SET_R1R0_01>; /* pull-up 10K */
458          };
459        };
460
461      };
462    };
463