Merge tag 'pinctrl-v6.4-1' of git://git.kernel.org/pub/scm/linux/kernel/git/linusw...
authorLinus Torvalds <torvalds@linux-foundation.org>
Tue, 2 May 2023 22:40:41 +0000 (15:40 -0700)
committerLinus Torvalds <torvalds@linux-foundation.org>
Tue, 2 May 2023 22:40:41 +0000 (15:40 -0700)
Pull pin control updates from Linus Walleij:
 "Mostly drivers! Nothing special: some new Qualcomm chips as usual, and
  the new NXP S32 and nVidia BlueField-3.

  Core changes:

   - Make a lot of pin controllers with GPIO and irqchips immutable,
     i.e. not living structs, but const structs. This is driving a
     changed initiated by the irqchip maintainers.

  New drivers:

   - New driver for the NXP S32 SoC pin controller

   - As part of a thorough cleanup and restructuring of the
     Ralink/Mediatek drivers, the Ralink MIPS pin control drivers were
     folded into the Mediatek directory and the family is renamed
     "mtmips". The Ralink chips live on as Mediatek MIPS family where
     new variants can be added. As part of this work also the device
     tree bindings were reworked.

   - New subdriver for the Qualcomm SM7150 SoC.

   - New subdriver for the Qualcomm IPQ9574 SoC.

   - New driver for the nVidia BlueField-3 SoC.

   - Support for the Qualcomm PMM8654AU mixed signal circuit GPIO.

   - Support for the Qualcomm PMI632 mixed signal circuit GPIO.

  Improvements:

   - Add some missing pins and generic cleanups on the Renesas r8a779g0
     and r8a779g0 pin controllers. Generic Renesas extension for power
     source selection on several SoCs.

   - Misc cleanups for the Atmel AT91 and AT91-PIO4 pin controllers

   - Make the GPIO mode work on the Qualcomm SM8550-lpass-lpi driver.

   - Several device tree binding cleanups as the binding YAML syntax is
     solidifying"

* tag 'pinctrl-v6.4-1' of git://git.kernel.org/pub/scm/linux/kernel/git/linusw/linux-pinctrl: (153 commits)
  pinctrl-bcm2835.c: fix race condition when setting gpio dir
  dt-bindings: pinctrl: qcom,sm8150: Drop duplicate function value "atest_usb2"
  dt-bindings: pinctrl: qcom: Add few missing functions
  pinctrl: qcom: spmi-gpio: Add PMI632 support
  dt-bindings: pinctrl: qcom,pmic-gpio: add PMI632
  pinctrl: wpcm450: select MFD_SYSCON
  pinctrl: qcom ssbi-gpio: Convert to immutable irq_chip
  pinctrl: qcom ssbi-mpp: Convert to immutable irq_chip
  pinctrl: qcom spmi-mpp: Convert to immutable irq_chip
  pinctrl: plgpio: Convert to immutable irq_chip
  pinctrl: pistachio: Convert to immutable irq_chip
  pinctrl: pic32: Convert to immutable irq_chip
  pinctrl: sx150x: Convert to immutable irq_chip
  pinctrl: stmfx: Convert to immutable irq_chip
  pinctrl: st: Convert to immutable irq_chip
  pinctrl: mcp23s08: Convert to immutable irq_chip
  pinctrl: equilibrium: Convert to immutable irq_chip
  pinctrl: npcm7xx: Convert to immutable irq_chip
  pinctrl: armada-37xx: Convert to immutable irq_chip
  pinctrl: nsp: Convert to immutable irq_chip
  ...

234 files changed:
Documentation/devicetree/bindings/gpio/nxp,pcf8575.yaml
Documentation/devicetree/bindings/pinctrl/actions,s500-pinctrl.yaml
Documentation/devicetree/bindings/pinctrl/allwinner,sun4i-a10-pinctrl.yaml
Documentation/devicetree/bindings/pinctrl/amlogic,meson-pinctrl-a1.yaml [new file with mode: 0644]
Documentation/devicetree/bindings/pinctrl/amlogic,meson-pinctrl-common.yaml [new file with mode: 0644]
Documentation/devicetree/bindings/pinctrl/amlogic,meson-pinctrl-g12a-aobus.yaml [new file with mode: 0644]
Documentation/devicetree/bindings/pinctrl/amlogic,meson-pinctrl-g12a-periphs.yaml [new file with mode: 0644]
Documentation/devicetree/bindings/pinctrl/amlogic,meson8-pinctrl-aobus.yaml [new file with mode: 0644]
Documentation/devicetree/bindings/pinctrl/amlogic,meson8-pinctrl-cbus.yaml [new file with mode: 0644]
Documentation/devicetree/bindings/pinctrl/apple,pinctrl.yaml
Documentation/devicetree/bindings/pinctrl/aspeed,ast2400-pinctrl.yaml
Documentation/devicetree/bindings/pinctrl/aspeed,ast2500-pinctrl.yaml
Documentation/devicetree/bindings/pinctrl/aspeed,ast2600-pinctrl.yaml
Documentation/devicetree/bindings/pinctrl/brcm,bcm6318-pinctrl.yaml
Documentation/devicetree/bindings/pinctrl/brcm,bcm63268-pinctrl.yaml
Documentation/devicetree/bindings/pinctrl/brcm,bcm6328-pinctrl.yaml
Documentation/devicetree/bindings/pinctrl/brcm,bcm6358-pinctrl.yaml
Documentation/devicetree/bindings/pinctrl/brcm,bcm6362-pinctrl.yaml
Documentation/devicetree/bindings/pinctrl/brcm,bcm6368-pinctrl.yaml
Documentation/devicetree/bindings/pinctrl/brcm,ns-pinmux.yaml
Documentation/devicetree/bindings/pinctrl/canaan,k210-fpioa.yaml
Documentation/devicetree/bindings/pinctrl/cirrus,lochnagar.yaml
Documentation/devicetree/bindings/pinctrl/cirrus,madera.yaml
Documentation/devicetree/bindings/pinctrl/cypress,cy8c95x0.yaml
Documentation/devicetree/bindings/pinctrl/fsl,imx7d-pinctrl.yaml
Documentation/devicetree/bindings/pinctrl/fsl,imx8m-pinctrl.yaml
Documentation/devicetree/bindings/pinctrl/fsl,imx8ulp-pinctrl.yaml
Documentation/devicetree/bindings/pinctrl/fsl,imx93-pinctrl.yaml
Documentation/devicetree/bindings/pinctrl/ingenic,pinctrl.yaml
Documentation/devicetree/bindings/pinctrl/intel,lgm-io.yaml
Documentation/devicetree/bindings/pinctrl/intel,pinctrl-thunderbay.yaml [deleted file]
Documentation/devicetree/bindings/pinctrl/lantiq,pinctrl-xway.txt
Documentation/devicetree/bindings/pinctrl/marvell,ac5-pinctrl.yaml
Documentation/devicetree/bindings/pinctrl/mediatek,mt65xx-pinctrl.yaml
Documentation/devicetree/bindings/pinctrl/mediatek,mt6779-pinctrl.yaml
Documentation/devicetree/bindings/pinctrl/mediatek,mt6795-pinctrl.yaml [new file with mode: 0644]
Documentation/devicetree/bindings/pinctrl/mediatek,mt7620-pinctrl.yaml [new file with mode: 0644]
Documentation/devicetree/bindings/pinctrl/mediatek,mt7621-pinctrl.yaml [new file with mode: 0644]
Documentation/devicetree/bindings/pinctrl/mediatek,mt7622-pinctrl.yaml
Documentation/devicetree/bindings/pinctrl/mediatek,mt76x8-pinctrl.yaml [new file with mode: 0644]
Documentation/devicetree/bindings/pinctrl/mediatek,mt7981-pinctrl.yaml
Documentation/devicetree/bindings/pinctrl/mediatek,mt7986-pinctrl.yaml
Documentation/devicetree/bindings/pinctrl/mediatek,mt8183-pinctrl.yaml
Documentation/devicetree/bindings/pinctrl/mediatek,mt8186-pinctrl.yaml [new file with mode: 0644]
Documentation/devicetree/bindings/pinctrl/mediatek,mt8188-pinctrl.yaml
Documentation/devicetree/bindings/pinctrl/mediatek,mt8192-pinctrl.yaml [new file with mode: 0644]
Documentation/devicetree/bindings/pinctrl/mediatek,mt8195-pinctrl.yaml [new file with mode: 0644]
Documentation/devicetree/bindings/pinctrl/mediatek,mt8365-pinctrl.yaml
Documentation/devicetree/bindings/pinctrl/mediatek,pinctrl-mt6795.yaml [deleted file]
Documentation/devicetree/bindings/pinctrl/meson,pinctrl.txt [deleted file]
Documentation/devicetree/bindings/pinctrl/mscc,ocelot-pinctrl.yaml
Documentation/devicetree/bindings/pinctrl/nxp,s32g2-siul2-pinctrl.yaml [new file with mode: 0644]
Documentation/devicetree/bindings/pinctrl/pinctrl-mt8186.yaml [deleted file]
Documentation/devicetree/bindings/pinctrl/pinctrl-mt8192.yaml [deleted file]
Documentation/devicetree/bindings/pinctrl/pinctrl-mt8195.yaml [deleted file]
Documentation/devicetree/bindings/pinctrl/qcom,ipq5332-tlmm.yaml
Documentation/devicetree/bindings/pinctrl/qcom,ipq6018-pinctrl.yaml
Documentation/devicetree/bindings/pinctrl/qcom,ipq8074-pinctrl.yaml
Documentation/devicetree/bindings/pinctrl/qcom,ipq9574-tlmm.yaml [new file with mode: 0644]
Documentation/devicetree/bindings/pinctrl/qcom,mdm9607-tlmm.yaml
Documentation/devicetree/bindings/pinctrl/qcom,mdm9615-pinctrl.yaml
Documentation/devicetree/bindings/pinctrl/qcom,msm8226-pinctrl.yaml
Documentation/devicetree/bindings/pinctrl/qcom,msm8660-pinctrl.yaml
Documentation/devicetree/bindings/pinctrl/qcom,msm8909-tlmm.yaml
Documentation/devicetree/bindings/pinctrl/qcom,msm8916-pinctrl.yaml
Documentation/devicetree/bindings/pinctrl/qcom,msm8953-pinctrl.yaml
Documentation/devicetree/bindings/pinctrl/qcom,msm8960-pinctrl.yaml
Documentation/devicetree/bindings/pinctrl/qcom,msm8974-pinctrl.yaml
Documentation/devicetree/bindings/pinctrl/qcom,msm8976-pinctrl.yaml
Documentation/devicetree/bindings/pinctrl/qcom,msm8994-pinctrl.yaml
Documentation/devicetree/bindings/pinctrl/qcom,msm8996-pinctrl.yaml
Documentation/devicetree/bindings/pinctrl/qcom,msm8998-pinctrl.yaml
Documentation/devicetree/bindings/pinctrl/qcom,pmic-gpio.yaml
Documentation/devicetree/bindings/pinctrl/qcom,pmic-mpp.yaml
Documentation/devicetree/bindings/pinctrl/qcom,qcm2290-tlmm.yaml
Documentation/devicetree/bindings/pinctrl/qcom,qcs404-pinctrl.yaml
Documentation/devicetree/bindings/pinctrl/qcom,qdu1000-tlmm.yaml
Documentation/devicetree/bindings/pinctrl/qcom,sa8775p-tlmm.yaml
Documentation/devicetree/bindings/pinctrl/qcom,sc7180-pinctrl.yaml
Documentation/devicetree/bindings/pinctrl/qcom,sc7280-lpass-lpi-pinctrl.yaml
Documentation/devicetree/bindings/pinctrl/qcom,sc7280-pinctrl.yaml
Documentation/devicetree/bindings/pinctrl/qcom,sc8180x-tlmm.yaml
Documentation/devicetree/bindings/pinctrl/qcom,sc8280xp-lpass-lpi-pinctrl.yaml
Documentation/devicetree/bindings/pinctrl/qcom,sc8280xp-tlmm.yaml
Documentation/devicetree/bindings/pinctrl/qcom,sdm630-pinctrl.yaml
Documentation/devicetree/bindings/pinctrl/qcom,sdm670-tlmm.yaml
Documentation/devicetree/bindings/pinctrl/qcom,sdm845-pinctrl.yaml
Documentation/devicetree/bindings/pinctrl/qcom,sdx55-pinctrl.yaml
Documentation/devicetree/bindings/pinctrl/qcom,sdx65-tlmm.yaml
Documentation/devicetree/bindings/pinctrl/qcom,sm6115-tlmm.yaml
Documentation/devicetree/bindings/pinctrl/qcom,sm6125-tlmm.yaml
Documentation/devicetree/bindings/pinctrl/qcom,sm6350-tlmm.yaml
Documentation/devicetree/bindings/pinctrl/qcom,sm6375-tlmm.yaml
Documentation/devicetree/bindings/pinctrl/qcom,sm7150-tlmm.yaml [new file with mode: 0644]
Documentation/devicetree/bindings/pinctrl/qcom,sm8150-pinctrl.yaml
Documentation/devicetree/bindings/pinctrl/qcom,sm8250-lpass-lpi-pinctrl.yaml
Documentation/devicetree/bindings/pinctrl/qcom,sm8250-pinctrl.yaml
Documentation/devicetree/bindings/pinctrl/qcom,sm8350-tlmm.yaml
Documentation/devicetree/bindings/pinctrl/qcom,sm8450-lpass-lpi-pinctrl.yaml
Documentation/devicetree/bindings/pinctrl/qcom,sm8450-tlmm.yaml
Documentation/devicetree/bindings/pinctrl/qcom,sm8550-lpass-lpi-pinctrl.yaml
Documentation/devicetree/bindings/pinctrl/qcom,sm8550-tlmm.yaml
Documentation/devicetree/bindings/pinctrl/qcom,tlmm-common.yaml
Documentation/devicetree/bindings/pinctrl/ralink,mt7620-pinctrl.yaml [deleted file]
Documentation/devicetree/bindings/pinctrl/ralink,mt7621-pinctrl.yaml [deleted file]
Documentation/devicetree/bindings/pinctrl/ralink,rt2880-pinctrl.yaml
Documentation/devicetree/bindings/pinctrl/ralink,rt305x-pinctrl.yaml
Documentation/devicetree/bindings/pinctrl/ralink,rt3352-pinctrl.yaml [new file with mode: 0644]
Documentation/devicetree/bindings/pinctrl/ralink,rt3883-pinctrl.yaml
Documentation/devicetree/bindings/pinctrl/ralink,rt5350-pinctrl.yaml [new file with mode: 0644]
Documentation/devicetree/bindings/pinctrl/renesas,pfc.yaml
Documentation/devicetree/bindings/pinctrl/renesas,rza1-ports.yaml
Documentation/devicetree/bindings/pinctrl/renesas,rza2-pinctrl.yaml
Documentation/devicetree/bindings/pinctrl/renesas,rzg2l-pinctrl.yaml
Documentation/devicetree/bindings/pinctrl/renesas,rzn1-pinctrl.yaml
Documentation/devicetree/bindings/pinctrl/renesas,rzv2m-pinctrl.yaml
Documentation/devicetree/bindings/pinctrl/rockchip,pinctrl.yaml
Documentation/devicetree/bindings/pinctrl/samsung,pinctrl.yaml
Documentation/devicetree/bindings/pinctrl/semtech,sx1501q.yaml
Documentation/devicetree/bindings/pinctrl/socionext,uniphier-pinctrl.yaml
Documentation/devicetree/bindings/pinctrl/st,stm32-pinctrl.yaml
Documentation/devicetree/bindings/pinctrl/starfive,jh7100-pinctrl.yaml
Documentation/devicetree/bindings/pinctrl/sunplus,sp7021-pinctrl.yaml
Documentation/devicetree/bindings/pinctrl/toshiba,visconti-pinctrl.yaml
Documentation/devicetree/bindings/pinctrl/xlnx,zynq-pinctrl.yaml
MAINTAINERS
drivers/pinctrl/Kconfig
drivers/pinctrl/Makefile
drivers/pinctrl/bcm/pinctrl-bcm2835.c
drivers/pinctrl/bcm/pinctrl-iproc-gpio.c
drivers/pinctrl/bcm/pinctrl-nsp-gpio.c
drivers/pinctrl/freescale/Kconfig
drivers/pinctrl/freescale/pinctrl-imx.c
drivers/pinctrl/freescale/pinctrl-imx.h
drivers/pinctrl/mediatek/Kconfig
drivers/pinctrl/mediatek/Makefile
drivers/pinctrl/mediatek/pinctrl-moore.c
drivers/pinctrl/mediatek/pinctrl-mt7620.c [new file with mode: 0644]
drivers/pinctrl/mediatek/pinctrl-mt7621.c [new file with mode: 0644]
drivers/pinctrl/mediatek/pinctrl-mt76x8.c [new file with mode: 0644]
drivers/pinctrl/mediatek/pinctrl-mtmips.c [new file with mode: 0644]
drivers/pinctrl/mediatek/pinctrl-mtmips.h [new file with mode: 0644]
drivers/pinctrl/mediatek/pinctrl-rt2880.c [new file with mode: 0644]
drivers/pinctrl/mediatek/pinctrl-rt305x.c [new file with mode: 0644]
drivers/pinctrl/mediatek/pinctrl-rt3883.c [new file with mode: 0644]
drivers/pinctrl/mvebu/pinctrl-armada-37xx.c
drivers/pinctrl/nuvoton/Kconfig
drivers/pinctrl/nuvoton/pinctrl-npcm7xx.c
drivers/pinctrl/nxp/Kconfig [new file with mode: 0644]
drivers/pinctrl/nxp/Makefile [new file with mode: 0644]
drivers/pinctrl/nxp/pinctrl-s32.h [new file with mode: 0644]
drivers/pinctrl/nxp/pinctrl-s32cc.c [new file with mode: 0644]
drivers/pinctrl/nxp/pinctrl-s32g2.c [new file with mode: 0644]
drivers/pinctrl/pinctrl-amd.c
drivers/pinctrl/pinctrl-at91-pio4.c
drivers/pinctrl/pinctrl-at91.c
drivers/pinctrl/pinctrl-equilibrium.c
drivers/pinctrl/pinctrl-equilibrium.h
drivers/pinctrl/pinctrl-mcp23s08.c
drivers/pinctrl/pinctrl-mcp23s08.h
drivers/pinctrl/pinctrl-mlxbf3.c [new file with mode: 0644]
drivers/pinctrl/pinctrl-pic32.c
drivers/pinctrl/pinctrl-pistachio.c
drivers/pinctrl/pinctrl-single.c
drivers/pinctrl/pinctrl-st.c
drivers/pinctrl/pinctrl-stmfx.c
drivers/pinctrl/pinctrl-sx150x.c
drivers/pinctrl/pinctrl-thunderbay.c [deleted file]
drivers/pinctrl/pinctrl-xway.c
drivers/pinctrl/qcom/Kconfig
drivers/pinctrl/qcom/Makefile
drivers/pinctrl/qcom/pinctrl-ipq9574.c [new file with mode: 0644]
drivers/pinctrl/qcom/pinctrl-lpass-lpi.c
drivers/pinctrl/qcom/pinctrl-msm.c
drivers/pinctrl/qcom/pinctrl-msm8998.c
drivers/pinctrl/qcom/pinctrl-sm7150.c [new file with mode: 0644]
drivers/pinctrl/qcom/pinctrl-sm8550-lpass-lpi.c
drivers/pinctrl/qcom/pinctrl-spmi-gpio.c
drivers/pinctrl/qcom/pinctrl-spmi-mpp.c
drivers/pinctrl/qcom/pinctrl-ssbi-gpio.c
drivers/pinctrl/qcom/pinctrl-ssbi-mpp.c
drivers/pinctrl/ralink/Kconfig [deleted file]
drivers/pinctrl/ralink/Makefile [deleted file]
drivers/pinctrl/ralink/pinctrl-mt7620.c [deleted file]
drivers/pinctrl/ralink/pinctrl-mt7621.c [deleted file]
drivers/pinctrl/ralink/pinctrl-ralink.c [deleted file]
drivers/pinctrl/ralink/pinctrl-ralink.h [deleted file]
drivers/pinctrl/ralink/pinctrl-rt2880.c [deleted file]
drivers/pinctrl/ralink/pinctrl-rt305x.c [deleted file]
drivers/pinctrl/ralink/pinctrl-rt3883.c [deleted file]
drivers/pinctrl/renesas/Kconfig
drivers/pinctrl/renesas/Makefile
drivers/pinctrl/renesas/core.c
drivers/pinctrl/renesas/pfc-emev2.c
drivers/pinctrl/renesas/pfc-r8a73a4.c
drivers/pinctrl/renesas/pfc-r8a7740.c
drivers/pinctrl/renesas/pfc-r8a77470.c
drivers/pinctrl/renesas/pfc-r8a7778.c
drivers/pinctrl/renesas/pfc-r8a7779.c
drivers/pinctrl/renesas/pfc-r8a7790.c
drivers/pinctrl/renesas/pfc-r8a7791.c
drivers/pinctrl/renesas/pfc-r8a7792.c
drivers/pinctrl/renesas/pfc-r8a7794.c
drivers/pinctrl/renesas/pfc-r8a77950.c [deleted file]
drivers/pinctrl/renesas/pfc-r8a77951.c
drivers/pinctrl/renesas/pfc-r8a7796.c
drivers/pinctrl/renesas/pfc-r8a77965.c
drivers/pinctrl/renesas/pfc-r8a77970.c
drivers/pinctrl/renesas/pfc-r8a77980.c
drivers/pinctrl/renesas/pfc-r8a77990.c
drivers/pinctrl/renesas/pfc-r8a77995.c
drivers/pinctrl/renesas/pfc-r8a779a0.c
drivers/pinctrl/renesas/pfc-r8a779f0.c
drivers/pinctrl/renesas/pfc-r8a779g0.c
drivers/pinctrl/renesas/pfc-sh7203.c
drivers/pinctrl/renesas/pfc-sh7264.c
drivers/pinctrl/renesas/pfc-sh7269.c
drivers/pinctrl/renesas/pfc-sh73a0.c
drivers/pinctrl/renesas/pfc-sh7720.c
drivers/pinctrl/renesas/pfc-sh7722.c
drivers/pinctrl/renesas/pfc-sh7723.c
drivers/pinctrl/renesas/pfc-sh7724.c
drivers/pinctrl/renesas/pfc-sh7734.c
drivers/pinctrl/renesas/pfc-sh7757.c
drivers/pinctrl/renesas/pfc-sh7785.c
drivers/pinctrl/renesas/pfc-sh7786.c
drivers/pinctrl/renesas/pfc-shx3.c
drivers/pinctrl/renesas/pinctrl-rza1.c
drivers/pinctrl/renesas/pinctrl-rzn1.c
drivers/pinctrl/renesas/pinctrl.c
drivers/pinctrl/renesas/sh_pfc.h
drivers/pinctrl/spear/pinctrl-plgpio.c
drivers/pinctrl/stm32/pinctrl-stm32.c
drivers/pinctrl/sunxi/pinctrl-sunxi.c

index f0ff66c4c74e252dd33ac165ebd25e41da6e0d0f..3718103e966a13e1d77f73335ff73c18a3199469 100644 (file)
@@ -39,6 +39,10 @@ properties:
   reg:
     maxItems: 1
 
+  gpio-line-names:
+    minItems: 1
+    maxItems: 16
+
   gpio-controller: true
 
   '#gpio-cells':
index fb0f69ce9c16c4a5d4cf028c13753b1c2d8439ae..7cb8a747feee41fe84cb968e37a37a9bfc37ae3b 100644 (file)
@@ -185,7 +185,7 @@ patternProperties:
     additionalProperties: false
 
 allOf:
-  - $ref: "pinctrl.yaml#"
+  - $ref: pinctrl.yaml#
 
 required:
   - compatible
index 1e3c8de6cae1348f8cb92b33f175499c51e7b35e..467016cbb0378c441963c842ab4f7eb4940ff974 100644 (file)
@@ -142,7 +142,7 @@ allOf:
   # boards are defining it at the moment so it would generate a lot of
   # warnings.
 
-  - $ref: "pinctrl.yaml#"
+  - $ref: pinctrl.yaml#
   - if:
       not:
         properties:
diff --git a/Documentation/devicetree/bindings/pinctrl/amlogic,meson-pinctrl-a1.yaml b/Documentation/devicetree/bindings/pinctrl/amlogic,meson-pinctrl-a1.yaml
new file mode 100644 (file)
index 0000000..99080c9
--- /dev/null
@@ -0,0 +1,67 @@
+# SPDX-License-Identifier: (GPL-2.0-only OR BSD-2-Clause)
+%YAML 1.2
+---
+$id: http://devicetree.org/schemas/pinctrl/amlogic,meson-pinctrl-a1.yaml#
+$schema: http://devicetree.org/meta-schemas/core.yaml#
+
+title: Amlogic Meson A1 pinmux controller
+
+maintainers:
+  - Neil Armstrong <neil.armstrong@linaro.org>
+
+allOf:
+  - $ref: amlogic,meson-pinctrl-common.yaml#
+
+properties:
+  compatible:
+    enum:
+      - amlogic,meson-a1-periphs-pinctrl
+      - amlogic,meson-s4-periphs-pinctrl
+
+required:
+  - compatible
+
+patternProperties:
+  "^bank@[0-9a-z]+$":
+    $ref: amlogic,meson-pinctrl-common.yaml#/$defs/meson-gpio
+
+    unevaluatedProperties: false
+
+    properties:
+      reg:
+        maxItems: 2
+
+      reg-names:
+        items:
+          - const: mux
+          - const: gpio
+
+unevaluatedProperties:
+  type: object
+  $ref: amlogic,meson-pinctrl-common.yaml#/$defs/meson-pins
+
+examples:
+  - |
+    periphs_pinctrl: pinctrl {
+      compatible = "amlogic,meson-a1-periphs-pinctrl";
+      #address-cells = <1>;
+      #size-cells = <1>;
+      ranges;
+
+      bank@400 {
+        reg = <0x0400 0x003c>,
+              <0x0480 0x0118>;
+        reg-names = "mux", "gpio";
+        gpio-controller;
+        #gpio-cells = <2>;
+        gpio-ranges = <&periphs_pinctrl 0 0 62>;
+      };
+
+      cec_ao_a_h_pins: cec_ao_a_h {
+        mux {
+          groups = "cec_ao_a_h";
+          function = "cec_ao_a_h";
+          bias-disable;
+        };
+      };
+    };
diff --git a/Documentation/devicetree/bindings/pinctrl/amlogic,meson-pinctrl-common.yaml b/Documentation/devicetree/bindings/pinctrl/amlogic,meson-pinctrl-common.yaml
new file mode 100644 (file)
index 0000000..a7b29ef
--- /dev/null
@@ -0,0 +1,57 @@
+# SPDX-License-Identifier: (GPL-2.0-only OR BSD-2-Clause)
+%YAML 1.2
+---
+$id: http://devicetree.org/schemas/pinctrl/amlogic,meson-pinctrl-common.yaml#
+$schema: http://devicetree.org/meta-schemas/core.yaml#
+
+title: Amlogic Meson pinmux controller
+
+maintainers:
+  - Neil Armstrong <neil.armstrong@linaro.org>
+
+allOf:
+  - $ref: pinctrl.yaml#
+
+properties:
+  ranges: true
+
+  "#address-cells":
+    enum: [1, 2]
+
+  "#size-cells":
+    enum: [1, 2]
+
+required:
+  - ranges
+  - "#address-cells"
+  - "#size-cells"
+
+additionalProperties: true
+
+$defs:
+  meson-gpio:
+    type: object
+
+    properties:
+      gpio-controller: true
+
+      "#gpio-cells":
+        const: 2
+
+      gpio-ranges:
+        maxItems: 1
+
+    required:
+      - reg
+      - reg-names
+      - gpio-controller
+      - "#gpio-cells"
+      - gpio-ranges
+
+  meson-pins:
+    type: object
+    additionalProperties:
+      type: object
+      allOf:
+        - $ref: pincfg-node.yaml#
+        - $ref: pinmux-node.yaml#
diff --git a/Documentation/devicetree/bindings/pinctrl/amlogic,meson-pinctrl-g12a-aobus.yaml b/Documentation/devicetree/bindings/pinctrl/amlogic,meson-pinctrl-g12a-aobus.yaml
new file mode 100644 (file)
index 0000000..7c9c94e
--- /dev/null
@@ -0,0 +1,68 @@
+# SPDX-License-Identifier: (GPL-2.0-only OR BSD-2-Clause)
+%YAML 1.2
+---
+$id: http://devicetree.org/schemas/pinctrl/amlogic,meson-pinctrl-g12a-aobus.yaml#
+$schema: http://devicetree.org/meta-schemas/core.yaml#
+
+title: Amlogic Meson G12 AOBUS pinmux controller
+
+maintainers:
+  - Neil Armstrong <neil.armstrong@linaro.org>
+
+allOf:
+  - $ref: amlogic,meson-pinctrl-common.yaml#
+
+properties:
+  compatible:
+    enum:
+      - amlogic,meson-g12a-aobus-pinctrl
+
+required:
+  - compatible
+
+patternProperties:
+  "^bank@[0-9a-z]+$":
+    $ref: amlogic,meson-pinctrl-common.yaml#/$defs/meson-gpio
+
+    unevaluatedProperties: false
+
+    properties:
+      reg:
+        maxItems: 3
+
+      reg-names:
+        items:
+          - const: mux
+          - const: ds
+          - const: gpio
+
+unevaluatedProperties:
+  type: object
+  $ref: amlogic,meson-pinctrl-common.yaml#/$defs/meson-pins
+
+examples:
+  - |
+    ao_pinctrl: pinctrl {
+      compatible = "amlogic,meson-g12a-aobus-pinctrl";
+      #address-cells = <1>;
+      #size-cells = <1>;
+      ranges;
+
+      bank@14 {
+        reg = <0x14 0x8>,
+              <0x1c 0x8>,
+              <0x24 0x14>;
+        reg-names = "mux", "ds", "gpio";
+        gpio-controller;
+        #gpio-cells = <2>;
+        gpio-ranges = <&ao_pinctrl 0 0 15>;
+      };
+
+      cec_ao_a_h_pins: cec_ao_a_h {
+        mux {
+          groups = "cec_ao_a_h";
+          function = "cec_ao_a_h";
+          bias-disable;
+        };
+      };
+    };
diff --git a/Documentation/devicetree/bindings/pinctrl/amlogic,meson-pinctrl-g12a-periphs.yaml b/Documentation/devicetree/bindings/pinctrl/amlogic,meson-pinctrl-g12a-periphs.yaml
new file mode 100644 (file)
index 0000000..4bcb8b6
--- /dev/null
@@ -0,0 +1,72 @@
+# SPDX-License-Identifier: (GPL-2.0-only OR BSD-2-Clause)
+%YAML 1.2
+---
+$id: http://devicetree.org/schemas/pinctrl/amlogic,meson-pinctrl-g12a-periphs.yaml#
+$schema: http://devicetree.org/meta-schemas/core.yaml#
+
+title: Amlogic Meson G12 PERIPHS pinmux controller
+
+maintainers:
+  - Neil Armstrong <neil.armstrong@linaro.org>
+
+allOf:
+  - $ref: amlogic,meson-pinctrl-common.yaml#
+
+properties:
+  compatible:
+    enum:
+      - amlogic,meson-g12a-periphs-pinctrl
+
+required:
+  - compatible
+
+patternProperties:
+  "^bank@[0-9a-z]+$":
+    $ref: amlogic,meson-pinctrl-common.yaml#/$defs/meson-gpio
+
+    unevaluatedProperties: false
+
+    properties:
+      reg:
+        maxItems: 5
+
+      reg-names:
+        items:
+          - const: gpio
+          - const: pull
+          - const: pull-enable
+          - const: mux
+          - const: ds
+
+unevaluatedProperties:
+  type: object
+  $ref: amlogic,meson-pinctrl-common.yaml#/$defs/meson-pins
+
+examples:
+  - |
+    periphs_pinctrl: pinctrl {
+      compatible = "amlogic,meson-g12a-periphs-pinctrl";
+      #address-cells = <1>;
+      #size-cells = <1>;
+      ranges;
+
+      bank@40 {
+        reg = <0x40  0x4c>,
+              <0xe8  0x18>,
+              <0x120 0x18>,
+              <0x2c0 0x40>,
+              <0x340 0x1c>;
+        reg-names = "gpio", "pull", "pull-enable", "mux", "ds";
+        gpio-controller;
+        #gpio-cells = <2>;
+        gpio-ranges = <&periphs_pinctrl 0 0 86>;
+      };
+
+      cec_ao_a_h_pins: cec_ao_a_h {
+        mux {
+          groups = "cec_ao_a_h";
+          function = "cec_ao_a_h";
+          bias-disable;
+        };
+      };
+    };
diff --git a/Documentation/devicetree/bindings/pinctrl/amlogic,meson8-pinctrl-aobus.yaml b/Documentation/devicetree/bindings/pinctrl/amlogic,meson8-pinctrl-aobus.yaml
new file mode 100644 (file)
index 0000000..32d99c9
--- /dev/null
@@ -0,0 +1,76 @@
+# SPDX-License-Identifier: (GPL-2.0-only OR BSD-2-Clause)
+%YAML 1.2
+---
+$id: http://devicetree.org/schemas/pinctrl/amlogic,meson8-pinctrl-aobus.yaml#
+$schema: http://devicetree.org/meta-schemas/core.yaml#
+
+title: Amlogic Meson8 AOBUS pinmux controller
+
+maintainers:
+  - Neil Armstrong <neil.armstrong@linaro.org>
+
+allOf:
+  - $ref: amlogic,meson-pinctrl-common.yaml#
+
+properties:
+  compatible:
+    oneOf:
+      - enum:
+          - amlogic,meson8-aobus-pinctrl
+          - amlogic,meson8b-aobus-pinctrl
+          - amlogic,meson-gxbb-aobus-pinctrl
+          - amlogic,meson-gxl-aobus-pinctrl
+          - amlogic,meson-axg-aobus-pinctrl
+      - items:
+          - const: amlogic,meson8m2-aobus-pinctrl
+          - const: amlogic,meson8-aobus-pinctrl
+
+required:
+  - compatible
+
+patternProperties:
+  "^bank@[0-9a-z]+$":
+    $ref: amlogic,meson-pinctrl-common.yaml#/$defs/meson-gpio
+
+    unevaluatedProperties: false
+
+    properties:
+      reg:
+        maxItems: 3
+
+      reg-names:
+        items:
+          - const: mux
+          - const: pull
+          - const: gpio
+
+unevaluatedProperties:
+  type: object
+  $ref: amlogic,meson-pinctrl-common.yaml#/$defs/meson-pins
+
+examples:
+  - |
+    pinctrl_aobus: pinctrl {
+      compatible = "amlogic,meson8-aobus-pinctrl";
+      #address-cells = <1>;
+      #size-cells = <1>;
+      ranges;
+
+      bank@14 {
+        reg = <0x14 0x4>,
+              <0x2c 0x4>,
+              <0x24 0x8>;
+        reg-names = "mux", "pull", "gpio";
+        gpio-controller;
+        #gpio-cells = <2>;
+        gpio-ranges = <&pinctrl_aobus 0 0 16>;
+      };
+
+      cec_ao_a_h_pins: cec_ao_a_h {
+        mux {
+          groups = "cec_ao_a_h";
+          function = "cec_ao_a_h";
+          bias-disable;
+        };
+      };
+    };
diff --git a/Documentation/devicetree/bindings/pinctrl/amlogic,meson8-pinctrl-cbus.yaml b/Documentation/devicetree/bindings/pinctrl/amlogic,meson8-pinctrl-cbus.yaml
new file mode 100644 (file)
index 0000000..d044105
--- /dev/null
@@ -0,0 +1,78 @@
+# SPDX-License-Identifier: (GPL-2.0-only OR BSD-2-Clause)
+%YAML 1.2
+---
+$id: http://devicetree.org/schemas/pinctrl/amlogic,meson8-pinctrl-cbus.yaml#
+$schema: http://devicetree.org/meta-schemas/core.yaml#
+
+title: Amlogic Meson8 CBUS pinmux controller
+
+maintainers:
+  - Neil Armstrong <neil.armstrong@linaro.org>
+
+allOf:
+  - $ref: amlogic,meson-pinctrl-common.yaml#
+
+properties:
+  compatible:
+    oneOf:
+      - enum:
+          - amlogic,meson8-cbus-pinctrl
+          - amlogic,meson8b-cbus-pinctrl
+          - amlogic,meson-gxbb-periphs-pinctrl
+          - amlogic,meson-gxl-periphs-pinctrl
+          - amlogic,meson-axg-periphs-pinctrl
+      - items:
+          - const: amlogic,meson8m2-cbus-pinctrl
+          - const: amlogic,meson8-cbus-pinctrl
+
+required:
+  - compatible
+
+patternProperties:
+  "^bank@[0-9a-z]+$":
+    $ref: amlogic,meson-pinctrl-common.yaml#/$defs/meson-gpio
+
+    unevaluatedProperties: false
+
+    properties:
+      reg:
+        maxItems: 4
+
+      reg-names:
+        items:
+          - const: mux
+          - const: pull
+          - const: pull-enable
+          - const: gpio
+
+unevaluatedProperties:
+  type: object
+  $ref: amlogic,meson-pinctrl-common.yaml#/$defs/meson-pins
+
+examples:
+  - |
+    pinctrl_cbus: pinctrl {
+      compatible = "amlogic,meson8-cbus-pinctrl";
+      #address-cells = <1>;
+      #size-cells = <1>;
+      ranges;
+
+      bank@80b0 {
+        reg = <0x80b0 0x28>,
+              <0x80e8 0x18>,
+              <0x8120 0x18>,
+              <0x8030 0x30>;
+        reg-names = "mux", "pull", "pull-enable", "gpio";
+        gpio-controller;
+        #gpio-cells = <2>;
+        gpio-ranges = <&pinctrl_cbus 0 0 120>;
+      };
+
+      cec_ao_a_h_pins: cec_ao_a_h {
+        mux {
+          groups = "cec_ao_a_h";
+          function = "cec_ao_a_h";
+          bias-disable;
+        };
+      };
+    };
index 684c03a6bd4049879a401c6ee044ad07121c0458..9c07935919ea56ef881d9056b27089330a0cc11f 100644 (file)
@@ -74,7 +74,7 @@ patternProperties:
     additionalProperties: false
 
 allOf:
-  - $ref: "pinctrl.yaml#"
+  - $ref: pinctrl.yaml#
 
 required:
   - compatible
index f4f1ee6b116e854a6ca37f4db8b6320169ab2e6a..bef85c25cdef5bce80c27a539e0bd17c30439520 100644 (file)
@@ -32,7 +32,7 @@ patternProperties:
     then:
       patternProperties:
         "^function|groups$":
-          $ref: "/schemas/types.yaml#/definitions/string"
+          $ref: /schemas/types.yaml#/definitions/string
           enum: [ ACPI, ADC0, ADC1, ADC10, ADC11, ADC12, ADC13, ADC14, ADC15,
                   ADC2, ADC3, ADC4, ADC5, ADC6, ADC7, ADC8, ADC9, BMCINT, DDCCLK, DDCDAT,
                   EXTRST, FLACK, FLBUSY, FLWP, GPID, GPID0, GPID2, GPID4, GPID6, GPIE0,
@@ -51,7 +51,7 @@ patternProperties:
                   VGAHS, VGAVS, VPI18, VPI24, VPI30, VPO12, VPO24, WDTRST1, WDTRST2]
 
 allOf:
-  - $ref: "pinctrl.yaml#"
+  - $ref: pinctrl.yaml#
 
 required:
   - compatible
index 8168f00884710e4c7c08a14a11ae709e1a70c15c..14c391f168990524fdbf114c5044903b643f41f1 100644 (file)
@@ -44,7 +44,7 @@ patternProperties:
     then:
       patternProperties:
         "^function|groups$":
-          $ref: "/schemas/types.yaml#/definitions/string"
+          $ref: /schemas/types.yaml#/definitions/string
           enum: [ ACPI, ADC0, ADC1, ADC10, ADC11, ADC12, ADC13, ADC14, ADC15,
                   ADC2, ADC3, ADC4, ADC5, ADC6, ADC7, ADC8, ADC9, BMCINT, DDCCLK, DDCDAT,
                   ESPI, FWSPICS1, FWSPICS2, GPID0, GPID2, GPID4, GPID6, GPIE0, GPIE2,
@@ -65,7 +65,7 @@ patternProperties:
                   VGAVS, VPI24, VPO, WDTRST1, WDTRST2]
 
 allOf:
-  - $ref: "pinctrl.yaml#"
+  - $ref: pinctrl.yaml#
 
 required:
   - compatible
index 62424c42c981944afbb091244659c6abdd20464a..859a1889dc1e72fcb1f1275d1c40e04ce2ccaae4 100644 (file)
@@ -30,7 +30,7 @@ patternProperties:
     then:
       properties:
         function:
-          $ref: "/schemas/types.yaml#/definitions/string"
+          $ref: /schemas/types.yaml#/definitions/string
           enum: [ ADC0, ADC1, ADC10, ADC11, ADC12, ADC13, ADC14, ADC15, ADC2,
                   ADC3, ADC4, ADC5, ADC6, ADC7, ADC8, ADC9, BMCINT, EMMC, ESPI, ESPIALT,
                   FSI1, FSI2, FWQSPI, FWSPIABR, FWSPID, FWSPIWP, GPIT0, GPIT1, GPIT2, GPIT3,
@@ -55,7 +55,7 @@ patternProperties:
                   USB2BD, USB2BH, VB, VGAHS, VGAVS, WDTRST1, WDTRST2, WDTRST3, WDTRST4 ]
 
         groups:
-          $ref: "/schemas/types.yaml#/definitions/string"
+          $ref: /schemas/types.yaml#/definitions/string
           enum: [ ADC0, ADC1, ADC10, ADC11, ADC12, ADC13, ADC14, ADC15, ADC2,
                   ADC3, ADC4, ADC5, ADC6, ADC7, ADC8, ADC9, BMCINT, EMMCG1, EMMCG4,
                   EMMCG8, ESPI, ESPIALT, FSI1, FSI2, FWQSPI, FWSPIABR, FWSPID, FWSPIWP,
@@ -84,7 +84,7 @@ patternProperties:
                   WDTRST3, WDTRST4]
 
 allOf:
-  - $ref: "pinctrl.yaml#"
+  - $ref: pinctrl.yaml#
 
 required:
   - compatible
index ab019a1998e85693da4ad5f14423f3f6d0d221ef..4478a76171f7f2a2121a25cbeb3393ddf1ebcb9a 100644 (file)
@@ -38,7 +38,7 @@ patternProperties:
                 gpio8, gpio9, gpio10, gpio11, gpio12, gpio13, gpio40 ]
 
 allOf:
-  - $ref: "pinctrl.yaml#"
+  - $ref: pinctrl.yaml#
 
 required:
   - compatible
index 8c9d4668c8c43f6cd3ec065e8dd459e79caedb9f..73e1caa7c011abbf73e6cdf1accc8a6ea40248eb 100644 (file)
@@ -42,7 +42,7 @@ patternProperties:
                 vdsl_phy_override_3_grp, dsl_gpio8, dsl_gpio9 ]
 
 allOf:
-  - $ref: "pinctrl.yaml#"
+  - $ref: pinctrl.yaml#
 
 required:
   - compatible
index a8e22ec02215fd735f91415bc55d959b6ce9e537..2750ba42aeb8e998f5317e97577a2f2b5a68fe53 100644 (file)
@@ -37,7 +37,7 @@ patternProperties:
                 usb_port1 ]
 
 allOf:
-  - $ref: "pinctrl.yaml#"
+  - $ref: pinctrl.yaml#
 
 required:
   - compatible
index 35867355a47ad1aa1b20a3d314e90dee3dcfbbc6..2f6c540498bc6708cba88b62f59c6c8012bfafb8 100644 (file)
@@ -35,7 +35,7 @@ patternProperties:
                 led_grp, spi_cs_grp, utopia_grp, pwm_syn_clk, sys_irq_grp ]
 
 allOf:
-  - $ref: "pinctrl.yaml#"
+  - $ref: pinctrl.yaml#
 
 required:
   - compatible
index b584d4b272231b572a0bc1b33f0efe6ba97df048..b3044f805753ace0f9d2253f5179e79218ea2927 100644 (file)
@@ -42,7 +42,7 @@ patternProperties:
                 gpio22, gpio23, gpio24, gpio25, gpio26, gpio27, nand_grp ]
 
 allOf:
-  - $ref: "pinctrl.yaml#"
+  - $ref: pinctrl.yaml#
 
 required:
   - compatible
index 229323d9237d5705fcc1a9196ff1e6a237fa5b1f..3236871827df9d17226be6966e3f2e6c132823eb 100644 (file)
@@ -43,7 +43,7 @@ patternProperties:
                 gpio31, uart1_grp ]
 
 allOf:
-  - $ref: "pinctrl.yaml#"
+  - $ref: pinctrl.yaml#
 
 required:
   - compatible
index 8d1e5b1cdd5f18c982a5ebfb865b97eeab0e847d..0a39dd26ee1a2499ebd192294ee621e56c87f459 100644 (file)
@@ -53,7 +53,7 @@ patternProperties:
     additionalProperties: false
 
 allOf:
-  - $ref: "pinctrl.yaml#"
+  - $ref: pinctrl.yaml#
   - if:
       properties:
         compatible:
index a78cb2796001b8380b9e01f5ff57bf9e85dc9006..7f4f36a58e56cba672fdd4b12ca3e496c6e4fc2e 100644 (file)
@@ -144,7 +144,7 @@ patternProperties:
     additionalProperties: false
 
 allOf:
-  - $ref: "pinctrl.yaml#"
+  - $ref: pinctrl.yaml#
 
 required:
   - compatible
index 5cd512b7d5ba31882d4fc5369f19384913e2b90c..5e000b3fadde3a707d36a94e3755513fd3fbe9af 100644 (file)
@@ -173,7 +173,7 @@ properties:
     additionalProperties: false
 
 allOf:
-  - $ref: "pinctrl.yaml#"
+  - $ref: pinctrl.yaml#
 
 required:
   - compatible
index 6bd42e43cdabe3bfcd0be176501f4ef4f32ae574..bb61a30321a1c572159b614f39567b4af417e972 100644 (file)
@@ -40,8 +40,8 @@ properties:
       '-pins$':
         type: object
         allOf:
-          - $ref: "pincfg-node.yaml#"
-          - $ref: "pinmux-node.yaml#"
+          - $ref: pincfg-node.yaml#
+          - $ref: pinmux-node.yaml#
         properties:
           groups:
             description:
index 915cbbcc3555027db32fb79a006f0370ee2a4384..222d57541b656f710a54119214ff49a2e7a292c4 100644 (file)
@@ -109,7 +109,7 @@ required:
 additionalProperties: false
 
 allOf:
-  - $ref: "pinctrl.yaml#"
+  - $ref: pinctrl.yaml#
 
 examples:
   - |
index 62103866218813b66fb08a5ba91ae1f11daeb25a..7bd723ab12814328ec477394c6665ece2bfd3d07 100644 (file)
@@ -68,7 +68,7 @@ patternProperties:
     additionalProperties: false
 
 allOf:
-  - $ref: "pinctrl.yaml#"
+  - $ref: pinctrl.yaml#
 
 required:
   - compatible
index 7ae0843972585460ab1d6c6648c1e03ae4dd6dff..6068be11dfe28ca4f0538329042dde5a793ab466 100644 (file)
@@ -65,7 +65,7 @@ patternProperties:
     additionalProperties: false
 
 allOf:
-  - $ref: "pinctrl.yaml#"
+  - $ref: pinctrl.yaml#
 
 required:
   - compatible
index 693398d882236933696e8e3a8f680a2a837c69ce..7dcf681271d3ad81827fbe419877f54fee06016d 100644 (file)
@@ -57,7 +57,7 @@ patternProperties:
     additionalProperties: false
 
 allOf:
-  - $ref: "pinctrl.yaml#"
+  - $ref: pinctrl.yaml#
 
 required:
   - compatible
index 66baa6082a4fe5745950923f4831ff6639064b58..2f2405102996d819034f2c45b8ab52ddca48e8ce 100644 (file)
@@ -14,7 +14,7 @@ description:
   for common binding part and usage.
 
 allOf:
-  - $ref: "pinctrl.yaml#"
+  - $ref: pinctrl.yaml#
 
 properties:
   compatible:
index a4397930e0e8009511fa42a6ac2367ed6794baaf..35723966b70ac00d6596b786087e8cf1263d26f7 100644 (file)
@@ -119,7 +119,7 @@ patternProperties:
     additionalProperties: false
 
 allOf:
-  - $ref: "pinctrl.yaml#"
+  - $ref: pinctrl.yaml#
 
 required:
   - compatible
index ca0fef6e535e2b3e67ddb5956810068ac336c053..1144ca2896e336374a9f62850d8a152be90cd22c 100644 (file)
@@ -48,7 +48,7 @@ patternProperties:
     additionalProperties: false
 
 allOf:
-  - $ref: "pinctrl.yaml#"
+  - $ref: pinctrl.yaml#
 
 required:
   - compatible
diff --git a/Documentation/devicetree/bindings/pinctrl/intel,pinctrl-thunderbay.yaml b/Documentation/devicetree/bindings/pinctrl/intel,pinctrl-thunderbay.yaml
deleted file mode 100644 (file)
index f001add..0000000
+++ /dev/null
@@ -1,120 +0,0 @@
-# SPDX-License-Identifier: (GPL-2.0 OR BSD-2-Clause)
-%YAML 1.2
----
-$id: http://devicetree.org/schemas/pinctrl/intel,pinctrl-thunderbay.yaml#
-$schema: http://devicetree.org/meta-schemas/core.yaml#
-
-title: Intel Thunder Bay pin controller
-
-maintainers:
-  - Lakshmi Sowjanya D <lakshmi.sowjanya.d@intel.com>
-
-description: |
-  Intel Thunder Bay SoC integrates a pin controller which enables control
-  of pin directions, input/output values and configuration
-  for a total of 67 pins.
-
-properties:
-  compatible:
-    const: intel,thunderbay-pinctrl
-
-  reg:
-    maxItems: 1
-
-  gpio-controller: true
-
-  '#gpio-cells':
-    const: 2
-
-  gpio-ranges:
-    maxItems: 1
-
-  interrupts:
-    description:
-      Specifies the interrupt lines to be used by the controller.
-    maxItems: 2
-
-  interrupt-controller: true
-
-  '#interrupt-cells':
-    const: 2
-
-patternProperties:
-  '^gpio@[0-9a-f]*$':
-    type: object
-    additionalProperties: false
-
-    description:
-      Child nodes can be specified to contain pin configuration information,
-      which can then be utilized by pinctrl client devices.
-      The following properties are supported.
-
-    properties:
-      pins:
-        description: |
-          The name(s) of the pins to be configured in the child node.
-          Supported pin names are "GPIO0" up to "GPIO66".
-
-      bias-disable: true
-
-      bias-pull-down: true
-
-      bias-pull-up: true
-
-      drive-strength:
-        description: Drive strength for the pad.
-        enum: [0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15]
-
-      bias-bus-hold:
-        type: boolean
-
-      input-schmitt-enable:
-        type: boolean
-
-      slew-rate:
-        description: GPIO slew rate control.
-                      0 - Slow
-                      1 - Fast
-        enum: [0, 1]
-
-additionalProperties: false
-
-required:
-  - compatible
-  - reg
-  - gpio-controller
-  - '#gpio-cells'
-  - gpio-ranges
-  - interrupts
-  - interrupt-controller
-  - '#interrupt-cells'
-
-examples:
-  - |
-    #include <dt-bindings/interrupt-controller/arm-gic.h>
-    #include <dt-bindings/interrupt-controller/irq.h>
-    // Example 1
-    pinctrl0: gpio@0 {
-        compatible = "intel,thunderbay-pinctrl";
-        reg = <0x600b0000 0x88>;
-        gpio-controller;
-        #gpio-cells = <0x2>;
-        gpio-ranges = <&pinctrl0 0 0 67>;
-        interrupts = <GIC_SPI 94 IRQ_TYPE_LEVEL_HIGH>,
-                     <GIC_SPI 95 IRQ_TYPE_LEVEL_HIGH>;
-        interrupt-controller;
-        #interrupt-cells = <2>;
-    };
-
-    // Example 2
-    pinctrl1: gpio@1 {
-        compatible = "intel,thunderbay-pinctrl";
-        reg = <0x600c0000 0x88>;
-        gpio-controller;
-        #gpio-cells = <0x2>;
-        gpio-ranges = <&pinctrl1 0 0 53>;
-        interrupts = <GIC_SPI 94 IRQ_TYPE_LEVEL_HIGH>,
-                     <GIC_SPI 95 IRQ_TYPE_LEVEL_HIGH>;
-        interrupt-controller;
-        #interrupt-cells = <2>;
-    };
index 4658f105fa09e43f0b24731207ddb344194fa217..6bd9bc61becbb90c97bb599417ee08007407c308 100644 (file)
@@ -1,11 +1,7 @@
 Lantiq XWAY pinmux controller
 
 Required properties:
-- compatible: "lantiq,pinctrl-xway", (DEPRECATED: Use "lantiq,pinctrl-danube")
-             "lantiq,pinctrl-xr9", (DEPRECATED: Use "lantiq,xrx100-pinctrl" or
-                                       "lantiq,xrx200-pinctrl")
-             "lantiq,pinctrl-ase", (DEPRECATED: Use "lantiq,ase-pinctrl")
-             "lantiq,<chip>-pinctrl", where <chip> is:
+- compatible:  "lantiq,<chip>-pinctrl", where <chip> is:
                "ase" (XWAY AMAZON Family)
                "danube" (XWAY DANUBE Family)
                "xrx100" (XWAY xRX100 Family)
@@ -45,29 +41,6 @@ Required subnode-properties:
 
 Valid values for group and function names:
 
-XWAY: (DEPRECATED: Use DANUBE)
-  mux groups:
-    exin0, exin1, exin2, jtag, ebu a23, ebu a24, ebu a25, ebu clk, ebu cs1,
-    ebu wait, nand ale, nand cs1, nand cle, spi, spi_cs1, spi_cs2, spi_cs3,
-    spi_cs4, spi_cs5, spi_cs6, asc0, asc0 cts rts, stp, nmi, gpt1, gpt2,
-    gpt3, clkout0, clkout1, clkout2, clkout3, gnt1, gnt2, gnt3, req1, req2,
-    req3
-
-  functions:
-    spi, asc, cgu, jtag, exin, stp, gpt, nmi, pci, ebu
-
-XR9: ( DEPRECATED: Use xRX100/xRX200)
-  mux groups:
-    exin0, exin1, exin2, exin3, exin4, jtag, ebu a23, ebu a24, ebu a25,
-    ebu clk, ebu cs1, ebu wait, nand ale, nand cs1, nand cle, nand rdy,
-    nand rd, spi, spi_cs1, spi_cs2, spi_cs3, spi_cs4, spi_cs5, spi_cs6,
-    asc0, asc0 cts rts, stp, nmi, gpt1, gpt2, gpt3, clkout0, clkout1,
-    clkout2, clkout3, gnt1, gnt2, gnt3, gnt4, req1, req2, req3, req4, mdio,
-    gphy0 led0, gphy0 led1, gphy0 led2, gphy1 led0, gphy1 led1, gphy1 led2
-
-  functions:
-    spi, asc, cgu, jtag, exin, stp, gpt, nmi, pci, ebu, mdio, gphy
-
 AMAZON:
   mux groups:
     exin0, exin1, exin2, jtag, spi_di, spi_do, spi_clk, spi_cs1, spi_cs2,
@@ -139,12 +112,6 @@ Optional subnode-properties:
     0: none, 1: down, 2: up.
 - lantiq,open-drain: Boolean, enables open-drain on the defined pin.
 
-Valid values for XWAY pin names: (DEPRECATED: Use DANUBE)
-  Pinconf pins can be referenced via the names io0-io31.
-
-Valid values for XR9 pin names: (DEPRECATED: Use xrX100/xRX200)
-  Pinconf pins can be referenced via the names io0-io55.
-
 Valid values for AMAZON pin names:
   Pinconf pins can be referenced via the names io0-io31.
 
index 491f67e7cc4fa42db9b87bf862d7cafa9e8b51f4..afea9424c7e15f9733fd95a072adeea1ec59b763 100644 (file)
@@ -28,7 +28,7 @@ patternProperties:
 
     properties:
       marvell,function:
-        $ref: "/schemas/types.yaml#/definitions/string"
+        $ref: /schemas/types.yaml#/definitions/string
         description:
           Indicates the function to select.
         enum: [ dev_init_done, ge, gpio, i2c0, i2c1, int_out, led, nand, pcie, ptp, sdio,
@@ -47,7 +47,7 @@ patternProperties:
                   mpp40, mpp41, mpp42, mpp43, mpp44, mpp45 ]
 
 allOf:
-  - $ref: "pinctrl.yaml#"
+  - $ref: pinctrl.yaml#
 
 required:
   - compatible
index a55c8e4ff26efcd609ca1b9f1d7de602be5fde55..bccff08a5ba3f53fe91dfb1106a1e507d3eb1def 100644 (file)
@@ -4,13 +4,13 @@
 $id: http://devicetree.org/schemas/pinctrl/mediatek,mt65xx-pinctrl.yaml#
 $schema: http://devicetree.org/meta-schemas/core.yaml#
 
-title: Mediatek MT65xx Pin Controller
+title: MediaTek MT65xx Pin Controller
 
 maintainers:
   - Sean Wang <sean.wang@kernel.org>
 
-description: |+
-  The Mediatek's Pin controller is used to control SoC pins.
+description:
+  The MediaTek's MT65xx Pin controller is used to control SoC pins.
 
 properties:
   compatible:
@@ -30,7 +30,7 @@ properties:
 
   pins-are-numbered:
     $ref: /schemas/types.yaml#/definitions/flag
-    description: |
+    description:
       Specify the subnodes are using numbered pinmux to specify pins. (UNUSED)
     deprecated: true
 
@@ -38,10 +38,10 @@ properties:
 
   "#gpio-cells":
     const: 2
-    description: |
-      Number of cells in GPIO specifier. Since the generic GPIO
-      binding is used, the amount of cells must be specified as 2. See the below
-      mentioned gpio binding representation for description of particular cells.
+    description:
+      Number of cells in GPIO specifier. Since the generic GPIO binding is used,
+      the amount of cells must be specified as 2. See the below mentioned gpio
+      binding representation for description of particular cells.
 
   mediatek,pctl-regmap:
     $ref: /schemas/types.yaml#/definitions/phandle-array
@@ -49,7 +49,7 @@ properties:
       maxItems: 1
     minItems: 1
     maxItems: 2
-    description: |
+    description:
       Should be phandles of the syscfg node.
 
   interrupt-controller: true
@@ -67,7 +67,7 @@ required:
   - "#gpio-cells"
 
 allOf:
-  - $ref: "pinctrl.yaml#"
+  - $ref: pinctrl.yaml#
 
 patternProperties:
   'pins$':
@@ -77,25 +77,25 @@ patternProperties:
       '(^pins|pins?$)':
         type: object
         additionalProperties: false
-        description: |
+        description:
           A pinctrl node should contain at least one subnodes representing the
           pinctrl groups available on the machine. Each subnode will list the
           pins it needs, and how they should be configured, with regard to muxer
           configuration, pullups, drive strength, input enable/disable and input
           schmitt.
-        $ref: "/schemas/pinctrl/pincfg-node.yaml"
+        $ref: /schemas/pinctrl/pincfg-node.yaml
 
         properties:
           pinmux:
             description:
-              integer array, represents gpio pin number and mux setting.
+              Integer array, represents gpio pin number and mux setting.
               Supported pin number and mux varies for different SoCs, and are
-              defined as macros in <soc>-pinfunc.h directly.
+              defined as macros in dt-bindings/pinctrl/<soc>-pinfunc.h directly.
 
           bias-disable: true
 
           bias-pull-up:
-            description: |
+            description:
               Besides generic pinconfig options, it can be used as the pull up
               settings for 2 pull resistors, R0 and R1. User can configure those
               special pins. Some macros have been defined for this usage, such
@@ -117,7 +117,7 @@ patternProperties:
           input-schmitt-disable: true
 
           drive-strength:
-            description: |
+            description:
               Can support some arguments, such as MTK_DRIVE_4mA, MTK_DRIVE_6mA,
               etc. See dt-bindings/pinctrl/mt65xx.h for valid arguments.
 
index a2141eb0854e670a1036af582017162fe5ef79f8..7f0e2d6cd6d9a679d6e897c5211c0e8789920692 100644 (file)
@@ -4,15 +4,15 @@
 $id: http://devicetree.org/schemas/pinctrl/mediatek,mt6779-pinctrl.yaml#
 $schema: http://devicetree.org/meta-schemas/core.yaml#
 
-title: Mediatek MT6779 Pin Controller
+title: MediaTek MT6779 Pin Controller
 
 maintainers:
   - Andy Teng <andy.teng@mediatek.com>
   - Sean Wang <sean.wang@kernel.org>
 
 description:
-  The MediaTek pin controller on MT6779 is used to control pin
-  functions, pull up/down resistance and drive strength options.
+  The MediaTek pin controller on MT6779 is used to control pin functions, pull
+  up/down resistance and drive strength options.
 
 properties:
   compatible:
@@ -29,22 +29,22 @@ properties:
 
   "#gpio-cells":
     const: 2
-    description: |
-      Number of cells in GPIO specifier. Since the generic GPIO
-      binding is used, the amount of cells must be specified as 2. See the below
-      mentioned gpio binding representation for description of particular cells.
+    description:
+      Number of cells in GPIO specifier. Since the generic GPIO binding is used,
+      the amount of cells must be specified as 2. See the below mentioned gpio
+      binding representation for description of particular cells.
 
   gpio-ranges:
     minItems: 1
     maxItems: 5
-    description: |
+    description:
       GPIO valid number range.
 
   interrupt-controller: true
 
   interrupts:
     maxItems: 1
-    description: |
+    description:
       Specifies the summary IRQ.
 
   "#interrupt-cells":
@@ -58,7 +58,7 @@ required:
   - "#gpio-cells"
 
 allOf:
-  - $ref: "pinctrl.yaml#"
+  - $ref: pinctrl.yaml#
   - if:
       properties:
         compatible:
@@ -118,19 +118,20 @@ patternProperties:
     patternProperties:
       '-pins*$':
         type: object
-        description: |
+        description:
           A pinctrl node should contain at least one subnodes representing the
           pinctrl groups available on the machine. Each subnode will list the
           pins it needs, and how they should be configured, with regard to muxer
-          configuration, pullups, drive strength, input enable/disable and input schmitt.
-        $ref: "/schemas/pinctrl/pincfg-node.yaml"
+          configuration, pullups, drive strength, input enable/disable and input
+          schmitt.
+        $ref: /schemas/pinctrl/pincfg-node.yaml
 
         properties:
           pinmux:
             description:
-              integer array, represents gpio pin number and mux setting.
-              Supported pin number and mux varies for different SoCs, and are defined
-              as macros in boot/dts/<soc>-pinfunc.h directly.
+              Integer array, represents gpio pin number and mux setting.
+              Supported pin number and mux varies for different SoCs, and are
+              defined as macros in dt-bindings/pinctrl/<soc>-pinfunc.h directly.
 
           bias-disable: true
 
@@ -159,7 +160,8 @@ patternProperties:
           mediatek,pull-up-adv:
             description: |
               Pull up setings for 2 pull resistors, R0 and R1. User can
-              configure those special pins. Valid arguments are described as below:
+              configure those special pins. Valid arguments are described as
+              below:
               0: (R1, R0) = (0, 0) which means R1 disabled and R0 disabled.
               1: (R1, R0) = (0, 1) which means R1 disabled and R0 enabled.
               2: (R1, R0) = (1, 0) which means R1 enabled and R0 disabled.
@@ -170,7 +172,8 @@ patternProperties:
           mediatek,pull-down-adv:
             description: |
               Pull down settings for 2 pull resistors, R0 and R1. User can
-              configure those special pins. Valid arguments are described as below:
+              configure those special pins. Valid arguments are described as
+              below:
               0: (R1, R0) = (0, 0) which means R1 disabled and R0 disabled.
               1: (R1, R0) = (0, 1) which means R1 disabled and R0 enabled.
               2: (R1, R0) = (1, 0) which means R1 enabled and R0 disabled.
diff --git a/Documentation/devicetree/bindings/pinctrl/mediatek,mt6795-pinctrl.yaml b/Documentation/devicetree/bindings/pinctrl/mediatek,mt6795-pinctrl.yaml
new file mode 100644 (file)
index 0000000..601d86a
--- /dev/null
@@ -0,0 +1,228 @@
+# SPDX-License-Identifier: (GPL-2.0-only OR BSD-2-Clause)
+%YAML 1.2
+---
+$id: http://devicetree.org/schemas/pinctrl/mediatek,mt6795-pinctrl.yaml#
+$schema: http://devicetree.org/meta-schemas/core.yaml#
+
+title: MediaTek MT6795 Pin Controller
+
+maintainers:
+  - AngeloGioacchino Del Regno <angelogioacchino.delregno@collabora.com>
+  - Sean Wang <sean.wang@kernel.org>
+
+description:
+  The MediaTek's MT6795 Pin controller is used to control SoC pins.
+
+properties:
+  compatible:
+    const: mediatek,mt6795-pinctrl
+
+  gpio-controller: true
+
+  '#gpio-cells':
+    description:
+      Number of cells in GPIO specifier. Since the generic GPIO binding is used,
+      the amount of cells must be specified as 2. See the below mentioned gpio
+      binding representation for description of particular cells.
+    const: 2
+
+  gpio-ranges:
+    description: GPIO valid number range.
+    maxItems: 1
+
+  reg:
+    description:
+      Physical address base for GPIO base and eint registers.
+    minItems: 2
+
+  reg-names:
+    items:
+      - const: base
+      - const: eint
+
+  interrupt-controller: true
+
+  '#interrupt-cells':
+    const: 2
+
+  interrupts:
+    description: Interrupt outputs to the system interrupt controller (sysirq).
+    minItems: 1
+    items:
+      - description: EINT interrupt
+      - description: EINT event_b interrupt
+
+# PIN CONFIGURATION NODES
+patternProperties:
+  '-pins$':
+    type: object
+    additionalProperties: false
+    patternProperties:
+      '^pins':
+        type: object
+        additionalProperties: false
+        description: |
+          A pinctrl node should contain at least one subnodes representing the
+          pinctrl groups available on the machine. Each subnode will list the
+          pins it needs, and how they should be configured, with regard to muxer
+          configuration, pullups, drive strength, input enable/disable and input
+          schmitt.
+          An example of using macro:
+          pincontroller {
+            /* GPIO0 set as multifunction GPIO0 */
+            gpio-pins {
+              pins {
+                pinmux = <PINMUX_GPIO0__FUNC_GPIO0>;
+              }
+            };
+            /* GPIO45 set as multifunction SDA0 */
+            i2c0-pins {
+              pins {
+                pinmux = <PINMUX_GPIO45__FUNC_SDA0>;
+              }
+            };
+          };
+        $ref: pinmux-node.yaml
+
+        properties:
+          pinmux:
+            description:
+              Integer array, represents gpio pin number and mux setting.
+              Supported pin number and mux varies for different SoCs, and are
+              defined as macros in dt-bindings/pinctrl/<soc>-pinfunc.h directly.
+
+          drive-strength:
+            enum: [2, 4, 6, 8, 10, 12, 14, 16]
+
+          bias-pull-down:
+            oneOf:
+              - type: boolean
+              - enum: [100, 101, 102, 103]
+                description: mt6795 pull down PUPD/R0/R1 type define value.
+            description:
+              For normal pull down type, it is not necessary to specify R1R0
+              values; When pull down type is PUPD/R0/R1, adding R1R0 defines
+              will set different resistance values.
+
+          bias-pull-up:
+            oneOf:
+              - type: boolean
+              - enum: [100, 101, 102, 103]
+                description: mt6795 pull up PUPD/R0/R1 type define value.
+            description:
+              For normal pull up type, it is not necessary to specify R1R0
+              values; When pull up type is PUPD/R0/R1, adding R1R0 defines will
+              set different resistance values.
+
+          bias-disable: true
+
+          output-high: true
+
+          output-low: true
+
+          input-enable: true
+
+          input-disable: true
+
+          input-schmitt-enable: true
+
+          input-schmitt-disable: true
+
+          mediatek,pull-up-adv:
+            description: |
+              Pull up setings for 2 pull resistors, R0 and R1. User can
+              configure those special pins. Valid arguments are described as
+              below:
+              0: (R1, R0) = (0, 0) which means R1 disabled and R0 disabled.
+              1: (R1, R0) = (0, 1) which means R1 disabled and R0 enabled.
+              2: (R1, R0) = (1, 0) which means R1 enabled and R0 disabled.
+              3: (R1, R0) = (1, 1) which means R1 enabled and R0 enabled.
+            $ref: /schemas/types.yaml#/definitions/uint32
+            enum: [0, 1, 2, 3]
+
+          mediatek,pull-down-adv:
+            description: |
+              Pull down settings for 2 pull resistors, R0 and R1. User can
+              configure those special pins. Valid arguments are described as
+              below:
+              0: (R1, R0) = (0, 0) which means R1 disabled and R0 disabled.
+              1: (R1, R0) = (0, 1) which means R1 disabled and R0 enabled.
+              2: (R1, R0) = (1, 0) which means R1 enabled and R0 disabled.
+              3: (R1, R0) = (1, 1) which means R1 enabled and R0 enabled.
+            $ref: /schemas/types.yaml#/definitions/uint32
+            enum: [0, 1, 2, 3]
+
+        required:
+          - pinmux
+
+allOf:
+  - $ref: pinctrl.yaml#
+
+required:
+  - compatible
+  - reg
+  - reg-names
+  - interrupts
+  - interrupt-controller
+  - '#interrupt-cells'
+  - gpio-controller
+  - '#gpio-cells'
+  - gpio-ranges
+
+additionalProperties: false
+
+examples:
+  - |
+    #include <dt-bindings/interrupt-controller/arm-gic.h>
+    #include <dt-bindings/interrupt-controller/irq.h>
+    #include <dt-bindings/pinctrl/mt6795-pinfunc.h>
+
+    soc {
+        #address-cells = <2>;
+        #size-cells = <2>;
+
+        pio: pinctrl@10005000 {
+            compatible = "mediatek,mt6795-pinctrl";
+            reg = <0 0x10005000 0 0x1000>, <0 0x1000b000 0 0x1000>;
+            reg-names = "base", "eint";
+            gpio-controller;
+            #gpio-cells = <2>;
+            gpio-ranges = <&pio 0 0 196>;
+            interrupt-controller;
+            interrupts = <GIC_SPI 153 IRQ_TYPE_LEVEL_HIGH>;
+            #interrupt-cells = <2>;
+
+            i2c0-pins {
+                pins-sda-scl {
+                    pinmux = <PINMUX_GPIO45__FUNC_SDA0>,
+                             <PINMUX_GPIO46__FUNC_SCL0>;
+                };
+            };
+
+            mmc0-pins {
+                pins-cmd-dat {
+                    pinmux = <PINMUX_GPIO154__FUNC_MSDC0_DAT0>,
+                             <PINMUX_GPIO155__FUNC_MSDC0_DAT1>,
+                             <PINMUX_GPIO156__FUNC_MSDC0_DAT2>,
+                             <PINMUX_GPIO157__FUNC_MSDC0_DAT3>,
+                             <PINMUX_GPIO158__FUNC_MSDC0_DAT4>,
+                             <PINMUX_GPIO159__FUNC_MSDC0_DAT5>,
+                             <PINMUX_GPIO160__FUNC_MSDC0_DAT6>,
+                             <PINMUX_GPIO161__FUNC_MSDC0_DAT7>,
+                             <PINMUX_GPIO162__FUNC_MSDC0_CMD>;
+                    input-enable;
+                    bias-pull-up = <MTK_PUPD_SET_R1R0_01>;
+                };
+
+                pins-clk {
+                    pinmux = <PINMUX_GPIO163__FUNC_MSDC0_CLK>;
+                    bias-pull-down = <MTK_PUPD_SET_R1R0_10>;
+                };
+
+                pins-rst {
+                    pinmux = <PINMUX_GPIO165__FUNC_MSDC0_RSTB>;
+                    bias-pull-up = <MTK_PUPD_SET_R1R0_10>;
+                };
+            };
+        };
+    };
diff --git a/Documentation/devicetree/bindings/pinctrl/mediatek,mt7620-pinctrl.yaml b/Documentation/devicetree/bindings/pinctrl/mediatek,mt7620-pinctrl.yaml
new file mode 100644 (file)
index 0000000..591bc06
--- /dev/null
@@ -0,0 +1,298 @@
+# SPDX-License-Identifier: GPL-2.0-only OR BSD-2-Clause
+%YAML 1.2
+---
+$id: http://devicetree.org/schemas/pinctrl/mediatek,mt7620-pinctrl.yaml#
+$schema: http://devicetree.org/meta-schemas/core.yaml#
+
+title: MediaTek MT7620 Pin Controller
+
+maintainers:
+  - Arınç ÜNAL <arinc.unal@arinc9.com>
+  - Sergio Paracuellos <sergio.paracuellos@gmail.com>
+
+description: |
+  MediaTek MT7620 pin controller for MT7620 SoC.
+  The pin controller can only set the muxing of pin groups. Muxing individual
+  pins is not supported. There is no pinconf support.
+
+properties:
+  compatible:
+    const: ralink,mt7620-pinctrl
+
+patternProperties:
+  '-pins$':
+    type: object
+    additionalProperties: false
+
+    patternProperties:
+      '^(.*-)?pinmux$':
+        type: object
+        description: node for pinctrl.
+        $ref: pinmux-node.yaml#
+        additionalProperties: false
+
+        properties:
+          function:
+            description:
+              A string containing the name of the function to mux to the group.
+            enum: [ephy, gpio, gpio i2s, gpio uartf, i2c, i2s uartf, mdio, nand,
+                   pa, pcie refclk, pcie rst, pcm gpio, pcm i2s, pcm uartf,
+                   refclk, rgmii1, rgmii2, sd, spi, spi refclk, uartf, uartlite,
+                   wdt refclk, wdt rst, wled]
+
+          groups:
+            description:
+              An array of strings. Each string contains the name of a group.
+            maxItems: 1
+
+        required:
+          - groups
+          - function
+
+        allOf:
+          - if:
+              properties:
+                function:
+                  const: ephy
+            then:
+              properties:
+                groups:
+                  enum: [ephy]
+
+          - if:
+              properties:
+                function:
+                  const: gpio
+            then:
+              properties:
+                groups:
+                  enum: [ephy, i2c, mdio, nd_sd, pa, pcie, rgmii1, rgmii2, spi,
+                         spi refclk, uartf, uartlite, wdt, wled]
+
+          - if:
+              properties:
+                function:
+                  const: gpio i2s
+            then:
+              properties:
+                groups:
+                  enum: [uartf]
+
+          - if:
+              properties:
+                function:
+                  const: gpio uartf
+            then:
+              properties:
+                groups:
+                  enum: [uartf]
+
+          - if:
+              properties:
+                function:
+                  const: i2c
+            then:
+              properties:
+                groups:
+                  enum: [i2c]
+
+          - if:
+              properties:
+                function:
+                  const: i2s uartf
+            then:
+              properties:
+                groups:
+                  enum: [uartf]
+
+          - if:
+              properties:
+                function:
+                  const: mdio
+            then:
+              properties:
+                groups:
+                  enum: [mdio]
+
+          - if:
+              properties:
+                function:
+                  const: nand
+            then:
+              properties:
+                groups:
+                  enum: [nd_sd]
+
+          - if:
+              properties:
+                function:
+                  const: pa
+            then:
+              properties:
+                groups:
+                  enum: [pa]
+
+          - if:
+              properties:
+                function:
+                  const: pcie refclk
+            then:
+              properties:
+                groups:
+                  enum: [pcie]
+
+          - if:
+              properties:
+                function:
+                  const: pcie rst
+            then:
+              properties:
+                groups:
+                  enum: [pcie]
+
+          - if:
+              properties:
+                function:
+                  const: pcm gpio
+            then:
+              properties:
+                groups:
+                  enum: [uartf]
+
+          - if:
+              properties:
+                function:
+                  const: pcm i2s
+            then:
+              properties:
+                groups:
+                  enum: [uartf]
+
+          - if:
+              properties:
+                function:
+                  const: pcm uartf
+            then:
+              properties:
+                groups:
+                  enum: [uartf]
+
+          - if:
+              properties:
+                function:
+                  const: refclk
+            then:
+              properties:
+                groups:
+                  enum: [mdio]
+
+          - if:
+              properties:
+                function:
+                  const: rgmii1
+            then:
+              properties:
+                groups:
+                  enum: [rgmii1]
+
+          - if:
+              properties:
+                function:
+                  const: rgmii2
+            then:
+              properties:
+                groups:
+                  enum: [rgmii2]
+
+          - if:
+              properties:
+                function:
+                  const: sd
+            then:
+              properties:
+                groups:
+                  enum: [nd_sd]
+
+          - if:
+              properties:
+                function:
+                  const: spi
+            then:
+              properties:
+                groups:
+                  enum: [spi]
+
+          - if:
+              properties:
+                function:
+                  const: spi refclk
+            then:
+              properties:
+                groups:
+                  enum: [spi refclk]
+
+          - if:
+              properties:
+                function:
+                  const: uartf
+            then:
+              properties:
+                groups:
+                  enum: [uartf]
+
+          - if:
+              properties:
+                function:
+                  const: uartlite
+            then:
+              properties:
+                groups:
+                  enum: [uartlite]
+
+          - if:
+              properties:
+                function:
+                  const: wdt refclk
+            then:
+              properties:
+                groups:
+                  enum: [wdt]
+
+          - if:
+              properties:
+                function:
+                  const: wdt rst
+            then:
+              properties:
+                groups:
+                  enum: [wdt]
+
+          - if:
+              properties:
+                function:
+                  const: wled
+            then:
+              properties:
+                groups:
+                  enum: [wled]
+
+allOf:
+  - $ref: pinctrl.yaml#
+
+required:
+  - compatible
+
+additionalProperties: false
+
+examples:
+  - |
+    pinctrl {
+      compatible = "ralink,mt7620-pinctrl";
+
+      i2c_pins: i2c0-pins {
+        pinmux {
+          groups = "i2c";
+          function = "i2c";
+        };
+      };
+    };
diff --git a/Documentation/devicetree/bindings/pinctrl/mediatek,mt7621-pinctrl.yaml b/Documentation/devicetree/bindings/pinctrl/mediatek,mt7621-pinctrl.yaml
new file mode 100644 (file)
index 0000000..e568b9c
--- /dev/null
@@ -0,0 +1,261 @@
+# SPDX-License-Identifier: GPL-2.0-only OR BSD-2-Clause
+%YAML 1.2
+---
+$id: http://devicetree.org/schemas/pinctrl/mediatek,mt7621-pinctrl.yaml#
+$schema: http://devicetree.org/meta-schemas/core.yaml#
+
+title: MediaTek MT7621 Pin Controller
+
+maintainers:
+  - Arınç ÜNAL <arinc.unal@arinc9.com>
+  - Sergio Paracuellos <sergio.paracuellos@gmail.com>
+
+description: |
+  MediaTek MT7621 pin controller for MT7621 SoC.
+  The pin controller can only set the muxing of pin groups. Muxing individual
+  pins is not supported. There is no pinconf support.
+
+properties:
+  compatible:
+    const: ralink,mt7621-pinctrl
+
+patternProperties:
+  '-pins$':
+    type: object
+    additionalProperties: false
+
+    patternProperties:
+      '^(.*-)?pinmux$':
+        type: object
+        description: node for pinctrl.
+        $ref: pinmux-node.yaml#
+        additionalProperties: false
+
+        properties:
+          function:
+            description:
+              A string containing the name of the function to mux to the group.
+            enum: [gpio, i2c, i2s, jtag, mdio, nand1, nand2, pcie refclk,
+                   pcie rst, pcm, rgmii1, rgmii2, sdhci, spdif2, spdif3, spi,
+                   uart1, uart2, uart3, wdt refclk, wdt rst]
+
+          groups:
+            description:
+              An array of strings. Each string contains the name of a group.
+            maxItems: 1
+
+        required:
+          - groups
+          - function
+
+        allOf:
+          - if:
+              properties:
+                function:
+                  const: gpio
+            then:
+              properties:
+                groups:
+                  enum: [i2c, jtag, mdio, pcie, rgmii1, rgmii2, sdhci, spi,
+                         uart1, uart2, uart3, wdt]
+
+          - if:
+              properties:
+                function:
+                  const: i2c
+            then:
+              properties:
+                groups:
+                  enum: [i2c]
+
+          - if:
+              properties:
+                function:
+                  const: i2s
+            then:
+              properties:
+                groups:
+                  enum: [uart3]
+
+          - if:
+              properties:
+                function:
+                  const: jtag
+            then:
+              properties:
+                groups:
+                  enum: [jtag]
+
+          - if:
+              properties:
+                function:
+                  const: mdio
+            then:
+              properties:
+                groups:
+                  enum: [mdio]
+
+          - if:
+              properties:
+                function:
+                  const: nand1
+            then:
+              properties:
+                groups:
+                  enum: [spi]
+
+          - if:
+              properties:
+                function:
+                  const: nand2
+            then:
+              properties:
+                groups:
+                  enum: [sdhci]
+
+          - if:
+              properties:
+                function:
+                  const: pcie refclk
+            then:
+              properties:
+                groups:
+                  enum: [pcie]
+
+          - if:
+              properties:
+                function:
+                  const: pcie rst
+            then:
+              properties:
+                groups:
+                  enum: [pcie]
+
+          - if:
+              properties:
+                function:
+                  const: pcm
+            then:
+              properties:
+                groups:
+                  enum: [uart2]
+
+          - if:
+              properties:
+                function:
+                  const: rgmii1
+            then:
+              properties:
+                groups:
+                  enum: [rgmii1]
+
+          - if:
+              properties:
+                function:
+                  const: rgmii2
+            then:
+              properties:
+                groups:
+                  enum: [rgmii2]
+
+          - if:
+              properties:
+                function:
+                  const: sdhci
+            then:
+              properties:
+                groups:
+                  enum: [sdhci]
+
+          - if:
+              properties:
+                function:
+                  const: spdif2
+            then:
+              properties:
+                groups:
+                  enum: [uart2]
+
+          - if:
+              properties:
+                function:
+                  const: spdif3
+            then:
+              properties:
+                groups:
+                  enum: [uart3]
+
+          - if:
+              properties:
+                function:
+                  const: spi
+            then:
+              properties:
+                groups:
+                  enum: [spi]
+
+          - if:
+              properties:
+                function:
+                  const: uart1
+            then:
+              properties:
+                groups:
+                  enum: [uart1]
+
+          - if:
+              properties:
+                function:
+                  const: uart2
+            then:
+              properties:
+                groups:
+                  enum: [uart2]
+
+          - if:
+              properties:
+                function:
+                  const: uart3
+            then:
+              properties:
+                groups:
+                  enum: [uart3]
+
+          - if:
+              properties:
+                function:
+                  const: wdt refclk
+            then:
+              properties:
+                groups:
+                  enum: [wdt]
+
+          - if:
+              properties:
+                function:
+                  const: wdt rst
+            then:
+              properties:
+                groups:
+                  enum: [wdt]
+
+allOf:
+  - $ref: pinctrl.yaml#
+
+required:
+  - compatible
+
+additionalProperties: false
+
+examples:
+  - |
+    pinctrl {
+      compatible = "ralink,mt7621-pinctrl";
+
+      i2c_pins: i2c0-pins {
+        pinmux {
+          groups = "i2c";
+          function = "i2c";
+        };
+      };
+    };
index ac93eb8f01a6e79d7e86d6c71d6f47385fcf3a86..bd72a326e6e069cbccc25b1cf394b0f9595c33af 100644 (file)
@@ -4,12 +4,12 @@
 $id: http://devicetree.org/schemas/pinctrl/mediatek,mt7622-pinctrl.yaml#
 $schema: http://devicetree.org/meta-schemas/core.yaml#
 
-title: Mediatek MT7622 Pin Controller
+title: MediaTek MT7622 Pin Controller
 
 maintainers:
   - Sean Wang <sean.wang@kernel.org>
 
-description: |+
+description:
   The MediaTek's MT7622 Pin controller is used to control SoC pins.
 
 properties:
@@ -29,10 +29,10 @@ properties:
 
   "#gpio-cells":
     const: 2
-    description: |
-      Number of cells in GPIO specifier. Since the generic GPIO
-      binding is used, the amount of cells must be specified as 2. See the below
-      mentioned gpio binding representation for description of particular cells.
+    description:
+      Number of cells in GPIO specifier. Since the generic GPIO binding is used,
+      the amount of cells must be specified as 2. See the below mentioned gpio
+      binding representation for description of particular cells.
 
   interrupt-controller: true
 
@@ -43,7 +43,7 @@ properties:
     const: 2
 
 allOf:
-  - $ref: "pinctrl.yaml#"
+  - $ref: pinctrl.yaml#
 
 required:
   - compatible
@@ -68,18 +68,18 @@ patternProperties:
       '^mux(-|$)':
         type: object
         additionalProperties: false
-        description: |
+        description:
           pinmux configuration nodes.
-        $ref: "/schemas/pinctrl/pinmux-node.yaml"
+        $ref: /schemas/pinctrl/pinmux-node.yaml
         properties:
           function:
-            description: |
+            description:
               A string containing the name of the function to mux to the group.
             enum: [emmc, eth, i2c, i2s, ir, led, flash, pcie, pmic, pwm, sd,
                    spi, tdm, uart, watchdog, wifi]
 
           groups:
-            description: |
+            description:
               An array of strings. Each string contains the name of a group.
 
           drive-strength:
@@ -247,18 +247,18 @@ patternProperties:
       '^conf(-|$)':
         type: object
         additionalProperties: false
-        description: |
+        description:
           pinconf configuration nodes.
-        $ref: "/schemas/pinctrl/pincfg-node.yaml"
+        $ref: /schemas/pinctrl/pincfg-node.yaml
 
         properties:
           groups:
-            description: |
+            description:
               An array of strings. Each string contains the name of a group.
               Valid values are the same as the pinmux node.
 
           pins:
-            description: |
+            description:
               An array of strings. Each string contains the name of a pin.
             enum: [GPIO_A, I2S1_IN, I2S1_OUT, I2S_BCLK, I2S_WS, I2S_MCLK, TXD0,
                    RXD0, SPI_WP, SPI_HOLD, SPI_CLK, SPI_MOSI, SPI_MISO, SPI_CS,
@@ -315,14 +315,14 @@ patternProperties:
             enum: [0, 1]
 
           mediatek,tdsel:
-            description: |
+            description:
               An integer describing the steps for output level shifter duty
               cycle when asserted (high pulse width adjustment). Valid arguments
               are from 0 to 15.
             $ref: /schemas/types.yaml#/definitions/uint32
 
           mediatek,rdsel:
-            description: |
+            description:
               An integer describing the steps for input level shifter duty cycle
               when asserted (high pulse width adjustment). Valid arguments are
               from 0 to 63.
diff --git a/Documentation/devicetree/bindings/pinctrl/mediatek,mt76x8-pinctrl.yaml b/Documentation/devicetree/bindings/pinctrl/mediatek,mt76x8-pinctrl.yaml
new file mode 100644 (file)
index 0000000..31849dd
--- /dev/null
@@ -0,0 +1,450 @@
+# SPDX-License-Identifier: GPL-2.0-only OR BSD-2-Clause
+%YAML 1.2
+---
+$id: http://devicetree.org/schemas/pinctrl/mediatek,mt76x8-pinctrl.yaml#
+$schema: http://devicetree.org/meta-schemas/core.yaml#
+
+title: MediaTek MT76X8 Pin Controller
+
+maintainers:
+  - Arınç ÜNAL <arinc.unal@arinc9.com>
+  - Sergio Paracuellos <sergio.paracuellos@gmail.com>
+
+description: |
+  MediaTek MT76X8 pin controller for MT7628 and MT7688 SoCs.
+  The pin controller can only set the muxing of pin groups. Muxing individual
+  pins is not supported. There is no pinconf support.
+
+properties:
+  compatible:
+    const: ralink,mt76x8-pinctrl
+
+patternProperties:
+  '-pins$':
+    type: object
+    additionalProperties: false
+
+    patternProperties:
+      '^(.*-)?pinmux$':
+        type: object
+        description: node for pinctrl.
+        $ref: pinmux-node.yaml#
+        additionalProperties: false
+
+        properties:
+          function:
+            description:
+              A string containing the name of the function to mux to the group.
+            enum: [antenna, debug, gpio, i2c, i2s, jtag, p0led_an, p0led_kn,
+                   p1led_an, p1led_kn, p2led_an, p2led_kn, p3led_an, p3led_kn,
+                   p4led_an, p4led_kn, pcie, pcm, perst, pwm, pwm0, pwm1,
+                   pwm_uart2, refclk, rsvd, sdxc, sdxc d5 d4, sdxc d6, sdxc d7,
+                   spi, spi cs1, spis, sw_r, uart0, uart1, uart2, utif, wdt,
+                   wled_an, wled_kn, -]
+
+          groups:
+            description:
+              An array of strings. Each string contains the name of a group.
+            maxItems: 1
+
+        required:
+          - groups
+          - function
+
+        allOf:
+          - if:
+              properties:
+                function:
+                  const: antenna
+            then:
+              properties:
+                groups:
+                  enum: [i2s]
+
+          - if:
+              properties:
+                function:
+                  const: debug
+            then:
+              properties:
+                groups:
+                  enum: [i2c]
+
+          - if:
+              properties:
+                function:
+                  const: gpio
+            then:
+              properties:
+                groups:
+                  enum: [gpio, i2c, i2s, p0led_an, p0led_kn, p1led_an, p1led_kn,
+                         p2led_an, p2led_kn, p3led_an, p3led_kn, p4led_an,
+                         p4led_kn, perst, pwm0, pwm1, refclk, sdmode, spi,
+                         spi cs1, spis, uart0, uart1, uart2, wdt, wled_an,
+                         wled_kn]
+
+          - if:
+              properties:
+                function:
+                  const: i2c
+            then:
+              properties:
+                groups:
+                  enum: [i2c]
+
+          - if:
+              properties:
+                function:
+                  const: i2s
+            then:
+              properties:
+                groups:
+                  enum: [i2s]
+
+          - if:
+              properties:
+                function:
+                  const: jtag
+            then:
+              properties:
+                groups:
+                  enum: [p0led_an, p0led_kn, p1led_an, p1led_kn, p2led_an,
+                         p2led_kn, p3led_an, p3led_kn, p4led_an, p4led_kn,
+                         sdmode]
+
+          - if:
+              properties:
+                function:
+                  const: p0led_an
+            then:
+              properties:
+                groups:
+                  enum: [p0led_an]
+
+          - if:
+              properties:
+                function:
+                  const: p0led_kn
+            then:
+              properties:
+                groups:
+                  enum: [p0led_kn]
+
+          - if:
+              properties:
+                function:
+                  const: p1led_an
+            then:
+              properties:
+                groups:
+                  enum: [p1led_an]
+
+          - if:
+              properties:
+                function:
+                  const: p1led_kn
+            then:
+              properties:
+                groups:
+                  enum: [p1led_kn]
+
+          - if:
+              properties:
+                function:
+                  const: p2led_an
+            then:
+              properties:
+                groups:
+                  enum: [p2led_an]
+
+          - if:
+              properties:
+                function:
+                  const: p2led_kn
+            then:
+              properties:
+                groups:
+                  enum: [p2led_kn]
+
+          - if:
+              properties:
+                function:
+                  const: p3led_an
+            then:
+              properties:
+                groups:
+                  enum: [p3led_an]
+
+          - if:
+              properties:
+                function:
+                  const: p3led_kn
+            then:
+              properties:
+                groups:
+                  enum: [p3led_kn]
+
+          - if:
+              properties:
+                function:
+                  const: p4led_an
+            then:
+              properties:
+                groups:
+                  enum: [p4led_an]
+
+          - if:
+              properties:
+                function:
+                  const: p4led_kn
+            then:
+              properties:
+                groups:
+                  enum: [p4led_kn]
+
+          - if:
+              properties:
+                function:
+                  const: pcie
+            then:
+              properties:
+                groups:
+                  enum: [gpio]
+
+          - if:
+              properties:
+                function:
+                  const: pcm
+            then:
+              properties:
+                groups:
+                  enum: [i2s]
+
+          - if:
+              properties:
+                function:
+                  const: perst
+            then:
+              properties:
+                groups:
+                  enum: [perst]
+
+          - if:
+              properties:
+                function:
+                  const: pwm
+            then:
+              properties:
+                groups:
+                  enum: [uart1, uart2]
+
+          - if:
+              properties:
+                function:
+                  const: pwm0
+            then:
+              properties:
+                groups:
+                  enum: [pwm0]
+
+          - if:
+              properties:
+                function:
+                  const: pwm1
+            then:
+              properties:
+                groups:
+                  enum: [pwm1]
+
+          - if:
+              properties:
+                function:
+                  const: pwm_uart2
+            then:
+              properties:
+                groups:
+                  enum: [spis]
+
+          - if:
+              properties:
+                function:
+                  const: refclk
+            then:
+              properties:
+                groups:
+                  enum: [gpio, refclk, spi cs1]
+
+          - if:
+              properties:
+                function:
+                  const: rsvd
+            then:
+              properties:
+                groups:
+                  enum: [p0led_an, p0led_kn, wled_an, wled_kn]
+
+          - if:
+              properties:
+                function:
+                  const: sdxc
+            then:
+              properties:
+                groups:
+                  enum: [sdmode]
+
+          - if:
+              properties:
+                function:
+                  const: sdxc d5 d4
+            then:
+              properties:
+                groups:
+                  enum: [uart2]
+
+          - if:
+              properties:
+                function:
+                  const: sdxc d6
+            then:
+              properties:
+                groups:
+                  enum: [pwm1]
+
+          - if:
+              properties:
+                function:
+                  const: sdxc d7
+            then:
+              properties:
+                groups:
+                  enum: [pwm0]
+
+          - if:
+              properties:
+                function:
+                  const: spi
+            then:
+              properties:
+                groups:
+                  enum: [spi]
+
+          - if:
+              properties:
+                function:
+                  const: spi cs1
+            then:
+              properties:
+                groups:
+                  enum: [spi cs1]
+
+          - if:
+              properties:
+                function:
+                  const: spis
+            then:
+              properties:
+                groups:
+                  enum: [spis]
+
+          - if:
+              properties:
+                function:
+                  const: sw_r
+            then:
+              properties:
+                groups:
+                  enum: [uart1]
+
+          - if:
+              properties:
+                function:
+                  const: uart0
+            then:
+              properties:
+                groups:
+                  enum: [uart0]
+
+          - if:
+              properties:
+                function:
+                  const: uart1
+            then:
+              properties:
+                groups:
+                  enum: [uart1]
+
+          - if:
+              properties:
+                function:
+                  const: uart2
+            then:
+              properties:
+                groups:
+                  enum: [uart2]
+
+          - if:
+              properties:
+                function:
+                  const: utif
+            then:
+              properties:
+                groups:
+                  enum: [p1led_an, p1led_kn, p2led_an, p2led_kn, p3led_an,
+                         p3led_kn, p4led_an, p4led_kn, pwm0, pwm1, sdmode, spis]
+
+          - if:
+              properties:
+                function:
+                  const: wdt
+            then:
+              properties:
+                groups:
+                  enum: [wdt]
+
+          - if:
+              properties:
+                function:
+                  const: wled_an
+            then:
+              properties:
+                groups:
+                  enum: [wled_an]
+
+          - if:
+              properties:
+                function:
+                  const: wled_kn
+            then:
+              properties:
+                groups:
+                  enum: [wled_kn]
+
+          - if:
+              properties:
+                function:
+                  const: "-"
+            then:
+              properties:
+                groups:
+                  enum: [i2c, spi cs1, uart0]
+
+allOf:
+  - $ref: pinctrl.yaml#
+
+required:
+  - compatible
+
+additionalProperties: false
+
+examples:
+  - |
+    pinctrl {
+      compatible = "ralink,mt76x8-pinctrl";
+
+      i2c_pins: i2c0-pins {
+        pinmux {
+          groups = "i2c";
+          function = "i2c";
+        };
+      };
+    };
index 74c66fbcb2ae6c659275185ac6eec718c3939cb6..10717cee9058d65b6a8e37ca6828fa6f0d87a654 100644 (file)
@@ -4,7 +4,7 @@
 $id: http://devicetree.org/schemas/pinctrl/mediatek,mt7981-pinctrl.yaml#
 $schema: http://devicetree.org/meta-schemas/core.yaml#
 
-title: Mediatek MT7981 Pin Controller
+title: MediaTek MT7981 Pin Controller
 
 maintainers:
   - Daniel Golle <daniel@makrotopia.org>
@@ -37,7 +37,7 @@ properties:
 
   "#gpio-cells":
     const: 2
-    description: >
+    description:
       Number of cells in GPIO specifier. Since the generic GPIO binding is used,
       the amount of cells must be specified as 2. See the below mentioned gpio
       binding representation for description of particular cells.
@@ -111,7 +111,9 @@ patternProperties:
           "watchdog1"            "watchdog"  13
           "udi"                  "udi"       9, 10, 11, 12, 13
           "drv_vbus"             "usb"       14
-          "emmc_45"              "flash"     15, 16, 17, 18, 19, 20, 21, 22, 23, 24, 25
+          "emmc_45"              "flash"     15, 16, 17, 18, 19, 20, 21, 22, 23,
+                                             24, 25
+
           "snfi"                 "flash"     16, 17, 18, 19, 20, 21
           "spi0"                 "spi"       16, 17, 18, 19
           "spi0_wp_hold"         "spi"       20, 21
@@ -148,7 +150,7 @@ patternProperties:
           "wf5g_led0"            "led"       31
           "wf5g_led1"            "led"       35
           "mt7531_int"           "eth"       38
-          "ant_sel"              "ant"       14, 15, 16, 17, 18, 19, 20, 21, 22
+          "ant_sel"              "ant"       14, 15, 16, 17, 18, 19, 20, 21, 22,
                                              23, 24, 25, 34, 35
 
         $ref: /schemas/pinctrl/pinmux-node.yaml
@@ -256,7 +258,8 @@ patternProperties:
             then:
               properties:
                 groups:
-                  enum: [gbe_led0, gbe_led1, wf2g_led0, wf2g_led1, wf5g_led0, wf5g_led1]
+                  enum: [gbe_led0, gbe_led1, wf2g_led0, wf2g_led1, wf5g_led0,
+                         wf5g_led1]
           - if:
               properties:
                 function:
@@ -275,7 +278,8 @@ patternProperties:
               properties:
                 groups:
                   items:
-                    enum: [spi1_0, spi0, spi0_wp_hold, spi1_1, spi2, spi2_wp_hold]
+                    enum: [spi1_0, spi0, spi0_wp_hold, spi1_1, spi2,
+                           spi2_wp_hold]
                   maxItems: 4
           - if:
               properties:
@@ -332,13 +336,14 @@ patternProperties:
                      JTAG_JTDO, JTAG_JTDI, JTAG_JTMS, JTAG_JTCLK, JTAG_JTRST_N,
                      WO_JTAG_JTDO, WO_JTAG_JTDI, WO_JTAG_JTMS, WO_JTAG_JTCLK,
                      WO_JTAG_JTRST_N, USB_VBUS, PWM0, SPI0_CLK, SPI0_MOSI,
-                     SPI0_MISO, SPI0_CS, SPI0_HOLD, SPI0_WP, SPI1_CLK, SPI1_MOSI,
-                     SPI1_MISO, SPI1_CS, SPI2_CLK, SPI2_MOSI, SPI2_MISO, SPI2_CS,
-                     SPI2_HOLD, SPI2_WP, UART0_RXD, UART0_TXD, PCIE_CLK_REQ,
-                     PCIE_WAKE_N, SMI_MDC, SMI_MDIO, GBE_INT, GBE_RESET,
-                     WF_DIG_RESETB, WF_CBA_RESETB, WF_XO_REQ, WF_TOP_CLK,
-                     WF_TOP_DATA, WF_HB1, WF_HB2, WF_HB3, WF_HB4, WF_HB0,
-                     WF_HB0_B, WF_HB5, WF_HB6, WF_HB7, WF_HB8, WF_HB9, WF_HB10]
+                     SPI0_MISO, SPI0_CS, SPI0_HOLD, SPI0_WP, SPI1_CLK,
+                     SPI1_MOSI, SPI1_MISO, SPI1_CS, SPI2_CLK, SPI2_MOSI,
+                     SPI2_MISO, SPI2_CS, SPI2_HOLD, SPI2_WP, UART0_RXD,
+                     UART0_TXD, PCIE_CLK_REQ, PCIE_WAKE_N, SMI_MDC, SMI_MDIO,
+                     GBE_INT, GBE_RESET, WF_DIG_RESETB, WF_CBA_RESETB,
+                     WF_XO_REQ, WF_TOP_CLK, WF_TOP_DATA, WF_HB1, WF_HB2, WF_HB3,
+                     WF_HB4, WF_HB0, WF_HB0_B, WF_HB5, WF_HB6, WF_HB7, WF_HB8,
+                     WF_HB9, WF_HB10]
             maxItems: 57
 
           bias-disable: true
@@ -348,7 +353,7 @@ patternProperties:
               - type: boolean
                 description: normal pull up.
               - enum: [100, 101, 102, 103]
-                description: >
+                description:
                   PUPD/R1/R0 pull down type. See MTK_PUPD_SET_R1R0 defines in
                   dt-bindings/pinctrl/mt65xx.h.
 
@@ -357,7 +362,7 @@ patternProperties:
               - type: boolean
                 description: normal pull down.
               - enum: [100, 101, 102, 103]
-                description: >
+                description:
                   PUPD/R1/R0 pull down type. See MTK_PUPD_SET_R1R0 defines in
                   dt-bindings/pinctrl/mt65xx.h.
 
index 216b356cd5192660aa8923409fb0f68eea9dd456..0f615ada290a558704ae5e07a7abdbc9ed8cbf38 100644 (file)
@@ -4,12 +4,12 @@
 $id: http://devicetree.org/schemas/pinctrl/mediatek,mt7986-pinctrl.yaml#
 $schema: http://devicetree.org/meta-schemas/core.yaml#
 
-title: Mediatek MT7986 Pin Controller
+title: MediaTek MT7986 Pin Controller
 
 maintainers:
   - Sean Wang <sean.wang@kernel.org>
 
-description: |+
+description:
   The MediaTek's MT7986 Pin controller is used to control SoC pins.
 
 properties:
@@ -37,15 +37,15 @@ properties:
 
   "#gpio-cells":
     const: 2
-    description: |
-      Number of cells in GPIO specifier. Since the generic GPIO
-      binding is used, the amount of cells must be specified as 2. See the below
-      mentioned gpio binding representation for description of particular cells.
+    description:
+      Number of cells in GPIO specifier. Since the generic GPIO binding is used,
+      the amount of cells must be specified as 2. See the below mentioned gpio
+      binding representation for description of particular cells.
 
   gpio-ranges:
     minItems: 1
     maxItems: 5
-    description: |
+    description:
       GPIO valid number range.
 
   interrupt-controller: true
@@ -57,7 +57,7 @@ properties:
     const: 2
 
 allOf:
-  - $ref: "pinctrl.yaml#"
+  - $ref: pinctrl.yaml#
 
 required:
   - compatible
@@ -72,7 +72,7 @@ patternProperties:
     additionalProperties: false
 
     patternProperties:
-      '.*mux.*':
+      '^.*mux.*$':
         type: object
         additionalProperties: false
         description: |
@@ -81,7 +81,7 @@ patternProperties:
           The following table shows the effective values of "group", "function"
           properties and chip pinout pins
 
-          groups           function    pins (in pin#)
+          groups            function    pins (in pin#)
           ---------------------------------------------------------------------
           "watchdog"        "watchdog"  0
           "wifi_led"        "led"       1, 2
@@ -97,8 +97,9 @@ patternProperties:
           "pwm1_0"          "pwm"       22,
           "snfi"            "flash"     23, 24, 25, 26, 27, 28
           "spi1_2"          "spi"       29, 30, 31, 32
-          "emmc_45"         "emmc"      22, 23, 24, 25, 26, 27, 28, 29, 30,
-                                        31, 32
+          "emmc_45"         "emmc"      22, 23, 24, 25, 26, 27, 28, 29, 30, 31,
+                                        32
+
           "spi1_1"          "spi"       23, 24, 25, 26
           "uart1_2_rx_tx"   "uart"      29, 30
           "uart1_2_cts_rts" "uart"      31, 32
@@ -115,8 +116,9 @@ patternProperties:
           "pcie_pereset"    "pcie"      41
           "uart1"           "uart"      42, 43, 44, 45
           "uart2"           "uart"      46, 47, 48, 49
-          "emmc_51"         "emmc"      50, 51, 52, 53, 54, 55, 56, 57, 57,
-                                        59, 60, 61
+          "emmc_51"         "emmc"      50, 51, 52, 53, 54, 55, 56, 57, 58, 59,
+                                        60, 61
+
           "pcm"             "audio"     62, 63, 64, 65
           "i2s"             "audio"     62, 63, 64, 65
           "switch_int"      "eth"       66
@@ -126,21 +128,20 @@ patternProperties:
           "wf_dbdc"         "wifi"      74, 75, 76, 77, 78, 79, 80, 81, 82, 83,
                                         84, 85
 
-        $ref: "/schemas/pinctrl/pinmux-node.yaml"
+        $ref: /schemas/pinctrl/pinmux-node.yaml
         properties:
           function:
-            description: |
+            description:
               A string containing the name of the function to mux to the group.
               There is no "audio", "pcie" functions on mt7986b, you can only use
               those functions on mt7986a.
             enum: [audio, emmc, eth, i2c, led, flash, pcie, pwm, spi, uart,
                    watchdog, wifi]
           groups:
-            description: |
+            description:
               An array of strings. Each string contains the name of a group.
-              There is no "pcie_pereset", "uart1", "uart2" "emmc_51", "pcm",
-              and "i2s" groups on mt7986b, you can only use those groups on
-              mt7986a.
+              There is no "pcie_pereset", "uart1", "uart2" "emmc_51", "pcm", and
+              "i2s" groups on mt7986b, you can only use those groups on mt7986a.
         required:
           - function
           - groups
@@ -255,32 +256,33 @@ patternProperties:
                   items:
                     enum: [wf_2g, wf_5g, wf_dbdc]
                   maxItems: 3
-      '.*conf.*':
+      '^.*conf.*$':
         type: object
         additionalProperties: false
-        description: |
+        description:
           pinconf configuration nodes.
-        $ref: "/schemas/pinctrl/pincfg-node.yaml"
+        $ref: /schemas/pinctrl/pincfg-node.yaml
 
         properties:
           pins:
-            description: |
-              An array of strings. Each string contains the name of a pin.
-              There is no PIN 41 to PIN 65 above on mt7686b, you can only use
-              those pins on mt7986a.
+            description:
+              An array of strings. Each string contains the name of a pin. There
+              is no PIN 41 to PIN 65 above on mt7686b, you can only use those
+              pins on mt7986a.
             items:
               enum: [SYS_WATCHDOG, WF2G_LED, WF5G_LED, I2C_SCL, I2C_SDA, GPIO_0,
                      GPIO_1, GPIO_2, GPIO_3, GPIO_4, GPIO_5, GPIO_6, GPIO_7,
-                     GPIO_8, GPIO_9, GPIO_10, GPIO_11, GPIO_12, GPIO_13, GPIO_14,
-                     GPIO_15, PWM0, PWM1, SPI0_CLK, SPI0_MOSI, SPI0_MISO, SPI0_CS,
-                     SPI0_HOLD, SPI0_WP, SPI1_CLK, SPI1_MOSI, SPI1_MISO, SPI1_CS,
-                     SPI2_CLK, SPI2_MOSI, SPI2_MISO, SPI2_CS, SPI2_HOLD, SPI2_WP,
-                     UART0_RXD, UART0_TXD, PCIE_PERESET_N, UART1_RXD, UART1_TXD,
-                     UART1_CTS, UART1_RTS, UART2_RXD, UART2_TXD, UART2_CTS,
-                     UART2_RTS, EMMC_DATA_0, EMMC_DATA_1, EMMC_DATA_2,
-                     EMMC_DATA_3, EMMC_DATA_4, EMMC_DATA_5, EMMC_DATA_6,
-                     EMMC_DATA_7, EMMC_CMD, EMMC_CK, EMMC_DSL, EMMC_RSTB, PCM_DTX,
-                     PCM_DRX, PCM_CLK, PCM_FS, MT7531_INT, SMI_MDC, SMI_MDIO,
+                     GPIO_8, GPIO_9, GPIO_10, GPIO_11, GPIO_12, GPIO_13,
+                     GPIO_14, GPIO_15, PWM0, PWM1, SPI0_CLK, SPI0_MOSI,
+                     SPI0_MISO, SPI0_CS, SPI0_HOLD, SPI0_WP, SPI1_CLK,
+                     SPI1_MOSI, SPI1_MISO, SPI1_CS, SPI2_CLK, SPI2_MOSI,
+                     SPI2_MISO, SPI2_CS, SPI2_HOLD, SPI2_WP, UART0_RXD,
+                     UART0_TXD, PCIE_PERESET_N, UART1_RXD, UART1_TXD, UART1_CTS,
+                     UART1_RTS, UART2_RXD, UART2_TXD, UART2_CTS, UART2_RTS,
+                     EMMC_DATA_0, EMMC_DATA_1, EMMC_DATA_2, EMMC_DATA_3,
+                     EMMC_DATA_4, EMMC_DATA_5, EMMC_DATA_6, EMMC_DATA_7,
+                     EMMC_CMD, EMMC_CK, EMMC_DSL, EMMC_RSTB, PCM_DTX, PCM_DRX,
+                     PCM_CLK, PCM_FS, MT7531_INT, SMI_MDC, SMI_MDIO,
                      WF0_DIG_RESETB, WF0_CBA_RESETB, WF0_XO_REQ, WF0_TOP_CLK,
                      WF0_TOP_DATA, WF0_HB1, WF0_HB2, WF0_HB3, WF0_HB4, WF0_HB0,
                      WF0_HB0_B, WF0_HB5, WF0_HB6, WF0_HB7, WF0_HB8, WF0_HB9,
@@ -297,7 +299,7 @@ patternProperties:
               - type: boolean
                 description: normal pull up.
               - enum: [100, 101, 102, 103]
-                description: |
+                description:
                   PUPD/R1/R0 pull down type. See MTK_PUPD_SET_R1R0 defines in
                   dt-bindings/pinctrl/mt65xx.h.
 
@@ -306,7 +308,7 @@ patternProperties:
               - type: boolean
                 description: normal pull down.
               - enum: [100, 101, 102, 103]
-                description: |
+                description:
                   PUPD/R1/R0 pull down type. See MTK_PUPD_SET_R1R0 defines in
                   dt-bindings/pinctrl/mt65xx.h.
 
index c30cd0d010ddbf3080930ca26110b3fe725b0ba1..ff24cf29eea739f908dade2391d7528e3b200fac 100644 (file)
@@ -4,12 +4,12 @@
 $id: http://devicetree.org/schemas/pinctrl/mediatek,mt8183-pinctrl.yaml#
 $schema: http://devicetree.org/meta-schemas/core.yaml#
 
-title: Mediatek MT8183 Pin Controller
+title: MediaTek MT8183 Pin Controller
 
 maintainers:
   - Sean Wang <sean.wang@kernel.org>
 
-description: |+
+description:
   The MediaTek's MT8183 Pin controller is used to control SoC pins.
 
 properties:
@@ -37,15 +37,15 @@ properties:
 
   "#gpio-cells":
     const: 2
-    description: |
-      Number of cells in GPIO specifier. Since the generic GPIO
-      binding is used, the amount of cells must be specified as 2. See the below
-      mentioned gpio binding representation for description of particular cells.
+    description:
+      Number of cells in GPIO specifier. Since the generic GPIO binding is used,
+      the amount of cells must be specified as 2. See the below mentioned gpio
+      binding representation for description of particular cells.
 
   gpio-ranges:
     minItems: 1
     maxItems: 5
-    description: |
+    description:
       GPIO valid number range.
 
   interrupt-controller: true
@@ -57,7 +57,7 @@ properties:
     const: 2
 
 allOf:
-  - $ref: "pinctrl.yaml#"
+  - $ref: pinctrl.yaml#
 
 required:
   - compatible
@@ -74,18 +74,18 @@ patternProperties:
       '^pins':
         type: object
         additionalProperties: false
-        description: |
+        description:
           A pinctrl node should contain at least one subnodes representing the
           pinctrl groups available on the machine. Each subnode will list the
           pins it needs, and how they should be configured, with regard to muxer
           configuration, pullups, drive strength, input enable/disable and input
           schmitt.
-        $ref: "/schemas/pinctrl/pincfg-node.yaml"
+        $ref: /schemas/pinctrl/pincfg-node.yaml
 
         properties:
           pinmux:
             description:
-              integer array, represents gpio pin number and mux setting.
+              Integer array, represents gpio pin number and mux setting.
               Supported pin number and mux varies for different SoCs, and are
               defined as macros in <soc>-pinfunc.h directly.
 
@@ -110,8 +110,13 @@ patternProperties:
           drive-strength:
             enum: [2, 4, 6, 8, 10, 12, 14, 16]
 
+          drive-strength-microamp:
+            enum: [125, 250, 500, 1000]
+
           mediatek,drive-strength-adv:
+            deprecated: true
             description: |
+              DEPRECATED: Please use drive-strength-microamp instead.
               Describe the specific driving setup property.
               For I2C pins, the existing generic driving setup can only support
               2/4/6/8/10/12/14/16mA driving. But in specific driving setup, they
@@ -139,7 +144,8 @@ patternProperties:
           mediatek,pull-up-adv:
             description: |
               Pull up setings for 2 pull resistors, R0 and R1. User can
-              configure those special pins. Valid arguments are described as below:
+              configure those special pins. Valid arguments are described as
+              below:
               0: (R1, R0) = (0, 0) which means R1 disabled and R0 disabled.
               1: (R1, R0) = (0, 1) which means R1 disabled and R0 enabled.
               2: (R1, R0) = (1, 0) which means R1 enabled and R0 disabled.
@@ -150,7 +156,8 @@ patternProperties:
           mediatek,pull-down-adv:
             description: |
               Pull down settings for 2 pull resistors, R0 and R1. User can
-              configure those special pins. Valid arguments are described as below:
+              configure those special pins. Valid arguments are described as
+              below:
               0: (R1, R0) = (0, 0) which means R1 disabled and R0 disabled.
               1: (R1, R0) = (0, 1) which means R1 disabled and R0 enabled.
               2: (R1, R0) = (1, 0) which means R1 enabled and R0 disabled.
@@ -159,14 +166,14 @@ patternProperties:
             enum: [0, 1, 2, 3]
 
           mediatek,tdsel:
-            description: |
+            description:
               An integer describing the steps for output level shifter duty
               cycle when asserted (high pulse width adjustment). Valid arguments
               are from 0 to 15.
             $ref: /schemas/types.yaml#/definitions/uint32
 
           mediatek,rdsel:
-            description: |
+            description:
               An integer describing the steps for input level shifter duty cycle
               when asserted (high pulse width adjustment). Valid arguments are
               from 0 to 63.
@@ -215,7 +222,7 @@ examples:
               pinmux = <PINMUX_GPIO48__FUNC_SCL5>,
                 <PINMUX_GPIO49__FUNC_SDA5>;
               mediatek,pull-up-adv = <3>;
-              mediatek,drive-strength-adv = <7>;
+              drive-strength-microamp = <1000>;
             };
           };
 
@@ -224,7 +231,6 @@ examples:
               pinmux = <PINMUX_GPIO50__FUNC_SCL3>,
                 <PINMUX_GPIO51__FUNC_SDA3>;
               mediatek,pull-down-adv = <2>;
-              mediatek,drive-strength-adv = <4>;
             };
           };
         };
diff --git a/Documentation/devicetree/bindings/pinctrl/mediatek,mt8186-pinctrl.yaml b/Documentation/devicetree/bindings/pinctrl/mediatek,mt8186-pinctrl.yaml
new file mode 100644 (file)
index 0000000..69136dd
--- /dev/null
@@ -0,0 +1,275 @@
+# SPDX-License-Identifier: (GPL-2.0-only OR BSD-2-Clause)
+%YAML 1.2
+---
+$id: http://devicetree.org/schemas/pinctrl/mediatek,mt8186-pinctrl.yaml#
+$schema: http://devicetree.org/meta-schemas/core.yaml#
+
+title: MediaTek MT8186 Pin Controller
+
+maintainers:
+  - Sean Wang <sean.wang@mediatek.com>
+
+description:
+  The MediaTek's MT8186 Pin controller is used to control SoC pins.
+
+properties:
+  compatible:
+    const: mediatek,mt8186-pinctrl
+
+  gpio-controller: true
+
+  '#gpio-cells':
+    description:
+      Number of cells in GPIO specifier. Since the generic GPIO binding is used,
+      the amount of cells must be specified as 2. See the below mentioned gpio
+      binding representation for description of particular cells.
+    const: 2
+
+  gpio-ranges:
+    maxItems: 1
+
+  gpio-line-names: true
+
+  reg:
+    description:
+      Physical address base for GPIO base registers. There are 8 different GPIO
+      physical address base in mt8186.
+    maxItems: 8
+
+  reg-names:
+    description:
+      GPIO base register names.
+    items:
+      - const: iocfg0
+      - const: iocfg_lt
+      - const: iocfg_lm
+      - const: iocfg_lb
+      - const: iocfg_bl
+      - const: iocfg_rb
+      - const: iocfg_rt
+      - const: eint
+
+  interrupt-controller: true
+
+  '#interrupt-cells':
+    const: 2
+
+  interrupts:
+    description: The interrupt outputs to sysirq
+    maxItems: 1
+
+  mediatek,rsel-resistance-in-si-unit:
+    type: boolean
+    description:
+      Identifying i2c pins pull up/down type which is RSEL. It can support RSEL
+      define or si unit value(ohm) to set different resistance.
+
+# PIN CONFIGURATION NODES
+patternProperties:
+  '-pins$':
+    type: object
+    additionalProperties: false
+    patternProperties:
+      '^pins':
+        type: object
+        additionalProperties: false
+        description: |
+          A pinctrl node should contain at least one subnodes representing the
+          pinctrl groups available on the machine. Each subnode will list the
+          pins it needs, and how they should be configured, with regard to muxer
+          configuration, pullups, drive strength, input enable/disable and input
+          schmitt.
+          An example of using macro:
+          pincontroller {
+            /* GPIO0 set as multifunction GPIO0 */
+            gpio-pins {
+              pins {
+                pinmux = <PINMUX_GPIO0__FUNC_GPIO0>;
+              }
+            };
+            /* GPIO128 set as multifunction SDA0 */
+            i2c0-pins {
+              pins {
+                pinmux = <PINMUX_GPIO128__FUNC_SDA0>;
+              }
+            };
+          };
+        $ref: pinmux-node.yaml
+
+        properties:
+          pinmux:
+            description:
+              Integer array, represents gpio pin number and mux setting.
+              Supported pin number and mux varies for different SoCs, and are
+              defined as macros in dt-bindings/pinctrl/<soc>-pinfunc.h directly.
+
+          drive-strength:
+            enum: [2, 4, 6, 8, 10, 12, 14, 16]
+
+          drive-strength-microamp:
+            enum: [125, 250, 500, 1000]
+
+          bias-pull-down:
+            oneOf:
+              - type: boolean
+              - enum: [100, 101, 102, 103]
+                description: mt8186 pull down PUPD/R0/R1 type define value.
+              - enum: [200, 201, 202, 203]
+                description: mt8186 pull down RSEL type define value.
+              - enum: [75000, 5000]
+                description: mt8186 pull down RSEL type si unit value(ohm).
+            description: |
+              For pull down type is normal, it don't need add RSEL & R1R0 define
+              and resistance value.
+              For pull down type is PUPD/R0/R1 type, it can add R1R0 define to
+              set different resistance. It can support "MTK_PUPD_SET_R1R0_00" &
+              "MTK_PUPD_SET_R1R0_01" & "MTK_PUPD_SET_R1R0_10" &
+              "MTK_PUPD_SET_R1R0_11" define in mt8186.
+              For pull down type is RSEL, it can add RSEL define & resistance
+              value(ohm) to set different resistance by identifying property
+              "mediatek,rsel-resistance-in-si-unit".
+              It can support "MTK_PULL_SET_RSEL_000" & "MTK_PULL_SET_RSEL_001" &
+              "MTK_PULL_SET_RSEL_010" & "MTK_PULL_SET_RSEL_011" define in
+              mt8186. It can also support resistance value(ohm) "75000" & "5000"
+              in mt8186.
+              An example of using RSEL define:
+              pincontroller {
+                i2c0_pin {
+                  pins {
+                    pinmux = <PINMUX_GPIO128__FUNC_SDA0>;
+                    bias-pull-down = <MTK_PULL_SET_RSEL_001>;
+                  }
+                };
+              };
+              An example of using si unit resistance value(ohm):
+              &pio {
+                mediatek,rsel-resistance-in-si-unit;
+              }
+              pincontroller {
+                i2c0_pin {
+                  pins {
+                    pinmux = <PINMUX_GPIO128__FUNC_SDA0>;
+                    bias-pull-down = <75000>;
+                  }
+                };
+              };
+
+          bias-pull-up:
+            oneOf:
+              - type: boolean
+              - enum: [100, 101, 102, 103]
+                description: mt8186 pull up PUPD/R0/R1 type define value.
+              - enum: [200, 201, 202, 203]
+                description: mt8186 pull up RSEL type define value.
+              - enum: [1000, 5000, 10000, 75000]
+                description: mt8186 pull up RSEL type si unit value(ohm).
+            description: |
+              For pull up type is normal, it don't need add RSEL & R1R0 define
+              and resistance value.
+              For pull up type is PUPD/R0/R1 type, it can add R1R0 define to
+              set different resistance. It can support "MTK_PUPD_SET_R1R0_00" &
+              "MTK_PUPD_SET_R1R0_01" & "MTK_PUPD_SET_R1R0_10" &
+              "MTK_PUPD_SET_R1R0_11" define in mt8186.
+              For pull up type is RSEL, it can add RSEL define & resistance
+              value(ohm) to set different resistance by identifying property
+              "mediatek,rsel-resistance-in-si-unit".
+              It can support "MTK_PULL_SET_RSEL_000" & "MTK_PULL_SET_RSEL_001" &
+              "MTK_PULL_SET_RSEL_010" & "MTK_PULL_SET_RSEL_011" define in
+              mt8186. It can also support resistance value(ohm) "1000" & "5000"
+              & "10000" & "75000" in mt8186.
+              An example of using si unit resistance value(ohm):
+              &pio {
+                mediatek,rsel-resistance-in-si-unit;
+              }
+              pincontroller {
+                i2c0-pins {
+                  pins {
+                    pinmux = <PINMUX_GPIO128__FUNC_SDA0>;
+                    bias-pull-up = <1000>;
+                  }
+                };
+              };
+
+          bias-disable: true
+
+          output-high: true
+
+          output-low: true
+
+          input-enable: true
+
+          input-disable: true
+
+          input-schmitt-enable: true
+
+          input-schmitt-disable: true
+
+        required:
+          - pinmux
+
+required:
+  - compatible
+  - reg
+  - interrupts
+  - interrupt-controller
+  - '#interrupt-cells'
+  - gpio-controller
+  - '#gpio-cells'
+  - gpio-ranges
+
+additionalProperties: false
+
+examples:
+  - |
+    #include <dt-bindings/pinctrl/mt8186-pinfunc.h>
+    #include <dt-bindings/interrupt-controller/arm-gic.h>
+
+    pio: pinctrl@10005000 {
+      compatible = "mediatek,mt8186-pinctrl";
+      reg = <0x10005000 0x1000>,
+            <0x10002000 0x0200>,
+            <0x10002200 0x0200>,
+            <0x10002400 0x0200>,
+            <0x10002600 0x0200>,
+            <0x10002A00 0x0200>,
+            <0x10002c00 0x0200>,
+            <0x1000b000 0x1000>;
+      reg-names = "iocfg0", "iocfg_lt", "iocfg_lm",
+                  "iocfg_lb", "iocfg_bl", "iocfg_rb",
+                  "iocfg_rt", "eint";
+      gpio-controller;
+      #gpio-cells = <2>;
+      gpio-ranges = <&pio 0 0 185>;
+      interrupt-controller;
+      interrupts = <GIC_SPI 186 IRQ_TYPE_LEVEL_HIGH 0>;
+      #interrupt-cells = <2>;
+
+      pio-pins {
+        pins {
+          pinmux = <PINMUX_GPIO0__FUNC_GPIO0>;
+          output-low;
+        };
+      };
+
+      spi0-pins {
+        pins-spi {
+          pinmux = <PINMUX_GPIO0__FUNC_SPI0_CLK_B>,
+                   <PINMUX_GPIO1__FUNC_SPI0_CSB_B>,
+                   <PINMUX_GPIO2__FUNC_SPI0_MO_B>;
+          bias-disable;
+        };
+        pins-spi-mi {
+          pinmux = <PINMUX_GPIO3__FUNC_SPI0_MI_B>;
+          bias-pull-down;
+        };
+      };
+
+      i2c0-pins {
+        pins {
+          pinmux = <PINMUX_GPIO127__FUNC_SCL0>,
+                   <PINMUX_GPIO128__FUNC_SDA0>;
+          bias-pull-up = <MTK_PULL_SET_RSEL_001>;
+          drive-strength-microamp = <1000>;
+        };
+      };
+    };
index 7e750f1e643d02afb8ad46ca989c9ef3177ee8fb..e994b0c70dbfd26da2ac6ae3b86c9613bb1baed2 100644 (file)
@@ -9,7 +9,7 @@ title: MediaTek MT8188 Pin Controller
 maintainers:
   - Hui Liu <hui.liu@mediatek.com>
 
-description: |
+description:
   The MediaTek's MT8188 Pin controller is used to control SoC pins.
 
 properties:
@@ -19,10 +19,10 @@ properties:
   gpio-controller: true
 
   '#gpio-cells':
-    description: |
-      Number of cells in GPIO specifier, should be two. The first cell
-      is the pin number, the second cell is used to specify optional
-      parameters which are defined in <dt-bindings/gpio/gpio.h>.
+    description:
+      Number of cells in GPIO specifier, should be two. The first cell is the
+      pin number, the second cell is used to specify optional parameters which
+      are defined in <dt-bindings/gpio/gpio.h>.
     const: 2
 
   gpio-ranges:
@@ -59,10 +59,11 @@ properties:
 
   mediatek,rsel-resistance-in-si-unit:
     type: boolean
-    description: |
-      We provide two methods to select the resistance for I2C when pull up or pull down.
-      The first is by RSEL definition value, another one is by resistance value(ohm).
-      This flag is used to identify if the method is resistance(si unit) value.
+    description:
+      We provide two methods to select the resistance for I2C when pull up or
+      pull down. The first is by RSEL definition value, another one is by
+      resistance value(ohm). This flag is used to identify if the method is
+      resistance(si unit) value.
 
 # PIN CONFIGURATION NODES
 patternProperties:
@@ -73,22 +74,22 @@ patternProperties:
     patternProperties:
       '^pins':
         type: object
-        $ref: "/schemas/pinctrl/pincfg-node.yaml"
+        $ref: /schemas/pinctrl/pincfg-node.yaml
         additionalProperties: false
-        description: |
+        description:
           A pinctrl node should contain at least one subnode representing the
           pinctrl groups available on the machine. Each subnode will list the
           pins it needs, and how they should be configured, with regard to muxer
-          configuration, pullups, drive strength, input enable/disable and
-          input schmitt.
+          configuration, pullups, drive strength, input enable/disable and input
+          schmitt.
 
         properties:
           pinmux:
-            description: |
+            description:
               Integer array, represents gpio pin number and mux setting.
               Supported pin number and mux varies for different SoCs, and are
-              defined as macros in dt-bindings/pinctrl/mediatek,<soc>-pinfunc.h
-              directly.
+              defined as macros in dt-bindings/pinctrl/mediatek,mt8188-pinfunc.h
+              directly, for this SoC.
 
           drive-strength:
             enum: [2, 4, 6, 8, 10, 12, 14, 16]
@@ -106,18 +107,21 @@ patternProperties:
               - enum: [75000, 5000]
                 description: mt8188 pull down RSEL type si unit value(ohm).
             description: |
-              For pull down type is normal, it doesn't need add RSEL & R1R0 define
-              and resistance value.
+              For pull down type is normal, it doesn't need add RSEL & R1R0
+              define and resistance value.
               For pull down type is PUPD/R0/R1 type, it can add R1R0 define to
               set different resistance. It can support "MTK_PUPD_SET_R1R0_00" &
-              "MTK_PUPD_SET_R1R0_01" & "MTK_PUPD_SET_R1R0_10" & "MTK_PUPD_SET_R1R0_11"
-              define in mt8188.
-              For pull down type is RSEL, it can add RSEL define & resistance value(ohm)
-              to set different resistance by identifying property "mediatek,rsel-resistance-in-si-unit".
-              It can support "MTK_PULL_SET_RSEL_000" & "MTK_PULL_SET_RSEL_001"
-              & "MTK_PULL_SET_RSEL_010" & "MTK_PULL_SET_RSEL_011" & "MTK_PULL_SET_RSEL_100"
-              & "MTK_PULL_SET_RSEL_101" & "MTK_PULL_SET_RSEL_110" & "MTK_PULL_SET_RSEL_111"
-              define in mt8188. It can also support resistance value(ohm) "75000" & "5000" in mt8188.
+              "MTK_PUPD_SET_R1R0_01" & "MTK_PUPD_SET_R1R0_10" &
+              "MTK_PUPD_SET_R1R0_11" define in mt8188.
+              For pull down type is RSEL, it can add RSEL define & resistance
+              value(ohm) to set different resistance by identifying property
+              "mediatek,rsel-resistance-in-si-unit". It can support
+              "MTK_PULL_SET_RSEL_000" & "MTK_PULL_SET_RSEL_001" &
+              "MTK_PULL_SET_RSEL_010" & "MTK_PULL_SET_RSEL_011" &
+              "MTK_PULL_SET_RSEL_100" & "MTK_PULL_SET_RSEL_101" &
+              "MTK_PULL_SET_RSEL_110" & "MTK_PULL_SET_RSEL_111" define in
+              mt8188. It can also support resistance value(ohm) "75000" & "5000"
+              in mt8188.
 
           bias-pull-up:
             oneOf:
@@ -131,17 +135,19 @@ patternProperties:
             description: |
               For pull up type is normal, it don't need add RSEL & R1R0 define
               and resistance value.
-              For pull up type is PUPD/R0/R1 type, it can add R1R0 define to
-              set different resistance. It can support "MTK_PUPD_SET_R1R0_00" &
-              "MTK_PUPD_SET_R1R0_01" & "MTK_PUPD_SET_R1R0_10" & "MTK_PUPD_SET_R1R0_11"
-              define in mt8188.
-              For pull up type is RSEL, it can add RSEL define & resistance value(ohm)
-              to set different resistance by identifying property "mediatek,rsel-resistance-in-si-unit".
-              It can support "MTK_PULL_SET_RSEL_000" & "MTK_PULL_SET_RSEL_001"
-              & "MTK_PULL_SET_RSEL_010" & "MTK_PULL_SET_RSEL_011" & "MTK_PULL_SET_RSEL_100"
-              & "MTK_PULL_SET_RSEL_101" & "MTK_PULL_SET_RSEL_110" & "MTK_PULL_SET_RSEL_111"
-              define in mt8188. It can also support resistance value(ohm)
-              "1000" & "1500" & "2000" & "3000" & "4000" & "5000" & "10000" & "75000" in mt8188.
+              For pull up type is PUPD/R0/R1 type, it can add R1R0 define to set
+              different resistance. It can support "MTK_PUPD_SET_R1R0_00" &
+              "MTK_PUPD_SET_R1R0_01" & "MTK_PUPD_SET_R1R0_10" &
+              "MTK_PUPD_SET_R1R0_11" define in mt8188.
+              For pull up type is RSEL, it can add RSEL define & resistance
+              value(ohm) to set different resistance by identifying property
+              "mediatek,rsel-resistance-in-si-unit". It can support
+              "MTK_PULL_SET_RSEL_000" & "MTK_PULL_SET_RSEL_001" &
+              "MTK_PULL_SET_RSEL_010" & "MTK_PULL_SET_RSEL_011" &
+              "MTK_PULL_SET_RSEL_100" & "MTK_PULL_SET_RSEL_101" &
+              "MTK_PULL_SET_RSEL_110" & "MTK_PULL_SET_RSEL_111" define in
+              mt8188. It can also support resistance value(ohm) "1000" & "1500"
+              & "2000" & "3000" & "4000" & "5000" & "10000" & "75000" in mt8188.
 
           bias-disable: true
 
diff --git a/Documentation/devicetree/bindings/pinctrl/mediatek,mt8192-pinctrl.yaml b/Documentation/devicetree/bindings/pinctrl/mediatek,mt8192-pinctrl.yaml
new file mode 100644 (file)
index 0000000..1686427
--- /dev/null
@@ -0,0 +1,184 @@
+# SPDX-License-Identifier: (GPL-2.0-only OR BSD-2-Clause)
+%YAML 1.2
+---
+$id: http://devicetree.org/schemas/pinctrl/mediatek,mt8192-pinctrl.yaml#
+$schema: http://devicetree.org/meta-schemas/core.yaml#
+
+title: MediaTek MT8192 Pin Controller
+
+maintainers:
+  - Sean Wang <sean.wang@mediatek.com>
+
+description:
+  The MediaTek's MT8192 Pin controller is used to control SoC pins.
+
+properties:
+  compatible:
+    const: mediatek,mt8192-pinctrl
+
+  gpio-controller: true
+
+  '#gpio-cells':
+    description:
+      Number of cells in GPIO specifier. Since the generic GPIO binding is used,
+      the amount of cells must be specified as 2. See the below mentioned gpio
+      binding representation for description of particular cells.
+    const: 2
+
+  gpio-ranges:
+    description: GPIO valid number range.
+    maxItems: 1
+
+  gpio-line-names: true
+
+  reg:
+    description:
+      Physical address base for GPIO base registers. There are 11 GPIO physical
+      address base in mt8192.
+    maxItems: 11
+
+  reg-names:
+    description:
+      GPIO base register names.
+    maxItems: 11
+
+  interrupt-controller: true
+
+  '#interrupt-cells':
+    const: 2
+
+  interrupts:
+    description: The interrupt outputs to sysirq.
+    maxItems: 1
+
+# PIN CONFIGURATION NODES
+patternProperties:
+  '-pins$':
+    type: object
+    additionalProperties: false
+    patternProperties:
+      '^pins':
+        type: object
+        description:
+          A pinctrl node should contain at least one subnodes representing the
+          pinctrl groups available on the machine. Each subnode will list the
+          pins it needs, and how they should be configured, with regard to muxer
+          configuration, pullups, drive strength, input enable/disable and input
+          schmitt.
+        $ref: pinmux-node.yaml
+
+        properties:
+          pinmux:
+            description:
+              Integer array, represents gpio pin number and mux setting.
+              Supported pin number and mux varies for different SoCs, and are
+              defined as macros in dt-bindings/pinctrl/<soc>-pinfunc.h directly.
+
+          drive-strength:
+            description:
+              It can support some arguments, such as MTK_DRIVE_4mA,
+              MTK_DRIVE_6mA, etc. See dt-bindings/pinctrl/mt65xx.h. It can only
+              support 2/4/6/8/10/12/14/16mA in mt8192.
+            enum: [2, 4, 6, 8, 10, 12, 14, 16]
+
+          drive-strength-microamp:
+            enum: [125, 250, 500, 1000]
+
+          bias-pull-down:
+            oneOf:
+              - type: boolean
+                description: normal pull down.
+              - enum: [100, 101, 102, 103]
+                description: PUPD/R1/R0 pull down type. See MTK_PUPD_SET_R1R0_
+                  defines in dt-bindings/pinctrl/mt65xx.h.
+              - enum: [200, 201, 202, 203]
+                description: RSEL pull down type. See MTK_PULL_SET_RSEL_ defines
+                  in dt-bindings/pinctrl/mt65xx.h.
+
+          bias-pull-up:
+            oneOf:
+              - type: boolean
+                description: normal pull up.
+              - enum: [100, 101, 102, 103]
+                description: PUPD/R1/R0 pull up type. See MTK_PUPD_SET_R1R0_
+                  defines in dt-bindings/pinctrl/mt65xx.h.
+              - enum: [200, 201, 202, 203]
+                description: RSEL pull up type. See MTK_PULL_SET_RSEL_ defines
+                  in dt-bindings/pinctrl/mt65xx.h.
+
+          bias-disable: true
+
+          output-high: true
+
+          output-low: true
+
+          input-enable: true
+
+          input-disable: true
+
+          input-schmitt-enable: true
+
+          input-schmitt-disable: true
+
+        required:
+          - pinmux
+
+        additionalProperties: false
+
+allOf:
+  - $ref: pinctrl.yaml#
+
+required:
+  - compatible
+  - reg
+  - interrupts
+  - interrupt-controller
+  - '#interrupt-cells'
+  - gpio-controller
+  - '#gpio-cells'
+  - gpio-ranges
+
+additionalProperties: false
+
+examples:
+  - |
+            #include <dt-bindings/pinctrl/mt8192-pinfunc.h>
+            #include <dt-bindings/interrupt-controller/arm-gic.h>
+            pio: pinctrl@10005000 {
+                    compatible = "mediatek,mt8192-pinctrl";
+                    reg = <0x10005000 0x1000>,
+                          <0x11c20000 0x1000>,
+                          <0x11d10000 0x1000>,
+                          <0x11d30000 0x1000>,
+                          <0x11d40000 0x1000>,
+                          <0x11e20000 0x1000>,
+                          <0x11e70000 0x1000>,
+                          <0x11ea0000 0x1000>,
+                          <0x11f20000 0x1000>,
+                          <0x11f30000 0x1000>,
+                          <0x1000b000 0x1000>;
+                    reg-names = "iocfg0", "iocfg_rm", "iocfg_bm",
+                          "iocfg_bl", "iocfg_br", "iocfg_lm",
+                          "iocfg_lb", "iocfg_rt", "iocfg_lt",
+                          "iocfg_tl", "eint";
+                    gpio-controller;
+                    #gpio-cells = <2>;
+                    gpio-ranges = <&pio 0 0 220>;
+                    interrupt-controller;
+                    interrupts = <GIC_SPI 212 IRQ_TYPE_LEVEL_HIGH 0>;
+                    #interrupt-cells = <2>;
+
+                    spi1-default-pins {
+                            pins-cs-mosi-clk {
+                                    pinmux = <PINMUX_GPIO157__FUNC_SPI1_A_CSB>,
+                                             <PINMUX_GPIO159__FUNC_SPI1_A_MO>,
+                                             <PINMUX_GPIO156__FUNC_SPI1_A_CLK>;
+                                    bias-disable;
+                            };
+
+                            pins-miso {
+                                    pinmux = <PINMUX_GPIO158__FUNC_SPI1_A_MI>;
+                                    bias-pull-down;
+                            };
+                    };
+            };
diff --git a/Documentation/devicetree/bindings/pinctrl/mediatek,mt8195-pinctrl.yaml b/Documentation/devicetree/bindings/pinctrl/mediatek,mt8195-pinctrl.yaml
new file mode 100644 (file)
index 0000000..33cb717
--- /dev/null
@@ -0,0 +1,286 @@
+# SPDX-License-Identifier: (GPL-2.0-only OR BSD-2-Clause)
+%YAML 1.2
+---
+$id: http://devicetree.org/schemas/pinctrl/mediatek,mt8195-pinctrl.yaml#
+$schema: http://devicetree.org/meta-schemas/core.yaml#
+
+title: MediaTek MT8195 Pin Controller
+
+maintainers:
+  - Sean Wang <sean.wang@mediatek.com>
+
+description:
+  The MediaTek's MT8195 Pin controller is used to control SoC pins.
+
+properties:
+  compatible:
+    const: mediatek,mt8195-pinctrl
+
+  gpio-controller: true
+
+  '#gpio-cells':
+    description:
+      Number of cells in GPIO specifier. Since the generic GPIO binding is used,
+      the amount of cells must be specified as 2. See the below mentioned gpio
+      binding representation for description of particular cells.
+    const: 2
+
+  gpio-ranges:
+    description: GPIO valid number range.
+    maxItems: 1
+
+  gpio-line-names: true
+
+  reg:
+    description:
+      Physical address base for GPIO base registers. There are 8 GPIO physical
+      address base in mt8195.
+    maxItems: 8
+
+  reg-names:
+    description:
+      GPIO base register names.
+    maxItems: 8
+
+  interrupt-controller: true
+
+  '#interrupt-cells':
+    const: 2
+
+  interrupts:
+    description: The interrupt outputs to sysirq.
+    maxItems: 1
+
+  mediatek,rsel-resistance-in-si-unit:
+    type: boolean
+    description:
+      Identifying i2c pins pull up/down type which is RSEL. It can support RSEL
+      define or si unit value(ohm) to set different resistance.
+
+# PIN CONFIGURATION NODES
+patternProperties:
+  '-pins$':
+    type: object
+    additionalProperties: false
+    patternProperties:
+      '^pins':
+        type: object
+        additionalProperties: false
+        description: |
+          A pinctrl node should contain at least one subnodes representing the
+          pinctrl groups available on the machine. Each subnode will list the
+          pins it needs, and how they should be configured, with regard to muxer
+          configuration, pullups, drive strength, input enable/disable and input
+          schmitt.
+          An example of using macro:
+          pincontroller {
+            /* GPIO0 set as multifunction GPIO0 */
+            gpio-pins {
+              pins {
+                pinmux = <PINMUX_GPIO0__FUNC_GPIO0>;
+              }
+            };
+            /* GPIO8 set as multifunction SDA0 */
+            i2c0-pins {
+              pins {
+                pinmux = <PINMUX_GPIO8__FUNC_SDA0>;
+              }
+            };
+          };
+        $ref: pinmux-node.yaml
+
+        properties:
+          pinmux:
+            description:
+              Integer array, represents gpio pin number and mux setting.
+              Supported pin number and mux varies for different SoCs, and are
+              defined as macros in dt-bindings/pinctrl/<soc>-pinfunc.h directly.
+
+          drive-strength:
+            enum: [2, 4, 6, 8, 10, 12, 14, 16]
+
+          drive-strength-microamp:
+            enum: [125, 250, 500, 1000]
+
+          bias-pull-down:
+            oneOf:
+              - type: boolean
+              - enum: [100, 101, 102, 103]
+                description: mt8195 pull down PUPD/R0/R1 type define value.
+              - enum: [200, 201, 202, 203, 204, 205, 206, 207]
+                description: mt8195 pull down RSEL type define value.
+              - enum: [75000, 5000]
+                description: mt8195 pull down RSEL type si unit value(ohm).
+            description: |
+              For pull down type is normal, it don't need add RSEL & R1R0 define
+              and resistance value.
+              For pull down type is PUPD/R0/R1 type, it can add R1R0 define to
+              set different resistance. It can support "MTK_PUPD_SET_R1R0_00" &
+              "MTK_PUPD_SET_R1R0_01" & "MTK_PUPD_SET_R1R0_10" &
+              "MTK_PUPD_SET_R1R0_11" define in mt8195.
+              For pull down type is RSEL, it can add RSEL define & resistance
+              value(ohm) to set different resistance by identifying property
+              "mediatek,rsel-resistance-in-si-unit".
+              It can support "MTK_PULL_SET_RSEL_000" & "MTK_PULL_SET_RSEL_001"
+              & "MTK_PULL_SET_RSEL_010" & "MTK_PULL_SET_RSEL_011"
+              & "MTK_PULL_SET_RSEL_100" & "MTK_PULL_SET_RSEL_101"
+              & "MTK_PULL_SET_RSEL_110" & "MTK_PULL_SET_RSEL_111"
+              define in mt8195. It can also support resistance value(ohm)
+              "75000" & "5000" in mt8195.
+
+              An example of using RSEL define:
+              pincontroller {
+                i2c0_pin {
+                  pins {
+                    pinmux = <PINMUX_GPIO8__FUNC_SDA0>;
+                    bias-pull-down = <MTK_PULL_SET_RSEL_001>;
+                  }
+                };
+              };
+              An example of using si unit resistance value(ohm):
+              &pio {
+                mediatek,rsel-resistance-in-si-unit;
+              }
+              pincontroller {
+                i2c0_pin {
+                  pins {
+                    pinmux = <PINMUX_GPIO8__FUNC_SDA0>;
+                    bias-pull-down = <75000>;
+                  }
+                };
+              };
+
+          bias-pull-up:
+            oneOf:
+              - type: boolean
+              - enum: [100, 101, 102, 103]
+                description: mt8195 pull up PUPD/R0/R1 type define value.
+              - enum: [200, 201, 202, 203, 204, 205, 206, 207]
+                description: mt8195 pull up RSEL type define value.
+              - enum: [1000, 1500, 2000, 3000, 4000, 5000, 10000, 75000]
+                description: mt8195 pull up RSEL type si unit value(ohm).
+            description: |
+              For pull up type is normal, it don't need add RSEL & R1R0 define
+              and resistance value.
+              For pull up type is PUPD/R0/R1 type, it can add R1R0 define to
+              set different resistance. It can support "MTK_PUPD_SET_R1R0_00" &
+              "MTK_PUPD_SET_R1R0_01" & "MTK_PUPD_SET_R1R0_10" &
+              "MTK_PUPD_SET_R1R0_11" define in mt8195.
+              For pull up type is RSEL, it can add RSEL define & resistance
+              value(ohm) to set different resistance by identifying property
+              "mediatek,rsel-resistance-in-si-unit".
+              It can support "MTK_PULL_SET_RSEL_000" & "MTK_PULL_SET_RSEL_001"
+              & "MTK_PULL_SET_RSEL_010" & "MTK_PULL_SET_RSEL_011"
+              & "MTK_PULL_SET_RSEL_100" & "MTK_PULL_SET_RSEL_101"
+              & "MTK_PULL_SET_RSEL_110" & "MTK_PULL_SET_RSEL_111"
+              define in mt8195. It can also support resistance value(ohm) "1000"
+              & "1500" & "2000" & "3000" & "4000" & "5000" & "10000" & "75000"
+              in mt8195.
+              An example of using RSEL define:
+              pincontroller {
+                i2c0-pins {
+                  pins {
+                    pinmux = <PINMUX_GPIO8__FUNC_SDA0>;
+                    bias-pull-up = <MTK_PULL_SET_RSEL_001>;
+                  }
+                };
+              };
+              An example of using si unit resistance value(ohm):
+              &pio {
+                mediatek,rsel-resistance-in-si-unit;
+              }
+              pincontroller {
+                i2c0-pins {
+                  pins {
+                    pinmux = <PINMUX_GPIO8__FUNC_SDA0>;
+                    bias-pull-up = <1000>;
+                  }
+                };
+              };
+
+          bias-disable: true
+
+          output-high: true
+
+          output-low: true
+
+          input-enable: true
+
+          input-disable: true
+
+          input-schmitt-enable: true
+
+          input-schmitt-disable: true
+
+        required:
+          - pinmux
+
+allOf:
+  - $ref: pinctrl.yaml#
+
+required:
+  - compatible
+  - reg
+  - interrupts
+  - interrupt-controller
+  - '#interrupt-cells'
+  - gpio-controller
+  - '#gpio-cells'
+  - gpio-ranges
+
+additionalProperties: false
+
+examples:
+  - |
+    #include <dt-bindings/pinctrl/mt8195-pinfunc.h>
+    #include <dt-bindings/interrupt-controller/arm-gic.h>
+    #
+    pio: pinctrl@10005000 {
+      compatible = "mediatek,mt8195-pinctrl";
+      reg = <0x10005000 0x1000>,
+            <0x11d10000 0x1000>,
+            <0x11d30000 0x1000>,
+            <0x11d40000 0x1000>,
+            <0x11e20000 0x1000>,
+            <0x11eb0000 0x1000>,
+            <0x11f40000 0x1000>,
+            <0x1000b000 0x1000>;
+      reg-names = "iocfg0", "iocfg_bm", "iocfg_bl",
+                  "iocfg_br", "iocfg_lm", "iocfg_rb",
+                  "iocfg_tl", "eint";
+      gpio-controller;
+      #gpio-cells = <2>;
+      gpio-ranges = <&pio 0 0 144>;
+      interrupt-controller;
+      interrupts = <GIC_SPI 225 IRQ_TYPE_LEVEL_HIGH 0>;
+      #interrupt-cells = <2>;
+
+      pio-pins {
+        pins {
+          pinmux = <PINMUX_GPIO0__FUNC_GPIO0>;
+          output-low;
+        };
+      };
+
+      spi0-pins {
+        pins-spi {
+          pinmux = <PINMUX_GPIO132__FUNC_SPIM0_CSB>,
+                   <PINMUX_GPIO134__FUNC_SPIM0_MO>,
+                   <PINMUX_GPIO133__FUNC_SPIM0_CLK>;
+          bias-disable;
+        };
+        pins-spi-mi {
+          pinmux = <PINMUX_GPIO135__FUNC_SPIM0_MI>;
+          bias-pull-down;
+        };
+      };
+
+      i2c0-pins {
+        pins {
+          pinmux = <PINMUX_GPIO8__FUNC_SDA0>,
+                   <PINMUX_GPIO9__FUNC_SCL0>;
+          bias-disable;
+          drive-strength-microamp = <1000>;
+        };
+      };
+    };
index 4b96884a1afc7d0fc08e0c52bd77de1e715ce1ac..61b33b5416f5f2917c1bc4ba00ce2fb0809fe0f1 100644 (file)
@@ -4,13 +4,13 @@
 $id: http://devicetree.org/schemas/pinctrl/mediatek,mt8365-pinctrl.yaml#
 $schema: http://devicetree.org/meta-schemas/core.yaml#
 
-title: Mediatek MT8365 Pin Controller
+title: MediaTek MT8365 Pin Controller
 
 maintainers:
   - Zhiyong Tao <zhiyong.tao@mediatek.com>
   - Bernhard Rosenkränzer <bero@baylibre.com>
 
-description: |
+description:
   The MediaTek's MT8365 Pin controller is used to control SoC pins.
 
 properties:
@@ -26,17 +26,17 @@ properties:
       maxItems: 1
     minItems: 1
     maxItems: 2
-    description: |
+    description:
       Should be phandles of the syscfg node.
 
   gpio-controller: true
 
   "#gpio-cells":
     const: 2
-    description: |
-      Number of cells in GPIO specifier. Since the generic GPIO
-      binding is used, the amount of cells must be specified as 2. See the below
-      mentioned gpio binding representation for description of particular cells.
+    description:
+      Number of cells in GPIO specifier. Since the generic GPIO binding is used,
+      the amount of cells must be specified as 2. See the below mentioned gpio
+      binding representation for description of particular cells.
 
   interrupt-controller: true
 
@@ -54,7 +54,7 @@ patternProperties:
       "pins$":
         type: object
         additionalProperties: false
-        description: |
+        description:
           A pinctrl node should contain at least one subnode representing the
           pinctrl groups available on the machine. Each subnode will list the
           pins it needs, and how they should be configured, with regard to muxer
@@ -65,19 +65,42 @@ patternProperties:
         properties:
           pinmux:
             description:
-              integer array, represents gpio pin number and mux setting.
+              Integer array, represents gpio pin number and mux setting.
               Supported pin number and mux varies for different SoCs, and are
               defined as macros in <soc>-pinfunc.h directly.
 
           bias-disable: true
 
           bias-pull-up:
+            oneOf:
+              - type: boolean
+              - enum: [100, 101, 102, 103]
+                description: Pull up R1/R0 type define value.
             description: |
-              Besides generic pinconfig options, it can be used as the pull up
-              settings for 2 pull resistors, R0 and R1. User can configure those
-              special pins.
+              For pull up type is normal, it don't need add R1/R0 define.
+              For pull up type is R1/R0 type, it can add value to set different
+              resistance. Valid arguments are described as below:
+              100: (R1, R0) = (0, 0) which means R1 disabled and R0 disabled.
+              101: (R1, R0) = (0, 1) which means R1 disabled and R0 enabled.
+              102: (R1, R0) = (1, 0) which means R1 enabled and R0 disabled.
+              103: (R1, R0) = (1, 1) which means R1 enabled and R0 enabled.
+
+          bias-pull-down:
+            oneOf:
+              - type: boolean
+              - enum: [100, 101, 102, 103]
+                description: Pull down R1/R0 type define value.
+            description: |
+              For pull down type is normal, it don't need add R1/R0 define.
+              For pull down type is R1/R0 type, it can add value to set
+              different resistance. Valid arguments are described as below:
+              100: (R1, R0) = (0, 0) which means R1 disabled and R0 disabled.
+              101: (R1, R0) = (0, 1) which means R1 disabled and R0 enabled.
+              102: (R1, R0) = (1, 0) which means R1 enabled and R0 disabled.
+              103: (R1, R0) = (1, 1) which means R1 enabled and R0 enabled.
 
-          bias-pull-down: true
+          drive-strength:
+            enum: [2, 4, 6, 8, 10, 12, 14, 16]
 
           input-enable: true
 
@@ -91,8 +114,13 @@ patternProperties:
 
           input-schmitt-disable: true
 
+          drive-strength-microamp:
+            enum: [125, 250, 500, 1000]
+
           mediatek,drive-strength-adv:
+            deprecated: true
             description: |
+              DEPRECATED: Please use drive-strength-microamp instead.
               Describe the specific driving setup property.
               For I2C pins, the existing generic driving setup can only support
               2/4/6/8/10/12/14/16mA driving. But in specific driving setup, they
@@ -118,9 +146,12 @@ patternProperties:
             enum: [0, 1, 2, 3, 4, 5, 6, 7]
 
           mediatek,pull-up-adv:
+            deprecated: true
             description: |
+              DEPRECATED: Please use bias-pull-up instead.
               Pull up setings for 2 pull resistors, R0 and R1. User can
-              configure those special pins. Valid arguments are described as below:
+              configure those special pins. Valid arguments are described as
+              below:
               0: (R1, R0) = (0, 0) which means R1 disabled and R0 disabled.
               1: (R1, R0) = (0, 1) which means R1 disabled and R0 enabled.
               2: (R1, R0) = (1, 0) which means R1 enabled and R0 disabled.
@@ -129,9 +160,12 @@ patternProperties:
             enum: [0, 1, 2, 3]
 
           mediatek,pull-down-adv:
+            deprecated: true
             description: |
+              DEPRECATED: Please use bias-pull-down instead.
               Pull down settings for 2 pull resistors, R0 and R1. User can
-              configure those special pins. Valid arguments are described as below:
+              configure those special pins. Valid arguments are described as
+              below:
               0: (R1, R0) = (0, 0) which means R1 disabled and R0 disabled.
               1: (R1, R0) = (0, 1) which means R1 disabled and R0 enabled.
               2: (R1, R0) = (1, 0) which means R1 enabled and R0 disabled.
@@ -140,14 +174,14 @@ patternProperties:
             enum: [0, 1, 2, 3]
 
           mediatek,tdsel:
-            description: |
+            description:
               An integer describing the steps for output level shifter duty
               cycle when asserted (high pulse width adjustment). Valid arguments
               are from 0 to 15.
             $ref: /schemas/types.yaml#/definitions/uint32
 
           mediatek,rdsel:
-            description: |
+            description:
               An integer describing the steps for input level shifter duty cycle
               when asserted (high pulse width adjustment). Valid arguments are
               from 0 to 63.
@@ -189,7 +223,6 @@ examples:
           pins {
             pinmux = <MT8365_PIN_59_SDA1__FUNC_SDA1_0>, <MT8365_PIN_60_SCL1__FUNC_SCL1_0>;
             mediatek,pull-up-adv = <3>;
-            mediatek,drive-strength-adv = <00>;
             bias-pull-up;
           };
         };
diff --git a/Documentation/devicetree/bindings/pinctrl/mediatek,pinctrl-mt6795.yaml b/Documentation/devicetree/bindings/pinctrl/mediatek,pinctrl-mt6795.yaml
deleted file mode 100644 (file)
index 9399e02..0000000
+++ /dev/null
@@ -1,227 +0,0 @@
-# SPDX-License-Identifier: (GPL-2.0-only OR BSD-2-Clause)
-%YAML 1.2
----
-$id: http://devicetree.org/schemas/pinctrl/mediatek,pinctrl-mt6795.yaml#
-$schema: http://devicetree.org/meta-schemas/core.yaml#
-
-title: Mediatek MT6795 Pin Controller
-
-maintainers:
-  - AngeloGioacchino Del Regno <angelogioacchino.delregno@collabora.com>
-  - Sean Wang <sean.wang@kernel.org>
-
-description: |
-  The Mediatek's Pin controller is used to control SoC pins.
-
-properties:
-  compatible:
-    const: mediatek,mt6795-pinctrl
-
-  gpio-controller: true
-
-  '#gpio-cells':
-    description: |
-      Number of cells in GPIO specifier. Since the generic GPIO binding is used,
-      the amount of cells must be specified as 2. See the below
-      mentioned gpio binding representation for description of particular cells.
-    const: 2
-
-  gpio-ranges:
-    description: GPIO valid number range.
-    maxItems: 1
-
-  reg:
-    description:
-      Physical address base for gpio base and eint registers.
-    minItems: 2
-
-  reg-names:
-    items:
-      - const: base
-      - const: eint
-
-  interrupt-controller: true
-
-  '#interrupt-cells':
-    const: 2
-
-  interrupts:
-    description: Interrupt outputs to the system interrupt controller (sysirq).
-    minItems: 1
-    items:
-      - description: EINT interrupt
-      - description: EINT event_b interrupt
-
-# PIN CONFIGURATION NODES
-patternProperties:
-  '-pins$':
-    type: object
-    additionalProperties: false
-    patternProperties:
-      '^pins':
-        type: object
-        additionalProperties: false
-        description: |
-          A pinctrl node should contain at least one subnodes representing the
-          pinctrl groups available on the machine. Each subnode will list the
-          pins it needs, and how they should be configured, with regard to muxer
-          configuration, pullups, drive strength, input enable/disable and
-          input schmitt.
-          An example of using macro:
-          pincontroller {
-            /* GPIO0 set as multifunction GPIO0 */
-            gpio-pins {
-              pins {
-                pinmux = <PINMUX_GPIO0__FUNC_GPIO0>;
-              }
-            };
-            /* GPIO45 set as multifunction SDA0 */
-            i2c0-pins {
-              pins {
-                pinmux = <PINMUX_GPIO45__FUNC_SDA0>;
-              }
-            };
-          };
-        $ref: "pinmux-node.yaml"
-
-        properties:
-          pinmux:
-            description: |
-              Integer array, represents gpio pin number and mux setting.
-              Supported pin number and mux varies for different SoCs, and are
-              defined as macros in dt-bindings/pinctrl/<soc>-pinfunc.h
-              directly.
-
-          drive-strength:
-            enum: [2, 4, 6, 8, 10, 12, 14, 16]
-
-          bias-pull-down:
-            oneOf:
-              - type: boolean
-              - enum: [100, 101, 102, 103]
-                description: mt6795 pull down PUPD/R0/R1 type define value.
-            description: |
-               For normal pull down type, it is not necessary to specify R1R0
-               values; When pull down type is PUPD/R0/R1, adding R1R0 defines
-               will set different resistance values.
-
-          bias-pull-up:
-            oneOf:
-              - type: boolean
-              - enum: [100, 101, 102, 103]
-                description: mt6795 pull up PUPD/R0/R1 type define value.
-            description: |
-               For normal pull up type, it is not necessary to specify R1R0
-               values; When pull up type is PUPD/R0/R1, adding R1R0 defines
-               will set different resistance values.
-
-          bias-disable: true
-
-          output-high: true
-
-          output-low: true
-
-          input-enable: true
-
-          input-disable: true
-
-          input-schmitt-enable: true
-
-          input-schmitt-disable: true
-
-          mediatek,pull-up-adv:
-            description: |
-              Pull up setings for 2 pull resistors, R0 and R1. User can
-              configure those special pins. Valid arguments are described as below:
-              0: (R1, R0) = (0, 0) which means R1 disabled and R0 disabled.
-              1: (R1, R0) = (0, 1) which means R1 disabled and R0 enabled.
-              2: (R1, R0) = (1, 0) which means R1 enabled and R0 disabled.
-              3: (R1, R0) = (1, 1) which means R1 enabled and R0 enabled.
-            $ref: /schemas/types.yaml#/definitions/uint32
-            enum: [0, 1, 2, 3]
-
-          mediatek,pull-down-adv:
-            description: |
-              Pull down settings for 2 pull resistors, R0 and R1. User can
-              configure those special pins. Valid arguments are described as below:
-              0: (R1, R0) = (0, 0) which means R1 disabled and R0 disabled.
-              1: (R1, R0) = (0, 1) which means R1 disabled and R0 enabled.
-              2: (R1, R0) = (1, 0) which means R1 enabled and R0 disabled.
-              3: (R1, R0) = (1, 1) which means R1 enabled and R0 enabled.
-            $ref: /schemas/types.yaml#/definitions/uint32
-            enum: [0, 1, 2, 3]
-
-        required:
-          - pinmux
-
-allOf:
-  - $ref: "pinctrl.yaml#"
-
-required:
-  - compatible
-  - reg
-  - reg-names
-  - interrupts
-  - interrupt-controller
-  - '#interrupt-cells'
-  - gpio-controller
-  - '#gpio-cells'
-  - gpio-ranges
-
-additionalProperties: false
-
-examples:
-  - |
-    #include <dt-bindings/interrupt-controller/arm-gic.h>
-    #include <dt-bindings/interrupt-controller/irq.h>
-    #include <dt-bindings/pinctrl/mt6795-pinfunc.h>
-
-    soc {
-        #address-cells = <2>;
-        #size-cells = <2>;
-
-        pio: pinctrl@10005000 {
-            compatible = "mediatek,mt6795-pinctrl";
-            reg = <0 0x10005000 0 0x1000>, <0 0x1000b000 0 0x1000>;
-            reg-names = "base", "eint";
-            gpio-controller;
-            #gpio-cells = <2>;
-            gpio-ranges = <&pio 0 0 196>;
-            interrupt-controller;
-            interrupts = <GIC_SPI 153 IRQ_TYPE_LEVEL_HIGH>;
-            #interrupt-cells = <2>;
-
-            i2c0-pins {
-                pins-sda-scl {
-                    pinmux = <PINMUX_GPIO45__FUNC_SDA0>,
-                             <PINMUX_GPIO46__FUNC_SCL0>;
-                };
-            };
-
-            mmc0-pins {
-                pins-cmd-dat {
-                    pinmux = <PINMUX_GPIO154__FUNC_MSDC0_DAT0>,
-                             <PINMUX_GPIO155__FUNC_MSDC0_DAT1>,
-                             <PINMUX_GPIO156__FUNC_MSDC0_DAT2>,
-                             <PINMUX_GPIO157__FUNC_MSDC0_DAT3>,
-                             <PINMUX_GPIO158__FUNC_MSDC0_DAT4>,
-                             <PINMUX_GPIO159__FUNC_MSDC0_DAT5>,
-                             <PINMUX_GPIO160__FUNC_MSDC0_DAT6>,
-                             <PINMUX_GPIO161__FUNC_MSDC0_DAT7>,
-                             <PINMUX_GPIO162__FUNC_MSDC0_CMD>;
-                    input-enable;
-                    bias-pull-up = <MTK_PUPD_SET_R1R0_01>;
-                };
-
-                pins-clk {
-                    pinmux = <PINMUX_GPIO163__FUNC_MSDC0_CLK>;
-                    bias-pull-down = <MTK_PUPD_SET_R1R0_10>;
-                };
-
-                pins-rst {
-                    pinmux = <PINMUX_GPIO165__FUNC_MSDC0_RSTB>;
-                    bias-pull-up = <MTK_PUPD_SET_R1R0_10>;
-                };
-            };
-        };
-    };
diff --git a/Documentation/devicetree/bindings/pinctrl/meson,pinctrl.txt b/Documentation/devicetree/bindings/pinctrl/meson,pinctrl.txt
deleted file mode 100644 (file)
index 8146193..0000000
+++ /dev/null
@@ -1,94 +0,0 @@
-== Amlogic Meson pinmux controller ==
-
-Required properties for the root node:
- - compatible: one of "amlogic,meson8-cbus-pinctrl"
-                     "amlogic,meson8b-cbus-pinctrl"
-                     "amlogic,meson8m2-cbus-pinctrl"
-                     "amlogic,meson8-aobus-pinctrl"
-                     "amlogic,meson8b-aobus-pinctrl"
-                     "amlogic,meson8m2-aobus-pinctrl"
-                     "amlogic,meson-gxbb-periphs-pinctrl"
-                     "amlogic,meson-gxbb-aobus-pinctrl"
-                     "amlogic,meson-gxl-periphs-pinctrl"
-                     "amlogic,meson-gxl-aobus-pinctrl"
-                     "amlogic,meson-axg-periphs-pinctrl"
-                     "amlogic,meson-axg-aobus-pinctrl"
-                     "amlogic,meson-g12a-periphs-pinctrl"
-                     "amlogic,meson-g12a-aobus-pinctrl"
-                     "amlogic,meson-a1-periphs-pinctrl"
-                     "amlogic,meson-s4-periphs-pinctrl"
- - reg: address and size of registers controlling irq functionality
-
-=== GPIO sub-nodes ===
-
-The GPIO bank for the controller is represented as a sub-node and it acts as a
-GPIO controller.
-
-Required properties for sub-nodes are:
- - reg: should contain a list of address and size, one tuple for each entry
-   in reg-names.
- - reg-names: an array of strings describing the "reg" entries.
-   Must contain "mux" and "gpio".
-   May contain "pull", "pull-enable" and "ds" when appropriate.
- - gpio-controller: identifies the node as a gpio controller
- - #gpio-cells: must be 2
-
-=== Other sub-nodes ===
-
-Child nodes without the "gpio-controller" represent some desired
-configuration for a pin or a group. Those nodes can be pinmux nodes or
-configuration nodes.
-
-Required properties for pinmux nodes are:
- - groups: a list of pinmux groups. The list of all available groups
-   depends on the SoC and can be found in driver sources.
- - function: the name of a function to activate for the specified set
-   of groups. The list of all available functions depends on the SoC
-   and can be found in driver sources.
-
-Required properties for configuration nodes:
- - pins: a list of pin names
-
-Configuration nodes support the following generic properties, as
-described in file pinctrl-bindings.txt:
- - "bias-disable"
- - "bias-pull-up"
- - "bias-pull-down"
- - "output-enable"
- - "output-disable"
- - "output-low"
- - "output-high"
-
-Optional properties :
- - drive-strength-microamp: Drive strength for the specified pins in uA.
-                           This property is only valid for G12A and newer.
-
-=== Example ===
-
-       pinctrl: pinctrl@c1109880 {
-               compatible = "amlogic,meson8-cbus-pinctrl";
-               reg = <0xc1109880 0x10>;
-               #address-cells = <1>;
-               #size-cells = <1>;
-               ranges;
-
-               gpio: banks@c11080b0 {
-                       reg = <0xc11080b0 0x28>,
-                             <0xc11080e8 0x18>,
-                             <0xc1108120 0x18>,
-                             <0xc1108030 0x30>;
-                       reg-names = "mux", "pull", "pull-enable", "gpio";
-                       gpio-controller;
-                       #gpio-cells = <2>;
-               };
-
-               nand {
-                       mux {
-                               groups = "nand_io", "nand_io_ce0", "nand_io_ce1",
-                                        "nand_io_rb0", "nand_ale", "nand_cle",
-                                        "nand_wen_clk", "nand_ren_clk", "nand_dqs",
-                                        "nand_ce2", "nand_ce3";
-                               function = "nand";
-                       };
-               };
-       };
index 98d547c34ef37c3696fec69b77be78d71c679cbf..dbb3e1bd58c104a365a511bc04cda9f7bbdd66e1 100644 (file)
@@ -54,8 +54,8 @@ patternProperties:
   '-pins$':
     type: object
     allOf:
-      - $ref: "pinmux-node.yaml"
-      - $ref: "pincfg-node.yaml"
+      - $ref: pinmux-node.yaml
+      - $ref: pincfg-node.yaml
 
     properties:
       function: true
@@ -78,7 +78,7 @@ required:
   - gpio-ranges
 
 allOf:
-  - $ref: "pinctrl.yaml#"
+  - $ref: pinctrl.yaml#
   - if:
       properties:
         compatible:
diff --git a/Documentation/devicetree/bindings/pinctrl/nxp,s32g2-siul2-pinctrl.yaml b/Documentation/devicetree/bindings/pinctrl/nxp,s32g2-siul2-pinctrl.yaml
new file mode 100644 (file)
index 0000000..d49aafd
--- /dev/null
@@ -0,0 +1,123 @@
+# SPDX-License-Identifier: (GPL-2.0-only OR BSD-2-Clause)
+# Copyright 2022 NXP
+%YAML 1.2
+---
+$id: http://devicetree.org/schemas/pinctrl/nxp,s32g2-siul2-pinctrl.yaml#
+$schema: http://devicetree.org/meta-schemas/core.yaml#
+
+title: NXP S32G2 pin controller
+
+maintainers:
+  - Ghennadi Procopciuc <Ghennadi.Procopciuc@oss.nxp.com>
+  - Chester Lin <clin@suse.com>
+
+description: |
+  S32G2 pinmux is implemented in SIUL2 (System Integration Unit Lite2),
+  whose memory map is split into two regions:
+    SIUL2_0 @ 0x4009c000
+    SIUL2_1 @ 0x44010000
+
+  Every SIUL2 region has multiple register types, and here only MSCR and
+  IMCR registers need to be revealed for kernel to configure pinmux.
+
+  Please note that some register indexes are reserved in S32G2, such as
+  MSCR102-MSCR111, MSCR123-MSCR143, IMCR84-IMCR118 and IMCR398-IMCR429.
+
+properties:
+  compatible:
+    enum:
+      - nxp,s32g2-siul2-pinctrl
+
+  reg:
+    description: |
+      A list of MSCR/IMCR register regions to be reserved.
+      - MSCR (Multiplexed Signal Configuration Register)
+        An MSCR register can configure the associated pin as either a GPIO pin
+        or a function output pin depends on the selected signal source.
+      - IMCR (Input Multiplexed Signal Configuration Register)
+        An IMCR register can configure the associated pin as function input
+        pin depends on the selected signal source.
+    items:
+      - description: MSCR registers group 0 in SIUL2_0
+      - description: MSCR registers group 1 in SIUL2_1
+      - description: MSCR registers group 2 in SIUL2_1
+      - description: IMCR registers group 0 in SIUL2_0
+      - description: IMCR registers group 1 in SIUL2_1
+      - description: IMCR registers group 2 in SIUL2_1
+
+patternProperties:
+  '-pins$':
+    type: object
+    additionalProperties: false
+
+    patternProperties:
+      '-grp[0-9]$':
+        type: object
+        allOf:
+          - $ref: pinmux-node.yaml#
+          - $ref: pincfg-node.yaml#
+        description: |
+          Pinctrl node's client devices specify pin muxes using subnodes,
+          which in turn use the standard properties below.
+
+        properties:
+          bias-disable: true
+          bias-high-impedance: true
+          bias-pull-up: true
+          bias-pull-down: true
+          drive-open-drain: true
+          input-enable: true
+          output-enable: true
+
+          pinmux:
+            description: |
+              An integer array for representing pinmux configurations of
+              a device. Each integer consists of a PIN_ID and a 4-bit
+              selected signal source(SSS) as IOMUX setting, which is
+              calculated as: pinmux = (PIN_ID << 4 | SSS)
+
+          slew-rate:
+            description: Supported slew rate based on Fmax values (MHz)
+            enum: [83, 133, 150, 166, 208]
+
+        additionalProperties: false
+
+required:
+  - compatible
+  - reg
+
+additionalProperties: false
+
+examples:
+  - |
+    pinctrl@4009c240 {
+        compatible = "nxp,s32g2-siul2-pinctrl";
+
+              /* MSCR0-MSCR101 registers on siul2_0 */
+        reg = <0x4009c240 0x198>,
+              /* MSCR112-MSCR122 registers on siul2_1 */
+              <0x44010400 0x2c>,
+              /* MSCR144-MSCR190 registers on siul2_1 */
+              <0x44010480 0xbc>,
+              /* IMCR0-IMCR83 registers on siul2_0 */
+              <0x4009ca40 0x150>,
+              /* IMCR119-IMCR397 registers on siul2_1 */
+              <0x44010c1c 0x45c>,
+              /* IMCR430-IMCR495 registers on siul2_1 */
+              <0x440110f8 0x108>;
+
+        llce-can0-pins {
+            llce-can0-grp0 {
+                pinmux = <0x2b0>;
+                input-enable;
+                slew-rate = <208>;
+            };
+
+            llce-can0-grp1 {
+                pinmux = <0x2c2>;
+                output-enable;
+                slew-rate = <208>;
+            };
+        };
+    };
+...
diff --git a/Documentation/devicetree/bindings/pinctrl/pinctrl-mt8186.yaml b/Documentation/devicetree/bindings/pinctrl/pinctrl-mt8186.yaml
deleted file mode 100644 (file)
index 26573a7..0000000
+++ /dev/null
@@ -1,276 +0,0 @@
-# SPDX-License-Identifier: (GPL-2.0-only OR BSD-2-Clause)
-%YAML 1.2
----
-$id: http://devicetree.org/schemas/pinctrl/pinctrl-mt8186.yaml#
-$schema: http://devicetree.org/meta-schemas/core.yaml#
-
-title: Mediatek MT8186 Pin Controller
-
-maintainers:
-  - Sean Wang <sean.wang@mediatek.com>
-
-description: |
-  The Mediatek's Pin controller is used to control SoC pins.
-
-properties:
-  compatible:
-    const: mediatek,mt8186-pinctrl
-
-  gpio-controller: true
-
-  '#gpio-cells':
-    description: |
-      Number of cells in GPIO specifier. Since the generic GPIO binding is used,
-      the amount of cells must be specified as 2. See the below
-      mentioned gpio binding representation for description of particular cells.
-    const: 2
-
-  gpio-ranges:
-    maxItems: 1
-
-  gpio-line-names: true
-
-  reg:
-    description: |
-      Physical address base for gpio base registers. There are 8 different GPIO
-      physical address base in mt8186.
-    maxItems: 8
-
-  reg-names:
-    description: |
-      Gpio base register names.
-    items:
-      - const: iocfg0
-      - const: iocfg_lt
-      - const: iocfg_lm
-      - const: iocfg_lb
-      - const: iocfg_bl
-      - const: iocfg_rb
-      - const: iocfg_rt
-      - const: eint
-
-  interrupt-controller: true
-
-  '#interrupt-cells':
-    const: 2
-
-  interrupts:
-    description: The interrupt outputs to sysirq
-    maxItems: 1
-
-  mediatek,rsel-resistance-in-si-unit:
-    type: boolean
-    description: |
-      Identifying i2c pins pull up/down type which is RSEL. It can support
-      RSEL define or si unit value(ohm) to set different resistance.
-
-# PIN CONFIGURATION NODES
-patternProperties:
-  '-pins$':
-    type: object
-    additionalProperties: false
-    patternProperties:
-      '^pins':
-        type: object
-        additionalProperties: false
-        description: |
-          A pinctrl node should contain at least one subnodes representing the
-          pinctrl groups available on the machine. Each subnode will list the
-          pins it needs, and how they should be configured, with regard to muxer
-          configuration, pullups, drive strength, input enable/disable and
-          input schmitt.
-          An example of using macro:
-          pincontroller {
-            /* GPIO0 set as multifunction GPIO0 */
-            gpio-pins {
-              pins {
-                pinmux = <PINMUX_GPIO0__FUNC_GPIO0>;
-              }
-            };
-            /* GPIO128 set as multifunction SDA0 */
-            i2c0-pins {
-              pins {
-                pinmux = <PINMUX_GPIO128__FUNC_SDA0>;
-              }
-            };
-          };
-        $ref: "pinmux-node.yaml"
-
-        properties:
-          pinmux:
-            description: |
-              Integer array, represents gpio pin number and mux setting.
-              Supported pin number and mux varies for different SoCs, and are
-              defined as macros in dt-bindings/pinctrl/<soc>-pinfunc.h
-              directly.
-
-          drive-strength:
-            enum: [2, 4, 6, 8, 10, 12, 14, 16]
-
-          drive-strength-microamp:
-            enum: [125, 250, 500, 1000]
-
-          bias-pull-down:
-            oneOf:
-              - type: boolean
-              - enum: [100, 101, 102, 103]
-                description: mt8186 pull down PUPD/R0/R1 type define value.
-              - enum: [200, 201, 202, 203]
-                description: mt8186 pull down RSEL type define value.
-              - enum: [75000, 5000]
-                description: mt8186 pull down RSEL type si unit value(ohm).
-            description: |
-              For pull down type is normal, it don't need add RSEL & R1R0 define
-              and resistance value.
-              For pull down type is PUPD/R0/R1 type, it can add R1R0 define to
-              set different resistance. It can support "MTK_PUPD_SET_R1R0_00" &
-              "MTK_PUPD_SET_R1R0_01" & "MTK_PUPD_SET_R1R0_10" &
-              "MTK_PUPD_SET_R1R0_11" define in mt8186.
-              For pull down type is RSEL, it can add RSEL define & resistance
-              value(ohm) to set different resistance by identifying property
-              "mediatek,rsel-resistance-in-si-unit".
-              It can support "MTK_PULL_SET_RSEL_000" & "MTK_PULL_SET_RSEL_001"
-              & "MTK_PULL_SET_RSEL_010" & "MTK_PULL_SET_RSEL_011"
-              define in mt8186. It can also support resistance value(ohm)
-              "75000" & "5000" in mt8186.
-              An example of using RSEL define:
-              pincontroller {
-                i2c0_pin {
-                  pins {
-                    pinmux = <PINMUX_GPIO128__FUNC_SDA0>;
-                    bias-pull-down = <MTK_PULL_SET_RSEL_001>;
-                  }
-                };
-              };
-              An example of using si unit resistance value(ohm):
-              &pio {
-                mediatek,rsel-resistance-in-si-unit;
-              }
-              pincontroller {
-                i2c0_pin {
-                  pins {
-                    pinmux = <PINMUX_GPIO128__FUNC_SDA0>;
-                    bias-pull-down = <75000>;
-                  }
-                };
-              };
-
-          bias-pull-up:
-            oneOf:
-              - type: boolean
-              - enum: [100, 101, 102, 103]
-                description: mt8186 pull up PUPD/R0/R1 type define value.
-              - enum: [200, 201, 202, 203]
-                description: mt8186 pull up RSEL type define value.
-              - enum: [1000, 5000, 10000, 75000]
-                description: mt8186 pull up RSEL type si unit value(ohm).
-            description: |
-              For pull up type is normal, it don't need add RSEL & R1R0 define
-              and resistance value.
-              For pull up type is PUPD/R0/R1 type, it can add R1R0 define to
-              set different resistance. It can support "MTK_PUPD_SET_R1R0_00" &
-              "MTK_PUPD_SET_R1R0_01" & "MTK_PUPD_SET_R1R0_10" &
-              "MTK_PUPD_SET_R1R0_11" define in mt8186.
-              For pull up type is RSEL, it can add RSEL define & resistance
-              value(ohm) to set different resistance by identifying property
-              "mediatek,rsel-resistance-in-si-unit".
-              It can support "MTK_PULL_SET_RSEL_000" & "MTK_PULL_SET_RSEL_001"
-              & "MTK_PULL_SET_RSEL_010" & "MTK_PULL_SET_RSEL_011"
-              define in mt8186. It can also support resistance value(ohm)
-              "1000" & "5000" & "10000" & "75000" in mt8186.
-              An example of using si unit resistance value(ohm):
-              &pio {
-                mediatek,rsel-resistance-in-si-unit;
-              }
-              pincontroller {
-                i2c0-pins {
-                  pins {
-                    pinmux = <PINMUX_GPIO128__FUNC_SDA0>;
-                    bias-pull-up = <1000>;
-                  }
-                };
-              };
-
-          bias-disable: true
-
-          output-high: true
-
-          output-low: true
-
-          input-enable: true
-
-          input-disable: true
-
-          input-schmitt-enable: true
-
-          input-schmitt-disable: true
-
-        required:
-          - pinmux
-
-required:
-  - compatible
-  - reg
-  - interrupts
-  - interrupt-controller
-  - '#interrupt-cells'
-  - gpio-controller
-  - '#gpio-cells'
-  - gpio-ranges
-
-additionalProperties: false
-
-examples:
-  - |
-    #include <dt-bindings/pinctrl/mt8186-pinfunc.h>
-    #include <dt-bindings/interrupt-controller/arm-gic.h>
-
-    pio: pinctrl@10005000 {
-      compatible = "mediatek,mt8186-pinctrl";
-      reg = <0x10005000 0x1000>,
-            <0x10002000 0x0200>,
-            <0x10002200 0x0200>,
-            <0x10002400 0x0200>,
-            <0x10002600 0x0200>,
-            <0x10002A00 0x0200>,
-            <0x10002c00 0x0200>,
-            <0x1000b000 0x1000>;
-      reg-names = "iocfg0", "iocfg_lt", "iocfg_lm",
-                  "iocfg_lb", "iocfg_bl", "iocfg_rb",
-                  "iocfg_rt", "eint";
-      gpio-controller;
-      #gpio-cells = <2>;
-      gpio-ranges = <&pio 0 0 185>;
-      interrupt-controller;
-      interrupts = <GIC_SPI 186 IRQ_TYPE_LEVEL_HIGH 0>;
-      #interrupt-cells = <2>;
-
-      pio-pins {
-        pins {
-          pinmux = <PINMUX_GPIO0__FUNC_GPIO0>;
-          output-low;
-        };
-      };
-
-      spi0-pins {
-        pins-spi {
-          pinmux = <PINMUX_GPIO0__FUNC_SPI0_CLK_B>,
-                   <PINMUX_GPIO1__FUNC_SPI0_CSB_B>,
-                   <PINMUX_GPIO2__FUNC_SPI0_MO_B>;
-          bias-disable;
-        };
-        pins-spi-mi {
-          pinmux = <PINMUX_GPIO3__FUNC_SPI0_MI_B>;
-          bias-pull-down;
-        };
-      };
-
-      i2c0-pins {
-        pins {
-          pinmux = <PINMUX_GPIO127__FUNC_SCL0>,
-                   <PINMUX_GPIO128__FUNC_SDA0>;
-          bias-pull-up = <MTK_PULL_SET_RSEL_001>;
-          drive-strength-microamp = <1000>;
-        };
-      };
-    };
diff --git a/Documentation/devicetree/bindings/pinctrl/pinctrl-mt8192.yaml b/Documentation/devicetree/bindings/pinctrl/pinctrl-mt8192.yaml
deleted file mode 100644 (file)
index a09ebbf..0000000
+++ /dev/null
@@ -1,183 +0,0 @@
-# SPDX-License-Identifier: (GPL-2.0-only OR BSD-2-Clause)
-%YAML 1.2
----
-$id: http://devicetree.org/schemas/pinctrl/pinctrl-mt8192.yaml#
-$schema: http://devicetree.org/meta-schemas/core.yaml#
-
-title: Mediatek MT8192 Pin Controller
-
-maintainers:
-  - Sean Wang <sean.wang@mediatek.com>
-
-description: |
-  The Mediatek's Pin controller is used to control SoC pins.
-
-properties:
-  compatible:
-    const: mediatek,mt8192-pinctrl
-
-  gpio-controller: true
-
-  '#gpio-cells':
-    description: |
-      Number of cells in GPIO specifier. Since the generic GPIO binding is used,
-      the amount of cells must be specified as 2. See the below
-      mentioned gpio binding representation for description of particular cells.
-    const: 2
-
-  gpio-ranges:
-    description: gpio valid number range.
-    maxItems: 1
-
-  gpio-line-names: true
-
-  reg:
-    description: |
-      Physical address base for gpio base registers. There are 11 GPIO
-      physical address base in mt8192.
-    maxItems: 11
-
-  reg-names:
-    description: |
-      Gpio base register names.
-    maxItems: 11
-
-  interrupt-controller: true
-
-  '#interrupt-cells':
-    const: 2
-
-  interrupts:
-    description: The interrupt outputs to sysirq.
-    maxItems: 1
-
-# PIN CONFIGURATION NODES
-patternProperties:
-  '-pins$':
-    type: object
-    additionalProperties: false
-    patternProperties:
-      '^pins':
-        type: object
-        description: |
-          A pinctrl node should contain at least one subnodes representing the
-          pinctrl groups available on the machine. Each subnode will list the
-          pins it needs, and how they should be configured, with regard to muxer
-          configuration, pullups, drive strength, input enable/disable and
-          input schmitt.
-        $ref: "pinmux-node.yaml"
-
-        properties:
-          pinmux:
-            description: |
-              Integer array, represents gpio pin number and mux setting.
-              Supported pin number and mux varies for different SoCs, and are defined
-              as macros in dt-bindings/pinctrl/<soc>-pinfunc.h directly.
-
-          drive-strength:
-            description: |
-              It can support some arguments, such as MTK_DRIVE_4mA, MTK_DRIVE_6mA, etc. See
-              dt-bindings/pinctrl/mt65xx.h. It can only support 2/4/6/8/10/12/14/16mA in mt8192.
-            enum: [2, 4, 6, 8, 10, 12, 14, 16]
-
-          drive-strength-microamp:
-            enum: [125, 250, 500, 1000]
-
-          bias-pull-down:
-            oneOf:
-              - type: boolean
-                description: normal pull down.
-              - enum: [100, 101, 102, 103]
-                description: PUPD/R1/R0 pull down type. See MTK_PUPD_SET_R1R0_
-                  defines in dt-bindings/pinctrl/mt65xx.h.
-              - enum: [200, 201, 202, 203]
-                description: RSEL pull down type. See MTK_PULL_SET_RSEL_
-                  defines in dt-bindings/pinctrl/mt65xx.h.
-
-          bias-pull-up:
-            oneOf:
-              - type: boolean
-                description: normal pull up.
-              - enum: [100, 101, 102, 103]
-                description: PUPD/R1/R0 pull up type. See MTK_PUPD_SET_R1R0_
-                  defines in dt-bindings/pinctrl/mt65xx.h.
-              - enum: [200, 201, 202, 203]
-                description: RSEL pull up type. See MTK_PULL_SET_RSEL_
-                  defines in dt-bindings/pinctrl/mt65xx.h.
-
-          bias-disable: true
-
-          output-high: true
-
-          output-low: true
-
-          input-enable: true
-
-          input-disable: true
-
-          input-schmitt-enable: true
-
-          input-schmitt-disable: true
-
-        required:
-          - pinmux
-
-        additionalProperties: false
-
-allOf:
-  - $ref: "pinctrl.yaml#"
-
-required:
-  - compatible
-  - reg
-  - interrupts
-  - interrupt-controller
-  - '#interrupt-cells'
-  - gpio-controller
-  - '#gpio-cells'
-  - gpio-ranges
-
-additionalProperties: false
-
-examples:
-  - |
-            #include <dt-bindings/pinctrl/mt8192-pinfunc.h>
-            #include <dt-bindings/interrupt-controller/arm-gic.h>
-            pio: pinctrl@10005000 {
-                    compatible = "mediatek,mt8192-pinctrl";
-                    reg = <0x10005000 0x1000>,
-                          <0x11c20000 0x1000>,
-                          <0x11d10000 0x1000>,
-                          <0x11d30000 0x1000>,
-                          <0x11d40000 0x1000>,
-                          <0x11e20000 0x1000>,
-                          <0x11e70000 0x1000>,
-                          <0x11ea0000 0x1000>,
-                          <0x11f20000 0x1000>,
-                          <0x11f30000 0x1000>,
-                          <0x1000b000 0x1000>;
-                    reg-names = "iocfg0", "iocfg_rm", "iocfg_bm",
-                          "iocfg_bl", "iocfg_br", "iocfg_lm",
-                          "iocfg_lb", "iocfg_rt", "iocfg_lt",
-                          "iocfg_tl", "eint";
-                    gpio-controller;
-                    #gpio-cells = <2>;
-                    gpio-ranges = <&pio 0 0 220>;
-                    interrupt-controller;
-                    interrupts = <GIC_SPI 212 IRQ_TYPE_LEVEL_HIGH 0>;
-                    #interrupt-cells = <2>;
-
-                    spi1-default-pins {
-                            pins-cs-mosi-clk {
-                                    pinmux = <PINMUX_GPIO157__FUNC_SPI1_A_CSB>,
-                                             <PINMUX_GPIO159__FUNC_SPI1_A_MO>,
-                                             <PINMUX_GPIO156__FUNC_SPI1_A_CLK>;
-                                    bias-disable;
-                            };
-
-                            pins-miso {
-                                    pinmux = <PINMUX_GPIO158__FUNC_SPI1_A_MI>;
-                                    bias-pull-down;
-                            };
-                    };
-            };
diff --git a/Documentation/devicetree/bindings/pinctrl/pinctrl-mt8195.yaml b/Documentation/devicetree/bindings/pinctrl/pinctrl-mt8195.yaml
deleted file mode 100644 (file)
index 66fe17e..0000000
+++ /dev/null
@@ -1,287 +0,0 @@
-# SPDX-License-Identifier: (GPL-2.0-only OR BSD-2-Clause)
-%YAML 1.2
----
-$id: http://devicetree.org/schemas/pinctrl/pinctrl-mt8195.yaml#
-$schema: http://devicetree.org/meta-schemas/core.yaml#
-
-title: Mediatek MT8195 Pin Controller
-
-maintainers:
-  - Sean Wang <sean.wang@mediatek.com>
-
-description: |
-  The Mediatek's Pin controller is used to control SoC pins.
-
-properties:
-  compatible:
-    const: mediatek,mt8195-pinctrl
-
-  gpio-controller: true
-
-  '#gpio-cells':
-    description: |
-      Number of cells in GPIO specifier. Since the generic GPIO binding is used,
-      the amount of cells must be specified as 2. See the below
-      mentioned gpio binding representation for description of particular cells.
-    const: 2
-
-  gpio-ranges:
-    description: gpio valid number range.
-    maxItems: 1
-
-  gpio-line-names: true
-
-  reg:
-    description: |
-      Physical address base for gpio base registers. There are 8 GPIO
-      physical address base in mt8195.
-    maxItems: 8
-
-  reg-names:
-    description: |
-      Gpio base register names.
-    maxItems: 8
-
-  interrupt-controller: true
-
-  '#interrupt-cells':
-    const: 2
-
-  interrupts:
-    description: The interrupt outputs to sysirq.
-    maxItems: 1
-
-  mediatek,rsel-resistance-in-si-unit:
-    type: boolean
-    description: |
-      Identifying i2c pins pull up/down type which is RSEL. It can support
-      RSEL define or si unit value(ohm) to set different resistance.
-
-# PIN CONFIGURATION NODES
-patternProperties:
-  '-pins$':
-    type: object
-    additionalProperties: false
-    patternProperties:
-      '^pins':
-        type: object
-        additionalProperties: false
-        description: |
-          A pinctrl node should contain at least one subnodes representing the
-          pinctrl groups available on the machine. Each subnode will list the
-          pins it needs, and how they should be configured, with regard to muxer
-          configuration, pullups, drive strength, input enable/disable and
-          input schmitt.
-          An example of using macro:
-          pincontroller {
-            /* GPIO0 set as multifunction GPIO0 */
-            gpio-pins {
-              pins {
-                pinmux = <PINMUX_GPIO0__FUNC_GPIO0>;
-              }
-            };
-            /* GPIO8 set as multifunction SDA0 */
-            i2c0-pins {
-              pins {
-                pinmux = <PINMUX_GPIO8__FUNC_SDA0>;
-              }
-            };
-          };
-        $ref: "pinmux-node.yaml"
-
-        properties:
-          pinmux:
-            description: |
-              Integer array, represents gpio pin number and mux setting.
-              Supported pin number and mux varies for different SoCs, and are
-              defined as macros in dt-bindings/pinctrl/<soc>-pinfunc.h
-              directly.
-
-          drive-strength:
-            enum: [2, 4, 6, 8, 10, 12, 14, 16]
-
-          drive-strength-microamp:
-            enum: [125, 250, 500, 1000]
-
-          bias-pull-down:
-            oneOf:
-              - type: boolean
-              - enum: [100, 101, 102, 103]
-                description: mt8195 pull down PUPD/R0/R1 type define value.
-              - enum: [200, 201, 202, 203, 204, 205, 206, 207]
-                description: mt8195 pull down RSEL type define value.
-              - enum: [75000, 5000]
-                description: mt8195 pull down RSEL type si unit value(ohm).
-            description: |
-              For pull down type is normal, it don't need add RSEL & R1R0 define
-              and resistance value.
-              For pull down type is PUPD/R0/R1 type, it can add R1R0 define to
-              set different resistance. It can support "MTK_PUPD_SET_R1R0_00" &
-              "MTK_PUPD_SET_R1R0_01" & "MTK_PUPD_SET_R1R0_10" &
-              "MTK_PUPD_SET_R1R0_11" define in mt8195.
-              For pull down type is RSEL, it can add RSEL define & resistance
-              value(ohm) to set different resistance by identifying property
-              "mediatek,rsel-resistance-in-si-unit".
-              It can support "MTK_PULL_SET_RSEL_000" & "MTK_PULL_SET_RSEL_001"
-              & "MTK_PULL_SET_RSEL_010" & "MTK_PULL_SET_RSEL_011"
-              & "MTK_PULL_SET_RSEL_100" & "MTK_PULL_SET_RSEL_101"
-              & "MTK_PULL_SET_RSEL_110" & "MTK_PULL_SET_RSEL_111"
-              define in mt8195. It can also support resistance value(ohm)
-              "75000" & "5000" in mt8195.
-
-              An example of using RSEL define:
-              pincontroller {
-                i2c0_pin {
-                  pins {
-                    pinmux = <PINMUX_GPIO8__FUNC_SDA0>;
-                    bias-pull-down = <MTK_PULL_SET_RSEL_001>;
-                  }
-                };
-              };
-              An example of using si unit resistance value(ohm):
-              &pio {
-                mediatek,rsel-resistance-in-si-unit;
-              }
-              pincontroller {
-                i2c0_pin {
-                  pins {
-                    pinmux = <PINMUX_GPIO8__FUNC_SDA0>;
-                    bias-pull-down = <75000>;
-                  }
-                };
-              };
-
-          bias-pull-up:
-            oneOf:
-              - type: boolean
-              - enum: [100, 101, 102, 103]
-                description: mt8195 pull up PUPD/R0/R1 type define value.
-              - enum: [200, 201, 202, 203, 204, 205, 206, 207]
-                description: mt8195 pull up RSEL type define value.
-              - enum: [1000, 1500, 2000, 3000, 4000, 5000, 10000, 75000]
-                description: mt8195 pull up RSEL type si unit value(ohm).
-            description: |
-              For pull up type is normal, it don't need add RSEL & R1R0 define
-              and resistance value.
-              For pull up type is PUPD/R0/R1 type, it can add R1R0 define to
-              set different resistance. It can support "MTK_PUPD_SET_R1R0_00" &
-              "MTK_PUPD_SET_R1R0_01" & "MTK_PUPD_SET_R1R0_10" &
-              "MTK_PUPD_SET_R1R0_11" define in mt8195.
-              For pull up type is RSEL, it can add RSEL define & resistance
-              value(ohm) to set different resistance by identifying property
-              "mediatek,rsel-resistance-in-si-unit".
-              It can support "MTK_PULL_SET_RSEL_000" & "MTK_PULL_SET_RSEL_001"
-              & "MTK_PULL_SET_RSEL_010" & "MTK_PULL_SET_RSEL_011"
-              & "MTK_PULL_SET_RSEL_100" & "MTK_PULL_SET_RSEL_101"
-              & "MTK_PULL_SET_RSEL_110" & "MTK_PULL_SET_RSEL_111"
-              define in mt8195. It can also support resistance value(ohm)
-              "1000" & "1500" & "2000" & "3000" & "4000" & "5000" & "10000" &
-              "75000" in mt8195.
-              An example of using RSEL define:
-              pincontroller {
-                i2c0-pins {
-                  pins {
-                    pinmux = <PINMUX_GPIO8__FUNC_SDA0>;
-                    bias-pull-up = <MTK_PULL_SET_RSEL_001>;
-                  }
-                };
-              };
-              An example of using si unit resistance value(ohm):
-              &pio {
-                mediatek,rsel-resistance-in-si-unit;
-              }
-              pincontroller {
-                i2c0-pins {
-                  pins {
-                    pinmux = <PINMUX_GPIO8__FUNC_SDA0>;
-                    bias-pull-up = <1000>;
-                  }
-                };
-              };
-
-          bias-disable: true
-
-          output-high: true
-
-          output-low: true
-
-          input-enable: true
-
-          input-disable: true
-
-          input-schmitt-enable: true
-
-          input-schmitt-disable: true
-
-        required:
-          - pinmux
-
-allOf:
-  - $ref: "pinctrl.yaml#"
-
-required:
-  - compatible
-  - reg
-  - interrupts
-  - interrupt-controller
-  - '#interrupt-cells'
-  - gpio-controller
-  - '#gpio-cells'
-  - gpio-ranges
-
-additionalProperties: false
-
-examples:
-  - |
-    #include <dt-bindings/pinctrl/mt8195-pinfunc.h>
-    #include <dt-bindings/interrupt-controller/arm-gic.h>
-    #
-    pio: pinctrl@10005000 {
-      compatible = "mediatek,mt8195-pinctrl";
-      reg = <0x10005000 0x1000>,
-            <0x11d10000 0x1000>,
-            <0x11d30000 0x1000>,
-            <0x11d40000 0x1000>,
-            <0x11e20000 0x1000>,
-            <0x11eb0000 0x1000>,
-            <0x11f40000 0x1000>,
-            <0x1000b000 0x1000>;
-      reg-names = "iocfg0", "iocfg_bm", "iocfg_bl",
-                  "iocfg_br", "iocfg_lm", "iocfg_rb",
-                  "iocfg_tl", "eint";
-      gpio-controller;
-      #gpio-cells = <2>;
-      gpio-ranges = <&pio 0 0 144>;
-      interrupt-controller;
-      interrupts = <GIC_SPI 225 IRQ_TYPE_LEVEL_HIGH 0>;
-      #interrupt-cells = <2>;
-
-      pio-pins {
-        pins {
-          pinmux = <PINMUX_GPIO0__FUNC_GPIO0>;
-          output-low;
-        };
-      };
-
-      spi0-pins {
-        pins-spi {
-          pinmux = <PINMUX_GPIO132__FUNC_SPIM0_CSB>,
-                   <PINMUX_GPIO134__FUNC_SPIM0_MO>,
-                   <PINMUX_GPIO133__FUNC_SPIM0_CLK>;
-          bias-disable;
-        };
-        pins-spi-mi {
-          pinmux = <PINMUX_GPIO135__FUNC_SPIM0_MI>;
-          bias-pull-down;
-        };
-      };
-
-      i2c0-pins {
-        pins {
-          pinmux = <PINMUX_GPIO8__FUNC_SDA0>,
-                   <PINMUX_GPIO9__FUNC_SCL0>;
-          bias-disable;
-          drive-strength-microamp = <1000>;
-        };
-      };
-    };
index 300747252a7b5c1a036a49830ebba4eb20012b56..3d3086ae1ba6946a6d0e2934d6ef8d1ff500cb3a 100644 (file)
@@ -56,6 +56,7 @@ $defs:
       Pinctrl node's client devices use subnodes for desired pin configuration.
       Client device subnodes use below standard properties.
     $ref: qcom,tlmm-common.yaml#/$defs/qcom-tlmm-state
+    unevaluatedProperties: false
 
     properties:
       pins:
@@ -92,19 +93,9 @@ $defs:
                 rx1, sdc_data, sdc_clk, sdc_cmd, tsens_max, wci_txd, wci_rxd,
                 wsi_clk, wsi_clk3, wsi_data, wsi_data3, wsis_reset, xfem ]
 
-      bias-pull-down: true
-      bias-pull-up: true
-      bias-disable: true
-      drive-strength: true
-      input-enable: true
-      output-high: true
-      output-low: true
-
     required:
       - pins
 
-    additionalProperties: false
-
 required:
   - compatible
   - reg
index 28f1b6a07b70d8d07435236377d7bc02fdc5b183..7c3e5e043f078df68f774a06f40b4157666e0f73 100644 (file)
@@ -43,6 +43,7 @@ $defs:
       Pinctrl node's client devices use subnodes for desired pin configuration.
       Client device subnodes use below standard properties.
     $ref: qcom,tlmm-common.yaml#/$defs/qcom-tlmm-state
+    unevaluatedProperties: false
 
     properties:
       pins:
@@ -89,18 +90,9 @@ $defs:
                 sd_write, sec_mi2s, smb_int, ssbi_wtr0, ssbi_wtr1, uim1, uim2,
                 uim3, uim_batt, wcss_bt, wcss_fm, wcss_wlan, webcam1_rst ]
 
-      bias-pull-down: true
-      bias-pull-up: true
-      bias-disable: true
-      drive-strength: true
-      output-high: true
-      output-low: true
-
     required:
       - pins
 
-    additionalProperties: false
-
 allOf:
   - $ref: /schemas/pinctrl/qcom,tlmm-common.yaml#
 
index 3137db927fc0a7e419435c0c1eefb0021050654d..e053fbd588b51efabee91573c8f7bddecc6da01e 100644 (file)
@@ -53,6 +53,7 @@ $defs:
       Pinctrl node's client devices use subnodes for desired pin configuration.
       Client device subnodes use below standard properties.
     $ref: qcom,tlmm-common.yaml#/$defs/qcom-tlmm-state
+    unevaluatedProperties: false
 
     properties:
       pins:
@@ -92,19 +93,9 @@ $defs:
                 qdss_tracedata_b, qpic, rx0, rx1, rx2, sd_card, sd_write,
                 tsens_max, wci2a, wci2b, wci2c, wci2d ]
 
-      bias-pull-down: true
-      bias-pull-up: true
-      bias-disable: true
-      drive-strength: true
-      input-enable: true
-      output-high: true
-      output-low: true
-
     required:
       - pins
 
-    additionalProperties: false
-
 allOf:
   - $ref: /schemas/pinctrl/qcom,tlmm-common.yaml#
 
diff --git a/Documentation/devicetree/bindings/pinctrl/qcom,ipq9574-tlmm.yaml b/Documentation/devicetree/bindings/pinctrl/qcom,ipq9574-tlmm.yaml
new file mode 100644 (file)
index 0000000..673713d
--- /dev/null
@@ -0,0 +1,130 @@
+# SPDX-License-Identifier: (GPL-2.0-only OR BSD-2-Clause)
+%YAML 1.2
+---
+$id: http://devicetree.org/schemas/pinctrl/qcom,ipq9574-tlmm.yaml#
+$schema: http://devicetree.org/meta-schemas/core.yaml#
+
+title: Qualcomm Technologies, Inc. IPQ9574 TLMM block
+
+maintainers:
+  - Bjorn Andersson <andersson@kernel.org>
+  - Krzysztof Kozlowski <krzysztof.kozlowski@linaro.org>
+
+description:
+  Top Level Mode Multiplexer pin controller in Qualcomm IPQ9574 SoC.
+
+properties:
+  compatible:
+    const: qcom,ipq9574-tlmm
+
+  reg:
+    maxItems: 1
+
+  interrupts:
+    maxItems: 1
+
+  interrupt-controller: true
+  "#interrupt-cells": true
+  gpio-controller: true
+  "#gpio-cells": true
+  gpio-ranges: true
+  wakeup-parent: true
+
+  gpio-reserved-ranges:
+    minItems: 1
+    maxItems: 33
+
+  gpio-line-names:
+    maxItems: 65
+
+patternProperties:
+  "-state$":
+    oneOf:
+      - $ref: "#/$defs/qcom-ipq9574-tlmm-state"
+      - patternProperties:
+          "-pins$":
+            $ref: "#/$defs/qcom-ipq9574-tlmm-state"
+        additionalProperties: false
+
+$defs:
+  qcom-ipq9574-tlmm-state:
+    type: object
+    description:
+      Pinctrl node's client devices use subnodes for desired pin configuration.
+      Client device subnodes use below standard properties.
+    $ref: qcom,tlmm-common.yaml#/$defs/qcom-tlmm-state
+
+    properties:
+      pins:
+        description:
+          List of gpio pins affected by the properties specified in this
+          subnode.
+        items:
+          pattern: "^gpio([0-9]|[1-5][0-9]|6[0-4])$"
+        minItems: 1
+        maxItems: 8
+
+      function:
+        description:
+          Specify the alternative function to be configured for the specified
+          pins.
+
+        enum: [ atest_char, atest_char0, atest_char1, atest_char2, atest_char3,
+                audio_pdm0, audio_pdm1, audio_pri, audio_sec, blsp0_spi, blsp0_uart,
+                blsp1_i2c, blsp1_spi, blsp1_uart, blsp2_i2c, blsp2_spi,
+                blsp2_uart, blsp3_i2c, blsp3_spi, blsp3_uart, blsp4_i2c,
+                blsp4_spi, blsp4_uart, blsp5_i2c, blsp5_uart, cri_trng0,
+                cri_trng1, cri_trng2, cri_trng3, cxc0, cxc1, dbg_out, dwc_ddrphy,
+                gcc_plltest, gcc_tlmm, gpio, mac, mdc, mdio, pcie0_clk, pcie0_wake,
+                pcie1_clk, pcie1_wake, pcie2_clk, pcie2_wake, pcie3_clk, pcie3_wake,
+                prng_rosc0, prng_rosc1, prng_rosc2, prng_rosc3, pta, pwm,
+                qdss_cti_trig_in_a0, qdss_cti_trig_in_a1, qdss_cti_trig_in_b0,
+                qdss_cti_trig_in_b1, qdss_cti_trig_out_a0, qdss_cti_trig_out_a1,
+                qdss_cti_trig_out_b0, qdss_cti_trig_out_b1, qdss_traceclk_a,
+                qdss_traceclk_b, qdss_tracectl_a, qdss_tracectl_b, qdss_tracedata_a,
+                qdss_tracedata_b, qspi_clk, qspi_cs, qspi_data,
+                rx0, rx1, sdc_clk, sdc_cmd, sdc_data, sdc_rclk, tsens_max,
+                wci20, wci21, wsa_swrm ]
+
+      bias-pull-down: true
+      bias-pull-up: true
+      bias-disable: true
+      drive-strength: true
+      input-enable: true
+      output-high: true
+      output-low: true
+
+    required:
+      - pins
+
+    additionalProperties: false
+
+allOf:
+  - $ref: /schemas/pinctrl/qcom,tlmm-common.yaml#
+
+required:
+  - compatible
+  - reg
+
+additionalProperties: false
+
+examples:
+  - |
+    #include <dt-bindings/interrupt-controller/arm-gic.h>
+    tlmm: pinctrl@1000000 {
+        compatible = "qcom,ipq9574-tlmm";
+        reg = <0x01000000 0x300000>;
+        interrupts = <GIC_SPI 208 IRQ_TYPE_LEVEL_HIGH>;
+        gpio-controller;
+        #gpio-cells = <2>;
+        interrupt-controller;
+        #interrupt-cells = <2>;
+        gpio-ranges = <&tlmm 0 0 65>;
+
+        uart2-state {
+            pins = "gpio34", "gpio35";
+            function = "blsp2_uart";
+            drive-strength = <8>;
+            bias-pull-down;
+        };
+    };
index 96b598bf9a76ff0984be7c08f0f7dcf531ff5c3d..2aedb7e7bc8b1df324f99111b6138cd7754838db 100644 (file)
@@ -54,6 +54,7 @@ $defs:
       Pinctrl node's client devices use subnodes for desired pin configuration.
       Client device subnodes use below standard properties.
     $ref: qcom,tlmm-common.yaml#/$defs/qcom-tlmm-state
+    unevaluatedProperties: false
 
     properties:
       pins:
@@ -105,19 +106,9 @@ $defs:
                 uim1_clk, uim1_data, uim1_present, uim1_reset, uim2_clk,
                 uim2_data, uim2_present, uim2_reset, uim_batt, wlan_en1, ]
 
-      bias-disable: true
-      bias-pull-down: true
-      bias-pull-up: true
-      drive-strength: true
-      input-enable: true
-      output-high: true
-      output-low: true
-
     required:
       - pins
 
-    additionalProperties: false
-
 examples:
   - |
     #include <dt-bindings/interrupt-controller/arm-gic.h>
index c7c94d742ed2b983d1e3dd96484f78095c441096..5885aee95c98e247f0f1af760f456892a2358b8f 100644 (file)
@@ -51,6 +51,7 @@ $defs:
       Pinctrl node's client devices use subnodes for desired pin configuration.
       Client device subnodes use below standard properties.
     $ref: qcom,tlmm-common.yaml#/$defs/qcom-tlmm-state
+    unevaluatedProperties: false
 
     properties:
       pins:
@@ -70,19 +71,9 @@ $defs:
         enum: [ gpio, gsbi2_i2c, gsbi3, gsbi4, gsbi5_i2c, gsbi5_uart,
                 sdc2, ebi2_lcdc, ps_hold, prim_audio, sec_audio, cdc_mclk, ]
 
-      bias-disable: true
-      bias-pull-down: true
-      bias-pull-up: true
-      drive-strength: true
-      output-high: true
-      output-low: true
-      input-enable: true
-
     required:
       - pins
 
-    additionalProperties: false
-
 examples:
   - |
     #include <dt-bindings/interrupt-controller/arm-gic.h>
index 6cb667fa8665ea3bc69af72f9e817193432dd180..9efb76509580434bece9e5784a0b639e7562e593 100644 (file)
@@ -48,6 +48,7 @@ $defs:
       Pinctrl node's client devices use subnodes for desired pin configuration.
       Client device subnodes use below standard properties.
     $ref: qcom,tlmm-common.yaml#/$defs/qcom-tlmm-state
+    unevaluatedProperties: false
 
     properties:
       pins:
@@ -71,19 +72,9 @@ $defs:
                 blsp_uart3, blsp_uart4, blsp_uart5, cam_mclk0, cam_mclk1,
                 gp0_clk, gp1_clk, sdc3, wlan ]
 
-      bias-pull-down: true
-      bias-pull-up: true
-      bias-disable: true
-      drive-strength: true
-      input-enable: true
-      output-high: true
-      output-low: true
-
     required:
       - pins
 
-    additionalProperties: false
-
 allOf:
   - $ref: /schemas/pinctrl/qcom,tlmm-common.yaml#
 
index 348d84c3cd2161af6753efe1378067a3048a7719..a05971611780947e2c156605a92abeac01e6dbe4 100644 (file)
@@ -53,6 +53,7 @@ $defs:
       Pinctrl node's client devices use subnodes for desired pin configuration.
       Client device subnodes use below standard properties.
     $ref: qcom,tlmm-common.yaml#/$defs/qcom-tlmm-state
+    unevaluatedProperties: false
 
     properties:
       pins:
@@ -81,20 +82,9 @@ $defs:
                 sdc5, tsif1, tsif2, usb_fs1, usb_fs1_oe_n, usb_fs2,
                 usb_fs2_oe_n, vfe, vsens_alarm, ebi2, ebi2cs ]
 
-
-      bias-pull-down: true
-      bias-pull-up: true
-      bias-disable: true
-      drive-strength: true
-      input-enable: true
-      output-high: true
-      output-low: true
-
     required:
       - pins
 
-    additionalProperties: false
-
 allOf:
   - $ref: /schemas/pinctrl/qcom,tlmm-common.yaml#
 
index 85082adc1811f2c0ca149d8515fc603d5b75d92a..5095e86fe9a2136a204126bb0050cb5371f79c6a 100644 (file)
@@ -55,6 +55,7 @@ $defs:
       Pinctrl node's client devices use subnodes for desired pin configuration.
       Client device subnodes use below standard properties.
     $ref: qcom,tlmm-common.yaml#/$defs/qcom-tlmm-state
+    unevaluatedProperties: false
 
     properties:
       pins:
@@ -104,19 +105,9 @@ $defs:
                 uim3_clk, uim3_data, uim3_present, uim3_reset, uim_batt,
                 wcss_bt, wcss_fm, wcss_wlan ]
 
-      bias-disable: true
-      bias-pull-down: true
-      bias-pull-up: true
-      drive-strength: true
-      input-enable: true
-      output-high: true
-      output-low: true
-
     required:
       - pins
 
-    additionalProperties: false
-
 examples:
   - |
     #include <dt-bindings/interrupt-controller/arm-gic.h>
index 633c9e5ed49e062525587cabccf5087046a058fe..063d004967bbeb3355b4d9153cadac8d18030f10 100644 (file)
@@ -53,6 +53,7 @@ $defs:
       Pinctrl node's client devices use subnodes for desired pin configuration.
       Client device subnodes use below standard properties.
     $ref: qcom,tlmm-common.yaml#/$defs/qcom-tlmm-state
+    unevaluatedProperties: false
 
     properties:
       pins:
@@ -103,19 +104,9 @@ $defs:
                 uim1, uim2, uim3, uim_batt, wcss_bt, wcss_fm, wcss_wlan,
                 webcam1_rst ]
 
-      bias-pull-down: true
-      bias-pull-up: true
-      bias-disable: true
-      drive-strength: true
-      input-enable: true
-      output-high: true
-      output-low: true
-
     required:
       - pins
 
-    additionalProperties: false
-
 allOf:
   - $ref: /schemas/pinctrl/qcom,tlmm-common.yaml#
 
index ce219827ccc832c5ef329ca5ac5be07b43860a54..798aac9e6e31b207a89deaa5ac4e72e7e145d074 100644 (file)
@@ -45,6 +45,7 @@ $defs:
       Pinctrl node's client devices use subnodes for desired pin configuration.
       Client device subnodes use below standard properties.
     $ref: qcom,tlmm-common.yaml#/$defs/qcom-tlmm-state
+    unevaluatedProperties: false
 
     properties:
       pins:
@@ -106,18 +107,9 @@ $defs:
                 uim_batt, us_emitter, us_euro, wcss_bt, wcss_fm, wcss_wlan,
                 wcss_wlan0, wcss_wlan1, wcss_wlan2, wsa_en, wsa_io, wsa_irq ]
 
-      bias-pull-down: true
-      bias-pull-up: true
-      bias-disable: true
-      drive-strength: true
-      output-high: true
-      output-low: true
-
     required:
       - pins
 
-    additionalProperties: false
-
 allOf:
   - $ref: /schemas/pinctrl/qcom,tlmm-common.yaml#
 
index cf386f644ccb02568b5d622458243a51bb567dab..9172b50f7a9825680e7359385bf42f785892b2e8 100644 (file)
@@ -53,6 +53,7 @@ $defs:
       Pinctrl node's client devices use subnodes for desired pin configuration.
       Client device subnodes use below standard properties.
     $ref: qcom,tlmm-common.yaml#/$defs/qcom-tlmm-state
+    unevaluatedProperties: false
 
     properties:
       pins:
@@ -97,19 +98,9 @@ $defs:
                 vfe_camif_timer7_a, vfe_camif_timer7_b, vfe_camif_timer7_c,
                 wlan ]
 
-      bias-pull-down: true
-      bias-pull-up: true
-      bias-disable: true
-      drive-strength: true
-      input-enable: true
-      output-high: true
-      output-low: true
-
     required:
       - pins
 
-    additionalProperties: false
-
 allOf:
   - $ref: /schemas/pinctrl/qcom,tlmm-common.yaml#
 
index afe4a80f0b79621f2171e0ffe407c3a5029e3f60..8a3be65c51edee8ae16f1cd9cf21d828f9190716 100644 (file)
@@ -53,6 +53,7 @@ $defs:
       Pinctrl node's client devices use subnodes for desired pin configuration.
       Client device subnodes use below standard properties.
     $ref: qcom,tlmm-common.yaml#/$defs/qcom-tlmm-state
+    unevaluatedProperties: false
 
     properties:
       pins:
@@ -93,14 +94,6 @@ $defs:
                 tsif1, tsif2, hsic, grfc, audio_ref_clk, qua_mi2s, pri_mi2s,
                 spkr_mi2s, ter_mi2s, sec_mi2s, bt, fm, wlan, slimbus, hsic_ctl ]
 
-      bias-pull-down: true
-      bias-pull-up: true
-      bias-disable: true
-      drive-strength: true
-      input-enable: true
-      output-high: true
-      output-low: true
-
     required:
       - pins
 
@@ -124,8 +117,6 @@ $defs:
             output-high: false
             output-low: false
 
-    additionalProperties: false
-
 allOf:
   - $ref: /schemas/pinctrl/qcom,tlmm-common.yaml#
 
index 5dfcc3eadbb0c69a4ec031be21c3cf45f5e5904b..ca95de0b87a6a19f49a57a308092a29dcd7bc207 100644 (file)
@@ -53,6 +53,7 @@ $defs:
       Desired pin configuration for a device or its specific state (like sleep
       or active).
     $ref: qcom,tlmm-common.yaml#/$defs/qcom-tlmm-state
+    unevaluatedProperties: false
 
     properties:
       pins:
@@ -93,19 +94,9 @@ $defs:
                 wsa_irq, blsp_i2c8, pa_indicator, modem_tsync, ssbi_wtr1,
                 gsm1_tx, gsm0_tx, sdcard_det, sec_mi2s, ss_switch ]
 
-      bias-pull-down: true
-      bias-pull-up: true
-      bias-disable: true
-      drive-strength: true
-      input-enable: true
-      output-high: true
-      output-low: true
-
     required:
       - pins
 
-    additionalProperties: false
-
 allOf:
   - $ref: /schemas/pinctrl/qcom,tlmm-common.yaml#
 
index 0c4936fc35ef40db8b422f44782b6b6461c49d23..41525ecfa8e3a4d4691e8462163c93b2af70a789 100644 (file)
@@ -55,6 +55,7 @@ $defs:
       Pinctrl node's client devices use subnodes for desired pin configuration.
       Client device subnodes use below standard properties.
     $ref: qcom,tlmm-common.yaml#/$defs/qcom-tlmm-state
+    unevaluatedProperties: false
 
     properties:
       pins:
@@ -103,19 +104,9 @@ $defs:
                 pri_mi2s, sdc4, sec_mi2s, slimbus, spkr_i2s, ter_mi2s, tsif1,
                 tsif2, uim_batt_alarm, uim1, uim2, uim3, uim4 ]
 
-      bias-pull-down: true
-      bias-pull-up: true
-      bias-disable: true
-      drive-strength: true
-      input-enable: true
-      output-high: true
-      output-low: true
-
     required:
       - pins
 
-    additionalProperties: false
-
 allOf:
   - $ref: /schemas/pinctrl/qcom,tlmm-common.yaml#
 
index 047b4584e3c0139b6f1998c5279ccb6ae489444a..59d406b609574f4a2c19f20c6e7c2859fddad89b 100644 (file)
@@ -53,6 +53,7 @@ $defs:
       Pinctrl node's client devices use subnodes for desired pin configuration.
       Client device subnodes use below standard properties.
     $ref: qcom,tlmm-common.yaml#/$defs/qcom-tlmm-state
+    unevaluatedProperties: false
 
     properties:
       pins:
@@ -122,19 +123,9 @@ $defs:
                 modem_tsync, nav_dr, nav_pps, pci_e1, gsm_tx, qspi_cs, ssbi2,
                 ssbi1, mss_lte, qspi_clk, qspi0, qspi1, qspi2, qspi3 ]
 
-      bias-pull-down: true
-      bias-pull-up: true
-      bias-disable: true
-      drive-strength: true
-      input-enable: true
-      output-high: true
-      output-low: true
-
     required:
       - pins
 
-    additionalProperties: false
-
 allOf:
   - $ref: /schemas/pinctrl/qcom,tlmm-common.yaml#
 
index c07ee986804600d1181cc9d101a6e89a92fef541..bd6d7caf499afb6e1c3026d81c3e69f22285bc99 100644 (file)
@@ -53,6 +53,7 @@ $defs:
       Pinctrl node's client devices use subnodes for desired pin configuration.
       Client device subnodes use below standard properties.
     $ref: qcom,tlmm-common.yaml#/$defs/qcom-tlmm-state
+    unevaluatedProperties: false
 
     properties:
       pins:
@@ -107,19 +108,9 @@ $defs:
                 vsense_clkout, vsense_data0, vsense_data1, vsense_mode,
                 wlan1_adc0, wlan1_adc1, wlan2_adc0, wlan2_adc1 ]
 
-      bias-pull-down: true
-      bias-pull-up: true
-      bias-disable: true
-      drive-strength: true
-      input-enable: true
-      output-high: true
-      output-low: true
-
     required:
       - pins
 
-    additionalProperties: false
-
 allOf:
   - $ref: /schemas/pinctrl/qcom,tlmm-common.yaml#
 
index db505fdeac86f23b0977bc1f55f7a3943b335c6f..eaadd5a9a44532dfd988f7b58250d78d354d4c35 100644 (file)
@@ -52,12 +52,14 @@ properties:
           - qcom,pm8994-gpio
           - qcom,pm8998-gpio
           - qcom,pma8084-gpio
+          - qcom,pmi632-gpio
           - qcom,pmi8950-gpio
           - qcom,pmi8994-gpio
           - qcom,pmi8998-gpio
           - qcom,pmk8350-gpio
           - qcom,pmk8550-gpio
           - qcom,pmm8155au-gpio
+          - qcom,pmm8654au-gpio
           - qcom,pmp8074-gpio
           - qcom,pmr735a-gpio
           - qcom,pmr735b-gpio
@@ -173,6 +175,7 @@ allOf:
               - qcom,pm8350b-gpio
               - qcom,pm8550ve-gpio
               - qcom,pm8950-gpio
+              - qcom,pmi632-gpio
     then:
       properties:
         gpio-line-names:
@@ -395,8 +398,8 @@ $defs:
   qcom-pmic-gpio-state:
     type: object
     allOf:
-      - $ref: "pinmux-node.yaml"
-      - $ref: "pincfg-node.yaml"
+      - $ref: pinmux-node.yaml
+      - $ref: pincfg-node.yaml
     properties:
       pins:
         description:
@@ -434,11 +437,13 @@ $defs:
                  - gpio1-gpio22 for pm8994
                  - gpio1-gpio26 for pm8998
                  - gpio1-gpio22 for pma8084
+                 - gpio1-gpio8 for pmi632
                  - gpio1-gpio2 for pmi8950
                  - gpio1-gpio10 for pmi8994
                  - gpio1-gpio4 for pmk8350
                  - gpio1-gpio6 for pmk8550
                  - gpio1-gpio10 for pmm8155au
+                 - gpio1-gpio12 for pmm8654au
                  - gpio1-gpio12 for pmp8074 (holes on gpio1 and gpio12)
                  - gpio1-gpio4 for pmr735a
                  - gpio1-gpio4 for pmr735b
index 9412b9362328de15167ba812f1f3ca9421bf0087..c91d3e3a094b8f319785e2c0aefcf8d1761c31db 100644 (file)
@@ -82,8 +82,8 @@ $defs:
   qcom-pmic-mpp-state:
     type: object
     allOf:
-      - $ref: "pinmux-node.yaml"
-      - $ref: "pincfg-node.yaml"
+      - $ref: pinmux-node.yaml
+      - $ref: pincfg-node.yaml
     properties:
       pins:
         description:
index 6271fd15e0b6764856bdf3412a032f17a355a0ff..03276364933664387fb4b67e584412cd87add40c 100644 (file)
@@ -85,6 +85,7 @@ $defs:
       bias-pull-up: true
       bias-disable: true
       drive-strength: true
+      input-enable: true
       output-high: true
       output-low: true
 
index 20bc967a17b5ac411eee4df37a0cf70de84f4f6c..b1b9cd319e50a3212f38386e39b8275a267ef02a 100644 (file)
@@ -59,6 +59,7 @@ $defs:
       Pinctrl node's client devices use subnodes for desired pin configuration.
       Client device subnodes use below standard properties.
     $ref: qcom,tlmm-common.yaml#/$defs/qcom-tlmm-state
+    unevaluatedProperties: false
 
     properties:
       pins:
@@ -119,19 +120,9 @@ $defs:
                 spdifrx_opt, spi_lcd, spkr_dac0, wlan1_adc0, wlan1_adc1,
                 wlan2_adc0, wlan2_adc1, wsa_en ]
 
-      bias-pull-down: true
-      bias-pull-up: true
-      bias-disable: true
-      drive-strength: true
-      input-enable: true
-      output-high: true
-      output-low: true
-
     required:
       - pins
 
-    additionalProperties: false
-
 allOf:
   - $ref: /schemas/pinctrl/qcom,tlmm-common.yaml#
 
index 7e5fb9a6e7d350e115bb10997e01b19132139741..237cac4f6ce1dfcf1d28c9d9a7dea0669a0c423d 100644 (file)
@@ -55,6 +55,7 @@ $defs:
       Pinctrl node's client devices use subnodes for desired pin configuration.
       Client device subnodes use below standard properties.
     $ref: qcom,tlmm-common.yaml#/$defs/qcom-tlmm-state
+    unevaluatedProperties: false
 
     properties:
       pins:
@@ -93,19 +94,9 @@ $defs:
                 usb2phy_ac, usb_con_det, usb_dfp_en, usb_phy, vfr_0, vfr_1,
                 vsense_trigger ]
 
-      bias-disable: true
-      bias-pull-down: true
-      bias-pull-up: true
-      drive-strength: true
-      input-enable: true
-      output-high: true
-      output-low: true
-
     required:
       - pins
 
-    additionalProperties: false
-
 required:
   - compatible
   - reg
index 70d9106ad83dfa991f5d4b6d17ab20402ca9168b..e608a4f1bcaec78f0192c8567a61476a66a928ad 100644 (file)
@@ -58,6 +58,7 @@ $defs:
       Pinctrl node's client devices use subnodes for desired pin configuration.
       Client device subnodes use below standard properties.
     $ref: qcom,tlmm-common.yaml#/$defs/qcom-tlmm-state
+    unevaluatedProperties: false
 
     properties:
       pins:
@@ -103,19 +104,9 @@ $defs:
                 tgu_ch2, tgu_ch3, tgu_ch4, tgu_ch5, tsense_pwm1, tsense_pwm2,
                 tsense_pwm3, tsense_pwm4, usb2phy_ac, vsense_trigger ]
 
-      bias-disable: true
-      bias-pull-down: true
-      bias-pull-up: true
-      drive-strength: true
-      input-enable: true
-      output-high: true
-      output-low: true
-
     required:
       - pins
 
-    additionalProperties: false
-
 examples:
   - |
     #include <dt-bindings/interrupt-controller/arm-gic.h>
index f33792a1af6c68c0267fda393c689a1ff5e7df4a..573e459b1c44a1391278facdcf3b655601e0aa65 100644 (file)
@@ -59,6 +59,7 @@ $defs:
       Pinctrl node's client devices use subnodes for desired pin configuration.
       Client device subnodes use below standard properties.
     $ref: qcom,tlmm-common.yaml#/$defs/qcom-tlmm-state
+    unevaluatedProperties: false
 
     properties:
       pins:
@@ -100,19 +101,9 @@ $defs:
                 _V_GPIO, _V_PPS_IN, _V_PPS_OUT, vsense_trigger, wlan1_adc0,
                 wlan1_adc1, wlan2_adc0, wlan2_adc1 ]
 
-      bias-pull-down: true
-      bias-pull-up: true
-      bias-disable: true
-      drive-strength: true
-      input-enable: true
-      output-high: true
-      output-low: true
-
     required:
       - pins
 
-    additionalProperties: false
-
 allOf:
   - $ref: /schemas/pinctrl/qcom,tlmm-common.yaml#
 
index e51feb4c0700586f5c438d2bb57044db55825e36..fa51fa9536f767da5b1e9c7748016fda7fdc2234 100644 (file)
@@ -50,7 +50,7 @@ $defs:
     description:
       Pinctrl node's client devices use subnodes for desired pin configuration.
       Client device subnodes use below standard properties.
-    $ref: "/schemas/pinctrl/pincfg-node.yaml"
+    $ref: /schemas/pinctrl/pincfg-node.yaml
 
     properties:
       pins:
index 36502173cb79cab89e9687c658f979d13cc516cb..368d44ff54681290a751d8cb7ab0ca283b64ccd4 100644 (file)
@@ -62,6 +62,7 @@ $defs:
       Pinctrl node's client devices use subnodes for desired pin configuration.
       Client device subnodes use below standard properties.
     $ref: qcom,tlmm-common.yaml#/$defs/qcom-tlmm-state
+    unevaluatedProperties: false
 
     properties:
       pins:
@@ -110,20 +111,9 @@ $defs:
                 uim1_clk, uim1_data, uim1_present, uim1_reset, usb2phy_ac,
                 usb_phy, vfr_0, vfr_1, vsense_trigger ]
 
-      bias-pull-down: true
-      bias-pull-up: true
-      bias-bus-hold: true
-      bias-disable: true
-      drive-strength: true
-      input-enable: true
-      output-high: true
-      output-low: true
-
     required:
       - pins
 
-    additionalProperties: false
-
 allOf:
   - $ref: /schemas/pinctrl/qcom,tlmm-common.yaml#
 
index 0ace55c9868edeb2c0a13f63b6d4e324a6c100db..b086a5184235a67899d5b05e2ebea499e2768626 100644 (file)
@@ -62,6 +62,7 @@ $defs:
       Pinctrl node's client devices use subnodes for desired pin configuration.
       Client device subnodes use below standard properties.
     $ref: qcom,tlmm-common.yaml#/$defs/qcom-tlmm-state
+    unevaluatedProperties: false
 
     properties:
       pins:
@@ -102,19 +103,9 @@ $defs:
                 usb0_phy, usb1_phy, usb2phy_ac, vfr_1, vsense_trigger,
                 wlan1_adc, wlan2_adc, wmss_reset ]
 
-      bias-disable: true
-      bias-pull-down: true
-      bias-pull-up: true
-      drive-strength: true
-      input-enable: true
-      output-high: true
-      output-low: true
-
     required:
       - pins
 
-    additionalProperties: false
-
 examples:
   - |
     #include <dt-bindings/interrupt-controller/arm-gic.h>
index 200b3b6ccd87f86fa1bda7f9f9150e37b86423eb..a9167dac9ab58b239c226df894238bbbbb9fa737 100644 (file)
@@ -20,7 +20,7 @@ properties:
   reg:
     items:
       - description: LPASS LPI TLMM Control and Status registers
-      - description: LPASS LPI pins SLEW registers
+      - description: LPASS LPI MCC registers
 
   clocks:
     items:
index 97b27d6835e983edf571a070e61a13310cbb3195..4ae39fc7894a2e6763c4cc6d4529b05e1fb32f0e 100644 (file)
@@ -104,6 +104,7 @@ $defs:
                 usb1_phy, usb1_sbrx, usb1_sbtx, usb1_usb4, usb2phy_ac,
                 vsense_trigger ]
 
+      bias-bus-hold: true
       bias-disable: true
       bias-pull-down: true
       bias-pull-up: true
index ea6bd0b44f5695c3c90a46852c691cc33e7dd08e..508e0633b253e4a8ae12e54334cf7fb5f421f1b6 100644 (file)
@@ -65,6 +65,7 @@ $defs:
       Pinctrl node's client devices use subnodes for desired pin configuration.
       Client device subnodes use below standard properties.
     $ref: qcom,tlmm-common.yaml#/$defs/qcom-tlmm-state
+    unevaluatedProperties: false
 
     properties:
       pins:
@@ -122,19 +123,9 @@ $defs:
                 vsense_data0, vsense_data1, vsense_mode, wlan1_adc0,
                 wlan1_adc1, wlan2_adc0, wlan2_adc1 ]
 
-      bias-disable: true
-      bias-pull-down: true
-      bias-pull-up: true
-      drive-strength: true
-      input-enable: true
-      output-high: true
-      output-low: true
-
     required:
       - pins
 
-    additionalProperties: false
-
 required:
   - compatible
   - reg
index f586b3aa138e5123bd0503f20a0d5381bafeee68..84a15f77e710a5335f789d0d7fdcb05ecdbfc8ed 100644 (file)
@@ -58,6 +58,7 @@ $defs:
       Pinctrl node's client devices use subnodes for desired pin configuration.
       Client device subnodes use below standard properties.
     $ref: qcom,tlmm-common.yaml#/$defs/qcom-tlmm-state
+    unevaluatedProperties: false
 
     properties:
       pins:
@@ -94,20 +95,9 @@ $defs:
                 uim1_reset, uim2_clk, uim2_data, uim2_present, uim2_reset, uim_batt, usb_phy, vfr_1,
                 vsense_trigger, wlan1_adc0, wlan1_adc1, wlan2_adc0, wlan2_adc1, wsa_clk, wsa_data, ]
 
-
-      bias-disable: true
-      bias-pull-down: true
-      bias-pull-up: true
-      drive-strength: true
-      input-enable: true
-      output-high: true
-      output-low: true
-
     required:
       - pins
 
-    additionalProperties: false
-
 examples:
   - |
     #include <dt-bindings/interrupt-controller/arm-gic.h>
index 23d7c030fec0aa78058fd116d8b940abc0388b6a..d301881ddfa8e02031ef0cfb329bdfcdea8bda6b 100644 (file)
@@ -61,6 +61,7 @@ $defs:
       Pinctrl node's client devices use subnodes for desired pin configuration.
       Client device subnodes use below standard properties.
     $ref: qcom,tlmm-common.yaml#/$defs/qcom-tlmm-state
+    unevaluatedProperties: false
 
     properties:
       pins:
@@ -102,19 +103,9 @@ $defs:
                 uim_batt, usb_phy, vfr_1, vsense_trigger, wlan1_adc0,
                 wlan1_adc1, wlan2_adc0, wlan2_adc1]
 
-      bias-disable: true
-      bias-pull-down: true
-      bias-pull-up: true
-      drive-strength: true
-      input-enable: true
-      output-high: true
-      output-low: true
-
     required:
       - pins
 
-    additionalProperties: false
-
 required:
   - compatible
   - reg
index a40175258495a02bce31c97f4357c53ad4dff982..67af99dd8f147bfb122ce6b20304bbfbcb0e862f 100644 (file)
@@ -48,6 +48,7 @@ $defs:
       Pinctrl node's client devices use subnodes for desired pin configuration.
       Client device subnodes use below standard properties.
     $ref: qcom,tlmm-common.yaml#/$defs/qcom-tlmm-state
+    unevaluatedProperties: false
 
     properties:
       pins:
@@ -91,18 +92,9 @@ $defs:
                 uim1_present, uim1_reset, uim2_clk, uim2_data, uim2_present,
                 uim2_reset, usb2phy_ac, vsense_trigger ]
 
-      bias-pull-down: true
-      bias-pull-up: true
-      bias-disable: true
-      drive-strength: true
-      output-high: true
-      output-low: true
-
     required:
       - pins
 
-    additionalProperties: false
-
 allOf:
   - $ref: /schemas/pinctrl/qcom,tlmm-common.yaml#
 
index 89c5562583d157aaca194d55590ed45ec5c992b0..2ef793ae40387957a57086f2642c035764f1d929 100644 (file)
@@ -47,6 +47,7 @@ $defs:
       Pinctrl node's client devices use subnodes for desired pin configuration.
       Client device subnodes use below standard properties.
     $ref: qcom,tlmm-common.yaml#/$defs/qcom-tlmm-state
+    unevaluatedProperties: false
 
     properties:
       pins:
@@ -111,18 +112,9 @@ $defs:
                 qspi_cs, ssbi2, ssbi1, mss_lte, qspi_clk, qspi0, qspi1, qspi2, qspi3,
                 gpio ]
 
-      bias-pull-down: true
-      bias-pull-up: true
-      bias-disable: true
-      drive-strength: true
-      output-high: true
-      output-low: true
-
     required:
       - pins
 
-    additionalProperties: false
-
 allOf:
   - $ref: /schemas/pinctrl/qcom,tlmm-common.yaml#
 
index 29325483cd2b79b8518f69cce62e2c7ef2b0ce56..871df54f69a2eb192fd43a8c19d36e2fe54b4f8e 100644 (file)
@@ -53,6 +53,7 @@ $defs:
       Pinctrl node's client devices use subnodes for desired pin configuration.
       Client device subnodes use below standard properties.
     $ref: qcom,tlmm-common.yaml#/$defs/qcom-tlmm-state
+    unevaluatedProperties: false
 
     properties:
       pins:
@@ -85,18 +86,9 @@ $defs:
                 uim2_present, uim2_reset, usb_phy, vfr_1, vsense_trigger,
                 wlan1_adc0, elan1_adc1 ]
 
-      bias-pull-down: true
-      bias-pull-up: true
-      bias-disable: true
-      drive-strength: true
-      output-high: true
-      output-low: true
-
     required:
       - pins
 
-    additionalProperties: false
-
 allOf:
   - $ref: /schemas/pinctrl/qcom,tlmm-common.yaml#
 
index c9bc4893e8e8abbc5d61f51cc0412fe125b7b35f..8d77707b02b9fef344290b757f3308b5b51bb10e 100644 (file)
@@ -61,6 +61,7 @@ $defs:
       Pinctrl node's client devices use subnodes for desired pin configuration.
       Client device subnodes use below standard properties.
     $ref: qcom,tlmm-common.yaml#/$defs/qcom-tlmm-state
+    unevaluatedProperties: false
 
     properties:
       pins:
@@ -101,19 +102,9 @@ $defs:
                 wlan1_adc0, wlan1_adc1, wlan2_adc0, wlan2_adc1, wsa_clk, wsa_data ]
 
 
-      bias-disable: true
-      bias-pull-down: true
-      bias-pull-up: true
-      drive-strength: true
-      input-enable: true
-      output-high: true
-      output-low: true
-
     required:
       - pins
 
-    additionalProperties: false
-
 examples:
   - |
     #include <dt-bindings/interrupt-controller/arm-gic.h>
index d95935fcc8b5a1c9dd68bb905df7fa57bea613de..27af379cf791aa0b9fab6921098a3e5ee76850ea 100644 (file)
@@ -63,6 +63,7 @@ $defs:
       Pinctrl node's client devices use subnodes for desired pin configuration.
       Client device subnodes use below standard properties.
     $ref: qcom,tlmm-common.yaml#/$defs/qcom-tlmm-state
+    unevaluatedProperties: false
 
     properties:
       pins:
@@ -108,20 +109,9 @@ $defs:
                 uim2_present, uim2_reset, usb_phy, vfr_1, vsense_trigger, wlan1_adc0, wlan1_adc1,
                 wlan2_adc0, wlan2_adc1, ]
 
-
-      bias-disable: true
-      bias-pull-down: true
-      bias-pull-up: true
-      drive-strength: true
-      input-enable: true
-      output-high: true
-      output-low: true
-
     required:
       - pins
 
-    additionalProperties: false
-
 examples:
   - |
     #include <dt-bindings/interrupt-controller/arm-gic.h>
index 66cef48ed59b434af2659ba4261f64c0ce820a30..6e02ba24825f111bdee19a16123d1207921462b2 100644 (file)
@@ -55,6 +55,7 @@ $defs:
       Pinctrl node's client devices use subnodes for desired pin configuration.
       Client device subnodes use below standard properties.
     $ref: qcom,tlmm-common.yaml#/$defs/qcom-tlmm-state
+    unevaluatedProperties: false
 
     properties:
       pins:
@@ -109,20 +110,9 @@ $defs:
                 usb_phy, vfr_1, vsense_trigger, wlan1_adc0, wlan1_adc1,
                 wlan2_adc0, wlan2_adc1 ]
 
-
-      bias-disable: true
-      bias-pull-down: true
-      bias-pull-up: true
-      drive-strength: true
-      input-enable: true
-      output-high: true
-      output-low: true
-
     required:
       - pins
 
-    additionalProperties: false
-
 examples:
   - |
     #include <dt-bindings/interrupt-controller/arm-gic.h>
diff --git a/Documentation/devicetree/bindings/pinctrl/qcom,sm7150-tlmm.yaml b/Documentation/devicetree/bindings/pinctrl/qcom,sm7150-tlmm.yaml
new file mode 100644 (file)
index 0000000..a57d44e
--- /dev/null
@@ -0,0 +1,162 @@
+# SPDX-License-Identifier: (GPL-2.0-only OR BSD-2-Clause)
+%YAML 1.2
+---
+$id: http://devicetree.org/schemas/pinctrl/qcom,sm7150-tlmm.yaml#
+$schema: http://devicetree.org/meta-schemas/core.yaml#
+
+title: Qualcomm SM7150 TLMM pin controller
+
+maintainers:
+  - Bjorn Andersson <andersson@kernel.org>
+  - Danila Tikhonov <danila@jiaxyga.com>
+
+description:
+  Top Level Mode Multiplexer pin controller in Qualcomm SM7150 SoC.
+
+allOf:
+  - $ref: /schemas/pinctrl/qcom,tlmm-common.yaml#
+
+properties:
+  compatible:
+    const: qcom,sm7150-tlmm
+
+  reg:
+    maxItems: 3
+
+  reg-names:
+    items:
+      - const: west
+      - const: north
+      - const: south
+
+  interrupts:
+    maxItems: 1
+
+  interrupt-controller: true
+  "#interrupt-cells": true
+  gpio-controller: true
+  "#gpio-cells": true
+  gpio-ranges: true
+  wakeup-parent: true
+
+  gpio-reserved-ranges:
+    minItems: 1
+    maxItems: 60
+
+  gpio-line-names:
+    maxItems: 119
+
+patternProperties:
+  "-state$":
+    oneOf:
+      - $ref: "#/$defs/qcom-sm7150-tlmm-state"
+      - patternProperties:
+          "-pins$":
+            $ref: "#/$defs/qcom-sm7150-tlmm-state"
+        additionalProperties: false
+
+$defs:
+  qcom-sm7150-tlmm-state:
+    type: object
+    description:
+      Pinctrl node's client devices use subnodes for desired pin configuration.
+      Client device subnodes use below standard properties.
+    $ref: qcom,tlmm-common.yaml#/$defs/qcom-tlmm-state
+
+    properties:
+      pins:
+        description:
+          List of gpio pins affected by the properties specified in this
+          subnode.
+        items:
+          oneOf:
+            - pattern: "^gpio([0-9]|[1-9][0-9]|10[0-9]|11[0-8])$"
+            - enum: [ sdc1_rclk, sdc1_clk, sdc1_cmd, sdc1_data, sdc2_clk,
+                      sdc2_cmd, sdc2_data, ufs_reset ]
+        minItems: 1
+        maxItems: 36
+
+      function:
+        description:
+          Specify the alternative function to be configured for the specified
+          pins.
+
+        enum: [ gpio, adsp_ext, agera_pll, aoss_cti, atest_char, atest_tsens,
+                atest_tsens2, atest_usb1, atest_usb2, cam_mclk, cci_async,
+                cci_i2c, cci_timer0, cci_timer1, cci_timer2, cci_timer3,
+                cci_timer4, dbg_out, ddr_bist, ddr_pxi0, ddr_pxi1, ddr_pxi2,
+                ddr_pxi3, edp_hot, edp_lcd, gcc_gp1, gcc_gp2, gcc_gp3, gp_pdm0,
+                gp_pdm1, gp_pdm2, gps_tx, jitter_bist, ldo_en, ldo_update,
+                m_voc, mdp_vsync, mdp_vsync0, mdp_vsync1, mdp_vsync2,
+                mdp_vsync3, mss_lte, nav_pps_in, nav_pps_out, pa_indicator,
+                pci_e, phase_flag, pll_bist, pll_bypassnl, pll_reset, pri_mi2s,
+                pri_mi2s_ws, prng_rosc, qdss, qdss_cti, qlink_enable,
+                qlink_request, qua_mi2s, qup00, qup01, qup02, qup03, qup04,
+                qup10, qup11, qup12, qup13, qup14, qup15, sd_write, sdc40,
+                sdc41, sdc42, sdc43, sdc4_clk, sdc4_cmd, sec_mi2s, ter_mi2s,
+                tgu_ch0, tgu_ch1, tgu_ch2, tgu_ch3, tsif1_clk, tsif1_data,
+                tsif1_en, tsif1_error, tsif1_sync, tsif2_clk, tsif2_data,
+                tsif2_en, tsif2_error, tsif2_sync, uim1_clk, uim1_data,
+                uim1_present, uim1_reset, uim2_clk, uim2_data, uim2_present,
+                uim2_reset, uim_batt, usb_phy, vfr_1, vsense_trigger,
+                wlan1_adc0, wlan1_adc1, wlan2_adc0, wlan2_adc1, wsa_clk,
+                wsa_data ]
+
+      bias-pull-down: true
+      bias-pull-up: true
+      bias-disable: true
+      drive-strength: true
+      input-enable: true
+      output-high: true
+      output-low: true
+
+    required:
+      - pins
+
+    additionalProperties: false
+
+required:
+  - compatible
+  - reg
+  - reg-names
+
+additionalProperties: false
+
+examples:
+  - |
+    #include <dt-bindings/interrupt-controller/arm-gic.h>
+
+    tlmm: pinctrl@3500000 {
+        compatible = "qcom,sm7150-tlmm";
+        reg = <0x03500000 0x300000>,
+              <0x03900000 0x300000>,
+              <0x03d00000 0x300000>;
+        reg-names = "west", "north", "south";
+        interrupts = <GIC_SPI 208 IRQ_TYPE_LEVEL_HIGH>;
+        gpio-ranges = <&tlmm 0 0 120>;
+        gpio-controller;
+        #gpio-cells = <2>;
+        interrupt-controller;
+        #interrupt-cells = <2>;
+        wakeup-parent = <&pdc>;
+
+        gpio-wo-state {
+            pins = "gpio1";
+            function = "gpio";
+        };
+
+        uart-w-state {
+            rx-pins {
+                pins = "gpio44";
+                function = "qup12";
+                bias-pull-up;
+            };
+
+            tx-pins {
+                pins = "gpio45";
+                function = "qup12";
+                bias-disable;
+            };
+        };
+    };
+...
index 4376a9bd4d70dceafce08485701e8e52081852be..c6439626464ef9a5bb11a1c106f6e0098a4d0c87 100644 (file)
@@ -60,6 +60,7 @@ $defs:
       Pinctrl node's client devices use subnodes for desired pin configuration.
       Client device subnodes use below standard properties.
     $ref: qcom,tlmm-common.yaml#/$defs/qcom-tlmm-state
+    unevaluatedProperties: false
 
     properties:
       pins:
@@ -81,7 +82,7 @@ $defs:
         enum: [ adsp_ext, agera_pll, aoss_cti, ddr_pxi2, atest_char,
                 atest_char0, atest_char1, atest_char2, atest_char3, audio_ref,
                 atest_usb1, atest_usb2, atest_usb10, atest_usb11, atest_usb12,
-                atest_usb13, atest_usb20, atest_usb21, atest_usb22, atest_usb2,
+                atest_usb13, atest_usb20, atest_usb21, atest_usb22,
                 atest_usb23, btfm_slimbus, cam_mclk, cci_async, cci_i2c,
                 cci_timer0, cci_timer1, cci_timer2, cci_timer3, cci_timer4,
                 cri_trng, cri_trng0, cri_trng1, dbg_out, ddr_bist, ddr_pxi0,
@@ -101,19 +102,9 @@ $defs:
                 usb_phy, vfr_1, vsense_trigger, wlan1_adc0, wlan1_adc1,
                 wlan2_adc0, wlan2_adc1, wmss_reset ]
 
-      bias-pull-down: true
-      bias-pull-up: true
-      bias-disable: true
-      drive-strength: true
-      input-enable: true
-      output-high: true
-      output-low: true
-
     required:
       - pins
 
-    additionalProperties: false
-
 allOf:
   - $ref: /schemas/pinctrl/qcom,tlmm-common.yaml#
 
index de9d8854c69017ee3769f9883df4dd81e7e45cb4..4b4be7efc150ac90bcb8a8f55fdb222f5085498b 100644 (file)
@@ -55,7 +55,7 @@ $defs:
     description:
       Pinctrl node's client devices use subnodes for desired pin configuration.
       Client device subnodes use below standard properties.
-    $ref: "/schemas/pinctrl/pincfg-node.yaml"
+    $ref: /schemas/pinctrl/pincfg-node.yaml
 
     properties:
       pins:
index cf561dff8893d0cc1fc6767c793c6538a4ebf78f..021c5470852469f606bae49dcb31beb42927d3e7 100644 (file)
@@ -58,6 +58,7 @@ $defs:
       Pinctrl node's client devices use subnodes for desired pin configuration.
       Client device subnodes use below standard properties.
     $ref: qcom,tlmm-common.yaml#/$defs/qcom-tlmm-state
+    unevaluatedProperties: false
 
     properties:
       pins:
@@ -94,19 +95,9 @@ $defs:
                 tsif0_en, tsif0_error, tsif0_sync, tsif1_clk, tsif1_data, tsif1_en,
                 tsif1_error, tsif1_sync, usb2phy_ac, usb_phy, vsense_trigger ]
 
-      bias-pull-down: true
-      bias-pull-up: true
-      bias-disable: true
-      drive-strength: true
-      input-enable: true
-      output-high: true
-      output-low: true
-
     required:
       - pins
 
-    additionalProperties: false
-
 allOf:
   - $ref: /schemas/pinctrl/qcom,tlmm-common.yaml#
 
index 797242f68b1c9a91e4c9753d824521714b3658fb..6e8f41ff0a76bebdeb4eac05ddd0ab3be5d7b703 100644 (file)
@@ -62,6 +62,7 @@ $defs:
       Pinctrl node's client devices use subnodes for desired pin configuration.
       Client device subnodes use below standard properties.
     $ref: qcom,tlmm-common.yaml#/$defs/qcom-tlmm-state
+    unevaluatedProperties: false
 
     properties:
       pins:
@@ -104,21 +105,9 @@ $defs:
                 uim0_present, uim0_reset, uim1_clk, uim1_data, uim1_present,
                 uim1_reset, usb2phy_ac, usb_phy, vfr_0, vfr_1, vsense_trigger ]
 
-
-      bias-disable: true
-      bias-pull-down: true
-      bias-pull-up: true
-      drive-strength: true
-      input-disable: true
-      input-enable: true
-      output-high: true
-      output-low: true
-
     required:
       - pins
 
-    additionalProperties: false
-
 examples:
   - |
     #include <dt-bindings/interrupt-controller/arm-gic.h>
index 8bf51df0b231b91e513b81b61ee0c7c167ca888c..1eefa9aa6a86cc1598951e4d63a4005a4522940d 100644 (file)
@@ -20,7 +20,7 @@ properties:
   reg:
     items:
       - description: LPASS LPI TLMM Control and Status registers
-      - description: LPASS LPI pins SLEW registers
+      - description: LPASS LPI MCC registers
 
   clocks:
     items:
index 56c8046f1be044510122af65a207c0c7f63d60e3..5163fe3f536520890530d9bbbfa2c8858e4e3b92 100644 (file)
@@ -62,6 +62,7 @@ $defs:
       Pinctrl node's client devices use subnodes for desired pin configuration.
       Client device subnodes use below standard properties.
     $ref: qcom,tlmm-common.yaml#/$defs/qcom-tlmm-state
+    unevaluatedProperties: false
 
     properties:
       pins:
@@ -103,19 +104,9 @@ $defs:
                 uim0_reset, uim1_clk, uim1_data, uim1_present, uim1_reset,
                 usb2phy_ac, usb_phy, vfr_0, vfr_1, vsense_trigger ]
 
-      bias-disable: true
-      bias-pull-down: true
-      bias-pull-up: true
-      drive-strength: true
-      input-enable: true
-      output-high: true
-      output-low: true
-
     required:
       - pins
 
-    additionalProperties: false
-
 examples:
   - |
     #include <dt-bindings/interrupt-controller/arm-gic.h>
index 8f60a9113e7a28ab7628e036d4d2445102868d1e..ef974324684987480ec819da232d083f64b7a46f 100644 (file)
@@ -21,7 +21,7 @@ properties:
   reg:
     items:
       - description: LPASS LPI TLMM Control and Status registers
-      - description: LPASS LPI pins SLEW registers
+      - description: LPASS LPI MCC registers
 
   clocks:
     items:
index a457425ba112d87b29d19a7e82136ca7d7b4ebd6..f789c7753a92cede9652116e455935f2c346f951 100644 (file)
@@ -54,6 +54,7 @@ $defs:
       Pinctrl node's client devices use subnodes for desired pin configuration.
       Client device subnodes use below standard properties.
     $ref: qcom,tlmm-common.yaml#/$defs/qcom-tlmm-state
+    unevaluatedProperties: false
 
     properties:
       pins:
@@ -109,19 +110,9 @@ $defs:
                 uim1_clk, uim1_data, uim1_present, uim1_reset,
                 usb1_hs, usb_phy, vfr_0, vfr_1, vsense_trigger_mirnat ]
 
-      bias-disable: true
-      bias-pull-down: true
-      bias-pull-up: true
-      drive-strength: true
-      input-enable: true
-      output-high: true
-      output-low: true
-
     required:
       - pins
 
-    additionalProperties: false
-
 required:
   - compatible
   - reg
index 90b7d75840c18af336ae9b074effd9d785b314a8..aae3dcf6cac88ac1f425a19ea3fa94bfe6f0ca46 100644 (file)
@@ -52,7 +52,7 @@ properties:
       information.
 
 allOf:
-  - $ref: "pinctrl.yaml#"
+  - $ref: pinctrl.yaml#
 
 required:
   - interrupts
diff --git a/Documentation/devicetree/bindings/pinctrl/ralink,mt7620-pinctrl.yaml b/Documentation/devicetree/bindings/pinctrl/ralink,mt7620-pinctrl.yaml
deleted file mode 100644 (file)
index 1e63ea3..0000000
+++ /dev/null
@@ -1,658 +0,0 @@
-# SPDX-License-Identifier: GPL-2.0-only OR BSD-2-Clause
-%YAML 1.2
----
-$id: http://devicetree.org/schemas/pinctrl/ralink,mt7620-pinctrl.yaml#
-$schema: http://devicetree.org/meta-schemas/core.yaml#
-
-title: Ralink MT7620 Pin Controller
-
-maintainers:
-  - Arınç ÜNAL <arinc.unal@arinc9.com>
-  - Sergio Paracuellos <sergio.paracuellos@gmail.com>
-
-description:
-  Ralink MT7620 pin controller for MT7620, MT7628 and MT7688 SoCs.
-  The pin controller can only set the muxing of pin groups. Muxing individual
-  pins is not supported. There is no pinconf support.
-
-properties:
-  compatible:
-    const: ralink,mt7620-pinctrl
-
-patternProperties:
-  '-pins$':
-    type: object
-    patternProperties:
-      '^(.*-)?pinmux$':
-        type: object
-        description: node for pinctrl.
-        $ref: pinmux-node.yaml#
-
-        properties:
-          function:
-            description:
-              A string containing the name of the function to mux to the group.
-            anyOf:
-              - description: For MT7620 SoC
-                enum: [ephy, gpio, gpio i2s, gpio uartf, i2c, i2s uartf, mdio, nand, pa,
-                       pcie refclk, pcie rst, pcm gpio, pcm i2s, pcm uartf, refclk,
-                       rgmii1, rgmii2, sd, spi, spi refclk, uartf, uartlite, wdt refclk,
-                       wdt rst, wled]
-
-              - description: For MT7628 and MT7688 SoCs
-                enum: [antenna, debug, gpio, i2c, i2s, jtag, p0led_an, p0led_kn,
-                       p1led_an, p1led_kn, p2led_an, p2led_kn, p3led_an, p3led_kn,
-                       p4led_an, p4led_kn, pcie, pcm, perst, pwm, pwm0, pwm1, pwm_uart2,
-                       refclk, rsvd, sdxc, sdxc d5 d4, sdxc d6, sdxc d7, spi, spi cs1,
-                       spis, sw_r, uart0, uart1, uart2, utif, wdt, wled_an, wled_kn, -]
-
-          groups:
-            description:
-              An array of strings. Each string contains the name of a group.
-            maxItems: 1
-
-        required:
-          - groups
-          - function
-
-        allOf:
-          - if:
-              properties:
-                function:
-                  const: antenna
-            then:
-              properties:
-                groups:
-                  enum: [i2s]
-
-          - if:
-              properties:
-                function:
-                  const: debug
-            then:
-              properties:
-                groups:
-                  enum: [i2c]
-
-          - if:
-              properties:
-                function:
-                  const: ephy
-            then:
-              properties:
-                groups:
-                  enum: [ephy]
-
-          - if:
-              properties:
-                function:
-                  const: gpio
-            then:
-              properties:
-                groups:
-                  anyOf:
-                    - description: For MT7620 SoC
-                      enum: [ephy, i2c, mdio, nd_sd, pa, pcie, rgmii1, rgmii2,
-                             spi, spi refclk, uartf, uartlite, wdt, wled]
-
-                    - description: For MT7628 and MT7688 SoCs
-                      enum: [gpio, i2c, i2s, p0led_an, p0led_kn, p1led_an,
-                             p1led_kn, p2led_an, p2led_kn, p3led_an, p3led_kn,
-                             p4led_an, p4led_kn, perst, pwm0, pwm1, refclk,
-                             sdmode, spi, spi cs1, spis, uart0, uart1, uart2,
-                             wdt, wled_an, wled_kn]
-
-          - if:
-              properties:
-                function:
-                  const: gpio i2s
-            then:
-              properties:
-                groups:
-                  enum: [uartf]
-
-          - if:
-              properties:
-                function:
-                  const: gpio uartf
-            then:
-              properties:
-                groups:
-                  enum: [uartf]
-
-          - if:
-              properties:
-                function:
-                  const: i2c
-            then:
-              properties:
-                groups:
-                  enum: [i2c]
-
-          - if:
-              properties:
-                function:
-                  const: i2s
-            then:
-              properties:
-                groups:
-                  enum: [i2s]
-
-          - if:
-              properties:
-                function:
-                  const: i2s uartf
-            then:
-              properties:
-                groups:
-                  enum: [uartf]
-
-          - if:
-              properties:
-                function:
-                  const: jtag
-            then:
-              properties:
-                groups:
-                  enum: [p0led_an, p0led_kn, p1led_an, p1led_kn, p2led_an,
-                         p2led_kn, p3led_an, p3led_kn, p4led_an, p4led_kn,
-                         sdmode]
-
-          - if:
-              properties:
-                function:
-                  const: mdio
-            then:
-              properties:
-                groups:
-                  enum: [mdio]
-
-          - if:
-              properties:
-                function:
-                  const: nand
-            then:
-              properties:
-                groups:
-                  enum: [nd_sd]
-
-          - if:
-              properties:
-                function:
-                  const: p0led_an
-            then:
-              properties:
-                groups:
-                  enum: [p0led_an]
-
-          - if:
-              properties:
-                function:
-                  const: p0led_kn
-            then:
-              properties:
-                groups:
-                  enum: [p0led_kn]
-
-          - if:
-              properties:
-                function:
-                  const: p1led_an
-            then:
-              properties:
-                groups:
-                  enum: [p1led_an]
-
-          - if:
-              properties:
-                function:
-                  const: p1led_kn
-            then:
-              properties:
-                groups:
-                  enum: [p1led_kn]
-
-          - if:
-              properties:
-                function:
-                  const: p2led_an
-            then:
-              properties:
-                groups:
-                  enum: [p2led_an]
-
-          - if:
-              properties:
-                function:
-                  const: p2led_kn
-            then:
-              properties:
-                groups:
-                  enum: [p2led_kn]
-
-          - if:
-              properties:
-                function:
-                  const: p3led_an
-            then:
-              properties:
-                groups:
-                  enum: [p3led_an]
-
-          - if:
-              properties:
-                function:
-                  const: p3led_kn
-            then:
-              properties:
-                groups:
-                  enum: [p3led_kn]
-
-          - if:
-              properties:
-                function:
-                  const: p4led_an
-            then:
-              properties:
-                groups:
-                  enum: [p4led_an]
-
-          - if:
-              properties:
-                function:
-                  const: p4led_kn
-            then:
-              properties:
-                groups:
-                  enum: [p4led_kn]
-
-          - if:
-              properties:
-                function:
-                  const: pa
-            then:
-              properties:
-                groups:
-                  enum: [pa]
-
-          - if:
-              properties:
-                function:
-                  const: pcie
-            then:
-              properties:
-                groups:
-                  enum: [gpio]
-
-          - if:
-              properties:
-                function:
-                  const: pcie refclk
-            then:
-              properties:
-                groups:
-                  enum: [pcie]
-
-          - if:
-              properties:
-                function:
-                  const: pcie rst
-            then:
-              properties:
-                groups:
-                  enum: [pcie]
-
-          - if:
-              properties:
-                function:
-                  const: pcm
-            then:
-              properties:
-                groups:
-                  enum: [i2s]
-
-          - if:
-              properties:
-                function:
-                  const: pcm gpio
-            then:
-              properties:
-                groups:
-                  enum: [uartf]
-
-          - if:
-              properties:
-                function:
-                  const: pcm i2s
-            then:
-              properties:
-                groups:
-                  enum: [uartf]
-
-          - if:
-              properties:
-                function:
-                  const: pcm uartf
-            then:
-              properties:
-                groups:
-                  enum: [uartf]
-
-          - if:
-              properties:
-                function:
-                  const: perst
-            then:
-              properties:
-                groups:
-                  enum: [perst]
-
-          - if:
-              properties:
-                function:
-                  const: pwm
-            then:
-              properties:
-                groups:
-                  enum: [uart1, uart2]
-
-          - if:
-              properties:
-                function:
-                  const: pwm0
-            then:
-              properties:
-                groups:
-                  enum: [pwm0]
-
-          - if:
-              properties:
-                function:
-                  const: pwm1
-            then:
-              properties:
-                groups:
-                  enum: [pwm1]
-
-          - if:
-              properties:
-                function:
-                  const: pwm_uart2
-            then:
-              properties:
-                groups:
-                  enum: [spis]
-
-          - if:
-              properties:
-                function:
-                  const: refclk
-            then:
-              properties:
-                groups:
-                  anyOf:
-                    - description: For MT7620 SoC
-                      enum: [mdio]
-
-                    - description: For MT7628 and MT7688 SoCs
-                      enum: [gpio, refclk, spi cs1]
-
-          - if:
-              properties:
-                function:
-                  const: rgmii1
-            then:
-              properties:
-                groups:
-                  enum: [rgmii1]
-
-          - if:
-              properties:
-                function:
-                  const: rgmii2
-            then:
-              properties:
-                groups:
-                  enum: [rgmii2]
-
-          - if:
-              properties:
-                function:
-                  const: rsvd
-            then:
-              properties:
-                groups:
-                  enum: [p0led_an, p0led_kn, wled_an, wled_kn]
-
-          - if:
-              properties:
-                function:
-                  const: sd
-            then:
-              properties:
-                groups:
-                  enum: [nd_sd]
-
-          - if:
-              properties:
-                function:
-                  const: sdxc
-            then:
-              properties:
-                groups:
-                  enum: [sdmode]
-
-          - if:
-              properties:
-                function:
-                  const: sdxc d5 d4
-            then:
-              properties:
-                groups:
-                  enum: [uart2]
-
-          - if:
-              properties:
-                function:
-                  const: sdxc d6
-            then:
-              properties:
-                groups:
-                  enum: [pwm1]
-
-          - if:
-              properties:
-                function:
-                  const: sdxc d7
-            then:
-              properties:
-                groups:
-                  enum: [pwm0]
-
-          - if:
-              properties:
-                function:
-                  const: spi
-            then:
-              properties:
-                groups:
-                  enum: [spi]
-
-          - if:
-              properties:
-                function:
-                  const: spi cs1
-            then:
-              properties:
-                groups:
-                  enum: [spi cs1]
-
-          - if:
-              properties:
-                function:
-                  const: spi refclk
-            then:
-              properties:
-                groups:
-                  enum: [spi refclk]
-
-          - if:
-              properties:
-                function:
-                  const: spis
-            then:
-              properties:
-                groups:
-                  enum: [spis]
-
-          - if:
-              properties:
-                function:
-                  const: sw_r
-            then:
-              properties:
-                groups:
-                  enum: [uart1]
-
-          - if:
-              properties:
-                function:
-                  const: uart0
-            then:
-              properties:
-                groups:
-                  enum: [uart0]
-
-          - if:
-              properties:
-                function:
-                  const: uart1
-            then:
-              properties:
-                groups:
-                  enum: [uart1]
-
-          - if:
-              properties:
-                function:
-                  const: uart2
-            then:
-              properties:
-                groups:
-                  enum: [uart2]
-
-          - if:
-              properties:
-                function:
-                  const: uartf
-            then:
-              properties:
-                groups:
-                  enum: [uartf]
-
-          - if:
-              properties:
-                function:
-                  const: uartlite
-            then:
-              properties:
-                groups:
-                  enum: [uartlite]
-
-          - if:
-              properties:
-                function:
-                  const: utif
-            then:
-              properties:
-                groups:
-                  enum: [p1led_an, p1led_kn, p2led_an, p2led_kn, p3led_an,
-                         p3led_kn, p4led_an, p4led_kn, pwm0, pwm1, sdmode, spis]
-
-          - if:
-              properties:
-                function:
-                  const: wdt
-            then:
-              properties:
-                groups:
-                  enum: [wdt]
-
-          - if:
-              properties:
-                function:
-                  const: wdt refclk
-            then:
-              properties:
-                groups:
-                  enum: [wdt]
-
-          - if:
-              properties:
-                function:
-                  const: wdt rst
-            then:
-              properties:
-                groups:
-                  enum: [wdt]
-
-          - if:
-              properties:
-                function:
-                  const: wled
-            then:
-              properties:
-                groups:
-                  enum: [wled]
-
-          - if:
-              properties:
-                function:
-                  const: wled_an
-            then:
-              properties:
-                groups:
-                  enum: [wled_an]
-
-          - if:
-              properties:
-                function:
-                  const: wled_kn
-            then:
-              properties:
-                groups:
-                  enum: [wled_kn]
-
-          - if:
-              properties:
-                function:
-                  const: "-"
-            then:
-              properties:
-                groups:
-                  enum: [i2c, spi cs1, uart0]
-
-        additionalProperties: false
-
-    additionalProperties: false
-
-allOf:
-  - $ref: "pinctrl.yaml#"
-
-required:
-  - compatible
-
-additionalProperties: false
-
-examples:
-  - |
-    pinctrl {
-      compatible = "ralink,mt7620-pinctrl";
-
-      i2c_pins: i2c0-pins {
-        pinmux {
-          groups = "i2c";
-          function = "i2c";
-        };
-      };
-    };
diff --git a/Documentation/devicetree/bindings/pinctrl/ralink,mt7621-pinctrl.yaml b/Documentation/devicetree/bindings/pinctrl/ralink,mt7621-pinctrl.yaml
deleted file mode 100644 (file)
index 1b1d37b..0000000
+++ /dev/null
@@ -1,262 +0,0 @@
-# SPDX-License-Identifier: GPL-2.0-only OR BSD-2-Clause
-%YAML 1.2
----
-$id: http://devicetree.org/schemas/pinctrl/ralink,mt7621-pinctrl.yaml#
-$schema: http://devicetree.org/meta-schemas/core.yaml#
-
-title: Ralink MT7621 Pin Controller
-
-maintainers:
-  - Arınç ÜNAL <arinc.unal@arinc9.com>
-  - Sergio Paracuellos <sergio.paracuellos@gmail.com>
-
-description:
-  Ralink MT7621 pin controller for MT7621 SoC.
-  The pin controller can only set the muxing of pin groups. Muxing individual
-  pins is not supported. There is no pinconf support.
-
-properties:
-  compatible:
-    const: ralink,mt7621-pinctrl
-
-patternProperties:
-  '-pins$':
-    type: object
-    patternProperties:
-      '^(.*-)?pinmux$':
-        type: object
-        description: node for pinctrl.
-        $ref: pinmux-node.yaml#
-
-        properties:
-          function:
-            description:
-              A string containing the name of the function to mux to the group.
-            enum: [gpio, i2c, i2s, jtag, mdio, nand1, nand2, pcie refclk,
-                   pcie rst, pcm, rgmii1, rgmii2, sdhci, spdif2, spdif3, spi,
-                   uart1, uart2, uart3, wdt refclk, wdt rst]
-
-          groups:
-            description:
-              An array of strings. Each string contains the name of a group.
-            maxItems: 1
-
-        required:
-          - groups
-          - function
-
-        allOf:
-          - if:
-              properties:
-                function:
-                  const: gpio
-            then:
-              properties:
-                groups:
-                  enum: [i2c, jtag, mdio, pcie, rgmii1, rgmii2, sdhci, spi,
-                         uart1, uart2, uart3, wdt]
-
-          - if:
-              properties:
-                function:
-                  const: i2c
-            then:
-              properties:
-                groups:
-                  enum: [i2c]
-
-          - if:
-              properties:
-                function:
-                  const: i2s
-            then:
-              properties:
-                groups:
-                  enum: [uart3]
-
-          - if:
-              properties:
-                function:
-                  const: jtag
-            then:
-              properties:
-                groups:
-                  enum: [jtag]
-
-          - if:
-              properties:
-                function:
-                  const: mdio
-            then:
-              properties:
-                groups:
-                  enum: [mdio]
-
-          - if:
-              properties:
-                function:
-                  const: nand1
-            then:
-              properties:
-                groups:
-                  enum: [spi]
-
-          - if:
-              properties:
-                function:
-                  const: nand2
-            then:
-              properties:
-                groups:
-                  enum: [sdhci]
-
-          - if:
-              properties:
-                function:
-                  const: pcie refclk
-            then:
-              properties:
-                groups:
-                  enum: [pcie]
-
-          - if:
-              properties:
-                function:
-                  const: pcie rst
-            then:
-              properties:
-                groups:
-                  enum: [pcie]
-
-          - if:
-              properties:
-                function:
-                  const: pcm
-            then:
-              properties:
-                groups:
-                  enum: [uart2]
-
-          - if:
-              properties:
-                function:
-                  const: rgmii1
-            then:
-              properties:
-                groups:
-                  enum: [rgmii1]
-
-          - if:
-              properties:
-                function:
-                  const: rgmii2
-            then:
-              properties:
-                groups:
-                  enum: [rgmii2]
-
-          - if:
-              properties:
-                function:
-                  const: sdhci
-            then:
-              properties:
-                groups:
-                  enum: [sdhci]
-
-          - if:
-              properties:
-                function:
-                  const: spdif2
-            then:
-              properties:
-                groups:
-                  enum: [uart2]
-
-          - if:
-              properties:
-                function:
-                  const: spdif3
-            then:
-              properties:
-                groups:
-                  enum: [uart3]
-
-          - if:
-              properties:
-                function:
-                  const: spi
-            then:
-              properties:
-                groups:
-                  enum: [spi]
-
-          - if:
-              properties:
-                function:
-                  const: uart1
-            then:
-              properties:
-                groups:
-                  enum: [uart1]
-
-          - if:
-              properties:
-                function:
-                  const: uart2
-            then:
-              properties:
-                groups:
-                  enum: [uart2]
-
-          - if:
-              properties:
-                function:
-                  const: uart3
-            then:
-              properties:
-                groups:
-                  enum: [uart3]
-
-          - if:
-              properties:
-                function:
-                  const: wdt refclk
-            then:
-              properties:
-                groups:
-                  enum: [wdt]
-
-          - if:
-              properties:
-                function:
-                  const: wdt rst
-            then:
-              properties:
-                groups:
-                  enum: [wdt]
-
-        additionalProperties: false
-
-    additionalProperties: false
-
-allOf:
-  - $ref: "pinctrl.yaml#"
-
-required:
-  - compatible
-
-additionalProperties: false
-
-examples:
-  - |
-    pinctrl {
-      compatible = "ralink,mt7621-pinctrl";
-
-      i2c_pins: i2c0-pins {
-        pinmux {
-          groups = "i2c";
-          function = "i2c";
-        };
-      };
-    };
index 7fd0df880a7628097f7c582385ac8c8d57ac037e..43b33dbf115b51bc92ad4144c2dd5306cb04c13b 100644 (file)
@@ -10,7 +10,7 @@ maintainers:
   - Arınç ÜNAL <arinc.unal@arinc9.com>
   - Sergio Paracuellos <sergio.paracuellos@gmail.com>
 
-description:
+description: |
   Ralink RT2880 pin controller for RT2880 SoC.
   The pin controller can only set the muxing of pin groups. Muxing individual
   pins is not supported. There is no pinconf support.
@@ -22,11 +22,14 @@ properties:
 patternProperties:
   '-pins$':
     type: object
+    additionalProperties: false
+
     patternProperties:
       '^(.*-)?pinmux$':
         type: object
         description: node for pinctrl.
         $ref: pinmux-node.yaml#
+        additionalProperties: false
 
         properties:
           function:
@@ -116,12 +119,8 @@ patternProperties:
                 groups:
                   enum: [pci]
 
-        additionalProperties: false
-
-    additionalProperties: false
-
 allOf:
-  - $ref: "pinctrl.yaml#"
+  - $ref: pinctrl.yaml#
 
 required:
   - compatible
index 4d66ca752a3009e60e53014b59a61c3f84581a10..95a9042730099eef7eaee655014d04aef20180cb 100644 (file)
@@ -10,9 +10,8 @@ maintainers:
   - Arınç ÜNAL <arinc.unal@arinc9.com>
   - Sergio Paracuellos <sergio.paracuellos@gmail.com>
 
-description:
-  Ralink RT305X pin controller for RT3050, RT3052, RT3350, RT3352 and RT5350
-  SoCs.
+description: |
+  Ralink RT305X pin controller for RT3050, RT3052, and RT3350 SoCs.
   The pin controller can only set the muxing of pin groups. Muxing individual
   pins is not supported. There is no pinconf support.
 
@@ -23,31 +22,22 @@ properties:
 patternProperties:
   '-pins$':
     type: object
+    additionalProperties: false
+
     patternProperties:
       '^(.*-)?pinmux$':
         type: object
         description: node for pinctrl.
         $ref: pinmux-node.yaml#
+        additionalProperties: false
 
         properties:
           function:
             description:
               A string containing the name of the function to mux to the group.
-            anyOf:
-              - description: For RT3050, RT3052 and RT3350 SoCs
-                enum: [gpio, gpio i2s, gpio uartf, i2c, i2s uartf, jtag, mdio,
-                       pcm gpio, pcm i2s, pcm uartf, rgmii, sdram, spi, uartf,
-                       uartlite]
-
-              - description: For RT3352 SoC
-                enum: [gpio, gpio i2s, gpio uartf, i2c, i2s uartf, jtag, led,
-                       lna, mdio, pa, pcm gpio, pcm i2s, pcm uartf, rgmii, spi,
-                       spi_cs1, uartf, uartlite, wdg_cs1]
-
-              - description: For RT5350 SoC
-                enum: [gpio, gpio i2s, gpio uartf, i2c, i2s uartf, jtag, led,
-                       pcm gpio, pcm i2s, pcm uartf, spi, spi_cs1, uartf,
-                       uartlite, wdg_cs1]
+            enum: [gpio, gpio i2s, gpio uartf, i2c, i2s uartf, jtag, mdio,
+                   pcm gpio, pcm i2s, pcm uartf, rgmii, sdram, spi, uartf,
+                   uartlite]
 
           groups:
             description:
@@ -66,17 +56,7 @@ patternProperties:
             then:
               properties:
                 groups:
-                  anyOf:
-                    - description: For RT3050, RT3052 and RT3350 SoCs
-                      enum: [i2c, jtag, mdio, rgmii, sdram, spi, uartf,
-                             uartlite]
-
-                    - description: For RT3352 SoC
-                      enum: [i2c, jtag, led, lna, mdio, pa, rgmii, spi, spi_cs1,
-                             uartf, uartlite]
-
-                    - description: For RT5350 SoC
-                      enum: [i2c, jtag, led, spi, spi_cs1, uartf, uartlite]
+                  enum: [i2c, jtag, mdio, rgmii, sdram, spi, uartf, uartlite]
 
           - if:
               properties:
@@ -123,24 +103,6 @@ patternProperties:
                 groups:
                   enum: [jtag]
 
-          - if:
-              properties:
-                function:
-                  const: led
-            then:
-              properties:
-                groups:
-                  enum: [led]
-
-          - if:
-              properties:
-                function:
-                  const: lna
-            then:
-              properties:
-                groups:
-                  enum: [lna]
-
           - if:
               properties:
                 function:
@@ -150,15 +112,6 @@ patternProperties:
                 groups:
                   enum: [mdio]
 
-          - if:
-              properties:
-                function:
-                  const: pa
-            then:
-              properties:
-                groups:
-                  enum: [pa]
-
           - if:
               properties:
                 function:
@@ -213,15 +166,6 @@ patternProperties:
                 groups:
                   enum: [spi]
 
-          - if:
-              properties:
-                function:
-                  const: spi_cs1
-            then:
-              properties:
-                groups:
-                  enum: [spi_cs1]
-
           - if:
               properties:
                 function:
@@ -240,21 +184,8 @@ patternProperties:
                 groups:
                   enum: [uartlite]
 
-          - if:
-              properties:
-                function:
-                  const: wdg_cs1
-            then:
-              properties:
-                groups:
-                  enum: [spi_cs1]
-
-        additionalProperties: false
-
-    additionalProperties: false
-
 allOf:
-  - $ref: "pinctrl.yaml#"
+  - $ref: pinctrl.yaml#
 
 required:
   - compatible
diff --git a/Documentation/devicetree/bindings/pinctrl/ralink,rt3352-pinctrl.yaml b/Documentation/devicetree/bindings/pinctrl/ralink,rt3352-pinctrl.yaml
new file mode 100644 (file)
index 0000000..c9bc6cf
--- /dev/null
@@ -0,0 +1,243 @@
+# SPDX-License-Identifier: GPL-2.0-only OR BSD-2-Clause
+%YAML 1.2
+---
+$id: http://devicetree.org/schemas/pinctrl/ralink,rt3352-pinctrl.yaml#
+$schema: http://devicetree.org/meta-schemas/core.yaml#
+
+title: Ralink RT3352 Pin Controller
+
+maintainers:
+  - Arınç ÜNAL <arinc.unal@arinc9.com>
+  - Sergio Paracuellos <sergio.paracuellos@gmail.com>
+
+description: |
+  Ralink RT3352 pin controller for RT3352 SoC.
+  The pin controller can only set the muxing of pin groups. Muxing individual
+  pins is not supported. There is no pinconf support.
+
+properties:
+  compatible:
+    const: ralink,rt3352-pinctrl
+
+patternProperties:
+  '-pins$':
+    type: object
+    additionalProperties: false
+
+    patternProperties:
+      '^(.*-)?pinmux$':
+        type: object
+        description: node for pinctrl.
+        $ref: pinmux-node.yaml#
+        additionalProperties: false
+
+        properties:
+          function:
+            description:
+              A string containing the name of the function to mux to the group.
+            enum: [gpio, gpio i2s, gpio uartf, i2c, i2s uartf, jtag, led, lna,
+                   mdio, pa, pcm gpio, pcm i2s, pcm uartf, rgmii, spi, spi_cs1,
+                   uartf, uartlite, wdg_cs1]
+
+          groups:
+            description:
+              An array of strings. Each string contains the name of a group.
+            maxItems: 1
+
+        required:
+          - groups
+          - function
+
+        allOf:
+          - if:
+              properties:
+                function:
+                  const: gpio
+            then:
+              properties:
+                groups:
+                  enum: [i2c, jtag, led, lna, mdio, pa, rgmii, spi, spi_cs1,
+                         uartf, uartlite]
+
+          - if:
+              properties:
+                function:
+                  const: gpio i2s
+            then:
+              properties:
+                groups:
+                  enum: [uartf]
+
+          - if:
+              properties:
+                function:
+                  const: gpio uartf
+            then:
+              properties:
+                groups:
+                  enum: [uartf]
+
+          - if:
+              properties:
+                function:
+                  const: i2c
+            then:
+              properties:
+                groups:
+                  enum: [i2c]
+
+          - if:
+              properties:
+                function:
+                  const: i2s uartf
+            then:
+              properties:
+                groups:
+                  enum: [uartf]
+
+          - if:
+              properties:
+                function:
+                  const: jtag
+            then:
+              properties:
+                groups:
+                  enum: [jtag]
+
+          - if:
+              properties:
+                function:
+                  const: led
+            then:
+              properties:
+                groups:
+                  enum: [led]
+
+          - if:
+              properties:
+                function:
+                  const: lna
+            then:
+              properties:
+                groups:
+                  enum: [lna]
+
+          - if:
+              properties:
+                function:
+                  const: mdio
+            then:
+              properties:
+                groups:
+                  enum: [mdio]
+
+          - if:
+              properties:
+                function:
+                  const: pa
+            then:
+              properties:
+                groups:
+                  enum: [pa]
+
+          - if:
+              properties:
+                function:
+                  const: pcm gpio
+            then:
+              properties:
+                groups:
+                  enum: [uartf]
+
+          - if:
+              properties:
+                function:
+                  const: pcm i2s
+            then:
+              properties:
+                groups:
+                  enum: [uartf]
+
+          - if:
+              properties:
+                function:
+                  const: pcm uartf
+            then:
+              properties:
+                groups:
+                  enum: [uartf]
+
+          - if:
+              properties:
+                function:
+                  const: rgmii
+            then:
+              properties:
+                groups:
+                  enum: [rgmii]
+
+          - if:
+              properties:
+                function:
+                  const: spi
+            then:
+              properties:
+                groups:
+                  enum: [spi]
+
+          - if:
+              properties:
+                function:
+                  const: spi_cs1
+            then:
+              properties:
+                groups:
+                  enum: [spi_cs1]
+
+          - if:
+              properties:
+                function:
+                  const: uartf
+            then:
+              properties:
+                groups:
+                  enum: [uartf]
+
+          - if:
+              properties:
+                function:
+                  const: uartlite
+            then:
+              properties:
+                groups:
+                  enum: [uartlite]
+
+          - if:
+              properties:
+                function:
+                  const: wdg_cs1
+            then:
+              properties:
+                groups:
+                  enum: [spi_cs1]
+
+allOf:
+  - $ref: pinctrl.yaml#
+
+required:
+  - compatible
+
+additionalProperties: false
+
+examples:
+  - |
+    pinctrl {
+      compatible = "ralink,rt3352-pinctrl";
+
+      i2c_pins: i2c0-pins {
+        pinmux {
+          groups = "i2c";
+          function = "i2c";
+        };
+      };
+    };
index 008d93181aea62ffb776e4097701283acf90ab87..8d14e525b25e3da1c2024ac9d1fed0875c6a2325 100644 (file)
@@ -10,7 +10,7 @@ maintainers:
   - Arınç ÜNAL <arinc.unal@arinc9.com>
   - Sergio Paracuellos <sergio.paracuellos@gmail.com>
 
-description:
+description: |
   Ralink RT3883 pin controller for RT3883 SoC.
   The pin controller can only set the muxing of pin groups. Muxing individual
   pins is not supported. There is no pinconf support.
@@ -22,11 +22,14 @@ properties:
 patternProperties:
   '-pins$':
     type: object
+    additionalProperties: false
+
     patternProperties:
       '^(.*-)?pinmux$':
         type: object
         description: node for pinctrl.
         $ref: pinmux-node.yaml#
+        additionalProperties: false
 
         properties:
           function:
@@ -236,12 +239,8 @@ patternProperties:
                 groups:
                   enum: [uartlite]
 
-        additionalProperties: false
-
-    additionalProperties: false
-
 allOf:
-  - $ref: "pinctrl.yaml#"
+  - $ref: pinctrl.yaml#
 
 required:
   - compatible
diff --git a/Documentation/devicetree/bindings/pinctrl/ralink,rt5350-pinctrl.yaml b/Documentation/devicetree/bindings/pinctrl/ralink,rt5350-pinctrl.yaml
new file mode 100644 (file)
index 0000000..f248202
--- /dev/null
@@ -0,0 +1,206 @@
+# SPDX-License-Identifier: GPL-2.0-only OR BSD-2-Clause
+%YAML 1.2
+---
+$id: http://devicetree.org/schemas/pinctrl/ralink,rt5350-pinctrl.yaml#
+$schema: http://devicetree.org/meta-schemas/core.yaml#
+
+title: Ralink RT5350 Pin Controller
+
+maintainers:
+  - Arınç ÜNAL <arinc.unal@arinc9.com>
+  - Sergio Paracuellos <sergio.paracuellos@gmail.com>
+
+description: |
+  Ralink RT5350 pin controller for RT5350 SoC.
+  The pin controller can only set the muxing of pin groups. Muxing individual
+  pins is not supported. There is no pinconf support.
+
+properties:
+  compatible:
+    const: ralink,rt5350-pinctrl
+
+patternProperties:
+  '-pins$':
+    type: object
+    additionalProperties: false
+
+    patternProperties:
+      '^(.*-)?pinmux$':
+        type: object
+        description: node for pinctrl.
+        $ref: pinmux-node.yaml#
+        additionalProperties: false
+
+        properties:
+          function:
+            description:
+              A string containing the name of the function to mux to the group.
+            enum: [gpio, gpio i2s, gpio uartf, i2c, i2s uartf, jtag, led,
+                   pcm gpio, pcm i2s, pcm uartf, spi, spi_cs1, uartf, uartlite,
+                   wdg_cs1]
+
+          groups:
+            description:
+              An array of strings. Each string contains the name of a group.
+            maxItems: 1
+
+        required:
+          - groups
+          - function
+
+        allOf:
+          - if:
+              properties:
+                function:
+                  const: gpio
+            then:
+              properties:
+                groups:
+                  enum: [i2c, jtag, led, spi, spi_cs1, uartf, uartlite]
+
+          - if:
+              properties:
+                function:
+                  const: gpio i2s
+            then:
+              properties:
+                groups:
+                  enum: [uartf]
+
+          - if:
+              properties:
+                function:
+                  const: gpio uartf
+            then:
+              properties:
+                groups:
+                  enum: [uartf]
+
+          - if:
+              properties:
+                function:
+                  const: i2c
+            then:
+              properties:
+                groups:
+                  enum: [i2c]
+
+          - if:
+              properties:
+                function:
+                  const: i2s uartf
+            then:
+              properties:
+                groups:
+                  enum: [uartf]
+
+          - if:
+              properties:
+                function:
+                  const: jtag
+            then:
+              properties:
+                groups:
+                  enum: [jtag]
+
+          - if:
+              properties:
+                function:
+                  const: led
+            then:
+              properties:
+                groups:
+                  enum: [led]
+
+          - if:
+              properties:
+                function:
+                  const: pcm gpio
+            then:
+              properties:
+                groups:
+                  enum: [uartf]
+
+          - if:
+              properties:
+                function:
+                  const: pcm i2s
+            then:
+              properties:
+                groups:
+                  enum: [uartf]
+
+          - if:
+              properties:
+                function:
+                  const: pcm uartf
+            then:
+              properties:
+                groups:
+                  enum: [uartf]
+
+          - if:
+              properties:
+                function:
+                  const: spi
+            then:
+              properties:
+                groups:
+                  enum: [spi]
+
+          - if:
+              properties:
+                function:
+                  const: spi_cs1
+            then:
+              properties:
+                groups:
+                  enum: [spi_cs1]
+
+          - if:
+              properties:
+                function:
+                  const: uartf
+            then:
+              properties:
+                groups:
+                  enum: [uartf]
+
+          - if:
+              properties:
+                function:
+                  const: uartlite
+            then:
+              properties:
+                groups:
+                  enum: [uartlite]
+
+          - if:
+              properties:
+                function:
+                  const: wdg_cs1
+            then:
+              properties:
+                groups:
+                  enum: [spi_cs1]
+
+allOf:
+  - $ref: pinctrl.yaml#
+
+required:
+  - compatible
+
+additionalProperties: false
+
+examples:
+  - |
+    pinctrl {
+      compatible = "ralink,rt5350-pinctrl";
+
+      i2c_pins: i2c0-pins {
+        pinmux {
+          groups = "i2c";
+          function = "i2c";
+        };
+      };
+    };
index 4fc758fea7e676d7f019f0844fd8d19943593c6a..0fc3c0f52c191a44ae85bce1d526882f71260ebc 100644 (file)
@@ -73,7 +73,7 @@ properties:
     maxItems: 1
 
 allOf:
-  - $ref: "pinctrl.yaml#"
+  - $ref: pinctrl.yaml#
 
 required:
   - compatible
index 9083040c996ab06feccd6ecdbd8468dea5f81641..83800fcf0ce484154a24dda8b9ead7c6f73db752 100644 (file)
@@ -32,7 +32,7 @@ properties:
     maxItems: 1
 
 allOf:
-  - $ref: "pinctrl.yaml#"
+  - $ref: pinctrl.yaml#
 
 required:
   - compatible
index d761fddc220625bd1cf07af0b1388258cee7e7f4..37173a64fed2bba91afe390136ca6f95f8a685c4 100644 (file)
@@ -73,7 +73,7 @@ patternProperties:
       additionalProperties: false
 
 allOf:
-  - $ref: "pinctrl.yaml#"
+  - $ref: pinctrl.yaml#
 
 required:
   - compatible
index f081acb7ba049819f1eba3c4810183f62ebde3c0..9ce1a07fc015f7126a70ee6dbddb61bee5cdfcab 100644 (file)
@@ -113,7 +113,7 @@ additionalProperties:
         $ref: "#/additionalProperties/anyOf/0"
 
 allOf:
-  - $ref: "pinctrl.yaml#"
+  - $ref: pinctrl.yaml#
 
 required:
   - compatible
index 70b1788ab59443fdbc26a93912e8b858113ba9e0..f3b85b7eae31ba61fcf7d4a949fa065efb07522c 100644 (file)
@@ -32,7 +32,7 @@ properties:
       The bus clock, sometimes described as pclk, for register accesses.
 
 allOf:
-  - $ref: "pinctrl.yaml#"
+  - $ref: pinctrl.yaml#
 
 required:
   - compatible
index eac6245db7dcba72cf218e6fcb7f9e7b721a5a87..03f084292d68d0b68f012b2e77bd69190acbe446 100644 (file)
@@ -94,7 +94,7 @@ additionalProperties:
         $ref: "#/additionalProperties/anyOf/0"
 
 allOf:
-  - $ref: "pinctrl.yaml#"
+  - $ref: pinctrl.yaml#
 
 required:
   - compatible
index 45b767986a8784cc1fd07356011a8cbd6f1c14e7..10c335efe619e6dad1bbdadfe6eae43599b6959e 100644 (file)
@@ -50,12 +50,12 @@ properties:
       - rockchip,rv1126-pinctrl
 
   rockchip,grf:
-    $ref: "/schemas/types.yaml#/definitions/phandle"
+    $ref: /schemas/types.yaml#/definitions/phandle
     description:
       The phandle of the syscon node for the GRF registers.
 
   rockchip,pmu:
-    $ref: "/schemas/types.yaml#/definitions/phandle"
+    $ref: /schemas/types.yaml#/definitions/phandle
     description:
       The phandle of the syscon node for the PMU registers,
       as some SoCs carry parts of the iomux controller registers there.
@@ -71,7 +71,7 @@ properties:
   ranges: true
 
 allOf:
-  - $ref: "pinctrl.yaml#"
+  - $ref: pinctrl.yaml#
 
 required:
   - compatible
@@ -81,7 +81,7 @@ patternProperties:
   "gpio@[0-9a-f]+$":
     type: object
 
-    $ref: "/schemas/gpio/rockchip,gpio-bank.yaml#"
+    $ref: /schemas/gpio/rockchip,gpio-bank.yaml#
     deprecated: true
 
     unevaluatedProperties: false
@@ -117,7 +117,7 @@ additionalProperties:
     type: object
     properties:
       rockchip,pins:
-        $ref: "/schemas/types.yaml#/definitions/uint32-matrix"
+        $ref: /schemas/types.yaml#/definitions/uint32-matrix
         minItems: 1
         items:
           items:
index eb2b2692607d936ea71870dfaf224caa761f2075..26614621774a5d822ce21d977aaa2876f3a2a983 100644 (file)
@@ -117,7 +117,7 @@ required:
   - reg
 
 allOf:
-  - $ref: "pinctrl.yaml#"
+  - $ref: pinctrl.yaml#
   - if:
       properties:
         compatible:
index 0719c03d6f4bc067bc879ab79c9a20e7c0832eda..4214d7311f6bd82fd30f270c41cfe79a52c024a0 100644 (file)
@@ -62,8 +62,8 @@ patternProperties:
       - pins
 
     allOf:
-      - $ref: "pincfg-node.yaml#"
-      - $ref: "pinmux-node.yaml#"
+      - $ref: pincfg-node.yaml#
+      - $ref: pinmux-node.yaml#
       - if:
           properties:
             pins:
@@ -86,7 +86,7 @@ required:
   - gpio-controller
 
 allOf:
-  - $ref: "pinctrl.yaml#"
+  - $ref: pinctrl.yaml#
   - if:
       not:
         properties:
index bc34e2c872bcb42dda1889ef522c7f82a67cea7c..a6f34df82e90b1223bc1301e93af570fc78fc079 100644 (file)
@@ -61,7 +61,7 @@ additionalProperties:
     unevaluatedProperties: false
 
 allOf:
-  - $ref: "pinctrl.yaml#"
+  - $ref: pinctrl.yaml#
 
 required:
   - compatible
index eeb29b4ad4d1a1304f12d539392469bdd1422042..1ab0f8dde4770ce636ea0ee7f722fc8f61c3d3bb 100644 (file)
@@ -44,7 +44,7 @@ properties:
 
   st,syscfg:
     description: Phandle+args to the syscon node which includes IRQ mux selection.
-    $ref: "/schemas/types.yaml#/definitions/phandle-array"
+    $ref: /schemas/types.yaml#/definitions/phandle-array
     items:
       - items:
           - description: syscon node which includes IRQ mux selection
@@ -89,7 +89,7 @@ patternProperties:
       st,bank-name:
         description:
           Should be a name string for this bank as specified in the datasheet.
-        $ref: "/schemas/types.yaml#/definitions/string"
+        $ref: /schemas/types.yaml#/definitions/string
         enum:
           - GPIOA
           - GPIOB
@@ -108,7 +108,7 @@ patternProperties:
         description:
           Should correspond to the EXTI IOport selection (EXTI line used
           to select GPIOs as interrupts).
-        $ref: "/schemas/types.yaml#/definitions/uint32"
+        $ref: /schemas/types.yaml#/definitions/uint32
         minimum: 0
         maximum: 11
 
@@ -140,7 +140,7 @@ patternProperties:
           configuration, pullups, drive, output high/low and output speed.
         properties:
           pinmux:
-            $ref: "/schemas/types.yaml#/definitions/uint32-array"
+            $ref: /schemas/types.yaml#/definitions/uint32-array
             description: |
               Integer array, represents gpio pin number and mux setting.
               Supported pin number and mux varies for different SoCs, and are
@@ -201,7 +201,7 @@ patternProperties:
           - pinmux
 
 allOf:
-  - $ref: "pinctrl.yaml#"
+  - $ref: pinctrl.yaml#
 
 required:
   - compatible
index d78c3cd0c29598fa60795933b6e56141e0dc12e9..f3258f2fd3a48327f27636fe0015ad69d784a229 100644 (file)
@@ -111,7 +111,7 @@ patternProperties:
           pins it needs, and how they should be configured, with regard to
           muxer configuration, bias, input enable/disable, input schmitt
           trigger enable/disable, slew-rate and drive strength.
-        $ref: "/schemas/pinctrl/pincfg-node.yaml"
+        $ref: /schemas/pinctrl/pincfg-node.yaml
 
         properties:
           pins:
@@ -120,14 +120,14 @@ patternProperties:
               This should be set using either the PAD_GPIO or PAD_FUNC_SHARE
               macros.
               Either this or "pinmux" has to be specified, but not both.
-            $ref: "/schemas/pinctrl/pinmux-node.yaml#/properties/pins"
+            $ref: /schemas/pinctrl/pinmux-node.yaml#/properties/pins
 
           pinmux:
             description: |
               The list of GPIOs and their mux settings that properties in the
               node apply to. This should be set using the GPIOMUX macro.
               Either this or "pins" has to be specified, but not both.
-            $ref: "/schemas/pinctrl/pinmux-node.yaml#/properties/pinmux"
+            $ref: /schemas/pinctrl/pinmux-node.yaml#/properties/pinmux
 
           bias-disable: true
 
index 347061eece9ea41a9868cc815f3cfd52fbff469d..94b868c7ceb19eae3228209e4140eb904dff8196 100644 (file)
@@ -138,7 +138,7 @@ patternProperties:
         description: |
           Define pin-function which is used by pinctrl node's client device.
           The name should be one of string in the following enumeration.
-        $ref: "/schemas/types.yaml#/definitions/string"
+        $ref: /schemas/types.yaml#/definitions/string
         enum: [ SPI_FLASH, SPI_FLASH_4BIT, SPI_NAND, CARD0_EMMC, SD_CARD,
                 UA0, FPGA_IFX, HDMI_TX, LCDIF, USB0_OTG, USB1_OTG ]
 
@@ -146,7 +146,7 @@ patternProperties:
         description: |
           Define pin-group in a specified pin-function.
           The name should be one of string in the following enumeration.
-        $ref: "/schemas/types.yaml#/definitions/string"
+        $ref: /schemas/types.yaml#/definitions/string
         enum: [ SPI_FLASH1, SPI_FLASH2, SPI_FLASH_4BIT1, SPI_FLASH_4BIT2,
                 SPI_NAND, CARD0_EMMC, SD_CARD, UA0, FPGA_IFX, HDMI_TX1,
                 HDMI_TX2, HDMI_TX3, LCDIF, USB0_OTG, USB1_OTG ]
@@ -289,7 +289,7 @@ required:
 additionalProperties: false
 
 allOf:
-  - $ref: "pinctrl.yaml#"
+  - $ref: pinctrl.yaml#
 
 examples:
   - |
index 98b4663f9766c696b4c222ffb9d3f66819163e8c..19d47fd414bc0696008614e4d29b176dc57c4480 100644 (file)
@@ -21,7 +21,7 @@ properties:
     maxItems: 1
 
 allOf:
-  - $ref: "pinctrl.yaml#"
+  - $ref: pinctrl.yaml#
 
 required:
   - compatible
@@ -35,14 +35,14 @@ patternProperties:
       pinctrl groups available on the machine. Each subnode will list the
       pins it needs, and how they should be configured, with regard to muxer
       configuration, pullups, drive strength.
-    $ref: "pinmux-node.yaml"
+    $ref: pinmux-node.yaml
     additionalProperties: false
 
     properties:
       function:
         description:
           Function to mux.
-        $ref: "/schemas/types.yaml#/definitions/string"
+        $ref: /schemas/types.yaml#/definitions/string
         enum: [i2c0, i2c1, i2c2, i2c3, i2c4, i2c5, i2c6, i2c7, i2c8,
                spi0, spi1, spi2, spi3, spi4, spi5, spi6,
                uart0, uart1, uart2, uart3, pwm, pcmif_out, pcmif_in]
@@ -50,7 +50,7 @@ patternProperties:
       groups:
         description:
           Name of the pin group to use for the functions.
-        $ref: "/schemas/types.yaml#/definitions/string"
+        $ref: /schemas/types.yaml#/definitions/string
         enum: [i2c0_grp, i2c1_grp, i2c2_grp, i2c3_grp, i2c4_grp,
                i2c5_grp, i2c6_grp, i2c7_grp, i2c8_grp,
                spi0_grp, spi0_cs0_grp, spi0_cs1_grp, spi0_cs2_grp,
index cfd0cc549a7b115caf3ae96753dc67cc5e2d0efd..598a042850b8974e60d40e2b34657f1a071a094a 100644 (file)
@@ -168,7 +168,7 @@ patternProperties:
     additionalProperties: false
 
 allOf:
-  - $ref: "pinctrl.yaml#"
+  - $ref: pinctrl.yaml#
 
 required:
   - compatible
index 773b5650ad23b7a8d85582bbe109de40345a57a4..cb932c6f895907573fbd687f867ce3ad8cd4627e 100644 (file)
@@ -16629,6 +16629,28 @@ F:     Documentation/devicetree/bindings/pinctrl/mediatek,mt7622-pinctrl.yaml
 F:     Documentation/devicetree/bindings/pinctrl/mediatek,mt8183-pinctrl.yaml
 F:     drivers/pinctrl/mediatek/
 
+PIN CONTROLLER - MEDIATEK MIPS
+M:     Arınç ÜNAL <arinc.unal@arinc9.com>
+M:     Sergio Paracuellos <sergio.paracuellos@gmail.com>
+L:     linux-mediatek@lists.infradead.org (moderated for non-subscribers)
+L:     linux-mips@vger.kernel.org
+S:     Maintained
+F:     Documentation/devicetree/bindings/pinctrl/mediatek,mt7620-pinctrl.yaml
+F:     Documentation/devicetree/bindings/pinctrl/mediatek,mt7621-pinctrl.yaml
+F:     Documentation/devicetree/bindings/pinctrl/mediatek,mt76x8-pinctrl.yaml
+F:     Documentation/devicetree/bindings/pinctrl/ralink,rt2880-pinctrl.yaml
+F:     Documentation/devicetree/bindings/pinctrl/ralink,rt305x-pinctrl.yaml
+F:     Documentation/devicetree/bindings/pinctrl/ralink,rt3352-pinctrl.yaml
+F:     Documentation/devicetree/bindings/pinctrl/ralink,rt3883-pinctrl.yaml
+F:     Documentation/devicetree/bindings/pinctrl/ralink,rt5350-pinctrl.yaml
+F:     drivers/pinctrl/mediatek/pinctrl-mt7620.c
+F:     drivers/pinctrl/mediatek/pinctrl-mt7621.c
+F:     drivers/pinctrl/mediatek/pinctrl-mt76x8.c
+F:     drivers/pinctrl/mediatek/pinctrl-mtmips.*
+F:     drivers/pinctrl/mediatek/pinctrl-rt2880.c
+F:     drivers/pinctrl/mediatek/pinctrl-rt305x.c
+F:     drivers/pinctrl/mediatek/pinctrl-rt3883.c
+
 PIN CONTROLLER - MICROCHIP AT91
 M:     Ludovic Desroches <ludovic.desroches@microchip.com>
 L:     linux-arm-kernel@lists.infradead.org (moderated for non-subscribers)
@@ -16637,6 +16659,14 @@ S:     Supported
 F:     drivers/gpio/gpio-sama5d2-piobu.c
 F:     drivers/pinctrl/pinctrl-at91*
 
+PIN CONTROLLER - NXP S32
+M:     Chester Lin <clin@suse.com>
+R:     NXP S32 Linux Team <s32@nxp.com>
+L:     linux-gpio@vger.kernel.org
+S:     Maintained
+F:     Documentation/devicetree/bindings/pinctrl/nxp,s32*
+F:     drivers/pinctrl/nxp/
+
 PIN CONTROLLER - QUALCOMM
 M:     Bjorn Andersson <andersson@kernel.org>
 L:     linux-arm-msm@vger.kernel.org
@@ -16676,11 +16706,6 @@ L:     linux-omap@vger.kernel.org
 S:     Maintained
 F:     drivers/pinctrl/pinctrl-single.c
 
-PIN CONTROLLER - THUNDERBAY
-M:     Lakshmi Sowjanya D <lakshmi.sowjanya.d@intel.com>
-S:     Supported
-F:     drivers/pinctrl/pinctrl-thunderbay.c
-
 PIN CONTROLLER - SUNPLUS / TIBBO
 M:     Dvorkin Dmitry <dvorkin@tibbo.com>
 M:     Wells Lu <wellslutw@gmail.com>
@@ -17612,13 +17637,6 @@ L:     linux-mips@vger.kernel.org
 S:     Maintained
 F:     arch/mips/boot/dts/ralink/mt7621*
 
-RALINK PINCTRL DRIVER
-M:     Arınç ÜNAL <arinc.unal@arinc9.com>
-M:     Sergio Paracuellos <sergio.paracuellos@gmail.com>
-L:     linux-mips@vger.kernel.org
-S:     Maintained
-F:     drivers/pinctrl/ralink/
-
 RALINK RT2X00 WIRELESS LAN DRIVER
 M:     Stanislaw Gruszka <stf_xl@wp.pl>
 M:     Helmut Schaa <helmut.schaa@googlemail.com>
index dcb53c4a9584b2ee3fdf022f6ad14541357b62aa..5787c579dcf672c3072f11791b0ad3e172edb73d 100644 (file)
@@ -480,25 +480,6 @@ config PINCTRL_TB10X
        depends on OF && ARC_PLAT_TB10X
        select GPIOLIB
 
-config PINCTRL_THUNDERBAY
-       tristate "Generic pinctrl and GPIO driver for Intel Thunder Bay SoC"
-       depends on ARCH_THUNDERBAY || (ARM64 && COMPILE_TEST)
-       depends on HAS_IOMEM
-       select PINMUX
-       select PINCONF
-       select GENERIC_PINCONF
-       select GENERIC_PINCTRL_GROUPS
-       select GENERIC_PINMUX_FUNCTIONS
-       select GPIOLIB
-       select GPIOLIB_IRQCHIP
-       select GPIO_GENERIC
-       help
-         This selects pin control driver for the Intel Thunder Bay SoC.
-         It provides pin config functions such as pull-up, pull-down,
-         interrupt, drive strength, sec lock, Schmitt trigger, slew
-         rate control and direction control. This module will be
-         called as pinctrl-thunderbay.
-
 config PINCTRL_ZYNQ
        bool "Pinctrl driver for Xilinx Zynq"
        depends on ARCH_ZYNQ
@@ -523,6 +504,19 @@ config PINCTRL_ZYNQMP
          This driver can also be built as a module. If so, the module
          will be called pinctrl-zynqmp.
 
+config PINCTRL_MLXBF3
+       tristate "NVIDIA BlueField-3 SoC Pinctrl driver"
+       depends on (MELLANOX_PLATFORM && ARM64) || COMPILE_TEST
+       select PINMUX
+       select GPIOLIB
+       select GPIOLIB_IRQCHIP
+       select GPIO_MLXBF3
+       help
+         Say Y to select the pinctrl driver for BlueField-3 SoCs.
+         This pin controller allows selecting the mux function for
+         each pin. This driver can also be built as a module called
+         pinctrl-mlxbf3.
+
 source "drivers/pinctrl/actions/Kconfig"
 source "drivers/pinctrl/aspeed/Kconfig"
 source "drivers/pinctrl/bcm/Kconfig"
@@ -535,9 +529,9 @@ source "drivers/pinctrl/meson/Kconfig"
 source "drivers/pinctrl/mvebu/Kconfig"
 source "drivers/pinctrl/nomadik/Kconfig"
 source "drivers/pinctrl/nuvoton/Kconfig"
+source "drivers/pinctrl/nxp/Kconfig"
 source "drivers/pinctrl/pxa/Kconfig"
 source "drivers/pinctrl/qcom/Kconfig"
-source "drivers/pinctrl/ralink/Kconfig"
 source "drivers/pinctrl/renesas/Kconfig"
 source "drivers/pinctrl/samsung/Kconfig"
 source "drivers/pinctrl/spear/Kconfig"
index d5939840bb2ad5b7ea290f8f710a51aa2da1407f..e196c6e324adc8956741f3da0f6cbf2e2b96512f 100644 (file)
@@ -36,6 +36,7 @@ obj-$(CONFIG_PINCTRL_MCP23S08_I2C)    += pinctrl-mcp23s08_i2c.o
 obj-$(CONFIG_PINCTRL_MCP23S08_SPI)     += pinctrl-mcp23s08_spi.o
 obj-$(CONFIG_PINCTRL_MCP23S08) += pinctrl-mcp23s08.o
 obj-$(CONFIG_PINCTRL_MICROCHIP_SGPIO)  += pinctrl-microchip-sgpio.o
+obj-$(CONFIG_PINCTRL_MLXBF3)   += pinctrl-mlxbf3.o
 obj-$(CONFIG_PINCTRL_OCELOT)   += pinctrl-ocelot.o
 obj-$(CONFIG_PINCTRL_OXNAS)    += pinctrl-oxnas.o
 obj-$(CONFIG_PINCTRL_PALMAS)   += pinctrl-palmas.o
@@ -48,7 +49,6 @@ obj-$(CONFIG_PINCTRL_ST)      += pinctrl-st.o
 obj-$(CONFIG_PINCTRL_STMFX)    += pinctrl-stmfx.o
 obj-$(CONFIG_PINCTRL_SX150X)   += pinctrl-sx150x.o
 obj-$(CONFIG_PINCTRL_TB10X)    += pinctrl-tb10x.o
-obj-$(CONFIG_PINCTRL_THUNDERBAY) += pinctrl-thunderbay.o
 obj-$(CONFIG_PINCTRL_ZYNQMP)   += pinctrl-zynqmp.o
 obj-$(CONFIG_PINCTRL_ZYNQ)     += pinctrl-zynq.o
 
@@ -64,9 +64,9 @@ obj-$(CONFIG_PINCTRL_MESON)   += meson/
 obj-y                          += mvebu/
 obj-y                          += nomadik/
 obj-y                          += nuvoton/
+obj-y                          += nxp/
 obj-$(CONFIG_PINCTRL_PXA)      += pxa/
 obj-$(CONFIG_ARCH_QCOM)                += qcom/
-obj-$(CONFIG_PINCTRL_RALINK)   += ralink/
 obj-$(CONFIG_PINCTRL_RENESAS)  += renesas/
 obj-$(CONFIG_PINCTRL_SAMSUNG)  += samsung/
 obj-$(CONFIG_PINCTRL_SPEAR)    += spear/
index 8e2551a08c372e514e0f063062d6a60a3c96f9bf..7435173e10f43105078bd07a8a1529359dbd98dd 100644 (file)
@@ -90,6 +90,8 @@ struct bcm2835_pinctrl {
        struct pinctrl_gpio_range gpio_range;
 
        raw_spinlock_t irq_lock[BCM2835_NUM_BANKS];
+       /* Protect FSEL registers */
+       spinlock_t fsel_lock;
 };
 
 /* pins are just named GPIO0..GPIO53 */
@@ -284,14 +286,19 @@ static inline void bcm2835_pinctrl_fsel_set(
                struct bcm2835_pinctrl *pc, unsigned pin,
                enum bcm2835_fsel fsel)
 {
-       u32 val = bcm2835_gpio_rd(pc, FSEL_REG(pin));
-       enum bcm2835_fsel cur = (val >> FSEL_SHIFT(pin)) & BCM2835_FSEL_MASK;
+       u32 val;
+       enum bcm2835_fsel cur;
+       unsigned long flags;
+
+       spin_lock_irqsave(&pc->fsel_lock, flags);
+       val = bcm2835_gpio_rd(pc, FSEL_REG(pin));
+       cur = (val >> FSEL_SHIFT(pin)) & BCM2835_FSEL_MASK;
 
        dev_dbg(pc->dev, "read %08x (%u => %s)\n", val, pin,
-                       bcm2835_functions[cur]);
+               bcm2835_functions[cur]);
 
        if (cur == fsel)
-               return;
+               goto unlock;
 
        if (cur != BCM2835_FSEL_GPIO_IN && fsel != BCM2835_FSEL_GPIO_IN) {
                /* always transition through GPIO_IN */
@@ -309,6 +316,9 @@ static inline void bcm2835_pinctrl_fsel_set(
        dev_dbg(pc->dev, "write %08x (%u <= %s)\n", val, pin,
                        bcm2835_functions[fsel]);
        bcm2835_gpio_wr(pc, FSEL_REG(pin), val);
+
+unlock:
+       spin_unlock_irqrestore(&pc->fsel_lock, flags);
 }
 
 static int bcm2835_gpio_direction_input(struct gpio_chip *chip, unsigned offset)
@@ -1248,6 +1258,7 @@ static int bcm2835_pinctrl_probe(struct platform_device *pdev)
        pc->gpio_chip = *pdata->gpio_chip;
        pc->gpio_chip.parent = dev;
 
+       spin_lock_init(&pc->fsel_lock);
        for (i = 0; i < BCM2835_NUM_BANKS; i++) {
                unsigned long events;
                unsigned offset;
index 3df56a4ea510cd462b1a410d5f82f3d51a4da9a0..cc3eb7409ab39e82978d417cf2b79fdbe1c32fd4 100644 (file)
@@ -23,6 +23,7 @@
 #include <linux/kernel.h>
 #include <linux/of_device.h>
 #include <linux/of_irq.h>
+#include <linux/seq_file.h>
 #include <linux/slab.h>
 
 #include <linux/pinctrl/consumer.h>
@@ -108,7 +109,6 @@ struct iproc_gpio {
 
        raw_spinlock_t lock;
 
-       struct irq_chip irqchip;
        struct gpio_chip gc;
        unsigned num_banks;
 
@@ -217,7 +217,7 @@ static void iproc_gpio_irq_set_mask(struct irq_data *d, bool unmask)
 {
        struct gpio_chip *gc = irq_data_get_irq_chip_data(d);
        struct iproc_gpio *chip = gpiochip_get_data(gc);
-       unsigned gpio = d->hwirq;
+       unsigned gpio = irqd_to_hwirq(d);
 
        iproc_set_bit(chip, IPROC_GPIO_INT_MSK_OFFSET, gpio, unmask);
 }
@@ -231,6 +231,7 @@ static void iproc_gpio_irq_mask(struct irq_data *d)
        raw_spin_lock_irqsave(&chip->lock, flags);
        iproc_gpio_irq_set_mask(d, false);
        raw_spin_unlock_irqrestore(&chip->lock, flags);
+       gpiochip_disable_irq(gc, irqd_to_hwirq(d));
 }
 
 static void iproc_gpio_irq_unmask(struct irq_data *d)
@@ -239,6 +240,7 @@ static void iproc_gpio_irq_unmask(struct irq_data *d)
        struct iproc_gpio *chip = gpiochip_get_data(gc);
        unsigned long flags;
 
+       gpiochip_enable_irq(gc, irqd_to_hwirq(d));
        raw_spin_lock_irqsave(&chip->lock, flags);
        iproc_gpio_irq_set_mask(d, true);
        raw_spin_unlock_irqrestore(&chip->lock, flags);
@@ -302,6 +304,26 @@ static int iproc_gpio_irq_set_type(struct irq_data *d, unsigned int type)
        return 0;
 }
 
+static void iproc_gpio_irq_print_chip(struct irq_data *d, struct seq_file *p)
+{
+       struct gpio_chip *gc = irq_data_get_irq_chip_data(d);
+       struct iproc_gpio *chip = gpiochip_get_data(gc);
+
+       seq_printf(p, dev_name(chip->dev));
+}
+
+static const struct irq_chip iproc_gpio_irq_chip = {
+       .irq_ack = iproc_gpio_irq_ack,
+       .irq_mask = iproc_gpio_irq_mask,
+       .irq_unmask = iproc_gpio_irq_unmask,
+       .irq_set_type = iproc_gpio_irq_set_type,
+       .irq_enable = iproc_gpio_irq_unmask,
+       .irq_disable = iproc_gpio_irq_mask,
+       .irq_print_chip = iproc_gpio_irq_print_chip,
+       .flags = IRQCHIP_IMMUTABLE,
+       GPIOCHIP_IRQ_RESOURCE_HELPERS,
+};
+
 /*
  * Request the Iproc IOMUX pinmux controller to mux individual pins to GPIO
  */
@@ -852,20 +874,10 @@ static int iproc_gpio_probe(struct platform_device *pdev)
        /* optional GPIO interrupt support */
        irq = platform_get_irq_optional(pdev, 0);
        if (irq > 0) {
-               struct irq_chip *irqc;
                struct gpio_irq_chip *girq;
 
-               irqc = &chip->irqchip;
-               irqc->name = dev_name(dev);
-               irqc->irq_ack = iproc_gpio_irq_ack;
-               irqc->irq_mask = iproc_gpio_irq_mask;
-               irqc->irq_unmask = iproc_gpio_irq_unmask;
-               irqc->irq_set_type = iproc_gpio_irq_set_type;
-               irqc->irq_enable = iproc_gpio_irq_unmask;
-               irqc->irq_disable = iproc_gpio_irq_mask;
-
                girq = &gc->irq;
-               girq->chip = irqc;
+               gpio_irq_chip_set_chip(girq, &iproc_gpio_irq_chip);
                girq->parent_handler = iproc_gpio_irq_handler;
                girq->num_parents = 1;
                girq->parents = devm_kcalloc(dev, 1,
index 3c792bf03bda4a8049e7445ac737f1df5c3c70d7..5045a7e57f1d8183c6a4fd62fff80bd2d557a83a 100644 (file)
@@ -60,7 +60,6 @@ struct nsp_gpio {
        struct device *dev;
        void __iomem *base;
        void __iomem *io_ctrl;
-       struct irq_chip irqchip;
        struct gpio_chip gc;
        struct pinctrl_dev *pctl;
        struct pinctrl_desc pctldesc;
@@ -193,6 +192,7 @@ static void nsp_gpio_irq_mask(struct irq_data *d)
        raw_spin_lock_irqsave(&chip->lock, flags);
        nsp_gpio_irq_set_mask(d, false);
        raw_spin_unlock_irqrestore(&chip->lock, flags);
+       gpiochip_disable_irq(gc, irqd_to_hwirq(d));
 }
 
 static void nsp_gpio_irq_unmask(struct irq_data *d)
@@ -201,6 +201,7 @@ static void nsp_gpio_irq_unmask(struct irq_data *d)
        struct nsp_gpio *chip = gpiochip_get_data(gc);
        unsigned long flags;
 
+       gpiochip_enable_irq(gc, irqd_to_hwirq(d));
        raw_spin_lock_irqsave(&chip->lock, flags);
        nsp_gpio_irq_set_mask(d, true);
        raw_spin_unlock_irqrestore(&chip->lock, flags);
@@ -258,6 +259,16 @@ static int nsp_gpio_irq_set_type(struct irq_data *d, unsigned int type)
        return 0;
 }
 
+static const struct irq_chip nsp_gpio_irq_chip = {
+       .name = "gpio-a",
+       .irq_ack = nsp_gpio_irq_ack,
+       .irq_mask = nsp_gpio_irq_mask,
+       .irq_unmask = nsp_gpio_irq_unmask,
+       .irq_set_type = nsp_gpio_irq_set_type,
+       .flags = IRQCHIP_IMMUTABLE,
+       GPIOCHIP_IRQ_RESOURCE_HELPERS,
+};
+
 static int nsp_gpio_direction_input(struct gpio_chip *gc, unsigned gpio)
 {
        struct nsp_gpio *chip = gpiochip_get_data(gc);
@@ -650,14 +661,6 @@ static int nsp_gpio_probe(struct platform_device *pdev)
        irq = platform_get_irq(pdev, 0);
        if (irq > 0) {
                struct gpio_irq_chip *girq;
-               struct irq_chip *irqc;
-
-               irqc = &chip->irqchip;
-               irqc->name = "gpio-a";
-               irqc->irq_ack = nsp_gpio_irq_ack;
-               irqc->irq_mask = nsp_gpio_irq_mask;
-               irqc->irq_unmask = nsp_gpio_irq_unmask;
-               irqc->irq_set_type = nsp_gpio_irq_set_type;
 
                val = readl(chip->base + NSP_CHIP_A_INT_MASK);
                val = val | NSP_CHIP_A_GPIO_INT_BIT;
@@ -673,7 +676,7 @@ static int nsp_gpio_probe(struct platform_device *pdev)
                }
 
                girq = &chip->gc.irq;
-               girq->chip = irqc;
+               gpio_irq_chip_set_chip(girq, &nsp_gpio_irq_chip);
                /* This will let us handle the parent IRQ in the driver */
                girq->parent_handler = NULL;
                girq->num_parents = 0;
index 7a32f77792d9a5236b0647a2716953422620e1d4..27bdc548f3a7d055687fcb7d460c00125a9b51f1 100644 (file)
@@ -4,7 +4,7 @@ config PINCTRL_IMX
        depends on OF
        select GENERIC_PINCTRL_GROUPS
        select GENERIC_PINMUX_FUNCTIONS
-       select GENERIC_PINCONF
+       select PINCONF
        select REGMAP
 
 config PINCTRL_IMX_SCU
index e9aef764138fb3fabf180dcb58ce98d663f54d54..93ffb5fc04e7a63cd2cb1369f45b419e9dd253a8 100644 (file)
@@ -292,62 +292,6 @@ struct pinmux_ops imx_pmx_ops = {
        .set_mux = imx_pmx_set,
 };
 
-/* decode generic config into raw register values */
-static u32 imx_pinconf_decode_generic_config(struct imx_pinctrl *ipctl,
-                                             unsigned long *configs,
-                                             unsigned int num_configs)
-{
-       const struct imx_pinctrl_soc_info *info = ipctl->info;
-       const struct imx_cfg_params_decode *decode;
-       enum pin_config_param param;
-       u32 raw_config = 0;
-       u32 param_val;
-       int i, j;
-
-       WARN_ON(num_configs > info->num_decodes);
-
-       for (i = 0; i < num_configs; i++) {
-               param = pinconf_to_config_param(configs[i]);
-               param_val = pinconf_to_config_argument(configs[i]);
-               decode = info->decodes;
-               for (j = 0; j < info->num_decodes; j++) {
-                       if (param == decode->param) {
-                               if (decode->invert)
-                                       param_val = !param_val;
-                               raw_config |= (param_val << decode->shift)
-                                             & decode->mask;
-                               break;
-                       }
-                       decode++;
-               }
-       }
-
-       if (info->fixup)
-               info->fixup(configs, num_configs, &raw_config);
-
-       return raw_config;
-}
-
-static u32 imx_pinconf_parse_generic_config(struct device_node *np,
-                                           struct imx_pinctrl *ipctl)
-{
-       const struct imx_pinctrl_soc_info *info = ipctl->info;
-       struct pinctrl_dev *pctl = ipctl->pctl;
-       unsigned int num_configs;
-       unsigned long *configs;
-       int ret;
-
-       if (!info->generic_pinconf)
-               return 0;
-
-       ret = pinconf_generic_parse_dt_config(np, pctl, &configs,
-                                             &num_configs);
-       if (ret)
-               return 0;
-
-       return imx_pinconf_decode_generic_config(ipctl, configs, num_configs);
-}
-
 static int imx_pinconf_get_mmio(struct pinctrl_dev *pctldev, unsigned pin_id,
                                unsigned long *config)
 {
@@ -500,7 +444,6 @@ static const struct pinconf_ops imx_pinconf_ops = {
 /*
  * Each pin represented in fsl,pins consists of a number of u32 PIN_FUNC_ID
  * and 1 u32 CONFIG, the total size is PIN_FUNC_ID + CONFIG for each pin.
- * For generic_pinconf case, there's no extra u32 CONFIG.
  *
  * PIN_FUNC_ID format:
  * Default:
@@ -548,18 +491,12 @@ static void imx_pinctrl_parse_pin_mmio(struct imx_pinctrl *ipctl,
        pin_mmio->mux_mode = be32_to_cpu(*list++);
        pin_mmio->input_val = be32_to_cpu(*list++);
 
-       if (info->generic_pinconf) {
-               /* generic pin config decoded */
-               pin_mmio->config = imx_pinconf_parse_generic_config(np, ipctl);
-       } else {
-               /* legacy pin config read from devicetree */
-               config = be32_to_cpu(*list++);
+       config = be32_to_cpu(*list++);
 
-               /* SION bit is in mux register */
-               if (config & IMX_PAD_SION)
-                       pin_mmio->mux_mode |= IOMUXC_CONFIG_SION;
-               pin_mmio->config = config & ~IMX_PAD_SION;
-       }
+       /* SION bit is in mux register */
+       if (config & IMX_PAD_SION)
+               pin_mmio->mux_mode |= IOMUXC_CONFIG_SION;
+       pin_mmio->config = config & ~IMX_PAD_SION;
 
        *list_p = list;
 
@@ -587,9 +524,6 @@ static int imx_pinctrl_parse_groups(struct device_node *np,
        else
                pin_size = FSL_PIN_SIZE;
 
-       if (info->generic_pinconf)
-               pin_size -= 4;
-
        /* Initialise group */
        grp->name = np->name;
 
@@ -855,10 +789,6 @@ int imx_pinctrl_probe(struct platform_device *pdev,
        imx_pinctrl_desc->confops = &imx_pinconf_ops;
        imx_pinctrl_desc->owner = THIS_MODULE;
 
-       /* for generic pinconf */
-       imx_pinctrl_desc->custom_params = info->custom_params;
-       imx_pinctrl_desc->num_custom_params = info->num_custom_params;
-
        /* platform specific callback */
        imx_pmx_ops.gpio_set_direction = info->gpio_set_direction;
 
index fd8c4b6b3e364ea2a030cd5d2137837e3ca4f037..f65ff45b40038d416544c9e76ce4e5a1faafad0f 100644 (file)
@@ -11,7 +11,6 @@
 #ifndef __DRIVERS_PINCTRL_IMX_H
 #define __DRIVERS_PINCTRL_IMX_H
 
-#include <linux/pinctrl/pinconf-generic.h>
 #include <linux/pinctrl/pinmux.h>
 
 struct platform_device;
@@ -67,14 +66,6 @@ struct imx_pin_reg {
        s16 conf_reg;
 };
 
-/* decode a generic config into raw register value */
-struct imx_cfg_params_decode {
-       enum pin_config_param param;
-       u32 mask;
-       u8 shift;
-       bool invert;
-};
-
 /**
  * @dev: a pointer back to containing device
  * @base: the offset to the controller in virtual memory
@@ -100,15 +91,6 @@ struct imx_pinctrl_soc_info {
        unsigned int mux_mask;
        u8 mux_shift;
 
-       /* generic pinconf */
-       bool generic_pinconf;
-       const struct pinconf_generic_params *custom_params;
-       unsigned int num_custom_params;
-       const struct imx_cfg_params_decode *decodes;
-       unsigned int num_decodes;
-       void (*fixup)(unsigned long *configs, unsigned int num_configs,
-                     u32 *raw_config);
-
        int (*gpio_set_direction)(struct pinctrl_dev *pctldev,
                                  struct pinctrl_gpio_range *range,
                                  unsigned offset,
@@ -122,12 +104,6 @@ struct imx_pinctrl_soc_info {
                                      const __be32 **list_p);
 };
 
-#define IMX_CFG_PARAMS_DECODE(p, m, o) \
-       { .param = p, .mask = m, .shift = o, .invert = false, }
-
-#define IMX_CFG_PARAMS_DECODE_INVERT(p, m, o) \
-       { .param = p, .mask = m, .shift = o, .invert = true, }
-
 #define SHARE_MUX_CONF_REG     BIT(0)
 #define ZERO_OFFSET_VALID      BIT(1)
 #define IMX_USE_SCU            BIT(2)
index a71874fed3d60d35c49cf78978468a288847cc36..7af287252834a42499605e2c39fb948d00bc2b03 100644 (file)
@@ -1,6 +1,6 @@
 # SPDX-License-Identifier: GPL-2.0-only
 menu "MediaTek pinctrl drivers"
-       depends on ARCH_MEDIATEK || COMPILE_TEST
+       depends on ARCH_MEDIATEK || RALINK || COMPILE_TEST
 
 config EINT_MTK
        tristate "MediaTek External Interrupt Support"
@@ -17,11 +17,16 @@ config PINCTRL_MTK
        select GENERIC_PINCONF
        select GPIOLIB
        select EINT_MTK
-       select OF_GPIO
 
 config PINCTRL_MTK_V2
        tristate
 
+config PINCTRL_MTK_MTMIPS
+       bool
+       depends on RALINK
+       select PINMUX
+       select GENERIC_PINCONF
+
 config PINCTRL_MTK_MOORE
        bool
        depends on OF
@@ -29,7 +34,6 @@ config PINCTRL_MTK_MOORE
        select GENERIC_PINCTRL_GROUPS
        select GENERIC_PINMUX_FUNCTIONS
        select GPIOLIB
-       select OF_GPIO
        select EINT_MTK
        select PINCTRL_MTK_V2
 
@@ -40,9 +44,51 @@ config PINCTRL_MTK_PARIS
        select GENERIC_PINCONF
        select GPIOLIB
        select EINT_MTK
-       select OF_GPIO
        select PINCTRL_MTK_V2
 
+# For MIPS SoCs
+config PINCTRL_MT7620
+       bool "MediaTek MT7620 pin control"
+       depends on SOC_MT7620 || COMPILE_TEST
+       depends on RALINK
+       default SOC_MT7620
+       select PINCTRL_MTK_MTMIPS
+
+config PINCTRL_MT7621
+       bool "MediaTek MT7621 pin control"
+       depends on SOC_MT7621 || COMPILE_TEST
+       depends on RALINK
+       default SOC_MT7621
+       select PINCTRL_MTK_MTMIPS
+
+config PINCTRL_MT76X8
+       bool "MediaTek MT76X8 pin control"
+       depends on SOC_MT7620 || COMPILE_TEST
+       depends on RALINK
+       default SOC_MT7620
+       select PINCTRL_MTK_MTMIPS
+
+config PINCTRL_RT2880
+       bool "Ralink RT2880 pin control"
+       depends on SOC_RT288X || COMPILE_TEST
+       depends on RALINK
+       default SOC_RT288X
+       select PINCTRL_MTK_MTMIPS
+
+config PINCTRL_RT305X
+       bool "Ralink RT305X pin control"
+       depends on SOC_RT305X || COMPILE_TEST
+       depends on RALINK
+       default SOC_RT305X
+       select PINCTRL_MTK_MTMIPS
+
+config PINCTRL_RT3883
+       bool "Ralink RT3883 pin control"
+       depends on SOC_RT3883 || COMPILE_TEST
+       depends on RALINK
+       default SOC_RT3883
+       select PINCTRL_MTK_MTMIPS
+
 # For ARMv7 SoCs
 config PINCTRL_MT2701
        bool "MediaTek MT2701 pin control"
index 44d197af516a909723e2db81bc30d8b59d5a9a8a..680f7e8526e00a05ffe68822573ad720ce2e66dc 100644 (file)
@@ -1,32 +1,39 @@
 # SPDX-License-Identifier: GPL-2.0
 # Core
-obj-$(CONFIG_EINT_MTK)         += mtk-eint.o
-obj-$(CONFIG_PINCTRL_MTK)      += pinctrl-mtk-common.o
-obj-$(CONFIG_PINCTRL_MTK_V2)   += pinctrl-mtk-common-v2.o
-obj-$(CONFIG_PINCTRL_MTK_MOORE) += pinctrl-moore.o
-obj-$(CONFIG_PINCTRL_MTK_PARIS) += pinctrl-paris.o
+obj-$(CONFIG_EINT_MTK)                 += mtk-eint.o
+obj-$(CONFIG_PINCTRL_MTK)              += pinctrl-mtk-common.o
+obj-$(CONFIG_PINCTRL_MTK_V2)           += pinctrl-mtk-common-v2.o
+obj-$(CONFIG_PINCTRL_MTK_MTMIPS)       += pinctrl-mtmips.o
+obj-$(CONFIG_PINCTRL_MTK_MOORE)                += pinctrl-moore.o
+obj-$(CONFIG_PINCTRL_MTK_PARIS)                += pinctrl-paris.o
 
 # SoC Drivers
-obj-$(CONFIG_PINCTRL_MT2701)   += pinctrl-mt2701.o
-obj-$(CONFIG_PINCTRL_MT2712)   += pinctrl-mt2712.o
-obj-$(CONFIG_PINCTRL_MT8135)   += pinctrl-mt8135.o
-obj-$(CONFIG_PINCTRL_MT8127)   += pinctrl-mt8127.o
-obj-$(CONFIG_PINCTRL_MT6765)   += pinctrl-mt6765.o
-obj-$(CONFIG_PINCTRL_MT6779)   += pinctrl-mt6779.o
-obj-$(CONFIG_PINCTRL_MT6795)   += pinctrl-mt6795.o
-obj-$(CONFIG_PINCTRL_MT6797)   += pinctrl-mt6797.o
-obj-$(CONFIG_PINCTRL_MT7622)   += pinctrl-mt7622.o
-obj-$(CONFIG_PINCTRL_MT7623)   += pinctrl-mt7623.o
-obj-$(CONFIG_PINCTRL_MT7629)   += pinctrl-mt7629.o
-obj-$(CONFIG_PINCTRL_MT7981)   += pinctrl-mt7981.o
-obj-$(CONFIG_PINCTRL_MT7986)   += pinctrl-mt7986.o
-obj-$(CONFIG_PINCTRL_MT8167)   += pinctrl-mt8167.o
-obj-$(CONFIG_PINCTRL_MT8173)   += pinctrl-mt8173.o
-obj-$(CONFIG_PINCTRL_MT8183)   += pinctrl-mt8183.o
-obj-$(CONFIG_PINCTRL_MT8186)   += pinctrl-mt8186.o
-obj-$(CONFIG_PINCTRL_MT8188)   += pinctrl-mt8188.o
-obj-$(CONFIG_PINCTRL_MT8192)   += pinctrl-mt8192.o
-obj-$(CONFIG_PINCTRL_MT8195)    += pinctrl-mt8195.o
-obj-$(CONFIG_PINCTRL_MT8365)   += pinctrl-mt8365.o
-obj-$(CONFIG_PINCTRL_MT8516)   += pinctrl-mt8516.o
-obj-$(CONFIG_PINCTRL_MT6397)   += pinctrl-mt6397.o
+obj-$(CONFIG_PINCTRL_MT7620)           += pinctrl-mt7620.o
+obj-$(CONFIG_PINCTRL_MT7621)           += pinctrl-mt7621.o
+obj-$(CONFIG_PINCTRL_MT76X8)           += pinctrl-mt76x8.o
+obj-$(CONFIG_PINCTRL_RT2880)           += pinctrl-rt2880.o
+obj-$(CONFIG_PINCTRL_RT305X)           += pinctrl-rt305x.o
+obj-$(CONFIG_PINCTRL_RT3883)           += pinctrl-rt3883.o
+obj-$(CONFIG_PINCTRL_MT2701)           += pinctrl-mt2701.o
+obj-$(CONFIG_PINCTRL_MT2712)           += pinctrl-mt2712.o
+obj-$(CONFIG_PINCTRL_MT8135)           += pinctrl-mt8135.o
+obj-$(CONFIG_PINCTRL_MT8127)           += pinctrl-mt8127.o
+obj-$(CONFIG_PINCTRL_MT6765)           += pinctrl-mt6765.o
+obj-$(CONFIG_PINCTRL_MT6779)           += pinctrl-mt6779.o
+obj-$(CONFIG_PINCTRL_MT6795)           += pinctrl-mt6795.o
+obj-$(CONFIG_PINCTRL_MT6797)           += pinctrl-mt6797.o
+obj-$(CONFIG_PINCTRL_MT7622)           += pinctrl-mt7622.o
+obj-$(CONFIG_PINCTRL_MT7623)           += pinctrl-mt7623.o
+obj-$(CONFIG_PINCTRL_MT7629)           += pinctrl-mt7629.o
+obj-$(CONFIG_PINCTRL_MT7981)           += pinctrl-mt7981.o
+obj-$(CONFIG_PINCTRL_MT7986)           += pinctrl-mt7986.o
+obj-$(CONFIG_PINCTRL_MT8167)           += pinctrl-mt8167.o
+obj-$(CONFIG_PINCTRL_MT8173)           += pinctrl-mt8173.o
+obj-$(CONFIG_PINCTRL_MT8183)           += pinctrl-mt8183.o
+obj-$(CONFIG_PINCTRL_MT8186)           += pinctrl-mt8186.o
+obj-$(CONFIG_PINCTRL_MT8188)           += pinctrl-mt8188.o
+obj-$(CONFIG_PINCTRL_MT8192)           += pinctrl-mt8192.o
+obj-$(CONFIG_PINCTRL_MT8195)           += pinctrl-mt8195.o
+obj-$(CONFIG_PINCTRL_MT8365)           += pinctrl-mt8365.o
+obj-$(CONFIG_PINCTRL_MT8516)           += pinctrl-mt8516.o
+obj-$(CONFIG_PINCTRL_MT6397)           += pinctrl-mt6397.o
index 007b98ce563152d233a0632a2dcf239209c55680..8649a2f9d324d946e1cafacbb847678fcaa04713 100644 (file)
@@ -586,7 +586,7 @@ static int mtk_build_gpiochip(struct mtk_pinctrl *hw)
         * Documentation/devicetree/bindings/gpio/gpio.txt on how to
         * bind pinctrl and gpio drivers via the "gpio-ranges" property.
         */
-       if (!of_find_property(hw->dev->of_node, "gpio-ranges", NULL)) {
+       if (!of_property_present(hw->dev->of_node, "gpio-ranges")) {
                ret = gpiochip_add_pin_range(chip, dev_name(hw->dev), 0, 0,
                                             chip->ngpio);
                if (ret < 0) {
diff --git a/drivers/pinctrl/mediatek/pinctrl-mt7620.c b/drivers/pinctrl/mediatek/pinctrl-mt7620.c
new file mode 100644 (file)
index 0000000..d2624b9
--- /dev/null
@@ -0,0 +1,137 @@
+// SPDX-License-Identifier: GPL-2.0-only
+
+#include <linux/module.h>
+#include <linux/platform_device.h>
+#include <linux/of.h>
+#include "pinctrl-mtmips.h"
+
+#define MT7620_GPIO_MODE_UART0_SHIFT   2
+#define MT7620_GPIO_MODE_UART0_MASK    0x7
+#define MT7620_GPIO_MODE_UART0(x)      ((x) << MT7620_GPIO_MODE_UART0_SHIFT)
+#define MT7620_GPIO_MODE_UARTF         0x0
+#define MT7620_GPIO_MODE_PCM_UARTF     0x1
+#define MT7620_GPIO_MODE_PCM_I2S       0x2
+#define MT7620_GPIO_MODE_I2S_UARTF     0x3
+#define MT7620_GPIO_MODE_PCM_GPIO      0x4
+#define MT7620_GPIO_MODE_GPIO_UARTF    0x5
+#define MT7620_GPIO_MODE_GPIO_I2S      0x6
+#define MT7620_GPIO_MODE_GPIO          0x7
+
+#define MT7620_GPIO_MODE_NAND          0
+#define MT7620_GPIO_MODE_SD            1
+#define MT7620_GPIO_MODE_ND_SD_GPIO    2
+#define MT7620_GPIO_MODE_ND_SD_MASK    0x3
+#define MT7620_GPIO_MODE_ND_SD_SHIFT   18
+
+#define MT7620_GPIO_MODE_PCIE_RST      0
+#define MT7620_GPIO_MODE_PCIE_REF      1
+#define MT7620_GPIO_MODE_PCIE_GPIO     2
+#define MT7620_GPIO_MODE_PCIE_MASK     0x3
+#define MT7620_GPIO_MODE_PCIE_SHIFT    16
+
+#define MT7620_GPIO_MODE_WDT_RST       0
+#define MT7620_GPIO_MODE_WDT_REF       1
+#define MT7620_GPIO_MODE_WDT_GPIO      2
+#define MT7620_GPIO_MODE_WDT_MASK      0x3
+#define MT7620_GPIO_MODE_WDT_SHIFT     21
+
+#define MT7620_GPIO_MODE_MDIO          0
+#define MT7620_GPIO_MODE_MDIO_REFCLK   1
+#define MT7620_GPIO_MODE_MDIO_GPIO     2
+#define MT7620_GPIO_MODE_MDIO_MASK     0x3
+#define MT7620_GPIO_MODE_MDIO_SHIFT    7
+
+#define MT7620_GPIO_MODE_I2C           0
+#define MT7620_GPIO_MODE_UART1         5
+#define MT7620_GPIO_MODE_RGMII1                9
+#define MT7620_GPIO_MODE_RGMII2                10
+#define MT7620_GPIO_MODE_SPI           11
+#define MT7620_GPIO_MODE_SPI_REF_CLK   12
+#define MT7620_GPIO_MODE_WLED          13
+#define MT7620_GPIO_MODE_JTAG          15
+#define MT7620_GPIO_MODE_EPHY          15
+#define MT7620_GPIO_MODE_PA            20
+
+static struct mtmips_pmx_func i2c_grp[] =  { FUNC("i2c", 0, 1, 2) };
+static struct mtmips_pmx_func spi_grp[] = { FUNC("spi", 0, 3, 4) };
+static struct mtmips_pmx_func uartlite_grp[] = { FUNC("uartlite", 0, 15, 2) };
+static struct mtmips_pmx_func mdio_grp[] = {
+       FUNC("mdio", MT7620_GPIO_MODE_MDIO, 22, 2),
+       FUNC("refclk", MT7620_GPIO_MODE_MDIO_REFCLK, 22, 2),
+};
+static struct mtmips_pmx_func rgmii1_grp[] = { FUNC("rgmii1", 0, 24, 12) };
+static struct mtmips_pmx_func refclk_grp[] = { FUNC("spi refclk", 0, 37, 3) };
+static struct mtmips_pmx_func ephy_grp[] = { FUNC("ephy", 0, 40, 5) };
+static struct mtmips_pmx_func rgmii2_grp[] = { FUNC("rgmii2", 0, 60, 12) };
+static struct mtmips_pmx_func wled_grp[] = { FUNC("wled", 0, 72, 1) };
+static struct mtmips_pmx_func pa_grp[] = { FUNC("pa", 0, 18, 4) };
+static struct mtmips_pmx_func uartf_grp[] = {
+       FUNC("uartf", MT7620_GPIO_MODE_UARTF, 7, 8),
+       FUNC("pcm uartf", MT7620_GPIO_MODE_PCM_UARTF, 7, 8),
+       FUNC("pcm i2s", MT7620_GPIO_MODE_PCM_I2S, 7, 8),
+       FUNC("i2s uartf", MT7620_GPIO_MODE_I2S_UARTF, 7, 8),
+       FUNC("pcm gpio", MT7620_GPIO_MODE_PCM_GPIO, 11, 4),
+       FUNC("gpio uartf", MT7620_GPIO_MODE_GPIO_UARTF, 7, 4),
+       FUNC("gpio i2s", MT7620_GPIO_MODE_GPIO_I2S, 7, 4),
+};
+static struct mtmips_pmx_func wdt_grp[] = {
+       FUNC("wdt rst", 0, 17, 1),
+       FUNC("wdt refclk", 0, 17, 1),
+       };
+static struct mtmips_pmx_func pcie_rst_grp[] = {
+       FUNC("pcie rst", MT7620_GPIO_MODE_PCIE_RST, 36, 1),
+       FUNC("pcie refclk", MT7620_GPIO_MODE_PCIE_REF, 36, 1)
+};
+static struct mtmips_pmx_func nd_sd_grp[] = {
+       FUNC("nand", MT7620_GPIO_MODE_NAND, 45, 15),
+       FUNC("sd", MT7620_GPIO_MODE_SD, 47, 13)
+};
+
+static struct mtmips_pmx_group mt7620a_pinmux_data[] = {
+       GRP("i2c", i2c_grp, 1, MT7620_GPIO_MODE_I2C),
+       GRP("uartf", uartf_grp, MT7620_GPIO_MODE_UART0_MASK,
+               MT7620_GPIO_MODE_UART0_SHIFT),
+       GRP("spi", spi_grp, 1, MT7620_GPIO_MODE_SPI),
+       GRP("uartlite", uartlite_grp, 1, MT7620_GPIO_MODE_UART1),
+       GRP_G("wdt", wdt_grp, MT7620_GPIO_MODE_WDT_MASK,
+               MT7620_GPIO_MODE_WDT_GPIO, MT7620_GPIO_MODE_WDT_SHIFT),
+       GRP_G("mdio", mdio_grp, MT7620_GPIO_MODE_MDIO_MASK,
+               MT7620_GPIO_MODE_MDIO_GPIO, MT7620_GPIO_MODE_MDIO_SHIFT),
+       GRP("rgmii1", rgmii1_grp, 1, MT7620_GPIO_MODE_RGMII1),
+       GRP("spi refclk", refclk_grp, 1, MT7620_GPIO_MODE_SPI_REF_CLK),
+       GRP_G("pcie", pcie_rst_grp, MT7620_GPIO_MODE_PCIE_MASK,
+               MT7620_GPIO_MODE_PCIE_GPIO, MT7620_GPIO_MODE_PCIE_SHIFT),
+       GRP_G("nd_sd", nd_sd_grp, MT7620_GPIO_MODE_ND_SD_MASK,
+               MT7620_GPIO_MODE_ND_SD_GPIO, MT7620_GPIO_MODE_ND_SD_SHIFT),
+       GRP("rgmii2", rgmii2_grp, 1, MT7620_GPIO_MODE_RGMII2),
+       GRP("wled", wled_grp, 1, MT7620_GPIO_MODE_WLED),
+       GRP("ephy", ephy_grp, 1, MT7620_GPIO_MODE_EPHY),
+       GRP("pa", pa_grp, 1, MT7620_GPIO_MODE_PA),
+       { 0 }
+};
+
+static int mt7620_pinctrl_probe(struct platform_device *pdev)
+{
+       return mtmips_pinctrl_init(pdev, mt7620a_pinmux_data);
+}
+
+static const struct of_device_id mt7620_pinctrl_match[] = {
+       { .compatible = "ralink,mt7620-pinctrl" },
+       { .compatible = "ralink,rt2880-pinmux" },
+       {}
+};
+MODULE_DEVICE_TABLE(of, mt7620_pinctrl_match);
+
+static struct platform_driver mt7620_pinctrl_driver = {
+       .probe = mt7620_pinctrl_probe,
+       .driver = {
+               .name = "mt7620-pinctrl",
+               .of_match_table = mt7620_pinctrl_match,
+       },
+};
+
+static int __init mt7620_pinctrl_init(void)
+{
+       return platform_driver_register(&mt7620_pinctrl_driver);
+}
+core_initcall_sync(mt7620_pinctrl_init);
diff --git a/drivers/pinctrl/mediatek/pinctrl-mt7621.c b/drivers/pinctrl/mediatek/pinctrl-mt7621.c
new file mode 100644 (file)
index 0000000..b18c1a4
--- /dev/null
@@ -0,0 +1,117 @@
+// SPDX-License-Identifier: GPL-2.0-only
+
+#include <linux/module.h>
+#include <linux/platform_device.h>
+#include <linux/of.h>
+#include "pinctrl-mtmips.h"
+
+#define MT7621_GPIO_MODE_UART1         1
+#define MT7621_GPIO_MODE_I2C           2
+#define MT7621_GPIO_MODE_UART3_MASK    0x3
+#define MT7621_GPIO_MODE_UART3_SHIFT   3
+#define MT7621_GPIO_MODE_UART3_GPIO    1
+#define MT7621_GPIO_MODE_UART2_MASK    0x3
+#define MT7621_GPIO_MODE_UART2_SHIFT   5
+#define MT7621_GPIO_MODE_UART2_GPIO    1
+#define MT7621_GPIO_MODE_JTAG          7
+#define MT7621_GPIO_MODE_WDT_MASK      0x3
+#define MT7621_GPIO_MODE_WDT_SHIFT     8
+#define MT7621_GPIO_MODE_WDT_GPIO      1
+#define MT7621_GPIO_MODE_PCIE_RST      0
+#define MT7621_GPIO_MODE_PCIE_REF      2
+#define MT7621_GPIO_MODE_PCIE_MASK     0x3
+#define MT7621_GPIO_MODE_PCIE_SHIFT    10
+#define MT7621_GPIO_MODE_PCIE_GPIO     1
+#define MT7621_GPIO_MODE_MDIO_MASK     0x3
+#define MT7621_GPIO_MODE_MDIO_SHIFT    12
+#define MT7621_GPIO_MODE_MDIO_GPIO     1
+#define MT7621_GPIO_MODE_RGMII1                14
+#define MT7621_GPIO_MODE_RGMII2                15
+#define MT7621_GPIO_MODE_SPI_MASK      0x3
+#define MT7621_GPIO_MODE_SPI_SHIFT     16
+#define MT7621_GPIO_MODE_SPI_GPIO      1
+#define MT7621_GPIO_MODE_SDHCI_MASK    0x3
+#define MT7621_GPIO_MODE_SDHCI_SHIFT   18
+#define MT7621_GPIO_MODE_SDHCI_GPIO    1
+
+static struct mtmips_pmx_func uart1_grp[] =  { FUNC("uart1", 0, 1, 2) };
+static struct mtmips_pmx_func i2c_grp[] =  { FUNC("i2c", 0, 3, 2) };
+static struct mtmips_pmx_func uart3_grp[] = {
+       FUNC("uart3", 0, 5, 4),
+       FUNC("i2s", 2, 5, 4),
+       FUNC("spdif3", 3, 5, 4),
+};
+static struct mtmips_pmx_func uart2_grp[] = {
+       FUNC("uart2", 0, 9, 4),
+       FUNC("pcm", 2, 9, 4),
+       FUNC("spdif2", 3, 9, 4),
+};
+static struct mtmips_pmx_func jtag_grp[] = { FUNC("jtag", 0, 13, 5) };
+static struct mtmips_pmx_func wdt_grp[] = {
+       FUNC("wdt rst", 0, 18, 1),
+       FUNC("wdt refclk", 2, 18, 1),
+};
+static struct mtmips_pmx_func pcie_rst_grp[] = {
+       FUNC("pcie rst", MT7621_GPIO_MODE_PCIE_RST, 19, 1),
+       FUNC("pcie refclk", MT7621_GPIO_MODE_PCIE_REF, 19, 1)
+};
+static struct mtmips_pmx_func mdio_grp[] = { FUNC("mdio", 0, 20, 2) };
+static struct mtmips_pmx_func rgmii2_grp[] = { FUNC("rgmii2", 0, 22, 12) };
+static struct mtmips_pmx_func spi_grp[] = {
+       FUNC("spi", 0, 34, 7),
+       FUNC("nand1", 2, 34, 7),
+};
+static struct mtmips_pmx_func sdhci_grp[] = {
+       FUNC("sdhci", 0, 41, 8),
+       FUNC("nand2", 2, 41, 8),
+};
+static struct mtmips_pmx_func rgmii1_grp[] = { FUNC("rgmii1", 0, 49, 12) };
+
+static struct mtmips_pmx_group mt7621_pinmux_data[] = {
+       GRP("uart1", uart1_grp, 1, MT7621_GPIO_MODE_UART1),
+       GRP("i2c", i2c_grp, 1, MT7621_GPIO_MODE_I2C),
+       GRP_G("uart3", uart3_grp, MT7621_GPIO_MODE_UART3_MASK,
+               MT7621_GPIO_MODE_UART3_GPIO, MT7621_GPIO_MODE_UART3_SHIFT),
+       GRP_G("uart2", uart2_grp, MT7621_GPIO_MODE_UART2_MASK,
+               MT7621_GPIO_MODE_UART2_GPIO, MT7621_GPIO_MODE_UART2_SHIFT),
+       GRP("jtag", jtag_grp, 1, MT7621_GPIO_MODE_JTAG),
+       GRP_G("wdt", wdt_grp, MT7621_GPIO_MODE_WDT_MASK,
+               MT7621_GPIO_MODE_WDT_GPIO, MT7621_GPIO_MODE_WDT_SHIFT),
+       GRP_G("pcie", pcie_rst_grp, MT7621_GPIO_MODE_PCIE_MASK,
+               MT7621_GPIO_MODE_PCIE_GPIO, MT7621_GPIO_MODE_PCIE_SHIFT),
+       GRP_G("mdio", mdio_grp, MT7621_GPIO_MODE_MDIO_MASK,
+               MT7621_GPIO_MODE_MDIO_GPIO, MT7621_GPIO_MODE_MDIO_SHIFT),
+       GRP("rgmii2", rgmii2_grp, 1, MT7621_GPIO_MODE_RGMII2),
+       GRP_G("spi", spi_grp, MT7621_GPIO_MODE_SPI_MASK,
+               MT7621_GPIO_MODE_SPI_GPIO, MT7621_GPIO_MODE_SPI_SHIFT),
+       GRP_G("sdhci", sdhci_grp, MT7621_GPIO_MODE_SDHCI_MASK,
+               MT7621_GPIO_MODE_SDHCI_GPIO, MT7621_GPIO_MODE_SDHCI_SHIFT),
+       GRP("rgmii1", rgmii1_grp, 1, MT7621_GPIO_MODE_RGMII1),
+       { 0 }
+};
+
+static int mt7621_pinctrl_probe(struct platform_device *pdev)
+{
+       return mtmips_pinctrl_init(pdev, mt7621_pinmux_data);
+}
+
+static const struct of_device_id mt7621_pinctrl_match[] = {
+       { .compatible = "ralink,mt7621-pinctrl" },
+       { .compatible = "ralink,rt2880-pinmux" },
+       {}
+};
+MODULE_DEVICE_TABLE(of, mt7621_pinctrl_match);
+
+static struct platform_driver mt7621_pinctrl_driver = {
+       .probe = mt7621_pinctrl_probe,
+       .driver = {
+               .name = "mt7621-pinctrl",
+               .of_match_table = mt7621_pinctrl_match,
+       },
+};
+
+static int __init mt7621_pinctrl_init(void)
+{
+       return platform_driver_register(&mt7621_pinctrl_driver);
+}
+core_initcall_sync(mt7621_pinctrl_init);
diff --git a/drivers/pinctrl/mediatek/pinctrl-mt76x8.c b/drivers/pinctrl/mediatek/pinctrl-mt76x8.c
new file mode 100644 (file)
index 0000000..e7d6ad2
--- /dev/null
@@ -0,0 +1,283 @@
+// SPDX-License-Identifier: GPL-2.0-only
+
+#include <linux/module.h>
+#include <linux/platform_device.h>
+#include <linux/of.h>
+#include "pinctrl-mtmips.h"
+
+#define MT76X8_GPIO_MODE_MASK          0x3
+
+#define MT76X8_GPIO_MODE_P4LED_KN      58
+#define MT76X8_GPIO_MODE_P3LED_KN      56
+#define MT76X8_GPIO_MODE_P2LED_KN      54
+#define MT76X8_GPIO_MODE_P1LED_KN      52
+#define MT76X8_GPIO_MODE_P0LED_KN      50
+#define MT76X8_GPIO_MODE_WLED_KN       48
+#define MT76X8_GPIO_MODE_P4LED_AN      42
+#define MT76X8_GPIO_MODE_P3LED_AN      40
+#define MT76X8_GPIO_MODE_P2LED_AN      38
+#define MT76X8_GPIO_MODE_P1LED_AN      36
+#define MT76X8_GPIO_MODE_P0LED_AN      34
+#define MT76X8_GPIO_MODE_WLED_AN       32
+#define MT76X8_GPIO_MODE_PWM1          30
+#define MT76X8_GPIO_MODE_PWM0          28
+#define MT76X8_GPIO_MODE_UART2         26
+#define MT76X8_GPIO_MODE_UART1         24
+#define MT76X8_GPIO_MODE_I2C           20
+#define MT76X8_GPIO_MODE_REFCLK                18
+#define MT76X8_GPIO_MODE_PERST         16
+#define MT76X8_GPIO_MODE_WDT           14
+#define MT76X8_GPIO_MODE_SPI           12
+#define MT76X8_GPIO_MODE_SDMODE                10
+#define MT76X8_GPIO_MODE_UART0         8
+#define MT76X8_GPIO_MODE_I2S           6
+#define MT76X8_GPIO_MODE_CS1           4
+#define MT76X8_GPIO_MODE_SPIS          2
+#define MT76X8_GPIO_MODE_GPIO          0
+
+static struct mtmips_pmx_func pwm1_grp[] = {
+       FUNC("sdxc d6", 3, 19, 1),
+       FUNC("utif", 2, 19, 1),
+       FUNC("gpio", 1, 19, 1),
+       FUNC("pwm1", 0, 19, 1),
+};
+
+static struct mtmips_pmx_func pwm0_grp[] = {
+       FUNC("sdxc d7", 3, 18, 1),
+       FUNC("utif", 2, 18, 1),
+       FUNC("gpio", 1, 18, 1),
+       FUNC("pwm0", 0, 18, 1),
+};
+
+static struct mtmips_pmx_func uart2_grp[] = {
+       FUNC("sdxc d5 d4", 3, 20, 2),
+       FUNC("pwm", 2, 20, 2),
+       FUNC("gpio", 1, 20, 2),
+       FUNC("uart2", 0, 20, 2),
+};
+
+static struct mtmips_pmx_func uart1_grp[] = {
+       FUNC("sw_r", 3, 45, 2),
+       FUNC("pwm", 2, 45, 2),
+       FUNC("gpio", 1, 45, 2),
+       FUNC("uart1", 0, 45, 2),
+};
+
+static struct mtmips_pmx_func i2c_grp[] = {
+       FUNC("-", 3, 4, 2),
+       FUNC("debug", 2, 4, 2),
+       FUNC("gpio", 1, 4, 2),
+       FUNC("i2c", 0, 4, 2),
+};
+
+static struct mtmips_pmx_func refclk_grp[] = { FUNC("refclk", 0, 37, 1) };
+static struct mtmips_pmx_func perst_grp[] = { FUNC("perst", 0, 36, 1) };
+static struct mtmips_pmx_func wdt_grp[] = { FUNC("wdt", 0, 38, 1) };
+static struct mtmips_pmx_func spi_grp[] = { FUNC("spi", 0, 7, 4) };
+
+static struct mtmips_pmx_func sd_mode_grp[] = {
+       FUNC("jtag", 3, 22, 8),
+       FUNC("utif", 2, 22, 8),
+       FUNC("gpio", 1, 22, 8),
+       FUNC("sdxc", 0, 22, 8),
+};
+
+static struct mtmips_pmx_func uart0_grp[] = {
+       FUNC("-", 3, 12, 2),
+       FUNC("-", 2, 12, 2),
+       FUNC("gpio", 1, 12, 2),
+       FUNC("uart0", 0, 12, 2),
+};
+
+static struct mtmips_pmx_func i2s_grp[] = {
+       FUNC("antenna", 3, 0, 4),
+       FUNC("pcm", 2, 0, 4),
+       FUNC("gpio", 1, 0, 4),
+       FUNC("i2s", 0, 0, 4),
+};
+
+static struct mtmips_pmx_func spi_cs1_grp[] = {
+       FUNC("-", 3, 6, 1),
+       FUNC("refclk", 2, 6, 1),
+       FUNC("gpio", 1, 6, 1),
+       FUNC("spi cs1", 0, 6, 1),
+};
+
+static struct mtmips_pmx_func spis_grp[] = {
+       FUNC("pwm_uart2", 3, 14, 4),
+       FUNC("utif", 2, 14, 4),
+       FUNC("gpio", 1, 14, 4),
+       FUNC("spis", 0, 14, 4),
+};
+
+static struct mtmips_pmx_func gpio_grp[] = {
+       FUNC("pcie", 3, 11, 1),
+       FUNC("refclk", 2, 11, 1),
+       FUNC("gpio", 1, 11, 1),
+       FUNC("gpio", 0, 11, 1),
+};
+
+static struct mtmips_pmx_func p4led_kn_grp[] = {
+       FUNC("jtag", 3, 30, 1),
+       FUNC("utif", 2, 30, 1),
+       FUNC("gpio", 1, 30, 1),
+       FUNC("p4led_kn", 0, 30, 1),
+};
+
+static struct mtmips_pmx_func p3led_kn_grp[] = {
+       FUNC("jtag", 3, 31, 1),
+       FUNC("utif", 2, 31, 1),
+       FUNC("gpio", 1, 31, 1),
+       FUNC("p3led_kn", 0, 31, 1),
+};
+
+static struct mtmips_pmx_func p2led_kn_grp[] = {
+       FUNC("jtag", 3, 32, 1),
+       FUNC("utif", 2, 32, 1),
+       FUNC("gpio", 1, 32, 1),
+       FUNC("p2led_kn", 0, 32, 1),
+};
+
+static struct mtmips_pmx_func p1led_kn_grp[] = {
+       FUNC("jtag", 3, 33, 1),
+       FUNC("utif", 2, 33, 1),
+       FUNC("gpio", 1, 33, 1),
+       FUNC("p1led_kn", 0, 33, 1),
+};
+
+static struct mtmips_pmx_func p0led_kn_grp[] = {
+       FUNC("jtag", 3, 34, 1),
+       FUNC("rsvd", 2, 34, 1),
+       FUNC("gpio", 1, 34, 1),
+       FUNC("p0led_kn", 0, 34, 1),
+};
+
+static struct mtmips_pmx_func wled_kn_grp[] = {
+       FUNC("rsvd", 3, 35, 1),
+       FUNC("rsvd", 2, 35, 1),
+       FUNC("gpio", 1, 35, 1),
+       FUNC("wled_kn", 0, 35, 1),
+};
+
+static struct mtmips_pmx_func p4led_an_grp[] = {
+       FUNC("jtag", 3, 39, 1),
+       FUNC("utif", 2, 39, 1),
+       FUNC("gpio", 1, 39, 1),
+       FUNC("p4led_an", 0, 39, 1),
+};
+
+static struct mtmips_pmx_func p3led_an_grp[] = {
+       FUNC("jtag", 3, 40, 1),
+       FUNC("utif", 2, 40, 1),
+       FUNC("gpio", 1, 40, 1),
+       FUNC("p3led_an", 0, 40, 1),
+};
+
+static struct mtmips_pmx_func p2led_an_grp[] = {
+       FUNC("jtag", 3, 41, 1),
+       FUNC("utif", 2, 41, 1),
+       FUNC("gpio", 1, 41, 1),
+       FUNC("p2led_an", 0, 41, 1),
+};
+
+static struct mtmips_pmx_func p1led_an_grp[] = {
+       FUNC("jtag", 3, 42, 1),
+       FUNC("utif", 2, 42, 1),
+       FUNC("gpio", 1, 42, 1),
+       FUNC("p1led_an", 0, 42, 1),
+};
+
+static struct mtmips_pmx_func p0led_an_grp[] = {
+       FUNC("jtag", 3, 43, 1),
+       FUNC("rsvd", 2, 43, 1),
+       FUNC("gpio", 1, 43, 1),
+       FUNC("p0led_an", 0, 43, 1),
+};
+
+static struct mtmips_pmx_func wled_an_grp[] = {
+       FUNC("rsvd", 3, 44, 1),
+       FUNC("rsvd", 2, 44, 1),
+       FUNC("gpio", 1, 44, 1),
+       FUNC("wled_an", 0, 44, 1),
+};
+
+static struct mtmips_pmx_group mt76x8_pinmux_data[] = {
+       GRP_G("pwm1", pwm1_grp, MT76X8_GPIO_MODE_MASK,
+                               1, MT76X8_GPIO_MODE_PWM1),
+       GRP_G("pwm0", pwm0_grp, MT76X8_GPIO_MODE_MASK,
+                               1, MT76X8_GPIO_MODE_PWM0),
+       GRP_G("uart2", uart2_grp, MT76X8_GPIO_MODE_MASK,
+                               1, MT76X8_GPIO_MODE_UART2),
+       GRP_G("uart1", uart1_grp, MT76X8_GPIO_MODE_MASK,
+                               1, MT76X8_GPIO_MODE_UART1),
+       GRP_G("i2c", i2c_grp, MT76X8_GPIO_MODE_MASK,
+                               1, MT76X8_GPIO_MODE_I2C),
+       GRP("refclk", refclk_grp, 1, MT76X8_GPIO_MODE_REFCLK),
+       GRP("perst", perst_grp, 1, MT76X8_GPIO_MODE_PERST),
+       GRP("wdt", wdt_grp, 1, MT76X8_GPIO_MODE_WDT),
+       GRP("spi", spi_grp, 1, MT76X8_GPIO_MODE_SPI),
+       GRP_G("sdmode", sd_mode_grp, MT76X8_GPIO_MODE_MASK,
+                               1, MT76X8_GPIO_MODE_SDMODE),
+       GRP_G("uart0", uart0_grp, MT76X8_GPIO_MODE_MASK,
+                               1, MT76X8_GPIO_MODE_UART0),
+       GRP_G("i2s", i2s_grp, MT76X8_GPIO_MODE_MASK,
+                               1, MT76X8_GPIO_MODE_I2S),
+       GRP_G("spi cs1", spi_cs1_grp, MT76X8_GPIO_MODE_MASK,
+                               1, MT76X8_GPIO_MODE_CS1),
+       GRP_G("spis", spis_grp, MT76X8_GPIO_MODE_MASK,
+                               1, MT76X8_GPIO_MODE_SPIS),
+       GRP_G("gpio", gpio_grp, MT76X8_GPIO_MODE_MASK,
+                               1, MT76X8_GPIO_MODE_GPIO),
+       GRP_G("wled_an", wled_an_grp, MT76X8_GPIO_MODE_MASK,
+                               1, MT76X8_GPIO_MODE_WLED_AN),
+       GRP_G("p0led_an", p0led_an_grp, MT76X8_GPIO_MODE_MASK,
+                               1, MT76X8_GPIO_MODE_P0LED_AN),
+       GRP_G("p1led_an", p1led_an_grp, MT76X8_GPIO_MODE_MASK,
+                               1, MT76X8_GPIO_MODE_P1LED_AN),
+       GRP_G("p2led_an", p2led_an_grp, MT76X8_GPIO_MODE_MASK,
+                               1, MT76X8_GPIO_MODE_P2LED_AN),
+       GRP_G("p3led_an", p3led_an_grp, MT76X8_GPIO_MODE_MASK,
+                               1, MT76X8_GPIO_MODE_P3LED_AN),
+       GRP_G("p4led_an", p4led_an_grp, MT76X8_GPIO_MODE_MASK,
+                               1, MT76X8_GPIO_MODE_P4LED_AN),
+       GRP_G("wled_kn", wled_kn_grp, MT76X8_GPIO_MODE_MASK,
+                               1, MT76X8_GPIO_MODE_WLED_KN),
+       GRP_G("p0led_kn", p0led_kn_grp, MT76X8_GPIO_MODE_MASK,
+                               1, MT76X8_GPIO_MODE_P0LED_KN),
+       GRP_G("p1led_kn", p1led_kn_grp, MT76X8_GPIO_MODE_MASK,
+                               1, MT76X8_GPIO_MODE_P1LED_KN),
+       GRP_G("p2led_kn", p2led_kn_grp, MT76X8_GPIO_MODE_MASK,
+                               1, MT76X8_GPIO_MODE_P2LED_KN),
+       GRP_G("p3led_kn", p3led_kn_grp, MT76X8_GPIO_MODE_MASK,
+                               1, MT76X8_GPIO_MODE_P3LED_KN),
+       GRP_G("p4led_kn", p4led_kn_grp, MT76X8_GPIO_MODE_MASK,
+                               1, MT76X8_GPIO_MODE_P4LED_KN),
+       { 0 }
+};
+
+static int mt76x8_pinctrl_probe(struct platform_device *pdev)
+{
+       return mtmips_pinctrl_init(pdev, mt76x8_pinmux_data);
+}
+
+static const struct of_device_id mt76x8_pinctrl_match[] = {
+       { .compatible = "ralink,mt76x8-pinctrl" },
+       { .compatible = "ralink,mt7620-pinctrl" },
+       { .compatible = "ralink,rt2880-pinmux" },
+       {}
+};
+MODULE_DEVICE_TABLE(of, mt76x8_pinctrl_match);
+
+static struct platform_driver mt76x8_pinctrl_driver = {
+       .probe = mt76x8_pinctrl_probe,
+       .driver = {
+               .name = "mt76x8-pinctrl",
+               .of_match_table = mt76x8_pinctrl_match,
+       },
+};
+
+static int __init mt76x8_pinctrl_init(void)
+{
+       return platform_driver_register(&mt76x8_pinctrl_driver);
+}
+core_initcall_sync(mt76x8_pinctrl_init);
diff --git a/drivers/pinctrl/mediatek/pinctrl-mtmips.c b/drivers/pinctrl/mediatek/pinctrl-mtmips.c
new file mode 100644 (file)
index 0000000..efd77b6
--- /dev/null
@@ -0,0 +1,351 @@
+// SPDX-License-Identifier: GPL-2.0
+/*
+ *  Copyright (C) 2013 John Crispin <blogic@openwrt.org>
+ */
+
+#include <linux/module.h>
+#include <linux/device.h>
+#include <linux/io.h>
+#include <linux/platform_device.h>
+#include <linux/slab.h>
+#include <linux/of.h>
+#include <linux/pinctrl/pinctrl.h>
+#include <linux/pinctrl/pinconf.h>
+#include <linux/pinctrl/pinconf-generic.h>
+#include <linux/pinctrl/pinmux.h>
+#include <linux/pinctrl/consumer.h>
+#include <linux/pinctrl/machine.h>
+
+#include <asm/mach-ralink/ralink_regs.h>
+#include <asm/mach-ralink/mt7620.h>
+
+#include "pinctrl-mtmips.h"
+#include "../core.h"
+#include "../pinctrl-utils.h"
+
+#define SYSC_REG_GPIO_MODE     0x60
+#define SYSC_REG_GPIO_MODE2    0x64
+
+struct mtmips_priv {
+       struct device *dev;
+
+       struct pinctrl_pin_desc *pads;
+       struct pinctrl_desc *desc;
+
+       struct mtmips_pmx_func **func;
+       int func_count;
+
+       struct mtmips_pmx_group *groups;
+       const char **group_names;
+       int group_count;
+
+       u8 *gpio;
+       int max_pins;
+};
+
+static int mtmips_get_group_count(struct pinctrl_dev *pctrldev)
+{
+       struct mtmips_priv *p = pinctrl_dev_get_drvdata(pctrldev);
+
+       return p->group_count;
+}
+
+static const char *mtmips_get_group_name(struct pinctrl_dev *pctrldev,
+                                        unsigned int group)
+{
+       struct mtmips_priv *p = pinctrl_dev_get_drvdata(pctrldev);
+
+       return (group >= p->group_count) ? NULL : p->group_names[group];
+}
+
+static int mtmips_get_group_pins(struct pinctrl_dev *pctrldev,
+                                unsigned int group,
+                                const unsigned int **pins,
+                                unsigned int *num_pins)
+{
+       struct mtmips_priv *p = pinctrl_dev_get_drvdata(pctrldev);
+
+       if (group >= p->group_count)
+               return -EINVAL;
+
+       *pins = p->groups[group].func[0].pins;
+       *num_pins = p->groups[group].func[0].pin_count;
+
+       return 0;
+}
+
+static const struct pinctrl_ops mtmips_pctrl_ops = {
+       .get_groups_count       = mtmips_get_group_count,
+       .get_group_name         = mtmips_get_group_name,
+       .get_group_pins         = mtmips_get_group_pins,
+       .dt_node_to_map         = pinconf_generic_dt_node_to_map_all,
+       .dt_free_map            = pinconf_generic_dt_free_map,
+};
+
+static int mtmips_pmx_func_count(struct pinctrl_dev *pctrldev)
+{
+       struct mtmips_priv *p = pinctrl_dev_get_drvdata(pctrldev);
+
+       return p->func_count;
+}
+
+static const char *mtmips_pmx_func_name(struct pinctrl_dev *pctrldev,
+                                       unsigned int func)
+{
+       struct mtmips_priv *p = pinctrl_dev_get_drvdata(pctrldev);
+
+       return p->func[func]->name;
+}
+
+static int mtmips_pmx_group_get_groups(struct pinctrl_dev *pctrldev,
+                                      unsigned int func,
+                                      const char * const **groups,
+                                      unsigned int * const num_groups)
+{
+       struct mtmips_priv *p = pinctrl_dev_get_drvdata(pctrldev);
+
+       if (p->func[func]->group_count == 1)
+               *groups = &p->group_names[p->func[func]->groups[0]];
+       else
+               *groups = p->group_names;
+
+       *num_groups = p->func[func]->group_count;
+
+       return 0;
+}
+
+static int mtmips_pmx_group_enable(struct pinctrl_dev *pctrldev,
+                                  unsigned int func, unsigned int group)
+{
+       struct mtmips_priv *p = pinctrl_dev_get_drvdata(pctrldev);
+       u32 mode = 0;
+       u32 reg = SYSC_REG_GPIO_MODE;
+       int i;
+       int shift;
+
+       /* dont allow double use */
+       if (p->groups[group].enabled) {
+               dev_err(p->dev, "%s is already enabled\n",
+                       p->groups[group].name);
+               return 0;
+       }
+
+       p->groups[group].enabled = 1;
+       p->func[func]->enabled = 1;
+
+       shift = p->groups[group].shift;
+       if (shift >= 32) {
+               shift -= 32;
+               reg = SYSC_REG_GPIO_MODE2;
+       }
+       mode = rt_sysc_r32(reg);
+       mode &= ~(p->groups[group].mask << shift);
+
+       /* mark the pins as gpio */
+       for (i = 0; i < p->groups[group].func[0].pin_count; i++)
+               p->gpio[p->groups[group].func[0].pins[i]] = 1;
+
+       /* function 0 is gpio and needs special handling */
+       if (func == 0) {
+               mode |= p->groups[group].gpio << shift;
+       } else {
+               for (i = 0; i < p->func[func]->pin_count; i++)
+                       p->gpio[p->func[func]->pins[i]] = 0;
+               mode |= p->func[func]->value << shift;
+       }
+       rt_sysc_w32(mode, reg);
+
+       return 0;
+}
+
+static int mtmips_pmx_group_gpio_request_enable(struct pinctrl_dev *pctrldev,
+                                               struct pinctrl_gpio_range *range,
+                                               unsigned int pin)
+{
+       struct mtmips_priv *p = pinctrl_dev_get_drvdata(pctrldev);
+
+       if (!p->gpio[pin]) {
+               dev_err(p->dev, "pin %d is not set to gpio mux\n", pin);
+               return -EINVAL;
+       }
+
+       return 0;
+}
+
+static const struct pinmux_ops mtmips_pmx_group_ops = {
+       .get_functions_count    = mtmips_pmx_func_count,
+       .get_function_name      = mtmips_pmx_func_name,
+       .get_function_groups    = mtmips_pmx_group_get_groups,
+       .set_mux                = mtmips_pmx_group_enable,
+       .gpio_request_enable    = mtmips_pmx_group_gpio_request_enable,
+};
+
+static struct pinctrl_desc mtmips_pctrl_desc = {
+       .owner          = THIS_MODULE,
+       .name           = "mtmips-pinctrl",
+       .pctlops        = &mtmips_pctrl_ops,
+       .pmxops         = &mtmips_pmx_group_ops,
+};
+
+static struct mtmips_pmx_func gpio_func = {
+       .name = "gpio",
+};
+
+static int mtmips_pinctrl_index(struct mtmips_priv *p)
+{
+       struct mtmips_pmx_group *mux = p->groups;
+       int i, j, c = 0;
+
+       /* count the mux functions */
+       while (mux->name) {
+               p->group_count++;
+               mux++;
+       }
+
+       /* allocate the group names array needed by the gpio function */
+       p->group_names = devm_kcalloc(p->dev, p->group_count,
+                                     sizeof(char *), GFP_KERNEL);
+       if (!p->group_names)
+               return -ENOMEM;
+
+       for (i = 0; i < p->group_count; i++) {
+               p->group_names[i] = p->groups[i].name;
+               p->func_count += p->groups[i].func_count;
+       }
+
+       /* we have a dummy function[0] for gpio */
+       p->func_count++;
+
+       /* allocate our function and group mapping index buffers */
+       p->func = devm_kcalloc(p->dev, p->func_count,
+                              sizeof(*p->func), GFP_KERNEL);
+       gpio_func.groups = devm_kcalloc(p->dev, p->group_count, sizeof(int),
+                                       GFP_KERNEL);
+       if (!p->func || !gpio_func.groups)
+               return -ENOMEM;
+
+       /* add a backpointer to the function so it knows its group */
+       gpio_func.group_count = p->group_count;
+       for (i = 0; i < gpio_func.group_count; i++)
+               gpio_func.groups[i] = i;
+
+       p->func[c] = &gpio_func;
+       c++;
+
+       /* add remaining functions */
+       for (i = 0; i < p->group_count; i++) {
+               for (j = 0; j < p->groups[i].func_count; j++) {
+                       p->func[c] = &p->groups[i].func[j];
+                       p->func[c]->groups = devm_kzalloc(p->dev, sizeof(int),
+                                                   GFP_KERNEL);
+                       if (!p->func[c]->groups)
+                               return -ENOMEM;
+                       p->func[c]->groups[0] = i;
+                       p->func[c]->group_count = 1;
+                       c++;
+               }
+       }
+       return 0;
+}
+
+static int mtmips_pinctrl_pins(struct mtmips_priv *p)
+{
+       int i, j;
+
+       /*
+        * loop over the functions and initialize the pins array.
+        * also work out the highest pin used.
+        */
+       for (i = 0; i < p->func_count; i++) {
+               int pin;
+
+               if (!p->func[i]->pin_count)
+                       continue;
+
+               p->func[i]->pins = devm_kcalloc(p->dev,
+                                               p->func[i]->pin_count,
+                                               sizeof(int),
+                                               GFP_KERNEL);
+               if (!p->func[i]->pins)
+                       return -ENOMEM;
+               for (j = 0; j < p->func[i]->pin_count; j++)
+                       p->func[i]->pins[j] = p->func[i]->pin_first + j;
+
+               pin = p->func[i]->pin_first + p->func[i]->pin_count;
+               if (pin > p->max_pins)
+                       p->max_pins = pin;
+       }
+
+       /* the buffer that tells us which pins are gpio */
+       p->gpio = devm_kcalloc(p->dev, p->max_pins, sizeof(u8), GFP_KERNEL);
+       /* the pads needed to tell pinctrl about our pins */
+       p->pads = devm_kcalloc(p->dev, p->max_pins,
+                              sizeof(struct pinctrl_pin_desc), GFP_KERNEL);
+       if (!p->pads || !p->gpio)
+               return -ENOMEM;
+
+       memset(p->gpio, 1, sizeof(u8) * p->max_pins);
+       for (i = 0; i < p->func_count; i++) {
+               if (!p->func[i]->pin_count)
+                       continue;
+
+               for (j = 0; j < p->func[i]->pin_count; j++)
+                       p->gpio[p->func[i]->pins[j]] = 0;
+       }
+
+       /* pin 0 is always a gpio */
+       p->gpio[0] = 1;
+
+       /* set the pads */
+       for (i = 0; i < p->max_pins; i++) {
+               /* strlen("ioXY") + 1 = 5 */
+               char *name = devm_kzalloc(p->dev, 5, GFP_KERNEL);
+
+               if (!name)
+                       return -ENOMEM;
+               snprintf(name, 5, "io%d", i);
+               p->pads[i].number = i;
+               p->pads[i].name = name;
+       }
+       p->desc->pins = p->pads;
+       p->desc->npins = p->max_pins;
+
+       return 0;
+}
+
+int mtmips_pinctrl_init(struct platform_device *pdev,
+                       struct mtmips_pmx_group *data)
+{
+       struct mtmips_priv *p;
+       struct pinctrl_dev *dev;
+       int err;
+
+       if (!data)
+               return -ENOTSUPP;
+
+       /* setup the private data */
+       p = devm_kzalloc(&pdev->dev, sizeof(struct mtmips_priv), GFP_KERNEL);
+       if (!p)
+               return -ENOMEM;
+
+       p->dev = &pdev->dev;
+       p->desc = &mtmips_pctrl_desc;
+       p->groups = data;
+       platform_set_drvdata(pdev, p);
+
+       /* init the device */
+       err = mtmips_pinctrl_index(p);
+       if (err) {
+               dev_err(&pdev->dev, "failed to load index\n");
+               return err;
+       }
+
+       err = mtmips_pinctrl_pins(p);
+       if (err) {
+               dev_err(&pdev->dev, "failed to load pins\n");
+               return err;
+       }
+       dev = pinctrl_register(p->desc, &pdev->dev, p);
+
+       return PTR_ERR_OR_ZERO(dev);
+}
diff --git a/drivers/pinctrl/mediatek/pinctrl-mtmips.h b/drivers/pinctrl/mediatek/pinctrl-mtmips.h
new file mode 100644 (file)
index 0000000..a7c3dd7
--- /dev/null
@@ -0,0 +1,53 @@
+/* SPDX-License-Identifier: GPL-2.0-only */
+/*
+ *  Copyright (C) 2012 John Crispin <john@phrozen.org>
+ */
+
+#ifndef _PINCTRL_MTMIPS_H__
+#define _PINCTRL_MTMIPS_H__
+
+#define FUNC(name, value, pin_first, pin_count) \
+       { name, value, pin_first, pin_count }
+
+#define GRP(_name, _func, _mask, _shift) \
+       { .name = _name, .mask = _mask, .shift = _shift, \
+         .func = _func, .gpio = _mask, \
+         .func_count = ARRAY_SIZE(_func) }
+
+#define GRP_G(_name, _func, _mask, _gpio, _shift) \
+       { .name = _name, .mask = _mask, .shift = _shift, \
+         .func = _func, .gpio = _gpio, \
+         .func_count = ARRAY_SIZE(_func) }
+
+struct mtmips_pmx_group;
+
+struct mtmips_pmx_func {
+       const char *name;
+       const char value;
+
+       int pin_first;
+       int pin_count;
+       int *pins;
+
+       int *groups;
+       int group_count;
+
+       int enabled;
+};
+
+struct mtmips_pmx_group {
+       const char *name;
+       int enabled;
+
+       const u32 shift;
+       const char mask;
+       const char gpio;
+
+       struct mtmips_pmx_func *func;
+       int func_count;
+};
+
+int mtmips_pinctrl_init(struct platform_device *pdev,
+                       struct mtmips_pmx_group *data);
+
+#endif
diff --git a/drivers/pinctrl/mediatek/pinctrl-rt2880.c b/drivers/pinctrl/mediatek/pinctrl-rt2880.c
new file mode 100644 (file)
index 0000000..e036672
--- /dev/null
@@ -0,0 +1,61 @@
+// SPDX-License-Identifier: GPL-2.0-only
+
+#include <linux/bitops.h>
+#include <linux/module.h>
+#include <linux/platform_device.h>
+#include <linux/of.h>
+#include "pinctrl-mtmips.h"
+
+#define RT2880_GPIO_MODE_I2C           BIT(0)
+#define RT2880_GPIO_MODE_UART0         BIT(1)
+#define RT2880_GPIO_MODE_SPI           BIT(2)
+#define RT2880_GPIO_MODE_UART1         BIT(3)
+#define RT2880_GPIO_MODE_JTAG          BIT(4)
+#define RT2880_GPIO_MODE_MDIO          BIT(5)
+#define RT2880_GPIO_MODE_SDRAM         BIT(6)
+#define RT2880_GPIO_MODE_PCI           BIT(7)
+
+static struct mtmips_pmx_func i2c_grp[] = { FUNC("i2c", 0, 1, 2) };
+static struct mtmips_pmx_func spi_grp[] = { FUNC("spi", 0, 3, 4) };
+static struct mtmips_pmx_func uartlite_grp[] = { FUNC("uartlite", 0, 7, 8) };
+static struct mtmips_pmx_func jtag_grp[] = { FUNC("jtag", 0, 17, 5) };
+static struct mtmips_pmx_func mdio_grp[] = { FUNC("mdio", 0, 22, 2) };
+static struct mtmips_pmx_func sdram_grp[] = { FUNC("sdram", 0, 24, 16) };
+static struct mtmips_pmx_func pci_grp[] = { FUNC("pci", 0, 40, 32) };
+
+static struct mtmips_pmx_group rt2880_pinmux_data_act[] = {
+       GRP("i2c", i2c_grp, 1, RT2880_GPIO_MODE_I2C),
+       GRP("spi", spi_grp, 1, RT2880_GPIO_MODE_SPI),
+       GRP("uartlite", uartlite_grp, 1, RT2880_GPIO_MODE_UART0),
+       GRP("jtag", jtag_grp, 1, RT2880_GPIO_MODE_JTAG),
+       GRP("mdio", mdio_grp, 1, RT2880_GPIO_MODE_MDIO),
+       GRP("sdram", sdram_grp, 1, RT2880_GPIO_MODE_SDRAM),
+       GRP("pci", pci_grp, 1, RT2880_GPIO_MODE_PCI),
+       { 0 }
+};
+
+static int rt2880_pinctrl_probe(struct platform_device *pdev)
+{
+       return mtmips_pinctrl_init(pdev, rt2880_pinmux_data_act);
+}
+
+static const struct of_device_id rt2880_pinctrl_match[] = {
+       { .compatible = "ralink,rt2880-pinctrl" },
+       { .compatible = "ralink,rt2880-pinmux" },
+       {}
+};
+MODULE_DEVICE_TABLE(of, rt2880_pinctrl_match);
+
+static struct platform_driver rt2880_pinctrl_driver = {
+       .probe = rt2880_pinctrl_probe,
+       .driver = {
+               .name = "rt2880-pinctrl",
+               .of_match_table = rt2880_pinctrl_match,
+       },
+};
+
+static int __init rt2880_pinctrl_init(void)
+{
+       return platform_driver_register(&rt2880_pinctrl_driver);
+}
+core_initcall_sync(rt2880_pinctrl_init);
diff --git a/drivers/pinctrl/mediatek/pinctrl-rt305x.c b/drivers/pinctrl/mediatek/pinctrl-rt305x.c
new file mode 100644 (file)
index 0000000..77bd4d1
--- /dev/null
@@ -0,0 +1,140 @@
+// SPDX-License-Identifier: GPL-2.0-only
+
+#include <asm/mach-ralink/ralink_regs.h>
+#include <asm/mach-ralink/rt305x.h>
+#include <linux/module.h>
+#include <linux/platform_device.h>
+#include <linux/of.h>
+#include "pinctrl-mtmips.h"
+
+#define RT305X_GPIO_MODE_UART0_SHIFT   2
+#define RT305X_GPIO_MODE_UART0_MASK    0x7
+#define RT305X_GPIO_MODE_UART0(x)      ((x) << RT305X_GPIO_MODE_UART0_SHIFT)
+#define RT305X_GPIO_MODE_UARTF         0
+#define RT305X_GPIO_MODE_PCM_UARTF     1
+#define RT305X_GPIO_MODE_PCM_I2S       2
+#define RT305X_GPIO_MODE_I2S_UARTF     3
+#define RT305X_GPIO_MODE_PCM_GPIO      4
+#define RT305X_GPIO_MODE_GPIO_UARTF    5
+#define RT305X_GPIO_MODE_GPIO_I2S      6
+#define RT305X_GPIO_MODE_GPIO          7
+
+#define RT305X_GPIO_MODE_I2C           0
+#define RT305X_GPIO_MODE_SPI           1
+#define RT305X_GPIO_MODE_UART1         5
+#define RT305X_GPIO_MODE_JTAG          6
+#define RT305X_GPIO_MODE_MDIO          7
+#define RT305X_GPIO_MODE_SDRAM         8
+#define RT305X_GPIO_MODE_RGMII         9
+#define RT5350_GPIO_MODE_PHY_LED       14
+#define RT5350_GPIO_MODE_SPI_CS1       21
+#define RT3352_GPIO_MODE_LNA           18
+#define RT3352_GPIO_MODE_PA            20
+
+static struct mtmips_pmx_func i2c_grp[] =  { FUNC("i2c", 0, 1, 2) };
+static struct mtmips_pmx_func spi_grp[] = { FUNC("spi", 0, 3, 4) };
+static struct mtmips_pmx_func uartf_grp[] = {
+       FUNC("uartf", RT305X_GPIO_MODE_UARTF, 7, 8),
+       FUNC("pcm uartf", RT305X_GPIO_MODE_PCM_UARTF, 7, 8),
+       FUNC("pcm i2s", RT305X_GPIO_MODE_PCM_I2S, 7, 8),
+       FUNC("i2s uartf", RT305X_GPIO_MODE_I2S_UARTF, 7, 8),
+       FUNC("pcm gpio", RT305X_GPIO_MODE_PCM_GPIO, 11, 4),
+       FUNC("gpio uartf", RT305X_GPIO_MODE_GPIO_UARTF, 7, 4),
+       FUNC("gpio i2s", RT305X_GPIO_MODE_GPIO_I2S, 7, 4),
+};
+static struct mtmips_pmx_func uartlite_grp[] = { FUNC("uartlite", 0, 15, 2) };
+static struct mtmips_pmx_func jtag_grp[] = { FUNC("jtag", 0, 17, 5) };
+static struct mtmips_pmx_func mdio_grp[] = { FUNC("mdio", 0, 22, 2) };
+static struct mtmips_pmx_func rt5350_led_grp[] = { FUNC("led", 0, 22, 5) };
+static struct mtmips_pmx_func rt5350_cs1_grp[] = {
+       FUNC("spi_cs1", 0, 27, 1),
+       FUNC("wdg_cs1", 1, 27, 1),
+};
+static struct mtmips_pmx_func sdram_grp[] = { FUNC("sdram", 0, 24, 16) };
+static struct mtmips_pmx_func rt3352_rgmii_grp[] = {
+       FUNC("rgmii", 0, 24, 12)
+};
+static struct mtmips_pmx_func rgmii_grp[] = { FUNC("rgmii", 0, 40, 12) };
+static struct mtmips_pmx_func rt3352_lna_grp[] = { FUNC("lna", 0, 36, 2) };
+static struct mtmips_pmx_func rt3352_pa_grp[] = { FUNC("pa", 0, 38, 2) };
+static struct mtmips_pmx_func rt3352_led_grp[] = { FUNC("led", 0, 40, 5) };
+static struct mtmips_pmx_func rt3352_cs1_grp[] = {
+       FUNC("spi_cs1", 0, 45, 1),
+       FUNC("wdg_cs1", 1, 45, 1),
+};
+
+static struct mtmips_pmx_group rt3050_pinmux_data[] = {
+       GRP("i2c", i2c_grp, 1, RT305X_GPIO_MODE_I2C),
+       GRP("spi", spi_grp, 1, RT305X_GPIO_MODE_SPI),
+       GRP("uartf", uartf_grp, RT305X_GPIO_MODE_UART0_MASK,
+               RT305X_GPIO_MODE_UART0_SHIFT),
+       GRP("uartlite", uartlite_grp, 1, RT305X_GPIO_MODE_UART1),
+       GRP("jtag", jtag_grp, 1, RT305X_GPIO_MODE_JTAG),
+       GRP("mdio", mdio_grp, 1, RT305X_GPIO_MODE_MDIO),
+       GRP("rgmii", rgmii_grp, 1, RT305X_GPIO_MODE_RGMII),
+       GRP("sdram", sdram_grp, 1, RT305X_GPIO_MODE_SDRAM),
+       { 0 }
+};
+
+static struct mtmips_pmx_group rt3352_pinmux_data[] = {
+       GRP("i2c", i2c_grp, 1, RT305X_GPIO_MODE_I2C),
+       GRP("spi", spi_grp, 1, RT305X_GPIO_MODE_SPI),
+       GRP("uartf", uartf_grp, RT305X_GPIO_MODE_UART0_MASK,
+               RT305X_GPIO_MODE_UART0_SHIFT),
+       GRP("uartlite", uartlite_grp, 1, RT305X_GPIO_MODE_UART1),
+       GRP("jtag", jtag_grp, 1, RT305X_GPIO_MODE_JTAG),
+       GRP("mdio", mdio_grp, 1, RT305X_GPIO_MODE_MDIO),
+       GRP("rgmii", rt3352_rgmii_grp, 1, RT305X_GPIO_MODE_RGMII),
+       GRP("lna", rt3352_lna_grp, 1, RT3352_GPIO_MODE_LNA),
+       GRP("pa", rt3352_pa_grp, 1, RT3352_GPIO_MODE_PA),
+       GRP("led", rt3352_led_grp, 1, RT5350_GPIO_MODE_PHY_LED),
+       GRP("spi_cs1", rt3352_cs1_grp, 2, RT5350_GPIO_MODE_SPI_CS1),
+       { 0 }
+};
+
+static struct mtmips_pmx_group rt5350_pinmux_data[] = {
+       GRP("i2c", i2c_grp, 1, RT305X_GPIO_MODE_I2C),
+       GRP("spi", spi_grp, 1, RT305X_GPIO_MODE_SPI),
+       GRP("uartf", uartf_grp, RT305X_GPIO_MODE_UART0_MASK,
+               RT305X_GPIO_MODE_UART0_SHIFT),
+       GRP("uartlite", uartlite_grp, 1, RT305X_GPIO_MODE_UART1),
+       GRP("jtag", jtag_grp, 1, RT305X_GPIO_MODE_JTAG),
+       GRP("led", rt5350_led_grp, 1, RT5350_GPIO_MODE_PHY_LED),
+       GRP("spi_cs1", rt5350_cs1_grp, 2, RT5350_GPIO_MODE_SPI_CS1),
+       { 0 }
+};
+
+static int rt305x_pinctrl_probe(struct platform_device *pdev)
+{
+       if (soc_is_rt5350())
+               return mtmips_pinctrl_init(pdev, rt5350_pinmux_data);
+       else if (soc_is_rt305x() || soc_is_rt3350())
+               return mtmips_pinctrl_init(pdev, rt3050_pinmux_data);
+       else if (soc_is_rt3352())
+               return mtmips_pinctrl_init(pdev, rt3352_pinmux_data);
+       else
+               return -EINVAL;
+}
+
+static const struct of_device_id rt305x_pinctrl_match[] = {
+       { .compatible = "ralink,rt305x-pinctrl" },
+       { .compatible = "ralink,rt3352-pinctrl" },
+       { .compatible = "ralink,rt5350-pinctrl" },
+       { .compatible = "ralink,rt2880-pinmux" },
+       {}
+};
+MODULE_DEVICE_TABLE(of, rt305x_pinctrl_match);
+
+static struct platform_driver rt305x_pinctrl_driver = {
+       .probe = rt305x_pinctrl_probe,
+       .driver = {
+               .name = "rt305x-pinctrl",
+               .of_match_table = rt305x_pinctrl_match,
+       },
+};
+
+static int __init rt305x_pinctrl_init(void)
+{
+       return platform_driver_register(&rt305x_pinctrl_driver);
+}
+core_initcall_sync(rt305x_pinctrl_init);
diff --git a/drivers/pinctrl/mediatek/pinctrl-rt3883.c b/drivers/pinctrl/mediatek/pinctrl-rt3883.c
new file mode 100644 (file)
index 0000000..eeaf344
--- /dev/null
@@ -0,0 +1,108 @@
+// SPDX-License-Identifier: GPL-2.0-only
+
+#include <linux/module.h>
+#include <linux/platform_device.h>
+#include <linux/of.h>
+#include "pinctrl-mtmips.h"
+
+#define RT3883_GPIO_MODE_UART0_SHIFT   2
+#define RT3883_GPIO_MODE_UART0_MASK    0x7
+#define RT3883_GPIO_MODE_UART0(x)      ((x) << RT3883_GPIO_MODE_UART0_SHIFT)
+#define RT3883_GPIO_MODE_UARTF         0x0
+#define RT3883_GPIO_MODE_PCM_UARTF     0x1
+#define RT3883_GPIO_MODE_PCM_I2S       0x2
+#define RT3883_GPIO_MODE_I2S_UARTF     0x3
+#define RT3883_GPIO_MODE_PCM_GPIO      0x4
+#define RT3883_GPIO_MODE_GPIO_UARTF    0x5
+#define RT3883_GPIO_MODE_GPIO_I2S      0x6
+#define RT3883_GPIO_MODE_GPIO          0x7
+
+#define RT3883_GPIO_MODE_I2C           0
+#define RT3883_GPIO_MODE_SPI           1
+#define RT3883_GPIO_MODE_UART1         5
+#define RT3883_GPIO_MODE_JTAG          6
+#define RT3883_GPIO_MODE_MDIO          7
+#define RT3883_GPIO_MODE_GE1           9
+#define RT3883_GPIO_MODE_GE2           10
+
+#define RT3883_GPIO_MODE_PCI_SHIFT     11
+#define RT3883_GPIO_MODE_PCI_MASK      0x7
+#define RT3883_GPIO_MODE_PCI           (RT3883_GPIO_MODE_PCI_MASK << RT3883_GPIO_MODE_PCI_SHIFT)
+#define RT3883_GPIO_MODE_LNA_A_SHIFT   16
+#define RT3883_GPIO_MODE_LNA_A_MASK    0x3
+#define _RT3883_GPIO_MODE_LNA_A(_x)    ((_x) << RT3883_GPIO_MODE_LNA_A_SHIFT)
+#define RT3883_GPIO_MODE_LNA_A_GPIO    0x3
+#define RT3883_GPIO_MODE_LNA_A         _RT3883_GPIO_MODE_LNA_A(RT3883_GPIO_MODE_LNA_A_MASK)
+#define RT3883_GPIO_MODE_LNA_G_SHIFT   18
+#define RT3883_GPIO_MODE_LNA_G_MASK    0x3
+#define _RT3883_GPIO_MODE_LNA_G(_x)    ((_x) << RT3883_GPIO_MODE_LNA_G_SHIFT)
+#define RT3883_GPIO_MODE_LNA_G_GPIO    0x3
+#define RT3883_GPIO_MODE_LNA_G         _RT3883_GPIO_MODE_LNA_G(RT3883_GPIO_MODE_LNA_G_MASK)
+
+static struct mtmips_pmx_func i2c_grp[] =  { FUNC("i2c", 0, 1, 2) };
+static struct mtmips_pmx_func spi_grp[] = { FUNC("spi", 0, 3, 4) };
+static struct mtmips_pmx_func uartf_grp[] = {
+       FUNC("uartf", RT3883_GPIO_MODE_UARTF, 7, 8),
+       FUNC("pcm uartf", RT3883_GPIO_MODE_PCM_UARTF, 7, 8),
+       FUNC("pcm i2s", RT3883_GPIO_MODE_PCM_I2S, 7, 8),
+       FUNC("i2s uartf", RT3883_GPIO_MODE_I2S_UARTF, 7, 8),
+       FUNC("pcm gpio", RT3883_GPIO_MODE_PCM_GPIO, 11, 4),
+       FUNC("gpio uartf", RT3883_GPIO_MODE_GPIO_UARTF, 7, 4),
+       FUNC("gpio i2s", RT3883_GPIO_MODE_GPIO_I2S, 7, 4),
+};
+static struct mtmips_pmx_func uartlite_grp[] = { FUNC("uartlite", 0, 15, 2) };
+static struct mtmips_pmx_func jtag_grp[] = { FUNC("jtag", 0, 17, 5) };
+static struct mtmips_pmx_func mdio_grp[] = { FUNC("mdio", 0, 22, 2) };
+static struct mtmips_pmx_func lna_a_grp[] = { FUNC("lna a", 0, 32, 3) };
+static struct mtmips_pmx_func lna_g_grp[] = { FUNC("lna g", 0, 35, 3) };
+static struct mtmips_pmx_func pci_grp[] = {
+       FUNC("pci-dev", 0, 40, 32),
+       FUNC("pci-host2", 1, 40, 32),
+       FUNC("pci-host1", 2, 40, 32),
+       FUNC("pci-fnc", 3, 40, 32)
+};
+static struct mtmips_pmx_func ge1_grp[] = { FUNC("ge1", 0, 72, 12) };
+static struct mtmips_pmx_func ge2_grp[] = { FUNC("ge2", 0, 84, 12) };
+
+static struct mtmips_pmx_group rt3883_pinmux_data[] = {
+       GRP("i2c", i2c_grp, 1, RT3883_GPIO_MODE_I2C),
+       GRP("spi", spi_grp, 1, RT3883_GPIO_MODE_SPI),
+       GRP("uartf", uartf_grp, RT3883_GPIO_MODE_UART0_MASK,
+               RT3883_GPIO_MODE_UART0_SHIFT),
+       GRP("uartlite", uartlite_grp, 1, RT3883_GPIO_MODE_UART1),
+       GRP("jtag", jtag_grp, 1, RT3883_GPIO_MODE_JTAG),
+       GRP("mdio", mdio_grp, 1, RT3883_GPIO_MODE_MDIO),
+       GRP("lna a", lna_a_grp, 1, RT3883_GPIO_MODE_LNA_A),
+       GRP("lna g", lna_g_grp, 1, RT3883_GPIO_MODE_LNA_G),
+       GRP("pci", pci_grp, RT3883_GPIO_MODE_PCI_MASK,
+               RT3883_GPIO_MODE_PCI_SHIFT),
+       GRP("ge1", ge1_grp, 1, RT3883_GPIO_MODE_GE1),
+       GRP("ge2", ge2_grp, 1, RT3883_GPIO_MODE_GE2),
+       { 0 }
+};
+
+static int rt3883_pinctrl_probe(struct platform_device *pdev)
+{
+       return mtmips_pinctrl_init(pdev, rt3883_pinmux_data);
+}
+
+static const struct of_device_id rt3883_pinctrl_match[] = {
+       { .compatible = "ralink,rt3883-pinctrl" },
+       { .compatible = "ralink,rt2880-pinmux" },
+       {}
+};
+MODULE_DEVICE_TABLE(of, rt3883_pinctrl_match);
+
+static struct platform_driver rt3883_pinctrl_driver = {
+       .probe = rt3883_pinctrl_probe,
+       .driver = {
+               .name = "rt3883-pinctrl",
+               .of_match_table = rt3883_pinctrl_match,
+       },
+};
+
+static int __init rt3883_pinctrl_init(void)
+{
+       return platform_driver_register(&rt3883_pinctrl_driver);
+}
+core_initcall_sync(rt3883_pinctrl_init);
index 261b46841b9f66c88c106f69ff82baefa4f1d06e..67c6751a6f06db077f578d2ff2728f639450f681 100644 (file)
@@ -23,6 +23,7 @@
 #include <linux/platform_device.h>
 #include <linux/property.h>
 #include <linux/regmap.h>
+#include <linux/seq_file.h>
 #include <linux/slab.h>
 #include <linux/string_helpers.h>
 
@@ -101,7 +102,6 @@ struct armada_37xx_pinctrl {
        const struct armada_37xx_pin_data       *data;
        struct device                   *dev;
        struct gpio_chip                gpio_chip;
-       struct irq_chip                 irq_chip;
        raw_spinlock_t                  irq_lock;
        struct pinctrl_desc             pctl;
        struct pinctrl_dev              *pctl_dev;
@@ -548,6 +548,7 @@ static void armada_37xx_irq_mask(struct irq_data *d)
        val = readl(info->base + reg);
        writel(val & ~d->mask, info->base + reg);
        raw_spin_unlock_irqrestore(&info->irq_lock, flags);
+       gpiochip_disable_irq(chip, irqd_to_hwirq(d));
 }
 
 static void armada_37xx_irq_unmask(struct irq_data *d)
@@ -557,6 +558,7 @@ static void armada_37xx_irq_unmask(struct irq_data *d)
        u32 val, reg = IRQ_EN;
        unsigned long flags;
 
+       gpiochip_enable_irq(chip, irqd_to_hwirq(d));
        armada_37xx_irq_update_reg(&reg, d);
        raw_spin_lock_irqsave(&info->irq_lock, flags);
        val = readl(info->base + reg);
@@ -729,11 +731,30 @@ static unsigned int armada_37xx_irq_startup(struct irq_data *d)
        return 0;
 }
 
+static void armada_37xx_irq_print_chip(struct irq_data *d, struct seq_file *p)
+{
+       struct gpio_chip *chip = irq_data_get_irq_chip_data(d);
+       struct armada_37xx_pinctrl *info = gpiochip_get_data(chip);
+
+       seq_printf(p, info->data->name);
+}
+
+static const struct irq_chip armada_37xx_irqchip = {
+       .irq_ack = armada_37xx_irq_ack,
+       .irq_mask = armada_37xx_irq_mask,
+       .irq_unmask = armada_37xx_irq_unmask,
+       .irq_set_wake = armada_37xx_irq_set_wake,
+       .irq_set_type = armada_37xx_irq_set_type,
+       .irq_startup = armada_37xx_irq_startup,
+       .irq_print_chip = armada_37xx_irq_print_chip,
+       .flags = IRQCHIP_IMMUTABLE,
+       GPIOCHIP_IRQ_RESOURCE_HELPERS,
+};
+
 static int armada_37xx_irqchip_register(struct platform_device *pdev,
                                        struct armada_37xx_pinctrl *info)
 {
        struct gpio_chip *gc = &info->gpio_chip;
-       struct irq_chip *irqchip = &info->irq_chip;
        struct gpio_irq_chip *girq = &gc->irq;
        struct device_node *np = to_of_node(gc->fwnode);
        struct device *dev = &pdev->dev;
@@ -751,14 +772,7 @@ static int armada_37xx_irqchip_register(struct platform_device *pdev,
        if (IS_ERR(info->base))
                return PTR_ERR(info->base);
 
-       irqchip->irq_ack = armada_37xx_irq_ack;
-       irqchip->irq_mask = armada_37xx_irq_mask;
-       irqchip->irq_unmask = armada_37xx_irq_unmask;
-       irqchip->irq_set_wake = armada_37xx_irq_set_wake;
-       irqchip->irq_set_type = armada_37xx_irq_set_type;
-       irqchip->irq_startup = armada_37xx_irq_startup;
-       irqchip->name = info->data->name;
-       girq->chip = irqchip;
+       gpio_irq_chip_set_chip(girq, &armada_37xx_irqchip);
        girq->parent_handler = armada_37xx_irq_handler;
        /*
         * Many interrupts are connected to the parent interrupt
index 852b0d0eb08e09bd520fc97d895c2ad86c961bdc..8fe61b348181876f382bab92985768235539b76f 100644 (file)
@@ -11,6 +11,7 @@ config PINCTRL_WPCM450
        select GPIOLIB
        select GPIO_GENERIC
        select GPIOLIB_IRQCHIP
+       select MFD_SYSCON
        help
          Say Y or M here to enable pin controller and GPIO support for
          the Nuvoton WPCM450 SoC. This is strongly recommended when
index 4e12b3768d6565884aa8f8c82b8d7e9d80990b6e..21e61c2a379881cb15c732da694783aacea8ba46 100644 (file)
@@ -82,7 +82,6 @@ struct npcm7xx_gpio {
        struct gpio_chip        gc;
        int                     irqbase;
        int                     irq;
-       struct irq_chip         irq_chip;
        u32                     pinctrl_id;
        int (*direction_input)(struct gpio_chip *chip, unsigned int offset);
        int (*direction_output)(struct gpio_chip *chip, unsigned int offset,
@@ -240,9 +239,9 @@ static void npcmgpio_irq_handler(struct irq_desc *desc)
 
 static int npcmgpio_set_irq_type(struct irq_data *d, unsigned int type)
 {
-       struct npcm7xx_gpio *bank =
-               gpiochip_get_data(irq_data_get_irq_chip_data(d));
-       unsigned int gpio = BIT(d->hwirq);
+       struct gpio_chip *gc = irq_data_get_irq_chip_data(d);
+       struct npcm7xx_gpio *bank = gpiochip_get_data(gc);
+       unsigned int gpio = BIT(irqd_to_hwirq(d));
 
        dev_dbg(bank->gc.parent, "setirqtype: %u.%u = %u\n", gpio,
                d->irq, type);
@@ -288,9 +287,9 @@ static int npcmgpio_set_irq_type(struct irq_data *d, unsigned int type)
 
 static void npcmgpio_irq_ack(struct irq_data *d)
 {
-       struct npcm7xx_gpio *bank =
-               gpiochip_get_data(irq_data_get_irq_chip_data(d));
-       unsigned int gpio = d->hwirq;
+       struct gpio_chip *gc = irq_data_get_irq_chip_data(d);
+       struct npcm7xx_gpio *bank = gpiochip_get_data(gc);
+       unsigned int gpio = irqd_to_hwirq(d);
 
        dev_dbg(bank->gc.parent, "irq_ack: %u.%u\n", gpio, d->irq);
        iowrite32(BIT(gpio), bank->base + NPCM7XX_GP_N_EVST);
@@ -299,23 +298,25 @@ static void npcmgpio_irq_ack(struct irq_data *d)
 /* Disable GPIO interrupt */
 static void npcmgpio_irq_mask(struct irq_data *d)
 {
-       struct npcm7xx_gpio *bank =
-               gpiochip_get_data(irq_data_get_irq_chip_data(d));
-       unsigned int gpio = d->hwirq;
+       struct gpio_chip *gc = irq_data_get_irq_chip_data(d);
+       struct npcm7xx_gpio *bank = gpiochip_get_data(gc);
+       unsigned int gpio = irqd_to_hwirq(d);
 
        /* Clear events */
        dev_dbg(bank->gc.parent, "irq_mask: %u.%u\n", gpio, d->irq);
        iowrite32(BIT(gpio), bank->base + NPCM7XX_GP_N_EVENC);
+       gpiochip_disable_irq(gc, gpio);
 }
 
 /* Enable GPIO interrupt */
 static void npcmgpio_irq_unmask(struct irq_data *d)
 {
-       struct npcm7xx_gpio *bank =
-               gpiochip_get_data(irq_data_get_irq_chip_data(d));
-       unsigned int gpio = d->hwirq;
+       struct gpio_chip *gc = irq_data_get_irq_chip_data(d);
+       struct npcm7xx_gpio *bank = gpiochip_get_data(gc);
+       unsigned int gpio = irqd_to_hwirq(d);
 
        /* Enable events */
+       gpiochip_enable_irq(gc, gpio);
        dev_dbg(bank->gc.parent, "irq_unmask: %u.%u\n", gpio, d->irq);
        iowrite32(BIT(gpio), bank->base + NPCM7XX_GP_N_EVENS);
 }
@@ -323,7 +324,7 @@ static void npcmgpio_irq_unmask(struct irq_data *d)
 static unsigned int npcmgpio_irq_startup(struct irq_data *d)
 {
        struct gpio_chip *gc = irq_data_get_irq_chip_data(d);
-       unsigned int gpio = d->hwirq;
+       unsigned int gpio = irqd_to_hwirq(d);
 
        /* active-high, input, clear interrupt, enable interrupt */
        dev_dbg(gc->parent, "startup: %u.%u\n", gpio, d->irq);
@@ -341,6 +342,8 @@ static const struct irq_chip npcmgpio_irqchip = {
        .irq_mask = npcmgpio_irq_mask,
        .irq_set_type = npcmgpio_set_irq_type,
        .irq_startup = npcmgpio_irq_startup,
+       .flags = IRQCHIP_IMMUTABLE,
+       GPIOCHIP_IRQ_RESOURCE_HELPERS,
 };
 
 /* pinmux handing in the pinctrl driver*/
@@ -1906,7 +1909,6 @@ static int npcm7xx_gpio_of(struct npcm7xx_pinctrl *pctrl)
                        return -EINVAL;
                }
                pctrl->gpio_bank[id].irq = ret;
-               pctrl->gpio_bank[id].irq_chip = npcmgpio_irqchip;
                pctrl->gpio_bank[id].irqbase = id * NPCM7XX_GPIO_PER_BANK;
                pctrl->gpio_bank[id].pinctrl_id = args.args[0];
                pctrl->gpio_bank[id].gc.base = args.args[1];
@@ -1941,7 +1943,7 @@ static int npcm7xx_gpio_register(struct npcm7xx_pinctrl *pctrl)
                struct gpio_irq_chip *girq;
 
                girq = &pctrl->gpio_bank[id].gc.irq;
-               girq->chip = &pctrl->gpio_bank[id].irq_chip;
+               gpio_irq_chip_set_chip(girq, &npcmgpio_irqchip);
                girq->parent_handler = npcmgpio_irq_handler;
                girq->num_parents = 1;
                girq->parents = devm_kcalloc(pctrl->dev, 1,
diff --git a/drivers/pinctrl/nxp/Kconfig b/drivers/pinctrl/nxp/Kconfig
new file mode 100644 (file)
index 0000000..abca7ef
--- /dev/null
@@ -0,0 +1,15 @@
+# SPDX-License-Identifier: GPL-2.0-only
+config PINCTRL_S32CC
+       bool
+       depends on ARCH_S32 && OF
+       select GENERIC_PINCTRL_GROUPS
+       select GENERIC_PINMUX_FUNCTIONS
+       select GENERIC_PINCONF
+       select REGMAP_MMIO
+
+config PINCTRL_S32G2
+       depends on ARCH_S32 && OF
+       bool "NXP S32G2 pinctrl driver"
+       select PINCTRL_S32CC
+       help
+         Say Y here to enable the pinctrl driver for NXP S32G2 family SoCs
diff --git a/drivers/pinctrl/nxp/Makefile b/drivers/pinctrl/nxp/Makefile
new file mode 100644 (file)
index 0000000..c1cff48
--- /dev/null
@@ -0,0 +1,4 @@
+# SPDX-License-Identifier: GPL-2.0
+# NXP pin control
+obj-$(CONFIG_PINCTRL_S32CC)    += pinctrl-s32cc.o
+obj-$(CONFIG_PINCTRL_S32G2)    += pinctrl-s32g2.o
diff --git a/drivers/pinctrl/nxp/pinctrl-s32.h b/drivers/pinctrl/nxp/pinctrl-s32.h
new file mode 100644 (file)
index 0000000..2f7aecd
--- /dev/null
@@ -0,0 +1,57 @@
+/* SPDX-License-Identifier: GPL-2.0-or-later
+ *
+ * S32 pinmux core definitions
+ *
+ * Copyright 2016-2020, 2022 NXP
+ * Copyright (C) 2022 SUSE LLC
+ * Copyright 2015-2016 Freescale Semiconductor, Inc.
+ * Copyright (C) 2012 Linaro Ltd.
+ */
+
+#ifndef __DRIVERS_PINCTRL_S32_H
+#define __DRIVERS_PINCTRL_S32_H
+
+struct platform_device;
+
+/**
+ * struct s32_pin_group - describes an S32 pin group
+ * @data: generic data describes group name, number of pins, and a pin array in
+       this group.
+ * @pin_sss: an array of source signal select configs paired with pin array.
+ */
+struct s32_pin_group {
+       struct pingroup data;
+       unsigned int *pin_sss;
+};
+
+/**
+ * struct s32_pin_range - pin ID range for each memory region.
+ * @start: start pin ID
+ * @end: end pin ID
+ */
+struct s32_pin_range {
+       unsigned int start;
+       unsigned int end;
+};
+
+struct s32_pinctrl_soc_info {
+       struct device *dev;
+       const struct pinctrl_pin_desc *pins;
+       unsigned int npins;
+       struct s32_pin_group *groups;
+       unsigned int ngroups;
+       struct pinfunction *functions;
+       unsigned int nfunctions;
+       unsigned int grp_index;
+       const struct s32_pin_range *mem_pin_ranges;
+       unsigned int mem_regions;
+};
+
+#define S32_PINCTRL_PIN(pin)   PINCTRL_PIN(pin, #pin)
+#define S32_PIN_RANGE(_start, _end) { .start = _start, .end = _end }
+
+int s32_pinctrl_probe(struct platform_device *pdev,
+                       struct s32_pinctrl_soc_info *info);
+int s32_pinctrl_resume(struct device *dev);
+int s32_pinctrl_suspend(struct device *dev);
+#endif /* __DRIVERS_PINCTRL_S32_H */
diff --git a/drivers/pinctrl/nxp/pinctrl-s32cc.c b/drivers/pinctrl/nxp/pinctrl-s32cc.c
new file mode 100644 (file)
index 0000000..8373468
--- /dev/null
@@ -0,0 +1,973 @@
+// SPDX-License-Identifier: GPL-2.0-or-later
+/*
+ * Core driver for the S32 CC (Common Chassis) pin controller
+ *
+ * Copyright 2017-2022 NXP
+ * Copyright (C) 2022 SUSE LLC
+ * Copyright 2015-2016 Freescale Semiconductor, Inc.
+ */
+
+#include <linux/bitops.h>
+#include <linux/err.h>
+#include <linux/gpio/driver.h>
+#include <linux/init.h>
+#include <linux/io.h>
+#include <linux/module.h>
+#include <linux/of.h>
+#include <linux/of_device.h>
+#include <linux/pinctrl/machine.h>
+#include <linux/pinctrl/pinconf.h>
+#include <linux/pinctrl/pinctrl.h>
+#include <linux/pinctrl/pinmux.h>
+#include <linux/regmap.h>
+#include <linux/seq_file.h>
+#include <linux/slab.h>
+
+#include "../core.h"
+#include "../pinconf.h"
+#include "../pinctrl-utils.h"
+#include "pinctrl-s32.h"
+
+#define S32_PIN_ID_SHIFT       4
+#define S32_PIN_ID_MASK                GENMASK(31, S32_PIN_ID_SHIFT)
+
+#define S32_MSCR_SSS_MASK      GENMASK(2, 0)
+#define S32_MSCR_PUS           BIT(12)
+#define S32_MSCR_PUE           BIT(13)
+#define S32_MSCR_SRE(X)                (((X) & GENMASK(3, 0)) << 14)
+#define S32_MSCR_IBE           BIT(19)
+#define S32_MSCR_ODE           BIT(20)
+#define S32_MSCR_OBE           BIT(21)
+
+static struct regmap_config s32_regmap_config = {
+       .reg_bits = 32,
+       .val_bits = 32,
+       .reg_stride = 4,
+};
+
+static u32 get_pin_no(u32 pinmux)
+{
+       return (pinmux & S32_PIN_ID_MASK) >> S32_PIN_ID_SHIFT;
+}
+
+static u32 get_pin_func(u32 pinmux)
+{
+       return pinmux & GENMASK(3, 0);
+}
+
+struct s32_pinctrl_mem_region {
+       struct regmap *map;
+       const struct s32_pin_range *pin_range;
+       char name[8];
+};
+
+/*
+ * Holds pin configuration for GPIO's.
+ * @pin_id: Pin ID for this GPIO
+ * @config: Pin settings
+ * @list: Linked list entry for each gpio pin
+ */
+struct gpio_pin_config {
+       unsigned int pin_id;
+       unsigned int config;
+       struct list_head list;
+};
+
+/*
+ * Pad config save/restore for power suspend/resume.
+ */
+struct s32_pinctrl_context {
+       unsigned int *pads;
+};
+
+/*
+ * @dev: a pointer back to containing device
+ * @pctl: a pointer to the pinctrl device structure
+ * @regions: reserved memory regions with start/end pin
+ * @info: structure containing information about the pin
+ * @gpio_configs: Saved configurations for GPIO pins
+ * @gpiop_configs_lock: lock for the `gpio_configs` list
+ * @s32_pinctrl_context: Configuration saved over system sleep
+ */
+struct s32_pinctrl {
+       struct device *dev;
+       struct pinctrl_dev *pctl;
+       struct s32_pinctrl_mem_region *regions;
+       struct s32_pinctrl_soc_info *info;
+       struct list_head gpio_configs;
+       spinlock_t gpio_configs_lock;
+#ifdef CONFIG_PM_SLEEP
+       struct s32_pinctrl_context saved_context;
+#endif
+};
+
+static struct s32_pinctrl_mem_region *
+s32_get_region(struct pinctrl_dev *pctldev, unsigned int pin)
+{
+       struct s32_pinctrl *ipctl = pinctrl_dev_get_drvdata(pctldev);
+       const struct s32_pin_range *pin_range;
+       unsigned int mem_regions = ipctl->info->mem_regions;
+       unsigned int i;
+
+       for (i = 0; i < mem_regions; i++) {
+               pin_range = ipctl->regions[i].pin_range;
+               if (pin >= pin_range->start && pin <= pin_range->end)
+                       return &ipctl->regions[i];
+       }
+
+       return NULL;
+}
+
+static inline int s32_check_pin(struct pinctrl_dev *pctldev,
+                               unsigned int pin)
+{
+       return s32_get_region(pctldev, pin) ? 0 : -EINVAL;
+}
+
+static inline int s32_regmap_read(struct pinctrl_dev *pctldev,
+                          unsigned int pin, unsigned int *val)
+{
+       struct s32_pinctrl_mem_region *region;
+       unsigned int offset;
+
+       region = s32_get_region(pctldev, pin);
+       if (!region)
+               return -EINVAL;
+
+       offset = (pin - region->pin_range->start) *
+                       regmap_get_reg_stride(region->map);
+
+       return regmap_read(region->map, offset, val);
+}
+
+static inline int s32_regmap_write(struct pinctrl_dev *pctldev,
+                           unsigned int pin,
+                           unsigned int val)
+{
+       struct s32_pinctrl_mem_region *region;
+       unsigned int offset;
+
+       region = s32_get_region(pctldev, pin);
+       if (!region)
+               return -EINVAL;
+
+       offset = (pin - region->pin_range->start) *
+                       regmap_get_reg_stride(region->map);
+
+       return regmap_write(region->map, offset, val);
+
+}
+
+static inline int s32_regmap_update(struct pinctrl_dev *pctldev, unsigned int pin,
+                            unsigned int mask, unsigned int val)
+{
+       struct s32_pinctrl_mem_region *region;
+       unsigned int offset;
+
+       region = s32_get_region(pctldev, pin);
+       if (!region)
+               return -EINVAL;
+
+       offset = (pin - region->pin_range->start) *
+                       regmap_get_reg_stride(region->map);
+
+       return regmap_update_bits(region->map, offset, mask, val);
+}
+
+static int s32_get_groups_count(struct pinctrl_dev *pctldev)
+{
+       struct s32_pinctrl *ipctl = pinctrl_dev_get_drvdata(pctldev);
+       const struct s32_pinctrl_soc_info *info = ipctl->info;
+
+       return info->ngroups;
+}
+
+static const char *s32_get_group_name(struct pinctrl_dev *pctldev,
+                                     unsigned int selector)
+{
+       struct s32_pinctrl *ipctl = pinctrl_dev_get_drvdata(pctldev);
+       const struct s32_pinctrl_soc_info *info = ipctl->info;
+
+       return info->groups[selector].data.name;
+}
+
+static int s32_get_group_pins(struct pinctrl_dev *pctldev,
+                             unsigned int selector, const unsigned int **pins,
+                             unsigned int *npins)
+{
+       struct s32_pinctrl *ipctl = pinctrl_dev_get_drvdata(pctldev);
+       const struct s32_pinctrl_soc_info *info = ipctl->info;
+
+       *pins = info->groups[selector].data.pins;
+       *npins = info->groups[selector].data.npins;
+
+       return 0;
+}
+
+static void s32_pin_dbg_show(struct pinctrl_dev *pctldev, struct seq_file *s,
+                            unsigned int offset)
+{
+       seq_printf(s, "%s", dev_name(pctldev->dev));
+}
+
+static int s32_dt_group_node_to_map(struct pinctrl_dev *pctldev,
+                                   struct device_node *np,
+                                   struct pinctrl_map **map,
+                                   unsigned int *reserved_maps,
+                                   unsigned int *num_maps,
+                                   const char *func_name)
+{
+       struct s32_pinctrl *ipctl = pinctrl_dev_get_drvdata(pctldev);
+       struct device *dev = ipctl->dev;
+       unsigned long *cfgs = NULL;
+       unsigned int n_cfgs, reserve = 1;
+       int n_pins, ret;
+
+       n_pins = of_property_count_elems_of_size(np, "pinmux", sizeof(u32));
+       if (n_pins < 0) {
+               dev_warn(dev, "Can't find 'pinmux' property in node %pOFn\n", np);
+       } else if (!n_pins) {
+               return -EINVAL;
+       }
+
+       ret = pinconf_generic_parse_dt_config(np, pctldev, &cfgs, &n_cfgs);
+       if (ret) {
+               dev_err(dev, "%pOF: could not parse node property\n", np);
+               return ret;
+       }
+
+       if (n_cfgs)
+               reserve++;
+
+       ret = pinctrl_utils_reserve_map(pctldev, map, reserved_maps, num_maps,
+                                       reserve);
+       if (ret < 0)
+               goto free_cfgs;
+
+       ret = pinctrl_utils_add_map_mux(pctldev, map, reserved_maps, num_maps,
+                                       np->name, func_name);
+       if (ret < 0)
+               goto free_cfgs;
+
+       if (n_cfgs) {
+               ret = pinctrl_utils_add_map_configs(pctldev, map, reserved_maps,
+                                                   num_maps, np->name, cfgs, n_cfgs,
+                                                   PIN_MAP_TYPE_CONFIGS_GROUP);
+               if (ret < 0)
+                       goto free_cfgs;
+       }
+
+free_cfgs:
+       kfree(cfgs);
+       return ret;
+}
+
+static int s32_dt_node_to_map(struct pinctrl_dev *pctldev,
+                             struct device_node *np_config,
+                             struct pinctrl_map **map,
+                             unsigned int *num_maps)
+{
+       unsigned int reserved_maps;
+       struct device_node *np;
+       int ret = 0;
+
+       reserved_maps = 0;
+       *map = NULL;
+       *num_maps = 0;
+
+       for_each_available_child_of_node(np_config, np) {
+               ret = s32_dt_group_node_to_map(pctldev, np, map,
+                                              &reserved_maps, num_maps,
+                                              np_config->name);
+               if (ret < 0)
+                       break;
+       }
+
+       if (ret)
+               pinctrl_utils_free_map(pctldev, *map, *num_maps);
+
+       return ret;
+
+}
+
+static const struct pinctrl_ops s32_pctrl_ops = {
+       .get_groups_count = s32_get_groups_count,
+       .get_group_name = s32_get_group_name,
+       .get_group_pins = s32_get_group_pins,
+       .pin_dbg_show = s32_pin_dbg_show,
+       .dt_node_to_map = s32_dt_node_to_map,
+       .dt_free_map = pinctrl_utils_free_map,
+};
+
+static int s32_pmx_set(struct pinctrl_dev *pctldev, unsigned int selector,
+                      unsigned int group)
+{
+       struct s32_pinctrl *ipctl = pinctrl_dev_get_drvdata(pctldev);
+       const struct s32_pinctrl_soc_info *info = ipctl->info;
+       int i, ret;
+       struct s32_pin_group *grp;
+
+       /*
+        * Configure the mux mode for each pin in the group for a specific
+        * function.
+        */
+       grp = &info->groups[group];
+
+       dev_dbg(ipctl->dev, "set mux for function %s group %s\n",
+               info->functions[selector].name, grp->data.name);
+
+       /* Check beforehand so we don't have a partial config. */
+       for (i = 0; i < grp->data.npins; i++) {
+               if (s32_check_pin(pctldev, grp->data.pins[i]) != 0) {
+                       dev_err(info->dev, "invalid pin: %u in group: %u\n",
+                               grp->data.pins[i], group);
+                       return -EINVAL;
+               }
+       }
+
+       for (i = 0, ret = 0; i < grp->data.npins && !ret; i++) {
+               ret = s32_regmap_update(pctldev, grp->data.pins[i],
+                                       S32_MSCR_SSS_MASK, grp->pin_sss[i]);
+               if (ret) {
+                       dev_err(info->dev, "Failed to set pin %u\n",
+                               grp->data.pins[i]);
+                       return ret;
+               }
+       }
+
+       return 0;
+}
+
+static int s32_pmx_get_funcs_count(struct pinctrl_dev *pctldev)
+{
+       struct s32_pinctrl *ipctl = pinctrl_dev_get_drvdata(pctldev);
+       const struct s32_pinctrl_soc_info *info = ipctl->info;
+
+       return info->nfunctions;
+}
+
+static const char *s32_pmx_get_func_name(struct pinctrl_dev *pctldev,
+                                        unsigned int selector)
+{
+       struct s32_pinctrl *ipctl = pinctrl_dev_get_drvdata(pctldev);
+       const struct s32_pinctrl_soc_info *info = ipctl->info;
+
+       return info->functions[selector].name;
+}
+
+static int s32_pmx_get_groups(struct pinctrl_dev *pctldev,
+                             unsigned int selector,
+                             const char * const **groups,
+                             unsigned int * const num_groups)
+{
+       struct s32_pinctrl *ipctl = pinctrl_dev_get_drvdata(pctldev);
+       const struct s32_pinctrl_soc_info *info = ipctl->info;
+
+       *groups = info->functions[selector].groups;
+       *num_groups = info->functions[selector].ngroups;
+
+       return 0;
+}
+
+static int s32_pmx_gpio_request_enable(struct pinctrl_dev *pctldev,
+                                      struct pinctrl_gpio_range *range,
+                                      unsigned int offset)
+{
+       struct s32_pinctrl *ipctl = pinctrl_dev_get_drvdata(pctldev);
+       struct gpio_pin_config *gpio_pin;
+       unsigned int config;
+       unsigned long flags;
+       int ret;
+
+       ret = s32_regmap_read(pctldev, offset, &config);
+       if (ret)
+               return ret;
+
+       /* Save current configuration */
+       gpio_pin = kmalloc(sizeof(*gpio_pin), GFP_KERNEL);
+       if (!gpio_pin)
+               return -ENOMEM;
+
+       gpio_pin->pin_id = offset;
+       gpio_pin->config = config;
+
+       spin_lock_irqsave(&ipctl->gpio_configs_lock, flags);
+       list_add(&gpio_pin->list, &ipctl->gpio_configs);
+       spin_unlock_irqrestore(&ipctl->gpio_configs_lock, flags);
+
+       /* GPIO pin means SSS = 0 */
+       config &= ~S32_MSCR_SSS_MASK;
+
+       return s32_regmap_write(pctldev, offset, config);
+}
+
+static void s32_pmx_gpio_disable_free(struct pinctrl_dev *pctldev,
+                                     struct pinctrl_gpio_range *range,
+                                     unsigned int offset)
+{
+       struct s32_pinctrl *ipctl = pinctrl_dev_get_drvdata(pctldev);
+       struct gpio_pin_config *gpio_pin, *tmp;
+       unsigned long flags;
+       int ret;
+
+       spin_lock_irqsave(&ipctl->gpio_configs_lock, flags);
+
+       list_for_each_entry_safe(gpio_pin, tmp, &ipctl->gpio_configs, list) {
+               if (gpio_pin->pin_id == offset) {
+                       ret = s32_regmap_write(pctldev, gpio_pin->pin_id,
+                                                gpio_pin->config);
+                       if (ret != 0)
+                               goto unlock;
+
+                       list_del(&gpio_pin->list);
+                       kfree(gpio_pin);
+                       break;
+               }
+       }
+
+unlock:
+       spin_unlock_irqrestore(&ipctl->gpio_configs_lock, flags);
+}
+
+static int s32_pmx_gpio_set_direction(struct pinctrl_dev *pctldev,
+                                     struct pinctrl_gpio_range *range,
+                                     unsigned int offset,
+                                     bool input)
+{
+       unsigned int config;
+       unsigned int mask = S32_MSCR_IBE | S32_MSCR_OBE;
+
+       if (input) {
+               /* Disable output buffer and enable input buffer */
+               config = S32_MSCR_IBE;
+       } else {
+               /* Disable input buffer and enable output buffer */
+               config = S32_MSCR_OBE;
+       }
+
+       return s32_regmap_update(pctldev, offset, mask, config);
+}
+
+static const struct pinmux_ops s32_pmx_ops = {
+       .get_functions_count = s32_pmx_get_funcs_count,
+       .get_function_name = s32_pmx_get_func_name,
+       .get_function_groups = s32_pmx_get_groups,
+       .set_mux = s32_pmx_set,
+       .gpio_request_enable = s32_pmx_gpio_request_enable,
+       .gpio_disable_free = s32_pmx_gpio_disable_free,
+       .gpio_set_direction = s32_pmx_gpio_set_direction,
+};
+
+/* Set the reserved elements as -1 */
+static const int support_slew[] = {208, -1, -1, -1, 166, 150, 133, 83};
+
+static int s32_get_slew_regval(int arg)
+{
+       unsigned int i;
+
+       /* Translate a real slew rate (MHz) to a register value */
+       for (i = 0; i < ARRAY_SIZE(support_slew); i++) {
+               if (arg == support_slew[i])
+                       return i;
+       }
+
+       return -EINVAL;
+}
+
+static inline void s32_pin_set_pull(enum pin_config_param param,
+                                  unsigned int *mask, unsigned int *config)
+{
+       switch (param) {
+       case PIN_CONFIG_BIAS_DISABLE:
+       case PIN_CONFIG_BIAS_HIGH_IMPEDANCE:
+               *config &= ~(S32_MSCR_PUS | S32_MSCR_PUE);
+               break;
+       case PIN_CONFIG_BIAS_PULL_UP:
+               *config |= S32_MSCR_PUS | S32_MSCR_PUE;
+               break;
+       case PIN_CONFIG_BIAS_PULL_DOWN:
+               *config &= ~S32_MSCR_PUS;
+               *config |= S32_MSCR_PUE;
+               break;
+       default:
+               return;
+       }
+
+       *mask |= S32_MSCR_PUS | S32_MSCR_PUE;
+}
+
+static int s32_parse_pincfg(unsigned long pincfg, unsigned int *mask,
+                           unsigned int *config)
+{
+       enum pin_config_param param;
+       u32 arg;
+       int ret;
+
+       param = pinconf_to_config_param(pincfg);
+       arg = pinconf_to_config_argument(pincfg);
+
+       switch (param) {
+       /* All pins are persistent over suspend */
+       case PIN_CONFIG_PERSIST_STATE:
+               return 0;
+       case PIN_CONFIG_DRIVE_OPEN_DRAIN:
+               *config |= S32_MSCR_ODE;
+               *mask |= S32_MSCR_ODE;
+               break;
+       case PIN_CONFIG_OUTPUT_ENABLE:
+               if (arg)
+                       *config |= S32_MSCR_OBE;
+               else
+                       *config &= ~S32_MSCR_OBE;
+               *mask |= S32_MSCR_OBE;
+               break;
+       case PIN_CONFIG_INPUT_ENABLE:
+               if (arg)
+                       *config |= S32_MSCR_IBE;
+               else
+                       *config &= ~S32_MSCR_IBE;
+               *mask |= S32_MSCR_IBE;
+               break;
+       case PIN_CONFIG_SLEW_RATE:
+               ret = s32_get_slew_regval(arg);
+               if (ret < 0)
+                       return ret;
+               *config |= S32_MSCR_SRE((u32)ret);
+               *mask |= S32_MSCR_SRE(~0);
+               break;
+       case PIN_CONFIG_BIAS_DISABLE:
+       case PIN_CONFIG_BIAS_PULL_UP:
+       case PIN_CONFIG_BIAS_PULL_DOWN:
+               s32_pin_set_pull(param, mask, config);
+               break;
+       case PIN_CONFIG_BIAS_HIGH_IMPEDANCE:
+               *config &= ~(S32_MSCR_ODE | S32_MSCR_OBE | S32_MSCR_IBE);
+               *mask |= S32_MSCR_ODE | S32_MSCR_OBE | S32_MSCR_IBE;
+               s32_pin_set_pull(param, mask, config);
+               break;
+       default:
+               return -EOPNOTSUPP;
+       }
+
+       return 0;
+}
+
+static int s32_pinconf_mscr_update(struct pinctrl_dev *pctldev,
+                                  unsigned int pin_id,
+                                  unsigned long *configs,
+                                  unsigned int num_configs)
+{
+       struct s32_pinctrl *ipctl = pinctrl_dev_get_drvdata(pctldev);
+       unsigned int config = 0, mask = 0;
+       int i, ret;
+
+       ret = s32_check_pin(pctldev, pin_id);
+       if (ret)
+               return ret;
+
+       dev_dbg(ipctl->dev, "pinconf set pin %s with %u configs\n",
+               pin_get_name(pctldev, pin_id), num_configs);
+
+       for (i = 0; i < num_configs; i++) {
+               ret = s32_parse_pincfg(configs[i], &mask, &config);
+               if (ret)
+                       return ret;
+       }
+
+       if (!config && !mask)
+               return 0;
+
+       dev_dbg(ipctl->dev, "update: pin %u cfg 0x%x\n", pin_id, config);
+
+       return s32_regmap_update(pctldev, pin_id, mask, config);
+}
+
+static int s32_pinconf_get(struct pinctrl_dev *pctldev,
+                          unsigned int pin_id,
+                          unsigned long *config)
+{
+       return s32_regmap_read(pctldev, pin_id, (unsigned int *)config);
+}
+
+static int s32_pinconf_set(struct pinctrl_dev *pctldev,
+                          unsigned int pin_id, unsigned long *configs,
+                          unsigned int num_configs)
+{
+       return s32_pinconf_mscr_update(pctldev, pin_id, configs,
+                                      num_configs);
+}
+
+static int s32_pconf_group_set(struct pinctrl_dev *pctldev, unsigned int selector,
+                              unsigned long *configs, unsigned int num_configs)
+{
+       struct s32_pinctrl *ipctl = pinctrl_dev_get_drvdata(pctldev);
+       const struct s32_pinctrl_soc_info *info = ipctl->info;
+       struct s32_pin_group *grp;
+       int i, ret;
+
+       grp = &info->groups[selector];
+       for (i = 0; i < grp->data.npins; i++) {
+               ret = s32_pinconf_mscr_update(pctldev, grp->data.pins[i],
+                                             configs, num_configs);
+               if (ret)
+                       return ret;
+       }
+
+       return 0;
+}
+
+static void s32_pinconf_dbg_show(struct pinctrl_dev *pctldev,
+                                struct seq_file *s, unsigned int pin_id)
+{
+       unsigned int config;
+       int ret;
+
+       ret = s32_regmap_read(pctldev, pin_id, &config);
+       if (ret)
+               return;
+
+       seq_printf(s, "0x%x", config);
+}
+
+static void s32_pinconf_group_dbg_show(struct pinctrl_dev *pctldev,
+                                      struct seq_file *s, unsigned int selector)
+{
+       struct s32_pinctrl *ipctl = pinctrl_dev_get_drvdata(pctldev);
+       const struct s32_pinctrl_soc_info *info = ipctl->info;
+       struct s32_pin_group *grp;
+       unsigned int config;
+       const char *name;
+       int i, ret;
+
+       seq_puts(s, "\n");
+       grp = &info->groups[selector];
+       for (i = 0; i < grp->data.npins; i++) {
+               name = pin_get_name(pctldev, grp->data.pins[i]);
+               ret = s32_regmap_read(pctldev, grp->data.pins[i], &config);
+               if (ret)
+                       return;
+               seq_printf(s, "%s: 0x%x\n", name, config);
+       }
+}
+
+static const struct pinconf_ops s32_pinconf_ops = {
+       .pin_config_get = s32_pinconf_get,
+       .pin_config_set = s32_pinconf_set,
+       .pin_config_group_set = s32_pconf_group_set,
+       .pin_config_dbg_show = s32_pinconf_dbg_show,
+       .pin_config_group_dbg_show = s32_pinconf_group_dbg_show,
+};
+
+#ifdef CONFIG_PM_SLEEP
+static bool s32_pinctrl_should_save(struct s32_pinctrl *ipctl,
+                                   unsigned int pin)
+{
+       const struct pin_desc *pd = pin_desc_get(ipctl->pctl, pin);
+
+       if (!pd)
+               return false;
+
+       /*
+        * Only restore the pin if it is actually in use by the kernel (or
+        * by userspace).
+        */
+       if (pd->mux_owner || pd->gpio_owner)
+               return true;
+
+       return false;
+}
+
+int s32_pinctrl_suspend(struct device *dev)
+{
+       struct platform_device *pdev = to_platform_device(dev);
+       struct s32_pinctrl *ipctl = platform_get_drvdata(pdev);
+       const struct pinctrl_pin_desc *pin;
+       const struct s32_pinctrl_soc_info *info = ipctl->info;
+       struct s32_pinctrl_context *saved_context = &ipctl->saved_context;
+       int i;
+       int ret;
+       unsigned int config;
+
+       for (i = 0; i < info->npins; i++) {
+               pin = &info->pins[i];
+
+               if (!s32_pinctrl_should_save(ipctl, pin->number))
+                       continue;
+
+               ret = s32_regmap_read(ipctl->pctl, pin->number, &config);
+               if (ret)
+                       return -EINVAL;
+
+               saved_context->pads[i] = config;
+       }
+
+       return 0;
+}
+
+int s32_pinctrl_resume(struct device *dev)
+{
+       struct platform_device *pdev = to_platform_device(dev);
+       struct s32_pinctrl *ipctl = platform_get_drvdata(pdev);
+       const struct s32_pinctrl_soc_info *info = ipctl->info;
+       const struct pinctrl_pin_desc *pin;
+       struct s32_pinctrl_context *saved_context = &ipctl->saved_context;
+       int ret, i;
+
+       for (i = 0; i < info->npins; i++) {
+               pin = &info->pins[i];
+
+               if (!s32_pinctrl_should_save(ipctl, pin->number))
+                       continue;
+
+               ret = s32_regmap_write(ipctl->pctl, pin->number,
+                                        saved_context->pads[i]);
+               if (ret)
+                       return ret;
+       }
+
+       return 0;
+}
+#endif
+
+static int s32_pinctrl_parse_groups(struct device_node *np,
+                                    struct s32_pin_group *grp,
+                                    struct s32_pinctrl_soc_info *info)
+{
+       const __be32 *p;
+       struct device *dev;
+       struct property *prop;
+       unsigned int *pins, *sss;
+       int i, npins;
+       u32 pinmux;
+
+       dev = info->dev;
+
+       dev_dbg(dev, "group: %pOFn\n", np);
+
+       /* Initialise group */
+       grp->data.name = np->name;
+
+       npins = of_property_count_elems_of_size(np, "pinmux", sizeof(u32));
+       if (npins < 0) {
+               dev_err(dev, "Failed to read 'pinmux' property in node %s.\n",
+                       grp->data.name);
+               return -EINVAL;
+       }
+       if (!npins) {
+               dev_err(dev, "The group %s has no pins.\n", grp->data.name);
+               return -EINVAL;
+       }
+
+       grp->data.npins = npins;
+
+       pins = devm_kcalloc(info->dev, npins, sizeof(*pins), GFP_KERNEL);
+       sss = devm_kcalloc(info->dev, npins, sizeof(*sss), GFP_KERNEL);
+       if (!pins || !sss)
+               return -ENOMEM;
+
+       i = 0;
+       of_property_for_each_u32(np, "pinmux", prop, p, pinmux) {
+               pins[i] = get_pin_no(pinmux);
+               sss[i] = get_pin_func(pinmux);
+
+               dev_dbg(info->dev, "pin: 0x%x, sss: 0x%x", pins[i], sss[i]);
+               i++;
+       }
+
+       grp->data.pins = pins;
+       grp->pin_sss = sss;
+
+       return 0;
+}
+
+static int s32_pinctrl_parse_functions(struct device_node *np,
+                                       struct s32_pinctrl_soc_info *info,
+                                       u32 index)
+{
+       struct device_node *child;
+       struct pinfunction *func;
+       struct s32_pin_group *grp;
+       const char **groups;
+       u32 i = 0;
+       int ret = 0;
+
+       dev_dbg(info->dev, "parse function(%u): %pOFn\n", index, np);
+
+       func = &info->functions[index];
+
+       /* Initialise function */
+       func->name = np->name;
+       func->ngroups = of_get_child_count(np);
+       if (func->ngroups == 0) {
+               dev_err(info->dev, "no groups defined in %pOF\n", np);
+               return -EINVAL;
+       }
+
+       groups = devm_kcalloc(info->dev, func->ngroups,
+                                   sizeof(*func->groups), GFP_KERNEL);
+       if (!groups)
+               return -ENOMEM;
+
+       for_each_child_of_node(np, child) {
+               groups[i] = child->name;
+               grp = &info->groups[info->grp_index++];
+               ret = s32_pinctrl_parse_groups(child, grp, info);
+               if (ret)
+                       return ret;
+               i++;
+       }
+
+       func->groups = groups;
+
+       return 0;
+}
+
+static int s32_pinctrl_probe_dt(struct platform_device *pdev,
+                               struct s32_pinctrl *ipctl)
+{
+       struct s32_pinctrl_soc_info *info = ipctl->info;
+       struct device_node *np = pdev->dev.of_node;
+       struct device_node *child;
+       struct resource *res;
+       struct regmap *map;
+       void __iomem *base;
+       int mem_regions = info->mem_regions;
+       int ret;
+       u32 nfuncs = 0;
+       u32 i = 0;
+
+       if (!np)
+               return -ENODEV;
+
+       if (mem_regions == 0) {
+               dev_err(&pdev->dev, "mem_regions is 0\n");
+               return -EINVAL;
+       }
+
+       ipctl->regions = devm_kcalloc(&pdev->dev, mem_regions,
+                                     sizeof(*ipctl->regions), GFP_KERNEL);
+       if (!ipctl->regions)
+               return -ENOMEM;
+
+       for (i = 0; i < mem_regions; i++) {
+               base = devm_platform_get_and_ioremap_resource(pdev, i, &res);
+               if (IS_ERR(base))
+                       return PTR_ERR(base);
+
+               snprintf(ipctl->regions[i].name,
+                        sizeof(ipctl->regions[i].name), "map%u", i);
+
+               s32_regmap_config.name = ipctl->regions[i].name;
+               s32_regmap_config.max_register = resource_size(res) -
+                                                s32_regmap_config.reg_stride;
+
+               map = devm_regmap_init_mmio(&pdev->dev, base,
+                                               &s32_regmap_config);
+               if (IS_ERR(map)) {
+                       dev_err(&pdev->dev, "Failed to init regmap[%u]\n", i);
+                       return PTR_ERR(map);
+               }
+
+               ipctl->regions[i].map = map;
+               ipctl->regions[i].pin_range = &info->mem_pin_ranges[i];
+       }
+
+       nfuncs = of_get_child_count(np);
+       if (nfuncs <= 0) {
+               dev_err(&pdev->dev, "no functions defined\n");
+               return -EINVAL;
+       }
+
+       info->nfunctions = nfuncs;
+       info->functions = devm_kcalloc(&pdev->dev, nfuncs,
+                                      sizeof(*info->functions), GFP_KERNEL);
+       if (!info->functions)
+               return -ENOMEM;
+
+       info->ngroups = 0;
+       for_each_child_of_node(np, child)
+               info->ngroups += of_get_child_count(child);
+
+       info->groups = devm_kcalloc(&pdev->dev, info->ngroups,
+                                   sizeof(*info->groups), GFP_KERNEL);
+       if (!info->groups)
+               return -ENOMEM;
+
+       i = 0;
+       for_each_child_of_node(np, child) {
+               ret = s32_pinctrl_parse_functions(child, info, i++);
+               if (ret)
+                       return ret;
+       }
+
+       return 0;
+}
+
+int s32_pinctrl_probe(struct platform_device *pdev,
+                     struct s32_pinctrl_soc_info *info)
+{
+       struct s32_pinctrl *ipctl;
+       int ret;
+       struct pinctrl_desc *s32_pinctrl_desc;
+#ifdef CONFIG_PM_SLEEP
+       struct s32_pinctrl_context *saved_context;
+#endif
+
+       if (!info || !info->pins || !info->npins) {
+               dev_err(&pdev->dev, "wrong pinctrl info\n");
+               return -EINVAL;
+       }
+
+       info->dev = &pdev->dev;
+
+       /* Create state holders etc for this driver */
+       ipctl = devm_kzalloc(&pdev->dev, sizeof(*ipctl), GFP_KERNEL);
+       if (!ipctl)
+               return -ENOMEM;
+
+       ipctl->info = info;
+       ipctl->dev = info->dev;
+       platform_set_drvdata(pdev, ipctl);
+
+       INIT_LIST_HEAD(&ipctl->gpio_configs);
+       spin_lock_init(&ipctl->gpio_configs_lock);
+
+       s32_pinctrl_desc =
+               devm_kmalloc(&pdev->dev, sizeof(*s32_pinctrl_desc), GFP_KERNEL);
+       if (!s32_pinctrl_desc)
+               return -ENOMEM;
+
+       s32_pinctrl_desc->name = dev_name(&pdev->dev);
+       s32_pinctrl_desc->pins = info->pins;
+       s32_pinctrl_desc->npins = info->npins;
+       s32_pinctrl_desc->pctlops = &s32_pctrl_ops;
+       s32_pinctrl_desc->pmxops = &s32_pmx_ops;
+       s32_pinctrl_desc->confops = &s32_pinconf_ops;
+       s32_pinctrl_desc->owner = THIS_MODULE;
+
+       ret = s32_pinctrl_probe_dt(pdev, ipctl);
+       if (ret) {
+               dev_err(&pdev->dev, "fail to probe dt properties\n");
+               return ret;
+       }
+
+       ipctl->pctl = devm_pinctrl_register(&pdev->dev, s32_pinctrl_desc,
+                                           ipctl);
+       if (IS_ERR(ipctl->pctl))
+               return dev_err_probe(&pdev->dev, PTR_ERR(ipctl->pctl),
+                                    "could not register s32 pinctrl driver\n");
+
+#ifdef CONFIG_PM_SLEEP
+       saved_context = &ipctl->saved_context;
+       saved_context->pads =
+               devm_kcalloc(&pdev->dev, info->npins,
+                            sizeof(*saved_context->pads),
+                            GFP_KERNEL);
+       if (!saved_context->pads)
+               return -ENOMEM;
+#endif
+
+       dev_info(&pdev->dev, "initialized s32 pinctrl driver\n");
+
+       return 0;
+}
diff --git a/drivers/pinctrl/nxp/pinctrl-s32g2.c b/drivers/pinctrl/nxp/pinctrl-s32g2.c
new file mode 100644 (file)
index 0000000..d9f3ff6
--- /dev/null
@@ -0,0 +1,770 @@
+// SPDX-License-Identifier: GPL-2.0-or-later
+/*
+ * NXP S32G pinctrl driver
+ *
+ * Copyright 2015-2016 Freescale Semiconductor, Inc.
+ * Copyright 2017-2018, 2020-2022 NXP
+ * Copyright (C) 2022 SUSE LLC
+ */
+
+#include <linux/err.h>
+#include <linux/init.h>
+#include <linux/io.h>
+#include <linux/module.h>
+#include <linux/of.h>
+#include <linux/of_device.h>
+#include <linux/pinctrl/pinctrl.h>
+
+#include "pinctrl-s32.h"
+
+enum s32_pins {
+       S32G_MSCR_PA_00 =  0,
+       S32G_MSCR_PA_01 =  1,
+       S32G_MSCR_PA_02 =  2,
+       S32G_MSCR_PA_03 =  3,
+       S32G_MSCR_PA_04 =  4,
+       S32G_MSCR_PA_05 =  5,
+       S32G_MSCR_PA_06 =  6,
+       S32G_MSCR_PA_07 =  7,
+       S32G_MSCR_PA_08 =  8,
+       S32G_MSCR_PA_09 =  9,
+       S32G_MSCR_PA_10 =  10,
+       S32G_MSCR_PA_11 =  11,
+       S32G_MSCR_PA_12 =  12,
+       S32G_MSCR_PA_13 =  13,
+       S32G_MSCR_PA_14 =  14,
+       S32G_MSCR_PA_15 =  15,
+       S32G_MSCR_PB_00 =  16,
+       S32G_MSCR_PB_01 =  17,
+       S32G_MSCR_PB_02 =  18,
+       S32G_MSCR_PB_03 =  19,
+       S32G_MSCR_PB_04 =  20,
+       S32G_MSCR_PB_05 =  21,
+       S32G_MSCR_PB_06 =  22,
+       S32G_MSCR_PB_07 =  23,
+       S32G_MSCR_PB_08 =  24,
+       S32G_MSCR_PB_09 =  25,
+       S32G_MSCR_PB_10 =  26,
+       S32G_MSCR_PB_11 =  27,
+       S32G_MSCR_PB_12 =  28,
+       S32G_MSCR_PB_13 =  29,
+       S32G_MSCR_PB_14 =  30,
+       S32G_MSCR_PB_15 =  31,
+       S32G_MSCR_PC_00 =  32,
+       S32G_MSCR_PC_01 =  33,
+       S32G_MSCR_PC_02 =  34,
+       S32G_MSCR_PC_03 =  35,
+       S32G_MSCR_PC_04 =  36,
+       S32G_MSCR_PC_05 =  37,
+       S32G_MSCR_PC_06 =  38,
+       S32G_MSCR_PC_07 =  39,
+       S32G_MSCR_PC_08 =  40,
+       S32G_MSCR_PC_09 =  41,
+       S32G_MSCR_PC_10 =  42,
+       S32G_MSCR_PC_11 =  43,
+       S32G_MSCR_PC_12 =  44,
+       S32G_MSCR_PC_13 =  45,
+       S32G_MSCR_PC_14 =  46,
+       S32G_MSCR_PC_15 =  47,
+       S32G_MSCR_PD_00 =  48,
+       S32G_MSCR_PD_01 =  49,
+       S32G_MSCR_PD_02 =  50,
+       S32G_MSCR_PD_03 =  51,
+       S32G_MSCR_PD_04 =  52,
+       S32G_MSCR_PD_05 =  53,
+       S32G_MSCR_PD_06 =  54,
+       S32G_MSCR_PD_07 =  55,
+       S32G_MSCR_PD_08 =  56,
+       S32G_MSCR_PD_09 =  57,
+       S32G_MSCR_PD_10 =  58,
+       S32G_MSCR_PD_11 =  59,
+       S32G_MSCR_PD_12 =  60,
+       S32G_MSCR_PD_13 =  61,
+       S32G_MSCR_PD_14 =  62,
+       S32G_MSCR_PD_15 =  63,
+       S32G_MSCR_PE_00 =  64,
+       S32G_MSCR_PE_01 =  65,
+       S32G_MSCR_PE_02 =  66,
+       S32G_MSCR_PE_03 =  67,
+       S32G_MSCR_PE_04 =  68,
+       S32G_MSCR_PE_05 =  69,
+       S32G_MSCR_PE_06 =  70,
+       S32G_MSCR_PE_07 =  71,
+       S32G_MSCR_PE_08 =  72,
+       S32G_MSCR_PE_09 =  73,
+       S32G_MSCR_PE_10 =  74,
+       S32G_MSCR_PE_11 =  75,
+       S32G_MSCR_PE_12 =  76,
+       S32G_MSCR_PE_13 =  77,
+       S32G_MSCR_PE_14 =  78,
+       S32G_MSCR_PE_15 =  79,
+       S32G_MSCR_PF_00 =  80,
+       S32G_MSCR_PF_01 =  81,
+       S32G_MSCR_PF_02 =  82,
+       S32G_MSCR_PF_03 =  83,
+       S32G_MSCR_PF_04 =  84,
+       S32G_MSCR_PF_05 =  85,
+       S32G_MSCR_PF_06 =  86,
+       S32G_MSCR_PF_07 =  87,
+       S32G_MSCR_PF_08 =  88,
+       S32G_MSCR_PF_09 =  89,
+       S32G_MSCR_PF_10 =  90,
+       S32G_MSCR_PF_11 =  91,
+       S32G_MSCR_PF_12 =  92,
+       S32G_MSCR_PF_13 =  93,
+       S32G_MSCR_PF_14 =  94,
+       S32G_MSCR_PF_15 =  95,
+       S32G_MSCR_PG_00 =  96,
+       S32G_MSCR_PG_01 =  97,
+       S32G_MSCR_PG_02 =  98,
+       S32G_MSCR_PG_03 =  99,
+       S32G_MSCR_PG_04 =  100,
+       S32G_MSCR_PG_05 =  101,
+       S32G_MSCR_PH_00 =  112,
+       S32G_MSCR_PH_01 =  113,
+       S32G_MSCR_PH_02 =  114,
+       S32G_MSCR_PH_03 =  115,
+       S32G_MSCR_PH_04 =  116,
+       S32G_MSCR_PH_05 =  117,
+       S32G_MSCR_PH_06 =  118,
+       S32G_MSCR_PH_07 =  119,
+       S32G_MSCR_PH_08 =  120,
+       S32G_MSCR_PH_09 =  121,
+       S32G_MSCR_PH_10 =  122,
+       S32G_MSCR_PJ_00 =  144,
+       S32G_MSCR_PJ_01 =  145,
+       S32G_MSCR_PJ_02 =  146,
+       S32G_MSCR_PJ_03 =  147,
+       S32G_MSCR_PJ_04 =  148,
+       S32G_MSCR_PJ_05 =  149,
+       S32G_MSCR_PJ_06 =  150,
+       S32G_MSCR_PJ_07 =  151,
+       S32G_MSCR_PJ_08 =  152,
+       S32G_MSCR_PJ_09 =  153,
+       S32G_MSCR_PJ_10 =  154,
+       S32G_MSCR_PJ_11 =  155,
+       S32G_MSCR_PJ_12 =  156,
+       S32G_MSCR_PJ_13 =  157,
+       S32G_MSCR_PJ_14 =  158,
+       S32G_MSCR_PJ_15 =  159,
+       S32G_MSCR_PK_00 =  160,
+       S32G_MSCR_PK_01 =  161,
+       S32G_MSCR_PK_02 =  162,
+       S32G_MSCR_PK_03 =  163,
+       S32G_MSCR_PK_04 =  164,
+       S32G_MSCR_PK_05 =  165,
+       S32G_MSCR_PK_06 =  166,
+       S32G_MSCR_PK_07 =  167,
+       S32G_MSCR_PK_08 =  168,
+       S32G_MSCR_PK_09 =  169,
+       S32G_MSCR_PK_10 =  170,
+       S32G_MSCR_PK_11 =  171,
+       S32G_MSCR_PK_12 =  172,
+       S32G_MSCR_PK_13 =  173,
+       S32G_MSCR_PK_14 =  174,
+       S32G_MSCR_PK_15 =  175,
+       S32G_MSCR_PL_00 =  176,
+       S32G_MSCR_PL_01 =  177,
+       S32G_MSCR_PL_02 =  178,
+       S32G_MSCR_PL_03 =  179,
+       S32G_MSCR_PL_04 =  180,
+       S32G_MSCR_PL_05 =  181,
+       S32G_MSCR_PL_06 =  182,
+       S32G_MSCR_PL_07 =  183,
+       S32G_MSCR_PL_08 =  184,
+       S32G_MSCR_PL_09 =  185,
+       S32G_MSCR_PL_10 =  186,
+       S32G_MSCR_PL_11 =  187,
+       S32G_MSCR_PL_12 =  188,
+       S32G_MSCR_PL_13 =  189,
+       S32G_MSCR_PL_14 =  190,
+
+       S32G_IMCR_QSPI_A_DATA0 = 540,
+       S32G_IMCR_QSPI_A_DATA1 = 541,
+       S32G_IMCR_QSPI_A_DATA2 = 542,
+       S32G_IMCR_QSPI_A_DATA3 = 543,
+       S32G_IMCR_QSPI_A_DATA4 = 544,
+       S32G_IMCR_QSPI_A_DATA5 = 545,
+       S32G_IMCR_QSPI_A_DATA6 = 546,
+       S32G_IMCR_QSPI_A_DATA7 = 547,
+       S32G_IMCR_QSPI_DQS_A = 548,
+       S32G_IMCR_QSPI_B_DATA0 = 552,
+       S32G_IMCR_QSPI_B_DATA1 = 554,
+       S32G_IMCR_QSPI_B_DATA2 = 551,
+       S32G_IMCR_QSPI_B_DATA3 = 553,
+       S32G_IMCR_QSPI_B_DATA4 = 557,
+       S32G_IMCR_QSPI_B_DATA5 = 550,
+       S32G_IMCR_QSPI_B_DATA6 = 556,
+       S32G_IMCR_QSPI_B_DATA7 = 555,
+       S32G_IMCR_QSPI_DQS_B = 558,
+       S32G_IMCR_BOOT_BOOTMOD0 = 560,
+       S32G_IMCR_BOOT_BOOTMOD1 = 561,
+       S32G_IMCR_I2C0_SCL = 566,
+       S32G_IMCR_I2C0_SDA = 565,
+       S32G_IMCR_LIN0_RX = 512,
+       S32G_IMCR_USDHC_CMD = 515,
+       S32G_IMCR_USDHC_DAT0 = 516,
+       S32G_IMCR_USDHC_DAT1 = 517,
+       S32G_IMCR_USDHC_DAT2 = 520,
+       S32G_IMCR_USDHC_DAT3 = 521,
+       S32G_IMCR_USDHC_DAT4 = 522,
+       S32G_IMCR_USDHC_DAT5 = 523,
+       S32G_IMCR_USDHC_DAT6 = 519,
+       S32G_IMCR_USDHC_DAT7 = 518,
+       S32G_IMCR_USDHC_DQS = 524,
+       S32G_IMCR_CAN0_RXD = 513,
+       S32G_IMCR_CAN1_RXD = 631,
+       S32G_IMCR_CAN2_RXD = 632,
+       S32G_IMCR_CAN3_RXD = 633,
+       /* GMAC0 */
+       S32G_IMCR_Ethernet_MDIO = 527,
+       S32G_IMCR_Ethernet_CRS = 526,
+       S32G_IMCR_Ethernet_COL = 525,
+       S32G_IMCR_Ethernet_RX_D0 = 531,
+       S32G_IMCR_Ethernet_RX_D1 = 532,
+       S32G_IMCR_Ethernet_RX_D2 = 533,
+       S32G_IMCR_Ethernet_RX_D3 = 534,
+       S32G_IMCR_Ethernet_RX_ER = 528,
+       S32G_IMCR_Ethernet_RX_CLK = 529,
+       S32G_IMCR_Ethernet_RX_DV = 530,
+       S32G_IMCR_Ethernet_TX_CLK = 538,
+       S32G_IMCR_Ethernet_REF_CLK = 535,
+       /* PFE EMAC 0 MII */
+       /* PFE EMAC 1 MII */
+       S32G_IMCR_PFE_EMAC_1_MDIO = 857,
+       S32G_IMCR_PFE_EMAC_1_CRS = 856,
+       S32G_IMCR_PFE_EMAC_1_COL = 855,
+       S32G_IMCR_PFE_EMAC_1_RX_D0 = 861,
+       S32G_IMCR_PFE_EMAC_1_RX_D1 = 862,
+       S32G_IMCR_PFE_EMAC_1_RX_D2 = 863,
+       S32G_IMCR_PFE_EMAC_1_RX_D3 = 864,
+       S32G_IMCR_PFE_EMAC_1_RX_ER = 860,
+       S32G_IMCR_PFE_EMAC_1_RX_CLK = 859,
+       S32G_IMCR_PFE_EMAC_1_RX_DV = 865,
+       S32G_IMCR_PFE_EMAC_1_TX_CLK = 866,
+       S32G_IMCR_PFE_EMAC_1_REF_CLK = 858,
+       /* PFE EMAC 2 MII */
+       S32G_IMCR_PFE_EMAC_2_MDIO = 877,
+       S32G_IMCR_PFE_EMAC_2_CRS = 876,
+       S32G_IMCR_PFE_EMAC_2_COL = 875,
+       S32G_IMCR_PFE_EMAC_2_RX_D0 = 881,
+       S32G_IMCR_PFE_EMAC_2_RX_D1 = 882,
+       S32G_IMCR_PFE_EMAC_2_RX_D2 = 883,
+       S32G_IMCR_PFE_EMAC_2_RX_D3 = 884,
+       S32G_IMCR_PFE_EMAC_2_RX_ER = 880,
+       S32G_IMCR_PFE_EMAC_2_RX_CLK = 879,
+       S32G_IMCR_PFE_EMAC_2_RX_DV = 885,
+       S32G_IMCR_PFE_EMAC_2_TX_CLK = 886,
+       S32G_IMCR_PFE_EMAC_2_REF_CLK = 878,
+
+       S32G_IMCR_FlexRay0_A_RX = 785,
+       S32G_IMCR_FlexRay0_B_RX = 786,
+       S32G_IMCR_FlexTimer0_CH0 = 655,
+       S32G_IMCR_FlexTimer1_CH0 = 665,
+       S32G_IMCR_FlexTimer0_CH1 = 656,
+       S32G_IMCR_FlexTimer1_CH1 = 666,
+       S32G_IMCR_FlexTimer0_CH2 = 657,
+       S32G_IMCR_FlexTimer1_CH2 = 667,
+       S32G_IMCR_FlexTimer0_CH3 = 658,
+       S32G_IMCR_FlexTimer1_CH3 = 668,
+       S32G_IMCR_FlexTimer0_CH4 = 659,
+       S32G_IMCR_FlexTimer1_CH4 = 669,
+       S32G_IMCR_FlexTimer0_CH5 = 660,
+       S32G_IMCR_FlexTimer1_CH5 = 670,
+       S32G_IMCR_FlexTimer0_EXTCLK = 661,
+       S32G_IMCR_FlexTimer1_EXTCLK = 671,
+       S32G_IMCR_I2C1_SCL = 717,
+       S32G_IMCR_I2C1_SDA = 718,
+       S32G_IMCR_I2C2_SCL = 719,
+       S32G_IMCR_I2C2_SDA = 720,
+       S32G_IMCR_I2C3_SCL = 721,
+       S32G_IMCR_I2C3_SDA = 722,
+       S32G_IMCR_I2C4_SCL = 723,
+       S32G_IMCR_I2C4_SDA = 724,
+       S32G_IMCR_LIN1_RX = 736,
+       S32G_IMCR_LIN2_RX = 737,
+       S32G_IMCR_DSPI0_PCS0 = 980,
+       S32G_IMCR_DSPI0_SCK = 981,
+       S32G_IMCR_DSPI0_SIN = 982,
+       S32G_IMCR_DSPI1_PCS0 = 985,
+       S32G_IMCR_DSPI1_SCK = 986,
+       S32G_IMCR_DSPI1_SIN = 987,
+       S32G_IMCR_DSPI2_PCS0 = 990,
+       S32G_IMCR_DSPI2_SCK = 991,
+       S32G_IMCR_DSPI2_SIN = 992,
+       S32G_IMCR_DSPI3_PCS0 = 995,
+       S32G_IMCR_DSPI3_SCK = 996,
+       S32G_IMCR_DSPI3_SIN = 997,
+       S32G_IMCR_DSPI4_PCS0 = 1000,
+       S32G_IMCR_DSPI4_SCK = 1001,
+       S32G_IMCR_DSPI4_SIN = 1002,
+       S32G_IMCR_DSPI5_PCS0 = 1005,
+       S32G_IMCR_DSPI5_SCK = 1006,
+       S32G_IMCR_DSPI5_SIN = 1007,
+       S32G_IMCR_LLCE_CAN0_RXD = 745,
+       S32G_IMCR_LLCE_CAN1_RXD = 746,
+       S32G_IMCR_LLCE_CAN2_RXD = 747,
+       S32G_IMCR_LLCE_CAN3_RXD = 748,
+       S32G_IMCR_LLCE_CAN4_RXD = 749,
+       S32G_IMCR_LLCE_CAN5_RXD = 750,
+       S32G_IMCR_LLCE_CAN6_RXD = 751,
+       S32G_IMCR_LLCE_CAN7_RXD = 752,
+       S32G_IMCR_LLCE_CAN8_RXD = 753,
+       S32G_IMCR_LLCE_CAN9_RXD = 754,
+       S32G_IMCR_LLCE_CAN10_RXD = 755,
+       S32G_IMCR_LLCE_CAN11_RXD = 756,
+       S32G_IMCR_LLCE_CAN12_RXD = 757,
+       S32G_IMCR_LLCE_CAN13_RXD = 758,
+       S32G_IMCR_LLCE_CAN14_RXD = 759,
+       S32G_IMCR_LLCE_CAN15_RXD = 760,
+       S32G_IMCR_USB_CLK = 895,
+       S32G_IMCR_USB_DATA0 = 896,
+       S32G_IMCR_USB_DATA1 = 897,
+       S32G_IMCR_USB_DATA2 = 898,
+       S32G_IMCR_USB_DATA3 = 899,
+       S32G_IMCR_USB_DATA4 = 900,
+       S32G_IMCR_USB_DATA5 = 901,
+       S32G_IMCR_USB_DATA6 = 902,
+       S32G_IMCR_USB_DATA7 = 903,
+       S32G_IMCR_USB_DIR = 904,
+       S32G_IMCR_USB_NXT = 905,
+
+       S32G_IMCR_SIUL_EIRQ0 =  910,
+       S32G_IMCR_SIUL_EIRQ1 =  911,
+       S32G_IMCR_SIUL_EIRQ2 =  912,
+       S32G_IMCR_SIUL_EIRQ3 =  913,
+       S32G_IMCR_SIUL_EIRQ4 =  914,
+       S32G_IMCR_SIUL_EIRQ5 =  915,
+       S32G_IMCR_SIUL_EIRQ6 =  916,
+       S32G_IMCR_SIUL_EIRQ7 =  917,
+       S32G_IMCR_SIUL_EIRQ8 =  918,
+       S32G_IMCR_SIUL_EIRQ9 =  919,
+       S32G_IMCR_SIUL_EIRQ10 =  920,
+       S32G_IMCR_SIUL_EIRQ11 =  921,
+       S32G_IMCR_SIUL_EIRQ12 =  922,
+       S32G_IMCR_SIUL_EIRQ13 =  923,
+       S32G_IMCR_SIUL_EIRQ14 =  924,
+       S32G_IMCR_SIUL_EIRQ15 =  925,
+       S32G_IMCR_SIUL_EIRQ16 =  926,
+       S32G_IMCR_SIUL_EIRQ17 =  927,
+       S32G_IMCR_SIUL_EIRQ18 =  928,
+       S32G_IMCR_SIUL_EIRQ19 =  929,
+       S32G_IMCR_SIUL_EIRQ20 =  930,
+       S32G_IMCR_SIUL_EIRQ21 =  931,
+       S32G_IMCR_SIUL_EIRQ22 =  932,
+       S32G_IMCR_SIUL_EIRQ23 =  933,
+       S32G_IMCR_SIUL_EIRQ24 =  934,
+       S32G_IMCR_SIUL_EIRQ25 =  935,
+       S32G_IMCR_SIUL_EIRQ26 =  936,
+       S32G_IMCR_SIUL_EIRQ27 =  937,
+       S32G_IMCR_SIUL_EIRQ28 =  938,
+       S32G_IMCR_SIUL_EIRQ29 =  939,
+       S32G_IMCR_SIUL_EIRQ30 =  940,
+       S32G_IMCR_SIUL_EIRQ31 =  941,
+};
+
+/* Pad names for the pinmux subsystem */
+static const struct pinctrl_pin_desc s32_pinctrl_pads_siul2[] = {
+
+       /* SIUL2_0 pins. */
+
+       S32_PINCTRL_PIN(S32G_MSCR_PA_00),
+       S32_PINCTRL_PIN(S32G_MSCR_PA_01),
+       S32_PINCTRL_PIN(S32G_MSCR_PA_02),
+       S32_PINCTRL_PIN(S32G_MSCR_PA_03),
+       S32_PINCTRL_PIN(S32G_MSCR_PA_04),
+       S32_PINCTRL_PIN(S32G_MSCR_PA_05),
+       S32_PINCTRL_PIN(S32G_MSCR_PA_06),
+       S32_PINCTRL_PIN(S32G_MSCR_PA_07),
+       S32_PINCTRL_PIN(S32G_MSCR_PA_08),
+       S32_PINCTRL_PIN(S32G_MSCR_PA_09),
+       S32_PINCTRL_PIN(S32G_MSCR_PA_10),
+       S32_PINCTRL_PIN(S32G_MSCR_PA_11),
+       S32_PINCTRL_PIN(S32G_MSCR_PA_12),
+       S32_PINCTRL_PIN(S32G_MSCR_PA_13),
+       S32_PINCTRL_PIN(S32G_MSCR_PA_14),
+       S32_PINCTRL_PIN(S32G_MSCR_PA_15),
+       S32_PINCTRL_PIN(S32G_MSCR_PB_00),
+       S32_PINCTRL_PIN(S32G_MSCR_PB_01),
+       S32_PINCTRL_PIN(S32G_MSCR_PB_02),
+       S32_PINCTRL_PIN(S32G_MSCR_PB_03),
+       S32_PINCTRL_PIN(S32G_MSCR_PB_04),
+       S32_PINCTRL_PIN(S32G_MSCR_PB_05),
+       S32_PINCTRL_PIN(S32G_MSCR_PB_06),
+       S32_PINCTRL_PIN(S32G_MSCR_PB_07),
+       S32_PINCTRL_PIN(S32G_MSCR_PB_08),
+       S32_PINCTRL_PIN(S32G_MSCR_PB_09),
+       S32_PINCTRL_PIN(S32G_MSCR_PB_10),
+       S32_PINCTRL_PIN(S32G_MSCR_PB_11),
+       S32_PINCTRL_PIN(S32G_MSCR_PB_12),
+       S32_PINCTRL_PIN(S32G_MSCR_PB_13),
+       S32_PINCTRL_PIN(S32G_MSCR_PB_14),
+       S32_PINCTRL_PIN(S32G_MSCR_PB_15),
+       S32_PINCTRL_PIN(S32G_MSCR_PC_00),
+       S32_PINCTRL_PIN(S32G_MSCR_PC_01),
+       S32_PINCTRL_PIN(S32G_MSCR_PC_02),
+       S32_PINCTRL_PIN(S32G_MSCR_PC_03),
+       S32_PINCTRL_PIN(S32G_MSCR_PC_04),
+       S32_PINCTRL_PIN(S32G_MSCR_PC_05),
+       S32_PINCTRL_PIN(S32G_MSCR_PC_06),
+       S32_PINCTRL_PIN(S32G_MSCR_PC_07),
+       S32_PINCTRL_PIN(S32G_MSCR_PC_08),
+       S32_PINCTRL_PIN(S32G_MSCR_PC_09),
+       S32_PINCTRL_PIN(S32G_MSCR_PC_10),
+       S32_PINCTRL_PIN(S32G_MSCR_PC_11),
+       S32_PINCTRL_PIN(S32G_MSCR_PC_12),
+       S32_PINCTRL_PIN(S32G_MSCR_PC_13),
+       S32_PINCTRL_PIN(S32G_MSCR_PC_14),
+       S32_PINCTRL_PIN(S32G_MSCR_PC_15),
+       S32_PINCTRL_PIN(S32G_MSCR_PD_00),
+       S32_PINCTRL_PIN(S32G_MSCR_PD_01),
+       S32_PINCTRL_PIN(S32G_MSCR_PD_02),
+       S32_PINCTRL_PIN(S32G_MSCR_PD_03),
+       S32_PINCTRL_PIN(S32G_MSCR_PD_04),
+       S32_PINCTRL_PIN(S32G_MSCR_PD_05),
+       S32_PINCTRL_PIN(S32G_MSCR_PD_06),
+       S32_PINCTRL_PIN(S32G_MSCR_PD_07),
+       S32_PINCTRL_PIN(S32G_MSCR_PD_08),
+       S32_PINCTRL_PIN(S32G_MSCR_PD_09),
+       S32_PINCTRL_PIN(S32G_MSCR_PD_10),
+       S32_PINCTRL_PIN(S32G_MSCR_PD_11),
+       S32_PINCTRL_PIN(S32G_MSCR_PD_12),
+       S32_PINCTRL_PIN(S32G_MSCR_PD_13),
+       S32_PINCTRL_PIN(S32G_MSCR_PD_14),
+       S32_PINCTRL_PIN(S32G_MSCR_PD_15),
+       S32_PINCTRL_PIN(S32G_MSCR_PE_00),
+       S32_PINCTRL_PIN(S32G_MSCR_PE_01),
+       S32_PINCTRL_PIN(S32G_MSCR_PE_02),
+       S32_PINCTRL_PIN(S32G_MSCR_PE_03),
+       S32_PINCTRL_PIN(S32G_MSCR_PE_04),
+       S32_PINCTRL_PIN(S32G_MSCR_PE_05),
+       S32_PINCTRL_PIN(S32G_MSCR_PE_06),
+       S32_PINCTRL_PIN(S32G_MSCR_PE_07),
+       S32_PINCTRL_PIN(S32G_MSCR_PE_08),
+       S32_PINCTRL_PIN(S32G_MSCR_PE_09),
+       S32_PINCTRL_PIN(S32G_MSCR_PE_10),
+       S32_PINCTRL_PIN(S32G_MSCR_PE_11),
+       S32_PINCTRL_PIN(S32G_MSCR_PE_12),
+       S32_PINCTRL_PIN(S32G_MSCR_PE_13),
+       S32_PINCTRL_PIN(S32G_MSCR_PE_14),
+       S32_PINCTRL_PIN(S32G_MSCR_PE_15),
+       S32_PINCTRL_PIN(S32G_MSCR_PF_00),
+       S32_PINCTRL_PIN(S32G_MSCR_PF_01),
+       S32_PINCTRL_PIN(S32G_MSCR_PF_02),
+       S32_PINCTRL_PIN(S32G_MSCR_PF_03),
+       S32_PINCTRL_PIN(S32G_MSCR_PF_04),
+       S32_PINCTRL_PIN(S32G_MSCR_PF_05),
+       S32_PINCTRL_PIN(S32G_MSCR_PF_06),
+       S32_PINCTRL_PIN(S32G_MSCR_PF_07),
+       S32_PINCTRL_PIN(S32G_MSCR_PF_08),
+       S32_PINCTRL_PIN(S32G_MSCR_PF_09),
+       S32_PINCTRL_PIN(S32G_MSCR_PF_10),
+       S32_PINCTRL_PIN(S32G_MSCR_PF_11),
+       S32_PINCTRL_PIN(S32G_MSCR_PF_12),
+       S32_PINCTRL_PIN(S32G_MSCR_PF_13),
+       S32_PINCTRL_PIN(S32G_MSCR_PF_14),
+       S32_PINCTRL_PIN(S32G_MSCR_PF_15),
+       S32_PINCTRL_PIN(S32G_MSCR_PG_00),
+       S32_PINCTRL_PIN(S32G_MSCR_PG_01),
+       S32_PINCTRL_PIN(S32G_MSCR_PG_02),
+       S32_PINCTRL_PIN(S32G_MSCR_PG_03),
+       S32_PINCTRL_PIN(S32G_MSCR_PG_04),
+       S32_PINCTRL_PIN(S32G_MSCR_PG_05),
+
+       S32_PINCTRL_PIN(S32G_IMCR_QSPI_A_DATA0),
+       S32_PINCTRL_PIN(S32G_IMCR_QSPI_A_DATA1),
+       S32_PINCTRL_PIN(S32G_IMCR_QSPI_A_DATA2),
+       S32_PINCTRL_PIN(S32G_IMCR_QSPI_A_DATA3),
+       S32_PINCTRL_PIN(S32G_IMCR_QSPI_A_DATA4),
+       S32_PINCTRL_PIN(S32G_IMCR_QSPI_A_DATA5),
+       S32_PINCTRL_PIN(S32G_IMCR_QSPI_A_DATA6),
+       S32_PINCTRL_PIN(S32G_IMCR_QSPI_A_DATA7),
+       S32_PINCTRL_PIN(S32G_IMCR_QSPI_DQS_A),
+       S32_PINCTRL_PIN(S32G_IMCR_QSPI_B_DATA0),
+       S32_PINCTRL_PIN(S32G_IMCR_QSPI_B_DATA1),
+       S32_PINCTRL_PIN(S32G_IMCR_QSPI_B_DATA2),
+       S32_PINCTRL_PIN(S32G_IMCR_QSPI_B_DATA3),
+       S32_PINCTRL_PIN(S32G_IMCR_QSPI_B_DATA4),
+       S32_PINCTRL_PIN(S32G_IMCR_QSPI_B_DATA5),
+       S32_PINCTRL_PIN(S32G_IMCR_QSPI_B_DATA6),
+       S32_PINCTRL_PIN(S32G_IMCR_QSPI_B_DATA7),
+       S32_PINCTRL_PIN(S32G_IMCR_QSPI_DQS_B),
+       S32_PINCTRL_PIN(S32G_IMCR_I2C0_SCL),
+       S32_PINCTRL_PIN(S32G_IMCR_I2C0_SDA),
+       S32_PINCTRL_PIN(S32G_IMCR_LIN0_RX),
+       S32_PINCTRL_PIN(S32G_IMCR_USDHC_CMD),
+       S32_PINCTRL_PIN(S32G_IMCR_USDHC_DAT0),
+       S32_PINCTRL_PIN(S32G_IMCR_USDHC_DAT1),
+       S32_PINCTRL_PIN(S32G_IMCR_USDHC_DAT2),
+       S32_PINCTRL_PIN(S32G_IMCR_USDHC_DAT3),
+       S32_PINCTRL_PIN(S32G_IMCR_USDHC_DAT4),
+       S32_PINCTRL_PIN(S32G_IMCR_USDHC_DAT5),
+       S32_PINCTRL_PIN(S32G_IMCR_USDHC_DAT6),
+       S32_PINCTRL_PIN(S32G_IMCR_USDHC_DAT7),
+       S32_PINCTRL_PIN(S32G_IMCR_USDHC_DQS),
+       S32_PINCTRL_PIN(S32G_IMCR_CAN0_RXD),
+       /* GMAC0 */
+       S32_PINCTRL_PIN(S32G_IMCR_Ethernet_MDIO),
+       S32_PINCTRL_PIN(S32G_IMCR_Ethernet_CRS),
+       S32_PINCTRL_PIN(S32G_IMCR_Ethernet_COL),
+       S32_PINCTRL_PIN(S32G_IMCR_Ethernet_RX_D0),
+       S32_PINCTRL_PIN(S32G_IMCR_Ethernet_RX_D1),
+       S32_PINCTRL_PIN(S32G_IMCR_Ethernet_RX_D2),
+       S32_PINCTRL_PIN(S32G_IMCR_Ethernet_RX_D3),
+       S32_PINCTRL_PIN(S32G_IMCR_Ethernet_RX_ER),
+       S32_PINCTRL_PIN(S32G_IMCR_Ethernet_RX_CLK),
+       S32_PINCTRL_PIN(S32G_IMCR_Ethernet_RX_DV),
+       S32_PINCTRL_PIN(S32G_IMCR_Ethernet_TX_CLK),
+       S32_PINCTRL_PIN(S32G_IMCR_Ethernet_REF_CLK),
+
+       /* SIUL2_1 pins. */
+
+       S32_PINCTRL_PIN(S32G_MSCR_PH_00),
+       S32_PINCTRL_PIN(S32G_MSCR_PH_01),
+       S32_PINCTRL_PIN(S32G_MSCR_PH_02),
+       S32_PINCTRL_PIN(S32G_MSCR_PH_03),
+       S32_PINCTRL_PIN(S32G_MSCR_PH_04),
+       S32_PINCTRL_PIN(S32G_MSCR_PH_05),
+       S32_PINCTRL_PIN(S32G_MSCR_PH_06),
+       S32_PINCTRL_PIN(S32G_MSCR_PH_07),
+       S32_PINCTRL_PIN(S32G_MSCR_PH_08),
+       S32_PINCTRL_PIN(S32G_MSCR_PH_09),
+       S32_PINCTRL_PIN(S32G_MSCR_PH_10),
+       S32_PINCTRL_PIN(S32G_MSCR_PJ_00),
+       S32_PINCTRL_PIN(S32G_MSCR_PJ_01),
+       S32_PINCTRL_PIN(S32G_MSCR_PJ_02),
+       S32_PINCTRL_PIN(S32G_MSCR_PJ_03),
+       S32_PINCTRL_PIN(S32G_MSCR_PJ_04),
+       S32_PINCTRL_PIN(S32G_MSCR_PJ_05),
+       S32_PINCTRL_PIN(S32G_MSCR_PJ_06),
+       S32_PINCTRL_PIN(S32G_MSCR_PJ_07),
+       S32_PINCTRL_PIN(S32G_MSCR_PJ_08),
+       S32_PINCTRL_PIN(S32G_MSCR_PJ_09),
+       S32_PINCTRL_PIN(S32G_MSCR_PJ_10),
+       S32_PINCTRL_PIN(S32G_MSCR_PJ_11),
+       S32_PINCTRL_PIN(S32G_MSCR_PJ_12),
+       S32_PINCTRL_PIN(S32G_MSCR_PJ_13),
+       S32_PINCTRL_PIN(S32G_MSCR_PJ_14),
+       S32_PINCTRL_PIN(S32G_MSCR_PJ_15),
+       S32_PINCTRL_PIN(S32G_MSCR_PK_00),
+       S32_PINCTRL_PIN(S32G_MSCR_PK_01),
+       S32_PINCTRL_PIN(S32G_MSCR_PK_02),
+       S32_PINCTRL_PIN(S32G_MSCR_PK_03),
+       S32_PINCTRL_PIN(S32G_MSCR_PK_04),
+       S32_PINCTRL_PIN(S32G_MSCR_PK_05),
+       S32_PINCTRL_PIN(S32G_MSCR_PK_06),
+       S32_PINCTRL_PIN(S32G_MSCR_PK_07),
+       S32_PINCTRL_PIN(S32G_MSCR_PK_08),
+       S32_PINCTRL_PIN(S32G_MSCR_PK_09),
+       S32_PINCTRL_PIN(S32G_MSCR_PK_10),
+       S32_PINCTRL_PIN(S32G_MSCR_PK_11),
+       S32_PINCTRL_PIN(S32G_MSCR_PK_12),
+       S32_PINCTRL_PIN(S32G_MSCR_PK_13),
+       S32_PINCTRL_PIN(S32G_MSCR_PK_14),
+       S32_PINCTRL_PIN(S32G_MSCR_PK_15),
+       S32_PINCTRL_PIN(S32G_MSCR_PL_00),
+       S32_PINCTRL_PIN(S32G_MSCR_PL_01),
+       S32_PINCTRL_PIN(S32G_MSCR_PL_02),
+       S32_PINCTRL_PIN(S32G_MSCR_PL_03),
+       S32_PINCTRL_PIN(S32G_MSCR_PL_04),
+       S32_PINCTRL_PIN(S32G_MSCR_PL_05),
+       S32_PINCTRL_PIN(S32G_MSCR_PL_06),
+       S32_PINCTRL_PIN(S32G_MSCR_PL_07),
+       S32_PINCTRL_PIN(S32G_MSCR_PL_08),
+       S32_PINCTRL_PIN(S32G_MSCR_PL_09),
+       S32_PINCTRL_PIN(S32G_MSCR_PL_10),
+       S32_PINCTRL_PIN(S32G_MSCR_PL_11),
+       S32_PINCTRL_PIN(S32G_MSCR_PL_12),
+       S32_PINCTRL_PIN(S32G_MSCR_PL_13),
+       S32_PINCTRL_PIN(S32G_MSCR_PL_14),
+
+       S32_PINCTRL_PIN(S32G_IMCR_FlexRay0_A_RX),
+       S32_PINCTRL_PIN(S32G_IMCR_FlexRay0_B_RX),
+       S32_PINCTRL_PIN(S32G_IMCR_FlexTimer0_CH0),
+       S32_PINCTRL_PIN(S32G_IMCR_FlexTimer1_CH0),
+       S32_PINCTRL_PIN(S32G_IMCR_FlexTimer0_CH1),
+       S32_PINCTRL_PIN(S32G_IMCR_FlexTimer1_CH1),
+       S32_PINCTRL_PIN(S32G_IMCR_FlexTimer0_CH2),
+       S32_PINCTRL_PIN(S32G_IMCR_FlexTimer1_CH2),
+       S32_PINCTRL_PIN(S32G_IMCR_FlexTimer0_CH3),
+       S32_PINCTRL_PIN(S32G_IMCR_FlexTimer1_CH3),
+       S32_PINCTRL_PIN(S32G_IMCR_FlexTimer0_CH4),
+       S32_PINCTRL_PIN(S32G_IMCR_FlexTimer1_CH4),
+       S32_PINCTRL_PIN(S32G_IMCR_FlexTimer0_CH5),
+       S32_PINCTRL_PIN(S32G_IMCR_FlexTimer1_CH5),
+       S32_PINCTRL_PIN(S32G_IMCR_FlexTimer0_EXTCLK),
+       S32_PINCTRL_PIN(S32G_IMCR_FlexTimer1_EXTCLK),
+       S32_PINCTRL_PIN(S32G_IMCR_I2C1_SCL),
+       S32_PINCTRL_PIN(S32G_IMCR_I2C1_SDA),
+       S32_PINCTRL_PIN(S32G_IMCR_I2C2_SCL),
+       S32_PINCTRL_PIN(S32G_IMCR_I2C2_SDA),
+       S32_PINCTRL_PIN(S32G_IMCR_I2C3_SCL),
+       S32_PINCTRL_PIN(S32G_IMCR_I2C3_SDA),
+       S32_PINCTRL_PIN(S32G_IMCR_I2C4_SCL),
+       S32_PINCTRL_PIN(S32G_IMCR_I2C4_SDA),
+       S32_PINCTRL_PIN(S32G_IMCR_LIN1_RX),
+       S32_PINCTRL_PIN(S32G_IMCR_LIN2_RX),
+       S32_PINCTRL_PIN(S32G_IMCR_DSPI0_PCS0),
+       S32_PINCTRL_PIN(S32G_IMCR_DSPI0_SCK),
+       S32_PINCTRL_PIN(S32G_IMCR_DSPI0_SIN),
+       S32_PINCTRL_PIN(S32G_IMCR_DSPI1_PCS0),
+       S32_PINCTRL_PIN(S32G_IMCR_DSPI1_SCK),
+       S32_PINCTRL_PIN(S32G_IMCR_DSPI1_SIN),
+       S32_PINCTRL_PIN(S32G_IMCR_DSPI2_PCS0),
+       S32_PINCTRL_PIN(S32G_IMCR_DSPI2_SCK),
+       S32_PINCTRL_PIN(S32G_IMCR_DSPI2_SIN),
+       S32_PINCTRL_PIN(S32G_IMCR_DSPI3_PCS0),
+       S32_PINCTRL_PIN(S32G_IMCR_DSPI3_SCK),
+       S32_PINCTRL_PIN(S32G_IMCR_DSPI3_SIN),
+       S32_PINCTRL_PIN(S32G_IMCR_DSPI4_PCS0),
+       S32_PINCTRL_PIN(S32G_IMCR_DSPI4_SCK),
+       S32_PINCTRL_PIN(S32G_IMCR_DSPI4_SIN),
+       S32_PINCTRL_PIN(S32G_IMCR_DSPI5_PCS0),
+       S32_PINCTRL_PIN(S32G_IMCR_DSPI5_SCK),
+       S32_PINCTRL_PIN(S32G_IMCR_DSPI5_SIN),
+       S32_PINCTRL_PIN(S32G_IMCR_LLCE_CAN0_RXD),
+       S32_PINCTRL_PIN(S32G_IMCR_LLCE_CAN1_RXD),
+       S32_PINCTRL_PIN(S32G_IMCR_LLCE_CAN2_RXD),
+       S32_PINCTRL_PIN(S32G_IMCR_LLCE_CAN3_RXD),
+       S32_PINCTRL_PIN(S32G_IMCR_LLCE_CAN4_RXD),
+       S32_PINCTRL_PIN(S32G_IMCR_LLCE_CAN5_RXD),
+       S32_PINCTRL_PIN(S32G_IMCR_LLCE_CAN6_RXD),
+       S32_PINCTRL_PIN(S32G_IMCR_LLCE_CAN7_RXD),
+       S32_PINCTRL_PIN(S32G_IMCR_LLCE_CAN8_RXD),
+       S32_PINCTRL_PIN(S32G_IMCR_LLCE_CAN9_RXD),
+       S32_PINCTRL_PIN(S32G_IMCR_LLCE_CAN10_RXD),
+       S32_PINCTRL_PIN(S32G_IMCR_LLCE_CAN11_RXD),
+       S32_PINCTRL_PIN(S32G_IMCR_LLCE_CAN12_RXD),
+       S32_PINCTRL_PIN(S32G_IMCR_LLCE_CAN13_RXD),
+       S32_PINCTRL_PIN(S32G_IMCR_LLCE_CAN14_RXD),
+       S32_PINCTRL_PIN(S32G_IMCR_LLCE_CAN15_RXD),
+       S32_PINCTRL_PIN(S32G_IMCR_CAN1_RXD),
+       S32_PINCTRL_PIN(S32G_IMCR_CAN2_RXD),
+       S32_PINCTRL_PIN(S32G_IMCR_CAN3_RXD),
+       S32_PINCTRL_PIN(S32G_IMCR_USB_CLK),
+       S32_PINCTRL_PIN(S32G_IMCR_USB_DATA0),
+       S32_PINCTRL_PIN(S32G_IMCR_USB_DATA1),
+       S32_PINCTRL_PIN(S32G_IMCR_USB_DATA2),
+       S32_PINCTRL_PIN(S32G_IMCR_USB_DATA3),
+       S32_PINCTRL_PIN(S32G_IMCR_USB_DATA4),
+       S32_PINCTRL_PIN(S32G_IMCR_USB_DATA5),
+       S32_PINCTRL_PIN(S32G_IMCR_USB_DATA6),
+       S32_PINCTRL_PIN(S32G_IMCR_USB_DATA7),
+       S32_PINCTRL_PIN(S32G_IMCR_USB_DIR),
+       S32_PINCTRL_PIN(S32G_IMCR_USB_NXT),
+       S32_PINCTRL_PIN(S32G_IMCR_PFE_EMAC_1_MDIO),
+       S32_PINCTRL_PIN(S32G_IMCR_PFE_EMAC_1_CRS),
+       S32_PINCTRL_PIN(S32G_IMCR_PFE_EMAC_1_COL),
+       S32_PINCTRL_PIN(S32G_IMCR_PFE_EMAC_1_RX_D0),
+       S32_PINCTRL_PIN(S32G_IMCR_PFE_EMAC_1_RX_D1),
+       S32_PINCTRL_PIN(S32G_IMCR_PFE_EMAC_1_RX_D2),
+       S32_PINCTRL_PIN(S32G_IMCR_PFE_EMAC_1_RX_D3),
+       S32_PINCTRL_PIN(S32G_IMCR_PFE_EMAC_1_RX_ER),
+       S32_PINCTRL_PIN(S32G_IMCR_PFE_EMAC_1_RX_CLK),
+       S32_PINCTRL_PIN(S32G_IMCR_PFE_EMAC_1_RX_DV),
+       S32_PINCTRL_PIN(S32G_IMCR_PFE_EMAC_1_TX_CLK),
+       S32_PINCTRL_PIN(S32G_IMCR_PFE_EMAC_1_REF_CLK),
+       S32_PINCTRL_PIN(S32G_IMCR_PFE_EMAC_2_MDIO),
+       S32_PINCTRL_PIN(S32G_IMCR_PFE_EMAC_2_CRS),
+       S32_PINCTRL_PIN(S32G_IMCR_PFE_EMAC_2_COL),
+       S32_PINCTRL_PIN(S32G_IMCR_PFE_EMAC_2_RX_D0),
+       S32_PINCTRL_PIN(S32G_IMCR_PFE_EMAC_2_RX_D1),
+       S32_PINCTRL_PIN(S32G_IMCR_PFE_EMAC_2_RX_D2),
+       S32_PINCTRL_PIN(S32G_IMCR_PFE_EMAC_2_RX_D3),
+       S32_PINCTRL_PIN(S32G_IMCR_PFE_EMAC_2_RX_ER),
+       S32_PINCTRL_PIN(S32G_IMCR_PFE_EMAC_2_RX_CLK),
+       S32_PINCTRL_PIN(S32G_IMCR_PFE_EMAC_2_RX_DV),
+       S32_PINCTRL_PIN(S32G_IMCR_PFE_EMAC_2_TX_CLK),
+       S32_PINCTRL_PIN(S32G_IMCR_PFE_EMAC_2_REF_CLK),
+       S32_PINCTRL_PIN(S32G_IMCR_SIUL_EIRQ0),
+       S32_PINCTRL_PIN(S32G_IMCR_SIUL_EIRQ1),
+       S32_PINCTRL_PIN(S32G_IMCR_SIUL_EIRQ2),
+       S32_PINCTRL_PIN(S32G_IMCR_SIUL_EIRQ3),
+       S32_PINCTRL_PIN(S32G_IMCR_SIUL_EIRQ4),
+       S32_PINCTRL_PIN(S32G_IMCR_SIUL_EIRQ5),
+       S32_PINCTRL_PIN(S32G_IMCR_SIUL_EIRQ6),
+       S32_PINCTRL_PIN(S32G_IMCR_SIUL_EIRQ7),
+       S32_PINCTRL_PIN(S32G_IMCR_SIUL_EIRQ8),
+       S32_PINCTRL_PIN(S32G_IMCR_SIUL_EIRQ9),
+       S32_PINCTRL_PIN(S32G_IMCR_SIUL_EIRQ10),
+       S32_PINCTRL_PIN(S32G_IMCR_SIUL_EIRQ11),
+       S32_PINCTRL_PIN(S32G_IMCR_SIUL_EIRQ12),
+       S32_PINCTRL_PIN(S32G_IMCR_SIUL_EIRQ13),
+       S32_PINCTRL_PIN(S32G_IMCR_SIUL_EIRQ14),
+       S32_PINCTRL_PIN(S32G_IMCR_SIUL_EIRQ15),
+       S32_PINCTRL_PIN(S32G_IMCR_SIUL_EIRQ16),
+       S32_PINCTRL_PIN(S32G_IMCR_SIUL_EIRQ17),
+       S32_PINCTRL_PIN(S32G_IMCR_SIUL_EIRQ18),
+       S32_PINCTRL_PIN(S32G_IMCR_SIUL_EIRQ19),
+       S32_PINCTRL_PIN(S32G_IMCR_SIUL_EIRQ20),
+       S32_PINCTRL_PIN(S32G_IMCR_SIUL_EIRQ21),
+       S32_PINCTRL_PIN(S32G_IMCR_SIUL_EIRQ22),
+       S32_PINCTRL_PIN(S32G_IMCR_SIUL_EIRQ23),
+       S32_PINCTRL_PIN(S32G_IMCR_SIUL_EIRQ24),
+       S32_PINCTRL_PIN(S32G_IMCR_SIUL_EIRQ25),
+       S32_PINCTRL_PIN(S32G_IMCR_SIUL_EIRQ26),
+       S32_PINCTRL_PIN(S32G_IMCR_SIUL_EIRQ27),
+       S32_PINCTRL_PIN(S32G_IMCR_SIUL_EIRQ28),
+       S32_PINCTRL_PIN(S32G_IMCR_SIUL_EIRQ29),
+       S32_PINCTRL_PIN(S32G_IMCR_SIUL_EIRQ30),
+       S32_PINCTRL_PIN(S32G_IMCR_SIUL_EIRQ31),
+};
+
+static const struct s32_pin_range s32_pin_ranges_siul2[] = {
+       /* MSCR pin ID ranges */
+       S32_PIN_RANGE(0, 101),
+       S32_PIN_RANGE(112, 122),
+       S32_PIN_RANGE(144, 190),
+       /* IMCR pin ID ranges */
+       S32_PIN_RANGE(512, 595),
+       S32_PIN_RANGE(631, 909),
+       S32_PIN_RANGE(942, 1007),
+};
+
+static struct s32_pinctrl_soc_info s32_pinctrl_info = {
+       .pins = s32_pinctrl_pads_siul2,
+       .npins = ARRAY_SIZE(s32_pinctrl_pads_siul2),
+       .mem_pin_ranges = s32_pin_ranges_siul2,
+       .mem_regions = ARRAY_SIZE(s32_pin_ranges_siul2),
+};
+
+static const struct of_device_id s32_pinctrl_of_match[] = {
+       {
+
+               .compatible = "nxp,s32g2-siul2-pinctrl",
+               .data = (void *) &s32_pinctrl_info,
+       },
+       { /* sentinel */ }
+};
+MODULE_DEVICE_TABLE(of, s32_pinctrl_of_match);
+
+static int s32g_pinctrl_probe(struct platform_device *pdev)
+{
+       const struct of_device_id *of_id =
+               of_match_device(s32_pinctrl_of_match, &pdev->dev);
+
+       if (!of_id)
+               return -ENODEV;
+
+       return s32_pinctrl_probe
+                       (pdev, (struct s32_pinctrl_soc_info *) of_id->data);
+}
+
+static const struct dev_pm_ops s32g_pinctrl_pm_ops = {
+       LATE_SYSTEM_SLEEP_PM_OPS(s32_pinctrl_suspend, s32_pinctrl_resume)
+};
+
+static struct platform_driver s32g_pinctrl_driver = {
+       .driver = {
+               .name = "s32g-siul2-pinctrl",
+               .of_match_table = s32_pinctrl_of_match,
+               .pm = pm_sleep_ptr(&s32g_pinctrl_pm_ops),
+               .suppress_bind_attrs = true,
+       },
+       .probe = s32g_pinctrl_probe,
+};
+builtin_platform_driver(s32g_pinctrl_driver);
+
+MODULE_AUTHOR("Matthew Nunez <matthew.nunez@nxp.com>");
+MODULE_DESCRIPTION("NXP S32G pinctrl driver");
+MODULE_LICENSE("GPL");
index 0cc00e9dbcf01715c958f1060a7d56bba7710943..f279b360c20d38fbfb2a43829fefb80bba7d03d1 100644 (file)
@@ -206,15 +206,14 @@ static void amd_gpio_dbg_show(struct seq_file *s, struct gpio_chip *gc)
 
        char *level_trig;
        char *active_level;
-       char *interrupt_enable;
        char *interrupt_mask;
        char *wake_cntrl0;
        char *wake_cntrl1;
        char *wake_cntrl2;
        char *pin_sts;
+       char *interrupt_sts;
+       char *wake_sts;
        char *pull_up_sel;
-       char *pull_up_enable;
-       char *pull_down_enable;
        char *orientation;
        char debounce_value[40];
        char *debounce_enable;
@@ -246,6 +245,7 @@ static void amd_gpio_dbg_show(struct seq_file *s, struct gpio_chip *gc)
                        continue;
                }
                seq_printf(s, "GPIO bank%d\n", bank);
+               seq_puts(s, "gpio\t  int|active|trigger|S0i3| S3|S4/S5| Z|wake|pull|  orient|       debounce|reg\n");
                for (; i < pin_num; i++) {
                        seq_printf(s, "#%d\t", i);
                        raw_spin_lock_irqsave(&gpio_dev->lock, flags);
@@ -255,7 +255,6 @@ static void amd_gpio_dbg_show(struct seq_file *s, struct gpio_chip *gc)
                        if (pin_reg & BIT(INTERRUPT_ENABLE_OFF)) {
                                u8 level = (pin_reg >> ACTIVE_LEVEL_OFF) &
                                                ACTIVE_LEVEL_MASK;
-                               interrupt_enable = "+";
 
                                if (level == ACTIVE_LEVEL_HIGH)
                                        active_level = "↑";
@@ -272,65 +271,66 @@ static void amd_gpio_dbg_show(struct seq_file *s, struct gpio_chip *gc)
                                else
                                        level_trig = " edge";
 
-                       } else {
-                               interrupt_enable = "∅";
-                               active_level = "∅";
-                               level_trig = "    ∅";
-                       }
+                               if (pin_reg & BIT(INTERRUPT_MASK_OFF))
+                                       interrupt_mask = "😛";
+                               else
+                                       interrupt_mask = "😷";
 
-                       if (pin_reg & BIT(INTERRUPT_MASK_OFF))
-                               interrupt_mask = "😛";
-                       else
-                               interrupt_mask = "😷";
-                       seq_printf(s, "int %s (%s)| active-%s| %s-⚡| ",
-                                  interrupt_enable,
+                               if (pin_reg & BIT(INTERRUPT_STS_OFF))
+                                       interrupt_sts = "🔥";
+                               else
+                                       interrupt_sts = "  ";
+
+                               seq_printf(s, "%s %s|     %s|  %s|",
+                                  interrupt_sts,
                                   interrupt_mask,
                                   active_level,
                                   level_trig);
+                       } else
+                               seq_puts(s, "    ∅|      |       |");
 
                        if (pin_reg & BIT(WAKE_CNTRL_OFF_S0I3))
                                wake_cntrl0 = "⏰";
                        else
-                               wake_cntrl0 = " ";
-                       seq_printf(s, "S0i3 %s| ", wake_cntrl0);
+                               wake_cntrl0 = "  ";
+                       seq_printf(s, "  %s| ", wake_cntrl0);
 
                        if (pin_reg & BIT(WAKE_CNTRL_OFF_S3))
                                wake_cntrl1 = "⏰";
                        else
-                               wake_cntrl1 = " ";
-                       seq_printf(s, "S3 %s| ", wake_cntrl1);
+                               wake_cntrl1 = "  ";
+                       seq_printf(s, "%s|", wake_cntrl1);
 
                        if (pin_reg & BIT(WAKE_CNTRL_OFF_S4))
                                wake_cntrl2 = "⏰";
                        else
-                               wake_cntrl2 = " ";
-                       seq_printf(s, "S4/S5 %s| ", wake_cntrl2);
+                               wake_cntrl2 = "  ";
+                       seq_printf(s, "   %s|", wake_cntrl2);
 
                        if (pin_reg & BIT(WAKECNTRL_Z_OFF))
                                wake_cntrlz = "⏰";
                        else
-                               wake_cntrlz = " ∅";
-                       seq_printf(s, "Z %s| ", wake_cntrlz);
+                               wake_cntrlz = "  ";
+                       seq_printf(s, "%s|", wake_cntrlz);
+
+                       if (pin_reg & BIT(WAKE_STS_OFF))
+                               wake_sts = "🔥";
+                       else
+                               wake_sts = " ";
+                       seq_printf(s, "   %s|", wake_sts);
 
                        if (pin_reg & BIT(PULL_UP_ENABLE_OFF)) {
-                               pull_up_enable = "+";
                                if (pin_reg & BIT(PULL_UP_SEL_OFF))
                                        pull_up_sel = "8k";
                                else
                                        pull_up_sel = "4k";
-                       } else {
-                               pull_up_enable = "∅";
-                               pull_up_sel = "  ";
+                               seq_printf(s, "%s ↑|",
+                                          pull_up_sel);
+                       } else if (pin_reg & BIT(PULL_DOWN_ENABLE_OFF)) {
+                               seq_puts(s, "   ↓|");
+                       } else  {
+                               seq_puts(s, "    |");
                        }
-                       seq_printf(s, "pull-↑ %s (%s)| ",
-                                  pull_up_enable,
-                                  pull_up_sel);
-
-                       if (pin_reg & BIT(PULL_DOWN_ENABLE_OFF))
-                               pull_down_enable = "+";
-                       else
-                               pull_down_enable = "∅";
-                       seq_printf(s, "pull-↓ %s| ", pull_down_enable);
 
                        if (pin_reg & BIT(OUTPUT_ENABLE_OFF)) {
                                pin_sts = "output";
@@ -345,7 +345,7 @@ static void amd_gpio_dbg_show(struct seq_file *s, struct gpio_chip *gc)
                                else
                                        orientation = "↓";
                        }
-                       seq_printf(s, "%s %s| ", pin_sts, orientation);
+                       seq_printf(s, "%s %s|", pin_sts, orientation);
 
                        db_cntrl = (DB_CNTRl_MASK << DB_CNTRL_OFF) & pin_reg;
                        if (db_cntrl) {
@@ -364,19 +364,17 @@ static void amd_gpio_dbg_show(struct seq_file *s, struct gpio_chip *gc)
                                                unit = 61;
                                }
                                if ((DB_TYPE_REMOVE_GLITCH << DB_CNTRL_OFF) == db_cntrl)
-                                       debounce_enable = "b +";
+                                       debounce_enable = "b";
                                else if ((DB_TYPE_PRESERVE_LOW_GLITCH << DB_CNTRL_OFF) == db_cntrl)
-                                       debounce_enable = "↓ +";
+                                       debounce_enable = "↓";
                                else
-                                       debounce_enable = "↑ +";
-
+                                       debounce_enable = "↑";
+                               snprintf(debounce_value, sizeof(debounce_value), "%06u", time * unit);
+                               seq_printf(s, "%s (🕑 %sus)|", debounce_enable, debounce_value);
                        } else {
-                               debounce_enable = "  ∅";
-                               time = 0;
+                               seq_puts(s, "               |");
                        }
-                       snprintf(debounce_value, sizeof(debounce_value), "%u", time * unit);
-                       seq_printf(s, "debounce %s (🕑 %sus)| ", debounce_enable, debounce_value);
-                       seq_printf(s, " 0x%x\n", pin_reg);
+                       seq_printf(s, "0x%x\n", pin_reg);
                }
        }
 }
index c775d239444a6fcbf2dbcdf88c2a9aeb90e31edc..2fe40acb6a3e52377ab4bf6af9b6cd864a1b9d0a 100644 (file)
@@ -1067,7 +1067,6 @@ static int atmel_pinctrl_probe(struct platform_device *pdev)
        struct device *dev = &pdev->dev;
        struct pinctrl_pin_desc *pin_desc;
        const char **group_names;
-       const struct of_device_id *match;
        int i, ret;
        struct atmel_pioctrl *atmel_pioctrl;
        const struct atmel_pioctrl_data *atmel_pioctrl_data;
@@ -1079,12 +1078,10 @@ static int atmel_pinctrl_probe(struct platform_device *pdev)
        atmel_pioctrl->node = dev->of_node;
        platform_set_drvdata(pdev, atmel_pioctrl);
 
-       match = of_match_node(atmel_pctrl_of_match, dev->of_node);
-       if (!match) {
-               dev_err(dev, "unknown compatible string\n");
-               return -ENODEV;
-       }
-       atmel_pioctrl_data = match->data;
+       atmel_pioctrl_data = device_get_match_data(dev);
+       if (!atmel_pioctrl_data)
+               return dev_err_probe(dev, -ENODEV, "Invalid device data\n");
+
        atmel_pioctrl->nbanks = atmel_pioctrl_data->nbanks;
        atmel_pioctrl->npins = atmel_pioctrl->nbanks * ATMEL_PIO_NPINS_PER_BANK;
        /* if last bank has limited number of pins, adjust accordingly */
@@ -1098,11 +1095,9 @@ static int atmel_pinctrl_probe(struct platform_device *pdev)
        if (IS_ERR(atmel_pioctrl->reg_base))
                return PTR_ERR(atmel_pioctrl->reg_base);
 
-       atmel_pioctrl->clk = devm_clk_get(dev, NULL);
-       if (IS_ERR(atmel_pioctrl->clk)) {
-               dev_err(dev, "failed to get clock\n");
-               return PTR_ERR(atmel_pioctrl->clk);
-       }
+       atmel_pioctrl->clk = devm_clk_get_enabled(dev, NULL);
+       if (IS_ERR(atmel_pioctrl->clk))
+               return dev_err_probe(dev, PTR_ERR(atmel_pioctrl->clk), "failed to get clock\n");
 
        atmel_pioctrl->pins = devm_kcalloc(dev,
                                           atmel_pioctrl->npins,
@@ -1149,7 +1144,7 @@ static int atmel_pinctrl_probe(struct platform_device *pdev)
 
                pin_desc[i].number = i;
                /* Pin naming convention: P(bank_name)(bank_pin_number). */
-               pin_desc[i].name = devm_kasprintf(&pdev->dev, GFP_KERNEL, "P%c%d",
+               pin_desc[i].name = devm_kasprintf(&pdev->dev, GFP_KERNEL, "P%c%u",
                                                  bank + 'A', line);
 
                group->name = group_names[i] = pin_desc[i].name;
@@ -1202,10 +1197,8 @@ static int atmel_pinctrl_probe(struct platform_device *pdev)
        atmel_pioctrl->irq_domain = irq_domain_add_linear(dev->of_node,
                        atmel_pioctrl->gpio_chip->ngpio,
                        &irq_domain_simple_ops, NULL);
-       if (!atmel_pioctrl->irq_domain) {
-               dev_err(dev, "can't add the irq domain\n");
-               return -ENODEV;
-       }
+       if (!atmel_pioctrl->irq_domain)
+               return dev_err_probe(dev, -ENODEV, "can't add the irq domain\n");
 
        for (i = 0; i < atmel_pioctrl->npins; i++) {
                int irq = irq_create_mapping(atmel_pioctrl->irq_domain, i);
@@ -1218,25 +1211,19 @@ static int atmel_pinctrl_probe(struct platform_device *pdev)
                        i, irq);
        }
 
-       ret = clk_prepare_enable(atmel_pioctrl->clk);
-       if (ret) {
-               dev_err(dev, "failed to prepare and enable clock\n");
-               goto clk_prepare_enable_error;
-       }
-
        atmel_pioctrl->pinctrl_dev = devm_pinctrl_register(&pdev->dev,
                                                           &atmel_pinctrl_desc,
                                                           atmel_pioctrl);
        if (IS_ERR(atmel_pioctrl->pinctrl_dev)) {
                ret = PTR_ERR(atmel_pioctrl->pinctrl_dev);
                dev_err(dev, "pinctrl registration failed\n");
-               goto clk_unprep;
+               goto irq_domain_remove_error;
        }
 
        ret = gpiochip_add_data(atmel_pioctrl->gpio_chip, atmel_pioctrl);
        if (ret) {
                dev_err(dev, "failed to add gpiochip\n");
-               goto clk_unprep;
+               goto irq_domain_remove_error;
        }
 
        ret = gpiochip_add_pin_range(atmel_pioctrl->gpio_chip, dev_name(dev),
@@ -1253,10 +1240,7 @@ static int atmel_pinctrl_probe(struct platform_device *pdev)
 gpiochip_add_pin_range_error:
        gpiochip_remove(atmel_pioctrl->gpio_chip);
 
-clk_unprep:
-       clk_disable_unprepare(atmel_pioctrl->clk);
-
-clk_prepare_enable_error:
+irq_domain_remove_error:
        irq_domain_remove(atmel_pioctrl->irq_domain);
 
        return ret;
index 735c501e7a06c2ea95aeb372237bada9129e4c5d..871209c2415325d116a34e4a40bf645a524be908 100644 (file)
@@ -18,6 +18,7 @@
 #include <linux/pm.h>
 #include <linux/seq_file.h>
 #include <linux/slab.h>
+#include <linux/string_helpers.h>
 
 /* Since we request GPIOs from ourself */
 #include <linux/pinctrl/consumer.h>
@@ -41,7 +42,6 @@ struct at91_pinctrl_mux_ops;
  * @next: bank sharing same clock
  * @pioc_hwirq: PIO bank interrupt identifier on AIC
  * @pioc_virq: PIO bank Linux virtual interrupt
- * @pioc_idx: PIO bank index
  * @regbase: PIO bank virtual address
  * @clock: associated clock
  * @ops: at91 pinctrl mux ops
@@ -55,7 +55,6 @@ struct at91_gpio_chip {
        struct at91_gpio_chip   *next;
        int                     pioc_hwirq;
        int                     pioc_virq;
-       int                     pioc_idx;
        void __iomem            *regbase;
        struct clk              *clock;
        const struct at91_pinctrl_mux_ops *ops;
@@ -1293,18 +1292,18 @@ static const struct of_device_id at91_pinctrl_of_match[] = {
 static int at91_pinctrl_probe_dt(struct platform_device *pdev,
                                 struct at91_pinctrl *info)
 {
+       struct device *dev = &pdev->dev;
        int ret = 0;
        int i, j, ngpio_chips_enabled = 0;
        uint32_t *tmp;
-       struct device_node *np = pdev->dev.of_node;
+       struct device_node *np = dev->of_node;
        struct device_node *child;
 
        if (!np)
                return -ENODEV;
 
-       info->dev = &pdev->dev;
-       info->ops = (const struct at91_pinctrl_mux_ops *)
-               of_match_device(at91_pinctrl_of_match, &pdev->dev)->data;
+       info->dev = dev;
+       info->ops = of_device_get_match_data(dev);
        at91_pinctrl_child_count(info, np);
 
        /*
@@ -1323,35 +1322,31 @@ static int at91_pinctrl_probe_dt(struct platform_device *pdev,
        if (ret)
                return ret;
 
-       dev_dbg(&pdev->dev, "nmux = %d\n", info->nmux);
+       dev_dbg(dev, "nmux = %d\n", info->nmux);
 
-       dev_dbg(&pdev->dev, "mux-mask\n");
+       dev_dbg(dev, "mux-mask\n");
        tmp = info->mux_mask;
        for (i = 0; i < gpio_banks; i++) {
                for (j = 0; j < info->nmux; j++, tmp++) {
-                       dev_dbg(&pdev->dev, "%d:%d\t0x%x\n", i, j, tmp[0]);
+                       dev_dbg(dev, "%d:%d\t0x%x\n", i, j, tmp[0]);
                }
        }
 
-       dev_dbg(&pdev->dev, "nfunctions = %d\n", info->nfunctions);
-       dev_dbg(&pdev->dev, "ngroups = %d\n", info->ngroups);
-       info->functions = devm_kcalloc(&pdev->dev,
-                                       info->nfunctions,
-                                       sizeof(struct at91_pmx_func),
-                                       GFP_KERNEL);
+       dev_dbg(dev, "nfunctions = %d\n", info->nfunctions);
+       dev_dbg(dev, "ngroups = %d\n", info->ngroups);
+       info->functions = devm_kcalloc(dev, info->nfunctions, sizeof(*info->functions),
+                                      GFP_KERNEL);
        if (!info->functions)
                return -ENOMEM;
 
-       info->groups = devm_kcalloc(&pdev->dev,
-                                       info->ngroups,
-                                       sizeof(struct at91_pin_group),
-                                       GFP_KERNEL);
+       info->groups = devm_kcalloc(dev, info->ngroups, sizeof(*info->groups),
+                                   GFP_KERNEL);
        if (!info->groups)
                return -ENOMEM;
 
-       dev_dbg(&pdev->dev, "nbanks = %d\n", gpio_banks);
-       dev_dbg(&pdev->dev, "nfunctions = %d\n", info->nfunctions);
-       dev_dbg(&pdev->dev, "ngroups = %d\n", info->ngroups);
+       dev_dbg(dev, "nbanks = %d\n", gpio_banks);
+       dev_dbg(dev, "nfunctions = %d\n", info->nfunctions);
+       dev_dbg(dev, "ngroups = %d\n", info->ngroups);
 
        i = 0;
 
@@ -1360,9 +1355,8 @@ static int at91_pinctrl_probe_dt(struct platform_device *pdev,
                        continue;
                ret = at91_pinctrl_parse_functions(child, info, i++);
                if (ret) {
-                       dev_err(&pdev->dev, "failed to parse function\n");
                        of_node_put(child);
-                       return ret;
+                       return dev_err_probe(dev, ret, "failed to parse function\n");
                }
        }
 
@@ -1371,11 +1365,12 @@ static int at91_pinctrl_probe_dt(struct platform_device *pdev,
 
 static int at91_pinctrl_probe(struct platform_device *pdev)
 {
+       struct device *dev = &pdev->dev;
        struct at91_pinctrl *info;
        struct pinctrl_pin_desc *pdesc;
        int ret, i, j, k;
 
-       info = devm_kzalloc(&pdev->dev, sizeof(*info), GFP_KERNEL);
+       info = devm_kzalloc(dev, sizeof(*info), GFP_KERNEL);
        if (!info)
                return -ENOMEM;
 
@@ -1383,39 +1378,42 @@ static int at91_pinctrl_probe(struct platform_device *pdev)
        if (ret)
                return ret;
 
-       at91_pinctrl_desc.name = dev_name(&pdev->dev);
+       at91_pinctrl_desc.name = dev_name(dev);
        at91_pinctrl_desc.npins = gpio_banks * MAX_NB_GPIO_PER_BANK;
        at91_pinctrl_desc.pins = pdesc =
-               devm_kcalloc(&pdev->dev,
-                            at91_pinctrl_desc.npins, sizeof(*pdesc),
-                            GFP_KERNEL);
-
+               devm_kcalloc(dev, at91_pinctrl_desc.npins, sizeof(*pdesc), GFP_KERNEL);
        if (!at91_pinctrl_desc.pins)
                return -ENOMEM;
 
        for (i = 0, k = 0; i < gpio_banks; i++) {
+               char **names;
+
+               names = devm_kasprintf_strarray(dev, "pio", MAX_NB_GPIO_PER_BANK);
+               if (!names)
+                       return -ENOMEM;
+
                for (j = 0; j < MAX_NB_GPIO_PER_BANK; j++, k++) {
+                       char *name = names[j];
+
+                       strreplace(name, '-', i + 'A');
+
                        pdesc->number = k;
-                       pdesc->name = kasprintf(GFP_KERNEL, "pio%c%d", i + 'A', j);
+                       pdesc->name = name;
                        pdesc++;
                }
        }
 
        platform_set_drvdata(pdev, info);
-       info->pctl = devm_pinctrl_register(&pdev->dev, &at91_pinctrl_desc,
-                                          info);
-
-       if (IS_ERR(info->pctl)) {
-               dev_err(&pdev->dev, "could not register AT91 pinctrl driver\n");
-               return PTR_ERR(info->pctl);
-       }
+       info->pctl = devm_pinctrl_register(dev, &at91_pinctrl_desc, info);
+       if (IS_ERR(info->pctl))
+               return dev_err_probe(dev, PTR_ERR(info->pctl), "could not register AT91 pinctrl driver\n");
 
        /* We will handle a range of GPIO pins */
        for (i = 0; i < gpio_banks; i++)
                if (gpio_chips[i])
                        pinctrl_add_gpio_range(info->pctl, &gpio_chips[i]->range);
 
-       dev_info(&pdev->dev, "initialized AT91 pinctrl driver\n");
+       dev_info(dev, "initialized AT91 pinctrl driver\n");
 
        return 0;
 }
@@ -1526,6 +1524,20 @@ static void at91_gpio_dbg_show(struct seq_file *s, struct gpio_chip *chip)
 #define at91_gpio_dbg_show     NULL
 #endif
 
+static int gpio_irq_request_resources(struct irq_data *d)
+{
+       struct at91_gpio_chip *at91_gpio = irq_data_get_irq_chip_data(d);
+
+       return gpiochip_lock_as_irq(&at91_gpio->chip, irqd_to_hwirq(d));
+}
+
+static void gpio_irq_release_resources(struct irq_data *d)
+{
+       struct at91_gpio_chip *at91_gpio = irq_data_get_irq_chip_data(d);
+
+       gpiochip_unlock_as_irq(&at91_gpio->chip, irqd_to_hwirq(d));
+}
+
 /* Several AIC controller irqs are dispatched through this GPIO handler.
  * To use any AT91_PIN_* as an externally triggered IRQ, first call
  * at91_set_gpio_input() then maybe enable its glitch filter.
@@ -1545,6 +1557,9 @@ static void gpio_irq_mask(struct irq_data *d)
        struct at91_gpio_chip *at91_gpio = irq_data_get_irq_chip_data(d);
        void __iomem    *pio = at91_gpio->regbase;
        unsigned        mask = 1 << d->hwirq;
+       unsigned        gpio = irqd_to_hwirq(d);
+
+       gpiochip_disable_irq(&at91_gpio->chip, gpio);
 
        if (pio)
                writel_relaxed(mask, pio + PIO_IDR);
@@ -1555,6 +1570,9 @@ static void gpio_irq_unmask(struct irq_data *d)
        struct at91_gpio_chip *at91_gpio = irq_data_get_irq_chip_data(d);
        void __iomem    *pio = at91_gpio->regbase;
        unsigned        mask = 1 << d->hwirq;
+       unsigned        gpio = irqd_to_hwirq(d);
+
+       gpiochip_enable_irq(&at91_gpio->chip, gpio);
 
        if (pio)
                writel_relaxed(mask, pio + PIO_IER);
@@ -1706,6 +1724,7 @@ static void gpio_irq_handler(struct irq_desc *desc)
 static int at91_gpio_of_irq_setup(struct platform_device *pdev,
                                  struct at91_gpio_chip *at91_gpio)
 {
+       struct device           *dev = &pdev->dev;
        struct gpio_chip        *gpiochip_prev = NULL;
        struct at91_gpio_chip   *prev = NULL;
        struct irq_data         *d = irq_get_irq_data(at91_gpio->pioc_virq);
@@ -1713,20 +1732,22 @@ static int at91_gpio_of_irq_setup(struct platform_device *pdev,
        struct gpio_irq_chip    *girq;
        int i;
 
-       gpio_irqchip = devm_kzalloc(&pdev->dev, sizeof(*gpio_irqchip),
-                                   GFP_KERNEL);
+       gpio_irqchip = devm_kzalloc(dev, sizeof(*gpio_irqchip), GFP_KERNEL);
        if (!gpio_irqchip)
                return -ENOMEM;
 
        at91_gpio->pioc_hwirq = irqd_to_hwirq(d);
 
        gpio_irqchip->name = "GPIO";
+       gpio_irqchip->irq_request_resources = gpio_irq_request_resources;
+       gpio_irqchip->irq_release_resources = gpio_irq_release_resources;
        gpio_irqchip->irq_ack = gpio_irq_ack;
        gpio_irqchip->irq_disable = gpio_irq_mask;
        gpio_irqchip->irq_mask = gpio_irq_mask;
        gpio_irqchip->irq_unmask = gpio_irq_unmask;
        gpio_irqchip->irq_set_wake = pm_ptr(gpio_irq_set_wake);
        gpio_irqchip->irq_set_type = at91_gpio->ops->irq_type;
+       gpio_irqchip->flags = IRQCHIP_IMMUTABLE;
 
        /* Disable irqs of this PIO controller */
        writel_relaxed(~0, at91_gpio->regbase + PIO_IDR);
@@ -1737,7 +1758,7 @@ static int at91_gpio_of_irq_setup(struct platform_device *pdev,
         * interrupt.
         */
        girq = &at91_gpio->chip.irq;
-       girq->chip = gpio_irqchip;
+       gpio_irq_chip_set_chip(girq, gpio_irqchip);
        girq->default_type = IRQ_TYPE_NONE;
        girq->handler = handle_edge_irq;
 
@@ -1750,7 +1771,7 @@ static int at91_gpio_of_irq_setup(struct platform_device *pdev,
        if (!gpiochip_prev) {
                girq->parent_handler = gpio_irq_handler;
                girq->num_parents = 1;
-               girq->parents = devm_kcalloc(&pdev->dev, 1,
+               girq->parents = devm_kcalloc(dev, girq->num_parents,
                                             sizeof(*girq->parents),
                                             GFP_KERNEL);
                if (!girq->parents)
@@ -1797,7 +1818,8 @@ static const struct of_device_id at91_gpio_of_match[] = {
 
 static int at91_gpio_probe(struct platform_device *pdev)
 {
-       struct device_node *np = pdev->dev.of_node;
+       struct device *dev = &pdev->dev;
+       struct device_node *np = dev->of_node;
        struct at91_gpio_chip *at91_chip = NULL;
        struct gpio_chip *chip;
        struct pinctrl_gpio_range *range;
@@ -1808,74 +1830,51 @@ static int at91_gpio_probe(struct platform_device *pdev)
        char **names;
 
        BUG_ON(alias_idx >= ARRAY_SIZE(gpio_chips));
-       if (gpio_chips[alias_idx]) {
-               ret = -EBUSY;
-               goto err;
-       }
+       if (gpio_chips[alias_idx])
+               return dev_err_probe(dev, -EBUSY, "%d slot is occupied.\n", alias_idx);
 
        irq = platform_get_irq(pdev, 0);
-       if (irq < 0) {
-               ret = irq;
-               goto err;
-       }
+       if (irq < 0)
+               return irq;
 
-       at91_chip = devm_kzalloc(&pdev->dev, sizeof(*at91_chip), GFP_KERNEL);
-       if (!at91_chip) {
-               ret = -ENOMEM;
-               goto err;
-       }
+       at91_chip = devm_kzalloc(dev, sizeof(*at91_chip), GFP_KERNEL);
+       if (!at91_chip)
+               return -ENOMEM;
 
        at91_chip->regbase = devm_platform_ioremap_resource(pdev, 0);
-       if (IS_ERR(at91_chip->regbase)) {
-               ret = PTR_ERR(at91_chip->regbase);
-               goto err;
-       }
+       if (IS_ERR(at91_chip->regbase))
+               return PTR_ERR(at91_chip->regbase);
 
-       at91_chip->ops = (const struct at91_pinctrl_mux_ops *)
-               of_match_device(at91_gpio_of_match, &pdev->dev)->data;
+       at91_chip->ops = of_device_get_match_data(dev);
        at91_chip->pioc_virq = irq;
-       at91_chip->pioc_idx = alias_idx;
 
-       at91_chip->clock = devm_clk_get(&pdev->dev, NULL);
-       if (IS_ERR(at91_chip->clock)) {
-               dev_err(&pdev->dev, "failed to get clock, ignoring.\n");
-               ret = PTR_ERR(at91_chip->clock);
-               goto err;
-       }
-
-       ret = clk_prepare_enable(at91_chip->clock);
-       if (ret) {
-               dev_err(&pdev->dev, "failed to prepare and enable clock, ignoring.\n");
-               goto clk_enable_err;
-       }
+       at91_chip->clock = devm_clk_get_enabled(dev, NULL);
+       if (IS_ERR(at91_chip->clock))
+               return dev_err_probe(dev, PTR_ERR(at91_chip->clock), "failed to get clock, ignoring.\n");
 
        at91_chip->chip = at91_gpio_template;
        at91_chip->id = alias_idx;
 
        chip = &at91_chip->chip;
-       chip->label = dev_name(&pdev->dev);
-       chip->parent = &pdev->dev;
+       chip->label = dev_name(dev);
+       chip->parent = dev;
        chip->owner = THIS_MODULE;
        chip->base = alias_idx * MAX_NB_GPIO_PER_BANK;
 
        if (!of_property_read_u32(np, "#gpio-lines", &ngpio)) {
                if (ngpio >= MAX_NB_GPIO_PER_BANK)
-                       pr_err("at91_gpio.%d, gpio-nb >= %d failback to %d\n",
-                              alias_idx, MAX_NB_GPIO_PER_BANK, MAX_NB_GPIO_PER_BANK);
+                       dev_err(dev, "at91_gpio.%d, gpio-nb >= %d failback to %d\n",
+                               alias_idx, MAX_NB_GPIO_PER_BANK, MAX_NB_GPIO_PER_BANK);
                else
                        chip->ngpio = ngpio;
        }
 
-       names = devm_kcalloc(&pdev->dev, chip->ngpio, sizeof(char *),
-                            GFP_KERNEL);
-
-       if (!names) {
-               ret = -ENOMEM;
-               goto clk_enable_err;
-       }
+       names = devm_kasprintf_strarray(dev, "pio", chip->ngpio);
+       if (!names)
+               return -ENOMEM;
 
        for (i = 0; i < chip->ngpio; i++)
-               names[i] = devm_kasprintf(&pdev->dev, GFP_KERNEL, "pio%c%d", alias_idx + 'A', i);
+               strreplace(names[i], '-', alias_idx + 'A');
 
        chip->names = (const char *const *)names;
 
@@ -1889,27 +1888,19 @@ static int at91_gpio_probe(struct platform_device *pdev)
 
        ret = at91_gpio_of_irq_setup(pdev, at91_chip);
        if (ret)
-               goto gpiochip_add_err;
+               return ret;
 
        ret = gpiochip_add_data(chip, at91_chip);
        if (ret)
-               goto gpiochip_add_err;
+               return ret;
 
        gpio_chips[alias_idx] = at91_chip;
        platform_set_drvdata(pdev, at91_chip);
        gpio_banks = max(gpio_banks, alias_idx + 1);
 
-       dev_info(&pdev->dev, "at address %p\n", at91_chip->regbase);
+       dev_info(dev, "at address %p\n", at91_chip->regbase);
 
        return 0;
-
-gpiochip_add_err:
-clk_enable_err:
-       clk_disable_unprepare(at91_chip->clock);
-err:
-       dev_err(&pdev->dev, "Failure %i for GPIO %i\n", ret, alias_idx);
-
-       return ret;
 }
 
 static const struct dev_pm_ops at91_gpio_pm_ops = {
index 99cf24eb67ae661ef17531bbc3dcda0be4c997b7..5b5ddf7e5d0eb10a9ec8cc4154f29e8fe895e7ee 100644 (file)
@@ -32,6 +32,7 @@ static void eqbr_gpio_disable_irq(struct irq_data *d)
        raw_spin_lock_irqsave(&gctrl->lock, flags);
        writel(BIT(offset), gctrl->membase + GPIO_IRNENCLR);
        raw_spin_unlock_irqrestore(&gctrl->lock, flags);
+       gpiochip_disable_irq(gc, offset);
 }
 
 static void eqbr_gpio_enable_irq(struct irq_data *d)
@@ -42,6 +43,7 @@ static void eqbr_gpio_enable_irq(struct irq_data *d)
        unsigned long flags;
 
        gc->direction_input(gc, offset);
+       gpiochip_enable_irq(gc, offset);
        raw_spin_lock_irqsave(&gctrl->lock, flags);
        writel(BIT(offset), gctrl->membase + GPIO_IRNRNSET);
        raw_spin_unlock_irqrestore(&gctrl->lock, flags);
@@ -161,6 +163,17 @@ static void eqbr_irq_handler(struct irq_desc *desc)
        chained_irq_exit(ic, desc);
 }
 
+static const struct irq_chip eqbr_irq_chip = {
+       .name = "gpio_irq",
+       .irq_mask = eqbr_gpio_disable_irq,
+       .irq_unmask = eqbr_gpio_enable_irq,
+       .irq_ack = eqbr_gpio_ack_irq,
+       .irq_mask_ack = eqbr_gpio_mask_ack_irq,
+       .irq_set_type = eqbr_gpio_set_irq_type,
+       .flags = IRQCHIP_IMMUTABLE,
+       GPIOCHIP_IRQ_RESOURCE_HELPERS,
+};
+
 static int gpiochip_setup(struct device *dev, struct eqbr_gpio_ctrl *gctrl)
 {
        struct gpio_irq_chip *girq;
@@ -176,15 +189,8 @@ static int gpiochip_setup(struct device *dev, struct eqbr_gpio_ctrl *gctrl)
                return 0;
        }
 
-       gctrl->ic.name = "gpio_irq";
-       gctrl->ic.irq_mask = eqbr_gpio_disable_irq;
-       gctrl->ic.irq_unmask = eqbr_gpio_enable_irq;
-       gctrl->ic.irq_ack = eqbr_gpio_ack_irq;
-       gctrl->ic.irq_mask_ack = eqbr_gpio_mask_ack_irq;
-       gctrl->ic.irq_set_type = eqbr_gpio_set_irq_type;
-
        girq = &gctrl->chip.irq;
-       girq->chip = &gctrl->ic;
+       gpio_irq_chip_set_chip(girq, &eqbr_irq_chip);
        girq->parent_handler = eqbr_irq_handler;
        girq->num_parents = 1;
        girq->parents = devm_kcalloc(dev, 1, sizeof(*girq->parents), GFP_KERNEL);
index 0c635a5b79f019fc2cebb1f8cc9f1f64f0b9b236..83768cc8b3db2dcd69965db15e82a48c42a2373b 100644 (file)
@@ -103,7 +103,6 @@ struct fwnode_handle;
  * @fwnode: firmware node of gpio controller.
  * @bank: pointer to corresponding pin bank.
  * @membase: base address of the gpio controller.
- * @ic:   irq chip.
  * @name: gpio chip name.
  * @virq: irq number of the gpio chip to parent's irq domain.
  * @lock: spin lock to protect gpio register write.
@@ -113,7 +112,6 @@ struct eqbr_gpio_ctrl {
        struct fwnode_handle    *fwnode;
        struct eqbr_pin_bank    *bank;
        void __iomem            *membase;
-       struct irq_chip         ic;
        const char              *name;
        unsigned int            virq;
        raw_spinlock_t          lock; /* protect gpio register */
index 5f356edfd0fd56d84ae8730881dc17322c6d13b1..4551575e4e7d7d59475751bd6d15b4cdfea9dc5e 100644 (file)
@@ -10,6 +10,7 @@
 #include <linux/export.h>
 #include <linux/gpio/driver.h>
 #include <linux/gpio/consumer.h>
+#include <linux/seq_file.h>
 #include <linux/slab.h>
 #include <asm/byteorder.h>
 #include <linux/interrupt.h>
@@ -144,10 +145,9 @@ static int mcp_write(struct mcp23s08 *mcp, unsigned int reg, unsigned int val)
        return regmap_write(mcp->regmap, reg << mcp->reg_shift, val);
 }
 
-static int mcp_set_mask(struct mcp23s08 *mcp, unsigned int reg,
-                      unsigned int mask, bool enabled)
+static int mcp_update_bits(struct mcp23s08 *mcp, unsigned int reg,
+                          unsigned int mask, unsigned int val)
 {
-       u16 val  = enabled ? 0xffff : 0x0000;
        return regmap_update_bits(mcp->regmap, reg << mcp->reg_shift,
                                  mask, val);
 }
@@ -156,7 +156,7 @@ static int mcp_set_bit(struct mcp23s08 *mcp, unsigned int reg,
                       unsigned int pin, bool enabled)
 {
        u16 mask = BIT(pin);
-       return mcp_set_mask(mcp, reg, mask, enabled);
+       return mcp_update_bits(mcp, reg, mask, enabled ? mask : 0);
 }
 
 static const struct pinctrl_pin_desc mcp23x08_pins[] = {
@@ -308,9 +308,31 @@ static int mcp23s08_get(struct gpio_chip *chip, unsigned offset)
        return status;
 }
 
+static int mcp23s08_get_multiple(struct gpio_chip *chip,
+                                unsigned long *mask, unsigned long *bits)
+{
+       struct mcp23s08 *mcp = gpiochip_get_data(chip);
+       unsigned int status;
+       int ret;
+
+       mutex_lock(&mcp->lock);
+
+       /* REVISIT reading this clears any IRQ ... */
+       ret = mcp_read(mcp, MCP_GPIO, &status);
+       if (ret < 0)
+               status = 0;
+       else {
+               mcp->cached_gpio = status;
+               *bits = status;
+       }
+
+       mutex_unlock(&mcp->lock);
+       return ret;
+}
+
 static int __mcp23s08_set(struct mcp23s08 *mcp, unsigned mask, bool value)
 {
-       return mcp_set_mask(mcp, MCP_OLAT, mask, value);
+       return mcp_update_bits(mcp, MCP_OLAT, mask, value ? mask : 0);
 }
 
 static void mcp23s08_set(struct gpio_chip *chip, unsigned offset, int value)
@@ -323,6 +345,16 @@ static void mcp23s08_set(struct gpio_chip *chip, unsigned offset, int value)
        mutex_unlock(&mcp->lock);
 }
 
+static void mcp23s08_set_multiple(struct gpio_chip *chip,
+                                 unsigned long *mask, unsigned long *bits)
+{
+       struct mcp23s08 *mcp = gpiochip_get_data(chip);
+
+       mutex_lock(&mcp->lock);
+       mcp_update_bits(mcp, MCP_OLAT, *mask, *bits);
+       mutex_unlock(&mcp->lock);
+}
+
 static int
 mcp23s08_direction_output(struct gpio_chip *chip, unsigned offset, int value)
 {
@@ -333,7 +365,7 @@ mcp23s08_direction_output(struct gpio_chip *chip, unsigned offset, int value)
        mutex_lock(&mcp->lock);
        status = __mcp23s08_set(mcp, mask, value);
        if (status == 0) {
-               status = mcp_set_mask(mcp, MCP_IODIR, mask, false);
+               status = mcp_update_bits(mcp, MCP_IODIR, mask, 0);
        }
        mutex_unlock(&mcp->lock);
        return status;
@@ -436,17 +468,19 @@ static void mcp23s08_irq_mask(struct irq_data *data)
 {
        struct gpio_chip *gc = irq_data_get_irq_chip_data(data);
        struct mcp23s08 *mcp = gpiochip_get_data(gc);
-       unsigned int pos = data->hwirq;
+       unsigned int pos = irqd_to_hwirq(data);
 
        mcp_set_bit(mcp, MCP_GPINTEN, pos, false);
+       gpiochip_disable_irq(gc, pos);
 }
 
 static void mcp23s08_irq_unmask(struct irq_data *data)
 {
        struct gpio_chip *gc = irq_data_get_irq_chip_data(data);
        struct mcp23s08 *mcp = gpiochip_get_data(gc);
-       unsigned int pos = data->hwirq;
+       unsigned int pos = irqd_to_hwirq(data);
 
+       gpiochip_enable_irq(gc, pos);
        mcp_set_bit(mcp, MCP_GPINTEN, pos, true);
 }
 
@@ -454,7 +488,7 @@ static int mcp23s08_irq_set_type(struct irq_data *data, unsigned int type)
 {
        struct gpio_chip *gc = irq_data_get_irq_chip_data(data);
        struct mcp23s08 *mcp = gpiochip_get_data(gc);
-       unsigned int pos = data->hwirq;
+       unsigned int pos = irqd_to_hwirq(data);
 
        if ((type & IRQ_TYPE_EDGE_BOTH) == IRQ_TYPE_EDGE_BOTH) {
                mcp_set_bit(mcp, MCP_INTCON, pos, false);
@@ -523,6 +557,25 @@ static int mcp23s08_irq_setup(struct mcp23s08 *mcp)
        return 0;
 }
 
+static void mcp23s08_irq_print_chip(struct irq_data *d, struct seq_file *p)
+{
+       struct gpio_chip *gc = irq_data_get_irq_chip_data(d);
+       struct mcp23s08 *mcp = gpiochip_get_data(gc);
+
+       seq_printf(p, dev_name(mcp->dev));
+}
+
+static const struct irq_chip mcp23s08_irq_chip = {
+       .irq_mask = mcp23s08_irq_mask,
+       .irq_unmask = mcp23s08_irq_unmask,
+       .irq_set_type = mcp23s08_irq_set_type,
+       .irq_bus_lock = mcp23s08_irq_bus_lock,
+       .irq_bus_sync_unlock = mcp23s08_irq_bus_unlock,
+       .irq_print_chip = mcp23s08_irq_print_chip,
+       .flags = IRQCHIP_IMMUTABLE,
+       GPIOCHIP_IRQ_RESOURCE_HELPERS,
+};
+
 /*----------------------------------------------------------------------*/
 
 int mcp23s08_probe_one(struct mcp23s08 *mcp, struct device *dev,
@@ -538,17 +591,13 @@ int mcp23s08_probe_one(struct mcp23s08 *mcp, struct device *dev,
        mcp->addr = addr;
 
        mcp->irq_active_high = false;
-       mcp->irq_chip.name = dev_name(dev);
-       mcp->irq_chip.irq_mask = mcp23s08_irq_mask;
-       mcp->irq_chip.irq_unmask = mcp23s08_irq_unmask;
-       mcp->irq_chip.irq_set_type = mcp23s08_irq_set_type;
-       mcp->irq_chip.irq_bus_lock = mcp23s08_irq_bus_lock;
-       mcp->irq_chip.irq_bus_sync_unlock = mcp23s08_irq_bus_unlock;
 
        mcp->chip.direction_input = mcp23s08_direction_input;
        mcp->chip.get = mcp23s08_get;
+       mcp->chip.get_multiple = mcp23s08_get_multiple;
        mcp->chip.direction_output = mcp23s08_direction_output;
        mcp->chip.set = mcp23s08_set;
+       mcp->chip.set_multiple = mcp23s08_set_multiple;
 
        mcp->chip.base = base;
        mcp->chip.can_sleep = true;
@@ -603,7 +652,7 @@ int mcp23s08_probe_one(struct mcp23s08 *mcp, struct device *dev,
        if (mcp->irq && mcp->irq_controller) {
                struct gpio_irq_chip *girq = &mcp->chip.irq;
 
-               girq->chip = &mcp->irq_chip;
+               gpio_irq_chip_set_chip(girq, &mcp23s08_irq_chip);
                /* This will let us handle the parent IRQ in the driver */
                girq->parent_handler = NULL;
                girq->num_parents = 0;
index b8d15939e0c2c0e668dd97f36678c31bf480fbad..b15516af7783441bc1e133637e7fb66d4fb50f23 100644 (file)
@@ -36,7 +36,6 @@ struct mcp23s08 {
        struct mutex            lock;
 
        struct gpio_chip        chip;
-       struct irq_chip         irq_chip;
 
        struct regmap           *regmap;
        struct device           *dev;
diff --git a/drivers/pinctrl/pinctrl-mlxbf3.c b/drivers/pinctrl/pinctrl-mlxbf3.c
new file mode 100644 (file)
index 0000000..d9944e6
--- /dev/null
@@ -0,0 +1,320 @@
+// SPDX-License-Identifier: GPL-2.0-only or BSD-3-Clause
+/* Copyright (C) 2022 NVIDIA CORPORATION & AFFILIATES */
+
+#include <linux/bitfield.h>
+#include <linux/bitops.h>
+#include <linux/err.h>
+#include <linux/io.h>
+#include <linux/module.h>
+#include <linux/mod_devicetable.h>
+#include <linux/platform_device.h>
+#include <linux/types.h>
+
+#include <linux/pinctrl/pinctrl.h>
+#include <linux/pinctrl/pinmux.h>
+
+#define MLXBF3_NGPIOS_GPIO0    32
+#define MLXBF3_MAX_GPIO_PINS   56
+
+enum {
+       MLXBF3_GPIO_HW_MODE,
+       MLXBF3_GPIO_SW_MODE,
+};
+
+struct mlxbf3_pinctrl {
+       void __iomem *fw_ctrl_set0;
+       void __iomem *fw_ctrl_clr0;
+       void __iomem *fw_ctrl_set1;
+       void __iomem *fw_ctrl_clr1;
+       struct device *dev;
+       struct pinctrl_dev *pctl;
+       struct pinctrl_gpio_range gpio_range;
+};
+
+#define MLXBF3_GPIO_RANGE(_id, _pinbase, _gpiobase, _npins)    \
+       {                                                       \
+               .name = "mlxbf3_gpio_range",                    \
+               .id = _id,                                      \
+               .base = _gpiobase,                              \
+               .pin_base = _pinbase,                           \
+               .npins = _npins,                                \
+       }
+
+static struct pinctrl_gpio_range mlxbf3_pinctrl_gpio_ranges[] = {
+       MLXBF3_GPIO_RANGE(0, 0,  480, 32),
+       MLXBF3_GPIO_RANGE(1,  32, 456, 24),
+};
+
+static const struct pinctrl_pin_desc mlxbf3_pins[] = {
+       PINCTRL_PIN(0, "gpio0"),
+       PINCTRL_PIN(1, "gpio1"),
+       PINCTRL_PIN(2, "gpio2"),
+       PINCTRL_PIN(3, "gpio3"),
+       PINCTRL_PIN(4, "gpio4"),
+       PINCTRL_PIN(5, "gpio5"),
+       PINCTRL_PIN(6, "gpio6"),
+       PINCTRL_PIN(7, "gpio7"),
+       PINCTRL_PIN(8, "gpio8"),
+       PINCTRL_PIN(9, "gpio9"),
+       PINCTRL_PIN(10, "gpio10"),
+       PINCTRL_PIN(11, "gpio11"),
+       PINCTRL_PIN(12, "gpio12"),
+       PINCTRL_PIN(13, "gpio13"),
+       PINCTRL_PIN(14, "gpio14"),
+       PINCTRL_PIN(15, "gpio15"),
+       PINCTRL_PIN(16, "gpio16"),
+       PINCTRL_PIN(17, "gpio17"),
+       PINCTRL_PIN(18, "gpio18"),
+       PINCTRL_PIN(19, "gpio19"),
+       PINCTRL_PIN(20, "gpio20"),
+       PINCTRL_PIN(21, "gpio21"),
+       PINCTRL_PIN(22, "gpio22"),
+       PINCTRL_PIN(23, "gpio23"),
+       PINCTRL_PIN(24, "gpio24"),
+       PINCTRL_PIN(25, "gpio25"),
+       PINCTRL_PIN(26, "gpio26"),
+       PINCTRL_PIN(27, "gpio27"),
+       PINCTRL_PIN(28, "gpio28"),
+       PINCTRL_PIN(29, "gpio29"),
+       PINCTRL_PIN(30, "gpio30"),
+       PINCTRL_PIN(31, "gpio31"),
+       PINCTRL_PIN(32, "gpio32"),
+       PINCTRL_PIN(33, "gpio33"),
+       PINCTRL_PIN(34, "gpio34"),
+       PINCTRL_PIN(35, "gpio35"),
+       PINCTRL_PIN(36, "gpio36"),
+       PINCTRL_PIN(37, "gpio37"),
+       PINCTRL_PIN(38, "gpio38"),
+       PINCTRL_PIN(39, "gpio39"),
+       PINCTRL_PIN(40, "gpio40"),
+       PINCTRL_PIN(41, "gpio41"),
+       PINCTRL_PIN(42, "gpio42"),
+       PINCTRL_PIN(43, "gpio43"),
+       PINCTRL_PIN(44, "gpio44"),
+       PINCTRL_PIN(45, "gpio45"),
+       PINCTRL_PIN(46, "gpio46"),
+       PINCTRL_PIN(47, "gpio47"),
+       PINCTRL_PIN(48, "gpio48"),
+       PINCTRL_PIN(49, "gpio49"),
+       PINCTRL_PIN(50, "gpio50"),
+       PINCTRL_PIN(51, "gpio51"),
+       PINCTRL_PIN(52, "gpio52"),
+       PINCTRL_PIN(53, "gpio53"),
+       PINCTRL_PIN(54, "gpio54"),
+       PINCTRL_PIN(55, "gpio55"),
+};
+
+/*
+ * All single-pin functions can be mapped to any GPIO, however pinmux applies
+ * functions to pin groups and only those groups declared as supporting that
+ * function. To make this work we must put each pin in its own dummy group so
+ * that the functions can be described as applying to all pins.
+ * We use the same name as in the datasheet.
+ */
+static const char * const mlxbf3_pinctrl_single_group_names[] = {
+       "gpio0", "gpio1",  "gpio2",  "gpio3",  "gpio4",  "gpio5",  "gpio6", "gpio7",
+       "gpio8",  "gpio9",  "gpio10", "gpio11", "gpio12", "gpio13", "gpio14", "gpio15",
+       "gpio16", "gpio17", "gpio18", "gpio19", "gpio20", "gpio21", "gpio22", "gpio23",
+       "gpio24", "gpio25", "gpio26", "gpio27", "gpio28", "gpio29", "gpio30", "gpio31",
+       "gpio32", "gpio33", "gpio34", "gpio35", "gpio36", "gpio37", "gpio38", "gpio39",
+       "gpio40", "gpio41", "gpio42", "gpio43", "gpio44", "gpio45", "gpio46", "gpio47",
+       "gpio48", "gpio49", "gpio50", "gpio51", "gpio52", "gpio53", "gpio54", "gpio55",
+};
+
+static int mlxbf3_get_groups_count(struct pinctrl_dev *pctldev)
+{
+       /* Number single-pin groups */
+       return MLXBF3_MAX_GPIO_PINS;
+}
+
+static const char *mlxbf3_get_group_name(struct pinctrl_dev *pctldev,
+                                        unsigned int selector)
+{
+       return mlxbf3_pinctrl_single_group_names[selector];
+}
+
+static int mlxbf3_get_group_pins(struct pinctrl_dev *pctldev,
+                                unsigned int selector,
+                                const unsigned int **pins,
+                                unsigned int *num_pins)
+{
+       /* return the dummy group for a single pin */
+       *pins = &selector;
+       *num_pins = 1;
+
+       return 0;
+}
+
+static const struct pinctrl_ops mlxbf3_pinctrl_group_ops = {
+       .get_groups_count = mlxbf3_get_groups_count,
+       .get_group_name = mlxbf3_get_group_name,
+       .get_group_pins = mlxbf3_get_group_pins,
+};
+
+/*
+ * Only 2 functions are supported and they apply to all pins:
+ * 1) Default hardware functionality
+ * 2) Software controlled GPIO
+ */
+static const char * const mlxbf3_gpiofunc_group_names[] = { "swctrl" };
+static const char * const mlxbf3_hwfunc_group_names[]   = { "hwctrl" };
+
+static struct pinfunction mlxbf3_pmx_funcs[] = {
+       PINCTRL_PINFUNCTION("hwfunc", mlxbf3_hwfunc_group_names, 1),
+       PINCTRL_PINFUNCTION("gpiofunc", mlxbf3_gpiofunc_group_names, 1),
+};
+
+static int mlxbf3_pmx_get_funcs_count(struct pinctrl_dev *pctldev)
+{
+       return ARRAY_SIZE(mlxbf3_pmx_funcs);
+}
+
+static const char *mlxbf3_pmx_get_func_name(struct pinctrl_dev *pctldev,
+                                          unsigned int selector)
+{
+       return mlxbf3_pmx_funcs[selector].name;
+}
+
+static int mlxbf3_pmx_get_groups(struct pinctrl_dev *pctldev,
+                                unsigned int selector,
+                                const char * const **groups,
+                                unsigned int * const num_groups)
+{
+       *groups = mlxbf3_pmx_funcs[selector].groups;
+       *num_groups = MLXBF3_MAX_GPIO_PINS;
+
+       return 0;
+}
+
+static int mlxbf3_pmx_set(struct pinctrl_dev *pctldev,
+                             unsigned int selector,
+                             unsigned int group)
+{
+       struct mlxbf3_pinctrl *priv = pinctrl_dev_get_drvdata(pctldev);
+
+       if (selector == MLXBF3_GPIO_HW_MODE) {
+               if (group < MLXBF3_NGPIOS_GPIO0)
+                       writel(BIT(group), priv->fw_ctrl_clr0);
+               else
+                       writel(BIT(group % MLXBF3_NGPIOS_GPIO0), priv->fw_ctrl_clr1);
+       }
+
+       if (selector == MLXBF3_GPIO_SW_MODE) {
+               if (group < MLXBF3_NGPIOS_GPIO0)
+                       writel(BIT(group), priv->fw_ctrl_set0);
+               else
+                       writel(BIT(group % MLXBF3_NGPIOS_GPIO0), priv->fw_ctrl_set1);
+       }
+
+       return 0;
+}
+
+static int mlxbf3_gpio_request_enable(struct pinctrl_dev *pctldev,
+                                    struct pinctrl_gpio_range *range,
+                                    unsigned int offset)
+{
+       struct mlxbf3_pinctrl *priv = pinctrl_dev_get_drvdata(pctldev);
+
+       if (offset < MLXBF3_NGPIOS_GPIO0)
+               writel(BIT(offset), priv->fw_ctrl_set0);
+       else
+               writel(BIT(offset % MLXBF3_NGPIOS_GPIO0), priv->fw_ctrl_set1);
+
+       return 0;
+}
+
+static void mlxbf3_gpio_disable_free(struct pinctrl_dev *pctldev,
+                                   struct pinctrl_gpio_range *range,
+                                   unsigned int offset)
+{
+       struct mlxbf3_pinctrl *priv = pinctrl_dev_get_drvdata(pctldev);
+
+       /* disable GPIO functionality by giving control back to hardware */
+       if (offset < MLXBF3_NGPIOS_GPIO0)
+               writel(BIT(offset), priv->fw_ctrl_clr0);
+       else
+               writel(BIT(offset % MLXBF3_NGPIOS_GPIO0), priv->fw_ctrl_clr1);
+}
+
+static const struct pinmux_ops mlxbf3_pmx_ops = {
+       .get_functions_count = mlxbf3_pmx_get_funcs_count,
+       .get_function_name = mlxbf3_pmx_get_func_name,
+       .get_function_groups = mlxbf3_pmx_get_groups,
+       .set_mux = mlxbf3_pmx_set,
+       .gpio_request_enable = mlxbf3_gpio_request_enable,
+       .gpio_disable_free = mlxbf3_gpio_disable_free,
+};
+
+static struct pinctrl_desc mlxbf3_pin_desc = {
+       .name = "pinctrl-mlxbf3",
+       .pins = mlxbf3_pins,
+       .npins = ARRAY_SIZE(mlxbf3_pins),
+       .pctlops = &mlxbf3_pinctrl_group_ops,
+       .pmxops = &mlxbf3_pmx_ops,
+       .owner = THIS_MODULE,
+};
+
+static_assert(ARRAY_SIZE(mlxbf3_pinctrl_single_group_names) == MLXBF3_MAX_GPIO_PINS);
+
+static int mlxbf3_pinctrl_probe(struct platform_device *pdev)
+{
+       struct device *dev = &pdev->dev;
+       struct mlxbf3_pinctrl *priv;
+       int ret;
+
+       priv = devm_kzalloc(dev, sizeof(*priv), GFP_KERNEL);
+       if (!priv)
+               return -ENOMEM;
+
+       priv->dev = &pdev->dev;
+
+       priv->fw_ctrl_set0 = devm_platform_ioremap_resource(pdev, 0);
+       if (IS_ERR(priv->fw_ctrl_set0))
+               return PTR_ERR(priv->fw_ctrl_set0);
+
+       priv->fw_ctrl_clr0 = devm_platform_ioremap_resource(pdev, 1);
+       if (IS_ERR(priv->fw_ctrl_set0))
+               return PTR_ERR(priv->fw_ctrl_set0);
+
+       priv->fw_ctrl_set1 = devm_platform_ioremap_resource(pdev, 2);
+       if (IS_ERR(priv->fw_ctrl_set0))
+               return PTR_ERR(priv->fw_ctrl_set0);
+
+       priv->fw_ctrl_clr1 = devm_platform_ioremap_resource(pdev, 3);
+       if (IS_ERR(priv->fw_ctrl_set0))
+               return PTR_ERR(priv->fw_ctrl_set0);
+
+       ret = devm_pinctrl_register_and_init(dev,
+                                            &mlxbf3_pin_desc,
+                                            priv,
+                                            &priv->pctl);
+       if (ret)
+               return dev_err_probe(dev, ret, "Failed to register pinctrl\n");
+
+       ret = pinctrl_enable(priv->pctl);
+       if (ret)
+               return dev_err_probe(dev, ret, "Failed to enable pinctrl\n");
+
+       pinctrl_add_gpio_ranges(priv->pctl, mlxbf3_pinctrl_gpio_ranges, 2);
+
+       return 0;
+}
+
+static const struct acpi_device_id mlxbf3_pinctrl_acpi_ids[] = {
+       { "MLNXBF34", 0 },
+       {}
+};
+MODULE_DEVICE_TABLE(acpi, mlxbf3_pinctrl_acpi_ids);
+
+static struct platform_driver mlxbf3_pinctrl_driver = {
+       .driver = {
+               .name = "pinctrl-mlxbf3",
+               .acpi_match_table = mlxbf3_pinctrl_acpi_ids,
+       },
+       .probe = mlxbf3_pinctrl_probe,
+};
+module_platform_driver(mlxbf3_pinctrl_driver);
+
+MODULE_DESCRIPTION("NVIDIA pinctrl driver");
+MODULE_AUTHOR("Asmaa Mnebhi <asmaa@nvidia.com>");
+MODULE_LICENSE("Dual BSD/GPL");
index 37acfdfc2cae07b9e97812b1aaa16dabc85d56db..dad05294fa72639bb97b0446fbb3063bf065107b 100644 (file)
@@ -17,6 +17,7 @@
 #include <linux/pinctrl/pinctrl.h>
 #include <linux/pinctrl/pinmux.h>
 #include <linux/platform_device.h>
+#include <linux/seq_file.h>
 #include <linux/slab.h>
 #include <linux/spinlock.h>
 
@@ -60,8 +61,8 @@ struct pic32_desc_function {
 
 struct pic32_gpio_bank {
        void __iomem *reg_base;
+       int instance;
        struct gpio_chip gpio_chip;
-       struct irq_chip irq_chip;
        struct clk *clk;
 };
 
@@ -2008,12 +2009,14 @@ static void pic32_gpio_irq_mask(struct irq_data *data)
        struct pic32_gpio_bank *bank = irqd_to_bank(data);
 
        writel(BIT(PIC32_CNCON_ON), bank->reg_base + PIC32_CLR(CNCON_REG));
+       gpiochip_disable_irq(&bank->gpio_chip, irqd_to_hwirq(data));
 }
 
 static void pic32_gpio_irq_unmask(struct irq_data *data)
 {
        struct pic32_gpio_bank *bank = irqd_to_bank(data);
 
+       gpiochip_enable_irq(&bank->gpio_chip, irqd_to_hwirq(data));
        writel(BIT(PIC32_CNCON_ON), bank->reg_base + PIC32_SET(CNCON_REG));
 }
 
@@ -2030,7 +2033,7 @@ static unsigned int pic32_gpio_irq_startup(struct irq_data *data)
 static int pic32_gpio_irq_set_type(struct irq_data *data, unsigned int type)
 {
        struct pic32_gpio_bank *bank = irqd_to_bank(data);
-       u32 mask = BIT(data->hwirq);
+       u32 mask = irqd_to_hwirq(data);
 
        switch (type & IRQ_TYPE_SENSE_MASK) {
        case IRQ_TYPE_EDGE_RISING:
@@ -2122,14 +2125,7 @@ static void pic32_gpio_irq_handler(struct irq_desc *desc)
                        .owner = THIS_MODULE,                           \
                        .can_sleep = 0,                                 \
                },                                                      \
-               .irq_chip = {                                           \
-                       .name = "GPIO" #_bank,                          \
-                       .irq_startup = pic32_gpio_irq_startup,  \
-                       .irq_ack = pic32_gpio_irq_ack,          \
-                       .irq_mask = pic32_gpio_irq_mask,                \
-                       .irq_unmask = pic32_gpio_irq_unmask,            \
-                       .irq_set_type = pic32_gpio_irq_set_type,        \
-               },                                                      \
+               .instance = (_bank),                                    \
        }
 
 static struct pic32_gpio_bank pic32_gpio_banks[] = {
@@ -2145,6 +2141,24 @@ static struct pic32_gpio_bank pic32_gpio_banks[] = {
        GPIO_BANK(9, PINS_PER_BANK),
 };
 
+static void pic32_gpio_irq_print_chip(struct irq_data *data, struct seq_file *p)
+{
+       struct pic32_gpio_bank *bank = irqd_to_bank(data);
+
+       seq_printf(p, "GPIO%d", bank->instance);
+}
+
+static const struct irq_chip pic32_gpio_irq_chip = {
+       .irq_startup = pic32_gpio_irq_startup,
+       .irq_ack = pic32_gpio_irq_ack,
+       .irq_mask = pic32_gpio_irq_mask,
+       .irq_unmask = pic32_gpio_irq_unmask,
+       .irq_set_type = pic32_gpio_irq_set_type,
+       .irq_print_chip = pic32_gpio_irq_print_chip,
+       .flags = IRQCHIP_IMMUTABLE,
+       GPIOCHIP_IRQ_RESOURCE_HELPERS,
+};
+
 static int pic32_pinctrl_probe(struct platform_device *pdev)
 {
        struct pic32_pinctrl *pctl;
@@ -2243,7 +2257,7 @@ static int pic32_gpio_probe(struct platform_device *pdev)
        bank->gpio_chip.parent = &pdev->dev;
 
        girq = &bank->gpio_chip.irq;
-       girq->chip = &bank->irq_chip;
+       gpio_irq_chip_set_chip(girq, &pic32_gpio_irq_chip);
        girq->parent_handler = pic32_gpio_irq_handler;
        girq->num_parents = 1;
        girq->parents = devm_kcalloc(&pdev->dev, 1, sizeof(*girq->parents),
index 7ca4ecb6eb8d7ec8261ecf58f4f40490c7d09369..53408344927ad16c2292d17dfbba385bb0260352 100644 (file)
@@ -17,6 +17,7 @@
 #include <linux/pinctrl/pinmux.h>
 #include <linux/platform_device.h>
 #include <linux/property.h>
+#include <linux/seq_file.h>
 #include <linux/slab.h>
 #include <linux/spinlock.h>
 
@@ -93,10 +94,10 @@ struct pistachio_pin_group {
 struct pistachio_gpio_bank {
        struct pistachio_pinctrl *pctl;
        void __iomem *base;
+       int instance;
        unsigned int pin_base;
        unsigned int npins;
        struct gpio_chip gpio_chip;
-       struct irq_chip irq_chip;
 };
 
 struct pistachio_pinctrl {
@@ -1228,12 +1229,14 @@ static void pistachio_gpio_irq_mask(struct irq_data *data)
        struct pistachio_gpio_bank *bank = irqd_to_bank(data);
 
        gpio_mask_writel(bank, GPIO_INTERRUPT_EN, data->hwirq, 0);
+       gpiochip_disable_irq(&bank->gpio_chip, irqd_to_hwirq(data));
 }
 
 static void pistachio_gpio_irq_unmask(struct irq_data *data)
 {
        struct pistachio_gpio_bank *bank = irqd_to_bank(data);
 
+       gpiochip_enable_irq(&bank->gpio_chip, irqd_to_hwirq(data));
        gpio_mask_writel(bank, GPIO_INTERRUPT_EN, data->hwirq, 1);
 }
 
@@ -1312,6 +1315,7 @@ static void pistachio_gpio_irq_handler(struct irq_desc *desc)
 
 #define GPIO_BANK(_bank, _pin_base, _npins)                            \
        {                                                               \
+               .instance = (_bank),                                    \
                .pin_base = _pin_base,                                  \
                .npins = _npins,                                        \
                .gpio_chip = {                                          \
@@ -1326,14 +1330,6 @@ static void pistachio_gpio_irq_handler(struct irq_desc *desc)
                        .base = _pin_base,                              \
                        .ngpio = _npins,                                \
                },                                                      \
-               .irq_chip = {                                           \
-                       .name = "GPIO" #_bank,                          \
-                       .irq_startup = pistachio_gpio_irq_startup,      \
-                       .irq_ack = pistachio_gpio_irq_ack,              \
-                       .irq_mask = pistachio_gpio_irq_mask,            \
-                       .irq_unmask = pistachio_gpio_irq_unmask,        \
-                       .irq_set_type = pistachio_gpio_irq_set_type,    \
-               },                                                      \
        }
 
 static struct pistachio_gpio_bank pistachio_gpio_banks[] = {
@@ -1345,6 +1341,25 @@ static struct pistachio_gpio_bank pistachio_gpio_banks[] = {
        GPIO_BANK(5, PISTACHIO_PIN_MFIO(80), 10),
 };
 
+static void pistachio_gpio_irq_print_chip(struct irq_data *data,
+                                         struct seq_file *p)
+{
+       struct pistachio_gpio_bank *bank = irqd_to_bank(data);
+
+       seq_printf(p, "GPIO%d", bank->instance);
+}
+
+static const struct irq_chip pistachio_gpio_irq_chip = {
+       .irq_startup = pistachio_gpio_irq_startup,
+       .irq_ack = pistachio_gpio_irq_ack,
+       .irq_mask = pistachio_gpio_irq_mask,
+       .irq_unmask = pistachio_gpio_irq_unmask,
+       .irq_set_type = pistachio_gpio_irq_set_type,
+       .irq_print_chip = pistachio_gpio_irq_print_chip,
+       .flags = IRQCHIP_IMMUTABLE,
+       GPIOCHIP_IRQ_RESOURCE_HELPERS,
+};
+
 static int pistachio_gpio_register(struct pistachio_pinctrl *pctl)
 {
        struct pistachio_gpio_bank *bank;
@@ -1394,7 +1409,7 @@ static int pistachio_gpio_register(struct pistachio_pinctrl *pctl)
                bank->gpio_chip.fwnode = child;
 
                girq = &bank->gpio_chip.irq;
-               girq->chip = &bank->irq_chip;
+               gpio_irq_chip_set_chip(girq, &pistachio_gpio_irq_chip);
                girq->parent_handler = pistachio_gpio_irq_handler;
                girq->num_parents = 1;
                girq->parents = devm_kcalloc(pctl->dev, 1,
index 190923757cda00db822bb22c84cd667116cc39c7..0dabbcf68b9f2f22192831b183646bbef379f31c 100644 (file)
@@ -939,11 +939,11 @@ static int pcs_parse_pinconf(struct pcs_device *pcs, struct device_node *np,
 
        /* cacluate how much properties are supported in current node */
        for (i = 0; i < ARRAY_SIZE(prop2); i++) {
-               if (of_find_property(np, prop2[i].name, NULL))
+               if (of_property_present(np, prop2[i].name))
                        nconfs++;
        }
        for (i = 0; i < ARRAY_SIZE(prop4); i++) {
-               if (of_find_property(np, prop4[i].name, NULL))
+               if (of_property_present(np, prop4[i].name))
                        nconfs++;
        }
        if (!nconfs)
index 1409339f0279334440c9fc545bc4ccc35666d4de..c1f36b164ea5de74ef489075bb452810fd33cadc 100644 (file)
@@ -1313,7 +1313,8 @@ static void st_gpio_irq_mask(struct irq_data *d)
        struct gpio_chip *gc = irq_data_get_irq_chip_data(d);
        struct st_gpio_bank *bank = gpiochip_get_data(gc);
 
-       writel(BIT(d->hwirq), bank->base + REG_PIO_CLR_PMASK);
+       writel(BIT(irqd_to_hwirq(d)), bank->base + REG_PIO_CLR_PMASK);
+       gpiochip_disable_irq(gc, irqd_to_hwirq(d));
 }
 
 static void st_gpio_irq_unmask(struct irq_data *d)
@@ -1321,7 +1322,8 @@ static void st_gpio_irq_unmask(struct irq_data *d)
        struct gpio_chip *gc = irq_data_get_irq_chip_data(d);
        struct st_gpio_bank *bank = gpiochip_get_data(gc);
 
-       writel(BIT(d->hwirq), bank->base + REG_PIO_SET_PMASK);
+       gpiochip_enable_irq(gc, irqd_to_hwirq(d));
+       writel(BIT(irqd_to_hwirq(d)), bank->base + REG_PIO_SET_PMASK);
 }
 
 static int st_gpio_irq_request_resources(struct irq_data *d)
@@ -1330,14 +1332,14 @@ static int st_gpio_irq_request_resources(struct irq_data *d)
 
        st_gpio_direction_input(gc, d->hwirq);
 
-       return gpiochip_lock_as_irq(gc, d->hwirq);
+       return gpiochip_reqres_irq(gc, d->hwirq);
 }
 
 static void st_gpio_irq_release_resources(struct irq_data *d)
 {
        struct gpio_chip *gc = irq_data_get_irq_chip_data(d);
 
-       gpiochip_unlock_as_irq(gc, d->hwirq);
+       gpiochip_relres_irq(gc, d->hwirq);
 }
 
 static int st_gpio_irq_set_type(struct irq_data *d, unsigned type)
@@ -1492,7 +1494,7 @@ static const struct gpio_chip st_gpio_template = {
        .ngpio                  = ST_GPIO_PINS_PER_BANK,
 };
 
-static struct irq_chip st_gpio_irqchip = {
+static const struct irq_chip st_gpio_irqchip = {
        .name                   = "GPIO",
        .irq_request_resources  = st_gpio_irq_request_resources,
        .irq_release_resources  = st_gpio_irq_release_resources,
@@ -1500,7 +1502,7 @@ static struct irq_chip st_gpio_irqchip = {
        .irq_mask               = st_gpio_irq_mask,
        .irq_unmask             = st_gpio_irq_unmask,
        .irq_set_type           = st_gpio_irq_set_type,
-       .flags                  = IRQCHIP_SKIP_SET_WAKE,
+       .flags                  = IRQCHIP_SKIP_SET_WAKE | IRQCHIP_IMMUTABLE,
 };
 
 static int st_gpiolib_register_bank(struct st_pinctrl *info,
@@ -1570,7 +1572,7 @@ static int st_gpiolib_register_bank(struct st_pinctrl *info,
                }
 
                girq = &bank->gpio_chip.irq;
-               girq->chip = &st_gpio_irqchip;
+               gpio_irq_chip_set_chip(girq, &st_gpio_irqchip);
                girq->parent_handler = st_gpio_irq_handler;
                girq->num_parents = 1;
                girq->parents = devm_kcalloc(dev, 1, sizeof(*girq->parents),
index 1181c4b506b11f0fbc2b493fcc56c4e4ca797fbe..ab23d7ac3107ed00492e329f5f1a06b6369e1be9 100644 (file)
@@ -85,7 +85,6 @@ struct stmfx_pinctrl {
        struct pinctrl_dev *pctl_dev;
        struct pinctrl_desc pctl_desc;
        struct gpio_chip gpio_chip;
-       struct irq_chip irq_chip;
        struct mutex lock; /* IRQ bus lock */
        unsigned long gpio_valid_mask;
        /* Cache of IRQ_GPI_* registers for bus_lock */
@@ -427,6 +426,7 @@ static void stmfx_pinctrl_irq_mask(struct irq_data *data)
        u32 mask = get_mask(data->hwirq);
 
        pctl->irq_gpi_src[reg] &= ~mask;
+       gpiochip_disable_irq(gpio_chip, irqd_to_hwirq(data));
 }
 
 static void stmfx_pinctrl_irq_unmask(struct irq_data *data)
@@ -436,6 +436,7 @@ static void stmfx_pinctrl_irq_unmask(struct irq_data *data)
        u32 reg = get_reg(data->hwirq);
        u32 mask = get_mask(data->hwirq);
 
+       gpiochip_enable_irq(gpio_chip, irqd_to_hwirq(data));
        pctl->irq_gpi_src[reg] |= mask;
 }
 
@@ -592,6 +593,26 @@ static irqreturn_t stmfx_pinctrl_irq_thread_fn(int irq, void *dev_id)
        return IRQ_HANDLED;
 }
 
+static void stmfx_pinctrl_irq_print_chip(struct irq_data *d, struct seq_file *p)
+{
+       struct gpio_chip *gpio_chip = irq_data_get_irq_chip_data(d);
+       struct stmfx_pinctrl *pctl = gpiochip_get_data(gpio_chip);
+
+       seq_printf(p, dev_name(pctl->dev));
+}
+
+static const struct irq_chip stmfx_pinctrl_irq_chip = {
+       .irq_mask = stmfx_pinctrl_irq_mask,
+       .irq_unmask = stmfx_pinctrl_irq_unmask,
+       .irq_set_type = stmfx_pinctrl_irq_set_type,
+       .irq_bus_lock = stmfx_pinctrl_irq_bus_lock,
+       .irq_bus_sync_unlock = stmfx_pinctrl_irq_bus_sync_unlock,
+       .irq_request_resources = stmfx_gpio_irq_request_resources,
+       .irq_release_resources = stmfx_gpio_irq_release_resources,
+       .irq_print_chip = stmfx_pinctrl_irq_print_chip,
+       .flags = IRQCHIP_IMMUTABLE,
+};
+
 static int stmfx_pinctrl_gpio_function_enable(struct stmfx_pinctrl *pctl)
 {
        struct pinctrl_gpio_range *gpio_range;
@@ -632,7 +653,7 @@ static int stmfx_pinctrl_probe(struct platform_device *pdev)
        pctl->dev = &pdev->dev;
        pctl->stmfx = stmfx;
 
-       if (!of_find_property(np, "gpio-ranges", NULL)) {
+       if (!of_property_present(np, "gpio-ranges")) {
                dev_err(pctl->dev, "missing required gpio-ranges property\n");
                return -EINVAL;
        }
@@ -678,17 +699,8 @@ static int stmfx_pinctrl_probe(struct platform_device *pdev)
        pctl->gpio_chip.ngpio = pctl->pctl_desc.npins;
        pctl->gpio_chip.can_sleep = true;
 
-       pctl->irq_chip.name = dev_name(pctl->dev);
-       pctl->irq_chip.irq_mask = stmfx_pinctrl_irq_mask;
-       pctl->irq_chip.irq_unmask = stmfx_pinctrl_irq_unmask;
-       pctl->irq_chip.irq_set_type = stmfx_pinctrl_irq_set_type;
-       pctl->irq_chip.irq_bus_lock = stmfx_pinctrl_irq_bus_lock;
-       pctl->irq_chip.irq_bus_sync_unlock = stmfx_pinctrl_irq_bus_sync_unlock;
-       pctl->irq_chip.irq_request_resources = stmfx_gpio_irq_request_resources;
-       pctl->irq_chip.irq_release_resources = stmfx_gpio_irq_release_resources;
-
        girq = &pctl->gpio_chip.irq;
-       girq->chip = &pctl->irq_chip;
+       gpio_irq_chip_set_chip(girq, &stmfx_pinctrl_irq_chip);
        /* This will let us handle the parent IRQ in the driver */
        girq->parent_handler = NULL;
        girq->num_parents = 0;
@@ -710,7 +722,7 @@ static int stmfx_pinctrl_probe(struct platform_device *pdev)
        ret = devm_request_threaded_irq(pctl->dev, irq, NULL,
                                        stmfx_pinctrl_irq_thread_fn,
                                        IRQF_ONESHOT,
-                                       pctl->irq_chip.name, pctl);
+                                       dev_name(pctl->dev), pctl);
        if (ret) {
                dev_err(pctl->dev, "cannot request irq%d\n", irq);
                return ret;
index 0b5ff99641e1bdcf982561e8cea63bcd27e565d2..7632ffc3946f2650c1cf3afb00086a0486980ba2 100644 (file)
@@ -99,7 +99,6 @@ struct sx150x_pinctrl {
        struct pinctrl_dev *pctldev;
        struct pinctrl_desc pinctrl_desc;
        struct gpio_chip gpio;
-       struct irq_chip irq_chip;
        struct regmap *regmap;
        struct {
                u32 sense;
@@ -487,19 +486,21 @@ static int sx150x_gpio_direction_output(struct gpio_chip *chip,
 
 static void sx150x_irq_mask(struct irq_data *d)
 {
-       struct sx150x_pinctrl *pctl =
-                       gpiochip_get_data(irq_data_get_irq_chip_data(d));
-       unsigned int n = d->hwirq;
+       struct gpio_chip *gc = irq_data_get_irq_chip_data(d);
+       struct sx150x_pinctrl *pctl = gpiochip_get_data(gc);
+       unsigned int n = irqd_to_hwirq(d);
 
        pctl->irq.masked |= BIT(n);
+       gpiochip_disable_irq(gc, n);
 }
 
 static void sx150x_irq_unmask(struct irq_data *d)
 {
-       struct sx150x_pinctrl *pctl =
-                       gpiochip_get_data(irq_data_get_irq_chip_data(d));
-       unsigned int n = d->hwirq;
+       struct gpio_chip *gc = irq_data_get_irq_chip_data(d);
+       struct sx150x_pinctrl *pctl = gpiochip_get_data(gc);
+       unsigned int n = irqd_to_hwirq(d);
 
+       gpiochip_enable_irq(gc, n);
        pctl->irq.masked &= ~BIT(n);
 }
 
@@ -520,14 +521,14 @@ static void sx150x_irq_set_sense(struct sx150x_pinctrl *pctl,
 
 static int sx150x_irq_set_type(struct irq_data *d, unsigned int flow_type)
 {
-       struct sx150x_pinctrl *pctl =
-                       gpiochip_get_data(irq_data_get_irq_chip_data(d));
+       struct gpio_chip *gc = irq_data_get_irq_chip_data(d);
+       struct sx150x_pinctrl *pctl = gpiochip_get_data(gc);
        unsigned int n, val = 0;
 
        if (flow_type & (IRQ_TYPE_LEVEL_HIGH | IRQ_TYPE_LEVEL_LOW))
                return -EINVAL;
 
-       n = d->hwirq;
+       n = irqd_to_hwirq(d);
 
        if (flow_type & IRQ_TYPE_EDGE_RISING)
                val |= SX150X_IRQ_TYPE_EDGE_RISING;
@@ -562,22 +563,42 @@ static irqreturn_t sx150x_irq_thread_fn(int irq, void *dev_id)
 
 static void sx150x_irq_bus_lock(struct irq_data *d)
 {
-       struct sx150x_pinctrl *pctl =
-                       gpiochip_get_data(irq_data_get_irq_chip_data(d));
+       struct gpio_chip *gc = irq_data_get_irq_chip_data(d);
+       struct sx150x_pinctrl *pctl = gpiochip_get_data(gc);
 
        mutex_lock(&pctl->lock);
 }
 
 static void sx150x_irq_bus_sync_unlock(struct irq_data *d)
 {
-       struct sx150x_pinctrl *pctl =
-                       gpiochip_get_data(irq_data_get_irq_chip_data(d));
+       struct gpio_chip *gc = irq_data_get_irq_chip_data(d);
+       struct sx150x_pinctrl *pctl = gpiochip_get_data(gc);
 
        regmap_write(pctl->regmap, pctl->data->reg_irq_mask, pctl->irq.masked);
        regmap_write(pctl->regmap, pctl->data->reg_sense, pctl->irq.sense);
        mutex_unlock(&pctl->lock);
 }
 
+
+static void sx150x_irq_print_chip(struct irq_data *d, struct seq_file *p)
+{
+       struct gpio_chip *gc = irq_data_get_irq_chip_data(d);
+       struct sx150x_pinctrl *pctl = gpiochip_get_data(gc);
+
+       seq_printf(p, pctl->client->name);
+}
+
+static const struct irq_chip sx150x_irq_chip = {
+       .irq_mask = sx150x_irq_mask,
+       .irq_unmask = sx150x_irq_unmask,
+       .irq_set_type = sx150x_irq_set_type,
+       .irq_bus_lock = sx150x_irq_bus_lock,
+       .irq_bus_sync_unlock = sx150x_irq_bus_sync_unlock,
+       .irq_print_chip = sx150x_irq_print_chip,
+       .flags = IRQCHIP_IMMUTABLE,
+       GPIOCHIP_IRQ_RESOURCE_HELPERS,
+};
+
 static int sx150x_pinconf_get(struct pinctrl_dev *pctldev, unsigned int pin,
                              unsigned long *config)
 {
@@ -1181,19 +1202,8 @@ static int sx150x_probe(struct i2c_client *client)
        if (client->irq > 0) {
                struct gpio_irq_chip *girq;
 
-               pctl->irq_chip.irq_mask = sx150x_irq_mask;
-               pctl->irq_chip.irq_unmask = sx150x_irq_unmask;
-               pctl->irq_chip.irq_set_type = sx150x_irq_set_type;
-               pctl->irq_chip.irq_bus_lock = sx150x_irq_bus_lock;
-               pctl->irq_chip.irq_bus_sync_unlock = sx150x_irq_bus_sync_unlock;
-               pctl->irq_chip.name = devm_kstrdup(dev, client->name,
-                                                  GFP_KERNEL);
-               if (!pctl->irq_chip.name)
-                       return -ENOMEM;
-
                pctl->irq.masked = ~0;
                pctl->irq.sense = 0;
-
                /*
                 * Because sx150x_irq_threaded_fn invokes all of the
                 * nested interrupt handlers via handle_nested_irq,
@@ -1206,7 +1216,7 @@ static int sx150x_probe(struct i2c_client *client)
                 * called (should not happen)
                 */
                girq = &pctl->gpio.irq;
-               girq->chip = &pctl->irq_chip;
+               gpio_irq_chip_set_chip(girq, &sx150x_irq_chip);
                /* This will let us handle the parent IRQ in the driver */
                girq->parent_handler = NULL;
                girq->num_parents = 0;
@@ -1219,7 +1229,7 @@ static int sx150x_probe(struct i2c_client *client)
                                                sx150x_irq_thread_fn,
                                                IRQF_ONESHOT | IRQF_SHARED |
                                                IRQF_TRIGGER_FALLING,
-                                               pctl->irq_chip.name, pctl);
+                                               client->name, pctl);
                if (ret < 0)
                        return ret;
        }
@@ -1250,7 +1260,7 @@ static int sx150x_probe(struct i2c_client *client)
 static struct i2c_driver sx150x_driver = {
        .driver = {
                .name = "sx150x-pinctrl",
-               .of_match_table = of_match_ptr(sx150x_of_match),
+               .of_match_table = sx150x_of_match,
        },
        .probe_new = sx150x_probe,
        .id_table = sx150x_id,
diff --git a/drivers/pinctrl/pinctrl-thunderbay.c b/drivers/pinctrl/pinctrl-thunderbay.c
deleted file mode 100644 (file)
index 7a5ff95..0000000
+++ /dev/null
@@ -1,1294 +0,0 @@
-// SPDX-License-Identifier: GPL-2.0
-/*
- * Intel Thunder Bay SOC pinctrl/GPIO driver
- *
- * Copyright (C) 2021 Intel Corporation
- */
-
-#include <linux/device.h>
-#include <linux/err.h>
-#include <linux/gpio/driver.h>
-#include <linux/init.h>
-#include <linux/interrupt.h>
-#include <linux/io.h>
-#include <linux/irq.h>
-#include <linux/module.h>
-#include <linux/of.h>
-#include <linux/of_irq.h>
-
-#include <linux/pinctrl/pinconf.h>
-#include <linux/pinctrl/pinconf-generic.h>
-#include <linux/pinctrl/pinctrl.h>
-#include <linux/pinctrl/pinmux.h>
-
-#include <linux/platform_device.h>
-#include <linux/slab.h>
-#include <linux/spinlock.h>
-
-#include "core.h"
-#include "pinconf.h"
-#include "pinctrl-utils.h"
-#include "pinmux.h"
-
-/* Bit 0:2 and 4:6 should be used for mode selection */
-#define THB_GPIO_PINMUX_MODE_0                 0x00
-#define THB_GPIO_PINMUX_MODE_1                 0x11
-#define THB_GPIO_PINMUX_MODE_2                 0x22
-#define THB_GPIO_PINMUX_MODE_3                 0x33
-#define THB_GPIO_PINMUX_MODE_4                 0x44
-
-#define THB_GPIO_PORT_SELECT_MASK              BIT(8)
-#define THB_GPIO_PAD_DIRECTION_MASK            BIT(10)
-#define THB_GPIO_SPU_MASK                      BIT(11)
-#define THB_GPIO_PULL_ENABLE_MASK              BIT(12)
-#define THB_GPIO_PULL_UP_MASK                  BIT(13)
-#define THB_GPIO_PULL_DOWN_MASK                        BIT(14)
-#define THB_GPIO_ENAQ_MASK                     BIT(15)
-/* bit 16-19: Drive Strength for the Pad */
-#define THB_GPIO_DRIVE_STRENGTH_MASK           (0xF0000)
-#define THB_GPIO_SLEW_RATE_MASK                        BIT(20)
-#define THB_GPIO_SCHMITT_TRIGGER_MASK          BIT(21)
-
-#define THB_GPIO_REG_OFFSET(pin_num)                   ((pin_num) * (0x4))
-#define THB_MAX_MODE_SUPPORTED                         (5u)
-#define THB_MAX_NPINS_SUPPORTED                                (67u)
-
-/* store Pin status */
-static u32 thb_pinx_status[THB_MAX_NPINS_SUPPORTED];
-
-struct thunderbay_mux_desc {
-       u8 mode;
-       const char *name;
-};
-
-#define THUNDERBAY_PIN_DESC(pin_number, pin_name, ...) {        \
-       .number = pin_number,                           \
-       .name = pin_name,                               \
-       .drv_data = &(struct thunderbay_mux_desc[]) {   \
-                       __VA_ARGS__, { } },             \
-}
-
-#define THUNDERBAY_MUX(pin_mode, pin_function) {                \
-       .mode = pin_mode,                               \
-       .name = pin_function,                           \
-}
-
-struct thunderbay_pin_soc {
-       const struct pinctrl_pin_desc           *pins;
-       unsigned int                            npins;
-};
-
-/**
- * struct thunderbay_pinctrl - Intel Thunderbay pinctrl structure
- * @pctrl: Pointer to the pin controller device
- * @base0: First register base address
- * @dev: Pointer to the device structure
- * @chip: GPIO chip used by this pin controller
- * @soc: Pin control configuration data based on SoC
- * @ngroups: Number of pin groups available
- * @nfuncs: Number of pin functions available
- */
-struct thunderbay_pinctrl {
-       struct pinctrl_dev              *pctrl;
-       void __iomem                    *base0;
-       struct device                   *dev;
-       struct gpio_chip                chip;
-       const struct thunderbay_pin_soc *soc;
-       unsigned int                    ngroups;
-       unsigned int                    nfuncs;
-};
-
-static const struct pinctrl_pin_desc thunderbay_pins[] = {
-       THUNDERBAY_PIN_DESC(0, "GPIO0",
-                           THUNDERBAY_MUX(0X0, "I2C0_M0"),
-                           THUNDERBAY_MUX(0X1, "EMPTY_M1"),
-                           THUNDERBAY_MUX(0X2, "EMPTY_M2"),
-                           THUNDERBAY_MUX(0X3, "EMPTY_M3"),
-                           THUNDERBAY_MUX(0X4, "GPIO_M4")),
-       THUNDERBAY_PIN_DESC(1, "GPIO1",
-                           THUNDERBAY_MUX(0X0, "I2C0_M0"),
-                           THUNDERBAY_MUX(0X1, "EMPTY_M1"),
-                           THUNDERBAY_MUX(0X2, "EMPTY_M2"),
-                           THUNDERBAY_MUX(0X3, "EMPTY_M3"),
-                           THUNDERBAY_MUX(0X4, "GPIO_M4")),
-       THUNDERBAY_PIN_DESC(2, "GPIO2",
-                           THUNDERBAY_MUX(0X0, "I2C1_M0"),
-                           THUNDERBAY_MUX(0X1, "EMPTY_M1"),
-                           THUNDERBAY_MUX(0X2, "EMPTY_M2"),
-                           THUNDERBAY_MUX(0X3, "EMPTY_M3"),
-                           THUNDERBAY_MUX(0X4, "GPIO_M4")),
-       THUNDERBAY_PIN_DESC(3, "GPIO3",
-                           THUNDERBAY_MUX(0X0, "I2C1_M0"),
-                           THUNDERBAY_MUX(0X1, "EMPTY_M1"),
-                           THUNDERBAY_MUX(0X2, "EMPTY_M2"),
-                           THUNDERBAY_MUX(0X3, "EMPTY_M3"),
-                           THUNDERBAY_MUX(0X4, "GPIO_M4")),
-       THUNDERBAY_PIN_DESC(4, "GPIO4",
-                           THUNDERBAY_MUX(0X0, "I2C2_M0"),
-                           THUNDERBAY_MUX(0X1, "EMPTY_M1"),
-                           THUNDERBAY_MUX(0X2, "EMPTY_M2"),
-                           THUNDERBAY_MUX(0X3, "EMPTY_M3"),
-                           THUNDERBAY_MUX(0X4, "GPIO_M4")),
-       THUNDERBAY_PIN_DESC(5, "GPIO5",
-                           THUNDERBAY_MUX(0X0, "I2C2_M0"),
-                           THUNDERBAY_MUX(0X1, "EMPTY_M1"),
-                           THUNDERBAY_MUX(0X2, "EMPTY_M2"),
-                           THUNDERBAY_MUX(0X3, "EMPTY_M3"),
-                           THUNDERBAY_MUX(0X4, "GPIO_M4")),
-       THUNDERBAY_PIN_DESC(6, "GPIO6",
-                           THUNDERBAY_MUX(0X0, "I2C3_M0"),
-                           THUNDERBAY_MUX(0X1, "EMPTY_M1"),
-                           THUNDERBAY_MUX(0X2, "EMPTY_M2"),
-                           THUNDERBAY_MUX(0X3, "EMPTY_M3"),
-                           THUNDERBAY_MUX(0X4, "GPIO_M4")),
-       THUNDERBAY_PIN_DESC(7, "GPIO7",
-                           THUNDERBAY_MUX(0X0, "I2C3_M0"),
-                           THUNDERBAY_MUX(0X1, "EMPTY_M1"),
-                           THUNDERBAY_MUX(0X2, "EMPTY_M2"),
-                           THUNDERBAY_MUX(0X3, "EMPTY_M3"),
-                           THUNDERBAY_MUX(0X4, "GPIO_M4")),
-       THUNDERBAY_PIN_DESC(8, "GPIO8",
-                           THUNDERBAY_MUX(0X0, "I2C4_M0"),
-                           THUNDERBAY_MUX(0X1, "EMPTY_M1"),
-                           THUNDERBAY_MUX(0X2, "EMPTY_M2"),
-                           THUNDERBAY_MUX(0X3, "EMPTY_M3"),
-                           THUNDERBAY_MUX(0X4, "GPIO_M4")),
-       THUNDERBAY_PIN_DESC(9, "GPIO9",
-                           THUNDERBAY_MUX(0X0, "I2C4_M0"),
-                           THUNDERBAY_MUX(0X1, "EMPTY_M1"),
-                           THUNDERBAY_MUX(0X2, "EMPTY_M2"),
-                           THUNDERBAY_MUX(0X3, "EMPTY_M3"),
-                           THUNDERBAY_MUX(0X4, "GPIO_M4")),
-       THUNDERBAY_PIN_DESC(10, "GPIO10",
-                           THUNDERBAY_MUX(0X0, "UART0_M0"),
-                           THUNDERBAY_MUX(0X1, "RT0_DSU_M1"),
-                           THUNDERBAY_MUX(0X2, "EMPTY_M2"),
-                           THUNDERBAY_MUX(0X3, "EMPTY_M3"),
-                           THUNDERBAY_MUX(0X4, "GPIO_M4")),
-       THUNDERBAY_PIN_DESC(11, "GPIO11",
-                           THUNDERBAY_MUX(0X0, "UART0_M0"),
-                           THUNDERBAY_MUX(0X1, "RT0_DSU_M1"),
-                           THUNDERBAY_MUX(0X2, "EMPTY_M2"),
-                           THUNDERBAY_MUX(0X3, "EMPTY_M3"),
-                           THUNDERBAY_MUX(0X4, "GPIO_M4")),
-       THUNDERBAY_PIN_DESC(12, "GPIO12",
-                           THUNDERBAY_MUX(0X0, "UART0_M0"),
-                           THUNDERBAY_MUX(0X1, "RT1_DSU_M1"),
-                           THUNDERBAY_MUX(0X2, "EMPTY_M2"),
-                           THUNDERBAY_MUX(0X3, "EMPTY_M3"),
-                           THUNDERBAY_MUX(0X4, "GPIO_M4")),
-       THUNDERBAY_PIN_DESC(13, "GPIO13",
-                           THUNDERBAY_MUX(0X0, "UART0_M0"),
-                           THUNDERBAY_MUX(0X1, "RT1_DSU_M1"),
-                           THUNDERBAY_MUX(0X2, "EMPTY_M2"),
-                           THUNDERBAY_MUX(0X3, "EMPTY_M3"),
-                           THUNDERBAY_MUX(0X4, "GPIO_M4")),
-       THUNDERBAY_PIN_DESC(14, "GPIO14",
-                           THUNDERBAY_MUX(0X0, "UART1_M0"),
-                           THUNDERBAY_MUX(0X1, "RT2_DSU_M1"),
-                           THUNDERBAY_MUX(0X2, "EMPTY_M2"),
-                           THUNDERBAY_MUX(0X3, "TRIGGER_M3"),
-                           THUNDERBAY_MUX(0X4, "GPIO_M4")),
-       THUNDERBAY_PIN_DESC(15, "GPIO15",
-                           THUNDERBAY_MUX(0X0, "UART1_M0"),
-                           THUNDERBAY_MUX(0X1, "RT2_DSU_M1"),
-                           THUNDERBAY_MUX(0X2, "EMPTY_M2"),
-                           THUNDERBAY_MUX(0X3, "TRIGGER_M3"),
-                           THUNDERBAY_MUX(0X4, "GPIO_M4")),
-       THUNDERBAY_PIN_DESC(16, "GPIO16",
-                           THUNDERBAY_MUX(0X0, "UART1_M0"),
-                           THUNDERBAY_MUX(0X1, "RT3_DSU_M1"),
-                           THUNDERBAY_MUX(0X2, "EMPTY_M2"),
-                           THUNDERBAY_MUX(0X3, "EMPTY_M3"),
-                           THUNDERBAY_MUX(0X4, "GPIO_M4")),
-       THUNDERBAY_PIN_DESC(17, "GPIO17",
-                           THUNDERBAY_MUX(0X0, "UART1_M0"),
-                           THUNDERBAY_MUX(0X1, "RT3_DSU_M1"),
-                           THUNDERBAY_MUX(0X2, "EMPTY_M2"),
-                           THUNDERBAY_MUX(0X3, "EMPTY_M3"),
-                           THUNDERBAY_MUX(0X4, "GPIO_M4")),
-       THUNDERBAY_PIN_DESC(18, "GPIO18",
-                           THUNDERBAY_MUX(0X0, "SPI0_M0"),
-                           THUNDERBAY_MUX(0X1, "EMPTY_M1"),
-                           THUNDERBAY_MUX(0X2, "EMPTY_M2"),
-                           THUNDERBAY_MUX(0X3, "EMPTY_M3"),
-                           THUNDERBAY_MUX(0X4, "GPIO_M4")),
-       THUNDERBAY_PIN_DESC(19, "GPIO19",
-                           THUNDERBAY_MUX(0X0, "SPI0_M0"),
-                           THUNDERBAY_MUX(0X1, "EMPTY_M1"),
-                           THUNDERBAY_MUX(0X2, "EMPTY_M2"),
-                           THUNDERBAY_MUX(0X3, "EMPTY_M3"),
-                           THUNDERBAY_MUX(0X4, "GPIO_M4")),
-       THUNDERBAY_PIN_DESC(20, "GPIO20",
-                           THUNDERBAY_MUX(0X0, "SPI0_M0"),
-                           THUNDERBAY_MUX(0X1, "EMPTY_M1"),
-                           THUNDERBAY_MUX(0X2, "TPIU_TRACE_M2"),
-                           THUNDERBAY_MUX(0X3, "EMPTY_M3"),
-                           THUNDERBAY_MUX(0X4, "GPIO_M4")),
-       THUNDERBAY_PIN_DESC(21, "GPIO21",
-                           THUNDERBAY_MUX(0X0, "SPI0_M0"),
-                           THUNDERBAY_MUX(0X1, "EMPTY_M1"),
-                           THUNDERBAY_MUX(0X2, "TPIU_TRACE_M2"),
-                           THUNDERBAY_MUX(0X3, "EMPTY_M3"),
-                           THUNDERBAY_MUX(0X4, "GPIO_M4")),
-       THUNDERBAY_PIN_DESC(22, "GPIO22",
-                           THUNDERBAY_MUX(0X0, "SPI1_M0"),
-                           THUNDERBAY_MUX(0X1, "EMPTY_M0"),
-                           THUNDERBAY_MUX(0X2, "EMPTY_M2"),
-                           THUNDERBAY_MUX(0X3, "EMPTY_M3"),
-                           THUNDERBAY_MUX(0X4, "GPIO_M4")),
-       THUNDERBAY_PIN_DESC(23, "GPIO23",
-                           THUNDERBAY_MUX(0X0, "SPI1_M0"),
-                           THUNDERBAY_MUX(0X1, "EMPTY_M1"),
-                           THUNDERBAY_MUX(0X2, "EMPTY_M2"),
-                           THUNDERBAY_MUX(0X3, "EMPTY_M3"),
-                           THUNDERBAY_MUX(0X4, "GPIO_M4")),
-       THUNDERBAY_PIN_DESC(24, "GPIO24",
-                           THUNDERBAY_MUX(0X0, "SPI1_M0"),
-                           THUNDERBAY_MUX(0X1, "TPIU_TRACE_M1"),
-                           THUNDERBAY_MUX(0X2, "EMPTY_M2"),
-                           THUNDERBAY_MUX(0X3, "EMPTY_M3"),
-                           THUNDERBAY_MUX(0X4, "GPIO_M4")),
-       THUNDERBAY_PIN_DESC(25, "GPIO25",
-                           THUNDERBAY_MUX(0X0, "SPI1_M0"),
-                           THUNDERBAY_MUX(0X1, "TPIU_TRACE_M1"),
-                           THUNDERBAY_MUX(0X2, "EMPTY_M2"),
-                           THUNDERBAY_MUX(0X3, "EMPTY_M3"),
-                           THUNDERBAY_MUX(0X4, "GPIO_M4")),
-       THUNDERBAY_PIN_DESC(26, "GPIO26",
-                           THUNDERBAY_MUX(0X0, "ETHER0_M0"),
-                           THUNDERBAY_MUX(0X1, "TPIU_DATA_M1"),
-                           THUNDERBAY_MUX(0X2, "TPIU_DATA_M2"),
-                           THUNDERBAY_MUX(0X3, "DEBUG_M3"),
-                           THUNDERBAY_MUX(0X4, "GPIO_M4")),
-       THUNDERBAY_PIN_DESC(27, "GPIO27",
-                           THUNDERBAY_MUX(0X0, "ETHER0_M0"),
-                           THUNDERBAY_MUX(0X1, "TPIU_DATA_M1"),
-                           THUNDERBAY_MUX(0X2, "TPIU_DATA_M2"),
-                           THUNDERBAY_MUX(0X3, "DEBUG_M3"),
-                           THUNDERBAY_MUX(0X4, "GPIO_M4")),
-       THUNDERBAY_PIN_DESC(28, "GPIO28",
-                           THUNDERBAY_MUX(0X0, "ETHER0_M0"),
-                           THUNDERBAY_MUX(0X1, "TPIU_DATA_M1"),
-                           THUNDERBAY_MUX(0X2, "TPIU_DATA_M2"),
-                           THUNDERBAY_MUX(0X3, "DEBUG_M3"),
-                           THUNDERBAY_MUX(0X4, "GPIO_M4")),
-       THUNDERBAY_PIN_DESC(29, "GPIO29",
-                           THUNDERBAY_MUX(0X0, "ETHER0_M0"),
-                           THUNDERBAY_MUX(0X1, "TPIU_DATA_M1"),
-                           THUNDERBAY_MUX(0X2, "TPIU_DATA_M2"),
-                           THUNDERBAY_MUX(0X3, "DEBUG_M3"),
-                           THUNDERBAY_MUX(0X4, "GPIO_M4")),
-       THUNDERBAY_PIN_DESC(30, "GPIO30",
-                           THUNDERBAY_MUX(0X0, "ETHER0_M0"),
-                           THUNDERBAY_MUX(0X1, "TPIU_DATA_M1"),
-                           THUNDERBAY_MUX(0X2, "TPIU_DATA_M2"),
-                           THUNDERBAY_MUX(0X3, "DEBUG_M3"),
-                           THUNDERBAY_MUX(0X4, "GPIO_M4")),
-       THUNDERBAY_PIN_DESC(31, "GPIO31",
-                           THUNDERBAY_MUX(0X0, "ETHER0_M0"),
-                           THUNDERBAY_MUX(0X1, "TPIU_DATA_M1"),
-                           THUNDERBAY_MUX(0X2, "TPIU_DATA_M2"),
-                           THUNDERBAY_MUX(0X3, "DEBUG_M3"),
-                           THUNDERBAY_MUX(0X4, "GPIO_M4")),
-       THUNDERBAY_PIN_DESC(32, "GPIO32",
-                           THUNDERBAY_MUX(0X0, "ETHER0_M0"),
-                           THUNDERBAY_MUX(0X1, "TPIU_DATA_M1"),
-                           THUNDERBAY_MUX(0X2, "TPIU_DATA_M2"),
-                           THUNDERBAY_MUX(0X3, "DEBUG_M3"),
-                           THUNDERBAY_MUX(0X4, "GPIO_M4")),
-       THUNDERBAY_PIN_DESC(33, "GPIO33",
-                           THUNDERBAY_MUX(0X0, "ETHER0_M0"),
-                           THUNDERBAY_MUX(0X1, "TPIU_DATA_M1"),
-                           THUNDERBAY_MUX(0X2, "TPIU_DATA_M2"),
-                           THUNDERBAY_MUX(0X3, "DEBUG_M3"),
-                           THUNDERBAY_MUX(0X4, "GPIO_M4")),
-       THUNDERBAY_PIN_DESC(34, "GPIO34",
-                           THUNDERBAY_MUX(0X0, "ETHER0_M0"),
-                           THUNDERBAY_MUX(0X1, "TPIU_DATA_M1"),
-                           THUNDERBAY_MUX(0X2, "TPIU_DATA_M2"),
-                           THUNDERBAY_MUX(0X3, "DIG_VIEW_0"),
-                           THUNDERBAY_MUX(0X4, "GPIO_M4")),
-       THUNDERBAY_PIN_DESC(35, "GPIO35",
-                           THUNDERBAY_MUX(0X0, "ETHER0_M0"),
-                           THUNDERBAY_MUX(0X1, "TPIU_DATA_M1"),
-                           THUNDERBAY_MUX(0X2, "TPIU_DATA_M2"),
-                           THUNDERBAY_MUX(0X3, "DIG_VIEW_1"),
-                           THUNDERBAY_MUX(0X4, "GPIO_M4")),
-       THUNDERBAY_PIN_DESC(36, "GPIO36",
-                           THUNDERBAY_MUX(0X0, "ETHER0_M0"),
-                           THUNDERBAY_MUX(0X1, "TPIU_DATA_M1"),
-                           THUNDERBAY_MUX(0X2, "TPIU_DATA_M2"),
-                           THUNDERBAY_MUX(0X3, "CPR_IO_OUT_CLK_0"),
-                           THUNDERBAY_MUX(0X4, "GPIO_M4")),
-       THUNDERBAY_PIN_DESC(37, "GPIO37",
-                           THUNDERBAY_MUX(0X0, "ETHER0_M0"),
-                           THUNDERBAY_MUX(0X1, "TPIU_DATA_M1"),
-                           THUNDERBAY_MUX(0X2, "TPIU_DATA_M2"),
-                           THUNDERBAY_MUX(0X3, "CPR_IO_OUT_CLK_1"),
-                           THUNDERBAY_MUX(0X4, "GPIO_M4")),
-       THUNDERBAY_PIN_DESC(38, "GPIO38",
-                           THUNDERBAY_MUX(0X0, "ETHER0_M0"),
-                           THUNDERBAY_MUX(0X1, "TPIU_DATA_M1"),
-                           THUNDERBAY_MUX(0X2, "TPIU_DATA_M2"),
-                           THUNDERBAY_MUX(0X3, "CPR_IO_OUT_CLK_2"),
-                           THUNDERBAY_MUX(0X4, "GPIO_M4")),
-       THUNDERBAY_PIN_DESC(39, "GPIO39",
-                           THUNDERBAY_MUX(0X0, "ETHER0_M0"),
-                           THUNDERBAY_MUX(0X1, "TPIU_DATA_M1"),
-                           THUNDERBAY_MUX(0X2, "TPIU_DATA_M2"),
-                           THUNDERBAY_MUX(0X3, "CPR_IO_OUT_CLK_3"),
-                           THUNDERBAY_MUX(0X4, "GPIO_M4")),
-       THUNDERBAY_PIN_DESC(40, "GPIO40",
-                           THUNDERBAY_MUX(0X0, "ETHER0_M0"),
-                           THUNDERBAY_MUX(0X1, "TPIU_DATA_M1"),
-                           THUNDERBAY_MUX(0X2, "TPIU_DATA_M2"),
-                           THUNDERBAY_MUX(0X3, "EMPTY_M3"),
-                           THUNDERBAY_MUX(0X4, "GPIO_M4")),
-       THUNDERBAY_PIN_DESC(41, "GPIO41",
-                           THUNDERBAY_MUX(0X0, "POWER_INTERRUPT_MAX_PLATFORM_POWER_M0"),
-                           THUNDERBAY_MUX(0X1, "TPIU_DATA_M1"),
-                           THUNDERBAY_MUX(0X2, "TPIU_DATA_M2"),
-                           THUNDERBAY_MUX(0X3, "EMPTY_M3"),
-                           THUNDERBAY_MUX(0X4, "GPIO_M4")),
-       THUNDERBAY_PIN_DESC(42, "GPIO42",
-                           THUNDERBAY_MUX(0X0, "ETHER1_M0"),
-                           THUNDERBAY_MUX(0X1, "TPIU_DATA_M1"),
-                           THUNDERBAY_MUX(0X2, "TPIU_DATA_M2"),
-                           THUNDERBAY_MUX(0X3, "DEBUG_M3"),
-                           THUNDERBAY_MUX(0X4, "GPIO_M4")),
-       THUNDERBAY_PIN_DESC(43, "GPIO43",
-                           THUNDERBAY_MUX(0X0, "ETHER1_M0"),
-                           THUNDERBAY_MUX(0X1, "TPIU_DATA_M1"),
-                           THUNDERBAY_MUX(0X2, "TPIU_DATA_M2"),
-                           THUNDERBAY_MUX(0X3, "DEBUG_M3"),
-                           THUNDERBAY_MUX(0X4, "GPIO_M4")),
-       THUNDERBAY_PIN_DESC(44, "GPIO44",
-                           THUNDERBAY_MUX(0X0, "ETHER1_M0"),
-                           THUNDERBAY_MUX(0X1, "TPIU_DATA_M1"),
-                           THUNDERBAY_MUX(0X2, "TPIU_DATA_M2"),
-                           THUNDERBAY_MUX(0X3, "DEBUG_M3"),
-                           THUNDERBAY_MUX(0X4, "GPIO_M4")),
-       THUNDERBAY_PIN_DESC(45, "GPIO45",
-                           THUNDERBAY_MUX(0X0, "ETHER1_M0"),
-                           THUNDERBAY_MUX(0X1, "TPIU_DATA_M1"),
-                           THUNDERBAY_MUX(0X2, "TPIU_DATA_M2"),
-                           THUNDERBAY_MUX(0X3, "DEBUG_M3"),
-                           THUNDERBAY_MUX(0X4, "GPIO_M4")),
-       THUNDERBAY_PIN_DESC(46, "GPIO46",
-                           THUNDERBAY_MUX(0X0, "ETHER1_M0"),
-                           THUNDERBAY_MUX(0X1, "TPIU_DATA_M1"),
-                           THUNDERBAY_MUX(0X2, "TPIU_DATA_M2"),
-                           THUNDERBAY_MUX(0X3, "DEBUG_M3"),
-                           THUNDERBAY_MUX(0X4, "GPIO_M4")),
-       THUNDERBAY_PIN_DESC(47, "GPIO47",
-                           THUNDERBAY_MUX(0X0, "ETHER1_M0"),
-                           THUNDERBAY_MUX(0X1, "TPIU_DATA_M1"),
-                           THUNDERBAY_MUX(0X2, "TPIU_DATA_M2"),
-                           THUNDERBAY_MUX(0X3, "DEBUG_M3"),
-                           THUNDERBAY_MUX(0X4, "GPIO_M4")),
-       THUNDERBAY_PIN_DESC(48, "GPIO48",
-                           THUNDERBAY_MUX(0X0, "ETHER1_M0"),
-                           THUNDERBAY_MUX(0X1, "TPIU_DATA_M1"),
-                           THUNDERBAY_MUX(0X2, "TPIU_DATA_M2"),
-                           THUNDERBAY_MUX(0X3, "DEBUG_M3"),
-                           THUNDERBAY_MUX(0X4, "GPIO_M4")),
-       THUNDERBAY_PIN_DESC(49, "GPIO49",
-                           THUNDERBAY_MUX(0X0, "ETHER1_M0"),
-                           THUNDERBAY_MUX(0X1, "TPIU_DATA_M1"),
-                           THUNDERBAY_MUX(0X2, "TPIU_DATA_M2"),
-                           THUNDERBAY_MUX(0X3, "DEBUG_M3"),
-                           THUNDERBAY_MUX(0X4, "GPIO_M4")),
-       THUNDERBAY_PIN_DESC(50, "GPIO50",
-                           THUNDERBAY_MUX(0X0, "ETHER1_M0"),
-                           THUNDERBAY_MUX(0X1, "TPIU_DATA_M1"),
-                           THUNDERBAY_MUX(0X2, "TPIU_DATA_M2"),
-                           THUNDERBAY_MUX(0X3, "DIG_VIEW_0"),
-                           THUNDERBAY_MUX(0X4, "GPIO_M4")),
-       THUNDERBAY_PIN_DESC(51, "GPIO51",
-                           THUNDERBAY_MUX(0X0, "ETHER1_M0"),
-                           THUNDERBAY_MUX(0X1, "TPIU_DATA_M1"),
-                           THUNDERBAY_MUX(0X2, "TPIU_DATA_M2"),
-                           THUNDERBAY_MUX(0X3, "DIG_VIEW_1"),
-                           THUNDERBAY_MUX(0X4, "GPIO_M4")),
-       THUNDERBAY_PIN_DESC(52, "GPIO52",
-                           THUNDERBAY_MUX(0X0, "ETHER1_M0"),
-                           THUNDERBAY_MUX(0X1, "TPIU_DATA_M1"),
-                           THUNDERBAY_MUX(0X2, "TPIU_DATA_M2"),
-                           THUNDERBAY_MUX(0X3, "CPR_IO_OUT_CLK_0"),
-                           THUNDERBAY_MUX(0X4, "GPIO_M4")),
-       THUNDERBAY_PIN_DESC(53, "GPIO53",
-                           THUNDERBAY_MUX(0X0, "ETHER1_M0"),
-                           THUNDERBAY_MUX(0X1, "TPIU_DATA_M1"),
-                           THUNDERBAY_MUX(0X2, "TPIU_DATA_M2"),
-                           THUNDERBAY_MUX(0X3, "CPR_IO_OUT_CLK_1"),
-                           THUNDERBAY_MUX(0X4, "GPIO_M4")),
-       THUNDERBAY_PIN_DESC(54, "GPIO54",
-                           THUNDERBAY_MUX(0X0, "ETHER1_M0"),
-                           THUNDERBAY_MUX(0X1, "TPIU_DATA_M1"),
-                           THUNDERBAY_MUX(0X2, "TPIU_DATA_M2"),
-                           THUNDERBAY_MUX(0X3, "CPR_IO_OUT_CLK_2"),
-                           THUNDERBAY_MUX(0X4, "GPIO_M4")),
-       THUNDERBAY_PIN_DESC(55, "GPIO55",
-                           THUNDERBAY_MUX(0X0, "ETHER1_M0"),
-                           THUNDERBAY_MUX(0X1, "TPIU_DATA_M1"),
-                           THUNDERBAY_MUX(0X2, "TPIU_DATA_M2"),
-                           THUNDERBAY_MUX(0X3, "CPR_IO_OUT_CLK_3"),
-                           THUNDERBAY_MUX(0X4, "GPIO_M4")),
-       THUNDERBAY_PIN_DESC(56, "GPIO56",
-                           THUNDERBAY_MUX(0X0, "ETHER1_M0"),
-                           THUNDERBAY_MUX(0X1, "TPIU_DATA_M1"),
-                           THUNDERBAY_MUX(0X2, "TPIU_DATA_M2"),
-                           THUNDERBAY_MUX(0X3, "POWER_INTERRUPT_ICCMAX_VDDD_M3"),
-                           THUNDERBAY_MUX(0X4, "GPIO_M4")),
-       THUNDERBAY_PIN_DESC(57, "GPIO57",
-                           THUNDERBAY_MUX(0X0, "POWER_INTERRUPT_ICCMAX_VPU_M0"),
-                           THUNDERBAY_MUX(0X1, "TPIU_DATA_M1"),
-                           THUNDERBAY_MUX(0X2, "TPIU_DATA_M2"),
-                           THUNDERBAY_MUX(0X3, "EMPTY_M3"),
-                           THUNDERBAY_MUX(0X4, "GPIO_M4")),
-       THUNDERBAY_PIN_DESC(58, "GPIO58",
-                           THUNDERBAY_MUX(0X0, "THERMTRIP_M0"),
-                           THUNDERBAY_MUX(0X1, "EMPTY_M1"),
-                           THUNDERBAY_MUX(0X2, "EMPTY_M2"),
-                           THUNDERBAY_MUX(0X3, "EMPTY_M3"),
-                           THUNDERBAY_MUX(0X4, "GPIO_M4")),
-       THUNDERBAY_PIN_DESC(59, "GPIO59",
-                           THUNDERBAY_MUX(0X0, "THERMTRIP_M0"),
-                           THUNDERBAY_MUX(0X1, "EMPTY_M1"),
-                           THUNDERBAY_MUX(0X2, "EMPTY_M2"),
-                           THUNDERBAY_MUX(0X3, "EMPTY_M3"),
-                           THUNDERBAY_MUX(0X4, "GPIO_M4")),
-       THUNDERBAY_PIN_DESC(60, "GPIO60",
-                           THUNDERBAY_MUX(0X0, "SMBUS_M0"),
-                           THUNDERBAY_MUX(0X1, "EMPTY_M1"),
-                           THUNDERBAY_MUX(0X2, "EMPTY_M2"),
-                           THUNDERBAY_MUX(0X3, "EMPTY_M3"),
-                           THUNDERBAY_MUX(0X4, "GPIO_M4")),
-       THUNDERBAY_PIN_DESC(61, "GPIO61",
-                           THUNDERBAY_MUX(0X0, "SMBUS_M0"),
-                           THUNDERBAY_MUX(0X1, "EMPTY_M1"),
-                           THUNDERBAY_MUX(0X2, "EMPTY_M2"),
-                           THUNDERBAY_MUX(0X3, "POWER_INTERRUPT_ICCMAX_VDDD_M3"),
-                           THUNDERBAY_MUX(0X4, "GPIO_M4")),
-       THUNDERBAY_PIN_DESC(62, "GPIO62",
-                           THUNDERBAY_MUX(0X0, "PLATFORM_RESET_M0"),
-                           THUNDERBAY_MUX(0X1, "EMPTY_M1"),
-                           THUNDERBAY_MUX(0X2, "EMPTY_M2"),
-                           THUNDERBAY_MUX(0X3, "EMPTY_M3"),
-                           THUNDERBAY_MUX(0X4, "GPIO_M4")),
-       THUNDERBAY_PIN_DESC(63, "GPIO63",
-                           THUNDERBAY_MUX(0X0, "PLATFORM_RESET_M0"),
-                           THUNDERBAY_MUX(0X1, "EMPTY_M1"),
-                           THUNDERBAY_MUX(0X2, "EMPTY_M2"),
-                           THUNDERBAY_MUX(0X3, "EMPTY_M3"),
-                           THUNDERBAY_MUX(0X4, "GPIO_M4")),
-       THUNDERBAY_PIN_DESC(64, "GPIO64",
-                           THUNDERBAY_MUX(0X0, "PLATFORM_SHUTDOWN_M0"),
-                           THUNDERBAY_MUX(0X1, "EMPTY_M1"),
-                           THUNDERBAY_MUX(0X2, "EMPTY_M2"),
-                           THUNDERBAY_MUX(0X3, "EMPTY_M3"),
-                           THUNDERBAY_MUX(0X4, "GPIO_M4")),
-       THUNDERBAY_PIN_DESC(65, "GPIO65",
-                           THUNDERBAY_MUX(0X0, "PLATFORM_SHUTDOWN_M0"),
-                           THUNDERBAY_MUX(0X1, "EMPTY_M1"),
-                           THUNDERBAY_MUX(0X2, "EMPTY_M2"),
-                           THUNDERBAY_MUX(0X3, "EMPTY_M3"),
-                           THUNDERBAY_MUX(0X4, "GPIO_M4")),
-       THUNDERBAY_PIN_DESC(66, "GPIO66",
-                           THUNDERBAY_MUX(0X0, "POWER_INTERRUPT_ICCMAX_MEDIA_M0"),
-                           THUNDERBAY_MUX(0X1, "EMPTY_M1"),
-                           THUNDERBAY_MUX(0X2, "EMPTY_M2"),
-                           THUNDERBAY_MUX(0X3, "EMPTY_M3"),
-                           THUNDERBAY_MUX(0X4, "GPIO_M4")),
-};
-
-static const struct thunderbay_pin_soc thunderbay_data = {
-       .pins   = thunderbay_pins,
-       .npins  = ARRAY_SIZE(thunderbay_pins),
-};
-
-static u32 thb_gpio_read_reg(struct gpio_chip *chip, unsigned int pinnr)
-{
-       struct thunderbay_pinctrl *tpc = gpiochip_get_data(chip);
-
-       return readl(tpc->base0 + THB_GPIO_REG_OFFSET(pinnr));
-}
-
-static u32 thb_gpio_write_reg(struct gpio_chip *chip, unsigned int pinnr, u32 value)
-{
-       struct thunderbay_pinctrl *tpc = gpiochip_get_data(chip);
-
-       writel(value, (tpc->base0 + THB_GPIO_REG_OFFSET(pinnr)));
-       return 0;
-}
-
-static int thb_read_gpio_data(struct gpio_chip *chip, unsigned int offset, unsigned int pad_dir)
-{
-       int data_offset;
-       u32 data_reg;
-
-       /* as per GPIO Spec = pad_dir 0:input, 1:output */
-       data_offset = 0x2000u + (offset / 32);
-       if (!pad_dir)
-               data_offset += 4;
-       data_reg = thb_gpio_read_reg(chip, data_offset);
-
-       return data_reg & BIT(offset % 32);
-}
-
-static int thb_write_gpio_data(struct gpio_chip *chip, unsigned int offset, unsigned int value)
-{
-       int data_offset;
-       u32 data_reg;
-
-       data_offset = 0x2000u + (offset / 32);
-
-       data_reg = thb_gpio_read_reg(chip, data_offset);
-
-       if (value > 0)
-               data_reg |= BIT(offset % 32);
-       else
-               data_reg &= ~BIT(offset % 32);
-
-       return thb_gpio_write_reg(chip, data_offset, data_reg);
-}
-
-static int thunderbay_gpio_get_direction(struct gpio_chip *chip, unsigned int offset)
-{
-       u32 reg = thb_gpio_read_reg(chip, offset);
-
-       /* Return direction only if configured as GPIO else negative error */
-       if (reg & THB_GPIO_PORT_SELECT_MASK)
-               return !(reg & THB_GPIO_PAD_DIRECTION_MASK);
-       return -EINVAL;
-}
-
-static int thunderbay_gpio_set_direction_input(struct gpio_chip *chip, unsigned int offset)
-{
-       u32 reg = thb_gpio_read_reg(chip, offset);
-
-       /* set pin as input only if it is GPIO else error */
-       if (reg & THB_GPIO_PORT_SELECT_MASK) {
-               reg &= (~THB_GPIO_PAD_DIRECTION_MASK);
-               thb_gpio_write_reg(chip, offset, reg);
-               return 0;
-       }
-       return -EINVAL;
-}
-
-static void thunderbay_gpio_set_value(struct gpio_chip *chip, unsigned int offset, int value)
-{
-       u32 reg = thb_gpio_read_reg(chip, offset);
-
-       /* update pin value only if it is GPIO-output else error */
-       if ((reg & THB_GPIO_PORT_SELECT_MASK) && (reg & THB_GPIO_PAD_DIRECTION_MASK))
-               thb_write_gpio_data(chip, offset, value);
-}
-
-static int thunderbay_gpio_set_direction_output(struct gpio_chip *chip,
-                                               unsigned int offset, int value)
-{
-       u32 reg = thb_gpio_read_reg(chip, offset);
-
-       /* set pin as output only if it is GPIO else error */
-       if (reg & THB_GPIO_PORT_SELECT_MASK) {
-               reg |= THB_GPIO_PAD_DIRECTION_MASK;
-               thb_gpio_write_reg(chip, offset, reg);
-               thunderbay_gpio_set_value(chip, offset, value);
-               return 0;
-       }
-       return -EINVAL;
-}
-
-static int thunderbay_gpio_get_value(struct gpio_chip *chip, unsigned int offset)
-{
-       u32 reg = thb_gpio_read_reg(chip, offset);
-       int gpio_dir = 0;
-
-       /* Read pin value only if it is GPIO else error */
-       if (reg & THB_GPIO_PORT_SELECT_MASK) {
-               /* 0=in, 1=out */
-               gpio_dir = (reg & THB_GPIO_PAD_DIRECTION_MASK) > 0;
-
-               /* Returns negative value when pin is configured as PORT */
-               return thb_read_gpio_data(chip, offset, gpio_dir);
-       }
-       return -EINVAL;
-}
-
-static int thunderbay_gpiochip_probe(struct thunderbay_pinctrl *tpc)
-{
-       struct gpio_chip *chip = &tpc->chip;
-       int ret;
-
-       chip->label             = dev_name(tpc->dev);
-       chip->parent            = tpc->dev;
-       chip->request           = gpiochip_generic_request;
-       chip->free              = gpiochip_generic_free;
-       chip->get_direction     = thunderbay_gpio_get_direction;
-       chip->direction_input   = thunderbay_gpio_set_direction_input;
-       chip->direction_output  = thunderbay_gpio_set_direction_output;
-       chip->get               = thunderbay_gpio_get_value;
-       chip->set               = thunderbay_gpio_set_value;
-       chip->set_config        = gpiochip_generic_config;
-       /* identifies the first GPIO number handled by this chip; or,
-        * if negative during registration, requests dynamic ID allocation.
-        * Please pass -1 as base to let gpiolib select the chip base in all possible cases.
-        * We want to get rid of the static GPIO number space in the long run.
-        */
-       chip->base              = -1;
-       /* Number of GPIOs handled by this controller; the last GPIO handled is (base + ngpio - 1)*/
-       chip->ngpio             = THB_MAX_NPINS_SUPPORTED;
-
-       /* Register/add Thunder Bay GPIO chip with Linux framework */
-       ret = gpiochip_add_data(chip, tpc);
-       if (ret)
-               dev_err(tpc->dev, "Failed to add gpiochip\n");
-       return ret;
-}
-
-static int thunderbay_request_gpio(struct pinctrl_dev *pctldev,
-                                  struct pinctrl_gpio_range *range,
-                                  unsigned int pin)
-{
-       struct thunderbay_pinctrl *tpc = pinctrl_dev_get_drvdata(pctldev);
-       struct gpio_chip *chip = &tpc->chip;
-       u32 reg = 0;
-
-       if (thb_pinx_status[pin] == 0u) {
-               reg = thb_gpio_read_reg(chip, pin);
-               /* Updates PIN configuration as GPIO and sets GPIO to MODE-4*/
-               reg |= (THB_GPIO_PORT_SELECT_MASK | THB_GPIO_PINMUX_MODE_4);
-               thb_gpio_write_reg(chip, pin, reg);
-
-               /* update pin status as busy */
-               thb_pinx_status[pin] = 1u;
-
-               return 0;
-       }
-       return -EINVAL;
-}
-
-static void thunderbay_free_gpio(struct pinctrl_dev *pctldev,
-                                struct pinctrl_gpio_range *range,
-                                unsigned int pin)
-{
-       struct thunderbay_pinctrl *tpc = pinctrl_dev_get_drvdata(pctldev);
-       struct gpio_chip *chip = &tpc->chip;
-       u32 reg = 0;
-
-       if (thb_pinx_status[pin] == 1u) {
-               reg = thb_gpio_read_reg(chip, pin);
-
-               /* Updates PIN configuration from GPIO to PORT */
-               reg &= (~THB_GPIO_PORT_SELECT_MASK);
-
-               /* Change Port/gpio mode to default mode-0 */
-               reg &= (~THB_GPIO_PINMUX_MODE_4);
-
-               thb_gpio_write_reg(chip, pin, reg);
-
-               /* update pin status as free */
-               thb_pinx_status[pin] = 0u;
-       }
-}
-
-static int thb_pinctrl_set_mux(struct pinctrl_dev *pctldev,
-                              unsigned int func_select, unsigned int group_select)
-{
-       struct thunderbay_pinctrl *tpc = pinctrl_dev_get_drvdata(pctldev);
-       struct gpio_chip *chip = &tpc->chip;
-       struct function_desc *function;
-       unsigned int i, pin_mode;
-       struct group_desc *group;
-       int ret = -EINVAL;
-       u32 reg = 0u;
-
-       group = pinctrl_generic_get_group(pctldev, group_select);
-       if (!group)
-               return -EINVAL;
-
-       function = pinmux_generic_get_function(pctldev, func_select);
-       if (!function)
-               return -EINVAL;
-
-       pin_mode = *(unsigned int *)(function->data);
-
-       /* Change modes for pins in the selected group */
-       for (i = 0; i < group->num_pins; i++) {
-               reg = thb_gpio_read_reg(chip, group->pins[i]);
-
-               switch (pin_mode) {
-               case 0u:
-                       reg |= THB_GPIO_PINMUX_MODE_0;
-                       break;
-               case 1u:
-                       reg |= THB_GPIO_PINMUX_MODE_1;
-                       break;
-               case 2u:
-                       reg |= THB_GPIO_PINMUX_MODE_2;
-                       break;
-               case 3u:
-                       reg |= THB_GPIO_PINMUX_MODE_3;
-                       break;
-               case 4u:
-                       reg |= THB_GPIO_PINMUX_MODE_4;
-                       break;
-               default:
-                       return -EINVAL;
-               }
-
-               ret = thb_gpio_write_reg(chip, group->pins[i], reg);
-               if (~ret) {
-                       /* update pin status as busy */
-                       thb_pinx_status[group->pins[i]] = 1u;
-               }
-       }
-       return ret;
-}
-
-static int thunderbay_build_groups(struct thunderbay_pinctrl *tpc)
-{
-       struct group_desc *thunderbay_groups;
-       int i;
-
-       tpc->ngroups = tpc->soc->npins;
-       thunderbay_groups = devm_kcalloc(tpc->dev, tpc->ngroups,
-                                        sizeof(*thunderbay_groups), GFP_KERNEL);
-       if (!thunderbay_groups)
-               return -ENOMEM;
-
-       for (i = 0; i < tpc->ngroups; i++) {
-               struct group_desc *group = thunderbay_groups + i;
-               const struct pinctrl_pin_desc *pin_info = thunderbay_pins + i;
-
-               group->name = pin_info->name;
-               group->pins = (int *)&pin_info->number;
-               pinctrl_generic_add_group(tpc->pctrl, group->name,
-                                         group->pins, 1, NULL);
-       }
-       return 0;
-}
-
-static int thunderbay_add_functions(struct thunderbay_pinctrl *tpc, struct function_desc *funcs)
-{
-       int i;
-
-       /* Assign the groups for each function */
-       for (i = 0; i < tpc->nfuncs; i++) {
-               struct function_desc *func = &funcs[i];
-               const char **group_names;
-               unsigned int grp_idx = 0;
-               int j;
-
-               group_names = devm_kcalloc(tpc->dev, func->num_group_names,
-                                          sizeof(*group_names), GFP_KERNEL);
-               if (!group_names)
-                       return -ENOMEM;
-
-               for (j = 0; j < tpc->soc->npins; j++) {
-                       const struct pinctrl_pin_desc *pin_info = &thunderbay_pins[j];
-                       struct thunderbay_mux_desc *pin_mux;
-
-                       for (pin_mux = pin_info->drv_data; pin_mux->name; pin_mux++) {
-                               if (!strcmp(pin_mux->name, func->name))
-                                       group_names[grp_idx++] = pin_info->name;
-                       }
-               }
-
-               func->group_names = group_names;
-       }
-
-       /* Add all functions */
-       for (i = 0; i < tpc->nfuncs; i++) {
-               pinmux_generic_add_function(tpc->pctrl,
-                                           funcs[i].name,
-                                           funcs[i].group_names,
-                                           funcs[i].num_group_names,
-                                           funcs[i].data);
-       }
-
-       return 0;
-}
-
-static int thunderbay_build_functions(struct thunderbay_pinctrl *tpc)
-{
-       struct function_desc *thunderbay_funcs;
-       void *ptr;
-       int pin;
-       int ret;
-
-       /*
-        * Allocate maximum possible number of functions. Assume every pin
-        * being part of 8 (hw maximum) globally unique muxes.
-        */
-       tpc->nfuncs = 0;
-       thunderbay_funcs = kcalloc(tpc->soc->npins * 8,
-                                  sizeof(*thunderbay_funcs), GFP_KERNEL);
-       if (!thunderbay_funcs)
-               return -ENOMEM;
-
-       /* Setup 1 function for each unique mux */
-       for (pin = 0; pin < tpc->soc->npins; pin++) {
-               const struct pinctrl_pin_desc *pin_info = thunderbay_pins + pin;
-               struct thunderbay_mux_desc *pin_mux;
-
-               for (pin_mux = pin_info->drv_data; pin_mux->name; pin_mux++) {
-                       struct function_desc *func;
-
-                       /* Check if we already have function for this mux */
-                       for (func = thunderbay_funcs; func->name; func++) {
-                               if (!strcmp(pin_mux->name, func->name)) {
-                                       func->num_group_names++;
-                                       break;
-                               }
-                       }
-
-                       if (!func->name) {
-                               func->name = pin_mux->name;
-                               func->num_group_names = 1;
-                               func->data = (int *)&pin_mux->mode;
-                               tpc->nfuncs++;
-                       }
-               }
-       }
-
-       /* Reallocate memory based on actual number of functions */
-       ptr = krealloc(thunderbay_funcs,
-                      tpc->nfuncs * sizeof(*thunderbay_funcs), GFP_KERNEL);
-       if (!ptr)
-               return -ENOMEM;
-
-       thunderbay_funcs = ptr;
-       ret = thunderbay_add_functions(tpc, thunderbay_funcs);
-
-       kfree(thunderbay_funcs);
-       return ret;
-}
-
-static int thunderbay_pinconf_set_tristate(struct thunderbay_pinctrl *tpc,
-                                          unsigned int pin, u32 config)
-{
-       struct gpio_chip *chip = &tpc->chip;
-       u32 reg;
-
-       reg = thb_gpio_read_reg(chip, pin);
-       if (config > 0)
-               reg |= THB_GPIO_ENAQ_MASK;
-       else
-               reg &= ~THB_GPIO_ENAQ_MASK;
-
-       return thb_gpio_write_reg(chip, pin, reg);
-}
-
-static int thunderbay_pinconf_get_tristate(struct thunderbay_pinctrl *tpc,
-                                          unsigned int pin, u32 *config)
-{
-       struct gpio_chip *chip = &tpc->chip;
-       u32 reg;
-
-       reg = thb_gpio_read_reg(chip, pin);
-       *config = (reg & THB_GPIO_ENAQ_MASK) > 0;
-
-       return 0;
-}
-
-static int thunderbay_pinconf_set_pulldown(struct thunderbay_pinctrl *tpc,
-                                          unsigned int pin, u32 config)
-{
-       struct gpio_chip *chip = &tpc->chip;
-       u32 reg;
-
-       reg = thb_gpio_read_reg(chip, pin);
-       if (config > 0)
-               reg |= THB_GPIO_PULL_DOWN_MASK;
-       else
-               reg &= ~THB_GPIO_PULL_DOWN_MASK;
-
-       return thb_gpio_write_reg(chip, pin, reg);
-}
-
-static int thunderbay_pinconf_get_pulldown(struct thunderbay_pinctrl *tpc,
-                                          unsigned int pin, u32 *config)
-{
-       struct gpio_chip *chip = &tpc->chip;
-       u32 reg = 0;
-
-       reg = thb_gpio_read_reg(chip, pin);
-       *config = ((reg & THB_GPIO_PULL_DOWN_MASK) > 0) ? 1 : 0;
-
-       return 0;
-}
-
-static int thunderbay_pinconf_set_pullup(struct thunderbay_pinctrl *tpc,
-                                        unsigned int pin, u32 config)
-{
-       struct gpio_chip *chip = &tpc->chip;
-       u32 reg;
-
-       reg = thb_gpio_read_reg(chip, pin);
-       if (config > 0)
-               reg &= ~THB_GPIO_PULL_UP_MASK;
-       else
-               reg |= THB_GPIO_PULL_UP_MASK;
-
-       return thb_gpio_write_reg(chip, pin, reg);
-}
-
-static int thunderbay_pinconf_get_pullup(struct thunderbay_pinctrl *tpc,
-                                        unsigned int pin, u32 *config)
-{
-       struct gpio_chip *chip = &tpc->chip;
-       u32 reg;
-
-       reg = thb_gpio_read_reg(chip, pin);
-       *config = ((reg & THB_GPIO_PULL_UP_MASK) == 0) ? 1 : 0;
-
-       return 0;
-}
-
-static int thunderbay_pinconf_set_opendrain(struct thunderbay_pinctrl *tpc,
-                                           unsigned int pin, u32 config)
-{
-       struct gpio_chip *chip = &tpc->chip;
-       u32 reg;
-
-       reg = thb_gpio_read_reg(chip, pin);
-       if (config > 0)
-               reg &= ~THB_GPIO_PULL_ENABLE_MASK;
-       else
-               reg |= THB_GPIO_PULL_ENABLE_MASK;
-
-       return thb_gpio_write_reg(chip, pin, reg);
-}
-
-static int thunderbay_pinconf_get_opendrain(struct thunderbay_pinctrl *tpc,
-                                           unsigned int pin, u32 *config)
-{
-       struct gpio_chip *chip = &tpc->chip;
-       u32 reg;
-
-       reg = thb_gpio_read_reg(chip, pin);
-       *config = ((reg & THB_GPIO_PULL_ENABLE_MASK) == 0) ? 1 : 0;
-
-       return 0;
-}
-
-static int thunderbay_pinconf_set_pushpull(struct thunderbay_pinctrl *tpc,
-                                          unsigned int pin, u32 config)
-{
-       struct gpio_chip *chip = &tpc->chip;
-       u32 reg;
-
-       reg = thb_gpio_read_reg(chip, pin);
-       if (config > 0)
-               reg |= THB_GPIO_PULL_ENABLE_MASK;
-       else
-               reg &= ~THB_GPIO_PULL_ENABLE_MASK;
-
-       return thb_gpio_write_reg(chip, pin, reg);
-}
-
-static int thunderbay_pinconf_get_pushpull(struct thunderbay_pinctrl *tpc,
-                                          unsigned int pin, u32 *config)
-{
-       struct gpio_chip *chip = &tpc->chip;
-       u32 reg;
-
-       reg = thb_gpio_read_reg(chip, pin);
-       *config = ((reg & THB_GPIO_PULL_ENABLE_MASK) > 0) ? 1 : 0;
-
-       return 0;
-}
-
-static int thunderbay_pinconf_set_drivestrength(struct thunderbay_pinctrl *tpc,
-                                               unsigned int pin, u32 config)
-{
-       struct gpio_chip *chip = &tpc->chip;
-       u32 reg;
-
-       reg = thb_gpio_read_reg(chip, pin);
-
-       /* Drive Strength: 0x0 to 0xF */
-       if (config <= 0xF) {
-               reg = (reg | config);
-               return thb_gpio_write_reg(chip, pin, reg);
-       }
-
-       return -EINVAL;
-}
-
-static int thunderbay_pinconf_get_drivestrength(struct thunderbay_pinctrl *tpc,
-                                               unsigned int pin, u32 *config)
-{
-       struct gpio_chip *chip = &tpc->chip;
-       u32 reg;
-
-       reg = thb_gpio_read_reg(chip, pin);
-       reg = (reg & THB_GPIO_DRIVE_STRENGTH_MASK) >> 16;
-       *config = (reg > 0) ? reg : 0;
-
-       return 0;
-}
-
-static int thunderbay_pinconf_set_schmitt(struct thunderbay_pinctrl *tpc,
-                                         unsigned int pin, u32 config)
-{
-       struct gpio_chip *chip = &tpc->chip;
-       u32 reg;
-
-       reg = thb_gpio_read_reg(chip, pin);
-       if (config > 0)
-               reg |= THB_GPIO_SCHMITT_TRIGGER_MASK;
-       else
-               reg &= ~THB_GPIO_SCHMITT_TRIGGER_MASK;
-
-       return thb_gpio_write_reg(chip, pin, reg);
-}
-
-static int thunderbay_pinconf_get_schmitt(struct thunderbay_pinctrl *tpc,
-                                         unsigned int pin, u32 *config)
-{
-       struct gpio_chip *chip = &tpc->chip;
-       u32 reg;
-
-       reg = thb_gpio_read_reg(chip, pin);
-       *config = ((reg & THB_GPIO_SCHMITT_TRIGGER_MASK) > 0) ? 1 : 0;
-
-       return 0;
-}
-
-static int thunderbay_pinconf_set_slew_rate(struct thunderbay_pinctrl *tpc,
-                                           unsigned int pin, u32 config)
-{
-       struct gpio_chip *chip = &tpc->chip;
-       u32 reg = 0;
-
-       reg = thb_gpio_read_reg(chip, pin);
-       if (config > 0)
-               reg |= THB_GPIO_SLEW_RATE_MASK;
-       else
-               reg &= ~THB_GPIO_SLEW_RATE_MASK;
-
-       return thb_gpio_write_reg(chip, pin, reg);
-}
-
-static int thunderbay_pinconf_get_slew_rate(struct thunderbay_pinctrl *tpc,
-                                           unsigned int pin, u32 *config)
-{
-       struct gpio_chip *chip = &tpc->chip;
-       u32 reg;
-
-       reg = thb_gpio_read_reg(chip, pin);
-       *config = ((reg & THB_GPIO_SLEW_RATE_MASK) > 0) ? 1 : 0;
-
-       return 0;
-}
-
-static int thunderbay_pinconf_get(struct pinctrl_dev *pctldev, unsigned int pin,
-                                 unsigned long *config)
-{
-       struct thunderbay_pinctrl *tpc = pinctrl_dev_get_drvdata(pctldev);
-       enum pin_config_param param = pinconf_to_config_param(*config);
-       u32 arg;
-       int ret;
-
-       switch (param) {
-       case PIN_CONFIG_BIAS_HIGH_IMPEDANCE:
-               ret = thunderbay_pinconf_get_tristate(tpc, pin, &arg);
-               break;
-
-       case PIN_CONFIG_BIAS_PULL_DOWN:
-               ret = thunderbay_pinconf_get_pulldown(tpc, pin, &arg);
-               break;
-
-       case PIN_CONFIG_BIAS_PULL_UP:
-               ret = thunderbay_pinconf_get_pullup(tpc, pin, &arg);
-               break;
-
-       case PIN_CONFIG_DRIVE_OPEN_DRAIN:
-               ret = thunderbay_pinconf_get_opendrain(tpc, pin, &arg);
-               break;
-
-       case PIN_CONFIG_DRIVE_PUSH_PULL:
-               ret = thunderbay_pinconf_get_pushpull(tpc, pin, &arg);
-               break;
-
-       case PIN_CONFIG_DRIVE_STRENGTH:
-               ret = thunderbay_pinconf_get_drivestrength(tpc, pin, &arg);
-               break;
-
-       case PIN_CONFIG_INPUT_SCHMITT_ENABLE:
-               ret = thunderbay_pinconf_get_schmitt(tpc, pin, &arg);
-               break;
-
-       case PIN_CONFIG_SLEW_RATE:
-               ret = thunderbay_pinconf_get_slew_rate(tpc, pin, &arg);
-               break;
-
-       default:
-               return -ENOTSUPP;
-       }
-
-       *config = pinconf_to_config_packed(param, arg);
-
-       return ret;
-}
-
-static int thunderbay_pinconf_set(struct pinctrl_dev *pctldev, unsigned int pin,
-                                 unsigned long *configs, unsigned int num_configs)
-{
-       struct thunderbay_pinctrl *tpc = pinctrl_dev_get_drvdata(pctldev);
-       enum pin_config_param param;
-       unsigned int pinconf;
-       int ret = 0;
-       u32 arg;
-
-       for (pinconf = 0; pinconf < num_configs; pinconf++) {
-               param = pinconf_to_config_param(configs[pinconf]);
-               arg = pinconf_to_config_argument(configs[pinconf]);
-
-               switch (param) {
-               case PIN_CONFIG_BIAS_HIGH_IMPEDANCE:
-                       ret = thunderbay_pinconf_set_tristate(tpc, pin, arg);
-                       break;
-
-               case PIN_CONFIG_BIAS_PULL_DOWN:
-                       ret = thunderbay_pinconf_set_pulldown(tpc, pin, arg);
-                       break;
-
-               case PIN_CONFIG_BIAS_PULL_UP:
-                       ret = thunderbay_pinconf_set_pullup(tpc, pin, arg);
-                       break;
-
-               case PIN_CONFIG_DRIVE_OPEN_DRAIN:
-                       ret = thunderbay_pinconf_set_opendrain(tpc, pin, arg);
-                       break;
-
-               case PIN_CONFIG_DRIVE_PUSH_PULL:
-                       ret = thunderbay_pinconf_set_pushpull(tpc, pin, arg);
-                       break;
-
-               case PIN_CONFIG_DRIVE_STRENGTH:
-                       ret = thunderbay_pinconf_set_drivestrength(tpc, pin, arg);
-                       break;
-
-               case PIN_CONFIG_INPUT_SCHMITT_ENABLE:
-                       ret = thunderbay_pinconf_set_schmitt(tpc, pin, arg);
-                       break;
-
-               case PIN_CONFIG_SLEW_RATE:
-                       ret = thunderbay_pinconf_set_slew_rate(tpc, pin, arg);
-                       break;
-
-               default:
-                       return -ENOTSUPP;
-               }
-       }
-       return ret;
-}
-
-static const struct pinctrl_ops thunderbay_pctlops = {
-       .get_groups_count = pinctrl_generic_get_group_count,
-       .get_group_name   = pinctrl_generic_get_group_name,
-       .get_group_pins   = pinctrl_generic_get_group_pins,
-       .dt_node_to_map   = pinconf_generic_dt_node_to_map_all,
-       .dt_free_map      = pinconf_generic_dt_free_map,
-};
-
-static const struct pinmux_ops thunderbay_pmxops = {
-       .get_functions_count    = pinmux_generic_get_function_count,
-       .get_function_name      = pinmux_generic_get_function_name,
-       .get_function_groups    = pinmux_generic_get_function_groups,
-       .set_mux                = thb_pinctrl_set_mux,
-       .gpio_request_enable    = thunderbay_request_gpio,
-       .gpio_disable_free      = thunderbay_free_gpio,
-};
-
-static const struct pinconf_ops thunderbay_confops = {
-       .is_generic             = true,
-       .pin_config_get         = thunderbay_pinconf_get,
-       .pin_config_set         = thunderbay_pinconf_set,
-};
-
-static struct pinctrl_desc thunderbay_pinctrl_desc = {
-       .name           = "thunderbay-pinmux",
-       .pctlops        = &thunderbay_pctlops,
-       .pmxops         = &thunderbay_pmxops,
-       .confops        = &thunderbay_confops,
-       .owner          = THIS_MODULE,
-};
-
-static const struct of_device_id thunderbay_pinctrl_match[] = {
-       {
-               .compatible = "intel,thunderbay-pinctrl",
-               .data = &thunderbay_data
-       },
-       {}
-};
-
-static int thunderbay_pinctrl_probe(struct platform_device *pdev)
-{
-       const struct of_device_id *of_id;
-       struct device *dev = &pdev->dev;
-       struct thunderbay_pinctrl *tpc;
-       int ret;
-
-       of_id = of_match_node(thunderbay_pinctrl_match, pdev->dev.of_node);
-       if (!of_id)
-               return -ENODEV;
-
-       tpc = devm_kzalloc(dev, sizeof(*tpc), GFP_KERNEL);
-       if (!tpc)
-               return -ENOMEM;
-
-       tpc->dev = dev;
-       tpc->soc = of_id->data;
-
-       tpc->base0 = devm_platform_ioremap_resource(pdev, 0);
-       if (IS_ERR(tpc->base0))
-               return PTR_ERR(tpc->base0);
-
-       thunderbay_pinctrl_desc.pins = tpc->soc->pins;
-       thunderbay_pinctrl_desc.npins = tpc->soc->npins;
-
-       /* Register pinctrl */
-       tpc->pctrl = devm_pinctrl_register(dev, &thunderbay_pinctrl_desc, tpc);
-       if (IS_ERR(tpc->pctrl))
-               return PTR_ERR(tpc->pctrl);
-
-       /* Setup pinmux groups */
-       ret = thunderbay_build_groups(tpc);
-       if (ret)
-               return ret;
-
-       /* Setup pinmux functions */
-       ret = thunderbay_build_functions(tpc);
-       if (ret)
-               return ret;
-
-       /* Setup GPIO */
-       ret = thunderbay_gpiochip_probe(tpc);
-       if (ret < 0)
-               return ret;
-
-       platform_set_drvdata(pdev, tpc);
-
-       return 0;
-}
-
-static struct platform_driver thunderbay_pinctrl_driver = {
-       .driver = {
-               .name = "thunderbay-pinctrl",
-               .of_match_table = thunderbay_pinctrl_match,
-       },
-       .probe = thunderbay_pinctrl_probe,
-};
-
-builtin_platform_driver(thunderbay_pinctrl_driver);
-
-MODULE_AUTHOR("Lakshmi Sowjanya D <lakshmi.sowjanya.d@intel.com>");
-MODULE_AUTHOR("Kiran Kumar S <kiran.kumar1.s@intel.com>");
-MODULE_DESCRIPTION("Intel Thunder Bay Pinctrl/GPIO Driver");
-MODULE_LICENSE("GPL v2");
index 3a03beb8a755736091982be9ec233ddce3c9f824..858abb23b337819a148fdf9b6179af14c90c44c1 100644 (file)
@@ -107,243 +107,6 @@ enum xway_mux {
        XWAY_MUX_NONE = 0xffff,
 };
 
-/* ---------  DEPRECATED: xr9 related code --------- */
-/* ----------  use xrx100/xrx200 instead  ---------- */
-#define XR9_MAX_PIN            56
-
-static const struct ltq_mfp_pin xway_mfp[] = {
-       /*       pin    f0      f1      f2      f3   */
-       MFP_XWAY(GPIO0, GPIO,   EXIN,   NONE,   TDM),
-       MFP_XWAY(GPIO1, GPIO,   EXIN,   NONE,   NONE),
-       MFP_XWAY(GPIO2, GPIO,   CGU,    EXIN,   GPHY),
-       MFP_XWAY(GPIO3, GPIO,   CGU,    NONE,   PCI),
-       MFP_XWAY(GPIO4, GPIO,   STP,    NONE,   ASC),
-       MFP_XWAY(GPIO5, GPIO,   STP,    GPHY,   NONE),
-       MFP_XWAY(GPIO6, GPIO,   STP,    GPT,    ASC),
-       MFP_XWAY(GPIO7, GPIO,   CGU,    PCI,    GPHY),
-       MFP_XWAY(GPIO8, GPIO,   CGU,    NMI,    NONE),
-       MFP_XWAY(GPIO9, GPIO,   ASC,    SPI,    EXIN),
-       MFP_XWAY(GPIO10, GPIO,  ASC,    SPI,    NONE),
-       MFP_XWAY(GPIO11, GPIO,  ASC,    PCI,    SPI),
-       MFP_XWAY(GPIO12, GPIO,  ASC,    NONE,   NONE),
-       MFP_XWAY(GPIO13, GPIO,  EBU,    SPI,    NONE),
-       MFP_XWAY(GPIO14, GPIO,  CGU,    PCI,    NONE),
-       MFP_XWAY(GPIO15, GPIO,  SPI,    JTAG,   NONE),
-       MFP_XWAY(GPIO16, GPIO,  SPI,    NONE,   JTAG),
-       MFP_XWAY(GPIO17, GPIO,  SPI,    NONE,   JTAG),
-       MFP_XWAY(GPIO18, GPIO,  SPI,    NONE,   JTAG),
-       MFP_XWAY(GPIO19, GPIO,  PCI,    NONE,   NONE),
-       MFP_XWAY(GPIO20, GPIO,  JTAG,   NONE,   NONE),
-       MFP_XWAY(GPIO21, GPIO,  PCI,    EBU,    GPT),
-       MFP_XWAY(GPIO22, GPIO,  SPI,    NONE,   NONE),
-       MFP_XWAY(GPIO23, GPIO,  EBU,    PCI,    STP),
-       MFP_XWAY(GPIO24, GPIO,  EBU,    TDM,    PCI),
-       MFP_XWAY(GPIO25, GPIO,  TDM,    NONE,   ASC),
-       MFP_XWAY(GPIO26, GPIO,  EBU,    NONE,   TDM),
-       MFP_XWAY(GPIO27, GPIO,  TDM,    NONE,   ASC),
-       MFP_XWAY(GPIO28, GPIO,  GPT,    NONE,   NONE),
-       MFP_XWAY(GPIO29, GPIO,  PCI,    NONE,   NONE),
-       MFP_XWAY(GPIO30, GPIO,  PCI,    NONE,   NONE),
-       MFP_XWAY(GPIO31, GPIO,  EBU,    PCI,    NONE),
-       MFP_XWAY(GPIO32, GPIO,  NONE,   NONE,   EBU),
-       MFP_XWAY(GPIO33, GPIO,  NONE,   NONE,   EBU),
-       MFP_XWAY(GPIO34, GPIO,  NONE,   NONE,   EBU),
-       MFP_XWAY(GPIO35, GPIO,  NONE,   NONE,   EBU),
-       MFP_XWAY(GPIO36, GPIO,  SIN,    NONE,   EBU),
-       MFP_XWAY(GPIO37, GPIO,  PCI,    NONE,   NONE),
-       MFP_XWAY(GPIO38, GPIO,  PCI,    NONE,   NONE),
-       MFP_XWAY(GPIO39, GPIO,  EXIN,   NONE,   NONE),
-       MFP_XWAY(GPIO40, GPIO,  NONE,   NONE,   NONE),
-       MFP_XWAY(GPIO41, GPIO,  NONE,   NONE,   NONE),
-       MFP_XWAY(GPIO42, GPIO,  MDIO,   NONE,   NONE),
-       MFP_XWAY(GPIO43, GPIO,  MDIO,   NONE,   NONE),
-       MFP_XWAY(GPIO44, GPIO,  MII,    SIN,    GPHY),
-       MFP_XWAY(GPIO45, GPIO,  NONE,   GPHY,   SIN),
-       MFP_XWAY(GPIO46, GPIO,  NONE,   NONE,   EXIN),
-       MFP_XWAY(GPIO47, GPIO,  MII,    GPHY,   SIN),
-       MFP_XWAY(GPIO48, GPIO,  EBU,    NONE,   NONE),
-       MFP_XWAY(GPIO49, GPIO,  EBU,    NONE,   NONE),
-       MFP_XWAY(GPIO50, GPIO,  NONE,   NONE,   NONE),
-       MFP_XWAY(GPIO51, GPIO,  NONE,   NONE,   NONE),
-       MFP_XWAY(GPIO52, GPIO,  NONE,   NONE,   NONE),
-       MFP_XWAY(GPIO53, GPIO,  NONE,   NONE,   NONE),
-       MFP_XWAY(GPIO54, GPIO,  NONE,   NONE,   NONE),
-       MFP_XWAY(GPIO55, GPIO,  NONE,   NONE,   NONE),
-};
-
-static const unsigned pins_jtag[] = {GPIO15, GPIO16, GPIO17, GPIO19, GPIO35};
-static const unsigned pins_asc0[] = {GPIO11, GPIO12};
-static const unsigned pins_asc0_cts_rts[] = {GPIO9, GPIO10};
-static const unsigned pins_stp[] = {GPIO4, GPIO5, GPIO6};
-static const unsigned pins_nmi[] = {GPIO8};
-static const unsigned pins_mdio[] = {GPIO42, GPIO43};
-
-static const unsigned pins_gphy0_led0[] = {GPIO5};
-static const unsigned pins_gphy0_led1[] = {GPIO7};
-static const unsigned pins_gphy0_led2[] = {GPIO2};
-static const unsigned pins_gphy1_led0[] = {GPIO44};
-static const unsigned pins_gphy1_led1[] = {GPIO45};
-static const unsigned pins_gphy1_led2[] = {GPIO47};
-
-static const unsigned pins_ebu_a24[] = {GPIO13};
-static const unsigned pins_ebu_clk[] = {GPIO21};
-static const unsigned pins_ebu_cs1[] = {GPIO23};
-static const unsigned pins_ebu_a23[] = {GPIO24};
-static const unsigned pins_ebu_wait[] = {GPIO26};
-static const unsigned pins_ebu_a25[] = {GPIO31};
-static const unsigned pins_ebu_rdy[] = {GPIO48};
-static const unsigned pins_ebu_rd[] = {GPIO49};
-
-static const unsigned pins_nand_ale[] = {GPIO13};
-static const unsigned pins_nand_cs1[] = {GPIO23};
-static const unsigned pins_nand_cle[] = {GPIO24};
-static const unsigned pins_nand_rdy[] = {GPIO48};
-static const unsigned pins_nand_rd[] = {GPIO49};
-
-static const unsigned xway_exin_pin_map[] = {GPIO0, GPIO1, GPIO2, GPIO39, GPIO46, GPIO9};
-
-static const unsigned pins_exin0[] = {GPIO0};
-static const unsigned pins_exin1[] = {GPIO1};
-static const unsigned pins_exin2[] = {GPIO2};
-static const unsigned pins_exin3[] = {GPIO39};
-static const unsigned pins_exin4[] = {GPIO46};
-static const unsigned pins_exin5[] = {GPIO9};
-
-static const unsigned pins_spi[] = {GPIO16, GPIO17, GPIO18};
-static const unsigned pins_spi_cs1[] = {GPIO15};
-static const unsigned pins_spi_cs2[] = {GPIO22};
-static const unsigned pins_spi_cs3[] = {GPIO13};
-static const unsigned pins_spi_cs4[] = {GPIO10};
-static const unsigned pins_spi_cs5[] = {GPIO9};
-static const unsigned pins_spi_cs6[] = {GPIO11};
-
-static const unsigned pins_gpt1[] = {GPIO28};
-static const unsigned pins_gpt2[] = {GPIO21};
-static const unsigned pins_gpt3[] = {GPIO6};
-
-static const unsigned pins_clkout0[] = {GPIO8};
-static const unsigned pins_clkout1[] = {GPIO7};
-static const unsigned pins_clkout2[] = {GPIO3};
-static const unsigned pins_clkout3[] = {GPIO2};
-
-static const unsigned pins_pci_gnt1[] = {GPIO30};
-static const unsigned pins_pci_gnt2[] = {GPIO23};
-static const unsigned pins_pci_gnt3[] = {GPIO19};
-static const unsigned pins_pci_gnt4[] = {GPIO38};
-static const unsigned pins_pci_req1[] = {GPIO29};
-static const unsigned pins_pci_req2[] = {GPIO31};
-static const unsigned pins_pci_req3[] = {GPIO3};
-static const unsigned pins_pci_req4[] = {GPIO37};
-
-static const struct ltq_pin_group xway_grps[] = {
-       GRP_MUX("exin0", EXIN, pins_exin0),
-       GRP_MUX("exin1", EXIN, pins_exin1),
-       GRP_MUX("exin2", EXIN, pins_exin2),
-       GRP_MUX("jtag", JTAG, pins_jtag),
-       GRP_MUX("ebu a23", EBU, pins_ebu_a23),
-       GRP_MUX("ebu a24", EBU, pins_ebu_a24),
-       GRP_MUX("ebu a25", EBU, pins_ebu_a25),
-       GRP_MUX("ebu clk", EBU, pins_ebu_clk),
-       GRP_MUX("ebu cs1", EBU, pins_ebu_cs1),
-       GRP_MUX("ebu wait", EBU, pins_ebu_wait),
-       GRP_MUX("nand ale", EBU, pins_nand_ale),
-       GRP_MUX("nand cs1", EBU, pins_nand_cs1),
-       GRP_MUX("nand cle", EBU, pins_nand_cle),
-       GRP_MUX("spi", SPI, pins_spi),
-       GRP_MUX("spi_cs1", SPI, pins_spi_cs1),
-       GRP_MUX("spi_cs2", SPI, pins_spi_cs2),
-       GRP_MUX("spi_cs3", SPI, pins_spi_cs3),
-       GRP_MUX("spi_cs4", SPI, pins_spi_cs4),
-       GRP_MUX("spi_cs5", SPI, pins_spi_cs5),
-       GRP_MUX("spi_cs6", SPI, pins_spi_cs6),
-       GRP_MUX("asc0", ASC, pins_asc0),
-       GRP_MUX("asc0 cts rts", ASC, pins_asc0_cts_rts),
-       GRP_MUX("stp", STP, pins_stp),
-       GRP_MUX("nmi", NMI, pins_nmi),
-       GRP_MUX("gpt1", GPT, pins_gpt1),
-       GRP_MUX("gpt2", GPT, pins_gpt2),
-       GRP_MUX("gpt3", GPT, pins_gpt3),
-       GRP_MUX("clkout0", CGU, pins_clkout0),
-       GRP_MUX("clkout1", CGU, pins_clkout1),
-       GRP_MUX("clkout2", CGU, pins_clkout2),
-       GRP_MUX("clkout3", CGU, pins_clkout3),
-       GRP_MUX("gnt1", PCI, pins_pci_gnt1),
-       GRP_MUX("gnt2", PCI, pins_pci_gnt2),
-       GRP_MUX("gnt3", PCI, pins_pci_gnt3),
-       GRP_MUX("req1", PCI, pins_pci_req1),
-       GRP_MUX("req2", PCI, pins_pci_req2),
-       GRP_MUX("req3", PCI, pins_pci_req3),
-/* xrx only */
-       GRP_MUX("nand rdy", EBU, pins_nand_rdy),
-       GRP_MUX("nand rd", EBU, pins_nand_rd),
-       GRP_MUX("exin3", EXIN, pins_exin3),
-       GRP_MUX("exin4", EXIN, pins_exin4),
-       GRP_MUX("exin5", EXIN, pins_exin5),
-       GRP_MUX("gnt4", PCI, pins_pci_gnt4),
-       GRP_MUX("req4", PCI, pins_pci_gnt4),
-       GRP_MUX("mdio", MDIO, pins_mdio),
-       GRP_MUX("gphy0 led0", GPHY, pins_gphy0_led0),
-       GRP_MUX("gphy0 led1", GPHY, pins_gphy0_led1),
-       GRP_MUX("gphy0 led2", GPHY, pins_gphy0_led2),
-       GRP_MUX("gphy1 led0", GPHY, pins_gphy1_led0),
-       GRP_MUX("gphy1 led1", GPHY, pins_gphy1_led1),
-       GRP_MUX("gphy1 led2", GPHY, pins_gphy1_led2),
-};
-
-static const char * const xway_pci_grps[] = {"gnt1", "gnt2",
-                                               "gnt3", "req1",
-                                               "req2", "req3"};
-static const char * const xway_spi_grps[] = {"spi", "spi_cs1",
-                                               "spi_cs2", "spi_cs3",
-                                               "spi_cs4", "spi_cs5",
-                                               "spi_cs6"};
-static const char * const xway_cgu_grps[] = {"clkout0", "clkout1",
-                                               "clkout2", "clkout3"};
-static const char * const xway_ebu_grps[] = {"ebu a23", "ebu a24",
-                                               "ebu a25", "ebu cs1",
-                                               "ebu wait", "ebu clk",
-                                               "nand ale", "nand cs1",
-                                               "nand cle"};
-static const char * const xway_exin_grps[] = {"exin0", "exin1", "exin2"};
-static const char * const xway_gpt_grps[] = {"gpt1", "gpt2", "gpt3"};
-static const char * const xway_asc_grps[] = {"asc0", "asc0 cts rts"};
-static const char * const xway_jtag_grps[] = {"jtag"};
-static const char * const xway_stp_grps[] = {"stp"};
-static const char * const xway_nmi_grps[] = {"nmi"};
-
-/* ar9/vr9/gr9 */
-static const char * const xrx_mdio_grps[] = {"mdio"};
-static const char * const xrx_gphy_grps[] = {"gphy0 led0", "gphy0 led1",
-                                               "gphy0 led2", "gphy1 led0",
-                                               "gphy1 led1", "gphy1 led2"};
-static const char * const xrx_ebu_grps[] = {"ebu a23", "ebu a24",
-                                               "ebu a25", "ebu cs1",
-                                               "ebu wait", "ebu clk",
-                                               "nand ale", "nand cs1",
-                                               "nand cle", "nand rdy",
-                                               "nand rd"};
-static const char * const xrx_exin_grps[] = {"exin0", "exin1", "exin2",
-                                               "exin3", "exin4", "exin5"};
-static const char * const xrx_pci_grps[] = {"gnt1", "gnt2",
-                                               "gnt3", "gnt4",
-                                               "req1", "req2",
-                                               "req3", "req4"};
-
-static const struct ltq_pmx_func xrx_funcs[] = {
-       {"spi",         ARRAY_AND_SIZE(xway_spi_grps)},
-       {"asc",         ARRAY_AND_SIZE(xway_asc_grps)},
-       {"cgu",         ARRAY_AND_SIZE(xway_cgu_grps)},
-       {"jtag",        ARRAY_AND_SIZE(xway_jtag_grps)},
-       {"exin",        ARRAY_AND_SIZE(xrx_exin_grps)},
-       {"stp",         ARRAY_AND_SIZE(xway_stp_grps)},
-       {"gpt",         ARRAY_AND_SIZE(xway_gpt_grps)},
-       {"nmi",         ARRAY_AND_SIZE(xway_nmi_grps)},
-       {"pci",         ARRAY_AND_SIZE(xrx_pci_grps)},
-       {"ebu",         ARRAY_AND_SIZE(xrx_ebu_grps)},
-       {"mdio",        ARRAY_AND_SIZE(xrx_mdio_grps)},
-       {"gphy",        ARRAY_AND_SIZE(xrx_gphy_grps)},
-};
-
 /* ---------  ase related code --------- */
 #define ASE_MAX_PIN            32
 
@@ -1611,18 +1374,6 @@ struct pinctrl_xway_soc {
        unsigned int num_exin;
 };
 
-/* xway xr9 series (DEPRECATED: Use XWAY xRX100/xRX200 Family) */
-static struct pinctrl_xway_soc xr9_pinctrl = {
-       .pin_count = XR9_MAX_PIN,
-       .mfp = xway_mfp,
-       .grps = xway_grps,
-       .num_grps = ARRAY_SIZE(xway_grps),
-       .funcs = xrx_funcs,
-       .num_funcs = ARRAY_SIZE(xrx_funcs),
-       .exin = xway_exin_pin_map,
-       .num_exin = 6
-};
-
 /* XWAY AMAZON Family */
 static struct pinctrl_xway_soc ase_pinctrl = {
        .pin_count = ASE_MAX_PIN,
@@ -1689,9 +1440,6 @@ static struct pinctrl_gpio_range xway_gpio_range = {
 };
 
 static const struct of_device_id xway_match[] = {
-       { .compatible = "lantiq,pinctrl-xway", .data = &danube_pinctrl}, /*DEPRECATED*/
-       { .compatible = "lantiq,pinctrl-xr9", .data = &xr9_pinctrl}, /*DEPRECATED*/
-       { .compatible = "lantiq,pinctrl-ase", .data = &ase_pinctrl}, /*DEPRECATED*/
        { .compatible = "lantiq,ase-pinctrl", .data = &ase_pinctrl},
        { .compatible = "lantiq,danube-pinctrl", .data = &danube_pinctrl},
        { .compatible = "lantiq,xrx100-pinctrl", .data = &xrx100_pinctrl},
index 62d4810cfee11a45dc49488902add1f2c756a416..e52cfab8d5ae3f66fc6762f7ec80e2988a524163 100644 (file)
@@ -80,6 +80,17 @@ config PINCTRL_IPQ6018
          Qualcomm Technologies Inc. IPQ6018 platform. Select this for
          IPQ6018.
 
+config PINCTRL_IPQ9574
+       tristate "Qualcomm Technologies, Inc. IPQ9574 pin controller driver"
+       depends on OF || COMPILE_TEST
+       depends on ARM64 || COMPILE_TEST
+       depends on PINCTRL_MSM
+       help
+         This is the pinctrl, pinmux, pinconf and gpiolib driver for
+          the Qualcomm Technologies Inc. TLMM block found on the
+          Qualcomm Technologies Inc. IPQ9574 platform. Select this for
+          IPQ9574.
+
 config PINCTRL_MSM8226
        tristate "Qualcomm 8226 pin controller driver"
        depends on OF
@@ -417,6 +428,16 @@ config PINCTRL_SDX65
         Qualcomm Technologies Inc TLMM block found on the Qualcomm
         Technologies Inc SDX65 platform.
 
+config PINCTRL_SM7150
+       tristate "Qualcomm Technologies Inc SM7150 pin controller driver"
+       depends on OF
+       depends on ARM64 || COMPILE_TEST
+       depends on PINCTRL_MSM
+       help
+        This is the pinctrl, pinmux, pinconf and gpiolib driver for the
+        Qualcomm Technologies Inc TLMM block found on the Qualcomm
+        Technologies Inc SM7150 platform.
+
 config PINCTRL_SM8150
        tristate "Qualcomm Technologies Inc SM8150 pin controller driver"
        depends on OF
index bea53b52275ba9b4395ce66cbb640eaa0ccdfbba..521b021b74babecffa9b7ca31a92783bc188f169 100644 (file)
@@ -8,6 +8,7 @@ obj-$(CONFIG_PINCTRL_IPQ8064)   += pinctrl-ipq8064.o
 obj-$(CONFIG_PINCTRL_IPQ5332)  += pinctrl-ipq5332.o
 obj-$(CONFIG_PINCTRL_IPQ8074)  += pinctrl-ipq8074.o
 obj-$(CONFIG_PINCTRL_IPQ6018)  += pinctrl-ipq6018.o
+obj-$(CONFIG_PINCTRL_IPQ9574)  += pinctrl-ipq9574.o
 obj-$(CONFIG_PINCTRL_MSM8226)  += pinctrl-msm8226.o
 obj-$(CONFIG_PINCTRL_MSM8660)  += pinctrl-msm8660.o
 obj-$(CONFIG_PINCTRL_MSM8960)  += pinctrl-msm8960.o
@@ -44,6 +45,7 @@ obj-$(CONFIG_PINCTRL_SM6125) += pinctrl-sm6125.o
 obj-$(CONFIG_PINCTRL_SM6350) += pinctrl-sm6350.o
 obj-$(CONFIG_PINCTRL_SM6375) += pinctrl-sm6375.o
 obj-$(CONFIG_PINCTRL_SDX65) += pinctrl-sdx65.o
+obj-$(CONFIG_PINCTRL_SM7150) += pinctrl-sm7150.o
 obj-$(CONFIG_PINCTRL_SM8150) += pinctrl-sm8150.o
 obj-$(CONFIG_PINCTRL_SM8250) += pinctrl-sm8250.o
 obj-$(CONFIG_PINCTRL_SM8250_LPASS_LPI) += pinctrl-sm8250-lpass-lpi.o
diff --git a/drivers/pinctrl/qcom/pinctrl-ipq9574.c b/drivers/pinctrl/qcom/pinctrl-ipq9574.c
new file mode 100644 (file)
index 0000000..7f057b6
--- /dev/null
@@ -0,0 +1,826 @@
+// SPDX-License-Identifier: (GPL-2.0-only OR BSD-2-Clause)
+/*
+ * Copyright (c) 2023 The Linux Foundation. All rights reserved.
+ */
+
+#include <linux/module.h>
+#include <linux/of.h>
+#include <linux/platform_device.h>
+#include <linux/pinctrl/pinctrl.h>
+
+#include "pinctrl-msm.h"
+
+#define FUNCTION(fname)                                        \
+       [msm_mux_##fname] = {                           \
+               .name = #fname,                         \
+               .groups = fname##_groups,               \
+               .ngroups = ARRAY_SIZE(fname##_groups),  \
+       }
+
+#define REG_SIZE 0x1000
+#define PINGROUP(id, f1, f2, f3, f4, f5, f6, f7, f8, f9)       \
+       {                                               \
+               .name = "gpio" #id,                     \
+               .pins = gpio##id##_pins,                \
+               .npins = (unsigned int)ARRAY_SIZE(gpio##id##_pins),     \
+               .funcs = (int[]){                       \
+                       msm_mux_gpio, /* gpio mode */   \
+                       msm_mux_##f1,                   \
+                       msm_mux_##f2,                   \
+                       msm_mux_##f3,                   \
+                       msm_mux_##f4,                   \
+                       msm_mux_##f5,                   \
+                       msm_mux_##f6,                   \
+                       msm_mux_##f7,                   \
+                       msm_mux_##f8,                   \
+                       msm_mux_##f9                    \
+               },                                      \
+               .nfuncs = 10,                           \
+               .ctl_reg = REG_SIZE * id,                       \
+               .io_reg = 0x4 + REG_SIZE * id,          \
+               .intr_cfg_reg = 0x8 + REG_SIZE * id,            \
+               .intr_status_reg = 0xc + REG_SIZE * id, \
+               .intr_target_reg = 0x8 + REG_SIZE * id, \
+               .mux_bit = 2,                   \
+               .pull_bit = 0,                  \
+               .drv_bit = 6,                   \
+               .oe_bit = 9,                    \
+               .in_bit = 0,                    \
+               .out_bit = 1,                   \
+               .intr_enable_bit = 0,           \
+               .intr_status_bit = 0,           \
+               .intr_target_bit = 5,           \
+               .intr_target_kpss_val = 3,      \
+               .intr_raw_status_bit = 4,       \
+               .intr_polarity_bit = 1,         \
+               .intr_detection_bit = 2,        \
+               .intr_detection_width = 2,      \
+       }
+
+static const struct pinctrl_pin_desc ipq9574_pins[] = {
+       PINCTRL_PIN(0, "GPIO_0"),
+       PINCTRL_PIN(1, "GPIO_1"),
+       PINCTRL_PIN(2, "GPIO_2"),
+       PINCTRL_PIN(3, "GPIO_3"),
+       PINCTRL_PIN(4, "GPIO_4"),
+       PINCTRL_PIN(5, "GPIO_5"),
+       PINCTRL_PIN(6, "GPIO_6"),
+       PINCTRL_PIN(7, "GPIO_7"),
+       PINCTRL_PIN(8, "GPIO_8"),
+       PINCTRL_PIN(9, "GPIO_9"),
+       PINCTRL_PIN(10, "GPIO_10"),
+       PINCTRL_PIN(11, "GPIO_11"),
+       PINCTRL_PIN(12, "GPIO_12"),
+       PINCTRL_PIN(13, "GPIO_13"),
+       PINCTRL_PIN(14, "GPIO_14"),
+       PINCTRL_PIN(15, "GPIO_15"),
+       PINCTRL_PIN(16, "GPIO_16"),
+       PINCTRL_PIN(17, "GPIO_17"),
+       PINCTRL_PIN(18, "GPIO_18"),
+       PINCTRL_PIN(19, "GPIO_19"),
+       PINCTRL_PIN(20, "GPIO_20"),
+       PINCTRL_PIN(21, "GPIO_21"),
+       PINCTRL_PIN(22, "GPIO_22"),
+       PINCTRL_PIN(23, "GPIO_23"),
+       PINCTRL_PIN(24, "GPIO_24"),
+       PINCTRL_PIN(25, "GPIO_25"),
+       PINCTRL_PIN(26, "GPIO_26"),
+       PINCTRL_PIN(27, "GPIO_27"),
+       PINCTRL_PIN(28, "GPIO_28"),
+       PINCTRL_PIN(29, "GPIO_29"),
+       PINCTRL_PIN(30, "GPIO_30"),
+       PINCTRL_PIN(31, "GPIO_31"),
+       PINCTRL_PIN(32, "GPIO_32"),
+       PINCTRL_PIN(33, "GPIO_33"),
+       PINCTRL_PIN(34, "GPIO_34"),
+       PINCTRL_PIN(35, "GPIO_35"),
+       PINCTRL_PIN(36, "GPIO_36"),
+       PINCTRL_PIN(37, "GPIO_37"),
+       PINCTRL_PIN(38, "GPIO_38"),
+       PINCTRL_PIN(39, "GPIO_39"),
+       PINCTRL_PIN(40, "GPIO_40"),
+       PINCTRL_PIN(41, "GPIO_41"),
+       PINCTRL_PIN(42, "GPIO_42"),
+       PINCTRL_PIN(43, "GPIO_43"),
+       PINCTRL_PIN(44, "GPIO_44"),
+       PINCTRL_PIN(45, "GPIO_45"),
+       PINCTRL_PIN(46, "GPIO_46"),
+       PINCTRL_PIN(47, "GPIO_47"),
+       PINCTRL_PIN(48, "GPIO_48"),
+       PINCTRL_PIN(49, "GPIO_49"),
+       PINCTRL_PIN(50, "GPIO_50"),
+       PINCTRL_PIN(51, "GPIO_51"),
+       PINCTRL_PIN(52, "GPIO_52"),
+       PINCTRL_PIN(53, "GPIO_53"),
+       PINCTRL_PIN(54, "GPIO_54"),
+       PINCTRL_PIN(55, "GPIO_55"),
+       PINCTRL_PIN(56, "GPIO_56"),
+       PINCTRL_PIN(57, "GPIO_57"),
+       PINCTRL_PIN(58, "GPIO_58"),
+       PINCTRL_PIN(59, "GPIO_59"),
+       PINCTRL_PIN(60, "GPIO_60"),
+       PINCTRL_PIN(61, "GPIO_61"),
+       PINCTRL_PIN(62, "GPIO_62"),
+       PINCTRL_PIN(63, "GPIO_63"),
+       PINCTRL_PIN(64, "GPIO_64"),
+};
+
+#define DECLARE_MSM_GPIO_PINS(pin) \
+       static const unsigned int gpio##pin##_pins[] = { pin }
+DECLARE_MSM_GPIO_PINS(0);
+DECLARE_MSM_GPIO_PINS(1);
+DECLARE_MSM_GPIO_PINS(2);
+DECLARE_MSM_GPIO_PINS(3);
+DECLARE_MSM_GPIO_PINS(4);
+DECLARE_MSM_GPIO_PINS(5);
+DECLARE_MSM_GPIO_PINS(6);
+DECLARE_MSM_GPIO_PINS(7);
+DECLARE_MSM_GPIO_PINS(8);
+DECLARE_MSM_GPIO_PINS(9);
+DECLARE_MSM_GPIO_PINS(10);
+DECLARE_MSM_GPIO_PINS(11);
+DECLARE_MSM_GPIO_PINS(12);
+DECLARE_MSM_GPIO_PINS(13);
+DECLARE_MSM_GPIO_PINS(14);
+DECLARE_MSM_GPIO_PINS(15);
+DECLARE_MSM_GPIO_PINS(16);
+DECLARE_MSM_GPIO_PINS(17);
+DECLARE_MSM_GPIO_PINS(18);
+DECLARE_MSM_GPIO_PINS(19);
+DECLARE_MSM_GPIO_PINS(20);
+DECLARE_MSM_GPIO_PINS(21);
+DECLARE_MSM_GPIO_PINS(22);
+DECLARE_MSM_GPIO_PINS(23);
+DECLARE_MSM_GPIO_PINS(24);
+DECLARE_MSM_GPIO_PINS(25);
+DECLARE_MSM_GPIO_PINS(26);
+DECLARE_MSM_GPIO_PINS(27);
+DECLARE_MSM_GPIO_PINS(28);
+DECLARE_MSM_GPIO_PINS(29);
+DECLARE_MSM_GPIO_PINS(30);
+DECLARE_MSM_GPIO_PINS(31);
+DECLARE_MSM_GPIO_PINS(32);
+DECLARE_MSM_GPIO_PINS(33);
+DECLARE_MSM_GPIO_PINS(34);
+DECLARE_MSM_GPIO_PINS(35);
+DECLARE_MSM_GPIO_PINS(36);
+DECLARE_MSM_GPIO_PINS(37);
+DECLARE_MSM_GPIO_PINS(38);
+DECLARE_MSM_GPIO_PINS(39);
+DECLARE_MSM_GPIO_PINS(40);
+DECLARE_MSM_GPIO_PINS(41);
+DECLARE_MSM_GPIO_PINS(42);
+DECLARE_MSM_GPIO_PINS(43);
+DECLARE_MSM_GPIO_PINS(44);
+DECLARE_MSM_GPIO_PINS(45);
+DECLARE_MSM_GPIO_PINS(46);
+DECLARE_MSM_GPIO_PINS(47);
+DECLARE_MSM_GPIO_PINS(48);
+DECLARE_MSM_GPIO_PINS(49);
+DECLARE_MSM_GPIO_PINS(50);
+DECLARE_MSM_GPIO_PINS(51);
+DECLARE_MSM_GPIO_PINS(52);
+DECLARE_MSM_GPIO_PINS(53);
+DECLARE_MSM_GPIO_PINS(54);
+DECLARE_MSM_GPIO_PINS(55);
+DECLARE_MSM_GPIO_PINS(56);
+DECLARE_MSM_GPIO_PINS(57);
+DECLARE_MSM_GPIO_PINS(58);
+DECLARE_MSM_GPIO_PINS(59);
+DECLARE_MSM_GPIO_PINS(60);
+DECLARE_MSM_GPIO_PINS(61);
+DECLARE_MSM_GPIO_PINS(62);
+DECLARE_MSM_GPIO_PINS(63);
+DECLARE_MSM_GPIO_PINS(64);
+
+enum ipq9574_functions {
+       msm_mux_atest_char,
+       msm_mux_atest_char0,
+       msm_mux_atest_char1,
+       msm_mux_atest_char2,
+       msm_mux_atest_char3,
+       msm_mux_audio_pdm0,
+       msm_mux_audio_pdm1,
+       msm_mux_audio_pri,
+       msm_mux_audio_sec,
+       msm_mux_blsp0_spi,
+       msm_mux_blsp0_uart,
+       msm_mux_blsp1_i2c,
+       msm_mux_blsp1_spi,
+       msm_mux_blsp1_uart,
+       msm_mux_blsp2_i2c,
+       msm_mux_blsp2_spi,
+       msm_mux_blsp2_uart,
+       msm_mux_blsp3_i2c,
+       msm_mux_blsp3_spi,
+       msm_mux_blsp3_uart,
+       msm_mux_blsp4_i2c,
+       msm_mux_blsp4_spi,
+       msm_mux_blsp4_uart,
+       msm_mux_blsp5_i2c,
+       msm_mux_blsp5_uart,
+       msm_mux_cri_trng0,
+       msm_mux_cri_trng1,
+       msm_mux_cri_trng2,
+       msm_mux_cri_trng3,
+       msm_mux_cxc0,
+       msm_mux_cxc1,
+       msm_mux_dbg_out,
+       msm_mux_dwc_ddrphy,
+       msm_mux_gcc_plltest,
+       msm_mux_gcc_tlmm,
+       msm_mux_gpio,
+       msm_mux_mac,
+       msm_mux_mdc,
+       msm_mux_mdio,
+       msm_mux_pcie0_clk,
+       msm_mux_pcie0_wake,
+       msm_mux_pcie1_clk,
+       msm_mux_pcie1_wake,
+       msm_mux_pcie2_clk,
+       msm_mux_pcie2_wake,
+       msm_mux_pcie3_clk,
+       msm_mux_pcie3_wake,
+       msm_mux_prng_rosc0,
+       msm_mux_prng_rosc1,
+       msm_mux_prng_rosc2,
+       msm_mux_prng_rosc3,
+       msm_mux_pta,
+       msm_mux_pwm,
+       msm_mux_qdss_cti_trig_in_a0,
+       msm_mux_qdss_cti_trig_in_a1,
+       msm_mux_qdss_cti_trig_in_b0,
+       msm_mux_qdss_cti_trig_in_b1,
+       msm_mux_qdss_cti_trig_out_a0,
+       msm_mux_qdss_cti_trig_out_a1,
+       msm_mux_qdss_cti_trig_out_b0,
+       msm_mux_qdss_cti_trig_out_b1,
+       msm_mux_qdss_traceclk_a,
+       msm_mux_qdss_traceclk_b,
+       msm_mux_qdss_tracectl_a,
+       msm_mux_qdss_tracectl_b,
+       msm_mux_qdss_tracedata_a,
+       msm_mux_qdss_tracedata_b,
+       msm_mux_qspi_data,
+       msm_mux_qspi_clk,
+       msm_mux_qspi_cs,
+       msm_mux_rx0,
+       msm_mux_rx1,
+       msm_mux_sdc_data,
+       msm_mux_sdc_clk,
+       msm_mux_sdc_cmd,
+       msm_mux_sdc_rclk,
+       msm_mux_tsens_max,
+       msm_mux_wci20,
+       msm_mux_wci21,
+       msm_mux_wsa_swrm,
+       msm_mux__,
+};
+
+static const char * const gpio_groups[] = {
+       "gpio0", "gpio1", "gpio2", "gpio3", "gpio4", "gpio5", "gpio6", "gpio7",
+       "gpio8", "gpio9", "gpio10", "gpio11", "gpio12", "gpio13", "gpio14",
+       "gpio15", "gpio16", "gpio17", "gpio18", "gpio19", "gpio20", "gpio21",
+       "gpio22", "gpio23", "gpio24", "gpio25", "gpio26", "gpio27", "gpio28",
+       "gpio29", "gpio30", "gpio31", "gpio32", "gpio33", "gpio34", "gpio35",
+       "gpio36", "gpio37", "gpio38", "gpio39", "gpio40", "gpio41", "gpio42",
+       "gpio43", "gpio44", "gpio45", "gpio46", "gpio47", "gpio48", "gpio49",
+       "gpio50", "gpio51", "gpio52", "gpio53", "gpio54", "gpio55", "gpio56",
+       "gpio57", "gpio58", "gpio59", "gpio60", "gpio61", "gpio62", "gpio63",
+       "gpio64",
+};
+
+static const char * const sdc_data_groups[] = {
+       "gpio0",
+       "gpio1",
+       "gpio2",
+       "gpio3",
+       "gpio6",
+       "gpio7",
+       "gpio8",
+       "gpio9",
+};
+
+static const char * const qspi_data_groups[] = {
+       "gpio0",
+       "gpio1",
+       "gpio2",
+       "gpio3",
+};
+
+static const char * const qdss_traceclk_b_groups[] = {
+       "gpio0",
+};
+
+static const char * const qdss_tracectl_b_groups[] = {
+       "gpio1",
+};
+
+static const char * const qdss_tracedata_b_groups[] = {
+       "gpio2", "gpio3", "gpio4", "gpio5", "gpio6", "gpio7", "gpio8", "gpio9",
+       "gpio10", "gpio11", "gpio12", "gpio13", "gpio14", "gpio15", "gpio16",
+       "gpio17",
+};
+
+static const char * const sdc_cmd_groups[] = {
+       "gpio4",
+};
+
+static const char * const qspi_cs_groups[] = {
+       "gpio4",
+};
+
+static const char * const sdc_clk_groups[] = {
+       "gpio5",
+};
+
+static const char * const qspi_clk_groups[] = {
+       "gpio5",
+};
+
+static const char * const sdc_rclk_groups[] = {
+       "gpio10",
+};
+
+static const char * const blsp0_spi_groups[] = {
+       "gpio11", "gpio12", "gpio13", "gpio14",
+};
+
+static const char * const blsp0_uart_groups[] = {
+       "gpio11", "gpio12", "gpio13", "gpio14",
+};
+
+static const char * const blsp3_spi_groups[] = {
+       "gpio15", "gpio16", "gpio17", "gpio18", "gpio19", "gpio20", "gpio21",
+};
+
+static const char * const blsp3_i2c_groups[] = {
+       "gpio15", "gpio16",
+};
+
+static const char * const blsp3_uart_groups[] = {
+       "gpio15", "gpio16", "gpio17", "gpio18",
+};
+
+static const char * const dbg_out_groups[] = {
+       "gpio17",
+};
+
+static const char * const cri_trng0_groups[] = {
+       "gpio20", "gpio38",
+};
+
+static const char * const cri_trng1_groups[] = {
+       "gpio21", "gpio34",
+};
+
+static const char * const pcie0_clk_groups[] = {
+       "gpio22",
+};
+
+static const char * const pta_groups[] = {
+       "gpio22", "gpio23", "gpio24", "gpio54", "gpio55", "gpio56", "gpio61",
+       "gpio62", "gpio63",
+};
+
+static const char * const wci21_groups[] = {
+       "gpio23", "gpio24",
+};
+
+static const char * const cxc0_groups[] = {
+       "gpio23", "gpio24",
+};
+
+static const char * const pcie0_wake_groups[] = {
+       "gpio24",
+};
+
+static const char * const qdss_cti_trig_out_b0_groups[] = {
+       "gpio24",
+};
+
+static const char * const pcie1_clk_groups[] = {
+       "gpio25",
+};
+
+static const char * const qdss_cti_trig_in_b0_groups[] = {
+       "gpio25",
+};
+
+static const char * const atest_char0_groups[] = {
+       "gpio26",
+};
+
+static const char * const qdss_cti_trig_out_b1_groups[] = {
+       "gpio26",
+};
+
+static const char * const pcie1_wake_groups[] = {
+       "gpio27",
+};
+
+static const char * const atest_char1_groups[] = {
+       "gpio27",
+};
+
+static const char * const qdss_cti_trig_in_b1_groups[] = {
+       "gpio27",
+};
+
+static const char * const pcie2_clk_groups[] = {
+       "gpio28",
+};
+
+static const char * const atest_char2_groups[] = {
+       "gpio28",
+};
+
+static const char * const atest_char3_groups[] = {
+       "gpio29",
+};
+
+static const char * const pcie2_wake_groups[] = {
+       "gpio30",
+};
+
+static const char * const pwm_groups[] = {
+       "gpio30", "gpio31", "gpio32", "gpio33", "gpio44", "gpio45", "gpio46",
+       "gpio47", "gpio50", "gpio51", "gpio52", "gpio53", "gpio54", "gpio55",
+       "gpio56", "gpio57", "gpio58", "gpio59", "gpio60",
+};
+
+static const char * const atest_char_groups[] = {
+       "gpio30",
+};
+
+static const char * const pcie3_clk_groups[] = {
+       "gpio31",
+};
+
+static const char * const qdss_cti_trig_in_a1_groups[] = {
+       "gpio31",
+};
+
+static const char * const qdss_cti_trig_out_a1_groups[] = {
+       "gpio32",
+};
+
+static const char * const pcie3_wake_groups[] = {
+       "gpio33",
+};
+
+static const char * const qdss_cti_trig_in_a0_groups[] = {
+       "gpio33",
+};
+
+static const char * const blsp2_uart_groups[] = {
+       "gpio34", "gpio35",
+};
+
+static const char * const blsp2_i2c_groups[] = {
+       "gpio34", "gpio35",
+};
+
+static const char * const blsp2_spi_groups[] = {
+       "gpio34", "gpio35", "gpio36", "gpio37",
+};
+
+static const char * const blsp1_uart_groups[] = {
+       "gpio34", "gpio35", "gpio36", "gpio37",
+};
+
+static const char * const qdss_cti_trig_out_a0_groups[] = {
+       "gpio34",
+};
+
+static const char * const cri_trng2_groups[] = {
+       "gpio35",
+};
+
+static const char * const blsp1_i2c_groups[] = {
+       "gpio36", "gpio37",
+};
+
+static const char * const cri_trng3_groups[] = {
+       "gpio36",
+};
+
+static const char * const dwc_ddrphy_groups[] = {
+       "gpio37",
+};
+
+static const char * const mdc_groups[] = {
+       "gpio38",
+};
+
+static const char * const mdio_groups[] = {
+       "gpio39",
+};
+
+static const char * const audio_pri_groups[] = {
+       "gpio40", "gpio41", "gpio42", "gpio43", "gpio61", "gpio61",
+};
+
+static const char * const audio_pdm0_groups[] = {
+       "gpio40", "gpio41", "gpio42", "gpio43",
+};
+
+static const char * const qdss_traceclk_a_groups[] = {
+       "gpio43",
+};
+
+static const char * const audio_sec_groups[] = {
+       "gpio44", "gpio45", "gpio46", "gpio47", "gpio62", "gpio62",
+};
+
+static const char * const wsa_swrm_groups[] = {
+       "gpio44", "gpio45",
+};
+
+static const char * const qdss_tracectl_a_groups[] = {
+       "gpio44",
+};
+
+static const char * const qdss_tracedata_a_groups[] = {
+       "gpio45", "gpio46", "gpio47", "gpio48", "gpio49", "gpio50", "gpio51",
+       "gpio52", "gpio53", "gpio54", "gpio55", "gpio56", "gpio57", "gpio58",
+       "gpio59", "gpio60",
+};
+
+static const char * const rx1_groups[] = {
+       "gpio46",
+};
+
+static const char * const mac_groups[] = {
+       "gpio46", "gpio47", "gpio57", "gpio58",
+};
+
+static const char * const blsp5_i2c_groups[] = {
+       "gpio48", "gpio49",
+};
+
+static const char * const blsp5_uart_groups[] = {
+       "gpio48", "gpio49",
+};
+
+static const char * const blsp4_uart_groups[] = {
+       "gpio50", "gpio51", "gpio52", "gpio53",
+};
+
+static const char * const blsp4_i2c_groups[] = {
+       "gpio50", "gpio51",
+};
+
+static const char * const blsp4_spi_groups[] = {
+       "gpio50", "gpio51", "gpio52", "gpio53",
+};
+
+static const char * const wci20_groups[] = {
+       "gpio57", "gpio58",
+};
+
+static const char * const cxc1_groups[] = {
+       "gpio57", "gpio58",
+};
+
+static const char * const rx0_groups[] = {
+       "gpio59",
+};
+
+static const char * const prng_rosc0_groups[] = {
+       "gpio60",
+};
+
+static const char * const gcc_plltest_groups[] = {
+       "gpio60", "gpio62",
+};
+
+static const char * const blsp1_spi_groups[] = {
+       "gpio61", "gpio62", "gpio63", "gpio64",
+};
+
+static const char * const audio_pdm1_groups[] = {
+       "gpio61", "gpio62", "gpio63", "gpio64",
+};
+
+static const char * const prng_rosc1_groups[] = {
+       "gpio61",
+};
+
+static const char * const gcc_tlmm_groups[] = {
+       "gpio61",
+};
+
+static const char * const prng_rosc2_groups[] = {
+       "gpio62",
+};
+
+static const char * const prng_rosc3_groups[] = {
+       "gpio63",
+};
+
+static const char * const tsens_max_groups[] = {
+       "gpio64",
+};
+
+static const struct msm_function ipq9574_functions[] = {
+       FUNCTION(atest_char),
+       FUNCTION(atest_char0),
+       FUNCTION(atest_char1),
+       FUNCTION(atest_char2),
+       FUNCTION(atest_char3),
+       FUNCTION(audio_pdm0),
+       FUNCTION(audio_pdm1),
+       FUNCTION(audio_pri),
+       FUNCTION(audio_sec),
+       FUNCTION(blsp0_spi),
+       FUNCTION(blsp0_uart),
+       FUNCTION(blsp1_i2c),
+       FUNCTION(blsp1_spi),
+       FUNCTION(blsp1_uart),
+       FUNCTION(blsp2_i2c),
+       FUNCTION(blsp2_spi),
+       FUNCTION(blsp2_uart),
+       FUNCTION(blsp3_i2c),
+       FUNCTION(blsp3_spi),
+       FUNCTION(blsp3_uart),
+       FUNCTION(blsp4_i2c),
+       FUNCTION(blsp4_spi),
+       FUNCTION(blsp4_uart),
+       FUNCTION(blsp5_i2c),
+       FUNCTION(blsp5_uart),
+       FUNCTION(cri_trng0),
+       FUNCTION(cri_trng1),
+       FUNCTION(cri_trng2),
+       FUNCTION(cri_trng3),
+       FUNCTION(cxc0),
+       FUNCTION(cxc1),
+       FUNCTION(dbg_out),
+       FUNCTION(dwc_ddrphy),
+       FUNCTION(gcc_plltest),
+       FUNCTION(gcc_tlmm),
+       FUNCTION(gpio),
+       FUNCTION(mac),
+       FUNCTION(mdc),
+       FUNCTION(mdio),
+       FUNCTION(pcie0_clk),
+       FUNCTION(pcie0_wake),
+       FUNCTION(pcie1_clk),
+       FUNCTION(pcie1_wake),
+       FUNCTION(pcie2_clk),
+       FUNCTION(pcie2_wake),
+       FUNCTION(pcie3_clk),
+       FUNCTION(pcie3_wake),
+       FUNCTION(prng_rosc0),
+       FUNCTION(prng_rosc1),
+       FUNCTION(prng_rosc2),
+       FUNCTION(prng_rosc3),
+       FUNCTION(pta),
+       FUNCTION(pwm),
+       FUNCTION(qdss_cti_trig_in_a0),
+       FUNCTION(qdss_cti_trig_in_a1),
+       FUNCTION(qdss_cti_trig_in_b0),
+       FUNCTION(qdss_cti_trig_in_b1),
+       FUNCTION(qdss_cti_trig_out_a0),
+       FUNCTION(qdss_cti_trig_out_a1),
+       FUNCTION(qdss_cti_trig_out_b0),
+       FUNCTION(qdss_cti_trig_out_b1),
+       FUNCTION(qdss_traceclk_a),
+       FUNCTION(qdss_traceclk_b),
+       FUNCTION(qdss_tracectl_a),
+       FUNCTION(qdss_tracectl_b),
+       FUNCTION(qdss_tracedata_a),
+       FUNCTION(qdss_tracedata_b),
+       FUNCTION(qspi_data),
+       FUNCTION(qspi_clk),
+       FUNCTION(qspi_cs),
+       FUNCTION(rx0),
+       FUNCTION(rx1),
+       FUNCTION(sdc_data),
+       FUNCTION(sdc_clk),
+       FUNCTION(sdc_cmd),
+       FUNCTION(sdc_rclk),
+       FUNCTION(tsens_max),
+       FUNCTION(wci20),
+       FUNCTION(wci21),
+       FUNCTION(wsa_swrm),
+};
+
+static const struct msm_pingroup ipq9574_groups[] = {
+       PINGROUP(0, sdc_data, qspi_data, qdss_traceclk_b, _, _, _, _, _, _),
+       PINGROUP(1, sdc_data, qspi_data, qdss_tracectl_b, _, _, _, _, _, _),
+       PINGROUP(2, sdc_data, qspi_data, qdss_tracedata_b, _, _, _, _, _, _),
+       PINGROUP(3, sdc_data, qspi_data, qdss_tracedata_b, _, _, _, _, _, _),
+       PINGROUP(4, sdc_cmd, qspi_cs, qdss_tracedata_b, _, _, _, _, _, _),
+       PINGROUP(5, sdc_clk, qspi_clk, qdss_tracedata_b, _, _, _, _, _, _),
+       PINGROUP(6, sdc_data, qdss_tracedata_b, _, _, _, _, _, _, _),
+       PINGROUP(7, sdc_data, qdss_tracedata_b, _, _, _, _, _, _, _),
+       PINGROUP(8, sdc_data, qdss_tracedata_b, _, _, _, _, _, _, _),
+       PINGROUP(9, sdc_data, qdss_tracedata_b, _, _, _, _, _, _, _),
+       PINGROUP(10, sdc_rclk, qdss_tracedata_b, _, _, _, _, _, _, _),
+       PINGROUP(11, blsp0_spi, blsp0_uart, qdss_tracedata_b, _, _, _, _, _, _),
+       PINGROUP(12, blsp0_spi, blsp0_uart, qdss_tracedata_b, _, _, _, _, _, _),
+       PINGROUP(13, blsp0_spi, blsp0_uart, qdss_tracedata_b, _, _, _, _, _, _),
+       PINGROUP(14, blsp0_spi, blsp0_uart, qdss_tracedata_b, _, _, _, _, _, _),
+       PINGROUP(15, blsp3_spi, blsp3_i2c, blsp3_uart, qdss_tracedata_b, _, _, _, _, _),
+       PINGROUP(16, blsp3_spi, blsp3_i2c, blsp3_uart, qdss_tracedata_b, _, _, _, _, _),
+       PINGROUP(17, blsp3_spi, blsp3_uart, dbg_out, qdss_tracedata_b, _, _, _, _, _),
+       PINGROUP(18, blsp3_spi, blsp3_uart, _, _, _, _, _, _, _),
+       PINGROUP(19, blsp3_spi, _, _, _, _, _, _, _, _),
+       PINGROUP(20, blsp3_spi, _, cri_trng0, _, _, _, _, _, _),
+       PINGROUP(21, blsp3_spi, _, cri_trng1, _, _, _, _, _, _),
+       PINGROUP(22, pcie0_clk, _, pta, _, _, _, _, _, _),
+       PINGROUP(23, _, pta, wci21, cxc0, _, _, _, _, _),
+       PINGROUP(24, pcie0_wake, _, pta, wci21, cxc0, _, qdss_cti_trig_out_b0, _, _),
+       PINGROUP(25, pcie1_clk, _, _, qdss_cti_trig_in_b0, _, _, _, _, _),
+       PINGROUP(26, _, atest_char0, _, qdss_cti_trig_out_b1, _, _, _, _, _),
+       PINGROUP(27, pcie1_wake, _, atest_char1, qdss_cti_trig_in_b1, _, _, _, _, _),
+       PINGROUP(28, pcie2_clk, atest_char2, _, _, _, _, _, _, _),
+       PINGROUP(29, atest_char3, _, _, _, _, _, _, _, _),
+       PINGROUP(30, pcie2_wake, pwm, atest_char, _, _, _, _, _, _),
+       PINGROUP(31, pcie3_clk, pwm, _, qdss_cti_trig_in_a1, _, _, _, _, _),
+       PINGROUP(32, pwm, _, qdss_cti_trig_out_a1, _, _, _, _, _, _),
+       PINGROUP(33, pcie3_wake, pwm, _, qdss_cti_trig_in_a0, _, _, _, _, _),
+       PINGROUP(34, blsp2_uart, blsp2_i2c, blsp2_spi, blsp1_uart, _, cri_trng1, qdss_cti_trig_out_a0, _, _),
+       PINGROUP(35, blsp2_uart, blsp2_i2c, blsp2_spi, blsp1_uart, _, cri_trng2, _, _, _),
+       PINGROUP(36, blsp1_uart, blsp1_i2c, blsp2_spi, _, cri_trng3, _, _, _, _),
+       PINGROUP(37, blsp1_uart, blsp1_i2c, blsp2_spi, _, dwc_ddrphy, _, _, _, _),
+       PINGROUP(38, mdc, _, cri_trng0, _, _, _, _, _, _),
+       PINGROUP(39, mdio, _, _, _, _, _, _, _, _),
+       PINGROUP(40, audio_pri, audio_pdm0, _, _, _, _, _, _, _),
+       PINGROUP(41, audio_pri, audio_pdm0, _, _, _, _, _, _, _),
+       PINGROUP(42, audio_pri, audio_pdm0, _, _, _, _, _, _, _),
+       PINGROUP(43, audio_pri, audio_pdm0, _, qdss_traceclk_a, _, _, _, _, _),
+       PINGROUP(44, pwm, audio_sec, wsa_swrm, _, qdss_tracectl_a, _, _, _, _),
+       PINGROUP(45, pwm, audio_sec, wsa_swrm, _, qdss_tracedata_a, _, _, _, _),
+       PINGROUP(46, pwm, audio_sec, rx1, mac, _, qdss_tracedata_a, _, _, _),
+       PINGROUP(47, pwm, audio_sec, mac, _, qdss_tracedata_a, _, _, _, _),
+       PINGROUP(48, blsp5_i2c, blsp5_uart, _, qdss_tracedata_a, _, _, _, _, _),
+       PINGROUP(49, blsp5_i2c, blsp5_uart, _, qdss_tracedata_a, _, _, _, _, _),
+       PINGROUP(50, blsp4_uart, blsp4_i2c, blsp4_spi, pwm, qdss_tracedata_a, _, _, _, _),
+       PINGROUP(51, blsp4_uart, blsp4_i2c, blsp4_spi, pwm, qdss_tracedata_a, _, _, _, _),
+       PINGROUP(52, blsp4_uart, blsp4_spi, pwm, qdss_tracedata_a, _, _, _, _, _),
+       PINGROUP(53, blsp4_uart, blsp4_spi, pwm, qdss_tracedata_a, _, _, _, _, _),
+       PINGROUP(54, pta, pwm, qdss_tracedata_a, _, _, _, _, _, _),
+       PINGROUP(55, pta, pwm, qdss_tracedata_a, _, _, _, _, _, _),
+       PINGROUP(56, pta, pwm, qdss_tracedata_a, _, _, _, _, _, _),
+       PINGROUP(57, wci20, cxc1, mac, pwm, qdss_tracedata_a, _, _, _, _),
+       PINGROUP(58, wci20, cxc1, mac, pwm, qdss_tracedata_a, _, _, _, _),
+       PINGROUP(59, rx0, pwm, qdss_tracedata_a, _, _, _, _, _, _),
+       PINGROUP(60, pwm, prng_rosc0, qdss_tracedata_a, _, gcc_plltest, _, _, _, _),
+       PINGROUP(61, blsp1_spi, audio_pri, audio_pdm1, audio_pri, pta, prng_rosc1, gcc_tlmm, _, _),
+       PINGROUP(62, blsp1_spi, audio_sec, audio_pdm1, audio_sec, pta, prng_rosc2, gcc_plltest, _, _),
+       PINGROUP(63, blsp1_spi, audio_pdm1, pta, prng_rosc3, _, _, _, _, _),
+       PINGROUP(64, blsp1_spi, audio_pdm1, tsens_max, _, _, _, _, _, _),
+};
+
+/* Reserving GPIO59 for controlling the QFPROM LDO regulator */
+static const int ipq9574_reserved_gpios[] = {
+       59, -1
+};
+
+static const struct msm_pinctrl_soc_data ipq9574_pinctrl = {
+       .pins = ipq9574_pins,
+       .npins = ARRAY_SIZE(ipq9574_pins),
+       .functions = ipq9574_functions,
+       .nfunctions = ARRAY_SIZE(ipq9574_functions),
+       .groups = ipq9574_groups,
+       .ngroups = ARRAY_SIZE(ipq9574_groups),
+       .reserved_gpios = ipq9574_reserved_gpios,
+       .ngpios = 65,
+};
+
+static int ipq9574_pinctrl_probe(struct platform_device *pdev)
+{
+       return msm_pinctrl_probe(pdev, &ipq9574_pinctrl);
+}
+
+static const struct of_device_id ipq9574_pinctrl_of_match[] = {
+       { .compatible = "qcom,ipq9574-tlmm", },
+       { }
+};
+MODULE_DEVICE_TABLE(of, ipq9574_pinctrl_of_match);
+
+static struct platform_driver ipq9574_pinctrl_driver = {
+       .driver = {
+               .name = "ipq9574-tlmm",
+               .of_match_table = ipq9574_pinctrl_of_match,
+       },
+       .probe = ipq9574_pinctrl_probe,
+       .remove = msm_pinctrl_remove,
+};
+
+static int __init ipq9574_pinctrl_init(void)
+{
+       return platform_driver_register(&ipq9574_pinctrl_driver);
+}
+arch_initcall(ipq9574_pinctrl_init);
+
+static void __exit ipq9574_pinctrl_exit(void)
+{
+       platform_driver_unregister(&ipq9574_pinctrl_driver);
+}
+module_exit(ipq9574_pinctrl_exit);
+
+MODULE_DESCRIPTION("QTI IPQ9574 TLMM driver");
+MODULE_LICENSE("GPL");
index 87920257bb7320bac1844bc23814f094638974a5..fdb6585a92346135af526cb82bd38d36ad45cd18 100644 (file)
@@ -19,6 +19,8 @@
 
 #include "pinctrl-lpass-lpi.h"
 
+#define MAX_NR_GPIO            23
+#define GPIO_FUNC              0
 #define MAX_LPI_NUM_CLKS       2
 
 struct lpi_pinctrl {
@@ -30,6 +32,7 @@ struct lpi_pinctrl {
        char __iomem *slew_base;
        struct clk_bulk_data clks[MAX_LPI_NUM_CLKS];
        struct mutex slew_access_lock;
+       DECLARE_BITMAP(ever_gpio, MAX_NR_GPIO);
        const struct lpi_pinctrl_variant_data *data;
 };
 
@@ -84,10 +87,10 @@ static int lpi_gpio_get_function_groups(struct pinctrl_dev *pctldev,
 }
 
 static int lpi_gpio_set_mux(struct pinctrl_dev *pctldev, unsigned int function,
-                           unsigned int group_num)
+                           unsigned int group)
 {
        struct lpi_pinctrl *pctrl = pinctrl_dev_get_drvdata(pctldev);
-       const struct lpi_pingroup *g = &pctrl->data->groups[group_num];
+       const struct lpi_pingroup *g = &pctrl->data->groups[group];
        u32 val;
        int i, pin = g->pin;
 
@@ -100,6 +103,28 @@ static int lpi_gpio_set_mux(struct pinctrl_dev *pctldev, unsigned int function,
                return -EINVAL;
 
        val = lpi_gpio_read(pctrl, pin, LPI_GPIO_CFG_REG);
+
+       /*
+        * If this is the first time muxing to GPIO and the direction is
+        * output, make sure that we're not going to be glitching the pin
+        * by reading the current state of the pin and setting it as the
+        * output.
+        */
+       if (i == GPIO_FUNC && (val & LPI_GPIO_OE_MASK) &&
+           !test_and_set_bit(group, pctrl->ever_gpio)) {
+               u32 io_val = lpi_gpio_read(pctrl, group, LPI_GPIO_VALUE_REG);
+
+               if (io_val & LPI_GPIO_VALUE_IN_MASK) {
+                       if (!(io_val & LPI_GPIO_VALUE_OUT_MASK))
+                               lpi_gpio_write(pctrl, group, LPI_GPIO_VALUE_REG,
+                                              io_val | LPI_GPIO_VALUE_OUT_MASK);
+               } else {
+                       if (io_val & LPI_GPIO_VALUE_OUT_MASK)
+                               lpi_gpio_write(pctrl, group, LPI_GPIO_VALUE_REG,
+                                              io_val & ~LPI_GPIO_VALUE_OUT_MASK);
+               }
+       }
+
        u32p_replace_bits(&val, i, LPI_GPIO_FUNCTION_MASK);
        lpi_gpio_write(pctrl, pin, LPI_GPIO_CFG_REG, val);
 
@@ -221,6 +246,15 @@ static int lpi_config_set(struct pinctrl_dev *pctldev, unsigned int group,
                }
        }
 
+       /*
+        * As per Hardware Programming Guide, when configuring pin as output,
+        * set the pin value before setting output-enable (OE).
+        */
+       if (output_enabled) {
+               val = u32_encode_bits(value ? 1 : 0, LPI_GPIO_VALUE_OUT_MASK);
+               lpi_gpio_write(pctrl, group, LPI_GPIO_VALUE_REG, val);
+       }
+
        val = lpi_gpio_read(pctrl, group, LPI_GPIO_CFG_REG);
 
        u32p_replace_bits(&val, pullup, LPI_GPIO_PULL_MASK);
@@ -230,11 +264,6 @@ static int lpi_config_set(struct pinctrl_dev *pctldev, unsigned int group,
 
        lpi_gpio_write(pctrl, group, LPI_GPIO_CFG_REG, val);
 
-       if (output_enabled) {
-               val = u32_encode_bits(value ? 1 : 0, LPI_GPIO_VALUE_OUT_MASK);
-               lpi_gpio_write(pctrl, group, LPI_GPIO_VALUE_REG, val);
-       }
-
        return 0;
 }
 
@@ -390,6 +419,9 @@ int lpi_pinctrl_probe(struct platform_device *pdev)
        if (!data)
                return -EINVAL;
 
+       if (WARN_ON(data->npins > MAX_NR_GPIO))
+               return -EINVAL;
+
        pctrl->data = data;
        pctrl->dev = &pdev->dev;
 
index 4515f375c5e8d1551567db6ebdfbb8843d235927..c5f52d4f7781bab207d8c917efbd7fdba6f74411 100644 (file)
@@ -517,7 +517,7 @@ static int msm_config_group_set(struct pinctrl_dev *pctldev,
                         * The points above, explain why this _should_ be a
                         * no-op. However, for historical reasons and to
                         * support old device trees, we'll violate the docs
-                        * still affect the output.
+                        * and still affect the output.
                         *
                         * It should further be noted that this old historical
                         * behavior actually overrides arg to 0. That means
@@ -1506,8 +1506,7 @@ int msm_pinctrl_probe(struct platform_device *pdev,
                                return PTR_ERR(pctrl->regs[i]);
                }
        } else {
-               res = platform_get_resource(pdev, IORESOURCE_MEM, 0);
-               pctrl->regs[0] = devm_ioremap_resource(&pdev->dev, res);
+               pctrl->regs[0] = devm_platform_get_and_ioremap_resource(pdev, 0, &res);
                if (IS_ERR(pctrl->regs[0]))
                        return PTR_ERR(pctrl->regs[0]);
 
index a05f41fe2706bcea40d79a17b2eede757e4b1603..1a061bc9b8fa978090100932cbad3d482cd451b9 100644 (file)
@@ -1503,6 +1503,18 @@ static const struct msm_pingroup msm8998_groups[] = {
        UFS_RESET(ufs_reset, 0x19d000),
 };
 
+static const struct msm_gpio_wakeirq_map msm8998_mpm_map[] = {
+       { 1, 3 }, { 5, 4 }, { 9, 5 }, { 11, 6 }, { 22, 8 }, { 24, 9 }, { 26, 10 },
+       { 34, 11 }, { 36, 12 }, { 37, 13 }, { 38, 14 }, { 40, 15 }, { 42, 16 }, { 46, 17 },
+       { 50, 18 }, { 53, 19 }, { 54, 20 }, { 56, 21 }, { 57, 22 }, { 58, 23 }, { 59, 24 },
+       { 60, 25 }, { 61, 26 }, { 62, 27 }, { 63, 28 }, { 64, 29 }, { 66, 7 }, { 71, 30 },
+       { 73, 31 }, { 77, 32 }, { 78, 33 }, { 79, 34 }, { 80, 35 }, { 82, 36 }, { 86, 37 },
+       { 91, 38 }, { 92, 39 }, { 95, 40 }, { 97, 41 }, { 101, 42 }, { 104, 43 }, { 106, 44 },
+       { 108, 45 }, { 110, 48 }, { 112, 46 }, { 113, 47 }, { 115, 51 }, { 116, 54 }, { 117, 55 },
+       { 118, 56 }, { 119, 57 }, { 120, 58 }, { 121, 59 }, { 122, 60 }, { 123, 61 }, { 124, 62 },
+       { 125, 63 }, { 126, 64 }, { 127, 50 }, { 129, 65 }, { 131, 66 }, { 132, 67 }, { 133, 68 },
+};
+
 static const struct msm_pinctrl_soc_data msm8998_pinctrl = {
        .pins = msm8998_pins,
        .npins = ARRAY_SIZE(msm8998_pins),
@@ -1511,6 +1523,8 @@ static const struct msm_pinctrl_soc_data msm8998_pinctrl = {
        .groups = msm8998_groups,
        .ngroups = ARRAY_SIZE(msm8998_groups),
        .ngpios = 150,
+       .wakeirq_map = msm8998_mpm_map,
+       .nwakeirq_map = ARRAY_SIZE(msm8998_mpm_map),
 };
 
 static int msm8998_pinctrl_probe(struct platform_device *pdev)
diff --git a/drivers/pinctrl/qcom/pinctrl-sm7150.c b/drivers/pinctrl/qcom/pinctrl-sm7150.c
new file mode 100644 (file)
index 0000000..2a87e3f
--- /dev/null
@@ -0,0 +1,1280 @@
+// SPDX-License-Identifier: GPL-2.0-only
+/*
+ * Copyright (c) 2018, The Linux Foundation. All rights reserved.
+ * Copyright (c) 2023, Danila Tikhonov <danila@jiaxyga.com>
+ */
+
+#include <linux/module.h>
+#include <linux/of.h>
+#include <linux/platform_device.h>
+#include <linux/pinctrl/pinctrl.h>
+
+#include "pinctrl-msm.h"
+
+static const char * const sm7150_tiles[] = {
+       "north",
+       "south",
+       "west",
+};
+
+enum {
+       NORTH,
+       SOUTH,
+       WEST
+};
+
+#define FUNCTION(fname)                                        \
+       [msm_mux_##fname] = {                           \
+               .name = #fname,                         \
+               .groups = fname##_groups,               \
+               .ngroups = ARRAY_SIZE(fname##_groups),  \
+       }
+
+#define REG_SIZE 0x1000
+
+#define PINGROUP(id, _tile, f1, f2, f3, f4, f5, f6, f7, f8, f9) \
+       {                                               \
+               .name = "gpio" #id,                     \
+               .pins = gpio##id##_pins,                \
+               .npins = ARRAY_SIZE(gpio##id##_pins),   \
+               .funcs = (int[]){                       \
+                       msm_mux_gpio, /* gpio mode */   \
+                       msm_mux_##f1,                   \
+                       msm_mux_##f2,                   \
+                       msm_mux_##f3,                   \
+                       msm_mux_##f4,                   \
+                       msm_mux_##f5,                   \
+                       msm_mux_##f6,                   \
+                       msm_mux_##f7,                   \
+                       msm_mux_##f8,                   \
+                       msm_mux_##f9                    \
+               },                                      \
+               .nfuncs = 10,                           \
+               .ctl_reg = REG_SIZE * id,               \
+               .io_reg = 0x4 + REG_SIZE * id,          \
+               .intr_cfg_reg = 0x8 + REG_SIZE * id,    \
+               .intr_status_reg = 0xc + REG_SIZE * id, \
+               .intr_target_reg = 0x8 + REG_SIZE * id, \
+               .tile = _tile,                          \
+               .mux_bit = 2,                           \
+               .pull_bit = 0,                          \
+               .drv_bit = 6,                           \
+               .oe_bit = 9,                            \
+               .in_bit = 0,                            \
+               .out_bit = 1,                           \
+               .intr_enable_bit = 0,                   \
+               .intr_status_bit = 0,                   \
+               .intr_target_bit = 5,                   \
+               .intr_target_kpss_val = 3,              \
+               .intr_raw_status_bit = 4,               \
+               .intr_polarity_bit = 1,                 \
+               .intr_detection_bit = 2,                \
+               .intr_detection_width = 2,              \
+       }
+
+#define SDC_QDSD_PINGROUP(pg_name, ctl, pull, drv)     \
+       {                                               \
+               .name = #pg_name,                       \
+               .pins = pg_name##_pins,                 \
+               .npins = ARRAY_SIZE(pg_name##_pins),    \
+               .ctl_reg = ctl,                         \
+               .io_reg = 0,                            \
+               .intr_cfg_reg = 0,                      \
+               .intr_status_reg = 0,                   \
+               .intr_target_reg = 0,                   \
+               .tile = SOUTH,                          \
+               .mux_bit = -1,                          \
+               .pull_bit = pull,                       \
+               .drv_bit = drv,                         \
+               .oe_bit = -1,                           \
+               .in_bit = -1,                           \
+               .out_bit = -1,                          \
+               .intr_enable_bit = -1,                  \
+               .intr_status_bit = -1,                  \
+               .intr_target_bit = -1,                  \
+               .intr_raw_status_bit = -1,              \
+               .intr_polarity_bit = -1,                \
+               .intr_detection_bit = -1,               \
+               .intr_detection_width = -1,             \
+       }
+
+#define UFS_RESET(pg_name, offset)                     \
+       {                                               \
+               .name = #pg_name,                       \
+               .pins = pg_name##_pins,                 \
+               .npins = ARRAY_SIZE(pg_name##_pins),    \
+               .ctl_reg = offset,                      \
+               .io_reg = offset + 0x4,                 \
+               .intr_cfg_reg = 0,                      \
+               .intr_status_reg = 0,                   \
+               .intr_target_reg = 0,                   \
+               .tile = SOUTH,                          \
+               .mux_bit = -1,                          \
+               .pull_bit = 3,                          \
+               .drv_bit = 0,                           \
+               .oe_bit = -1,                           \
+               .in_bit = -1,                           \
+               .out_bit = 0,                           \
+               .intr_enable_bit = -1,                  \
+               .intr_status_bit = -1,                  \
+               .intr_target_bit = -1,                  \
+               .intr_raw_status_bit = -1,              \
+               .intr_polarity_bit = -1,                \
+               .intr_detection_bit = -1,               \
+               .intr_detection_width = -1,             \
+       }
+
+static const struct pinctrl_pin_desc sm7150_pins[] = {
+       PINCTRL_PIN(0, "GPIO_0"),
+       PINCTRL_PIN(1, "GPIO_1"),
+       PINCTRL_PIN(2, "GPIO_2"),
+       PINCTRL_PIN(3, "GPIO_3"),
+       PINCTRL_PIN(4, "GPIO_4"),
+       PINCTRL_PIN(5, "GPIO_5"),
+       PINCTRL_PIN(6, "GPIO_6"),
+       PINCTRL_PIN(7, "GPIO_7"),
+       PINCTRL_PIN(8, "GPIO_8"),
+       PINCTRL_PIN(9, "GPIO_9"),
+       PINCTRL_PIN(10, "GPIO_10"),
+       PINCTRL_PIN(11, "GPIO_11"),
+       PINCTRL_PIN(12, "GPIO_12"),
+       PINCTRL_PIN(13, "GPIO_13"),
+       PINCTRL_PIN(14, "GPIO_14"),
+       PINCTRL_PIN(15, "GPIO_15"),
+       PINCTRL_PIN(16, "GPIO_16"),
+       PINCTRL_PIN(17, "GPIO_17"),
+       PINCTRL_PIN(18, "GPIO_18"),
+       PINCTRL_PIN(19, "GPIO_19"),
+       PINCTRL_PIN(20, "GPIO_20"),
+       PINCTRL_PIN(21, "GPIO_21"),
+       PINCTRL_PIN(22, "GPIO_22"),
+       PINCTRL_PIN(23, "GPIO_23"),
+       PINCTRL_PIN(24, "GPIO_24"),
+       PINCTRL_PIN(25, "GPIO_25"),
+       PINCTRL_PIN(26, "GPIO_26"),
+       PINCTRL_PIN(27, "GPIO_27"),
+       PINCTRL_PIN(28, "GPIO_28"),
+       PINCTRL_PIN(29, "GPIO_29"),
+       PINCTRL_PIN(30, "GPIO_30"),
+       PINCTRL_PIN(31, "GPIO_31"),
+       PINCTRL_PIN(32, "GPIO_32"),
+       PINCTRL_PIN(33, "GPIO_33"),
+       PINCTRL_PIN(34, "GPIO_34"),
+       PINCTRL_PIN(35, "GPIO_35"),
+       PINCTRL_PIN(36, "GPIO_36"),
+       PINCTRL_PIN(37, "GPIO_37"),
+       PINCTRL_PIN(38, "GPIO_38"),
+       PINCTRL_PIN(39, "GPIO_39"),
+       PINCTRL_PIN(40, "GPIO_40"),
+       PINCTRL_PIN(41, "GPIO_41"),
+       PINCTRL_PIN(42, "GPIO_42"),
+       PINCTRL_PIN(43, "GPIO_43"),
+       PINCTRL_PIN(44, "GPIO_44"),
+       PINCTRL_PIN(45, "GPIO_45"),
+       PINCTRL_PIN(46, "GPIO_46"),
+       PINCTRL_PIN(47, "GPIO_47"),
+       PINCTRL_PIN(48, "GPIO_48"),
+       PINCTRL_PIN(49, "GPIO_49"),
+       PINCTRL_PIN(50, "GPIO_50"),
+       PINCTRL_PIN(51, "GPIO_51"),
+       PINCTRL_PIN(52, "GPIO_52"),
+       PINCTRL_PIN(53, "GPIO_53"),
+       PINCTRL_PIN(54, "GPIO_54"),
+       PINCTRL_PIN(55, "GPIO_55"),
+       PINCTRL_PIN(56, "GPIO_56"),
+       PINCTRL_PIN(57, "GPIO_57"),
+       PINCTRL_PIN(58, "GPIO_58"),
+       PINCTRL_PIN(59, "GPIO_59"),
+       PINCTRL_PIN(60, "GPIO_60"),
+       PINCTRL_PIN(61, "GPIO_61"),
+       PINCTRL_PIN(62, "GPIO_62"),
+       PINCTRL_PIN(63, "GPIO_63"),
+       PINCTRL_PIN(64, "GPIO_64"),
+       PINCTRL_PIN(65, "GPIO_65"),
+       PINCTRL_PIN(66, "GPIO_66"),
+       PINCTRL_PIN(67, "GPIO_67"),
+       PINCTRL_PIN(68, "GPIO_68"),
+       PINCTRL_PIN(69, "GPIO_69"),
+       PINCTRL_PIN(70, "GPIO_70"),
+       PINCTRL_PIN(71, "GPIO_71"),
+       PINCTRL_PIN(72, "GPIO_72"),
+       PINCTRL_PIN(73, "GPIO_73"),
+       PINCTRL_PIN(74, "GPIO_74"),
+       PINCTRL_PIN(75, "GPIO_75"),
+       PINCTRL_PIN(76, "GPIO_76"),
+       PINCTRL_PIN(77, "GPIO_77"),
+       PINCTRL_PIN(78, "GPIO_78"),
+       PINCTRL_PIN(79, "GPIO_79"),
+       PINCTRL_PIN(80, "GPIO_80"),
+       PINCTRL_PIN(81, "GPIO_81"),
+       PINCTRL_PIN(82, "GPIO_82"),
+       PINCTRL_PIN(83, "GPIO_83"),
+       PINCTRL_PIN(84, "GPIO_84"),
+       PINCTRL_PIN(85, "GPIO_85"),
+       PINCTRL_PIN(86, "GPIO_86"),
+       PINCTRL_PIN(87, "GPIO_87"),
+       PINCTRL_PIN(88, "GPIO_88"),
+       PINCTRL_PIN(89, "GPIO_89"),
+       PINCTRL_PIN(90, "GPIO_90"),
+       PINCTRL_PIN(91, "GPIO_91"),
+       PINCTRL_PIN(92, "GPIO_92"),
+       PINCTRL_PIN(93, "GPIO_93"),
+       PINCTRL_PIN(94, "GPIO_94"),
+       PINCTRL_PIN(95, "GPIO_95"),
+       PINCTRL_PIN(96, "GPIO_96"),
+       PINCTRL_PIN(97, "GPIO_97"),
+       PINCTRL_PIN(98, "GPIO_98"),
+       PINCTRL_PIN(99, "GPIO_99"),
+       PINCTRL_PIN(100, "GPIO_100"),
+       PINCTRL_PIN(101, "GPIO_101"),
+       PINCTRL_PIN(102, "GPIO_102"),
+       PINCTRL_PIN(103, "GPIO_103"),
+       PINCTRL_PIN(104, "GPIO_104"),
+       PINCTRL_PIN(105, "GPIO_105"),
+       PINCTRL_PIN(106, "GPIO_106"),
+       PINCTRL_PIN(107, "GPIO_107"),
+       PINCTRL_PIN(108, "GPIO_108"),
+       PINCTRL_PIN(109, "GPIO_109"),
+       PINCTRL_PIN(110, "GPIO_110"),
+       PINCTRL_PIN(111, "GPIO_111"),
+       PINCTRL_PIN(112, "GPIO_112"),
+       PINCTRL_PIN(113, "GPIO_113"),
+       PINCTRL_PIN(114, "GPIO_114"),
+       PINCTRL_PIN(115, "GPIO_115"),
+       PINCTRL_PIN(116, "GPIO_116"),
+       PINCTRL_PIN(117, "GPIO_117"),
+       PINCTRL_PIN(118, "GPIO_118"),
+       PINCTRL_PIN(119, "UFS_RESET"),
+       PINCTRL_PIN(120, "SDC1_RCLK"),
+       PINCTRL_PIN(121, "SDC1_CLK"),
+       PINCTRL_PIN(122, "SDC1_CMD"),
+       PINCTRL_PIN(123, "SDC1_DATA"),
+       PINCTRL_PIN(124, "SDC2_CLK"),
+       PINCTRL_PIN(125, "SDC2_CMD"),
+       PINCTRL_PIN(126, "SDC2_DATA"),
+
+};
+
+#define DECLARE_MSM_GPIO_PINS(pin) \
+       static const unsigned int gpio##pin##_pins[] = { pin }
+DECLARE_MSM_GPIO_PINS(0);
+DECLARE_MSM_GPIO_PINS(1);
+DECLARE_MSM_GPIO_PINS(2);
+DECLARE_MSM_GPIO_PINS(3);
+DECLARE_MSM_GPIO_PINS(4);
+DECLARE_MSM_GPIO_PINS(5);
+DECLARE_MSM_GPIO_PINS(6);
+DECLARE_MSM_GPIO_PINS(7);
+DECLARE_MSM_GPIO_PINS(8);
+DECLARE_MSM_GPIO_PINS(9);
+DECLARE_MSM_GPIO_PINS(10);
+DECLARE_MSM_GPIO_PINS(11);
+DECLARE_MSM_GPIO_PINS(12);
+DECLARE_MSM_GPIO_PINS(13);
+DECLARE_MSM_GPIO_PINS(14);
+DECLARE_MSM_GPIO_PINS(15);
+DECLARE_MSM_GPIO_PINS(16);
+DECLARE_MSM_GPIO_PINS(17);
+DECLARE_MSM_GPIO_PINS(18);
+DECLARE_MSM_GPIO_PINS(19);
+DECLARE_MSM_GPIO_PINS(20);
+DECLARE_MSM_GPIO_PINS(21);
+DECLARE_MSM_GPIO_PINS(22);
+DECLARE_MSM_GPIO_PINS(23);
+DECLARE_MSM_GPIO_PINS(24);
+DECLARE_MSM_GPIO_PINS(25);
+DECLARE_MSM_GPIO_PINS(26);
+DECLARE_MSM_GPIO_PINS(27);
+DECLARE_MSM_GPIO_PINS(28);
+DECLARE_MSM_GPIO_PINS(29);
+DECLARE_MSM_GPIO_PINS(30);
+DECLARE_MSM_GPIO_PINS(31);
+DECLARE_MSM_GPIO_PINS(32);
+DECLARE_MSM_GPIO_PINS(33);
+DECLARE_MSM_GPIO_PINS(34);
+DECLARE_MSM_GPIO_PINS(35);
+DECLARE_MSM_GPIO_PINS(36);
+DECLARE_MSM_GPIO_PINS(37);
+DECLARE_MSM_GPIO_PINS(38);
+DECLARE_MSM_GPIO_PINS(39);
+DECLARE_MSM_GPIO_PINS(40);
+DECLARE_MSM_GPIO_PINS(41);
+DECLARE_MSM_GPIO_PINS(42);
+DECLARE_MSM_GPIO_PINS(43);
+DECLARE_MSM_GPIO_PINS(44);
+DECLARE_MSM_GPIO_PINS(45);
+DECLARE_MSM_GPIO_PINS(46);
+DECLARE_MSM_GPIO_PINS(47);
+DECLARE_MSM_GPIO_PINS(48);
+DECLARE_MSM_GPIO_PINS(49);
+DECLARE_MSM_GPIO_PINS(50);
+DECLARE_MSM_GPIO_PINS(51);
+DECLARE_MSM_GPIO_PINS(52);
+DECLARE_MSM_GPIO_PINS(53);
+DECLARE_MSM_GPIO_PINS(54);
+DECLARE_MSM_GPIO_PINS(55);
+DECLARE_MSM_GPIO_PINS(56);
+DECLARE_MSM_GPIO_PINS(57);
+DECLARE_MSM_GPIO_PINS(58);
+DECLARE_MSM_GPIO_PINS(59);
+DECLARE_MSM_GPIO_PINS(60);
+DECLARE_MSM_GPIO_PINS(61);
+DECLARE_MSM_GPIO_PINS(62);
+DECLARE_MSM_GPIO_PINS(63);
+DECLARE_MSM_GPIO_PINS(64);
+DECLARE_MSM_GPIO_PINS(65);
+DECLARE_MSM_GPIO_PINS(66);
+DECLARE_MSM_GPIO_PINS(67);
+DECLARE_MSM_GPIO_PINS(68);
+DECLARE_MSM_GPIO_PINS(69);
+DECLARE_MSM_GPIO_PINS(70);
+DECLARE_MSM_GPIO_PINS(71);
+DECLARE_MSM_GPIO_PINS(72);
+DECLARE_MSM_GPIO_PINS(73);
+DECLARE_MSM_GPIO_PINS(74);
+DECLARE_MSM_GPIO_PINS(75);
+DECLARE_MSM_GPIO_PINS(76);
+DECLARE_MSM_GPIO_PINS(77);
+DECLARE_MSM_GPIO_PINS(78);
+DECLARE_MSM_GPIO_PINS(79);
+DECLARE_MSM_GPIO_PINS(80);
+DECLARE_MSM_GPIO_PINS(81);
+DECLARE_MSM_GPIO_PINS(82);
+DECLARE_MSM_GPIO_PINS(83);
+DECLARE_MSM_GPIO_PINS(84);
+DECLARE_MSM_GPIO_PINS(85);
+DECLARE_MSM_GPIO_PINS(86);
+DECLARE_MSM_GPIO_PINS(87);
+DECLARE_MSM_GPIO_PINS(88);
+DECLARE_MSM_GPIO_PINS(89);
+DECLARE_MSM_GPIO_PINS(90);
+DECLARE_MSM_GPIO_PINS(91);
+DECLARE_MSM_GPIO_PINS(92);
+DECLARE_MSM_GPIO_PINS(93);
+DECLARE_MSM_GPIO_PINS(94);
+DECLARE_MSM_GPIO_PINS(95);
+DECLARE_MSM_GPIO_PINS(96);
+DECLARE_MSM_GPIO_PINS(97);
+DECLARE_MSM_GPIO_PINS(98);
+DECLARE_MSM_GPIO_PINS(99);
+DECLARE_MSM_GPIO_PINS(100);
+DECLARE_MSM_GPIO_PINS(101);
+DECLARE_MSM_GPIO_PINS(102);
+DECLARE_MSM_GPIO_PINS(103);
+DECLARE_MSM_GPIO_PINS(104);
+DECLARE_MSM_GPIO_PINS(105);
+DECLARE_MSM_GPIO_PINS(106);
+DECLARE_MSM_GPIO_PINS(107);
+DECLARE_MSM_GPIO_PINS(108);
+DECLARE_MSM_GPIO_PINS(109);
+DECLARE_MSM_GPIO_PINS(110);
+DECLARE_MSM_GPIO_PINS(111);
+DECLARE_MSM_GPIO_PINS(112);
+DECLARE_MSM_GPIO_PINS(113);
+DECLARE_MSM_GPIO_PINS(114);
+DECLARE_MSM_GPIO_PINS(115);
+DECLARE_MSM_GPIO_PINS(116);
+DECLARE_MSM_GPIO_PINS(117);
+DECLARE_MSM_GPIO_PINS(118);
+
+static const unsigned int ufs_reset_pins[] = { 119 };
+static const unsigned int sdc1_rclk_pins[] = { 120 };
+static const unsigned int sdc1_clk_pins[] = { 121 };
+static const unsigned int sdc1_cmd_pins[] = { 122 };
+static const unsigned int sdc1_data_pins[] = { 123 };
+static const unsigned int sdc2_clk_pins[] = { 124 };
+static const unsigned int sdc2_cmd_pins[] = { 125 };
+static const unsigned int sdc2_data_pins[] = { 126 };
+
+enum sm7150_functions {
+       msm_mux_gpio,
+       msm_mux_adsp_ext,
+       msm_mux_agera_pll,
+       msm_mux_aoss_cti,
+       msm_mux_atest_char,
+       msm_mux_atest_tsens,
+       msm_mux_atest_tsens2,
+       msm_mux_atest_usb1,
+       msm_mux_atest_usb2,
+       msm_mux_cam_mclk,
+       msm_mux_cci_async,
+       msm_mux_cci_i2c,
+       msm_mux_cci_timer0,
+       msm_mux_cci_timer1,
+       msm_mux_cci_timer2,
+       msm_mux_cci_timer3,
+       msm_mux_cci_timer4,
+       msm_mux_dbg_out,
+       msm_mux_ddr_bist,
+       msm_mux_ddr_pxi0,
+       msm_mux_ddr_pxi1,
+       msm_mux_ddr_pxi2,
+       msm_mux_ddr_pxi3,
+       msm_mux_edp_hot,
+       msm_mux_edp_lcd,
+       msm_mux_gcc_gp1,
+       msm_mux_gcc_gp2,
+       msm_mux_gcc_gp3,
+       msm_mux_gp_pdm0,
+       msm_mux_gp_pdm1,
+       msm_mux_gp_pdm2,
+       msm_mux_gps_tx,
+       msm_mux_jitter_bist,
+       msm_mux_ldo_en,
+       msm_mux_ldo_update,
+       msm_mux_m_voc,
+       msm_mux_mdp_vsync,
+       msm_mux_mdp_vsync0,
+       msm_mux_mdp_vsync1,
+       msm_mux_mdp_vsync2,
+       msm_mux_mdp_vsync3,
+       msm_mux_mss_lte,
+       msm_mux_nav_pps_in,
+       msm_mux_nav_pps_out,
+       msm_mux_pa_indicator,
+       msm_mux_pci_e,
+       msm_mux_phase_flag,
+       msm_mux_pll_bist,
+       msm_mux_pll_bypassnl,
+       msm_mux_pll_reset,
+       msm_mux_pri_mi2s,
+       msm_mux_pri_mi2s_ws,
+       msm_mux_prng_rosc,
+       msm_mux_qdss,
+       msm_mux_qdss_cti,
+       msm_mux_qlink_enable,
+       msm_mux_qlink_request,
+       msm_mux_qua_mi2s,
+       msm_mux_qup00,
+       msm_mux_qup01,
+       msm_mux_qup02,
+       msm_mux_qup03,
+       msm_mux_qup04,
+       msm_mux_qup10,
+       msm_mux_qup11,
+       msm_mux_qup12,
+       msm_mux_qup13,
+       msm_mux_qup14,
+       msm_mux_qup15,
+       msm_mux_sd_write,
+       msm_mux_sdc40,
+       msm_mux_sdc41,
+       msm_mux_sdc42,
+       msm_mux_sdc43,
+       msm_mux_sdc4_clk,
+       msm_mux_sdc4_cmd,
+       msm_mux_sec_mi2s,
+       msm_mux_ter_mi2s,
+       msm_mux_tgu_ch0,
+       msm_mux_tgu_ch1,
+       msm_mux_tgu_ch2,
+       msm_mux_tgu_ch3,
+       msm_mux_tsif1_clk,
+       msm_mux_tsif1_data,
+       msm_mux_tsif1_en,
+       msm_mux_tsif1_error,
+       msm_mux_tsif1_sync,
+       msm_mux_tsif2_clk,
+       msm_mux_tsif2_data,
+       msm_mux_tsif2_en,
+       msm_mux_tsif2_error,
+       msm_mux_tsif2_sync,
+       msm_mux_uim1_clk,
+       msm_mux_uim1_data,
+       msm_mux_uim1_present,
+       msm_mux_uim1_reset,
+       msm_mux_uim2_clk,
+       msm_mux_uim2_data,
+       msm_mux_uim2_present,
+       msm_mux_uim2_reset,
+       msm_mux_uim_batt,
+       msm_mux_usb_phy,
+       msm_mux_vfr_1,
+       msm_mux_vsense_trigger,
+       msm_mux_wlan1_adc0,
+       msm_mux_wlan1_adc1,
+       msm_mux_wlan2_adc0,
+       msm_mux_wlan2_adc1,
+       msm_mux_wsa_clk,
+       msm_mux_wsa_data,
+       msm_mux__,
+};
+
+static const char * const gpio_groups[] = {
+       "gpio0", "gpio1", "gpio2", "gpio3", "gpio4", "gpio5", "gpio6", "gpio7",
+       "gpio8", "gpio9", "gpio10", "gpio11", "gpio12", "gpio13", "gpio14",
+       "gpio15", "gpio16", "gpio17", "gpio18", "gpio19", "gpio20", "gpio21",
+       "gpio22", "gpio23", "gpio24", "gpio25", "gpio26", "gpio27", "gpio28",
+       "gpio29", "gpio30", "gpio31", "gpio32", "gpio33", "gpio34", "gpio35",
+       "gpio36", "gpio37", "gpio38", "gpio39", "gpio40", "gpio41", "gpio42",
+       "gpio43", "gpio44", "gpio45", "gpio46", "gpio47", "gpio48", "gpio49",
+       "gpio50", "gpio51", "gpio52", "gpio53", "gpio54", "gpio55", "gpio56",
+       "gpio57", "gpio58", "gpio59", "gpio60", "gpio61", "gpio62", "gpio63",
+       "gpio64", "gpio65", "gpio66", "gpio67", "gpio68", "gpio69", "gpio70",
+       "gpio71", "gpio72", "gpio73", "gpio74", "gpio75", "gpio76", "gpio77",
+       "gpio78", "gpio79", "gpio80", "gpio81", "gpio82", "gpio83", "gpio84",
+       "gpio85", "gpio86", "gpio87", "gpio88", "gpio89", "gpio90", "gpio91",
+       "gpio92", "gpio93", "gpio94", "gpio95", "gpio96", "gpio97", "gpio98",
+       "gpio99", "gpio100", "gpio101", "gpio102", "gpio103", "gpio104",
+       "gpio105", "gpio106", "gpio107", "gpio108", "gpio109", "gpio110",
+       "gpio111", "gpio112", "gpio113", "gpio114", "gpio115", "gpio116",
+       "gpio117", "gpio118",
+};
+
+static const char * const adsp_ext_groups[] = {
+       "gpio87",
+};
+
+static const char * const agera_pll_groups[] = {
+       "gpio28",
+};
+
+static const char * const aoss_cti_groups[] = {
+       "gpio85",
+};
+
+static const char * const atest_char_groups[] = {
+       "gpio86", "gpio87", "gpio88", "gpio89", "gpio90",
+};
+
+static const char * const atest_tsens_groups[] = {
+       "gpio29",
+};
+
+static const char * const atest_tsens2_groups[] = {
+       "gpio7",
+};
+
+static const char * const atest_usb1_groups[] = {
+       "gpio7", "gpio10", "gpio11", "gpio39", "gpio44",
+};
+
+static const char * const atest_usb2_groups[] = {
+       "gpio51", "gpio52", "gpio53", "gpio54", "gpio55"
+};
+
+static const char * const cam_mclk_groups[] = {
+       "gpio13", "gpio14", "gpio15", "gpio16",
+};
+
+static const char * const cci_async_groups[] = {
+       "gpio24", "gpio25", "gpio26",
+};
+
+static const char * const cci_i2c_groups[] = {
+       "gpio17", "gpio18", "gpio19", "gpio20", "gpio27", "gpio28",
+};
+
+static const char * const cci_timer0_groups[] = {
+       "gpio21",
+};
+
+static const char * const cci_timer1_groups[] = {
+       "gpio22",
+};
+
+static const char * const cci_timer2_groups[] = {
+       "gpio23",
+};
+
+static const char * const cci_timer3_groups[] = {
+       "gpio24",
+};
+
+static const char * const cci_timer4_groups[] = {
+       "gpio25",
+};
+
+static const char * const dbg_out_groups[] = {
+       "gpio3",
+};
+
+static const char * const ddr_bist_groups[] = {
+       "gpio7", "gpio8", "gpio9", "gpio10",
+};
+
+static const char * const ddr_pxi0_groups[] = {
+       "gpio6", "gpio7",
+};
+
+static const char * const ddr_pxi1_groups[] = {
+       "gpio39", "gpio44",
+};
+
+static const char * const ddr_pxi2_groups[] = {
+       "gpio10", "gpio11",
+};
+
+static const char * const ddr_pxi3_groups[] = {
+       "gpio12", "gpio13",
+};
+
+static const char * const edp_hot_groups[] = {
+       "gpio85",
+};
+
+static const char * const edp_lcd_groups[] = {
+       "gpio11",
+};
+
+static const char * const gcc_gp1_groups[] = {
+       "gpio48", "gpio56",
+};
+
+static const char * const gcc_gp2_groups[] = {
+       "gpio21",
+};
+
+static const char * const gcc_gp3_groups[] = {
+       "gpio22",
+};
+
+static const char * const gp_pdm0_groups[] = {
+       "gpio37", "gpio68",
+};
+
+static const char * const gp_pdm1_groups[] = {
+       "gpio8", "gpio50",
+};
+
+static const char * const gp_pdm2_groups[] = {
+       "gpio57",
+};
+
+static const char * const gps_tx_groups[] = {
+       "gpio83", "gpio84", "gpio107", "gpio109",
+};
+
+static const char * const jitter_bist_groups[] = {
+       "gpio26",
+};
+
+static const char * const ldo_en_groups[] = {
+       "gpio70",
+};
+
+static const char * const ldo_update_groups[] = {
+       "gpio71",
+};
+
+static const char * const m_voc_groups[] = {
+       "gpio12",
+};
+
+static const char * const mdp_vsync_groups[] = {
+       "gpio10", "gpio11", "gpio12", "gpio70", "gpio71",
+};
+
+static const char * const mdp_vsync0_groups[] = {
+       "gpio63",
+};
+
+static const char * const mdp_vsync1_groups[] = {
+       "gpio63",
+};
+
+static const char * const mdp_vsync2_groups[] = {
+       "gpio63",
+};
+
+static const char * const mdp_vsync3_groups[] = {
+       "gpio63",
+};
+
+static const char * const mss_lte_groups[] = {
+       "gpio108", "gpio109",
+};
+
+static const char * const nav_pps_in_groups[] = {
+       "gpio83", "gpio84", "gpio107",
+};
+
+static const char * const nav_pps_out_groups[] = {
+       "gpio83", "gpio84", "gpio107",
+};
+
+static const char * const pa_indicator_groups[] = {
+       "gpio99",
+};
+
+static const char * const pci_e_groups[] = {
+       "gpio66", "gpio67", "gpio68",
+};
+
+static const char * const phase_flag_groups[] = {
+       "gpio0", "gpio1", "gpio2", "gpio6", "gpio7", "gpio10", "gpio11",
+       "gpio12", "gpio13", "gpio14", "gpio15", "gpio16", "gpio17", "gpio24",
+       "gpio25", "gpio26", "gpio27", "gpio28", "gpio29", "gpio30", "gpio35",
+       "gpio36", "gpio37", "gpio38", "gpio39", "gpio43", "gpio44", "gpio56",
+       "gpio57", "gpio60", "gpio61", "gpio62",
+};
+
+static const char * const pll_bist_groups[] = {
+       "gpio27",
+};
+
+static const char * const pll_bypassnl_groups[] = {
+       "gpio13",
+};
+
+static const char * const pll_reset_groups[] = {
+       "gpio14",
+};
+
+static const char * const pri_mi2s_groups[] = {
+       "gpio49", "gpio51", "gpio52",
+};
+
+static const char * const pri_mi2s_ws_groups[] = {
+       "gpio50",
+};
+
+static const char * const prng_rosc_groups[] = {
+       "gpio72",
+};
+
+static const char * const qdss_groups[] = {
+       "gpio13", "gpio86", "gpio14", "gpio87", "gpio15", "gpio88", "gpio16",
+       "gpio89", "gpio17", "gpio90", "gpio18", "gpio91", "gpio19", "gpio34",
+       "gpio20", "gpio35", "gpio21", "gpio53", "gpio22", "gpio30", "gpio23",
+       "gpio54", "gpio24", "gpio55", "gpio25", "gpio57", "gpio26", "gpio31",
+       "gpio27", "gpio56", "gpio28", "gpio36", "gpio29", "gpio37", "gpio93",
+       "gpio104",
+};
+
+static const char * const qdss_cti_groups[] = {
+       "gpio4", "gpio5", "gpio32", "gpio44", "gpio45", "gpio63",
+};
+
+static const char * const qlink_enable_groups[] = {
+       "gpio97",
+};
+
+static const char * const qlink_request_groups[] = {
+       "gpio96",
+};
+
+static const char * const qua_mi2s_groups[] = {
+       "gpio58",
+};
+
+static const char * const qup00_groups[] = {
+       "gpio49", "gpio50", "gpio51", "gpio52", "gpio57", "gpio58",
+};
+
+static const char * const qup01_groups[] = {
+       "gpio0", "gpio1", "gpio2", "gpio3", "gpio12", "gpio37",
+};
+
+static const char * const qup02_groups[] = {
+       "gpio34", "gpio35",
+};
+
+static const char * const qup03_groups[] = {
+       "gpio38", "gpio39", "gpio40", "gpio41",
+};
+
+static const char * const qup04_groups[] = {
+       "gpio53", "gpio54", "gpio55", "gpio56",
+};
+
+static const char * const qup10_groups[] = {
+       "gpio59", "gpio60", "gpio61", "gpio62", "gpio63", "gpio64", "gpio65",
+};
+
+static const char * const qup11_groups[] = {
+       "gpio6", "gpio7", "gpio8", "gpio9",
+};
+
+static const char * const qup12_groups[] = {
+       "gpio42", "gpio43", "gpio44", "gpio45",
+};
+
+static const char * const qup13_groups[] = {
+       "gpio46", "gpio47",
+};
+
+static const char * const qup14_groups[] = {
+       "gpio110", "gpio111", "gpio112", "gpio113",
+};
+
+static const char * const qup15_groups[] = {
+       "gpio92", "gpio101", "gpio102", "gpio103",
+};
+
+static const char * const sd_write_groups[] = {
+       "gpio33",
+};
+
+static const char * const sdc40_groups[] = {
+       "gpio69",
+};
+
+static const char * const sdc41_groups[] = {
+       "gpio68",
+};
+
+static const char * const sdc42_groups[] = {
+       "gpio67",
+};
+
+static const char * const sdc43_groups[] = {
+       "gpio65",
+};
+
+static const char * const sdc4_clk_groups[] = {
+       "gpio66",
+};
+
+static const char * const sdc4_cmd_groups[] = {
+       "gpio64",
+};
+
+static const char * const sec_mi2s_groups[] = {
+       "gpio57",
+};
+
+static const char * const ter_mi2s_groups[] = {
+       "gpio53", "gpio54", "gpio55", "gpio56",
+};
+
+static const char * const tgu_ch0_groups[] = {
+       "gpio63",
+};
+
+static const char * const tgu_ch1_groups[] = {
+       "gpio64",
+};
+
+static const char * const tgu_ch2_groups[] = {
+       "gpio65",
+};
+
+static const char * const tgu_ch3_groups[] = {
+       "gpio62",
+};
+
+static const char * const tsif1_clk_groups[] = {
+       "gpio62",
+};
+
+static const char * const tsif1_data_groups[] = {
+       "gpio64",
+};
+
+static const char * const tsif1_en_groups[] = {
+       "gpio63",
+};
+
+static const char * const tsif1_error_groups[] = {
+       "gpio60",
+};
+
+static const char * const tsif1_sync_groups[] = {
+       "gpio61",
+};
+
+static const char * const tsif2_clk_groups[] = {
+       "gpio66",
+};
+
+static const char * const tsif2_data_groups[] = {
+       "gpio68",
+};
+
+static const char * const tsif2_en_groups[] = {
+       "gpio67",
+};
+
+static const char * const tsif2_error_groups[] = {
+       "gpio65",
+};
+
+static const char * const tsif2_sync_groups[] = {
+       "gpio69",
+};
+
+static const char * const uim1_clk_groups[] = {
+       "gpio80",
+};
+
+static const char * const uim1_data_groups[] = {
+       "gpio79",
+};
+
+static const char * const uim1_present_groups[] = {
+       "gpio82",
+};
+
+static const char * const uim1_reset_groups[] = {
+       "gpio81",
+};
+
+static const char * const uim2_clk_groups[] = {
+       "gpio76",
+};
+
+static const char * const uim2_data_groups[] = {
+       "gpio75",
+};
+
+static const char * const uim2_present_groups[] = {
+       "gpio78",
+};
+
+static const char * const uim2_reset_groups[] = {
+       "gpio77",
+};
+
+static const char * const uim_batt_groups[] = {
+       "gpio85",
+};
+
+static const char * const usb_phy_groups[] = {
+       "gpio104",
+};
+
+static const char * const vfr_1_groups[] = {
+       "gpio65",
+};
+
+static const char * const vsense_trigger_groups[] = {
+       "gpio7",
+};
+
+static const char * const wlan1_adc0_groups[] = {
+       "gpio39",
+};
+
+static const char * const wlan1_adc1_groups[] = {
+       "gpio44",
+};
+
+static const char * const wlan2_adc0_groups[] = {
+       "gpio11",
+};
+
+static const char * const wlan2_adc1_groups[] = {
+       "gpio10",
+};
+
+static const char * const wsa_clk_groups[] = {
+       "gpio49",
+};
+
+static const char * const wsa_data_groups[] = {
+       "gpio50",
+};
+
+static const struct msm_function sm7150_functions[] = {
+       FUNCTION(gpio),
+       FUNCTION(adsp_ext),
+       FUNCTION(agera_pll),
+       FUNCTION(aoss_cti),
+       FUNCTION(atest_char),
+       FUNCTION(atest_tsens),
+       FUNCTION(atest_tsens2),
+       FUNCTION(atest_usb1),
+       FUNCTION(atest_usb2),
+       FUNCTION(cam_mclk),
+       FUNCTION(cci_async),
+       FUNCTION(cci_i2c),
+       FUNCTION(cci_timer0),
+       FUNCTION(cci_timer1),
+       FUNCTION(cci_timer2),
+       FUNCTION(cci_timer3),
+       FUNCTION(cci_timer4),
+       FUNCTION(dbg_out),
+       FUNCTION(ddr_bist),
+       FUNCTION(ddr_pxi0),
+       FUNCTION(ddr_pxi1),
+       FUNCTION(ddr_pxi2),
+       FUNCTION(ddr_pxi3),
+       FUNCTION(edp_hot),
+       FUNCTION(edp_lcd),
+       FUNCTION(gcc_gp1),
+       FUNCTION(gcc_gp2),
+       FUNCTION(gcc_gp3),
+       FUNCTION(gp_pdm0),
+       FUNCTION(gp_pdm1),
+       FUNCTION(gp_pdm2),
+       FUNCTION(gps_tx),
+       FUNCTION(jitter_bist),
+       FUNCTION(ldo_en),
+       FUNCTION(ldo_update),
+       FUNCTION(m_voc),
+       FUNCTION(mdp_vsync),
+       FUNCTION(mdp_vsync0),
+       FUNCTION(mdp_vsync1),
+       FUNCTION(mdp_vsync2),
+       FUNCTION(mdp_vsync3),
+       FUNCTION(mss_lte),
+       FUNCTION(nav_pps_in),
+       FUNCTION(nav_pps_out),
+       FUNCTION(pa_indicator),
+       FUNCTION(pci_e),
+       FUNCTION(phase_flag),
+       FUNCTION(pll_bist),
+       FUNCTION(pll_bypassnl),
+       FUNCTION(pll_reset),
+       FUNCTION(pri_mi2s),
+       FUNCTION(pri_mi2s_ws),
+       FUNCTION(prng_rosc),
+       FUNCTION(qdss_cti),
+       FUNCTION(qdss),
+       FUNCTION(qlink_enable),
+       FUNCTION(qlink_request),
+       FUNCTION(qua_mi2s),
+       FUNCTION(qup00),
+       FUNCTION(qup01),
+       FUNCTION(qup02),
+       FUNCTION(qup03),
+       FUNCTION(qup04),
+       FUNCTION(qup10),
+       FUNCTION(qup11),
+       FUNCTION(qup12),
+       FUNCTION(qup13),
+       FUNCTION(qup14),
+       FUNCTION(qup15),
+       FUNCTION(sd_write),
+       FUNCTION(sdc40),
+       FUNCTION(sdc41),
+       FUNCTION(sdc42),
+       FUNCTION(sdc43),
+       FUNCTION(sdc4_clk),
+       FUNCTION(sdc4_cmd),
+       FUNCTION(sec_mi2s),
+       FUNCTION(ter_mi2s),
+       FUNCTION(tgu_ch0),
+       FUNCTION(tgu_ch1),
+       FUNCTION(tgu_ch2),
+       FUNCTION(tgu_ch3),
+       FUNCTION(tsif1_clk),
+       FUNCTION(tsif1_data),
+       FUNCTION(tsif1_en),
+       FUNCTION(tsif1_error),
+       FUNCTION(tsif1_sync),
+       FUNCTION(tsif2_clk),
+       FUNCTION(tsif2_data),
+       FUNCTION(tsif2_en),
+       FUNCTION(tsif2_error),
+       FUNCTION(tsif2_sync),
+       FUNCTION(uim1_clk),
+       FUNCTION(uim1_data),
+       FUNCTION(uim1_present),
+       FUNCTION(uim1_reset),
+       FUNCTION(uim2_clk),
+       FUNCTION(uim2_data),
+       FUNCTION(uim2_present),
+       FUNCTION(uim2_reset),
+       FUNCTION(uim_batt),
+       FUNCTION(usb_phy),
+       FUNCTION(vfr_1),
+       FUNCTION(vsense_trigger),
+       FUNCTION(wlan1_adc0),
+       FUNCTION(wlan1_adc1),
+       FUNCTION(wlan2_adc0),
+       FUNCTION(wlan2_adc1),
+       FUNCTION(wsa_clk),
+       FUNCTION(wsa_data),
+};
+
+/*
+ * Every pin is maintained as a single group, and missing or non-existing pin
+ * would be maintained as dummy group to synchronize pin group index with
+ * pin descriptor registered with pinctrl core.
+ * Clients would not be able to request these dummy pin groups.
+ */
+static const struct msm_pingroup sm7150_groups[] = {
+       [0] = PINGROUP(0, SOUTH, qup01, _, phase_flag, _, _, _, _, _, _),
+       [1] = PINGROUP(1, SOUTH, qup01, _, phase_flag, _, _, _, _, _, _),
+       [2] = PINGROUP(2, SOUTH, qup01, _, phase_flag, _, _, _, _, _, _),
+       [3] = PINGROUP(3, SOUTH, qup01, dbg_out, _, _, _, _, _, _, _),
+       [4] = PINGROUP(4, NORTH, _, qdss_cti, _, _, _, _, _, _, _),
+       [5] = PINGROUP(5, NORTH, _, qdss_cti, _, _, _, _, _, _, _),
+       [6] = PINGROUP(6, NORTH, qup11, _, phase_flag, ddr_pxi0, _, _, _, _, _),
+       [7] = PINGROUP(7, NORTH, qup11, ddr_bist, _, phase_flag, atest_tsens2, vsense_trigger, atest_usb1, ddr_pxi0, _),
+       [8] = PINGROUP(8, NORTH, qup11, gp_pdm1, ddr_bist, _, _, _, _, _, _),
+       [9] = PINGROUP(9, NORTH, qup11, ddr_bist, _, _, _, _, _, _, _),
+       [10] = PINGROUP(10, NORTH, mdp_vsync, ddr_bist, _, phase_flag, wlan2_adc1, atest_usb1, ddr_pxi2, _, _),
+       [11] = PINGROUP(11, NORTH, mdp_vsync, edp_lcd, _, phase_flag, wlan2_adc0, atest_usb1, ddr_pxi2, _, _),
+       [12] = PINGROUP(12, SOUTH, mdp_vsync, m_voc, qup01, _, phase_flag, ddr_pxi3, _, _, _),
+       [13] = PINGROUP(13, SOUTH, cam_mclk, pll_bypassnl, _, phase_flag, qdss, ddr_pxi3, _, _, _),
+       [14] = PINGROUP(14, SOUTH, cam_mclk, pll_reset, _, phase_flag, qdss, _, _, _, _),
+       [15] = PINGROUP(15, SOUTH, cam_mclk, _, phase_flag, qdss, _, _, _, _, _),
+       [16] = PINGROUP(16, SOUTH, cam_mclk, _, phase_flag, qdss, _, _, _, _, _),
+       [17] = PINGROUP(17, SOUTH, cci_i2c, _, phase_flag, qdss, _, _, _, _, _),
+       [18] = PINGROUP(18, SOUTH, cci_i2c, qdss, _, _, _, _, _, _, _),
+       [19] = PINGROUP(19, SOUTH, cci_i2c, qdss, _, _, _, _, _, _, _),
+       [20] = PINGROUP(20, SOUTH, cci_i2c, qdss, _, _, _, _, _, _, _),
+       [21] = PINGROUP(21, SOUTH, cci_timer0, gcc_gp2, _, qdss, _, _, _, _, _),
+       [22] = PINGROUP(22, SOUTH, cci_timer1, gcc_gp3, _, qdss, _, _, _, _, _),
+       [23] = PINGROUP(23, SOUTH, cci_timer2, qdss, _, _, _, _, _, _, _),
+       [24] = PINGROUP(24, SOUTH, cci_timer3, cci_async, _, phase_flag, qdss, _, _, _, _),
+       [25] = PINGROUP(25, SOUTH, cci_timer4, cci_async, _, phase_flag, qdss, _, _, _, _),
+       [26] = PINGROUP(26, SOUTH, cci_async, jitter_bist, _, phase_flag, qdss, _, _, _, _),
+       [27] = PINGROUP(27, SOUTH, cci_i2c, pll_bist, _, phase_flag, qdss, _, _, _, _),
+       [28] = PINGROUP(28, SOUTH, cci_i2c, agera_pll, _, phase_flag, qdss, _, _, _, _),
+       [29] = PINGROUP(29, NORTH, _, _, phase_flag, qdss, atest_tsens, _, _, _, _),
+       [30] = PINGROUP(30, SOUTH, _, phase_flag, qdss, _, _, _, _, _, _),
+       [31] = PINGROUP(31, WEST, _, qdss, _, _, _, _, _, _, _),
+       [32] = PINGROUP(32, NORTH, qdss_cti, _, _, _, _, _, _, _, _),
+       [33] = PINGROUP(33, NORTH, sd_write, _, _, _, _, _, _, _, _),
+       [34] = PINGROUP(34, SOUTH, qup02, qdss, _, _, _, _, _, _, _),
+       [35] = PINGROUP(35, SOUTH, qup02, _, phase_flag, qdss, _, _, _, _, _),
+       [36] = PINGROUP(36, SOUTH, _, phase_flag, qdss, _, _, _, _, _, _),
+       [37] = PINGROUP(37, SOUTH, qup01, gp_pdm0, _, phase_flag, qdss, _, _, _, _),
+       [38] = PINGROUP(38, SOUTH, qup03, _, phase_flag, _, _, _, _, _, _),
+       [39] = PINGROUP(39, SOUTH, qup03, _, phase_flag, _, wlan1_adc0, atest_usb1, ddr_pxi1, _, _),
+       [40] = PINGROUP(40, SOUTH, qup03, _, _, _, _, _, _, _, _),
+       [41] = PINGROUP(41, SOUTH, qup03, _, _, _, _, _, _, _, _),
+       [42] = PINGROUP(42, NORTH, qup12, _, _, _, _, _, _, _, _),
+       [43] = PINGROUP(43, NORTH, qup12, _, phase_flag, _, _, _, _, _, _),
+       [44] = PINGROUP(44, NORTH, qup12, _, phase_flag, qdss_cti, _, wlan1_adc1, atest_usb1, ddr_pxi1, _),
+       [45] = PINGROUP(45, NORTH, qup12, qdss_cti, _, _, _, _, _, _, _),
+       [46] = PINGROUP(46, NORTH, qup13, _, _, _, _, _, _, _, _),
+       [47] = PINGROUP(47, NORTH, qup13, _, _, _, _, _, _, _, _),
+       [48] = PINGROUP(48, WEST, gcc_gp1, _, _, _, _, _, _, _, _),
+       [49] = PINGROUP(49, WEST, pri_mi2s, qup00, wsa_clk, _, _, _, _, _, _),
+       [50] = PINGROUP(50, WEST, pri_mi2s_ws, qup00, wsa_data, gp_pdm1, _, _, _, _, _),
+       [51] = PINGROUP(51, WEST, pri_mi2s, qup00, atest_usb2, _, _, _, _, _, _),
+       [52] = PINGROUP(52, WEST, pri_mi2s, qup00, atest_usb2, _, _, _, _, _, _),
+       [53] = PINGROUP(53, WEST, ter_mi2s, qup04, qdss, atest_usb2, _, _, _, _, _),
+       [54] = PINGROUP(54, WEST, ter_mi2s, qup04, qdss, atest_usb2, _, _, _, _, _),
+       [55] = PINGROUP(55, WEST, ter_mi2s, qup04, qdss, atest_usb2, _, _, _, _, _),
+       [56] = PINGROUP(56, WEST, ter_mi2s, qup04, gcc_gp1, _, phase_flag, qdss, _, _, _),
+       [57] = PINGROUP(57, WEST, sec_mi2s, qup00, gp_pdm2, _, phase_flag, qdss, _, _, _),
+       [58] = PINGROUP(58, WEST, qua_mi2s, qup00, _, _, _, _, _, _, _),
+       [59] = PINGROUP(59, NORTH, qup10, _, _, _, _, _, _, _, _),
+       [60] = PINGROUP(60, NORTH, qup10, tsif1_error, _, phase_flag, _, _, _, _, _),
+       [61] = PINGROUP(61, NORTH, qup10, tsif1_sync, _, phase_flag, _, _, _, _, _),
+       [62] = PINGROUP(62, NORTH, qup10, tsif1_clk, tgu_ch3, _, phase_flag, _, _, _, _),
+       [63] = PINGROUP(63, NORTH, tsif1_en, mdp_vsync0, qup10, mdp_vsync1, mdp_vsync2, mdp_vsync3, tgu_ch0, qdss_cti, _),
+       [64] = PINGROUP(64, NORTH, tsif1_data, sdc4_cmd, qup10, tgu_ch1, _, _, _, _, _),
+       [65] = PINGROUP(65, NORTH, tsif2_error, sdc43, qup10, vfr_1, tgu_ch2, _, _, _, _),
+       [66] = PINGROUP(66, NORTH, tsif2_clk, sdc4_clk, pci_e, _, _, _, _, _, _),
+       [67] = PINGROUP(67, NORTH, tsif2_en, sdc42, pci_e, _, _, _, _, _, _),
+       [68] = PINGROUP(68, NORTH, tsif2_data, sdc41, pci_e, gp_pdm0, _, _, _, _, _),
+       [69] = PINGROUP(69, NORTH, tsif2_sync, sdc40, _, _, _, _, _, _, _),
+       [70] = PINGROUP(70, NORTH, _, _, mdp_vsync, ldo_en, _, _, _, _, _),
+       [71] = PINGROUP(71, NORTH, _, mdp_vsync, ldo_update, _, _, _, _, _, _),
+       [72] = PINGROUP(72, NORTH, prng_rosc, _, _, _, _, _, _, _, _),
+       [73] = PINGROUP(73, NORTH, _, _, _, _, _, _, _, _, _),
+       [74] = PINGROUP(74, WEST, _, _, _, _, _, _, _, _, _),
+       [75] = PINGROUP(75, WEST, uim2_data, _, _, _, _, _, _, _, _),
+       [76] = PINGROUP(76, WEST, uim2_clk, _, _, _, _, _, _, _, _),
+       [77] = PINGROUP(77, WEST, uim2_reset, _, _, _, _, _, _, _, _),
+       [78] = PINGROUP(78, WEST, uim2_present, _, _, _, _, _, _, _, _),
+       [79] = PINGROUP(79, WEST, uim1_data, _, _, _, _, _, _, _, _),
+       [80] = PINGROUP(80, WEST, uim1_clk, _, _, _, _, _, _, _, _),
+       [81] = PINGROUP(81, WEST, uim1_reset, _, _, _, _, _, _, _, _),
+       [82] = PINGROUP(82, WEST, uim1_present, _, _, _, _, _, _, _, _),
+       [83] = PINGROUP(83, WEST, _, nav_pps_in, nav_pps_out, gps_tx, _, _, _, _, _),
+       [84] = PINGROUP(84, WEST, _, nav_pps_in, nav_pps_out, gps_tx, _, _, _, _, _),
+       [85] = PINGROUP(85, WEST, uim_batt, edp_hot, aoss_cti, _, _, _, _, _, _),
+       [86] = PINGROUP(86, NORTH, qdss, atest_char, _, _, _, _, _, _, _),
+       [87] = PINGROUP(87, NORTH, adsp_ext, qdss, atest_char, _, _, _, _, _, _),
+       [88] = PINGROUP(88, NORTH, qdss, atest_char, _, _, _, _, _, _, _),
+       [89] = PINGROUP(89, NORTH, qdss, atest_char, _, _, _, _, _, _, _),
+       [90] = PINGROUP(90, NORTH, qdss, atest_char, _, _, _, _, _, _, _),
+       [91] = PINGROUP(91, NORTH, qdss, _, _, _, _, _, _, _, _),
+       [92] = PINGROUP(92, NORTH, _, _, qup15, _, _, _, _, _, _),
+       [93] = PINGROUP(93, NORTH, qdss, _, _, _, _, _, _, _, _),
+       [94] = PINGROUP(94, SOUTH, _, _, _, _, _, _, _, _, _),
+       [95] = PINGROUP(95, WEST, _, _, _, _, _, _, _, _, _),
+       [96] = PINGROUP(96, WEST, qlink_request, _, _, _, _, _, _, _, _),
+       [97] = PINGROUP(97, WEST, qlink_enable, _, _, _, _, _, _, _, _),
+       [98] = PINGROUP(98, WEST, _, _, _, _, _, _, _, _, _),
+       [99] = PINGROUP(99, WEST, _, pa_indicator, _, _, _, _, _, _, _),
+       [100] = PINGROUP(100, WEST, _, _, _, _, _, _, _, _, _),
+       [101] = PINGROUP(101, NORTH, _, _, qup15, _, _, _, _, _, _),
+       [102] = PINGROUP(102, NORTH, _, _, qup15, _, _, _, _, _, _),
+       [103] = PINGROUP(103, NORTH, _, qup15, _, _, _, _, _, _, _),
+       [104] = PINGROUP(104, WEST, usb_phy, _, qdss, _, _, _, _, _, _),
+       [105] = PINGROUP(105, NORTH, _, _, _, _, _, _, _, _, _),
+       [106] = PINGROUP(106, NORTH, _, _, _, _, _, _, _, _, _),
+       [107] = PINGROUP(107, WEST, _, nav_pps_in, nav_pps_out, gps_tx, _, _, _, _, _),
+       [108] = PINGROUP(108, SOUTH, mss_lte, _, _, _, _, _, _, _, _),
+       [109] = PINGROUP(109, SOUTH, mss_lte, gps_tx, _, _, _, _, _, _, _),
+       [110] = PINGROUP(110, NORTH, _, _, qup14, _, _, _, _, _, _),
+       [111] = PINGROUP(111, NORTH, _, _, qup14, _, _, _, _, _, _),
+       [112] = PINGROUP(112, NORTH, _, qup14, _, _, _, _, _, _, _),
+       [113] = PINGROUP(113, NORTH, _, qup14, _, _, _, _, _, _, _),
+       [114] = PINGROUP(114, NORTH, _, _, _, _, _, _, _, _, _),
+       [115] = PINGROUP(115, NORTH, _, _, _, _, _, _, _, _, _),
+       [116] = PINGROUP(116, NORTH, _, _, _, _, _, _, _, _, _),
+       [117] = PINGROUP(117, NORTH, _, _, _, _, _, _, _, _, _),
+       [118] = PINGROUP(118, NORTH, _, _, _, _, _, _, _, _, _),
+       [119] = UFS_RESET(ufs_reset, 0x9f000),
+       [120] = SDC_QDSD_PINGROUP(sdc1_rclk, 0x9a000, 15, 0),
+       [121] = SDC_QDSD_PINGROUP(sdc1_clk, 0x9a000, 13, 6),
+       [122] = SDC_QDSD_PINGROUP(sdc1_cmd, 0x9a000, 11, 3),
+       [123] = SDC_QDSD_PINGROUP(sdc1_data, 0x9a000, 9, 0),
+       [124] = SDC_QDSD_PINGROUP(sdc2_clk, 0x98000, 14, 6),
+       [125] = SDC_QDSD_PINGROUP(sdc2_cmd, 0x98000, 11, 3),
+       [126] = SDC_QDSD_PINGROUP(sdc2_data, 0x98000, 9, 0),
+};
+
+static const struct msm_gpio_wakeirq_map sm7150_pdc_map[] = {
+       {0, 40}, {3, 50}, {4, 42}, {5, 70}, {6, 41}, {9, 57},
+       {10, 80}, {11, 51}, {22, 90}, {24, 61}, {26, 52}, {30, 56},
+       {31, 33}, {32, 81}, {33, 62}, {34, 43}, {36, 91}, {37, 53},
+       {38, 63}, {39, 72}, {41, 101}, {42, 35}, {43, 34}, {45, 73},
+       {47, 82}, {48, 36}, {49, 37}, {50, 38}, {52, 39}, {53, 102},
+       {55, 92}, {56, 45}, {57, 46}, {58, 83}, {59, 47}, {62, 48},
+       {64, 74}, {65, 44}, {66, 93}, {67, 49}, {68, 55}, {69, 32},
+       {70, 54}, {73, 64}, {74, 71}, {78, 31}, {82, 30}, {84, 58},
+       {85, 103}, {86, 59}, {87, 60}, {88, 65}, {89, 66}, {90, 67},
+       {91, 68}, {92, 69}, {93, 75}, {94, 84}, {95, 94}, {96, 76},
+       {98, 77}, {101, 78}, {104, 99}, {109, 104}, {110, 79}, {113, 85},
+};
+
+static const struct msm_pinctrl_soc_data sm7150_tlmm = {
+       .pins = sm7150_pins,
+       .npins = ARRAY_SIZE(sm7150_pins),
+       .functions = sm7150_functions,
+       .nfunctions = ARRAY_SIZE(sm7150_functions),
+       .groups = sm7150_groups,
+       .ngroups = ARRAY_SIZE(sm7150_groups),
+       .ngpios = 120,
+       .tiles = sm7150_tiles,
+       .ntiles = ARRAY_SIZE(sm7150_tiles),
+       .wakeirq_map = sm7150_pdc_map,
+       .nwakeirq_map = ARRAY_SIZE(sm7150_pdc_map),
+       .wakeirq_dual_edge_errata = true,
+};
+
+static int sm7150_tlmm_probe(struct platform_device *pdev)
+{
+       return msm_pinctrl_probe(pdev, &sm7150_tlmm);
+}
+
+static const struct of_device_id sm7150_tlmm_of_match[] = {
+       { .compatible = "qcom,sm7150-tlmm", },
+       { },
+};
+
+static struct platform_driver sm7150_tlmm_driver = {
+       .driver = {
+               .name = "sm7150-tlmm",
+               .pm = &msm_pinctrl_dev_pm_ops,
+               .of_match_table = sm7150_tlmm_of_match,
+       },
+       .probe = sm7150_tlmm_probe,
+       .remove = msm_pinctrl_remove,
+};
+
+static int __init sm7150_tlmm_init(void)
+{
+       return platform_driver_register(&sm7150_tlmm_driver);
+}
+arch_initcall(sm7150_tlmm_init);
+
+static void __exit sm7150_tlmm_exit(void)
+{
+       platform_driver_unregister(&sm7150_tlmm_driver);
+}
+module_exit(sm7150_tlmm_exit);
+
+MODULE_DESCRIPTION("Qualcomm SM7150 TLMM driver");
+MODULE_LICENSE("GPL");
index c2bdd936d27f09638b196adba994bc8053da6ef6..db1a46fee9c62add8ab156e4d166284a80c160bd 100644 (file)
@@ -102,6 +102,13 @@ static const struct pinctrl_pin_desc sm8550_lpi_pins[] = {
        PINCTRL_PIN(22, "gpio22"),
 };
 
+static const char * const gpio_groups[] = {
+       "gpio0", "gpio1", "gpio2", "gpio3", "gpio4", "gpio5", "gpio6", "gpio7",
+       "gpio8", "gpio9", "gpio10", "gpio11", "gpio12", "gpio13", "gpio14",
+       "gpio15", "gpio16", "gpio17", "gpio18", "gpio19", "gpio20", "gpio21",
+       "gpio22",
+};
+
 static const char * const dmic1_clk_groups[] = { "gpio6" };
 static const char * const dmic1_data_groups[] = { "gpio7" };
 static const char * const dmic2_clk_groups[] = { "gpio8" };
@@ -168,6 +175,7 @@ static const struct lpi_pingroup sm8550_groups[] = {
 };
 
 static const struct lpi_function sm8550_functions[] = {
+       LPI_FUNCTION(gpio),
        LPI_FUNCTION(dmic1_clk),
        LPI_FUNCTION(dmic1_data),
        LPI_FUNCTION(dmic2_clk),
index ea3485344f0697a384c0f033007a5deabd63ab87..43c7857c06a504b7ac981c4cd2fcaf32c0b62717 100644 (file)
@@ -1232,12 +1232,14 @@ static const struct of_device_id pmic_gpio_of_match[] = {
        { .compatible = "qcom,pm8994-gpio", .data = (void *) 22 },
        { .compatible = "qcom,pm8998-gpio", .data = (void *) 26 },
        { .compatible = "qcom,pma8084-gpio", .data = (void *) 22 },
+       { .compatible = "qcom,pmi632-gpio", .data = (void *) 8 },
        { .compatible = "qcom,pmi8950-gpio", .data = (void *) 2 },
        { .compatible = "qcom,pmi8994-gpio", .data = (void *) 10 },
        { .compatible = "qcom,pmi8998-gpio", .data = (void *) 14 },
        { .compatible = "qcom,pmk8350-gpio", .data = (void *) 4 },
        { .compatible = "qcom,pmk8550-gpio", .data = (void *) 6 },
        { .compatible = "qcom,pmm8155au-gpio", .data = (void *) 10 },
+       { .compatible = "qcom,pmm8654au-gpio", .data = (void *) 12 },
        /* pmp8074 has 12 GPIOs with holes on 1 and 12 */
        { .compatible = "qcom,pmp8074-gpio", .data = (void *) 12 },
        { .compatible = "qcom,pmr735a-gpio", .data = (void *) 4 },
index 644fb4a0e72acdcba6e07d21569ba008ec828faa..fe0393829c207568dca3ea38657e4bf3dd59ee2f 100644 (file)
@@ -143,7 +143,6 @@ struct pmic_mpp_state {
        struct regmap   *map;
        struct pinctrl_dev *ctrl;
        struct gpio_chip chip;
-       struct irq_chip irq;
 };
 
 static const struct pinconf_generic_params pmic_mpp_bindings[] = {
@@ -823,6 +822,33 @@ static int pmic_mpp_child_to_parent_hwirq(struct gpio_chip *chip,
        return 0;
 }
 
+static void pmic_mpp_irq_mask(struct irq_data *d)
+{
+       struct gpio_chip *gc = irq_data_get_irq_chip_data(d);
+
+       irq_chip_mask_parent(d);
+       gpiochip_disable_irq(gc, irqd_to_hwirq(d));
+}
+
+static void pmic_mpp_irq_unmask(struct irq_data *d)
+{
+       struct gpio_chip *gc = irq_data_get_irq_chip_data(d);
+
+       gpiochip_enable_irq(gc, irqd_to_hwirq(d));
+       irq_chip_unmask_parent(d);
+}
+
+static const struct irq_chip pmic_mpp_irq_chip = {
+       .name = "spmi-mpp",
+       .irq_ack = irq_chip_ack_parent,
+       .irq_mask = pmic_mpp_irq_mask,
+       .irq_unmask = pmic_mpp_irq_unmask,
+       .irq_set_type = irq_chip_set_type_parent,
+       .irq_set_wake = irq_chip_set_wake_parent,
+       .flags = IRQCHIP_MASK_ON_SUSPEND | IRQCHIP_IMMUTABLE,
+       GPIOCHIP_IRQ_RESOURCE_HELPERS,
+};
+
 static int pmic_mpp_probe(struct platform_device *pdev)
 {
        struct irq_domain *parent_domain;
@@ -915,16 +941,8 @@ static int pmic_mpp_probe(struct platform_device *pdev)
        if (!parent_domain)
                return -ENXIO;
 
-       state->irq.name = "spmi-mpp",
-       state->irq.irq_ack = irq_chip_ack_parent,
-       state->irq.irq_mask = irq_chip_mask_parent,
-       state->irq.irq_unmask = irq_chip_unmask_parent,
-       state->irq.irq_set_type = irq_chip_set_type_parent,
-       state->irq.irq_set_wake = irq_chip_set_wake_parent,
-       state->irq.flags = IRQCHIP_MASK_ON_SUSPEND,
-
        girq = &state->chip.irq;
-       girq->chip = &state->irq;
+       gpio_irq_chip_set_chip(girq, &pmic_mpp_irq_chip);
        girq->default_type = IRQ_TYPE_NONE;
        girq->handler = handle_level_irq;
        girq->fwnode = dev_fwnode(state->dev);
index e973001e5c88832e91ff2008c8d2bb05232ab4cd..dec1ffc49ffd08228fbdd8047ff0c9f6083b394f 100644 (file)
@@ -652,12 +652,30 @@ static int pm8xxx_pin_populate(struct pm8xxx_gpio *pctrl,
        return 0;
 }
 
-static struct irq_chip pm8xxx_irq_chip = {
+static void pm8xxx_irq_disable(struct irq_data *d)
+{
+       struct gpio_chip *gc = irq_data_get_irq_chip_data(d);
+
+       gpiochip_disable_irq(gc, irqd_to_hwirq(d));
+}
+
+static void pm8xxx_irq_enable(struct irq_data *d)
+{
+       struct gpio_chip *gc = irq_data_get_irq_chip_data(d);
+
+       gpiochip_enable_irq(gc, irqd_to_hwirq(d));
+}
+
+static const struct irq_chip pm8xxx_irq_chip = {
        .name = "ssbi-gpio",
        .irq_mask_ack = irq_chip_mask_ack_parent,
        .irq_unmask = irq_chip_unmask_parent,
+       .irq_disable = pm8xxx_irq_disable,
+       .irq_enable = pm8xxx_irq_enable,
        .irq_set_type = irq_chip_set_type_parent,
-       .flags = IRQCHIP_MASK_ON_SUSPEND | IRQCHIP_SKIP_SET_WAKE,
+       .flags = IRQCHIP_MASK_ON_SUSPEND | IRQCHIP_SKIP_SET_WAKE |
+               IRQCHIP_IMMUTABLE,
+       GPIOCHIP_IRQ_RESOURCE_HELPERS,
 };
 
 static int pm8xxx_domain_translate(struct irq_domain *domain,
@@ -788,7 +806,7 @@ static int pm8xxx_gpio_probe(struct platform_device *pdev)
                return -ENXIO;
 
        girq = &pctrl->chip.irq;
-       girq->chip = &pm8xxx_irq_chip;
+       gpio_irq_chip_set_chip(girq, &pm8xxx_irq_chip);
        girq->default_type = IRQ_TYPE_NONE;
        girq->handler = handle_level_irq;
        girq->fwnode = dev_fwnode(pctrl->dev);
index 86f66cb8bf30ab32f4d06be9a951b74775f02cc2..b5aed540f07ec428ddfe60a7877ba597bd062a1a 100644 (file)
@@ -126,7 +126,6 @@ struct pm8xxx_mpp {
        struct regmap *regmap;
        struct pinctrl_dev *pctrl;
        struct gpio_chip chip;
-       struct irq_chip irq;
 
        struct pinctrl_desc desc;
        unsigned npins;
@@ -778,6 +777,32 @@ static int pm8xxx_mpp_child_to_parent_hwirq(struct gpio_chip *chip,
        return 0;
 }
 
+static void pm8xxx_mpp_irq_disable(struct irq_data *d)
+{
+       struct gpio_chip *gc = irq_data_get_irq_chip_data(d);
+
+       gpiochip_disable_irq(gc, irqd_to_hwirq(d));
+}
+
+static void pm8xxx_mpp_irq_enable(struct irq_data *d)
+{
+       struct gpio_chip *gc = irq_data_get_irq_chip_data(d);
+
+       gpiochip_enable_irq(gc, irqd_to_hwirq(d));
+}
+
+static const struct irq_chip pm8xxx_mpp_irq_chip = {
+       .name = "ssbi-mpp",
+       .irq_mask_ack = irq_chip_mask_ack_parent,
+       .irq_unmask = irq_chip_unmask_parent,
+       .irq_disable = pm8xxx_mpp_irq_disable,
+       .irq_enable = pm8xxx_mpp_irq_enable,
+       .irq_set_type = irq_chip_set_type_parent,
+       .flags = IRQCHIP_MASK_ON_SUSPEND | IRQCHIP_SKIP_SET_WAKE |
+               IRQCHIP_IMMUTABLE,
+       GPIOCHIP_IRQ_RESOURCE_HELPERS,
+};
+
 static const struct of_device_id pm8xxx_mpp_of_match[] = {
        { .compatible = "qcom,pm8018-mpp", .data = (void *) 6 },
        { .compatible = "qcom,pm8038-mpp", .data = (void *) 6 },
@@ -871,14 +896,8 @@ static int pm8xxx_mpp_probe(struct platform_device *pdev)
        if (!parent_domain)
                return -ENXIO;
 
-       pctrl->irq.name = "ssbi-mpp";
-       pctrl->irq.irq_mask_ack = irq_chip_mask_ack_parent;
-       pctrl->irq.irq_unmask = irq_chip_unmask_parent;
-       pctrl->irq.irq_set_type = irq_chip_set_type_parent;
-       pctrl->irq.flags = IRQCHIP_MASK_ON_SUSPEND | IRQCHIP_SKIP_SET_WAKE;
-
        girq = &pctrl->chip.irq;
-       girq->chip = &pctrl->irq;
+       gpio_irq_chip_set_chip(girq, &pm8xxx_mpp_irq_chip);
        girq->default_type = IRQ_TYPE_NONE;
        girq->handler = handle_level_irq;
        girq->fwnode = dev_fwnode(pctrl->dev);
diff --git a/drivers/pinctrl/ralink/Kconfig b/drivers/pinctrl/ralink/Kconfig
deleted file mode 100644 (file)
index 1e4c5e4..0000000
+++ /dev/null
@@ -1,35 +0,0 @@
-# SPDX-License-Identifier: GPL-2.0-only
-menu "Ralink pinctrl drivers"
-        depends on RALINK
-
-config PINCTRL_RALINK
-        bool "Ralink pinctrl driver"
-        select PINMUX
-        select GENERIC_PINCONF
-
-config PINCTRL_MT7620
-        bool "MT7620 pinctrl subdriver"
-        depends on RALINK && SOC_MT7620
-        select PINCTRL_RALINK
-
-config PINCTRL_MT7621
-        bool "MT7621 pinctrl subdriver"
-        depends on RALINK && SOC_MT7621
-        select PINCTRL_RALINK
-
-config PINCTRL_RT2880
-        bool "RT2880 pinctrl subdriver"
-        depends on RALINK && SOC_RT288X
-        select PINCTRL_RALINK
-
-config PINCTRL_RT305X
-        bool "RT305X pinctrl subdriver"
-        depends on RALINK && SOC_RT305X
-        select PINCTRL_RALINK
-
-config PINCTRL_RT3883
-        bool "RT3883 pinctrl subdriver"
-        depends on RALINK && SOC_RT3883
-        select PINCTRL_RALINK
-
-endmenu
diff --git a/drivers/pinctrl/ralink/Makefile b/drivers/pinctrl/ralink/Makefile
deleted file mode 100644 (file)
index 0ebbe55..0000000
+++ /dev/null
@@ -1,8 +0,0 @@
-# SPDX-License-Identifier: GPL-2.0
-obj-$(CONFIG_PINCTRL_RALINK)   += pinctrl-ralink.o
-
-obj-$(CONFIG_PINCTRL_MT7620)   += pinctrl-mt7620.o
-obj-$(CONFIG_PINCTRL_MT7621)   += pinctrl-mt7621.o
-obj-$(CONFIG_PINCTRL_RT2880)   += pinctrl-rt2880.o
-obj-$(CONFIG_PINCTRL_RT305X)   += pinctrl-rt305x.o
-obj-$(CONFIG_PINCTRL_RT3883)   += pinctrl-rt3883.o
diff --git a/drivers/pinctrl/ralink/pinctrl-mt7620.c b/drivers/pinctrl/ralink/pinctrl-mt7620.c
deleted file mode 100644 (file)
index 4e8d26b..0000000
+++ /dev/null
@@ -1,391 +0,0 @@
-// SPDX-License-Identifier: GPL-2.0-only
-
-#include <asm/mach-ralink/ralink_regs.h>
-#include <asm/mach-ralink/mt7620.h>
-#include <linux/module.h>
-#include <linux/platform_device.h>
-#include <linux/of.h>
-#include "pinctrl-ralink.h"
-
-#define MT7620_GPIO_MODE_UART0_SHIFT   2
-#define MT7620_GPIO_MODE_UART0_MASK    0x7
-#define MT7620_GPIO_MODE_UART0(x)      ((x) << MT7620_GPIO_MODE_UART0_SHIFT)
-#define MT7620_GPIO_MODE_UARTF         0x0
-#define MT7620_GPIO_MODE_PCM_UARTF     0x1
-#define MT7620_GPIO_MODE_PCM_I2S       0x2
-#define MT7620_GPIO_MODE_I2S_UARTF     0x3
-#define MT7620_GPIO_MODE_PCM_GPIO      0x4
-#define MT7620_GPIO_MODE_GPIO_UARTF    0x5
-#define MT7620_GPIO_MODE_GPIO_I2S      0x6
-#define MT7620_GPIO_MODE_GPIO          0x7
-
-#define MT7620_GPIO_MODE_NAND          0
-#define MT7620_GPIO_MODE_SD            1
-#define MT7620_GPIO_MODE_ND_SD_GPIO    2
-#define MT7620_GPIO_MODE_ND_SD_MASK    0x3
-#define MT7620_GPIO_MODE_ND_SD_SHIFT   18
-
-#define MT7620_GPIO_MODE_PCIE_RST      0
-#define MT7620_GPIO_MODE_PCIE_REF      1
-#define MT7620_GPIO_MODE_PCIE_GPIO     2
-#define MT7620_GPIO_MODE_PCIE_MASK     0x3
-#define MT7620_GPIO_MODE_PCIE_SHIFT    16
-
-#define MT7620_GPIO_MODE_WDT_RST       0
-#define MT7620_GPIO_MODE_WDT_REF       1
-#define MT7620_GPIO_MODE_WDT_GPIO      2
-#define MT7620_GPIO_MODE_WDT_MASK      0x3
-#define MT7620_GPIO_MODE_WDT_SHIFT     21
-
-#define MT7620_GPIO_MODE_MDIO          0
-#define MT7620_GPIO_MODE_MDIO_REFCLK   1
-#define MT7620_GPIO_MODE_MDIO_GPIO     2
-#define MT7620_GPIO_MODE_MDIO_MASK     0x3
-#define MT7620_GPIO_MODE_MDIO_SHIFT    7
-
-#define MT7620_GPIO_MODE_I2C           0
-#define MT7620_GPIO_MODE_UART1         5
-#define MT7620_GPIO_MODE_RGMII1                9
-#define MT7620_GPIO_MODE_RGMII2                10
-#define MT7620_GPIO_MODE_SPI           11
-#define MT7620_GPIO_MODE_SPI_REF_CLK   12
-#define MT7620_GPIO_MODE_WLED          13
-#define MT7620_GPIO_MODE_JTAG          15
-#define MT7620_GPIO_MODE_EPHY          15
-#define MT7620_GPIO_MODE_PA            20
-
-static struct ralink_pmx_func i2c_grp[] =  { FUNC("i2c", 0, 1, 2) };
-static struct ralink_pmx_func spi_grp[] = { FUNC("spi", 0, 3, 4) };
-static struct ralink_pmx_func uartlite_grp[] = { FUNC("uartlite", 0, 15, 2) };
-static struct ralink_pmx_func mdio_grp[] = {
-       FUNC("mdio", MT7620_GPIO_MODE_MDIO, 22, 2),
-       FUNC("refclk", MT7620_GPIO_MODE_MDIO_REFCLK, 22, 2),
-};
-static struct ralink_pmx_func rgmii1_grp[] = { FUNC("rgmii1", 0, 24, 12) };
-static struct ralink_pmx_func refclk_grp[] = { FUNC("spi refclk", 0, 37, 3) };
-static struct ralink_pmx_func ephy_grp[] = { FUNC("ephy", 0, 40, 5) };
-static struct ralink_pmx_func rgmii2_grp[] = { FUNC("rgmii2", 0, 60, 12) };
-static struct ralink_pmx_func wled_grp[] = { FUNC("wled", 0, 72, 1) };
-static struct ralink_pmx_func pa_grp[] = { FUNC("pa", 0, 18, 4) };
-static struct ralink_pmx_func uartf_grp[] = {
-       FUNC("uartf", MT7620_GPIO_MODE_UARTF, 7, 8),
-       FUNC("pcm uartf", MT7620_GPIO_MODE_PCM_UARTF, 7, 8),
-       FUNC("pcm i2s", MT7620_GPIO_MODE_PCM_I2S, 7, 8),
-       FUNC("i2s uartf", MT7620_GPIO_MODE_I2S_UARTF, 7, 8),
-       FUNC("pcm gpio", MT7620_GPIO_MODE_PCM_GPIO, 11, 4),
-       FUNC("gpio uartf", MT7620_GPIO_MODE_GPIO_UARTF, 7, 4),
-       FUNC("gpio i2s", MT7620_GPIO_MODE_GPIO_I2S, 7, 4),
-};
-static struct ralink_pmx_func wdt_grp[] = {
-       FUNC("wdt rst", 0, 17, 1),
-       FUNC("wdt refclk", 0, 17, 1),
-       };
-static struct ralink_pmx_func pcie_rst_grp[] = {
-       FUNC("pcie rst", MT7620_GPIO_MODE_PCIE_RST, 36, 1),
-       FUNC("pcie refclk", MT7620_GPIO_MODE_PCIE_REF, 36, 1)
-};
-static struct ralink_pmx_func nd_sd_grp[] = {
-       FUNC("nand", MT7620_GPIO_MODE_NAND, 45, 15),
-       FUNC("sd", MT7620_GPIO_MODE_SD, 47, 13)
-};
-
-static struct ralink_pmx_group mt7620a_pinmux_data[] = {
-       GRP("i2c", i2c_grp, 1, MT7620_GPIO_MODE_I2C),
-       GRP("uartf", uartf_grp, MT7620_GPIO_MODE_UART0_MASK,
-               MT7620_GPIO_MODE_UART0_SHIFT),
-       GRP("spi", spi_grp, 1, MT7620_GPIO_MODE_SPI),
-       GRP("uartlite", uartlite_grp, 1, MT7620_GPIO_MODE_UART1),
-       GRP_G("wdt", wdt_grp, MT7620_GPIO_MODE_WDT_MASK,
-               MT7620_GPIO_MODE_WDT_GPIO, MT7620_GPIO_MODE_WDT_SHIFT),
-       GRP_G("mdio", mdio_grp, MT7620_GPIO_MODE_MDIO_MASK,
-               MT7620_GPIO_MODE_MDIO_GPIO, MT7620_GPIO_MODE_MDIO_SHIFT),
-       GRP("rgmii1", rgmii1_grp, 1, MT7620_GPIO_MODE_RGMII1),
-       GRP("spi refclk", refclk_grp, 1, MT7620_GPIO_MODE_SPI_REF_CLK),
-       GRP_G("pcie", pcie_rst_grp, MT7620_GPIO_MODE_PCIE_MASK,
-               MT7620_GPIO_MODE_PCIE_GPIO, MT7620_GPIO_MODE_PCIE_SHIFT),
-       GRP_G("nd_sd", nd_sd_grp, MT7620_GPIO_MODE_ND_SD_MASK,
-               MT7620_GPIO_MODE_ND_SD_GPIO, MT7620_GPIO_MODE_ND_SD_SHIFT),
-       GRP("rgmii2", rgmii2_grp, 1, MT7620_GPIO_MODE_RGMII2),
-       GRP("wled", wled_grp, 1, MT7620_GPIO_MODE_WLED),
-       GRP("ephy", ephy_grp, 1, MT7620_GPIO_MODE_EPHY),
-       GRP("pa", pa_grp, 1, MT7620_GPIO_MODE_PA),
-       { 0 }
-};
-
-static struct ralink_pmx_func pwm1_grp_mt76x8[] = {
-       FUNC("sdxc d6", 3, 19, 1),
-       FUNC("utif", 2, 19, 1),
-       FUNC("gpio", 1, 19, 1),
-       FUNC("pwm1", 0, 19, 1),
-};
-
-static struct ralink_pmx_func pwm0_grp_mt76x8[] = {
-       FUNC("sdxc d7", 3, 18, 1),
-       FUNC("utif", 2, 18, 1),
-       FUNC("gpio", 1, 18, 1),
-       FUNC("pwm0", 0, 18, 1),
-};
-
-static struct ralink_pmx_func uart2_grp_mt76x8[] = {
-       FUNC("sdxc d5 d4", 3, 20, 2),
-       FUNC("pwm", 2, 20, 2),
-       FUNC("gpio", 1, 20, 2),
-       FUNC("uart2", 0, 20, 2),
-};
-
-static struct ralink_pmx_func uart1_grp_mt76x8[] = {
-       FUNC("sw_r", 3, 45, 2),
-       FUNC("pwm", 2, 45, 2),
-       FUNC("gpio", 1, 45, 2),
-       FUNC("uart1", 0, 45, 2),
-};
-
-static struct ralink_pmx_func i2c_grp_mt76x8[] = {
-       FUNC("-", 3, 4, 2),
-       FUNC("debug", 2, 4, 2),
-       FUNC("gpio", 1, 4, 2),
-       FUNC("i2c", 0, 4, 2),
-};
-
-static struct ralink_pmx_func refclk_grp_mt76x8[] = { FUNC("refclk", 0, 37, 1) };
-static struct ralink_pmx_func perst_grp_mt76x8[] = { FUNC("perst", 0, 36, 1) };
-static struct ralink_pmx_func wdt_grp_mt76x8[] = { FUNC("wdt", 0, 38, 1) };
-static struct ralink_pmx_func spi_grp_mt76x8[] = { FUNC("spi", 0, 7, 4) };
-
-static struct ralink_pmx_func sd_mode_grp_mt76x8[] = {
-       FUNC("jtag", 3, 22, 8),
-       FUNC("utif", 2, 22, 8),
-       FUNC("gpio", 1, 22, 8),
-       FUNC("sdxc", 0, 22, 8),
-};
-
-static struct ralink_pmx_func uart0_grp_mt76x8[] = {
-       FUNC("-", 3, 12, 2),
-       FUNC("-", 2, 12, 2),
-       FUNC("gpio", 1, 12, 2),
-       FUNC("uart0", 0, 12, 2),
-};
-
-static struct ralink_pmx_func i2s_grp_mt76x8[] = {
-       FUNC("antenna", 3, 0, 4),
-       FUNC("pcm", 2, 0, 4),
-       FUNC("gpio", 1, 0, 4),
-       FUNC("i2s", 0, 0, 4),
-};
-
-static struct ralink_pmx_func spi_cs1_grp_mt76x8[] = {
-       FUNC("-", 3, 6, 1),
-       FUNC("refclk", 2, 6, 1),
-       FUNC("gpio", 1, 6, 1),
-       FUNC("spi cs1", 0, 6, 1),
-};
-
-static struct ralink_pmx_func spis_grp_mt76x8[] = {
-       FUNC("pwm_uart2", 3, 14, 4),
-       FUNC("utif", 2, 14, 4),
-       FUNC("gpio", 1, 14, 4),
-       FUNC("spis", 0, 14, 4),
-};
-
-static struct ralink_pmx_func gpio_grp_mt76x8[] = {
-       FUNC("pcie", 3, 11, 1),
-       FUNC("refclk", 2, 11, 1),
-       FUNC("gpio", 1, 11, 1),
-       FUNC("gpio", 0, 11, 1),
-};
-
-static struct ralink_pmx_func p4led_kn_grp_mt76x8[] = {
-       FUNC("jtag", 3, 30, 1),
-       FUNC("utif", 2, 30, 1),
-       FUNC("gpio", 1, 30, 1),
-       FUNC("p4led_kn", 0, 30, 1),
-};
-
-static struct ralink_pmx_func p3led_kn_grp_mt76x8[] = {
-       FUNC("jtag", 3, 31, 1),
-       FUNC("utif", 2, 31, 1),
-       FUNC("gpio", 1, 31, 1),
-       FUNC("p3led_kn", 0, 31, 1),
-};
-
-static struct ralink_pmx_func p2led_kn_grp_mt76x8[] = {
-       FUNC("jtag", 3, 32, 1),
-       FUNC("utif", 2, 32, 1),
-       FUNC("gpio", 1, 32, 1),
-       FUNC("p2led_kn", 0, 32, 1),
-};
-
-static struct ralink_pmx_func p1led_kn_grp_mt76x8[] = {
-       FUNC("jtag", 3, 33, 1),
-       FUNC("utif", 2, 33, 1),
-       FUNC("gpio", 1, 33, 1),
-       FUNC("p1led_kn", 0, 33, 1),
-};
-
-static struct ralink_pmx_func p0led_kn_grp_mt76x8[] = {
-       FUNC("jtag", 3, 34, 1),
-       FUNC("rsvd", 2, 34, 1),
-       FUNC("gpio", 1, 34, 1),
-       FUNC("p0led_kn", 0, 34, 1),
-};
-
-static struct ralink_pmx_func wled_kn_grp_mt76x8[] = {
-       FUNC("rsvd", 3, 35, 1),
-       FUNC("rsvd", 2, 35, 1),
-       FUNC("gpio", 1, 35, 1),
-       FUNC("wled_kn", 0, 35, 1),
-};
-
-static struct ralink_pmx_func p4led_an_grp_mt76x8[] = {
-       FUNC("jtag", 3, 39, 1),
-       FUNC("utif", 2, 39, 1),
-       FUNC("gpio", 1, 39, 1),
-       FUNC("p4led_an", 0, 39, 1),
-};
-
-static struct ralink_pmx_func p3led_an_grp_mt76x8[] = {
-       FUNC("jtag", 3, 40, 1),
-       FUNC("utif", 2, 40, 1),
-       FUNC("gpio", 1, 40, 1),
-       FUNC("p3led_an", 0, 40, 1),
-};
-
-static struct ralink_pmx_func p2led_an_grp_mt76x8[] = {
-       FUNC("jtag", 3, 41, 1),
-       FUNC("utif", 2, 41, 1),
-       FUNC("gpio", 1, 41, 1),
-       FUNC("p2led_an", 0, 41, 1),
-};
-
-static struct ralink_pmx_func p1led_an_grp_mt76x8[] = {
-       FUNC("jtag", 3, 42, 1),
-       FUNC("utif", 2, 42, 1),
-       FUNC("gpio", 1, 42, 1),
-       FUNC("p1led_an", 0, 42, 1),
-};
-
-static struct ralink_pmx_func p0led_an_grp_mt76x8[] = {
-       FUNC("jtag", 3, 43, 1),
-       FUNC("rsvd", 2, 43, 1),
-       FUNC("gpio", 1, 43, 1),
-       FUNC("p0led_an", 0, 43, 1),
-};
-
-static struct ralink_pmx_func wled_an_grp_mt76x8[] = {
-       FUNC("rsvd", 3, 44, 1),
-       FUNC("rsvd", 2, 44, 1),
-       FUNC("gpio", 1, 44, 1),
-       FUNC("wled_an", 0, 44, 1),
-};
-
-#define MT76X8_GPIO_MODE_MASK          0x3
-
-#define MT76X8_GPIO_MODE_P4LED_KN      58
-#define MT76X8_GPIO_MODE_P3LED_KN      56
-#define MT76X8_GPIO_MODE_P2LED_KN      54
-#define MT76X8_GPIO_MODE_P1LED_KN      52
-#define MT76X8_GPIO_MODE_P0LED_KN      50
-#define MT76X8_GPIO_MODE_WLED_KN       48
-#define MT76X8_GPIO_MODE_P4LED_AN      42
-#define MT76X8_GPIO_MODE_P3LED_AN      40
-#define MT76X8_GPIO_MODE_P2LED_AN      38
-#define MT76X8_GPIO_MODE_P1LED_AN      36
-#define MT76X8_GPIO_MODE_P0LED_AN      34
-#define MT76X8_GPIO_MODE_WLED_AN       32
-#define MT76X8_GPIO_MODE_PWM1          30
-#define MT76X8_GPIO_MODE_PWM0          28
-#define MT76X8_GPIO_MODE_UART2         26
-#define MT76X8_GPIO_MODE_UART1         24
-#define MT76X8_GPIO_MODE_I2C           20
-#define MT76X8_GPIO_MODE_REFCLK                18
-#define MT76X8_GPIO_MODE_PERST         16
-#define MT76X8_GPIO_MODE_WDT           14
-#define MT76X8_GPIO_MODE_SPI           12
-#define MT76X8_GPIO_MODE_SDMODE                10
-#define MT76X8_GPIO_MODE_UART0         8
-#define MT76X8_GPIO_MODE_I2S           6
-#define MT76X8_GPIO_MODE_CS1           4
-#define MT76X8_GPIO_MODE_SPIS          2
-#define MT76X8_GPIO_MODE_GPIO          0
-
-static struct ralink_pmx_group mt76x8_pinmux_data[] = {
-       GRP_G("pwm1", pwm1_grp_mt76x8, MT76X8_GPIO_MODE_MASK,
-                               1, MT76X8_GPIO_MODE_PWM1),
-       GRP_G("pwm0", pwm0_grp_mt76x8, MT76X8_GPIO_MODE_MASK,
-                               1, MT76X8_GPIO_MODE_PWM0),
-       GRP_G("uart2", uart2_grp_mt76x8, MT76X8_GPIO_MODE_MASK,
-                               1, MT76X8_GPIO_MODE_UART2),
-       GRP_G("uart1", uart1_grp_mt76x8, MT76X8_GPIO_MODE_MASK,
-                               1, MT76X8_GPIO_MODE_UART1),
-       GRP_G("i2c", i2c_grp_mt76x8, MT76X8_GPIO_MODE_MASK,
-                               1, MT76X8_GPIO_MODE_I2C),
-       GRP("refclk", refclk_grp_mt76x8, 1, MT76X8_GPIO_MODE_REFCLK),
-       GRP("perst", perst_grp_mt76x8, 1, MT76X8_GPIO_MODE_PERST),
-       GRP("wdt", wdt_grp_mt76x8, 1, MT76X8_GPIO_MODE_WDT),
-       GRP("spi", spi_grp_mt76x8, 1, MT76X8_GPIO_MODE_SPI),
-       GRP_G("sdmode", sd_mode_grp_mt76x8, MT76X8_GPIO_MODE_MASK,
-                               1, MT76X8_GPIO_MODE_SDMODE),
-       GRP_G("uart0", uart0_grp_mt76x8, MT76X8_GPIO_MODE_MASK,
-                               1, MT76X8_GPIO_MODE_UART0),
-       GRP_G("i2s", i2s_grp_mt76x8, MT76X8_GPIO_MODE_MASK,
-                               1, MT76X8_GPIO_MODE_I2S),
-       GRP_G("spi cs1", spi_cs1_grp_mt76x8, MT76X8_GPIO_MODE_MASK,
-                               1, MT76X8_GPIO_MODE_CS1),
-       GRP_G("spis", spis_grp_mt76x8, MT76X8_GPIO_MODE_MASK,
-                               1, MT76X8_GPIO_MODE_SPIS),
-       GRP_G("gpio", gpio_grp_mt76x8, MT76X8_GPIO_MODE_MASK,
-                               1, MT76X8_GPIO_MODE_GPIO),
-       GRP_G("wled_an", wled_an_grp_mt76x8, MT76X8_GPIO_MODE_MASK,
-                               1, MT76X8_GPIO_MODE_WLED_AN),
-       GRP_G("p0led_an", p0led_an_grp_mt76x8, MT76X8_GPIO_MODE_MASK,
-                               1, MT76X8_GPIO_MODE_P0LED_AN),
-       GRP_G("p1led_an", p1led_an_grp_mt76x8, MT76X8_GPIO_MODE_MASK,
-                               1, MT76X8_GPIO_MODE_P1LED_AN),
-       GRP_G("p2led_an", p2led_an_grp_mt76x8, MT76X8_GPIO_MODE_MASK,
-                               1, MT76X8_GPIO_MODE_P2LED_AN),
-       GRP_G("p3led_an", p3led_an_grp_mt76x8, MT76X8_GPIO_MODE_MASK,
-                               1, MT76X8_GPIO_MODE_P3LED_AN),
-       GRP_G("p4led_an", p4led_an_grp_mt76x8, MT76X8_GPIO_MODE_MASK,
-                               1, MT76X8_GPIO_MODE_P4LED_AN),
-       GRP_G("wled_kn", wled_kn_grp_mt76x8, MT76X8_GPIO_MODE_MASK,
-                               1, MT76X8_GPIO_MODE_WLED_KN),
-       GRP_G("p0led_kn", p0led_kn_grp_mt76x8, MT76X8_GPIO_MODE_MASK,
-                               1, MT76X8_GPIO_MODE_P0LED_KN),
-       GRP_G("p1led_kn", p1led_kn_grp_mt76x8, MT76X8_GPIO_MODE_MASK,
-                               1, MT76X8_GPIO_MODE_P1LED_KN),
-       GRP_G("p2led_kn", p2led_kn_grp_mt76x8, MT76X8_GPIO_MODE_MASK,
-                               1, MT76X8_GPIO_MODE_P2LED_KN),
-       GRP_G("p3led_kn", p3led_kn_grp_mt76x8, MT76X8_GPIO_MODE_MASK,
-                               1, MT76X8_GPIO_MODE_P3LED_KN),
-       GRP_G("p4led_kn", p4led_kn_grp_mt76x8, MT76X8_GPIO_MODE_MASK,
-                               1, MT76X8_GPIO_MODE_P4LED_KN),
-       { 0 }
-};
-
-static int mt7620_pinctrl_probe(struct platform_device *pdev)
-{
-       if (is_mt76x8())
-               return ralink_pinctrl_init(pdev, mt76x8_pinmux_data);
-       else
-               return ralink_pinctrl_init(pdev, mt7620a_pinmux_data);
-}
-
-static const struct of_device_id mt7620_pinctrl_match[] = {
-       { .compatible = "ralink,mt7620-pinctrl" },
-       {}
-};
-MODULE_DEVICE_TABLE(of, mt7620_pinctrl_match);
-
-static struct platform_driver mt7620_pinctrl_driver = {
-       .probe = mt7620_pinctrl_probe,
-       .driver = {
-               .name = "mt7620-pinctrl",
-               .of_match_table = mt7620_pinctrl_match,
-       },
-};
-
-static int __init mt7620_pinctrl_init(void)
-{
-       return platform_driver_register(&mt7620_pinctrl_driver);
-}
-core_initcall_sync(mt7620_pinctrl_init);
diff --git a/drivers/pinctrl/ralink/pinctrl-mt7621.c b/drivers/pinctrl/ralink/pinctrl-mt7621.c
deleted file mode 100644 (file)
index eddc0ba..0000000
+++ /dev/null
@@ -1,116 +0,0 @@
-// SPDX-License-Identifier: GPL-2.0-only
-
-#include <linux/module.h>
-#include <linux/platform_device.h>
-#include <linux/of.h>
-#include "pinctrl-ralink.h"
-
-#define MT7621_GPIO_MODE_UART1         1
-#define MT7621_GPIO_MODE_I2C           2
-#define MT7621_GPIO_MODE_UART3_MASK    0x3
-#define MT7621_GPIO_MODE_UART3_SHIFT   3
-#define MT7621_GPIO_MODE_UART3_GPIO    1
-#define MT7621_GPIO_MODE_UART2_MASK    0x3
-#define MT7621_GPIO_MODE_UART2_SHIFT   5
-#define MT7621_GPIO_MODE_UART2_GPIO    1
-#define MT7621_GPIO_MODE_JTAG          7
-#define MT7621_GPIO_MODE_WDT_MASK      0x3
-#define MT7621_GPIO_MODE_WDT_SHIFT     8
-#define MT7621_GPIO_MODE_WDT_GPIO      1
-#define MT7621_GPIO_MODE_PCIE_RST      0
-#define MT7621_GPIO_MODE_PCIE_REF      2
-#define MT7621_GPIO_MODE_PCIE_MASK     0x3
-#define MT7621_GPIO_MODE_PCIE_SHIFT    10
-#define MT7621_GPIO_MODE_PCIE_GPIO     1
-#define MT7621_GPIO_MODE_MDIO_MASK     0x3
-#define MT7621_GPIO_MODE_MDIO_SHIFT    12
-#define MT7621_GPIO_MODE_MDIO_GPIO     1
-#define MT7621_GPIO_MODE_RGMII1                14
-#define MT7621_GPIO_MODE_RGMII2                15
-#define MT7621_GPIO_MODE_SPI_MASK      0x3
-#define MT7621_GPIO_MODE_SPI_SHIFT     16
-#define MT7621_GPIO_MODE_SPI_GPIO      1
-#define MT7621_GPIO_MODE_SDHCI_MASK    0x3
-#define MT7621_GPIO_MODE_SDHCI_SHIFT   18
-#define MT7621_GPIO_MODE_SDHCI_GPIO    1
-
-static struct ralink_pmx_func uart1_grp[] =  { FUNC("uart1", 0, 1, 2) };
-static struct ralink_pmx_func i2c_grp[] =  { FUNC("i2c", 0, 3, 2) };
-static struct ralink_pmx_func uart3_grp[] = {
-       FUNC("uart3", 0, 5, 4),
-       FUNC("i2s", 2, 5, 4),
-       FUNC("spdif3", 3, 5, 4),
-};
-static struct ralink_pmx_func uart2_grp[] = {
-       FUNC("uart2", 0, 9, 4),
-       FUNC("pcm", 2, 9, 4),
-       FUNC("spdif2", 3, 9, 4),
-};
-static struct ralink_pmx_func jtag_grp[] = { FUNC("jtag", 0, 13, 5) };
-static struct ralink_pmx_func wdt_grp[] = {
-       FUNC("wdt rst", 0, 18, 1),
-       FUNC("wdt refclk", 2, 18, 1),
-};
-static struct ralink_pmx_func pcie_rst_grp[] = {
-       FUNC("pcie rst", MT7621_GPIO_MODE_PCIE_RST, 19, 1),
-       FUNC("pcie refclk", MT7621_GPIO_MODE_PCIE_REF, 19, 1)
-};
-static struct ralink_pmx_func mdio_grp[] = { FUNC("mdio", 0, 20, 2) };
-static struct ralink_pmx_func rgmii2_grp[] = { FUNC("rgmii2", 0, 22, 12) };
-static struct ralink_pmx_func spi_grp[] = {
-       FUNC("spi", 0, 34, 7),
-       FUNC("nand1", 2, 34, 7),
-};
-static struct ralink_pmx_func sdhci_grp[] = {
-       FUNC("sdhci", 0, 41, 8),
-       FUNC("nand2", 2, 41, 8),
-};
-static struct ralink_pmx_func rgmii1_grp[] = { FUNC("rgmii1", 0, 49, 12) };
-
-static struct ralink_pmx_group mt7621_pinmux_data[] = {
-       GRP("uart1", uart1_grp, 1, MT7621_GPIO_MODE_UART1),
-       GRP("i2c", i2c_grp, 1, MT7621_GPIO_MODE_I2C),
-       GRP_G("uart3", uart3_grp, MT7621_GPIO_MODE_UART3_MASK,
-               MT7621_GPIO_MODE_UART3_GPIO, MT7621_GPIO_MODE_UART3_SHIFT),
-       GRP_G("uart2", uart2_grp, MT7621_GPIO_MODE_UART2_MASK,
-               MT7621_GPIO_MODE_UART2_GPIO, MT7621_GPIO_MODE_UART2_SHIFT),
-       GRP("jtag", jtag_grp, 1, MT7621_GPIO_MODE_JTAG),
-       GRP_G("wdt", wdt_grp, MT7621_GPIO_MODE_WDT_MASK,
-               MT7621_GPIO_MODE_WDT_GPIO, MT7621_GPIO_MODE_WDT_SHIFT),
-       GRP_G("pcie", pcie_rst_grp, MT7621_GPIO_MODE_PCIE_MASK,
-               MT7621_GPIO_MODE_PCIE_GPIO, MT7621_GPIO_MODE_PCIE_SHIFT),
-       GRP_G("mdio", mdio_grp, MT7621_GPIO_MODE_MDIO_MASK,
-               MT7621_GPIO_MODE_MDIO_GPIO, MT7621_GPIO_MODE_MDIO_SHIFT),
-       GRP("rgmii2", rgmii2_grp, 1, MT7621_GPIO_MODE_RGMII2),
-       GRP_G("spi", spi_grp, MT7621_GPIO_MODE_SPI_MASK,
-               MT7621_GPIO_MODE_SPI_GPIO, MT7621_GPIO_MODE_SPI_SHIFT),
-       GRP_G("sdhci", sdhci_grp, MT7621_GPIO_MODE_SDHCI_MASK,
-               MT7621_GPIO_MODE_SDHCI_GPIO, MT7621_GPIO_MODE_SDHCI_SHIFT),
-       GRP("rgmii1", rgmii1_grp, 1, MT7621_GPIO_MODE_RGMII1),
-       { 0 }
-};
-
-static int mt7621_pinctrl_probe(struct platform_device *pdev)
-{
-       return ralink_pinctrl_init(pdev, mt7621_pinmux_data);
-}
-
-static const struct of_device_id mt7621_pinctrl_match[] = {
-       { .compatible = "ralink,mt7621-pinctrl" },
-       {}
-};
-MODULE_DEVICE_TABLE(of, mt7621_pinctrl_match);
-
-static struct platform_driver mt7621_pinctrl_driver = {
-       .probe = mt7621_pinctrl_probe,
-       .driver = {
-               .name = "mt7621-pinctrl",
-               .of_match_table = mt7621_pinctrl_match,
-       },
-};
-
-static int __init mt7621_pinctrl_init(void)
-{
-       return platform_driver_register(&mt7621_pinctrl_driver);
-}
-core_initcall_sync(mt7621_pinctrl_init);
diff --git a/drivers/pinctrl/ralink/pinctrl-ralink.c b/drivers/pinctrl/ralink/pinctrl-ralink.c
deleted file mode 100644 (file)
index 770862f..0000000
+++ /dev/null
@@ -1,351 +0,0 @@
-// SPDX-License-Identifier: GPL-2.0
-/*
- *  Copyright (C) 2013 John Crispin <blogic@openwrt.org>
- */
-
-#include <linux/module.h>
-#include <linux/device.h>
-#include <linux/io.h>
-#include <linux/platform_device.h>
-#include <linux/slab.h>
-#include <linux/of.h>
-#include <linux/pinctrl/pinctrl.h>
-#include <linux/pinctrl/pinconf.h>
-#include <linux/pinctrl/pinconf-generic.h>
-#include <linux/pinctrl/pinmux.h>
-#include <linux/pinctrl/consumer.h>
-#include <linux/pinctrl/machine.h>
-
-#include <asm/mach-ralink/ralink_regs.h>
-#include <asm/mach-ralink/mt7620.h>
-
-#include "pinctrl-ralink.h"
-#include "../core.h"
-#include "../pinctrl-utils.h"
-
-#define SYSC_REG_GPIO_MODE     0x60
-#define SYSC_REG_GPIO_MODE2    0x64
-
-struct ralink_priv {
-       struct device *dev;
-
-       struct pinctrl_pin_desc *pads;
-       struct pinctrl_desc *desc;
-
-       struct ralink_pmx_func **func;
-       int func_count;
-
-       struct ralink_pmx_group *groups;
-       const char **group_names;
-       int group_count;
-
-       u8 *gpio;
-       int max_pins;
-};
-
-static int ralink_get_group_count(struct pinctrl_dev *pctrldev)
-{
-       struct ralink_priv *p = pinctrl_dev_get_drvdata(pctrldev);
-
-       return p->group_count;
-}
-
-static const char *ralink_get_group_name(struct pinctrl_dev *pctrldev,
-                                        unsigned int group)
-{
-       struct ralink_priv *p = pinctrl_dev_get_drvdata(pctrldev);
-
-       return (group >= p->group_count) ? NULL : p->group_names[group];
-}
-
-static int ralink_get_group_pins(struct pinctrl_dev *pctrldev,
-                                unsigned int group,
-                                const unsigned int **pins,
-                                unsigned int *num_pins)
-{
-       struct ralink_priv *p = pinctrl_dev_get_drvdata(pctrldev);
-
-       if (group >= p->group_count)
-               return -EINVAL;
-
-       *pins = p->groups[group].func[0].pins;
-       *num_pins = p->groups[group].func[0].pin_count;
-
-       return 0;
-}
-
-static const struct pinctrl_ops ralink_pctrl_ops = {
-       .get_groups_count       = ralink_get_group_count,
-       .get_group_name         = ralink_get_group_name,
-       .get_group_pins         = ralink_get_group_pins,
-       .dt_node_to_map         = pinconf_generic_dt_node_to_map_all,
-       .dt_free_map            = pinconf_generic_dt_free_map,
-};
-
-static int ralink_pmx_func_count(struct pinctrl_dev *pctrldev)
-{
-       struct ralink_priv *p = pinctrl_dev_get_drvdata(pctrldev);
-
-       return p->func_count;
-}
-
-static const char *ralink_pmx_func_name(struct pinctrl_dev *pctrldev,
-                                       unsigned int func)
-{
-       struct ralink_priv *p = pinctrl_dev_get_drvdata(pctrldev);
-
-       return p->func[func]->name;
-}
-
-static int ralink_pmx_group_get_groups(struct pinctrl_dev *pctrldev,
-                                      unsigned int func,
-                                      const char * const **groups,
-                                      unsigned int * const num_groups)
-{
-       struct ralink_priv *p = pinctrl_dev_get_drvdata(pctrldev);
-
-       if (p->func[func]->group_count == 1)
-               *groups = &p->group_names[p->func[func]->groups[0]];
-       else
-               *groups = p->group_names;
-
-       *num_groups = p->func[func]->group_count;
-
-       return 0;
-}
-
-static int ralink_pmx_group_enable(struct pinctrl_dev *pctrldev,
-                                  unsigned int func, unsigned int group)
-{
-       struct ralink_priv *p = pinctrl_dev_get_drvdata(pctrldev);
-       u32 mode = 0;
-       u32 reg = SYSC_REG_GPIO_MODE;
-       int i;
-       int shift;
-
-       /* dont allow double use */
-       if (p->groups[group].enabled) {
-               dev_err(p->dev, "%s is already enabled\n",
-                       p->groups[group].name);
-               return 0;
-       }
-
-       p->groups[group].enabled = 1;
-       p->func[func]->enabled = 1;
-
-       shift = p->groups[group].shift;
-       if (shift >= 32) {
-               shift -= 32;
-               reg = SYSC_REG_GPIO_MODE2;
-       }
-       mode = rt_sysc_r32(reg);
-       mode &= ~(p->groups[group].mask << shift);
-
-       /* mark the pins as gpio */
-       for (i = 0; i < p->groups[group].func[0].pin_count; i++)
-               p->gpio[p->groups[group].func[0].pins[i]] = 1;
-
-       /* function 0 is gpio and needs special handling */
-       if (func == 0) {
-               mode |= p->groups[group].gpio << shift;
-       } else {
-               for (i = 0; i < p->func[func]->pin_count; i++)
-                       p->gpio[p->func[func]->pins[i]] = 0;
-               mode |= p->func[func]->value << shift;
-       }
-       rt_sysc_w32(mode, reg);
-
-       return 0;
-}
-
-static int ralink_pmx_group_gpio_request_enable(struct pinctrl_dev *pctrldev,
-                                               struct pinctrl_gpio_range *range,
-                                               unsigned int pin)
-{
-       struct ralink_priv *p = pinctrl_dev_get_drvdata(pctrldev);
-
-       if (!p->gpio[pin]) {
-               dev_err(p->dev, "pin %d is not set to gpio mux\n", pin);
-               return -EINVAL;
-       }
-
-       return 0;
-}
-
-static const struct pinmux_ops ralink_pmx_group_ops = {
-       .get_functions_count    = ralink_pmx_func_count,
-       .get_function_name      = ralink_pmx_func_name,
-       .get_function_groups    = ralink_pmx_group_get_groups,
-       .set_mux                = ralink_pmx_group_enable,
-       .gpio_request_enable    = ralink_pmx_group_gpio_request_enable,
-};
-
-static struct pinctrl_desc ralink_pctrl_desc = {
-       .owner          = THIS_MODULE,
-       .name           = "ralink-pinctrl",
-       .pctlops        = &ralink_pctrl_ops,
-       .pmxops         = &ralink_pmx_group_ops,
-};
-
-static struct ralink_pmx_func gpio_func = {
-       .name = "gpio",
-};
-
-static int ralink_pinctrl_index(struct ralink_priv *p)
-{
-       struct ralink_pmx_group *mux = p->groups;
-       int i, j, c = 0;
-
-       /* count the mux functions */
-       while (mux->name) {
-               p->group_count++;
-               mux++;
-       }
-
-       /* allocate the group names array needed by the gpio function */
-       p->group_names = devm_kcalloc(p->dev, p->group_count,
-                                     sizeof(char *), GFP_KERNEL);
-       if (!p->group_names)
-               return -ENOMEM;
-
-       for (i = 0; i < p->group_count; i++) {
-               p->group_names[i] = p->groups[i].name;
-               p->func_count += p->groups[i].func_count;
-       }
-
-       /* we have a dummy function[0] for gpio */
-       p->func_count++;
-
-       /* allocate our function and group mapping index buffers */
-       p->func = devm_kcalloc(p->dev, p->func_count,
-                              sizeof(*p->func), GFP_KERNEL);
-       gpio_func.groups = devm_kcalloc(p->dev, p->group_count, sizeof(int),
-                                       GFP_KERNEL);
-       if (!p->func || !gpio_func.groups)
-               return -ENOMEM;
-
-       /* add a backpointer to the function so it knows its group */
-       gpio_func.group_count = p->group_count;
-       for (i = 0; i < gpio_func.group_count; i++)
-               gpio_func.groups[i] = i;
-
-       p->func[c] = &gpio_func;
-       c++;
-
-       /* add remaining functions */
-       for (i = 0; i < p->group_count; i++) {
-               for (j = 0; j < p->groups[i].func_count; j++) {
-                       p->func[c] = &p->groups[i].func[j];
-                       p->func[c]->groups = devm_kzalloc(p->dev, sizeof(int),
-                                                   GFP_KERNEL);
-                       if (!p->func[c]->groups)
-                               return -ENOMEM;
-                       p->func[c]->groups[0] = i;
-                       p->func[c]->group_count = 1;
-                       c++;
-               }
-       }
-       return 0;
-}
-
-static int ralink_pinctrl_pins(struct ralink_priv *p)
-{
-       int i, j;
-
-       /*
-        * loop over the functions and initialize the pins array.
-        * also work out the highest pin used.
-        */
-       for (i = 0; i < p->func_count; i++) {
-               int pin;
-
-               if (!p->func[i]->pin_count)
-                       continue;
-
-               p->func[i]->pins = devm_kcalloc(p->dev,
-                                               p->func[i]->pin_count,
-                                               sizeof(int),
-                                               GFP_KERNEL);
-               if (!p->func[i]->pins)
-                       return -ENOMEM;
-               for (j = 0; j < p->func[i]->pin_count; j++)
-                       p->func[i]->pins[j] = p->func[i]->pin_first + j;
-
-               pin = p->func[i]->pin_first + p->func[i]->pin_count;
-               if (pin > p->max_pins)
-                       p->max_pins = pin;
-       }
-
-       /* the buffer that tells us which pins are gpio */
-       p->gpio = devm_kcalloc(p->dev, p->max_pins, sizeof(u8), GFP_KERNEL);
-       /* the pads needed to tell pinctrl about our pins */
-       p->pads = devm_kcalloc(p->dev, p->max_pins,
-                              sizeof(struct pinctrl_pin_desc), GFP_KERNEL);
-       if (!p->pads || !p->gpio)
-               return -ENOMEM;
-
-       memset(p->gpio, 1, sizeof(u8) * p->max_pins);
-       for (i = 0; i < p->func_count; i++) {
-               if (!p->func[i]->pin_count)
-                       continue;
-
-               for (j = 0; j < p->func[i]->pin_count; j++)
-                       p->gpio[p->func[i]->pins[j]] = 0;
-       }
-
-       /* pin 0 is always a gpio */
-       p->gpio[0] = 1;
-
-       /* set the pads */
-       for (i = 0; i < p->max_pins; i++) {
-               /* strlen("ioXY") + 1 = 5 */
-               char *name = devm_kzalloc(p->dev, 5, GFP_KERNEL);
-
-               if (!name)
-                       return -ENOMEM;
-               snprintf(name, 5, "io%d", i);
-               p->pads[i].number = i;
-               p->pads[i].name = name;
-       }
-       p->desc->pins = p->pads;
-       p->desc->npins = p->max_pins;
-
-       return 0;
-}
-
-int ralink_pinctrl_init(struct platform_device *pdev,
-                       struct ralink_pmx_group *data)
-{
-       struct ralink_priv *p;
-       struct pinctrl_dev *dev;
-       int err;
-
-       if (!data)
-               return -ENOTSUPP;
-
-       /* setup the private data */
-       p = devm_kzalloc(&pdev->dev, sizeof(struct ralink_priv), GFP_KERNEL);
-       if (!p)
-               return -ENOMEM;
-
-       p->dev = &pdev->dev;
-       p->desc = &ralink_pctrl_desc;
-       p->groups = data;
-       platform_set_drvdata(pdev, p);
-
-       /* init the device */
-       err = ralink_pinctrl_index(p);
-       if (err) {
-               dev_err(&pdev->dev, "failed to load index\n");
-               return err;
-       }
-
-       err = ralink_pinctrl_pins(p);
-       if (err) {
-               dev_err(&pdev->dev, "failed to load pins\n");
-               return err;
-       }
-       dev = pinctrl_register(p->desc, &pdev->dev, p);
-
-       return PTR_ERR_OR_ZERO(dev);
-}
diff --git a/drivers/pinctrl/ralink/pinctrl-ralink.h b/drivers/pinctrl/ralink/pinctrl-ralink.h
deleted file mode 100644 (file)
index e6037be..0000000
+++ /dev/null
@@ -1,53 +0,0 @@
-/* SPDX-License-Identifier: GPL-2.0-only */
-/*
- *  Copyright (C) 2012 John Crispin <john@phrozen.org>
- */
-
-#ifndef _PINCTRL_RALINK_H__
-#define _PINCTRL_RALINK_H__
-
-#define FUNC(name, value, pin_first, pin_count) \
-       { name, value, pin_first, pin_count }
-
-#define GRP(_name, _func, _mask, _shift) \
-       { .name = _name, .mask = _mask, .shift = _shift, \
-         .func = _func, .gpio = _mask, \
-         .func_count = ARRAY_SIZE(_func) }
-
-#define GRP_G(_name, _func, _mask, _gpio, _shift) \
-       { .name = _name, .mask = _mask, .shift = _shift, \
-         .func = _func, .gpio = _gpio, \
-         .func_count = ARRAY_SIZE(_func) }
-
-struct ralink_pmx_group;
-
-struct ralink_pmx_func {
-       const char *name;
-       const char value;
-
-       int pin_first;
-       int pin_count;
-       int *pins;
-
-       int *groups;
-       int group_count;
-
-       int enabled;
-};
-
-struct ralink_pmx_group {
-       const char *name;
-       int enabled;
-
-       const u32 shift;
-       const char mask;
-       const char gpio;
-
-       struct ralink_pmx_func *func;
-       int func_count;
-};
-
-int ralink_pinctrl_init(struct platform_device *pdev,
-                       struct ralink_pmx_group *data);
-
-#endif
diff --git a/drivers/pinctrl/ralink/pinctrl-rt2880.c b/drivers/pinctrl/ralink/pinctrl-rt2880.c
deleted file mode 100644 (file)
index 3e2f1aa..0000000
+++ /dev/null
@@ -1,60 +0,0 @@
-// SPDX-License-Identifier: GPL-2.0-only
-
-#include <linux/bitops.h>
-#include <linux/module.h>
-#include <linux/platform_device.h>
-#include <linux/of.h>
-#include "pinctrl-ralink.h"
-
-#define RT2880_GPIO_MODE_I2C           BIT(0)
-#define RT2880_GPIO_MODE_UART0         BIT(1)
-#define RT2880_GPIO_MODE_SPI           BIT(2)
-#define RT2880_GPIO_MODE_UART1         BIT(3)
-#define RT2880_GPIO_MODE_JTAG          BIT(4)
-#define RT2880_GPIO_MODE_MDIO          BIT(5)
-#define RT2880_GPIO_MODE_SDRAM         BIT(6)
-#define RT2880_GPIO_MODE_PCI           BIT(7)
-
-static struct ralink_pmx_func i2c_grp[] = { FUNC("i2c", 0, 1, 2) };
-static struct ralink_pmx_func spi_grp[] = { FUNC("spi", 0, 3, 4) };
-static struct ralink_pmx_func uartlite_grp[] = { FUNC("uartlite", 0, 7, 8) };
-static struct ralink_pmx_func jtag_grp[] = { FUNC("jtag", 0, 17, 5) };
-static struct ralink_pmx_func mdio_grp[] = { FUNC("mdio", 0, 22, 2) };
-static struct ralink_pmx_func sdram_grp[] = { FUNC("sdram", 0, 24, 16) };
-static struct ralink_pmx_func pci_grp[] = { FUNC("pci", 0, 40, 32) };
-
-static struct ralink_pmx_group rt2880_pinmux_data_act[] = {
-       GRP("i2c", i2c_grp, 1, RT2880_GPIO_MODE_I2C),
-       GRP("spi", spi_grp, 1, RT2880_GPIO_MODE_SPI),
-       GRP("uartlite", uartlite_grp, 1, RT2880_GPIO_MODE_UART0),
-       GRP("jtag", jtag_grp, 1, RT2880_GPIO_MODE_JTAG),
-       GRP("mdio", mdio_grp, 1, RT2880_GPIO_MODE_MDIO),
-       GRP("sdram", sdram_grp, 1, RT2880_GPIO_MODE_SDRAM),
-       GRP("pci", pci_grp, 1, RT2880_GPIO_MODE_PCI),
-       { 0 }
-};
-
-static int rt2880_pinctrl_probe(struct platform_device *pdev)
-{
-       return ralink_pinctrl_init(pdev, rt2880_pinmux_data_act);
-}
-
-static const struct of_device_id rt2880_pinctrl_match[] = {
-       { .compatible = "ralink,rt2880-pinctrl" },
-       {}
-};
-MODULE_DEVICE_TABLE(of, rt2880_pinctrl_match);
-
-static struct platform_driver rt2880_pinctrl_driver = {
-       .probe = rt2880_pinctrl_probe,
-       .driver = {
-               .name = "rt2880-pinctrl",
-               .of_match_table = rt2880_pinctrl_match,
-       },
-};
-
-static int __init rt2880_pinctrl_init(void)
-{
-       return platform_driver_register(&rt2880_pinctrl_driver);
-}
-core_initcall_sync(rt2880_pinctrl_init);
diff --git a/drivers/pinctrl/ralink/pinctrl-rt305x.c b/drivers/pinctrl/ralink/pinctrl-rt305x.c
deleted file mode 100644 (file)
index bdaee5c..0000000
+++ /dev/null
@@ -1,137 +0,0 @@
-// SPDX-License-Identifier: GPL-2.0-only
-
-#include <asm/mach-ralink/ralink_regs.h>
-#include <asm/mach-ralink/rt305x.h>
-#include <linux/module.h>
-#include <linux/platform_device.h>
-#include <linux/of.h>
-#include "pinctrl-ralink.h"
-
-#define RT305X_GPIO_MODE_UART0_SHIFT   2
-#define RT305X_GPIO_MODE_UART0_MASK    0x7
-#define RT305X_GPIO_MODE_UART0(x)      ((x) << RT305X_GPIO_MODE_UART0_SHIFT)
-#define RT305X_GPIO_MODE_UARTF         0
-#define RT305X_GPIO_MODE_PCM_UARTF     1
-#define RT305X_GPIO_MODE_PCM_I2S       2
-#define RT305X_GPIO_MODE_I2S_UARTF     3
-#define RT305X_GPIO_MODE_PCM_GPIO      4
-#define RT305X_GPIO_MODE_GPIO_UARTF    5
-#define RT305X_GPIO_MODE_GPIO_I2S      6
-#define RT305X_GPIO_MODE_GPIO          7
-
-#define RT305X_GPIO_MODE_I2C           0
-#define RT305X_GPIO_MODE_SPI           1
-#define RT305X_GPIO_MODE_UART1         5
-#define RT305X_GPIO_MODE_JTAG          6
-#define RT305X_GPIO_MODE_MDIO          7
-#define RT305X_GPIO_MODE_SDRAM         8
-#define RT305X_GPIO_MODE_RGMII         9
-#define RT5350_GPIO_MODE_PHY_LED       14
-#define RT5350_GPIO_MODE_SPI_CS1       21
-#define RT3352_GPIO_MODE_LNA           18
-#define RT3352_GPIO_MODE_PA            20
-
-static struct ralink_pmx_func i2c_grp[] =  { FUNC("i2c", 0, 1, 2) };
-static struct ralink_pmx_func spi_grp[] = { FUNC("spi", 0, 3, 4) };
-static struct ralink_pmx_func uartf_grp[] = {
-       FUNC("uartf", RT305X_GPIO_MODE_UARTF, 7, 8),
-       FUNC("pcm uartf", RT305X_GPIO_MODE_PCM_UARTF, 7, 8),
-       FUNC("pcm i2s", RT305X_GPIO_MODE_PCM_I2S, 7, 8),
-       FUNC("i2s uartf", RT305X_GPIO_MODE_I2S_UARTF, 7, 8),
-       FUNC("pcm gpio", RT305X_GPIO_MODE_PCM_GPIO, 11, 4),
-       FUNC("gpio uartf", RT305X_GPIO_MODE_GPIO_UARTF, 7, 4),
-       FUNC("gpio i2s", RT305X_GPIO_MODE_GPIO_I2S, 7, 4),
-};
-static struct ralink_pmx_func uartlite_grp[] = { FUNC("uartlite", 0, 15, 2) };
-static struct ralink_pmx_func jtag_grp[] = { FUNC("jtag", 0, 17, 5) };
-static struct ralink_pmx_func mdio_grp[] = { FUNC("mdio", 0, 22, 2) };
-static struct ralink_pmx_func rt5350_led_grp[] = { FUNC("led", 0, 22, 5) };
-static struct ralink_pmx_func rt5350_cs1_grp[] = {
-       FUNC("spi_cs1", 0, 27, 1),
-       FUNC("wdg_cs1", 1, 27, 1),
-};
-static struct ralink_pmx_func sdram_grp[] = { FUNC("sdram", 0, 24, 16) };
-static struct ralink_pmx_func rt3352_rgmii_grp[] = {
-       FUNC("rgmii", 0, 24, 12)
-};
-static struct ralink_pmx_func rgmii_grp[] = { FUNC("rgmii", 0, 40, 12) };
-static struct ralink_pmx_func rt3352_lna_grp[] = { FUNC("lna", 0, 36, 2) };
-static struct ralink_pmx_func rt3352_pa_grp[] = { FUNC("pa", 0, 38, 2) };
-static struct ralink_pmx_func rt3352_led_grp[] = { FUNC("led", 0, 40, 5) };
-static struct ralink_pmx_func rt3352_cs1_grp[] = {
-       FUNC("spi_cs1", 0, 45, 1),
-       FUNC("wdg_cs1", 1, 45, 1),
-};
-
-static struct ralink_pmx_group rt3050_pinmux_data[] = {
-       GRP("i2c", i2c_grp, 1, RT305X_GPIO_MODE_I2C),
-       GRP("spi", spi_grp, 1, RT305X_GPIO_MODE_SPI),
-       GRP("uartf", uartf_grp, RT305X_GPIO_MODE_UART0_MASK,
-               RT305X_GPIO_MODE_UART0_SHIFT),
-       GRP("uartlite", uartlite_grp, 1, RT305X_GPIO_MODE_UART1),
-       GRP("jtag", jtag_grp, 1, RT305X_GPIO_MODE_JTAG),
-       GRP("mdio", mdio_grp, 1, RT305X_GPIO_MODE_MDIO),
-       GRP("rgmii", rgmii_grp, 1, RT305X_GPIO_MODE_RGMII),
-       GRP("sdram", sdram_grp, 1, RT305X_GPIO_MODE_SDRAM),
-       { 0 }
-};
-
-static struct ralink_pmx_group rt3352_pinmux_data[] = {
-       GRP("i2c", i2c_grp, 1, RT305X_GPIO_MODE_I2C),
-       GRP("spi", spi_grp, 1, RT305X_GPIO_MODE_SPI),
-       GRP("uartf", uartf_grp, RT305X_GPIO_MODE_UART0_MASK,
-               RT305X_GPIO_MODE_UART0_SHIFT),
-       GRP("uartlite", uartlite_grp, 1, RT305X_GPIO_MODE_UART1),
-       GRP("jtag", jtag_grp, 1, RT305X_GPIO_MODE_JTAG),
-       GRP("mdio", mdio_grp, 1, RT305X_GPIO_MODE_MDIO),
-       GRP("rgmii", rt3352_rgmii_grp, 1, RT305X_GPIO_MODE_RGMII),
-       GRP("lna", rt3352_lna_grp, 1, RT3352_GPIO_MODE_LNA),
-       GRP("pa", rt3352_pa_grp, 1, RT3352_GPIO_MODE_PA),
-       GRP("led", rt3352_led_grp, 1, RT5350_GPIO_MODE_PHY_LED),
-       GRP("spi_cs1", rt3352_cs1_grp, 2, RT5350_GPIO_MODE_SPI_CS1),
-       { 0 }
-};
-
-static struct ralink_pmx_group rt5350_pinmux_data[] = {
-       GRP("i2c", i2c_grp, 1, RT305X_GPIO_MODE_I2C),
-       GRP("spi", spi_grp, 1, RT305X_GPIO_MODE_SPI),
-       GRP("uartf", uartf_grp, RT305X_GPIO_MODE_UART0_MASK,
-               RT305X_GPIO_MODE_UART0_SHIFT),
-       GRP("uartlite", uartlite_grp, 1, RT305X_GPIO_MODE_UART1),
-       GRP("jtag", jtag_grp, 1, RT305X_GPIO_MODE_JTAG),
-       GRP("led", rt5350_led_grp, 1, RT5350_GPIO_MODE_PHY_LED),
-       GRP("spi_cs1", rt5350_cs1_grp, 2, RT5350_GPIO_MODE_SPI_CS1),
-       { 0 }
-};
-
-static int rt305x_pinctrl_probe(struct platform_device *pdev)
-{
-       if (soc_is_rt5350())
-               return ralink_pinctrl_init(pdev, rt5350_pinmux_data);
-       else if (soc_is_rt305x() || soc_is_rt3350())
-               return ralink_pinctrl_init(pdev, rt3050_pinmux_data);
-       else if (soc_is_rt3352())
-               return ralink_pinctrl_init(pdev, rt3352_pinmux_data);
-       else
-               return -EINVAL;
-}
-
-static const struct of_device_id rt305x_pinctrl_match[] = {
-       { .compatible = "ralink,rt305x-pinctrl" },
-       {}
-};
-MODULE_DEVICE_TABLE(of, rt305x_pinctrl_match);
-
-static struct platform_driver rt305x_pinctrl_driver = {
-       .probe = rt305x_pinctrl_probe,
-       .driver = {
-               .name = "rt305x-pinctrl",
-               .of_match_table = rt305x_pinctrl_match,
-       },
-};
-
-static int __init rt305x_pinctrl_init(void)
-{
-       return platform_driver_register(&rt305x_pinctrl_driver);
-}
-core_initcall_sync(rt305x_pinctrl_init);
diff --git a/drivers/pinctrl/ralink/pinctrl-rt3883.c b/drivers/pinctrl/ralink/pinctrl-rt3883.c
deleted file mode 100644 (file)
index 3922086..0000000
+++ /dev/null
@@ -1,107 +0,0 @@
-// SPDX-License-Identifier: GPL-2.0-only
-
-#include <linux/module.h>
-#include <linux/platform_device.h>
-#include <linux/of.h>
-#include "pinctrl-ralink.h"
-
-#define RT3883_GPIO_MODE_UART0_SHIFT   2
-#define RT3883_GPIO_MODE_UART0_MASK    0x7
-#define RT3883_GPIO_MODE_UART0(x)      ((x) << RT3883_GPIO_MODE_UART0_SHIFT)
-#define RT3883_GPIO_MODE_UARTF         0x0
-#define RT3883_GPIO_MODE_PCM_UARTF     0x1
-#define RT3883_GPIO_MODE_PCM_I2S       0x2
-#define RT3883_GPIO_MODE_I2S_UARTF     0x3
-#define RT3883_GPIO_MODE_PCM_GPIO      0x4
-#define RT3883_GPIO_MODE_GPIO_UARTF    0x5
-#define RT3883_GPIO_MODE_GPIO_I2S      0x6
-#define RT3883_GPIO_MODE_GPIO          0x7
-
-#define RT3883_GPIO_MODE_I2C           0
-#define RT3883_GPIO_MODE_SPI           1
-#define RT3883_GPIO_MODE_UART1         5
-#define RT3883_GPIO_MODE_JTAG          6
-#define RT3883_GPIO_MODE_MDIO          7
-#define RT3883_GPIO_MODE_GE1           9
-#define RT3883_GPIO_MODE_GE2           10
-
-#define RT3883_GPIO_MODE_PCI_SHIFT     11
-#define RT3883_GPIO_MODE_PCI_MASK      0x7
-#define RT3883_GPIO_MODE_PCI           (RT3883_GPIO_MODE_PCI_MASK << RT3883_GPIO_MODE_PCI_SHIFT)
-#define RT3883_GPIO_MODE_LNA_A_SHIFT   16
-#define RT3883_GPIO_MODE_LNA_A_MASK    0x3
-#define _RT3883_GPIO_MODE_LNA_A(_x)    ((_x) << RT3883_GPIO_MODE_LNA_A_SHIFT)
-#define RT3883_GPIO_MODE_LNA_A_GPIO    0x3
-#define RT3883_GPIO_MODE_LNA_A         _RT3883_GPIO_MODE_LNA_A(RT3883_GPIO_MODE_LNA_A_MASK)
-#define RT3883_GPIO_MODE_LNA_G_SHIFT   18
-#define RT3883_GPIO_MODE_LNA_G_MASK    0x3
-#define _RT3883_GPIO_MODE_LNA_G(_x)    ((_x) << RT3883_GPIO_MODE_LNA_G_SHIFT)
-#define RT3883_GPIO_MODE_LNA_G_GPIO    0x3
-#define RT3883_GPIO_MODE_LNA_G         _RT3883_GPIO_MODE_LNA_G(RT3883_GPIO_MODE_LNA_G_MASK)
-
-static struct ralink_pmx_func i2c_grp[] =  { FUNC("i2c", 0, 1, 2) };
-static struct ralink_pmx_func spi_grp[] = { FUNC("spi", 0, 3, 4) };
-static struct ralink_pmx_func uartf_grp[] = {
-       FUNC("uartf", RT3883_GPIO_MODE_UARTF, 7, 8),
-       FUNC("pcm uartf", RT3883_GPIO_MODE_PCM_UARTF, 7, 8),
-       FUNC("pcm i2s", RT3883_GPIO_MODE_PCM_I2S, 7, 8),
-       FUNC("i2s uartf", RT3883_GPIO_MODE_I2S_UARTF, 7, 8),
-       FUNC("pcm gpio", RT3883_GPIO_MODE_PCM_GPIO, 11, 4),
-       FUNC("gpio uartf", RT3883_GPIO_MODE_GPIO_UARTF, 7, 4),
-       FUNC("gpio i2s", RT3883_GPIO_MODE_GPIO_I2S, 7, 4),
-};
-static struct ralink_pmx_func uartlite_grp[] = { FUNC("uartlite", 0, 15, 2) };
-static struct ralink_pmx_func jtag_grp[] = { FUNC("jtag", 0, 17, 5) };
-static struct ralink_pmx_func mdio_grp[] = { FUNC("mdio", 0, 22, 2) };
-static struct ralink_pmx_func lna_a_grp[] = { FUNC("lna a", 0, 32, 3) };
-static struct ralink_pmx_func lna_g_grp[] = { FUNC("lna g", 0, 35, 3) };
-static struct ralink_pmx_func pci_grp[] = {
-       FUNC("pci-dev", 0, 40, 32),
-       FUNC("pci-host2", 1, 40, 32),
-       FUNC("pci-host1", 2, 40, 32),
-       FUNC("pci-fnc", 3, 40, 32)
-};
-static struct ralink_pmx_func ge1_grp[] = { FUNC("ge1", 0, 72, 12) };
-static struct ralink_pmx_func ge2_grp[] = { FUNC("ge2", 0, 84, 12) };
-
-static struct ralink_pmx_group rt3883_pinmux_data[] = {
-       GRP("i2c", i2c_grp, 1, RT3883_GPIO_MODE_I2C),
-       GRP("spi", spi_grp, 1, RT3883_GPIO_MODE_SPI),
-       GRP("uartf", uartf_grp, RT3883_GPIO_MODE_UART0_MASK,
-               RT3883_GPIO_MODE_UART0_SHIFT),
-       GRP("uartlite", uartlite_grp, 1, RT3883_GPIO_MODE_UART1),
-       GRP("jtag", jtag_grp, 1, RT3883_GPIO_MODE_JTAG),
-       GRP("mdio", mdio_grp, 1, RT3883_GPIO_MODE_MDIO),
-       GRP("lna a", lna_a_grp, 1, RT3883_GPIO_MODE_LNA_A),
-       GRP("lna g", lna_g_grp, 1, RT3883_GPIO_MODE_LNA_G),
-       GRP("pci", pci_grp, RT3883_GPIO_MODE_PCI_MASK,
-               RT3883_GPIO_MODE_PCI_SHIFT),
-       GRP("ge1", ge1_grp, 1, RT3883_GPIO_MODE_GE1),
-       GRP("ge2", ge2_grp, 1, RT3883_GPIO_MODE_GE2),
-       { 0 }
-};
-
-static int rt3883_pinctrl_probe(struct platform_device *pdev)
-{
-       return ralink_pinctrl_init(pdev, rt3883_pinmux_data);
-}
-
-static const struct of_device_id rt3883_pinctrl_match[] = {
-       { .compatible = "ralink,rt3883-pinctrl" },
-       {}
-};
-MODULE_DEVICE_TABLE(of, rt3883_pinctrl_match);
-
-static struct platform_driver rt3883_pinctrl_driver = {
-       .probe = rt3883_pinctrl_probe,
-       .driver = {
-               .name = "rt3883-pinctrl",
-               .of_match_table = rt3883_pinctrl_match,
-       },
-};
-
-static int __init rt3883_pinctrl_init(void)
-{
-       return platform_driver_register(&rt3883_pinctrl_driver);
-}
-core_initcall_sync(rt3883_pinctrl_init);
index 0903a0a4183198d21f829542c97edab74ecbad29..77730dc548ed3c7050089cac172e81895bef7f70 100644 (file)
@@ -27,7 +27,6 @@ config PINCTRL_RENESAS
        select PINCTRL_PFC_R8A7792 if ARCH_R8A7792
        select PINCTRL_PFC_R8A7793 if ARCH_R8A7793
        select PINCTRL_PFC_R8A7794 if ARCH_R8A7794
-       select PINCTRL_PFC_R8A77950 if ARCH_R8A77950
        select PINCTRL_PFC_R8A77951 if ARCH_R8A77951
        select PINCTRL_PFC_R8A77960 if ARCH_R8A77960
        select PINCTRL_PFC_R8A77961 if ARCH_R8A77961
@@ -103,10 +102,6 @@ config PINCTRL_PFC_R8A7790
        bool "pin control support for R-Car H2" if COMPILE_TEST
        select PINCTRL_SH_PFC
 
-config PINCTRL_PFC_R8A77950
-       bool "pin control support for R-Car H3 ES1.x" if COMPILE_TEST
-       select PINCTRL_SH_PFC
-
 config PINCTRL_PFC_R8A77951
        bool "pin control support for R-Car H3 ES2.0+" if COMPILE_TEST
        select PINCTRL_SH_PFC
index 558b30ce0dec98dad0fc011c021aefeafd8cc992..3e776955bd4bc776987e1ab6e7567ac875dadc9d 100644 (file)
@@ -20,7 +20,6 @@ obj-$(CONFIG_PINCTRL_PFC_R8A7791)     += pfc-r8a7791.o
 obj-$(CONFIG_PINCTRL_PFC_R8A7792)      += pfc-r8a7792.o
 obj-$(CONFIG_PINCTRL_PFC_R8A7793)      += pfc-r8a7791.o
 obj-$(CONFIG_PINCTRL_PFC_R8A7794)      += pfc-r8a7794.o
-obj-$(CONFIG_PINCTRL_PFC_R8A77950)     += pfc-r8a77950.o
 obj-$(CONFIG_PINCTRL_PFC_R8A77951)     += pfc-r8a77951.o
 obj-$(CONFIG_PINCTRL_PFC_R8A77960)     += pfc-r8a7796.o
 obj-$(CONFIG_PINCTRL_PFC_R8A77961)     += pfc-r8a7796.o
index c91102d3f1d1559020a0a31ba4c192b610f8f6eb..0c8d081da6a8008540421b1279d872dadf2c9a1e 100644 (file)
@@ -573,23 +573,12 @@ static const struct of_device_id sh_pfc_of_table[] = {
                .data = &r8a7794_pinmux_info,
        },
 #endif
-/*
- * Both r8a7795 entries must be present to make sanity checks work, but only
- * the first entry is actually used.
- * R-Car H3 ES1.x is matched using soc_device_match() instead.
- */
 #ifdef CONFIG_PINCTRL_PFC_R8A77951
        {
                .compatible = "renesas,pfc-r8a7795",
                .data = &r8a77951_pinmux_info,
        },
 #endif
-#ifdef CONFIG_PINCTRL_PFC_R8A77950
-       {
-               .compatible = "renesas,pfc-r8a7795",
-               .data = &r8a77950_pinmux_info,
-       },
-#endif
 #ifdef CONFIG_PINCTRL_PFC_R8A77960
        {
                .compatible = "renesas,pfc-r8a7796",
@@ -656,7 +645,7 @@ static const struct of_device_id sh_pfc_of_table[] = {
                .data = &sh73a0_pinmux_info,
        },
 #endif
-       { },
+       { /* sentinel */ }
 };
 #endif
 
@@ -1125,9 +1114,9 @@ static void __init sh_pfc_check_info(const struct sh_pfc_soc_info *info)
                        }
                }
 
-               if (pin->configs & SH_PFC_PIN_CFG_IO_VOLTAGE) {
+               if (pin->configs & SH_PFC_PIN_CFG_IO_VOLTAGE_MASK) {
                        if (!info->ops || !info->ops->pin_to_pocctrl)
-                               sh_pfc_err_once(power, "SH_PFC_PIN_CFG_IO_VOLTAGE flag set but .pin_to_pocctrl() not implemented\n");
+                               sh_pfc_err_once(power, "SH_PFC_PIN_CFG_IO_VOLTAGE set but .pin_to_pocctrl() not implemented\n");
                        else if (info->ops->pin_to_pocctrl(pin->pin, &x) < 0)
                                sh_pfc_err("pin %s: SH_PFC_PIN_CFG_IO_VOLTAGE set but invalid pin_to_pocctrl()\n",
                                           pin->name);
@@ -1309,41 +1298,15 @@ free_regs:
 static inline void sh_pfc_check_driver(struct platform_driver *pdrv) {}
 #endif /* !DEBUG */
 
-#ifdef CONFIG_OF
-static const void *sh_pfc_quirk_match(void)
-{
-#ifdef CONFIG_PINCTRL_PFC_R8A77950
-       const struct soc_device_attribute *match;
-       static const struct soc_device_attribute quirks[] = {
-               {
-                       .soc_id = "r8a7795", .revision = "ES1.*",
-                       .data = &r8a77950_pinmux_info,
-               },
-               { /* sentinel */ }
-       };
-
-       match = soc_device_match(quirks);
-       if (match)
-               return match->data;
-#endif /* CONFIG_PINCTRL_PFC_R8A77950 */
-
-       return NULL;
-}
-#endif /* CONFIG_OF */
-
 static int sh_pfc_probe(struct platform_device *pdev)
 {
        const struct sh_pfc_soc_info *info;
        struct sh_pfc *pfc;
        int ret;
 
-#ifdef CONFIG_OF
-       if (pdev->dev.of_node) {
-               info = sh_pfc_quirk_match();
-               if (!info)
-                       info = of_device_get_match_data(&pdev->dev);
-       } else
-#endif
+       if (pdev->dev.of_node)
+               info = of_device_get_match_data(&pdev->dev);
+       else
                info = (const void *)platform_get_device_id(pdev)->driver_data;
 
        pfc = devm_kzalloc(&pdev->dev, sizeof(*pfc), GFP_KERNEL);
@@ -1446,7 +1409,7 @@ static const struct platform_device_id sh_pfc_id_table[] = {
 #ifdef CONFIG_PINCTRL_PFC_SHX3
        { "pfc-shx3", (kernel_ulong_t)&shx3_pinmux_info },
 #endif
-       { },
+       { /* sentinel */ }
 };
 
 static struct platform_driver sh_pfc_driver = {
index 1d8b540110f23e4c3c1160e9779054d8593384a5..86d18b03668eacb8c0d8a1b963bd8f8c0220bdd4 100644 (file)
@@ -1644,7 +1644,7 @@ static const struct pinmux_cfg_reg pinmux_config_regs[] = {
                FN_SEL_HSI_1_0_00, FN_SEL_HSI_1_0_01, 0, 0,
                ))
        },
-       { },
+       { /* sentinel */ }
 };
 
 const struct sh_pfc_soc_info emev2_pinmux_info = {
index dbfc46fe2f2770924f047bbbf48d1283ecb67205..be0a4914eab3357ac0b84124a9be2e10441cadee 100644 (file)
@@ -2384,7 +2384,7 @@ static const struct pinmux_cfg_reg pinmux_config_regs[] = {
                        MSEL8CR_00_0, MSEL8CR_00_1,
                ))
        },
-       { },
+       { /* sentinel */ }
 };
 
 static const struct pinmux_data_reg pinmux_data_regs[] = {
@@ -2510,7 +2510,7 @@ static const struct pinmux_data_reg pinmux_data_regs[] = {
                        PORT323_DATA, PORT322_DATA, PORT321_DATA, PORT320_DATA,
                ))
        },
-       { },
+       { /* sentinel */ }
 };
 
 static const struct pinmux_irq pinmux_irqs[] = {
index 6dcd39918daf96bca1d255c9d6e46917a3bfd9bb..9ee3b700a3d3d2986d0652ed74e4a8d9c78496fc 100644 (file)
@@ -3348,7 +3348,7 @@ static const struct pinmux_cfg_reg pinmux_config_regs[] = {
                        MSEL5CR_0_0,    MSEL5CR_0_1,
                ))
        },
-       { },
+       { /* sentinel */ }
 };
 
 static const struct pinmux_data_reg pinmux_data_regs[] = {
@@ -3452,7 +3452,7 @@ static const struct pinmux_data_reg pinmux_data_regs[] = {
                0, 0, 0, 0,
                0, 0, 0, 0 ))
        },
-       { },
+       { /* sentinel */ }
 };
 
 static const struct pinmux_irq pinmux_irqs[] = {
index b5725c3ed2b60e8828bfbd28796ef61e1ebbf656..ed48b043763fef6c9f9569c5faf1fccec16e4f22 100644 (file)
 #define CPU_ALL_GP(fn, sfx)                                            \
        PORT_GP_CFG_4(0,  fn, sfx, SH_PFC_PIN_CFG_PULL_UP),             \
        PORT_GP_CFG_1(0,  4, fn, sfx, SH_PFC_PIN_CFG_PULL_UP),          \
-       PORT_GP_CFG_1(0,  5, fn, sfx, SH_PFC_PIN_CFG_IO_VOLTAGE | SH_PFC_PIN_CFG_PULL_UP),      \
-       PORT_GP_CFG_1(0,  6, fn, sfx, SH_PFC_PIN_CFG_IO_VOLTAGE | SH_PFC_PIN_CFG_PULL_UP),      \
-       PORT_GP_CFG_1(0,  7, fn, sfx, SH_PFC_PIN_CFG_IO_VOLTAGE | SH_PFC_PIN_CFG_PULL_UP),      \
-       PORT_GP_CFG_1(0,  8, fn, sfx, SH_PFC_PIN_CFG_IO_VOLTAGE | SH_PFC_PIN_CFG_PULL_UP),      \
-       PORT_GP_CFG_1(0,  9, fn, sfx, SH_PFC_PIN_CFG_IO_VOLTAGE | SH_PFC_PIN_CFG_PULL_UP),      \
-       PORT_GP_CFG_1(0, 10, fn, sfx, SH_PFC_PIN_CFG_IO_VOLTAGE | SH_PFC_PIN_CFG_PULL_UP),      \
+       PORT_GP_CFG_1(0,  5, fn, sfx, SH_PFC_PIN_CFG_IO_VOLTAGE_18_33 | SH_PFC_PIN_CFG_PULL_UP),        \
+       PORT_GP_CFG_1(0,  6, fn, sfx, SH_PFC_PIN_CFG_IO_VOLTAGE_18_33 | SH_PFC_PIN_CFG_PULL_UP),        \
+       PORT_GP_CFG_1(0,  7, fn, sfx, SH_PFC_PIN_CFG_IO_VOLTAGE_18_33 | SH_PFC_PIN_CFG_PULL_UP),        \
+       PORT_GP_CFG_1(0,  8, fn, sfx, SH_PFC_PIN_CFG_IO_VOLTAGE_18_33 | SH_PFC_PIN_CFG_PULL_UP),        \
+       PORT_GP_CFG_1(0,  9, fn, sfx, SH_PFC_PIN_CFG_IO_VOLTAGE_18_33 | SH_PFC_PIN_CFG_PULL_UP),        \
+       PORT_GP_CFG_1(0, 10, fn, sfx, SH_PFC_PIN_CFG_IO_VOLTAGE_18_33 | SH_PFC_PIN_CFG_PULL_UP),        \
        PORT_GP_CFG_1(0, 11, fn, sfx, SH_PFC_PIN_CFG_PULL_UP),          \
        PORT_GP_CFG_1(0, 12, fn, sfx, SH_PFC_PIN_CFG_PULL_UP),          \
-       PORT_GP_CFG_1(0, 13, fn, sfx, SH_PFC_PIN_CFG_IO_VOLTAGE | SH_PFC_PIN_CFG_PULL_UP),      \
-       PORT_GP_CFG_1(0, 14, fn, sfx, SH_PFC_PIN_CFG_IO_VOLTAGE | SH_PFC_PIN_CFG_PULL_UP),      \
-       PORT_GP_CFG_1(0, 15, fn, sfx, SH_PFC_PIN_CFG_IO_VOLTAGE | SH_PFC_PIN_CFG_PULL_UP),      \
-       PORT_GP_CFG_1(0, 16, fn, sfx, SH_PFC_PIN_CFG_IO_VOLTAGE | SH_PFC_PIN_CFG_PULL_UP),      \
-       PORT_GP_CFG_1(0, 17, fn, sfx, SH_PFC_PIN_CFG_IO_VOLTAGE | SH_PFC_PIN_CFG_PULL_UP),      \
-       PORT_GP_CFG_1(0, 18, fn, sfx, SH_PFC_PIN_CFG_IO_VOLTAGE | SH_PFC_PIN_CFG_PULL_UP),      \
-       PORT_GP_CFG_1(0, 19, fn, sfx, SH_PFC_PIN_CFG_IO_VOLTAGE | SH_PFC_PIN_CFG_PULL_UP),      \
-       PORT_GP_CFG_1(0, 20, fn, sfx, SH_PFC_PIN_CFG_IO_VOLTAGE | SH_PFC_PIN_CFG_PULL_UP),      \
-       PORT_GP_CFG_1(0, 21, fn, sfx, SH_PFC_PIN_CFG_IO_VOLTAGE | SH_PFC_PIN_CFG_PULL_UP),      \
-       PORT_GP_CFG_1(0, 22, fn, sfx, SH_PFC_PIN_CFG_IO_VOLTAGE | SH_PFC_PIN_CFG_PULL_UP),      \
+       PORT_GP_CFG_1(0, 13, fn, sfx, SH_PFC_PIN_CFG_IO_VOLTAGE_18_33 | SH_PFC_PIN_CFG_PULL_UP),        \
+       PORT_GP_CFG_1(0, 14, fn, sfx, SH_PFC_PIN_CFG_IO_VOLTAGE_18_33 | SH_PFC_PIN_CFG_PULL_UP),        \
+       PORT_GP_CFG_1(0, 15, fn, sfx, SH_PFC_PIN_CFG_IO_VOLTAGE_18_33 | SH_PFC_PIN_CFG_PULL_UP),        \
+       PORT_GP_CFG_1(0, 16, fn, sfx, SH_PFC_PIN_CFG_IO_VOLTAGE_18_33 | SH_PFC_PIN_CFG_PULL_UP),        \
+       PORT_GP_CFG_1(0, 17, fn, sfx, SH_PFC_PIN_CFG_IO_VOLTAGE_18_33 | SH_PFC_PIN_CFG_PULL_UP),        \
+       PORT_GP_CFG_1(0, 18, fn, sfx, SH_PFC_PIN_CFG_IO_VOLTAGE_18_33 | SH_PFC_PIN_CFG_PULL_UP),        \
+       PORT_GP_CFG_1(0, 19, fn, sfx, SH_PFC_PIN_CFG_IO_VOLTAGE_18_33 | SH_PFC_PIN_CFG_PULL_UP),        \
+       PORT_GP_CFG_1(0, 20, fn, sfx, SH_PFC_PIN_CFG_IO_VOLTAGE_18_33 | SH_PFC_PIN_CFG_PULL_UP),        \
+       PORT_GP_CFG_1(0, 21, fn, sfx, SH_PFC_PIN_CFG_IO_VOLTAGE_18_33 | SH_PFC_PIN_CFG_PULL_UP),        \
+       PORT_GP_CFG_1(0, 22, fn, sfx, SH_PFC_PIN_CFG_IO_VOLTAGE_18_33 | SH_PFC_PIN_CFG_PULL_UP),        \
        PORT_GP_CFG_23(1, fn, sfx, SH_PFC_PIN_CFG_PULL_UP),             \
        PORT_GP_CFG_32(2, fn, sfx, SH_PFC_PIN_CFG_PULL_UP),             \
        PORT_GP_CFG_17(3, fn, sfx, SH_PFC_PIN_CFG_PULL_UP),             \
        PORT_GP_CFG_1(3, 28, fn, sfx, SH_PFC_PIN_CFG_PULL_UP),          \
        PORT_GP_CFG_1(3, 29, fn, sfx, SH_PFC_PIN_CFG_PULL_UP),          \
        PORT_GP_CFG_14(4, fn, sfx, SH_PFC_PIN_CFG_PULL_UP),             \
-       PORT_GP_CFG_1(4, 14, fn, sfx, SH_PFC_PIN_CFG_IO_VOLTAGE | SH_PFC_PIN_CFG_PULL_UP),      \
-       PORT_GP_CFG_1(4, 15, fn, sfx, SH_PFC_PIN_CFG_IO_VOLTAGE | SH_PFC_PIN_CFG_PULL_UP),      \
-       PORT_GP_CFG_1(4, 16, fn, sfx, SH_PFC_PIN_CFG_IO_VOLTAGE | SH_PFC_PIN_CFG_PULL_UP),      \
-       PORT_GP_CFG_1(4, 17, fn, sfx, SH_PFC_PIN_CFG_IO_VOLTAGE | SH_PFC_PIN_CFG_PULL_UP),      \
-       PORT_GP_CFG_1(4, 18, fn, sfx, SH_PFC_PIN_CFG_IO_VOLTAGE | SH_PFC_PIN_CFG_PULL_UP),      \
-       PORT_GP_CFG_1(4, 19, fn, sfx, SH_PFC_PIN_CFG_IO_VOLTAGE | SH_PFC_PIN_CFG_PULL_UP),      \
+       PORT_GP_CFG_1(4, 14, fn, sfx, SH_PFC_PIN_CFG_IO_VOLTAGE_18_33 | SH_PFC_PIN_CFG_PULL_UP),        \
+       PORT_GP_CFG_1(4, 15, fn, sfx, SH_PFC_PIN_CFG_IO_VOLTAGE_18_33 | SH_PFC_PIN_CFG_PULL_UP),        \
+       PORT_GP_CFG_1(4, 16, fn, sfx, SH_PFC_PIN_CFG_IO_VOLTAGE_18_33 | SH_PFC_PIN_CFG_PULL_UP),        \
+       PORT_GP_CFG_1(4, 17, fn, sfx, SH_PFC_PIN_CFG_IO_VOLTAGE_18_33 | SH_PFC_PIN_CFG_PULL_UP),        \
+       PORT_GP_CFG_1(4, 18, fn, sfx, SH_PFC_PIN_CFG_IO_VOLTAGE_18_33 | SH_PFC_PIN_CFG_PULL_UP),        \
+       PORT_GP_CFG_1(4, 19, fn, sfx, SH_PFC_PIN_CFG_IO_VOLTAGE_18_33 | SH_PFC_PIN_CFG_PULL_UP),        \
        PORT_GP_CFG_1(4, 20, fn, sfx, SH_PFC_PIN_CFG_PULL_UP),          \
        PORT_GP_CFG_1(4, 21, fn, sfx, SH_PFC_PIN_CFG_PULL_UP),          \
        PORT_GP_CFG_1(4, 22, fn, sfx, SH_PFC_PIN_CFG_PULL_UP),          \
@@ -3252,7 +3252,7 @@ static const struct pinmux_cfg_reg pinmux_config_regs[] = {
                /* SEL_SSI0 [2] */
                FN_SEL_SSI0_0, FN_SEL_SSI0_1, 0, 0, ))
        },
-       { },
+       { /* sentinel */ }
 };
 
 static int r8a77470_pin_to_pocctrl(unsigned int pin, u32 *pocctrl)
index 35bdb9af8160756680a2a0b1844c6319845bc198..c52761d80f7bed164a64873af11871bd61688342 100644 (file)
@@ -2832,7 +2832,7 @@ static const struct pinmux_cfg_reg pinmux_config_regs[] = {
                FN_SEL_I2C1_A,          FN_SEL_I2C1_B,
                ))
        },
-       { },
+       { /* sentinel */ }
 };
 
 static const struct pinmux_bias_reg pinmux_bias_regs[] = {
@@ -3040,7 +3040,7 @@ static const struct pinmux_bias_reg pinmux_bias_regs[] = {
                [30] = SH_PFC_PIN_NONE,
                [31] = SH_PFC_PIN_NONE,
        } },
-       { /* sentinel */ },
+       { /* sentinel */ }
 };
 
 static const struct sh_pfc_soc_operations r8a7778_pfc_ops = {
index fcc8ea48881fb961cdf9480f0486745fce350dfe..1172a359384d5799d9541bcd125c4fe79561370a 100644 (file)
 #include "sh_pfc.h"
 
 #define CPU_ALL_GP(fn, sfx)                                            \
-       PORT_GP_32(0, fn, sfx),                                         \
-       PORT_GP_32(1, fn, sfx),                                         \
-       PORT_GP_32(2, fn, sfx),                                         \
-       PORT_GP_32(3, fn, sfx),                                         \
-       PORT_GP_32(4, fn, sfx),                                         \
-       PORT_GP_32(5, fn, sfx),                                         \
-       PORT_GP_9(6, fn, sfx)
+       PORT_GP_CFG_32(0, fn, sfx, SH_PFC_PIN_CFG_PULL_UP),             \
+       PORT_GP_CFG_32(1, fn, sfx, SH_PFC_PIN_CFG_PULL_UP),             \
+       PORT_GP_CFG_1(2, 0, fn, sfx, SH_PFC_PIN_CFG_PULL_UP),           \
+       PORT_GP_1(2, 1, fn, sfx),                                       \
+       PORT_GP_1(2, 2, fn, sfx),                                       \
+       PORT_GP_1(2, 3, fn, sfx),                                       \
+       PORT_GP_1(2, 4, fn, sfx),                                       \
+       PORT_GP_1(2, 5, fn, sfx),                                       \
+       PORT_GP_1(2, 6, fn, sfx),                                       \
+       PORT_GP_1(2, 7, fn, sfx),                                       \
+       PORT_GP_1(2, 8, fn, sfx),                                       \
+       PORT_GP_1(2, 9, fn, sfx),                                       \
+       PORT_GP_1(2, 10, fn, sfx),                                      \
+       PORT_GP_1(2, 11, fn, sfx),                                      \
+       PORT_GP_1(2, 12, fn, sfx),                                      \
+       PORT_GP_1(2, 13, fn, sfx),                                      \
+       PORT_GP_1(2, 14, fn, sfx),                                      \
+       PORT_GP_1(2, 15, fn, sfx),                                      \
+       PORT_GP_1(2, 16, fn, sfx),                                      \
+       PORT_GP_1(2, 17, fn, sfx),                                      \
+       PORT_GP_1(2, 18, fn, sfx),                                      \
+       PORT_GP_1(2, 19, fn, sfx),                                      \
+       PORT_GP_1(2, 20, fn, sfx),                                      \
+       PORT_GP_1(2, 21, fn, sfx),                                      \
+       PORT_GP_1(2, 22, fn, sfx),                                      \
+       PORT_GP_1(2, 23, fn, sfx),                                      \
+       PORT_GP_1(2, 24, fn, sfx),                                      \
+       PORT_GP_1(2, 25, fn, sfx),                                      \
+       PORT_GP_1(2, 26, fn, sfx),                                      \
+       PORT_GP_1(2, 27, fn, sfx),                                      \
+       PORT_GP_1(2, 28, fn, sfx),                                      \
+       PORT_GP_1(2, 29, fn, sfx),                                      \
+       PORT_GP_CFG_1(2, 30, fn, sfx, SH_PFC_PIN_CFG_PULL_UP),          \
+       PORT_GP_CFG_1(2, 31, fn, sfx, SH_PFC_PIN_CFG_PULL_UP),          \
+       PORT_GP_CFG_25(3, fn, sfx, SH_PFC_PIN_CFG_PULL_UP),             \
+       PORT_GP_1(3, 25, fn, sfx),                                      \
+       PORT_GP_1(3, 26, fn, sfx),                                      \
+       PORT_GP_1(3, 27, fn, sfx),                                      \
+       PORT_GP_CFG_1(3, 28, fn, sfx, SH_PFC_PIN_CFG_PULL_UP),          \
+       PORT_GP_CFG_1(3, 29, fn, sfx, SH_PFC_PIN_CFG_PULL_UP),          \
+       PORT_GP_CFG_1(3, 30, fn, sfx, SH_PFC_PIN_CFG_PULL_UP),          \
+       PORT_GP_CFG_1(3, 31, fn, sfx, SH_PFC_PIN_CFG_PULL_UP),          \
+       PORT_GP_CFG_32(4, fn, sfx, SH_PFC_PIN_CFG_PULL_UP),             \
+       PORT_GP_CFG_32(5, fn, sfx, SH_PFC_PIN_CFG_PULL_UP),             \
+       PORT_GP_CFG_9(6, fn, sfx, SH_PFC_PIN_CFG_PULL_UP)
+
+#define CPU_ALL_NOGP(fn)                                               \
+       PIN_NOGP_CFG(ASEBRK_N_ACK, "ASEBRK#/ACK", fn, SH_PFC_PIN_CFG_PULL_UP), \
+       PIN_NOGP_CFG(D0, "D0", fn, SH_PFC_PIN_CFG_PULL_UP),             \
+       PIN_NOGP_CFG(D1, "D1", fn, SH_PFC_PIN_CFG_PULL_UP),             \
+       PIN_NOGP_CFG(D2, "D2", fn, SH_PFC_PIN_CFG_PULL_UP),             \
+       PIN_NOGP_CFG(D3, "D3", fn, SH_PFC_PIN_CFG_PULL_UP),             \
+       PIN_NOGP_CFG(D4, "D4", fn, SH_PFC_PIN_CFG_PULL_UP),             \
+       PIN_NOGP_CFG(D5, "D5", fn, SH_PFC_PIN_CFG_PULL_UP),             \
+       PIN_NOGP_CFG(D6, "D6", fn, SH_PFC_PIN_CFG_PULL_UP),             \
+       PIN_NOGP_CFG(D7, "D7", fn, SH_PFC_PIN_CFG_PULL_UP),             \
+       PIN_NOGP_CFG(D8, "D8", fn, SH_PFC_PIN_CFG_PULL_UP),             \
+       PIN_NOGP_CFG(D9, "D9", fn, SH_PFC_PIN_CFG_PULL_UP),             \
+       PIN_NOGP_CFG(D10, "D10", fn, SH_PFC_PIN_CFG_PULL_UP),           \
+       PIN_NOGP_CFG(D11, "D11", fn, SH_PFC_PIN_CFG_PULL_UP),           \
+       PIN_NOGP_CFG(D12, "D12", fn, SH_PFC_PIN_CFG_PULL_UP),           \
+       PIN_NOGP_CFG(D13, "D13", fn, SH_PFC_PIN_CFG_PULL_UP),           \
+       PIN_NOGP_CFG(D14, "D14", fn, SH_PFC_PIN_CFG_PULL_UP),           \
+       PIN_NOGP_CFG(D15, "D15", fn, SH_PFC_PIN_CFG_PULL_UP),           \
+       PIN_NOGP_CFG(PRESETOUT_N, "PRESETOUT#", fn, SH_PFC_PIN_CFG_PULL_UP), \
+       PIN_NOGP_CFG(TCK, "TCK", fn, SH_PFC_PIN_CFG_PULL_UP),           \
+       PIN_NOGP_CFG(TDI, "TDI", fn, SH_PFC_PIN_CFG_PULL_UP),           \
+       PIN_NOGP_CFG(TDO, "TDO", fn, SH_PFC_PIN_CFG_PULL_UP),           \
+       PIN_NOGP_CFG(TMS, "TMS", fn, SH_PFC_PIN_CFG_PULL_UP),           \
+       PIN_NOGP_CFG(TRST_N, "TRST#", fn, SH_PFC_PIN_CFG_PULL_UP)
 
 enum {
        PINMUX_RESERVED = 0,
@@ -1390,8 +1453,17 @@ static const u16 pinmux_data[] = {
        PINMUX_IPSR_MSEL(IP12_17_15, SCK4_B, SEL_SCIF4_1),
 };
 
+/*
+ * Pins not associated with a GPIO port.
+ */
+enum {
+       GP_ASSIGN_LAST(),
+       NOGP_ALL(),
+};
+
 static const struct sh_pfc_pin pinmux_pins[] = {
        PINMUX_GPIO_GP_ALL(),
+       PINMUX_NOGP_ALL(),
 };
 
 /* - DU0 -------------------------------------------------------------------- */
@@ -1962,6 +2034,67 @@ static const unsigned int mmc1_ctrl_pins[] = {
 static const unsigned int mmc1_ctrl_mux[] = {
        MMC1_CMD_MARK, MMC1_CLK_MARK,
 };
+/* - PWM -------------------------------------------------------------------- */
+static const unsigned int pwm0_pins[] = {
+       RCAR_GP_PIN(1, 3),
+};
+static const unsigned int pwm0_mux[] = {
+       PWM0_MARK,
+};
+static const unsigned int pwm0_b_pins[] = {
+       RCAR_GP_PIN(0, 12),
+};
+static const unsigned int pwm0_b_mux[] = {
+       PWM0_B_MARK,
+};
+static const unsigned int pwm0_c_pins[] = {
+       RCAR_GP_PIN(4, 5),
+};
+static const unsigned int pwm0_c_mux[] = {
+       PWM0_C_MARK,
+};
+static const unsigned int pwm0_d_pins[] = {
+       RCAR_GP_PIN(4, 18),
+};
+static const unsigned int pwm0_d_mux[] = {
+       PWM0_D_MARK,
+};
+static const unsigned int pwm1_pins[] = {
+       RCAR_GP_PIN(4, 28),
+};
+static const unsigned int pwm1_mux[] = {
+       PWM1_MARK,
+};
+static const unsigned int pwm2_pins[] = {
+       RCAR_GP_PIN(3, 25),
+};
+static const unsigned int pwm2_mux[] = {
+       PWM2_MARK,
+};
+static const unsigned int pwm3_pins[] = {
+       RCAR_GP_PIN(3, 26),
+};
+static const unsigned int pwm3_mux[] = {
+       PWM3_MARK,
+};
+static const unsigned int pwm4_pins[] = {
+       RCAR_GP_PIN(3, 27),
+};
+static const unsigned int pwm4_mux[] = {
+       PWM4_MARK,
+};
+static const unsigned int pwm5_pins[] = {
+       RCAR_GP_PIN(4, 17),
+};
+static const unsigned int pwm5_mux[] = {
+       PWM5_MARK,
+};
+static const unsigned int pwm6_pins[] = {
+       RCAR_GP_PIN(1, 2),
+};
+static const unsigned int pwm6_mux[] = {
+       PWM6_MARK,
+};
 /* - SCIF0 ------------------------------------------------------------------ */
 static const unsigned int scif0_data_pins[] = {
        /* RXD, TXD */
@@ -2699,6 +2832,16 @@ static const struct sh_pfc_pin_group pinmux_groups[] = {
        BUS_DATA_PIN_GROUP(mmc1_data, 4),
        BUS_DATA_PIN_GROUP(mmc1_data, 8),
        SH_PFC_PIN_GROUP(mmc1_ctrl),
+       SH_PFC_PIN_GROUP(pwm0),
+       SH_PFC_PIN_GROUP(pwm0_b),
+       SH_PFC_PIN_GROUP(pwm0_c),
+       SH_PFC_PIN_GROUP(pwm0_d),
+       SH_PFC_PIN_GROUP(pwm1),
+       SH_PFC_PIN_GROUP(pwm2),
+       SH_PFC_PIN_GROUP(pwm3),
+       SH_PFC_PIN_GROUP(pwm4),
+       SH_PFC_PIN_GROUP(pwm5),
+       SH_PFC_PIN_GROUP(pwm6),
        SH_PFC_PIN_GROUP(scif0_data),
        SH_PFC_PIN_GROUP(scif0_clk),
        SH_PFC_PIN_GROUP(scif0_ctrl),
@@ -2912,6 +3055,37 @@ static const char * const mmc1_groups[] = {
        "mmc1_ctrl",
 };
 
+static const char * const pwm0_groups[] = {
+       "pwm0",
+       "pwm0_b",
+       "pwm0_c",
+       "pwm0_d",
+};
+
+static const char * const pwm1_groups[] = {
+       "pwm1",
+};
+
+static const char * const pwm2_groups[] = {
+       "pwm2",
+};
+
+static const char * const pwm3_groups[] = {
+       "pwm3",
+};
+
+static const char * const pwm4_groups[] = {
+       "pwm4",
+};
+
+static const char * const pwm5_groups[] = {
+       "pwm5",
+};
+
+static const char * const pwm6_groups[] = {
+       "pwm6",
+};
+
 static const char * const scif0_groups[] = {
        "scif0_data",
        "scif0_clk",
@@ -3075,6 +3249,13 @@ static const struct sh_pfc_function pinmux_functions[] = {
        SH_PFC_FUNCTION(lbsc),
        SH_PFC_FUNCTION(mmc0),
        SH_PFC_FUNCTION(mmc1),
+       SH_PFC_FUNCTION(pwm0),
+       SH_PFC_FUNCTION(pwm1),
+       SH_PFC_FUNCTION(pwm2),
+       SH_PFC_FUNCTION(pwm3),
+       SH_PFC_FUNCTION(pwm4),
+       SH_PFC_FUNCTION(pwm5),
+       SH_PFC_FUNCTION(pwm6),
        SH_PFC_FUNCTION(scif0),
        SH_PFC_FUNCTION(scif1),
        SH_PFC_FUNCTION(scif2),
@@ -3919,11 +4100,259 @@ static const struct pinmux_cfg_reg pinmux_config_regs[] = {
            /* SEL_I2C1 [2] */
            FN_SEL_I2C1_0, FN_SEL_I2C1_1, FN_SEL_I2C1_2, FN_SEL_I2C1_3 ))
        },
-       { },
+       { /* sentinel */ }
+};
+
+static const struct pinmux_bias_reg pinmux_bias_regs[] = {
+       { PINMUX_BIAS_REG("PUPR0", 0xfffc0100, "N/A", 0) {
+               [ 0] = RCAR_GP_PIN(0,  2),      /* A0 */
+               [ 1] = RCAR_GP_PIN(5,  0),      /* A1 */
+               [ 2] = RCAR_GP_PIN(5,  1),      /* A2 */
+               [ 3] = RCAR_GP_PIN(5,  2),      /* A3 */
+               [ 4] = RCAR_GP_PIN(5,  3),      /* A4 */
+               [ 5] = RCAR_GP_PIN(5,  4),      /* A5 */
+               [ 6] = RCAR_GP_PIN(5,  5),      /* A6 */
+               [ 7] = RCAR_GP_PIN(5,  6),      /* A7 */
+               [ 8] = RCAR_GP_PIN(5,  7),      /* A8 */
+               [ 9] = RCAR_GP_PIN(5,  8),      /* A9 */
+               [10] = RCAR_GP_PIN(5,  9),      /* A10 */
+               [11] = RCAR_GP_PIN(5, 10),      /* A11 */
+               [12] = RCAR_GP_PIN(5, 11),      /* A12 */
+               [13] = RCAR_GP_PIN(5, 12),      /* A13 */
+               [14] = RCAR_GP_PIN(5, 13),      /* A14 */
+               [15] = RCAR_GP_PIN(5, 14),      /* A15 */
+               [16] = RCAR_GP_PIN(5, 15),      /* A16 */
+               [17] = RCAR_GP_PIN(0,  3),      /* A17 */
+               [18] = RCAR_GP_PIN(0,  4),      /* A18 */
+               [19] = RCAR_GP_PIN(0,  5),      /* A19 */
+               [20] = RCAR_GP_PIN(0,  6),      /* A20 */
+               [21] = RCAR_GP_PIN(0,  7),      /* A21 */
+               [22] = RCAR_GP_PIN(0,  8),      /* A22 */
+               [23] = RCAR_GP_PIN(0,  9),      /* A23 */
+               [24] = RCAR_GP_PIN(0, 10),      /* A24 */
+               [25] = RCAR_GP_PIN(0, 11),      /* A25 */
+               [26] = RCAR_GP_PIN(0, 15),      /* EX_CS0# */
+               [27] = RCAR_GP_PIN(0, 16),      /* EX_CS1# */
+               [28] = RCAR_GP_PIN(0, 17),      /* EX_CS2# */
+               [29] = RCAR_GP_PIN(0, 18),      /* EX_CS3# */
+               [30] = RCAR_GP_PIN(0, 19),      /* EX_CS4# */
+               [31] = RCAR_GP_PIN(0, 20),      /* EX_CS5# */
+       } },
+       { PINMUX_BIAS_REG("PUPR1", 0xfffc0104, "N/A", 0) {
+               [ 0] = PIN_PRESETOUT_N,         /* PRESETOUT# */
+               [ 1] = RCAR_GP_PIN(0, 21),      /* BS# */
+               [ 2] = RCAR_GP_PIN(0, 22),      /* RD/WR# */
+               [ 3] = RCAR_GP_PIN(5, 17),      /* WE0# */
+               [ 4] = RCAR_GP_PIN(5, 18),      /* WE1# */
+               [ 5] = RCAR_GP_PIN(5, 19),      /* EX_WAIT0 */
+               [ 6] = RCAR_GP_PIN(0,  0),      /* AVS1 */
+               [ 7] = RCAR_GP_PIN(0,  1),      /* AVS2 */
+               [ 8] = SH_PFC_PIN_NONE,
+               [ 9] = SH_PFC_PIN_NONE,
+               [10] = PIN_TRST_N,              /* TRST# */
+               [11] = PIN_TCK,                 /* TCK */
+               [12] = PIN_TMS,                 /* TMS */
+               [13] = PIN_TDI,                 /* TDI */
+               [14] = PIN_TDO,                 /* TDO */
+               [15] = PIN_ASEBRK_N_ACK,        /* ASEBRK#/ACK */
+               [16] = PIN_D0,                  /* D0 */
+               [17] = PIN_D1,                  /* D1 */
+               [18] = PIN_D2,                  /* D2 */
+               [19] = PIN_D3,                  /* D3 */
+               [20] = PIN_D4,                  /* D4 */
+               [21] = PIN_D5,                  /* D5 */
+               [22] = PIN_D6,                  /* D6 */
+               [23] = PIN_D7,                  /* D7 */
+               [24] = PIN_D8,                  /* D8 */
+               [25] = PIN_D9,                  /* D9 */
+               [26] = PIN_D10,                 /* D10 */
+               [27] = PIN_D11,                 /* D11 */
+               [28] = PIN_D12,                 /* D12 */
+               [29] = PIN_D13,                 /* D13 */
+               [30] = PIN_D14,                 /* D14 */
+               [31] = PIN_D15,                 /* D15 */
+       } },
+       { PINMUX_BIAS_REG("PUPR2", 0xfffc0108, "N/A", 0) {
+               [ 0] = RCAR_GP_PIN(0, 23),      /* DU0_DR0 */
+               [ 1] = RCAR_GP_PIN(0, 24),      /* DU0_DR1 */
+               [ 2] = RCAR_GP_PIN(5, 23),      /* DU0_DR2 */
+               [ 3] = RCAR_GP_PIN(5, 24),      /* DU0_DR3 */
+               [ 4] = RCAR_GP_PIN(5, 25),      /* DU0_DR4 */
+               [ 5] = RCAR_GP_PIN(5, 26),      /* DU0_DR5 */
+               [ 6] = RCAR_GP_PIN(5, 27),      /* DU0_DR6 */
+               [ 7] = RCAR_GP_PIN(5, 28),      /* DU0_DR7 */
+               [ 8] = RCAR_GP_PIN(0, 25),      /* DU0_DG0 */
+               [ 9] = RCAR_GP_PIN(0, 26),      /* DU0_DG1 */
+               [10] = RCAR_GP_PIN(5, 29),      /* DU0_DG2 */
+               [11] = RCAR_GP_PIN(5, 30),      /* DU0_DG3 */
+               [12] = RCAR_GP_PIN(5, 31),      /* DU0_DG4 */
+               [13] = RCAR_GP_PIN(6,  0),      /* DU0_DG5 */
+               [14] = RCAR_GP_PIN(6,  1),      /* DU0_DG6 */
+               [15] = RCAR_GP_PIN(6,  2),      /* DU0_DG7 */
+               [16] = RCAR_GP_PIN(0, 27),      /* DU0_DB0 */
+               [17] = RCAR_GP_PIN(0, 28),      /* DU0_DB1 */
+               [18] = RCAR_GP_PIN(6,  3),      /* DU0_DB2 */
+               [19] = RCAR_GP_PIN(6,  4),      /* DU0_DB3 */
+               [20] = RCAR_GP_PIN(6,  5),      /* DU0_DB4 */
+               [21] = RCAR_GP_PIN(6,  6),      /* DU0_DB5 */
+               [22] = RCAR_GP_PIN(6,  7),      /* DU0_DB6 */
+               [23] = RCAR_GP_PIN(6,  8),      /* DU0_DB7 */
+               [24] = RCAR_GP_PIN(0, 29),      /* DU0_DOTCLKIN */
+               [25] = RCAR_GP_PIN(5, 20),      /* DU0_DOTCLKOUT0 */
+               [26] = RCAR_GP_PIN(5, 21),      /* DU0_HSYNC */
+               [27] = RCAR_GP_PIN(5, 22),      /* DU0_VSYNC */
+               [28] = RCAR_GP_PIN(0, 31),      /* DU0_EXODDF */
+               [29] = RCAR_GP_PIN(1,  0),      /* DU0_DISP */
+               [30] = RCAR_GP_PIN(1,  1),      /* DU0_CDE */
+               [31] = RCAR_GP_PIN(0, 30),      /* DU0_DOTCLKOUT1 */
+       } },
+       { PINMUX_BIAS_REG("PUPR3", 0xfffc010c, "N/A", 0) {
+               [ 0] = RCAR_GP_PIN(1,  2),      /* DU1_DR0 */
+               [ 1] = RCAR_GP_PIN(1,  3),      /* DU1_DR1 */
+               [ 2] = RCAR_GP_PIN(1,  4),      /* DU1_DR2 */
+               [ 3] = RCAR_GP_PIN(1,  5),      /* DU1_DR3 */
+               [ 4] = RCAR_GP_PIN(1,  6),      /* DU1_DR4 */
+               [ 5] = RCAR_GP_PIN(1,  7),      /* DU1_DR5 */
+               [ 6] = RCAR_GP_PIN(1,  8),      /* DU1_DR6 */
+               [ 7] = RCAR_GP_PIN(1,  9),      /* DU1_DR7 */
+               [ 8] = RCAR_GP_PIN(1, 10),      /* DU1_DG0 */
+               [ 9] = RCAR_GP_PIN(1, 11),      /* DU1_DG1 */
+               [10] = RCAR_GP_PIN(1, 12),      /* DU1_DG2 */
+               [11] = RCAR_GP_PIN(1, 13),      /* DU1_DG3 */
+               [12] = RCAR_GP_PIN(1, 14),      /* DU1_DG4 */
+               [13] = RCAR_GP_PIN(1, 15),      /* DU1_DG5 */
+               [14] = RCAR_GP_PIN(1, 16),      /* DU1_DG6 */
+               [15] = RCAR_GP_PIN(1, 17),      /* DU1_DG7 */
+               [16] = RCAR_GP_PIN(1, 18),      /* DU1_DB0 */
+               [17] = RCAR_GP_PIN(1, 19),      /* DU1_DB1 */
+               [18] = RCAR_GP_PIN(1, 20),      /* DU1_DB2 */
+               [19] = RCAR_GP_PIN(1, 21),      /* DU1_DB3 */
+               [20] = RCAR_GP_PIN(1, 22),      /* DU1_DB4 */
+               [21] = RCAR_GP_PIN(1, 23),      /* DU1_DB5 */
+               [22] = RCAR_GP_PIN(1, 24),      /* DU1_DB6 */
+               [23] = RCAR_GP_PIN(1, 25),      /* DU1_DB7 */
+               [24] = RCAR_GP_PIN(1, 26),      /* DU1_DOTCLKIN */
+               [25] = RCAR_GP_PIN(1, 27),      /* DU1_DOTCLKOUT */
+               [26] = RCAR_GP_PIN(1, 28),      /* DU1_HSYNC */
+               [27] = RCAR_GP_PIN(1, 29),      /* DU1_VSYNC */
+               [28] = RCAR_GP_PIN(1, 30),      /* DU1_EXODDF */
+               [29] = RCAR_GP_PIN(1, 31),      /* DU1_DISP */
+               [30] = RCAR_GP_PIN(2,  0),      /* DU1_CDE */
+               [31] = SH_PFC_PIN_NONE,
+       } },
+       { PINMUX_BIAS_REG("PUPR4", 0xfffc0110, "N/A", 0) {
+               [ 0] = RCAR_GP_PIN(2, 30),      /* VI1_CLK */
+               [ 1] = SH_PFC_PIN_NONE,
+               [ 2] = SH_PFC_PIN_NONE,
+               [ 3] = RCAR_GP_PIN(2, 31),      /* VI1_HSYNC# */
+               [ 4] = RCAR_GP_PIN(3,  0),      /* VI1_VSYNC# */
+               [ 5] = RCAR_GP_PIN(3,  1),      /* VI1_DATA0 */
+               [ 6] = RCAR_GP_PIN(3,  2),      /* VI1_DATA1 */
+               [ 7] = RCAR_GP_PIN(3,  3),      /* VI1_DATA2 */
+               [ 8] = RCAR_GP_PIN(3,  4),      /* VI1_DATA3 */
+               [ 9] = RCAR_GP_PIN(3,  5),      /* VI1_DATA4 */
+               [10] = RCAR_GP_PIN(3,  6),      /* VI1_DATA5 */
+               [11] = RCAR_GP_PIN(3,  7),      /* VI1_DATA6 */
+               [12] = RCAR_GP_PIN(3,  8),      /* VI1_DATA7 */
+               [13] = RCAR_GP_PIN(3,  9),      /* VI1_G0 */
+               [14] = RCAR_GP_PIN(3, 10),      /* VI1_G1 */
+               [15] = RCAR_GP_PIN(3, 11),      /* VI1_G2 */
+               [16] = RCAR_GP_PIN(3, 12),      /* VI1_G3 */
+               [17] = RCAR_GP_PIN(3, 13),      /* VI1_G4 */
+               [18] = RCAR_GP_PIN(3, 14),      /* VI1_G5 */
+               [19] = RCAR_GP_PIN(3, 15),      /* VI1_G6 */
+               [20] = RCAR_GP_PIN(3, 16),      /* VI1_G7 */
+               [21] = SH_PFC_PIN_NONE,
+               [22] = SH_PFC_PIN_NONE,
+               [23] = SH_PFC_PIN_NONE,
+               [24] = SH_PFC_PIN_NONE,
+               [25] = SH_PFC_PIN_NONE,
+               [26] = SH_PFC_PIN_NONE,
+               [27] = SH_PFC_PIN_NONE,
+               [28] = SH_PFC_PIN_NONE,
+               [29] = SH_PFC_PIN_NONE,
+               [30] = SH_PFC_PIN_NONE,
+               [31] = SH_PFC_PIN_NONE,
+       } },
+       { PINMUX_BIAS_REG("PUPR5", 0xfffc0114, "N/A", 0) {
+               [ 0] = RCAR_GP_PIN(3, 30),      /* SSI_SCK0129 */
+               [ 1] = RCAR_GP_PIN(3, 31),      /* SSI_WS0129 */
+               [ 2] = RCAR_GP_PIN(4,  0),      /* SSI_SDATA0 */
+               [ 3] = RCAR_GP_PIN(4,  1),      /* SSI_SDATA1 */
+               [ 4] = RCAR_GP_PIN(4,  2),      /* SSI_SDATA2 */
+               [ 5] = RCAR_GP_PIN(4,  3),      /* SSI_SCK34 */
+               [ 6] = RCAR_GP_PIN(4,  4),      /* SSI_WS34 */
+               [ 7] = RCAR_GP_PIN(4,  5),      /* SSI_SDATA3 */
+               [ 8] = RCAR_GP_PIN(4,  6),      /* SSI_SDATA4 */
+               [ 9] = RCAR_GP_PIN(4,  7),      /* SSI_SCK5 */
+               [10] = RCAR_GP_PIN(4,  8),      /* SSI_WS5 */
+               [11] = RCAR_GP_PIN(4,  9),      /* SSI_SDATA5 */
+               [12] = RCAR_GP_PIN(4, 10),      /* SSI_SCK6 */
+               [13] = RCAR_GP_PIN(4, 11),      /* SSI_WS6 */
+               [14] = RCAR_GP_PIN(4, 12),      /* SSI_SDATA6 */
+               [15] = RCAR_GP_PIN(4, 13),      /* SSI_SCK78 */
+               [16] = RCAR_GP_PIN(4, 14),      /* SSI_WS78 */
+               [17] = RCAR_GP_PIN(4, 15),      /* SSI_SDATA7 */
+               [18] = RCAR_GP_PIN(4, 16),      /* SSI_SDATA8 */
+               [19] = SH_PFC_PIN_NONE,
+               [20] = RCAR_GP_PIN(3, 17),      /* SD0_CLK */
+               [21] = RCAR_GP_PIN(3, 18),      /* SD0_CMD */
+               [22] = RCAR_GP_PIN(3, 21),      /* SD0_DAT0 */
+               [23] = RCAR_GP_PIN(3, 22),      /* SD0_DAT1 */
+               [24] = RCAR_GP_PIN(3, 23),      /* SD0_DAT2 */
+               [25] = RCAR_GP_PIN(3, 24),      /* SD0_DAT3 */
+               [26] = RCAR_GP_PIN(3, 19),      /* SD0_CD */
+               [27] = RCAR_GP_PIN(3, 20),      /* SD0_WP */
+               [28] = RCAR_GP_PIN(3, 28),      /* AUDIO_CLKA */
+               [29] = RCAR_GP_PIN(3, 29),      /* AUDIO_CLKB */
+               [30] = SH_PFC_PIN_NONE,
+               [31] = SH_PFC_PIN_NONE,
+       } },
+       { PINMUX_BIAS_REG("PUPR6", 0xfffc0118, "N/A", 0) {
+               [ 0] = RCAR_GP_PIN(4, 26),      /* PENC0 */
+               [ 1] = RCAR_GP_PIN(4, 27),      /* PENC1 */
+               [ 2] = RCAR_GP_PIN(4, 28),      /* PENC2 */
+               [ 3] = SH_PFC_PIN_NONE,
+               [ 4] = SH_PFC_PIN_NONE,
+               [ 5] = RCAR_GP_PIN(4, 20),      /* HTX0 */
+               [ 6] = RCAR_GP_PIN(4, 21),      /* HRX0 */
+               [ 7] = RCAR_GP_PIN(4, 17),      /* HSCK0 */
+               [ 8] = RCAR_GP_PIN(4, 18),      /* HCTS0# */
+               [ 9] = RCAR_GP_PIN(4, 19),      /* HRTS0# */
+               [10] = RCAR_GP_PIN(4, 22),      /* HSPI_CLK0 */
+               [11] = RCAR_GP_PIN(4, 23),      /* HSPI_CS0# */
+               [12] = RCAR_GP_PIN(4, 24),      /* HSPI_TX0 */
+               [13] = RCAR_GP_PIN(4, 25),      /* HSPI_RX0 */
+               [14] = RCAR_GP_PIN(4, 29),      /* FMCLK */
+               [15] = RCAR_GP_PIN(4, 30),      /* BPFCLK */
+               [16] = RCAR_GP_PIN(4, 31),      /* FMIN */
+               [17] = RCAR_GP_PIN(0, 12),      /* CLKOUT */
+               [18] = RCAR_GP_PIN(0, 13),      /* CS0# */
+               [19] = RCAR_GP_PIN(0, 14),      /* CS1#/A26 */
+               [20] = RCAR_GP_PIN(5, 16),      /* RD# */
+               [21] = SH_PFC_PIN_NONE,
+               [22] = SH_PFC_PIN_NONE,
+               [23] = SH_PFC_PIN_NONE,
+               [24] = SH_PFC_PIN_NONE,
+               [25] = SH_PFC_PIN_NONE,
+               [26] = SH_PFC_PIN_NONE,
+               [27] = SH_PFC_PIN_NONE,
+               [28] = SH_PFC_PIN_NONE,
+               [29] = SH_PFC_PIN_NONE,
+               [30] = SH_PFC_PIN_NONE,
+               [31] = SH_PFC_PIN_NONE,
+       } },
+       { /* sentinel */ }
+};
+
+static const struct sh_pfc_soc_operations r8a7779_pfc_ops = {
+       .get_bias = rcar_pinmux_get_bias,
+       .set_bias = rcar_pinmux_set_bias,
 };
 
 const struct sh_pfc_soc_info r8a7779_pinmux_info = {
        .name = "r8a7779_pfc",
+       .ops  = &r8a7779_pfc_ops,
 
        .unlock_reg = 0xfffc0000, /* PMMR */
 
@@ -3937,6 +4366,7 @@ const struct sh_pfc_soc_info r8a7779_pinmux_info = {
        .nr_functions = ARRAY_SIZE(pinmux_functions),
 
        .cfg_regs = pinmux_config_regs,
+       .bias_regs = pinmux_bias_regs,
 
        .pinmux_data = pinmux_data,
        .pinmux_data_size = ARRAY_SIZE(pinmux_data),
index ee21d650991bcec39bb1adc39bace5b0f7fcd6a5..791e089d47dbca584bbadf0b6dfe7842b72bf4ab 100644 (file)
@@ -24,7 +24,7 @@
        PORT_GP_CFG_32(0, fn, sfx, SH_PFC_PIN_CFG_PULL_UP),             \
        PORT_GP_CFG_30(1, fn, sfx, SH_PFC_PIN_CFG_PULL_UP),             \
        PORT_GP_CFG_30(2, fn, sfx, SH_PFC_PIN_CFG_PULL_UP),             \
-       PORT_GP_CFG_32(3, fn, sfx, SH_PFC_PIN_CFG_IO_VOLTAGE | SH_PFC_PIN_CFG_PULL_UP), \
+       PORT_GP_CFG_32(3, fn, sfx, SH_PFC_PIN_CFG_IO_VOLTAGE_18_33 | SH_PFC_PIN_CFG_PULL_UP),   \
        PORT_GP_CFG_32(4, fn, sfx, SH_PFC_PIN_CFG_PULL_UP),             \
        PORT_GP_CFG_32(5, fn, sfx, SH_PFC_PIN_CFG_PULL_UP)
 
@@ -5824,7 +5824,7 @@ static const struct pinmux_cfg_reg pinmux_config_regs[] = {
                /* SEL_I2C1 [2] */
                FN_SEL_I2C1_0, FN_SEL_I2C1_1, FN_SEL_I2C1_2, 0, ))
        },
-       { },
+       { /* sentinel */ }
 };
 
 static int r8a7790_pin_to_pocctrl(unsigned int pin, u32 *pocctrl)
index d57458504117daa3cd6ba2ffc1583a7b559c47b9..d9e5ce0dfb5b3e2dc49b865f875925b7902f979f 100644 (file)
@@ -22,7 +22,7 @@
        PORT_GP_CFG_32(3, fn, sfx, SH_PFC_PIN_CFG_PULL_UP),             \
        PORT_GP_CFG_32(4, fn, sfx, SH_PFC_PIN_CFG_PULL_UP),             \
        PORT_GP_CFG_32(5, fn, sfx, SH_PFC_PIN_CFG_PULL_UP),             \
-       PORT_GP_CFG_24(6, fn, sfx, SH_PFC_PIN_CFG_IO_VOLTAGE | SH_PFC_PIN_CFG_PULL_UP), \
+       PORT_GP_CFG_24(6, fn, sfx, SH_PFC_PIN_CFG_IO_VOLTAGE_18_33 | SH_PFC_PIN_CFG_PULL_UP),   \
        PORT_GP_CFG_1(6, 24, fn, sfx, SH_PFC_PIN_CFG_PULL_UP),          \
        PORT_GP_CFG_1(6, 25, fn, sfx, SH_PFC_PIN_CFG_PULL_UP),          \
        PORT_GP_CFG_1(6, 26, fn, sfx, SH_PFC_PIN_CFG_PULL_UP),          \
@@ -6552,7 +6552,7 @@ static const struct pinmux_cfg_reg pinmux_config_regs[] = {
                FN_SEL_SSP_0, FN_SEL_SSP_1, FN_SEL_SSP_2, 0,
                /* RESERVED [6] */ ))
        },
-       { },
+       { /* sentinel */ }
 };
 
 static int r8a7791_pin_to_pocctrl(unsigned int pin, u32 *pocctrl)
@@ -6874,7 +6874,7 @@ static const struct pinmux_bias_reg pinmux_bias_regs[] = {
                [30] = SH_PFC_PIN_NONE,
                [31] = SH_PFC_PIN_NONE,
        } },
-       { /* sentinel */ },
+       { /* sentinel */ }
 };
 
 static const struct sh_pfc_soc_operations r8a7791_pfc_ops = {
index 808a85d62415399fe0eadf37e77f83c6ec07ba72..2c51c32b8e0904fc68dfe0b67559784d15f77472 100644 (file)
@@ -2625,7 +2625,7 @@ static const struct pinmux_cfg_reg pinmux_config_regs[] = {
                /* IP7_1_0 [2] */
                FN_PWM0, FN_TCLK1, FN_FSO_CFE_0, 0 ))
        },
-       { },
+       { /* sentinel */ }
 };
 
 static const struct pinmux_bias_reg pinmux_bias_regs[] = {
index 668643553a70a71aa6cde9bf40b5c6af7dff779d..e800fef91ddb1e5b3fd12214aba0d49ae94c8937 100644 (file)
        PORT_GP_1(5, 25, fn, sfx),                                      \
        PORT_GP_1(5, 26, fn, sfx),                                      \
        PORT_GP_1(5, 27, fn, sfx),                                      \
-       PORT_GP_CFG_1(6, 0, fn, sfx, SH_PFC_PIN_CFG_IO_VOLTAGE),        \
-       PORT_GP_CFG_1(6, 1, fn, sfx, SH_PFC_PIN_CFG_IO_VOLTAGE | SH_PFC_PIN_CFG_PULL_UP),       \
-       PORT_GP_CFG_1(6, 2, fn, sfx, SH_PFC_PIN_CFG_IO_VOLTAGE | SH_PFC_PIN_CFG_PULL_UP),       \
-       PORT_GP_CFG_1(6, 3, fn, sfx, SH_PFC_PIN_CFG_IO_VOLTAGE | SH_PFC_PIN_CFG_PULL_UP),       \
-       PORT_GP_CFG_1(6, 4, fn, sfx, SH_PFC_PIN_CFG_IO_VOLTAGE | SH_PFC_PIN_CFG_PULL_UP),       \
-       PORT_GP_CFG_1(6, 5, fn, sfx, SH_PFC_PIN_CFG_IO_VOLTAGE | SH_PFC_PIN_CFG_PULL_UP),       \
-       PORT_GP_CFG_1(6, 6, fn, sfx, SH_PFC_PIN_CFG_IO_VOLTAGE | SH_PFC_PIN_CFG_PULL_UP),       \
-       PORT_GP_CFG_1(6, 7, fn, sfx, SH_PFC_PIN_CFG_IO_VOLTAGE | SH_PFC_PIN_CFG_PULL_UP),       \
-       PORT_GP_CFG_1(6, 8, fn, sfx, SH_PFC_PIN_CFG_IO_VOLTAGE),        \
-       PORT_GP_CFG_1(6, 9, fn, sfx, SH_PFC_PIN_CFG_IO_VOLTAGE | SH_PFC_PIN_CFG_PULL_UP),       \
-       PORT_GP_CFG_1(6, 10, fn, sfx, SH_PFC_PIN_CFG_IO_VOLTAGE | SH_PFC_PIN_CFG_PULL_UP),      \
-       PORT_GP_CFG_1(6, 11, fn, sfx, SH_PFC_PIN_CFG_IO_VOLTAGE | SH_PFC_PIN_CFG_PULL_UP),      \
-       PORT_GP_CFG_1(6, 12, fn, sfx, SH_PFC_PIN_CFG_IO_VOLTAGE | SH_PFC_PIN_CFG_PULL_UP),      \
-       PORT_GP_CFG_1(6, 13, fn, sfx, SH_PFC_PIN_CFG_IO_VOLTAGE | SH_PFC_PIN_CFG_PULL_UP),      \
-       PORT_GP_CFG_1(6, 14, fn, sfx, SH_PFC_PIN_CFG_IO_VOLTAGE | SH_PFC_PIN_CFG_PULL_UP),      \
-       PORT_GP_CFG_1(6, 15, fn, sfx, SH_PFC_PIN_CFG_IO_VOLTAGE | SH_PFC_PIN_CFG_PULL_UP),      \
-       PORT_GP_CFG_1(6, 16, fn, sfx, SH_PFC_PIN_CFG_IO_VOLTAGE),       \
-       PORT_GP_CFG_1(6, 17, fn, sfx, SH_PFC_PIN_CFG_IO_VOLTAGE | SH_PFC_PIN_CFG_PULL_UP),      \
-       PORT_GP_CFG_1(6, 18, fn, sfx, SH_PFC_PIN_CFG_IO_VOLTAGE | SH_PFC_PIN_CFG_PULL_UP),      \
-       PORT_GP_CFG_1(6, 19, fn, sfx, SH_PFC_PIN_CFG_IO_VOLTAGE | SH_PFC_PIN_CFG_PULL_UP),      \
-       PORT_GP_CFG_1(6, 20, fn, sfx, SH_PFC_PIN_CFG_IO_VOLTAGE | SH_PFC_PIN_CFG_PULL_UP),      \
-       PORT_GP_CFG_1(6, 21, fn, sfx, SH_PFC_PIN_CFG_IO_VOLTAGE | SH_PFC_PIN_CFG_PULL_UP),      \
-       PORT_GP_CFG_1(6, 22, fn, sfx, SH_PFC_PIN_CFG_IO_VOLTAGE | SH_PFC_PIN_CFG_PULL_UP),      \
-       PORT_GP_CFG_1(6, 23, fn, sfx, SH_PFC_PIN_CFG_IO_VOLTAGE | SH_PFC_PIN_CFG_PULL_UP),      \
+       PORT_GP_CFG_1(6, 0, fn, sfx, SH_PFC_PIN_CFG_IO_VOLTAGE_18_33),  \
+       PORT_GP_CFG_1(6, 1, fn, sfx, SH_PFC_PIN_CFG_IO_VOLTAGE_18_33 | SH_PFC_PIN_CFG_PULL_UP), \
+       PORT_GP_CFG_1(6, 2, fn, sfx, SH_PFC_PIN_CFG_IO_VOLTAGE_18_33 | SH_PFC_PIN_CFG_PULL_UP), \
+       PORT_GP_CFG_1(6, 3, fn, sfx, SH_PFC_PIN_CFG_IO_VOLTAGE_18_33 | SH_PFC_PIN_CFG_PULL_UP), \
+       PORT_GP_CFG_1(6, 4, fn, sfx, SH_PFC_PIN_CFG_IO_VOLTAGE_18_33 | SH_PFC_PIN_CFG_PULL_UP), \
+       PORT_GP_CFG_1(6, 5, fn, sfx, SH_PFC_PIN_CFG_IO_VOLTAGE_18_33 | SH_PFC_PIN_CFG_PULL_UP), \
+       PORT_GP_CFG_1(6, 6, fn, sfx, SH_PFC_PIN_CFG_IO_VOLTAGE_18_33 | SH_PFC_PIN_CFG_PULL_UP), \
+       PORT_GP_CFG_1(6, 7, fn, sfx, SH_PFC_PIN_CFG_IO_VOLTAGE_18_33 | SH_PFC_PIN_CFG_PULL_UP), \
+       PORT_GP_CFG_1(6, 8, fn, sfx, SH_PFC_PIN_CFG_IO_VOLTAGE_18_33),  \
+       PORT_GP_CFG_1(6, 9, fn, sfx, SH_PFC_PIN_CFG_IO_VOLTAGE_18_33 | SH_PFC_PIN_CFG_PULL_UP), \
+       PORT_GP_CFG_1(6, 10, fn, sfx, SH_PFC_PIN_CFG_IO_VOLTAGE_18_33 | SH_PFC_PIN_CFG_PULL_UP),        \
+       PORT_GP_CFG_1(6, 11, fn, sfx, SH_PFC_PIN_CFG_IO_VOLTAGE_18_33 | SH_PFC_PIN_CFG_PULL_UP),        \
+       PORT_GP_CFG_1(6, 12, fn, sfx, SH_PFC_PIN_CFG_IO_VOLTAGE_18_33 | SH_PFC_PIN_CFG_PULL_UP),        \
+       PORT_GP_CFG_1(6, 13, fn, sfx, SH_PFC_PIN_CFG_IO_VOLTAGE_18_33 | SH_PFC_PIN_CFG_PULL_UP),        \
+       PORT_GP_CFG_1(6, 14, fn, sfx, SH_PFC_PIN_CFG_IO_VOLTAGE_18_33 | SH_PFC_PIN_CFG_PULL_UP),        \
+       PORT_GP_CFG_1(6, 15, fn, sfx, SH_PFC_PIN_CFG_IO_VOLTAGE_18_33 | SH_PFC_PIN_CFG_PULL_UP),        \
+       PORT_GP_CFG_1(6, 16, fn, sfx, SH_PFC_PIN_CFG_IO_VOLTAGE_18_33), \
+       PORT_GP_CFG_1(6, 17, fn, sfx, SH_PFC_PIN_CFG_IO_VOLTAGE_18_33 | SH_PFC_PIN_CFG_PULL_UP),        \
+       PORT_GP_CFG_1(6, 18, fn, sfx, SH_PFC_PIN_CFG_IO_VOLTAGE_18_33 | SH_PFC_PIN_CFG_PULL_UP),        \
+       PORT_GP_CFG_1(6, 19, fn, sfx, SH_PFC_PIN_CFG_IO_VOLTAGE_18_33 | SH_PFC_PIN_CFG_PULL_UP),        \
+       PORT_GP_CFG_1(6, 20, fn, sfx, SH_PFC_PIN_CFG_IO_VOLTAGE_18_33 | SH_PFC_PIN_CFG_PULL_UP),        \
+       PORT_GP_CFG_1(6, 21, fn, sfx, SH_PFC_PIN_CFG_IO_VOLTAGE_18_33 | SH_PFC_PIN_CFG_PULL_UP),        \
+       PORT_GP_CFG_1(6, 22, fn, sfx, SH_PFC_PIN_CFG_IO_VOLTAGE_18_33 | SH_PFC_PIN_CFG_PULL_UP),        \
+       PORT_GP_CFG_1(6, 23, fn, sfx, SH_PFC_PIN_CFG_IO_VOLTAGE_18_33 | SH_PFC_PIN_CFG_PULL_UP),        \
        PORT_GP_CFG_1(6, 24, fn, sfx, SH_PFC_PIN_CFG_PULL_UP),          \
        PORT_GP_CFG_1(6, 25, fn, sfx, SH_PFC_PIN_CFG_PULL_UP)
 
@@ -5512,7 +5512,7 @@ static const struct pinmux_cfg_reg pinmux_config_regs[] = {
                FN_SEL_SSI9_0, FN_SEL_SSI9_1,
                /* RESERVED [12] */ ))
        },
-       { },
+       { /* sentinel */ }
 };
 
 static int r8a7794_pin_to_pocctrl(unsigned int pin, u32 *pocctrl)
diff --git a/drivers/pinctrl/renesas/pfc-r8a77950.c b/drivers/pinctrl/renesas/pfc-r8a77950.c
deleted file mode 100644 (file)
index cc66c6d..0000000
+++ /dev/null
@@ -1,5947 +0,0 @@
-// SPDX-License-Identifier: GPL-2.0
-/*
- * R8A77950 processor support - PFC hardware block.
- *
- * Copyright (C) 2015-2017  Renesas Electronics Corporation
- */
-
-#include <linux/errno.h>
-#include <linux/kernel.h>
-
-#include "sh_pfc.h"
-
-#define CFG_FLAGS (SH_PFC_PIN_CFG_DRIVE_STRENGTH | SH_PFC_PIN_CFG_PULL_UP_DOWN)
-
-#define CPU_ALL_GP(fn, sfx)                                            \
-       PORT_GP_CFG_16(0, fn, sfx, CFG_FLAGS),  \
-       PORT_GP_CFG_28(1, fn, sfx, CFG_FLAGS),  \
-       PORT_GP_CFG_15(2, fn, sfx, CFG_FLAGS),  \
-       PORT_GP_CFG_12(3, fn, sfx, CFG_FLAGS | SH_PFC_PIN_CFG_IO_VOLTAGE),      \
-       PORT_GP_CFG_1(3, 12, fn, sfx, CFG_FLAGS),       \
-       PORT_GP_CFG_1(3, 13, fn, sfx, CFG_FLAGS),       \
-       PORT_GP_CFG_1(3, 14, fn, sfx, CFG_FLAGS),       \
-       PORT_GP_CFG_1(3, 15, fn, sfx, CFG_FLAGS),       \
-       PORT_GP_CFG_18(4, fn, sfx, CFG_FLAGS | SH_PFC_PIN_CFG_IO_VOLTAGE),      \
-       PORT_GP_CFG_26(5, fn, sfx, CFG_FLAGS),  \
-       PORT_GP_CFG_32(6, fn, sfx, CFG_FLAGS),  \
-       PORT_GP_CFG_4(7, fn, sfx, CFG_FLAGS)
-
-#define CPU_ALL_NOGP(fn)                                               \
-       PIN_NOGP_CFG(ASEBRK, "ASEBRK", fn, CFG_FLAGS),                  \
-       PIN_NOGP_CFG(AVB_MDIO, "AVB_MDIO", fn, CFG_FLAGS),              \
-       PIN_NOGP_CFG(AVB_RD0, "AVB_RD0", fn, CFG_FLAGS),                \
-       PIN_NOGP_CFG(AVB_RD1, "AVB_RD1", fn, CFG_FLAGS),                \
-       PIN_NOGP_CFG(AVB_RD2, "AVB_RD2", fn, CFG_FLAGS),                \
-       PIN_NOGP_CFG(AVB_RD3, "AVB_RD3", fn, CFG_FLAGS),                \
-       PIN_NOGP_CFG(AVB_RXC, "AVB_RXC", fn, CFG_FLAGS),                \
-       PIN_NOGP_CFG(AVB_RX_CTL, "AVB_RX_CTL", fn, CFG_FLAGS),          \
-       PIN_NOGP_CFG(AVB_TD0, "AVB_TD0", fn, CFG_FLAGS),                \
-       PIN_NOGP_CFG(AVB_TD1, "AVB_TD1", fn, CFG_FLAGS),                \
-       PIN_NOGP_CFG(AVB_TD2, "AVB_TD2", fn, CFG_FLAGS),                \
-       PIN_NOGP_CFG(AVB_TD3, "AVB_TD3", fn, CFG_FLAGS),                \
-       PIN_NOGP_CFG(AVB_TXC, "AVB_TXC", fn, CFG_FLAGS),                \
-       PIN_NOGP_CFG(AVB_TXCREFCLK, "AVB_TXCREFCLK", fn, CFG_FLAGS),    \
-       PIN_NOGP_CFG(AVB_TX_CTL, "AVB_TX_CTL", fn, CFG_FLAGS),          \
-       PIN_NOGP_CFG(CLKOUT, "CLKOUT", fn, CFG_FLAGS),                  \
-       PIN_NOGP_CFG(DU_DOTCLKIN0, "DU_DOTCLKIN0", fn, CFG_FLAGS),      \
-       PIN_NOGP_CFG(DU_DOTCLKIN1, "DU_DOTCLKIN1", fn, CFG_FLAGS),      \
-       PIN_NOGP_CFG(DU_DOTCLKIN2, "DU_DOTCLKIN2", fn, CFG_FLAGS),      \
-       PIN_NOGP_CFG(DU_DOTCLKIN3, "DU_DOTCLKIN3", fn, CFG_FLAGS),      \
-       PIN_NOGP_CFG(EXTALR, "EXTALR", fn, SH_PFC_PIN_CFG_PULL_UP_DOWN),\
-       PIN_NOGP_CFG(FSCLKST_N, "FSCLKST#", fn, CFG_FLAGS),             \
-       PIN_NOGP_CFG(MLB_REF, "MLB_REF", fn, CFG_FLAGS),                \
-       PIN_NOGP_CFG(PRESETOUT_N, "PRESETOUT#", fn, CFG_FLAGS),         \
-       PIN_NOGP_CFG(QSPI0_IO2, "QSPI0_IO2", fn, CFG_FLAGS),            \
-       PIN_NOGP_CFG(QSPI0_IO3, "QSPI0_IO3", fn, CFG_FLAGS),            \
-       PIN_NOGP_CFG(QSPI0_MISO_IO1, "QSPI0_MISO_IO1", fn, CFG_FLAGS),  \
-       PIN_NOGP_CFG(QSPI0_MOSI_IO0, "QSPI0_MOSI_IO0", fn, CFG_FLAGS),  \
-       PIN_NOGP_CFG(QSPI0_SPCLK, "QSPI0_SPCLK", fn, CFG_FLAGS),        \
-       PIN_NOGP_CFG(QSPI0_SSL, "QSPI0_SSL", fn, CFG_FLAGS),            \
-       PIN_NOGP_CFG(QSPI1_IO2, "QSPI1_IO2", fn, CFG_FLAGS),            \
-       PIN_NOGP_CFG(QSPI1_IO3, "QSPI1_IO3", fn, CFG_FLAGS),            \
-       PIN_NOGP_CFG(QSPI1_MISO_IO1, "QSPI1_MISO_IO1", fn, CFG_FLAGS),  \
-       PIN_NOGP_CFG(QSPI1_MOSI_IO0, "QSPI1_MOSI_IO0", fn, CFG_FLAGS),  \
-       PIN_NOGP_CFG(QSPI1_SPCLK, "QSPI1_SPCLK", fn, CFG_FLAGS),        \
-       PIN_NOGP_CFG(QSPI1_SSL, "QSPI1_SSL", fn, CFG_FLAGS),            \
-       PIN_NOGP_CFG(RPC_INT_N, "RPC_INT#", fn, CFG_FLAGS),             \
-       PIN_NOGP_CFG(RPC_RESET_N, "RPC_RESET#", fn, CFG_FLAGS),         \
-       PIN_NOGP_CFG(RPC_WP_N, "RPC_WP#", fn, CFG_FLAGS),               \
-       PIN_NOGP_CFG(TCK, "TCK", fn, SH_PFC_PIN_CFG_PULL_UP_DOWN),      \
-       PIN_NOGP_CFG(TDI, "TDI", fn, SH_PFC_PIN_CFG_PULL_UP_DOWN),      \
-       PIN_NOGP_CFG(TDO, "TDO", fn, SH_PFC_PIN_CFG_DRIVE_STRENGTH),    \
-       PIN_NOGP_CFG(TMS, "TMS", fn, CFG_FLAGS),                        \
-       PIN_NOGP_CFG(TRST_N, "TRST#", fn, SH_PFC_PIN_CFG_PULL_UP_DOWN)
-
-/*
- * F_() : just information
- * FM() : macro for FN_xxx / xxx_MARK
- */
-
-/* GPSR0 */
-#define GPSR0_15       F_(D15,                 IP7_11_8)
-#define GPSR0_14       F_(D14,                 IP7_7_4)
-#define GPSR0_13       F_(D13,                 IP7_3_0)
-#define GPSR0_12       F_(D12,                 IP6_31_28)
-#define GPSR0_11       F_(D11,                 IP6_27_24)
-#define GPSR0_10       F_(D10,                 IP6_23_20)
-#define GPSR0_9                F_(D9,                  IP6_19_16)
-#define GPSR0_8                F_(D8,                  IP6_15_12)
-#define GPSR0_7                F_(D7,                  IP6_11_8)
-#define GPSR0_6                F_(D6,                  IP6_7_4)
-#define GPSR0_5                F_(D5,                  IP6_3_0)
-#define GPSR0_4                F_(D4,                  IP5_31_28)
-#define GPSR0_3                F_(D3,                  IP5_27_24)
-#define GPSR0_2                F_(D2,                  IP5_23_20)
-#define GPSR0_1                F_(D1,                  IP5_19_16)
-#define GPSR0_0                F_(D0,                  IP5_15_12)
-
-/* GPSR1 */
-#define GPSR1_27       F_(EX_WAIT0_A,          IP5_11_8)
-#define GPSR1_26       F_(WE1_N,               IP5_7_4)
-#define GPSR1_25       F_(WE0_N,               IP5_3_0)
-#define GPSR1_24       F_(RD_WR_N,             IP4_31_28)
-#define GPSR1_23       F_(RD_N,                IP4_27_24)
-#define GPSR1_22       F_(BS_N,                IP4_23_20)
-#define GPSR1_21       F_(CS1_N_A26,           IP4_19_16)
-#define GPSR1_20       F_(CS0_N,               IP4_15_12)
-#define GPSR1_19       F_(A19,                 IP4_11_8)
-#define GPSR1_18       F_(A18,                 IP4_7_4)
-#define GPSR1_17       F_(A17,                 IP4_3_0)
-#define GPSR1_16       F_(A16,                 IP3_31_28)
-#define GPSR1_15       F_(A15,                 IP3_27_24)
-#define GPSR1_14       F_(A14,                 IP3_23_20)
-#define GPSR1_13       F_(A13,                 IP3_19_16)
-#define GPSR1_12       F_(A12,                 IP3_15_12)
-#define GPSR1_11       F_(A11,                 IP3_11_8)
-#define GPSR1_10       F_(A10,                 IP3_7_4)
-#define GPSR1_9                F_(A9,                  IP3_3_0)
-#define GPSR1_8                F_(A8,                  IP2_31_28)
-#define GPSR1_7                F_(A7,                  IP2_27_24)
-#define GPSR1_6                F_(A6,                  IP2_23_20)
-#define GPSR1_5                F_(A5,                  IP2_19_16)
-#define GPSR1_4                F_(A4,                  IP2_15_12)
-#define GPSR1_3                F_(A3,                  IP2_11_8)
-#define GPSR1_2                F_(A2,                  IP2_7_4)
-#define GPSR1_1                F_(A1,                  IP2_3_0)
-#define GPSR1_0                F_(A0,                  IP1_31_28)
-
-/* GPSR2 */
-#define GPSR2_14       F_(AVB_AVTP_CAPTURE_A,  IP0_23_20)
-#define GPSR2_13       F_(AVB_AVTP_MATCH_A,    IP0_19_16)
-#define GPSR2_12       F_(AVB_LINK,            IP0_15_12)
-#define GPSR2_11       F_(AVB_PHY_INT,         IP0_11_8)
-#define GPSR2_10       F_(AVB_MAGIC,           IP0_7_4)
-#define GPSR2_9                F_(AVB_MDC,             IP0_3_0)
-#define GPSR2_8                F_(PWM2_A,              IP1_27_24)
-#define GPSR2_7                F_(PWM1_A,              IP1_23_20)
-#define GPSR2_6                F_(PWM0,                IP1_19_16)
-#define GPSR2_5                F_(IRQ5,                IP1_15_12)
-#define GPSR2_4                F_(IRQ4,                IP1_11_8)
-#define GPSR2_3                F_(IRQ3,                IP1_7_4)
-#define GPSR2_2                F_(IRQ2,                IP1_3_0)
-#define GPSR2_1                F_(IRQ1,                IP0_31_28)
-#define GPSR2_0                F_(IRQ0,                IP0_27_24)
-
-/* GPSR3 */
-#define GPSR3_15       F_(SD1_WP,              IP10_23_20)
-#define GPSR3_14       F_(SD1_CD,              IP10_19_16)
-#define GPSR3_13       F_(SD0_WP,              IP10_15_12)
-#define GPSR3_12       F_(SD0_CD,              IP10_11_8)
-#define GPSR3_11       F_(SD1_DAT3,            IP8_31_28)
-#define GPSR3_10       F_(SD1_DAT2,            IP8_27_24)
-#define GPSR3_9                F_(SD1_DAT1,            IP8_23_20)
-#define GPSR3_8                F_(SD1_DAT0,            IP8_19_16)
-#define GPSR3_7                F_(SD1_CMD,             IP8_15_12)
-#define GPSR3_6                F_(SD1_CLK,             IP8_11_8)
-#define GPSR3_5                F_(SD0_DAT3,            IP8_7_4)
-#define GPSR3_4                F_(SD0_DAT2,            IP8_3_0)
-#define GPSR3_3                F_(SD0_DAT1,            IP7_31_28)
-#define GPSR3_2                F_(SD0_DAT0,            IP7_27_24)
-#define GPSR3_1                F_(SD0_CMD,             IP7_23_20)
-#define GPSR3_0                F_(SD0_CLK,             IP7_19_16)
-
-/* GPSR4 */
-#define GPSR4_17       FM(SD3_DS)
-#define GPSR4_16       F_(SD3_DAT7,            IP10_7_4)
-#define GPSR4_15       F_(SD3_DAT6,            IP10_3_0)
-#define GPSR4_14       F_(SD3_DAT5,            IP9_31_28)
-#define GPSR4_13       F_(SD3_DAT4,            IP9_27_24)
-#define GPSR4_12       FM(SD3_DAT3)
-#define GPSR4_11       FM(SD3_DAT2)
-#define GPSR4_10       FM(SD3_DAT1)
-#define GPSR4_9                FM(SD3_DAT0)
-#define GPSR4_8                FM(SD3_CMD)
-#define GPSR4_7                FM(SD3_CLK)
-#define GPSR4_6                F_(SD2_DS,              IP9_23_20)
-#define GPSR4_5                F_(SD2_DAT3,            IP9_19_16)
-#define GPSR4_4                F_(SD2_DAT2,            IP9_15_12)
-#define GPSR4_3                F_(SD2_DAT1,            IP9_11_8)
-#define GPSR4_2                F_(SD2_DAT0,            IP9_7_4)
-#define GPSR4_1                FM(SD2_CMD)
-#define GPSR4_0                F_(SD2_CLK,             IP9_3_0)
-
-/* GPSR5 */
-#define GPSR5_25       F_(MLB_DAT,             IP13_19_16)
-#define GPSR5_24       F_(MLB_SIG,             IP13_15_12)
-#define GPSR5_23       F_(MLB_CLK,             IP13_11_8)
-#define GPSR5_22       FM(MSIOF0_RXD)
-#define GPSR5_21       F_(MSIOF0_SS2,          IP13_7_4)
-#define GPSR5_20       FM(MSIOF0_TXD)
-#define GPSR5_19       F_(MSIOF0_SS1,          IP13_3_0)
-#define GPSR5_18       F_(MSIOF0_SYNC,         IP12_31_28)
-#define GPSR5_17       FM(MSIOF0_SCK)
-#define GPSR5_16       F_(HRTS0_N,             IP12_27_24)
-#define GPSR5_15       F_(HCTS0_N,             IP12_23_20)
-#define GPSR5_14       F_(HTX0,                IP12_19_16)
-#define GPSR5_13       F_(HRX0,                IP12_15_12)
-#define GPSR5_12       F_(HSCK0,               IP12_11_8)
-#define GPSR5_11       F_(RX2_A,               IP12_7_4)
-#define GPSR5_10       F_(TX2_A,               IP12_3_0)
-#define GPSR5_9                F_(SCK2,                IP11_31_28)
-#define GPSR5_8                F_(RTS1_N,              IP11_27_24)
-#define GPSR5_7                F_(CTS1_N,              IP11_23_20)
-#define GPSR5_6                F_(TX1_A,               IP11_19_16)
-#define GPSR5_5                F_(RX1_A,               IP11_15_12)
-#define GPSR5_4                F_(RTS0_N,              IP11_11_8)
-#define GPSR5_3                F_(CTS0_N,              IP11_7_4)
-#define GPSR5_2                F_(TX0,                 IP11_3_0)
-#define GPSR5_1                F_(RX0,                 IP10_31_28)
-#define GPSR5_0                F_(SCK0,                IP10_27_24)
-
-/* GPSR6 */
-#define GPSR6_31       F_(USB31_OVC,           IP17_7_4)
-#define GPSR6_30       F_(USB31_PWEN,          IP17_3_0)
-#define GPSR6_29       F_(USB30_OVC,           IP16_31_28)
-#define GPSR6_28       F_(USB30_PWEN,          IP16_27_24)
-#define GPSR6_27       F_(USB1_OVC,            IP16_23_20)
-#define GPSR6_26       F_(USB1_PWEN,           IP16_19_16)
-#define GPSR6_25       F_(USB0_OVC,            IP16_15_12)
-#define GPSR6_24       F_(USB0_PWEN,           IP16_11_8)
-#define GPSR6_23       F_(AUDIO_CLKB_B,        IP16_7_4)
-#define GPSR6_22       F_(AUDIO_CLKA_A,        IP16_3_0)
-#define GPSR6_21       F_(SSI_SDATA9_A,        IP15_31_28)
-#define GPSR6_20       F_(SSI_SDATA8,          IP15_27_24)
-#define GPSR6_19       F_(SSI_SDATA7,          IP15_23_20)
-#define GPSR6_18       F_(SSI_WS78,            IP15_19_16)
-#define GPSR6_17       F_(SSI_SCK78,           IP15_15_12)
-#define GPSR6_16       F_(SSI_SDATA6,          IP15_11_8)
-#define GPSR6_15       F_(SSI_WS6,             IP15_7_4)
-#define GPSR6_14       F_(SSI_SCK6,            IP15_3_0)
-#define GPSR6_13       FM(SSI_SDATA5)
-#define GPSR6_12       FM(SSI_WS5)
-#define GPSR6_11       FM(SSI_SCK5)
-#define GPSR6_10       F_(SSI_SDATA4,          IP14_31_28)
-#define GPSR6_9                F_(SSI_WS4,             IP14_27_24)
-#define GPSR6_8                F_(SSI_SCK4,            IP14_23_20)
-#define GPSR6_7                F_(SSI_SDATA3,          IP14_19_16)
-#define GPSR6_6                F_(SSI_WS349,           IP14_15_12)
-#define GPSR6_5                F_(SSI_SCK349,          IP14_11_8)
-#define GPSR6_4                F_(SSI_SDATA2_A,        IP14_7_4)
-#define GPSR6_3                F_(SSI_SDATA1_A,        IP14_3_0)
-#define GPSR6_2                F_(SSI_SDATA0,          IP13_31_28)
-#define GPSR6_1                F_(SSI_WS01239,         IP13_27_24)
-#define GPSR6_0                F_(SSI_SCK01239,        IP13_23_20)
-
-/* GPSR7 */
-#define GPSR7_3                FM(GP7_03)
-#define GPSR7_2                FM(GP7_02)
-#define GPSR7_1                FM(AVS2)
-#define GPSR7_0                FM(AVS1)
-
-
-/* IPSRx */            /* 0 */                 /* 1 */         /* 2 */                 /* 3 */                         /* 4 */         /* 5 */         /* 6 */                 /* 7 */         /* 8 */                 /* 9 */         /* A */         /* B */         /* C - F */
-#define IP0_3_0                FM(AVB_MDC)             F_(0, 0)        FM(MSIOF2_SS2_C)        F_(0, 0)                        F_(0, 0)        F_(0, 0)        F_(0, 0)                F_(0, 0)        F_(0, 0)                F_(0, 0)        F_(0, 0)        F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
-#define IP0_7_4                FM(AVB_MAGIC)           F_(0, 0)        FM(MSIOF2_SS1_C)        FM(SCK4_A)                      F_(0, 0)        F_(0, 0)        F_(0, 0)                F_(0, 0)        F_(0, 0)                F_(0, 0)        F_(0, 0)        F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
-#define IP0_11_8       FM(AVB_PHY_INT)         F_(0, 0)        FM(MSIOF2_SYNC_C)       FM(RX4_A)                       F_(0, 0)        F_(0, 0)        F_(0, 0)                F_(0, 0)        F_(0, 0)                F_(0, 0)        F_(0, 0)        F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
-#define IP0_15_12      FM(AVB_LINK)            F_(0, 0)        FM(MSIOF2_SCK_C)        FM(TX4_A)                       F_(0, 0)        F_(0, 0)        F_(0, 0)                F_(0, 0)        F_(0, 0)                F_(0, 0)        F_(0, 0)        F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
-#define IP0_19_16      FM(AVB_AVTP_MATCH_A)    F_(0, 0)        FM(MSIOF2_RXD_C)        FM(CTS4_N_A)                    F_(0, 0)        F_(0, 0)        F_(0, 0)                F_(0, 0)        F_(0, 0)                F_(0, 0)        F_(0, 0)        F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
-#define IP0_23_20      FM(AVB_AVTP_CAPTURE_A)  F_(0, 0)        FM(MSIOF2_TXD_C)        FM(RTS4_N_A)                    F_(0, 0)        F_(0, 0)        F_(0, 0)                F_(0, 0)        F_(0, 0)                F_(0, 0)        F_(0, 0)        F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
-#define IP0_27_24      FM(IRQ0)                FM(QPOLB)       F_(0, 0)                FM(DU_CDE)                      FM(VI4_DATA0_B) FM(CAN0_TX_B)   FM(CANFD0_TX_B)         F_(0, 0)        F_(0, 0)                F_(0, 0)        F_(0, 0)        F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
-#define IP0_31_28      FM(IRQ1)                FM(QPOLA)       F_(0, 0)                FM(DU_DISP)                     FM(VI4_DATA1_B) FM(CAN0_RX_B)   FM(CANFD0_RX_B)         F_(0, 0)        F_(0, 0)                F_(0, 0)        F_(0, 0)        F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
-#define IP1_3_0                FM(IRQ2)                FM(QCPV_QDE)    F_(0, 0)                FM(DU_EXODDF_DU_ODDF_DISP_CDE)  FM(VI4_DATA2_B) F_(0, 0)        F_(0, 0)                F_(0, 0)        F_(0, 0)                FM(PWM3_B)      F_(0, 0)        F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
-#define IP1_7_4                FM(IRQ3)                FM(QSTVB_QVE)   FM(A25)                 FM(DU_DOTCLKOUT1)               FM(VI4_DATA3_B) F_(0, 0)        F_(0, 0)                F_(0, 0)        F_(0, 0)                FM(PWM4_B)      F_(0, 0)        F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
-#define IP1_11_8       FM(IRQ4)                FM(QSTH_QHS)    FM(A24)                 FM(DU_EXHSYNC_DU_HSYNC)         FM(VI4_DATA4_B) F_(0, 0)        F_(0, 0)                F_(0, 0)        F_(0, 0)                FM(PWM5_B)      F_(0, 0)        F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
-#define IP1_15_12      FM(IRQ5)                FM(QSTB_QHE)    FM(A23)                 FM(DU_EXVSYNC_DU_VSYNC)         FM(VI4_DATA5_B) F_(0, 0)        F_(0, 0)                F_(0, 0)        F_(0, 0)                FM(PWM6_B)      F_(0, 0)        F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
-#define IP1_19_16      FM(PWM0)                FM(AVB_AVTP_PPS)FM(A22)                 F_(0, 0)                        FM(VI4_DATA6_B) F_(0, 0)        F_(0, 0)                F_(0, 0)        F_(0, 0)                FM(IECLK_B)     F_(0, 0)        F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
-#define IP1_23_20      FM(PWM1_A)              F_(0, 0)        FM(A21)                 FM(HRX3_D)                      FM(VI4_DATA7_B) F_(0, 0)        F_(0, 0)                F_(0, 0)        F_(0, 0)                FM(IERX_B)      F_(0, 0)        F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
-#define IP1_27_24      FM(PWM2_A)              F_(0, 0)        FM(A20)                 FM(HTX3_D)                      F_(0, 0)        F_(0, 0)        F_(0, 0)                F_(0, 0)        F_(0, 0)                FM(IETX_B)      F_(0, 0)        F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
-#define IP1_31_28      FM(A0)                  FM(LCDOUT16)    FM(MSIOF3_SYNC_B)       F_(0, 0)                        FM(VI4_DATA8)   F_(0, 0)        FM(DU_DB0)              F_(0, 0)        F_(0, 0)                FM(PWM3_A)      F_(0, 0)        F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
-#define IP2_3_0                FM(A1)                  FM(LCDOUT17)    FM(MSIOF3_TXD_B)        F_(0, 0)                        FM(VI4_DATA9)   F_(0, 0)        FM(DU_DB1)              F_(0, 0)        F_(0, 0)                FM(PWM4_A)      F_(0, 0)        F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
-#define IP2_7_4                FM(A2)                  FM(LCDOUT18)    FM(MSIOF3_SCK_B)        F_(0, 0)                        FM(VI4_DATA10)  F_(0, 0)        FM(DU_DB2)              F_(0, 0)        F_(0, 0)                FM(PWM5_A)      F_(0, 0)        F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
-#define IP2_11_8       FM(A3)                  FM(LCDOUT19)    FM(MSIOF3_RXD_B)        F_(0, 0)                        FM(VI4_DATA11)  F_(0, 0)        FM(DU_DB3)              F_(0, 0)        F_(0, 0)                FM(PWM6_A)      F_(0, 0)        F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
-
-/* IPSRx */            /* 0 */                 /* 1 */         /* 2 */                 /* 3 */                         /* 4 */         /* 5 */         /* 6 */                 /* 7 */         /* 8 */                 /* 9 */         /* A */         /* B */         /* C - F */
-#define IP2_15_12      FM(A4)                  FM(LCDOUT20)    FM(MSIOF3_SS1_B)        F_(0, 0)                        FM(VI4_DATA12)  FM(VI5_DATA12)  FM(DU_DB4)              F_(0, 0)        F_(0, 0)                F_(0, 0)        F_(0, 0)        F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
-#define IP2_19_16      FM(A5)                  FM(LCDOUT21)    FM(MSIOF3_SS2_B)        FM(SCK4_B)                      FM(VI4_DATA13)  FM(VI5_DATA13)  FM(DU_DB5)              F_(0, 0)        F_(0, 0)                F_(0, 0)        F_(0, 0)        F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
-#define IP2_23_20      FM(A6)                  FM(LCDOUT22)    FM(MSIOF2_SS1_A)        FM(RX4_B)                       FM(VI4_DATA14)  FM(VI5_DATA14)  FM(DU_DB6)              F_(0, 0)        F_(0, 0)                F_(0, 0)        F_(0, 0)        F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
-#define IP2_27_24      FM(A7)                  FM(LCDOUT23)    FM(MSIOF2_SS2_A)        FM(TX4_B)                       FM(VI4_DATA15)  FM(VI5_DATA15)  FM(DU_DB7)              F_(0, 0)        F_(0, 0)                F_(0, 0)        F_(0, 0)        F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
-#define IP2_31_28      FM(A8)                  FM(RX3_B)       FM(MSIOF2_SYNC_A)       FM(HRX4_B)                      F_(0, 0)        F_(0, 0)        F_(0, 0)                FM(SDA6_A)      FM(AVB_AVTP_MATCH_B)    FM(PWM1_B)      F_(0, 0)        F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
-#define IP3_3_0                FM(A9)                  F_(0, 0)        FM(MSIOF2_SCK_A)        FM(CTS4_N_B)                    F_(0, 0)        FM(VI5_VSYNC_N) F_(0, 0)                F_(0, 0)        F_(0, 0)                F_(0, 0)        F_(0, 0)        F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
-#define IP3_7_4                FM(A10)                 F_(0, 0)        FM(MSIOF2_RXD_A)        FM(RTS4_N_B)                    F_(0, 0)        FM(VI5_HSYNC_N) F_(0, 0)                F_(0, 0)        F_(0, 0)                F_(0, 0)        F_(0, 0)        F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
-#define IP3_11_8       FM(A11)                 FM(TX3_B)       FM(MSIOF2_TXD_A)        FM(HTX4_B)                      FM(HSCK4)       FM(VI5_FIELD)   F_(0, 0)                FM(SCL6_A)      FM(AVB_AVTP_CAPTURE_B)  FM(PWM2_B)      F_(0, 0)        F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
-#define IP3_15_12      FM(A12)                 FM(LCDOUT12)    FM(MSIOF3_SCK_C)        F_(0, 0)                        FM(HRX4_A)      FM(VI5_DATA8)   FM(DU_DG4)              F_(0, 0)        F_(0, 0)                F_(0, 0)        F_(0, 0)        F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
-#define IP3_19_16      FM(A13)                 FM(LCDOUT13)    FM(MSIOF3_SYNC_C)       F_(0, 0)                        FM(HTX4_A)      FM(VI5_DATA9)   FM(DU_DG5)              F_(0, 0)        F_(0, 0)                F_(0, 0)        F_(0, 0)        F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
-#define IP3_23_20      FM(A14)                 FM(LCDOUT14)    FM(MSIOF3_RXD_C)        F_(0, 0)                        FM(HCTS4_N)     FM(VI5_DATA10)  FM(DU_DG6)              F_(0, 0)        F_(0, 0)                F_(0, 0)        F_(0, 0)        F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
-#define IP3_27_24      FM(A15)                 FM(LCDOUT15)    FM(MSIOF3_TXD_C)        F_(0, 0)                        FM(HRTS4_N)     FM(VI5_DATA11)  FM(DU_DG7)              F_(0, 0)        F_(0, 0)                F_(0, 0)        F_(0, 0)        F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
-#define IP3_31_28      FM(A16)                 FM(LCDOUT8)     F_(0, 0)                F_(0, 0)                        FM(VI4_FIELD)   F_(0, 0)        FM(DU_DG0)              F_(0, 0)        F_(0, 0)                F_(0, 0)        F_(0, 0)        F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
-#define IP4_3_0                FM(A17)                 FM(LCDOUT9)     F_(0, 0)                F_(0, 0)                        FM(VI4_VSYNC_N) F_(0, 0)        FM(DU_DG1)              F_(0, 0)        F_(0, 0)                F_(0, 0)        F_(0, 0)        F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
-#define IP4_7_4                FM(A18)                 FM(LCDOUT10)    F_(0, 0)                F_(0, 0)                        FM(VI4_HSYNC_N) F_(0, 0)        FM(DU_DG2)              F_(0, 0)        F_(0, 0)                F_(0, 0)        F_(0, 0)        F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
-#define IP4_11_8       FM(A19)                 FM(LCDOUT11)    F_(0, 0)                F_(0, 0)                        FM(VI4_CLKENB)  F_(0, 0)        FM(DU_DG3)              F_(0, 0)        F_(0, 0)                F_(0, 0)        F_(0, 0)        F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
-#define IP4_15_12      FM(CS0_N)               F_(0, 0)        F_(0, 0)                F_(0, 0)                        F_(0, 0)        FM(VI5_CLKENB)  F_(0, 0)                F_(0, 0)        F_(0, 0)                F_(0, 0)        F_(0, 0)        F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
-#define IP4_19_16      FM(CS1_N_A26)           F_(0, 0)        F_(0, 0)                F_(0, 0)                        F_(0, 0)        FM(VI5_CLK)     F_(0, 0)                FM(EX_WAIT0_B)  F_(0, 0)                F_(0, 0)        F_(0, 0)        F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
-#define IP4_23_20      FM(BS_N)                FM(QSTVA_QVS)   FM(MSIOF3_SCK_D)        FM(SCK3)                        FM(HSCK3)       F_(0, 0)        F_(0, 0)                F_(0, 0)        FM(CAN1_TX)             FM(CANFD1_TX)   FM(IETX_A)      F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
-#define IP4_27_24      FM(RD_N)                F_(0, 0)        FM(MSIOF3_SYNC_D)       FM(RX3_A)                       FM(HRX3_A)      F_(0, 0)        F_(0, 0)                F_(0, 0)        FM(CAN0_TX_A)           FM(CANFD0_TX_A) F_(0, 0)        F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
-#define IP4_31_28      FM(RD_WR_N)             F_(0, 0)        FM(MSIOF3_RXD_D)        FM(TX3_A)                       FM(HTX3_A)      F_(0, 0)        F_(0, 0)                F_(0, 0)        FM(CAN0_RX_A)           FM(CANFD0_RX_A) F_(0, 0)        F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
-#define IP5_3_0                FM(WE0_N)               F_(0, 0)        FM(MSIOF3_TXD_D)        FM(CTS3_N)                      FM(HCTS3_N)     F_(0, 0)        F_(0, 0)                FM(SCL6_B)      FM(CAN_CLK)             F_(0, 0)        FM(IECLK_A)     F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
-#define IP5_7_4                FM(WE1_N)               F_(0, 0)        FM(MSIOF3_SS1_D)        FM(RTS3_N)                      FM(HRTS3_N)     F_(0, 0)        F_(0, 0)                FM(SDA6_B)      FM(CAN1_RX)             FM(CANFD1_RX)   FM(IERX_A)      F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
-#define IP5_11_8       FM(EX_WAIT0_A)          FM(QCLK)        F_(0, 0)                F_(0, 0)                        FM(VI4_CLK)     F_(0, 0)        FM(DU_DOTCLKOUT0)       F_(0, 0)        F_(0, 0)                F_(0, 0)        F_(0, 0)        F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
-#define IP5_15_12      FM(D0)                  FM(MSIOF2_SS1_B)FM(MSIOF3_SCK_A)        F_(0, 0)                        FM(VI4_DATA16)  FM(VI5_DATA0)   F_(0, 0)                F_(0, 0)        F_(0, 0)                F_(0, 0)        F_(0, 0)        F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
-#define IP5_19_16      FM(D1)                  FM(MSIOF2_SS2_B)FM(MSIOF3_SYNC_A)       F_(0, 0)                        FM(VI4_DATA17)  FM(VI5_DATA1)   F_(0, 0)                F_(0, 0)        F_(0, 0)                F_(0, 0)        F_(0, 0)        F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
-#define IP5_23_20      FM(D2)                  F_(0, 0)        FM(MSIOF3_RXD_A)        F_(0, 0)                        FM(VI4_DATA18)  FM(VI5_DATA2)   F_(0, 0)                F_(0, 0)        F_(0, 0)                F_(0, 0)        F_(0, 0)        F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
-#define IP5_27_24      FM(D3)                  F_(0, 0)        FM(MSIOF3_TXD_A)        F_(0, 0)                        FM(VI4_DATA19)  FM(VI5_DATA3)   F_(0, 0)                F_(0, 0)        F_(0, 0)                F_(0, 0)        F_(0, 0)        F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
-#define IP5_31_28      FM(D4)                  FM(MSIOF2_SCK_B)F_(0, 0)                F_(0, 0)                        FM(VI4_DATA20)  FM(VI5_DATA4)   F_(0, 0)                F_(0, 0)        F_(0, 0)                F_(0, 0)        F_(0, 0)        F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
-#define IP6_3_0                FM(D5)                  FM(MSIOF2_SYNC_B)F_(0, 0)               F_(0, 0)                        FM(VI4_DATA21)  FM(VI5_DATA5)   F_(0, 0)                F_(0, 0)        F_(0, 0)                F_(0, 0)        F_(0, 0)        F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
-#define IP6_7_4                FM(D6)                  FM(MSIOF2_RXD_B)F_(0, 0)                F_(0, 0)                        FM(VI4_DATA22)  FM(VI5_DATA6)   F_(0, 0)                F_(0, 0)        F_(0, 0)                F_(0, 0)        F_(0, 0)        F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
-#define IP6_11_8       FM(D7)                  FM(MSIOF2_TXD_B)F_(0, 0)                F_(0, 0)                        FM(VI4_DATA23)  FM(VI5_DATA7)   F_(0, 0)                F_(0, 0)        F_(0, 0)                F_(0, 0)        F_(0, 0)        F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
-#define IP6_15_12      FM(D8)                  FM(LCDOUT0)     FM(MSIOF2_SCK_D)        FM(SCK4_C)                      FM(VI4_DATA0_A) F_(0, 0)        FM(DU_DR0)              F_(0, 0)        F_(0, 0)                F_(0, 0)        F_(0, 0)        F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
-#define IP6_19_16      FM(D9)                  FM(LCDOUT1)     FM(MSIOF2_SYNC_D)       F_(0, 0)                        FM(VI4_DATA1_A) F_(0, 0)        FM(DU_DR1)              F_(0, 0)        F_(0, 0)                F_(0, 0)        F_(0, 0)        F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
-#define IP6_23_20      FM(D10)                 FM(LCDOUT2)     FM(MSIOF2_RXD_D)        FM(HRX3_B)                      FM(VI4_DATA2_A) FM(CTS4_N_C)    FM(DU_DR2)              F_(0, 0)        F_(0, 0)                F_(0, 0)        F_(0, 0)        F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
-#define IP6_27_24      FM(D11)                 FM(LCDOUT3)     FM(MSIOF2_TXD_D)        FM(HTX3_B)                      FM(VI4_DATA3_A) FM(RTS4_N_C)    FM(DU_DR3)              F_(0, 0)        F_(0, 0)                F_(0, 0)        F_(0, 0)        F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
-#define IP6_31_28      FM(D12)                 FM(LCDOUT4)     FM(MSIOF2_SS1_D)        FM(RX4_C)                       FM(VI4_DATA4_A) F_(0, 0)        FM(DU_DR4)              F_(0, 0)        F_(0, 0)                F_(0, 0)        F_(0, 0)        F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
-#define IP7_3_0                FM(D13)                 FM(LCDOUT5)     FM(MSIOF2_SS2_D)        FM(TX4_C)                       FM(VI4_DATA5_A) F_(0, 0)        FM(DU_DR5)              F_(0, 0)        F_(0, 0)                F_(0, 0)        F_(0, 0)        F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
-#define IP7_7_4                FM(D14)                 FM(LCDOUT6)     FM(MSIOF3_SS1_A)        FM(HRX3_C)                      FM(VI4_DATA6_A) F_(0, 0)        FM(DU_DR6)              FM(SCL6_C)      F_(0, 0)                F_(0, 0)        F_(0, 0)        F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
-#define IP7_11_8       FM(D15)                 FM(LCDOUT7)     FM(MSIOF3_SS2_A)        FM(HTX3_C)                      FM(VI4_DATA7_A) F_(0, 0)        FM(DU_DR7)              FM(SDA6_C)      F_(0, 0)                F_(0, 0)        F_(0, 0)        F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
-#define IP7_15_12      FM(FSCLKST)             F_(0, 0)        F_(0, 0)                F_(0, 0)                        F_(0, 0)        F_(0, 0)        F_(0, 0)                F_(0, 0)        F_(0, 0)                F_(0, 0)        F_(0, 0)        F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
-#define IP7_19_16      FM(SD0_CLK)             F_(0, 0)        FM(MSIOF1_SCK_E)        F_(0, 0)                        F_(0, 0)        F_(0, 0)        FM(STP_OPWM_0_B)        F_(0, 0)        F_(0, 0)                F_(0, 0)        F_(0, 0)        F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
-
-/* IPSRx */            /* 0 */                 /* 1 */         /* 2 */                 /* 3 */                         /* 4 */         /* 5 */         /* 6 */                 /* 7 */         /* 8 */                 /* 9 */         /* A */         /* B */         /* C - F */
-#define IP7_23_20      FM(SD0_CMD)             F_(0, 0)        FM(MSIOF1_SYNC_E)       F_(0, 0)                        F_(0, 0)        F_(0, 0)        FM(STP_IVCXO27_0_B)     F_(0, 0)        F_(0, 0)                F_(0, 0)        F_(0, 0)        F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
-#define IP7_27_24      FM(SD0_DAT0)            F_(0, 0)        FM(MSIOF1_RXD_E)        F_(0, 0)                        F_(0, 0)        FM(TS_SCK0_B)   FM(STP_ISCLK_0_B)       F_(0, 0)        F_(0, 0)                F_(0, 0)        F_(0, 0)        F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
-#define IP7_31_28      FM(SD0_DAT1)            F_(0, 0)        FM(MSIOF1_TXD_E)        F_(0, 0)                        F_(0, 0)        FM(TS_SPSYNC0_B)FM(STP_ISSYNC_0_B)      F_(0, 0)        F_(0, 0)                F_(0, 0)        F_(0, 0)        F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
-#define IP8_3_0                FM(SD0_DAT2)            F_(0, 0)        FM(MSIOF1_SS1_E)        F_(0, 0)                        F_(0, 0)        FM(TS_SDAT0_B)  FM(STP_ISD_0_B)         F_(0, 0)        F_(0, 0)                F_(0, 0)        F_(0, 0)        F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
-#define IP8_7_4                FM(SD0_DAT3)            F_(0, 0)        FM(MSIOF1_SS2_E)        F_(0, 0)                        F_(0, 0)        FM(TS_SDEN0_B)  FM(STP_ISEN_0_B)        F_(0, 0)        F_(0, 0)                F_(0, 0)        F_(0, 0)        F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
-#define IP8_11_8       FM(SD1_CLK)             F_(0, 0)        FM(MSIOF1_SCK_G)        F_(0, 0)                        F_(0, 0)        FM(SIM0_CLK_A)  F_(0, 0)                F_(0, 0)        F_(0, 0)                F_(0, 0)        F_(0, 0)        F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
-#define IP8_15_12      FM(SD1_CMD)             F_(0, 0)        FM(MSIOF1_SYNC_G)       F_(0, 0)                        F_(0, 0)        FM(SIM0_D_A)    FM(STP_IVCXO27_1_B)     F_(0, 0)        F_(0, 0)                F_(0, 0)        F_(0, 0)        F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
-#define IP8_19_16      FM(SD1_DAT0)            FM(SD2_DAT4)    FM(MSIOF1_RXD_G)        F_(0, 0)                        F_(0, 0)        FM(TS_SCK1_B)   FM(STP_ISCLK_1_B)       F_(0, 0)        F_(0, 0)                F_(0, 0)        F_(0, 0)        F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
-#define IP8_23_20      FM(SD1_DAT1)            FM(SD2_DAT5)    FM(MSIOF1_TXD_G)        F_(0, 0)                        F_(0, 0)        FM(TS_SPSYNC1_B)FM(STP_ISSYNC_1_B)      F_(0, 0)        F_(0, 0)                F_(0, 0)        F_(0, 0)        F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
-#define IP8_27_24      FM(SD1_DAT2)            FM(SD2_DAT6)    FM(MSIOF1_SS1_G)        F_(0, 0)                        F_(0, 0)        FM(TS_SDAT1_B)  FM(STP_ISD_1_B)         F_(0, 0)        F_(0, 0)                F_(0, 0)        F_(0, 0)        F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
-#define IP8_31_28      FM(SD1_DAT3)            FM(SD2_DAT7)    FM(MSIOF1_SS2_G)        F_(0, 0)                        F_(0, 0)        FM(TS_SDEN1_B)  FM(STP_ISEN_1_B)        F_(0, 0)        F_(0, 0)                F_(0, 0)        F_(0, 0)        F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
-#define IP9_3_0                FM(SD2_CLK)             F_(0, 0)        F_(0, 0)                F_(0, 0)                        F_(0, 0)        F_(0, 0)        F_(0, 0)                F_(0, 0)        F_(0, 0)                F_(0, 0)        F_(0, 0)        F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
-#define IP9_7_4                FM(SD2_DAT0)            F_(0, 0)        F_(0, 0)                F_(0, 0)                        F_(0, 0)        F_(0, 0)        F_(0, 0)                F_(0, 0)        F_(0, 0)                F_(0, 0)        F_(0, 0)        F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
-#define IP9_11_8       FM(SD2_DAT1)            F_(0, 0)        F_(0, 0)                F_(0, 0)                        F_(0, 0)        F_(0, 0)        F_(0, 0)                F_(0, 0)        F_(0, 0)                F_(0, 0)        F_(0, 0)        F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
-#define IP9_15_12      FM(SD2_DAT2)            F_(0, 0)        F_(0, 0)                F_(0, 0)                        F_(0, 0)        F_(0, 0)        F_(0, 0)                F_(0, 0)        F_(0, 0)                F_(0, 0)        F_(0, 0)        F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
-#define IP9_19_16      FM(SD2_DAT3)            F_(0, 0)        F_(0, 0)                F_(0, 0)                        F_(0, 0)        F_(0, 0)        F_(0, 0)                F_(0, 0)        F_(0, 0)                F_(0, 0)        F_(0, 0)        F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
-#define IP9_23_20      FM(SD2_DS)              F_(0, 0)        F_(0, 0)                F_(0, 0)                        F_(0, 0)        F_(0, 0)        F_(0, 0)                F_(0, 0)        FM(SATA_DEVSLP_B)       F_(0, 0)        F_(0, 0)        F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
-#define IP9_27_24      FM(SD3_DAT4)            FM(SD2_CD_A)    F_(0, 0)                F_(0, 0)                        F_(0, 0)        F_(0, 0)        F_(0, 0)                F_(0, 0)        F_(0, 0)                F_(0, 0)        F_(0, 0)        F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
-#define IP9_31_28      FM(SD3_DAT5)            FM(SD2_WP_A)    F_(0, 0)                F_(0, 0)                        F_(0, 0)        F_(0, 0)        F_(0, 0)                F_(0, 0)        F_(0, 0)                F_(0, 0)        F_(0, 0)        F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
-#define IP10_3_0       FM(SD3_DAT6)            FM(SD3_CD)      F_(0, 0)                F_(0, 0)                        F_(0, 0)        F_(0, 0)        F_(0, 0)                F_(0, 0)        F_(0, 0)                F_(0, 0)        F_(0, 0)        F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
-#define IP10_7_4       FM(SD3_DAT7)            FM(SD3_WP)      F_(0, 0)                F_(0, 0)                        F_(0, 0)        F_(0, 0)        F_(0, 0)                F_(0, 0)        F_(0, 0)                F_(0, 0)        F_(0, 0)        F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
-#define IP10_11_8      FM(SD0_CD)              F_(0, 0)        F_(0, 0)                F_(0, 0)                        FM(SCL2_B)      FM(SIM0_RST_A)  F_(0, 0)                F_(0, 0)        F_(0, 0)                F_(0, 0)        F_(0, 0)        F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
-#define IP10_15_12     FM(SD0_WP)              F_(0, 0)        F_(0, 0)                F_(0, 0)                        FM(SDA2_B)      F_(0, 0)        F_(0, 0)                F_(0, 0)        F_(0, 0)                F_(0, 0)        F_(0, 0)        F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
-#define IP10_19_16     FM(SD1_CD)              F_(0, 0)        F_(0, 0)                F_(0, 0)                        F_(0, 0)        FM(SIM0_CLK_B)  F_(0, 0)                F_(0, 0)        F_(0, 0)                F_(0, 0)        F_(0, 0)        F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
-#define IP10_23_20     FM(SD1_WP)              F_(0, 0)        F_(0, 0)                F_(0, 0)                        F_(0, 0)        FM(SIM0_D_B)    F_(0, 0)                F_(0, 0)        F_(0, 0)                F_(0, 0)        F_(0, 0)        F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
-#define IP10_27_24     FM(SCK0)                FM(HSCK1_B)     FM(MSIOF1_SS2_B)        FM(AUDIO_CLKC_B)                FM(SDA2_A)      FM(SIM0_RST_B)  FM(STP_OPWM_0_C)        FM(RIF0_CLK_B)  F_(0, 0)                FM(ADICHS2)     F_(0, 0)        F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
-#define IP10_31_28     FM(RX0)                 FM(HRX1_B)      F_(0, 0)                F_(0, 0)                        F_(0, 0)        FM(TS_SCK0_C)   FM(STP_ISCLK_0_C)       FM(RIF0_D0_B)   F_(0, 0)                F_(0, 0)        F_(0, 0)        F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
-#define IP11_3_0       FM(TX0)                 FM(HTX1_B)      F_(0, 0)                F_(0, 0)                        F_(0, 0)        FM(TS_SPSYNC0_C)FM(STP_ISSYNC_0_C)      FM(RIF0_D1_B)   F_(0, 0)                F_(0, 0)        F_(0, 0)        F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
-#define IP11_7_4       FM(CTS0_N)              FM(HCTS1_N_B)   FM(MSIOF1_SYNC_B)       F_(0, 0)                        F_(0, 0)        FM(TS_SPSYNC1_C)FM(STP_ISSYNC_1_C)      FM(RIF1_SYNC_B) FM(AUDIO_CLKOUT_C)      FM(ADICS_SAMP)  F_(0, 0)        F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
-#define IP11_11_8      FM(RTS0_N)              FM(HRTS1_N_B)   FM(MSIOF1_SS1_B)        FM(AUDIO_CLKA_B)                FM(SCL2_A)      F_(0, 0)        FM(STP_IVCXO27_1_C)     FM(RIF0_SYNC_B) F_(0, 0)                FM(ADICHS1)     F_(0, 0)        F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
-#define IP11_15_12     FM(RX1_A)               FM(HRX1_A)      F_(0, 0)                F_(0, 0)                        F_(0, 0)        FM(TS_SDAT0_C)  FM(STP_ISD_0_C)         FM(RIF1_CLK_C)  F_(0, 0)                F_(0, 0)        F_(0, 0)        F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
-#define IP11_19_16     FM(TX1_A)               FM(HTX1_A)      F_(0, 0)                F_(0, 0)                        F_(0, 0)        FM(TS_SDEN0_C)  FM(STP_ISEN_0_C)        FM(RIF1_D0_C)   F_(0, 0)                F_(0, 0)        F_(0, 0)        F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
-#define IP11_23_20     FM(CTS1_N)              FM(HCTS1_N_A)   FM(MSIOF1_RXD_B)        F_(0, 0)                        F_(0, 0)        FM(TS_SDEN1_C)  FM(STP_ISEN_1_C)        FM(RIF1_D0_B)   F_(0, 0)                FM(ADIDATA)     F_(0, 0)        F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
-#define IP11_27_24     FM(RTS1_N)              FM(HRTS1_N_A)   FM(MSIOF1_TXD_B)        F_(0, 0)                        F_(0, 0)        FM(TS_SDAT1_C)  FM(STP_ISD_1_C)         FM(RIF1_D1_B)   F_(0, 0)                FM(ADICHS0)     F_(0, 0)        F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
-#define IP11_31_28     FM(SCK2)                FM(SCIF_CLK_B)  FM(MSIOF1_SCK_B)        F_(0, 0)                        F_(0, 0)        FM(TS_SCK1_C)   FM(STP_ISCLK_1_C)       FM(RIF1_CLK_B)  F_(0, 0)                FM(ADICLK)      F_(0, 0)        F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
-#define IP12_3_0       FM(TX2_A)               F_(0, 0)        F_(0, 0)                FM(SD2_CD_B)                    FM(SCL1_A)      F_(0, 0)        FM(FMCLK_A)             FM(RIF1_D1_C)   F_(0, 0)                FM(FSO_CFE_0_B) F_(0, 0)        F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
-#define IP12_7_4       FM(RX2_A)               F_(0, 0)        F_(0, 0)                FM(SD2_WP_B)                    FM(SDA1_A)      F_(0, 0)        FM(FMIN_A)              FM(RIF1_SYNC_C) F_(0, 0)                FM(FSO_CFE_1_B) F_(0, 0)        F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
-#define IP12_11_8      FM(HSCK0)               F_(0, 0)        FM(MSIOF1_SCK_D)        FM(AUDIO_CLKB_A)                FM(SSI_SDATA1_B)FM(TS_SCK0_D)   FM(STP_ISCLK_0_D)       FM(RIF0_CLK_C)  F_(0, 0)                F_(0, 0)        F_(0, 0)        F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
-#define IP12_15_12     FM(HRX0)                F_(0, 0)        FM(MSIOF1_RXD_D)        F_(0, 0)                        FM(SSI_SDATA2_B)FM(TS_SDEN0_D)  FM(STP_ISEN_0_D)        FM(RIF0_D0_C)   F_(0, 0)                F_(0, 0)        F_(0, 0)        F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
-#define IP12_19_16     FM(HTX0)                F_(0, 0)        FM(MSIOF1_TXD_D)        F_(0, 0)                        FM(SSI_SDATA9_B)FM(TS_SDAT0_D)  FM(STP_ISD_0_D)         FM(RIF0_D1_C)   F_(0, 0)                F_(0, 0)        F_(0, 0)        F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
-#define IP12_23_20     FM(HCTS0_N)             FM(RX2_B)       FM(MSIOF1_SYNC_D)       F_(0, 0)                        FM(SSI_SCK9_A)  FM(TS_SPSYNC0_D)FM(STP_ISSYNC_0_D)      FM(RIF0_SYNC_C) FM(AUDIO_CLKOUT1_A)     F_(0, 0)        F_(0, 0)        F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
-#define IP12_27_24     FM(HRTS0_N)             FM(TX2_B)       FM(MSIOF1_SS1_D)        F_(0, 0)                        FM(SSI_WS9_A)   F_(0, 0)        FM(STP_IVCXO27_0_D)     FM(BPFCLK_A)    FM(AUDIO_CLKOUT2_A)     F_(0, 0)        F_(0, 0)        F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
-
-/* IPSRx */            /* 0 */                 /* 1 */         /* 2 */                 /* 3 */                         /* 4 */         /* 5 */         /* 6 */                 /* 7 */         /* 8 */                 /* 9 */         /* A */         /* B */         /* C - F */
-#define IP12_31_28     FM(MSIOF0_SYNC)         F_(0, 0)        F_(0, 0)                F_(0, 0)                        F_(0, 0)        F_(0, 0)        F_(0, 0)                F_(0, 0)        FM(AUDIO_CLKOUT_A)      F_(0, 0)        F_(0, 0)        F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
-#define IP13_3_0       FM(MSIOF0_SS1)          FM(RX5)         F_(0, 0)                FM(AUDIO_CLKA_C)                FM(SSI_SCK2_A)  F_(0, 0)        FM(STP_IVCXO27_0_C)     F_(0, 0)        FM(AUDIO_CLKOUT3_A)     F_(0, 0)        FM(TCLK1_B)     F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
-#define IP13_7_4       FM(MSIOF0_SS2)          FM(TX5)         FM(MSIOF1_SS2_D)        FM(AUDIO_CLKC_A)                FM(SSI_WS2_A)   F_(0, 0)        FM(STP_OPWM_0_D)        F_(0, 0)        FM(AUDIO_CLKOUT_D)      F_(0, 0)        FM(SPEEDIN_B)   F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
-#define IP13_11_8      FM(MLB_CLK)             F_(0, 0)        FM(MSIOF1_SCK_F)        F_(0, 0)                        FM(SCL1_B)      F_(0, 0)        F_(0, 0)                F_(0, 0)        F_(0, 0)                F_(0, 0)        F_(0, 0)        F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
-#define IP13_15_12     FM(MLB_SIG)             FM(RX1_B)       FM(MSIOF1_SYNC_F)       F_(0, 0)                        FM(SDA1_B)      F_(0, 0)        F_(0, 0)                F_(0, 0)        F_(0, 0)                F_(0, 0)        F_(0, 0)        F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
-#define IP13_19_16     FM(MLB_DAT)             FM(TX1_B)       FM(MSIOF1_RXD_F)        F_(0, 0)                        F_(0, 0)        F_(0, 0)        F_(0, 0)                F_(0, 0)        F_(0, 0)                F_(0, 0)        F_(0, 0)        F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
-#define IP13_23_20     FM(SSI_SCK01239)        F_(0, 0)        FM(MSIOF1_TXD_F)        F_(0, 0)                        F_(0, 0)        F_(0, 0)        F_(0, 0)                F_(0, 0)        F_(0, 0)                F_(0, 0)        F_(0, 0)        F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
-#define IP13_27_24     FM(SSI_WS01239)         F_(0, 0)        FM(MSIOF1_SS1_F)        F_(0, 0)                        F_(0, 0)        F_(0, 0)        F_(0, 0)                F_(0, 0)        F_(0, 0)                F_(0, 0)        F_(0, 0)        F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
-#define IP13_31_28     FM(SSI_SDATA0)          F_(0, 0)        FM(MSIOF1_SS2_F)        F_(0, 0)                        F_(0, 0)        F_(0, 0)        F_(0, 0)                F_(0, 0)        F_(0, 0)                F_(0, 0)        F_(0, 0)        F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
-#define IP14_3_0       FM(SSI_SDATA1_A)        F_(0, 0)        F_(0, 0)                F_(0, 0)                        F_(0, 0)        F_(0, 0)        F_(0, 0)                F_(0, 0)        F_(0, 0)                F_(0, 0)        F_(0, 0)        F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
-#define IP14_7_4       FM(SSI_SDATA2_A)        F_(0, 0)        F_(0, 0)                F_(0, 0)                        FM(SSI_SCK1_B)  F_(0, 0)        F_(0, 0)                F_(0, 0)        F_(0, 0)                F_(0, 0)        F_(0, 0)        F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
-#define IP14_11_8      FM(SSI_SCK349)          F_(0, 0)        FM(MSIOF1_SS1_A)        F_(0, 0)                        F_(0, 0)        F_(0, 0)        FM(STP_OPWM_0_A)        F_(0, 0)        F_(0, 0)                F_(0, 0)        F_(0, 0)        F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
-#define IP14_15_12     FM(SSI_WS349)           FM(HCTS2_N_A)   FM(MSIOF1_SS2_A)        F_(0, 0)                        F_(0, 0)        F_(0, 0)        FM(STP_IVCXO27_0_A)     F_(0, 0)        F_(0, 0)                F_(0, 0)        F_(0, 0)        F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
-#define IP14_19_16     FM(SSI_SDATA3)          FM(HRTS2_N_A)   FM(MSIOF1_TXD_A)        F_(0, 0)                        F_(0, 0)        FM(TS_SCK0_A)   FM(STP_ISCLK_0_A)       FM(RIF0_D1_A)   FM(RIF2_D0_A)           F_(0, 0)        F_(0, 0)        F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
-#define IP14_23_20     FM(SSI_SCK4)            FM(HRX2_A)      FM(MSIOF1_SCK_A)        F_(0, 0)                        F_(0, 0)        FM(TS_SDAT0_A)  FM(STP_ISD_0_A)         FM(RIF0_CLK_A)  FM(RIF2_CLK_A)          F_(0, 0)        F_(0, 0)        F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
-#define IP14_27_24     FM(SSI_WS4)             FM(HTX2_A)      FM(MSIOF1_SYNC_A)       F_(0, 0)                        F_(0, 0)        FM(TS_SDEN0_A)  FM(STP_ISEN_0_A)        FM(RIF0_SYNC_A) FM(RIF2_SYNC_A)         F_(0, 0)        F_(0, 0)        F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
-#define IP14_31_28     FM(SSI_SDATA4)          FM(HSCK2_A)     FM(MSIOF1_RXD_A)        F_(0, 0)                        F_(0, 0)        FM(TS_SPSYNC0_A)FM(STP_ISSYNC_0_A)      FM(RIF0_D0_A)   FM(RIF2_D1_A)           F_(0, 0)        F_(0, 0)        F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
-#define IP15_3_0       FM(SSI_SCK6)            FM(USB2_PWEN)   F_(0, 0)                FM(SIM0_RST_D)                  F_(0, 0)        F_(0, 0)        F_(0, 0)                F_(0, 0)        F_(0, 0)                F_(0, 0)        F_(0, 0)        F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
-#define IP15_7_4       FM(SSI_WS6)             FM(USB2_OVC)    F_(0, 0)                FM(SIM0_D_D)                    F_(0, 0)        F_(0, 0)        F_(0, 0)                F_(0, 0)        F_(0, 0)                F_(0, 0)        F_(0, 0)        F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
-#define IP15_11_8      FM(SSI_SDATA6)          F_(0, 0)        F_(0, 0)                FM(SIM0_CLK_D)                  F_(0, 0)        F_(0, 0)        F_(0, 0)                F_(0, 0)        FM(SATA_DEVSLP_A)       F_(0, 0)        F_(0, 0)        F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
-#define IP15_15_12     FM(SSI_SCK78)           FM(HRX2_B)      FM(MSIOF1_SCK_C)        F_(0, 0)                        F_(0, 0)        FM(TS_SCK1_A)   FM(STP_ISCLK_1_A)       FM(RIF1_CLK_A)  FM(RIF3_CLK_A)          F_(0, 0)        F_(0, 0)        F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
-#define IP15_19_16     FM(SSI_WS78)            FM(HTX2_B)      FM(MSIOF1_SYNC_C)       F_(0, 0)                        F_(0, 0)        FM(TS_SDAT1_A)  FM(STP_ISD_1_A)         FM(RIF1_SYNC_A) FM(RIF3_SYNC_A)         F_(0, 0)        F_(0, 0)        F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
-#define IP15_23_20     FM(SSI_SDATA7)          FM(HCTS2_N_B)   FM(MSIOF1_RXD_C)        F_(0, 0)                        F_(0, 0)        FM(TS_SDEN1_A)  FM(STP_ISEN_1_A)        FM(RIF1_D0_A)   FM(RIF3_D0_A)           F_(0, 0)        FM(TCLK2_A)     F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
-#define IP15_27_24     FM(SSI_SDATA8)          FM(HRTS2_N_B)   FM(MSIOF1_TXD_C)        F_(0, 0)                        F_(0, 0)        FM(TS_SPSYNC1_A)FM(STP_ISSYNC_1_A)      FM(RIF1_D1_A)   FM(RIF3_D1_A)           F_(0, 0)        F_(0, 0)        F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
-#define IP15_31_28     FM(SSI_SDATA9_A)        FM(HSCK2_B)     FM(MSIOF1_SS1_C)        FM(HSCK1_A)                     FM(SSI_WS1_B)   FM(SCK1)        FM(STP_IVCXO27_1_A)     FM(SCK5)        F_(0, 0)                F_(0, 0)        F_(0, 0)        F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
-#define IP16_3_0       FM(AUDIO_CLKA_A)        F_(0, 0)        F_(0, 0)                F_(0, 0)                        F_(0, 0)        F_(0, 0)        F_(0, 0)                F_(0, 0)        F_(0, 0)                F_(0, 0)        F_(0, 0)        F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
-#define IP16_7_4       FM(AUDIO_CLKB_B)        FM(SCIF_CLK_A)  F_(0, 0)                F_(0, 0)                        F_(0, 0)        F_(0, 0)        FM(STP_IVCXO27_1_D)     FM(REMOCON_A)   F_(0, 0)                F_(0, 0)        FM(TCLK1_A)     F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
-#define IP16_11_8      FM(USB0_PWEN)           F_(0, 0)        F_(0, 0)                FM(SIM0_RST_C)                  F_(0, 0)        FM(TS_SCK1_D)   FM(STP_ISCLK_1_D)       FM(BPFCLK_B)    FM(RIF3_CLK_B)          F_(0, 0)        F_(0, 0)        F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
-#define IP16_15_12     FM(USB0_OVC)            F_(0, 0)        F_(0, 0)                FM(SIM0_D_C)                    F_(0, 0)        FM(TS_SDAT1_D)  FM(STP_ISD_1_D)         F_(0, 0)        FM(RIF3_SYNC_B)         F_(0, 0)        F_(0, 0)        F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
-#define IP16_19_16     FM(USB1_PWEN)           F_(0, 0)        F_(0, 0)                FM(SIM0_CLK_C)                  FM(SSI_SCK1_A)  FM(TS_SCK0_E)   FM(STP_ISCLK_0_E)       FM(FMCLK_B)     FM(RIF2_CLK_B)          F_(0, 0)        FM(SPEEDIN_A)   F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
-#define IP16_23_20     FM(USB1_OVC)            F_(0, 0)        FM(MSIOF1_SS2_C)        F_(0, 0)                        FM(SSI_WS1_A)   FM(TS_SDAT0_E)  FM(STP_ISD_0_E)         FM(FMIN_B)      FM(RIF2_SYNC_B)         F_(0, 0)        FM(REMOCON_B)   F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
-#define IP16_27_24     FM(USB30_PWEN)          F_(0, 0)        F_(0, 0)                FM(AUDIO_CLKOUT_B)              FM(SSI_SCK2_B)  FM(TS_SDEN1_D)  FM(STP_ISEN_1_D)        FM(STP_OPWM_0_E)FM(RIF3_D0_B)           F_(0, 0)        FM(TCLK2_B)     FM(TPU0TO0)     F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
-#define IP16_31_28     FM(USB30_OVC)           F_(0, 0)        F_(0, 0)                FM(AUDIO_CLKOUT1_B)             FM(SSI_WS2_B)   FM(TS_SPSYNC1_D)FM(STP_ISSYNC_1_D)      FM(STP_IVCXO27_0_E)FM(RIF3_D1_B)        F_(0, 0)        FM(FSO_TOE_B)   FM(TPU0TO1)     F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
-#define IP17_3_0       FM(USB31_PWEN)          F_(0, 0)        F_(0, 0)                FM(AUDIO_CLKOUT2_B)             FM(SSI_SCK9_B)  FM(TS_SDEN0_E)  FM(STP_ISEN_0_E)        F_(0, 0)        FM(RIF2_D0_B)           F_(0, 0)        F_(0, 0)        FM(TPU0TO2)     F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
-#define IP17_7_4       FM(USB31_OVC)           F_(0, 0)        F_(0, 0)                FM(AUDIO_CLKOUT3_B)             FM(SSI_WS9_B)   FM(TS_SPSYNC0_E)FM(STP_ISSYNC_0_E)      F_(0, 0)        FM(RIF2_D1_B)           F_(0, 0)        F_(0, 0)        FM(TPU0TO3)     F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
-
-#define PINMUX_GPSR    \
-\
-                                                                                               GPSR6_31 \
-                                                                                               GPSR6_30 \
-                                                                                               GPSR6_29 \
-                                                                                               GPSR6_28 \
-               GPSR1_27                                                                        GPSR6_27 \
-               GPSR1_26                                                                        GPSR6_26 \
-               GPSR1_25                                                        GPSR5_25        GPSR6_25 \
-               GPSR1_24                                                        GPSR5_24        GPSR6_24 \
-               GPSR1_23                                                        GPSR5_23        GPSR6_23 \
-               GPSR1_22                                                        GPSR5_22        GPSR6_22 \
-               GPSR1_21                                                        GPSR5_21        GPSR6_21 \
-               GPSR1_20                                                        GPSR5_20        GPSR6_20 \
-               GPSR1_19                                                        GPSR5_19        GPSR6_19 \
-               GPSR1_18                                                        GPSR5_18        GPSR6_18 \
-               GPSR1_17                                        GPSR4_17        GPSR5_17        GPSR6_17 \
-               GPSR1_16                                        GPSR4_16        GPSR5_16        GPSR6_16 \
-GPSR0_15       GPSR1_15                        GPSR3_15        GPSR4_15        GPSR5_15        GPSR6_15 \
-GPSR0_14       GPSR1_14        GPSR2_14        GPSR3_14        GPSR4_14        GPSR5_14        GPSR6_14 \
-GPSR0_13       GPSR1_13        GPSR2_13        GPSR3_13        GPSR4_13        GPSR5_13        GPSR6_13 \
-GPSR0_12       GPSR1_12        GPSR2_12        GPSR3_12        GPSR4_12        GPSR5_12        GPSR6_12 \
-GPSR0_11       GPSR1_11        GPSR2_11        GPSR3_11        GPSR4_11        GPSR5_11        GPSR6_11 \
-GPSR0_10       GPSR1_10        GPSR2_10        GPSR3_10        GPSR4_10        GPSR5_10        GPSR6_10 \
-GPSR0_9                GPSR1_9         GPSR2_9         GPSR3_9         GPSR4_9         GPSR5_9         GPSR6_9 \
-GPSR0_8                GPSR1_8         GPSR2_8         GPSR3_8         GPSR4_8         GPSR5_8         GPSR6_8 \
-GPSR0_7                GPSR1_7         GPSR2_7         GPSR3_7         GPSR4_7         GPSR5_7         GPSR6_7 \
-GPSR0_6                GPSR1_6         GPSR2_6         GPSR3_6         GPSR4_6         GPSR5_6         GPSR6_6 \
-GPSR0_5                GPSR1_5         GPSR2_5         GPSR3_5         GPSR4_5         GPSR5_5         GPSR6_5 \
-GPSR0_4                GPSR1_4         GPSR2_4         GPSR3_4         GPSR4_4         GPSR5_4         GPSR6_4 \
-GPSR0_3                GPSR1_3         GPSR2_3         GPSR3_3         GPSR4_3         GPSR5_3         GPSR6_3         GPSR7_3 \
-GPSR0_2                GPSR1_2         GPSR2_2         GPSR3_2         GPSR4_2         GPSR5_2         GPSR6_2         GPSR7_2 \
-GPSR0_1                GPSR1_1         GPSR2_1         GPSR3_1         GPSR4_1         GPSR5_1         GPSR6_1         GPSR7_1 \
-GPSR0_0                GPSR1_0         GPSR2_0         GPSR3_0         GPSR4_0         GPSR5_0         GPSR6_0         GPSR7_0
-
-#define PINMUX_IPSR                            \
-\
-FM(IP0_3_0)    IP0_3_0         FM(IP1_3_0)     IP1_3_0         FM(IP2_3_0)     IP2_3_0         FM(IP3_3_0)     IP3_3_0 \
-FM(IP0_7_4)    IP0_7_4         FM(IP1_7_4)     IP1_7_4         FM(IP2_7_4)     IP2_7_4         FM(IP3_7_4)     IP3_7_4 \
-FM(IP0_11_8)   IP0_11_8        FM(IP1_11_8)    IP1_11_8        FM(IP2_11_8)    IP2_11_8        FM(IP3_11_8)    IP3_11_8 \
-FM(IP0_15_12)  IP0_15_12       FM(IP1_15_12)   IP1_15_12       FM(IP2_15_12)   IP2_15_12       FM(IP3_15_12)   IP3_15_12 \
-FM(IP0_19_16)  IP0_19_16       FM(IP1_19_16)   IP1_19_16       FM(IP2_19_16)   IP2_19_16       FM(IP3_19_16)   IP3_19_16 \
-FM(IP0_23_20)  IP0_23_20       FM(IP1_23_20)   IP1_23_20       FM(IP2_23_20)   IP2_23_20       FM(IP3_23_20)   IP3_23_20 \
-FM(IP0_27_24)  IP0_27_24       FM(IP1_27_24)   IP1_27_24       FM(IP2_27_24)   IP2_27_24       FM(IP3_27_24)   IP3_27_24 \
-FM(IP0_31_28)  IP0_31_28       FM(IP1_31_28)   IP1_31_28       FM(IP2_31_28)   IP2_31_28       FM(IP3_31_28)   IP3_31_28 \
-\
-FM(IP4_3_0)    IP4_3_0         FM(IP5_3_0)     IP5_3_0         FM(IP6_3_0)     IP6_3_0         FM(IP7_3_0)     IP7_3_0 \
-FM(IP4_7_4)    IP4_7_4         FM(IP5_7_4)     IP5_7_4         FM(IP6_7_4)     IP6_7_4         FM(IP7_7_4)     IP7_7_4 \
-FM(IP4_11_8)   IP4_11_8        FM(IP5_11_8)    IP5_11_8        FM(IP6_11_8)    IP6_11_8        FM(IP7_11_8)    IP7_11_8 \
-FM(IP4_15_12)  IP4_15_12       FM(IP5_15_12)   IP5_15_12       FM(IP6_15_12)   IP6_15_12       FM(IP7_15_12)   IP7_15_12 \
-FM(IP4_19_16)  IP4_19_16       FM(IP5_19_16)   IP5_19_16       FM(IP6_19_16)   IP6_19_16       FM(IP7_19_16)   IP7_19_16 \
-FM(IP4_23_20)  IP4_23_20       FM(IP5_23_20)   IP5_23_20       FM(IP6_23_20)   IP6_23_20       FM(IP7_23_20)   IP7_23_20 \
-FM(IP4_27_24)  IP4_27_24       FM(IP5_27_24)   IP5_27_24       FM(IP6_27_24)   IP6_27_24       FM(IP7_27_24)   IP7_27_24 \
-FM(IP4_31_28)  IP4_31_28       FM(IP5_31_28)   IP5_31_28       FM(IP6_31_28)   IP6_31_28       FM(IP7_31_28)   IP7_31_28 \
-\
-FM(IP8_3_0)    IP8_3_0         FM(IP9_3_0)     IP9_3_0         FM(IP10_3_0)    IP10_3_0        FM(IP11_3_0)    IP11_3_0 \
-FM(IP8_7_4)    IP8_7_4         FM(IP9_7_4)     IP9_7_4         FM(IP10_7_4)    IP10_7_4        FM(IP11_7_4)    IP11_7_4 \
-FM(IP8_11_8)   IP8_11_8        FM(IP9_11_8)    IP9_11_8        FM(IP10_11_8)   IP10_11_8       FM(IP11_11_8)   IP11_11_8 \
-FM(IP8_15_12)  IP8_15_12       FM(IP9_15_12)   IP9_15_12       FM(IP10_15_12)  IP10_15_12      FM(IP11_15_12)  IP11_15_12 \
-FM(IP8_19_16)  IP8_19_16       FM(IP9_19_16)   IP9_19_16       FM(IP10_19_16)  IP10_19_16      FM(IP11_19_16)  IP11_19_16 \
-FM(IP8_23_20)  IP8_23_20       FM(IP9_23_20)   IP9_23_20       FM(IP10_23_20)  IP10_23_20      FM(IP11_23_20)  IP11_23_20 \
-FM(IP8_27_24)  IP8_27_24       FM(IP9_27_24)   IP9_27_24       FM(IP10_27_24)  IP10_27_24      FM(IP11_27_24)  IP11_27_24 \
-FM(IP8_31_28)  IP8_31_28       FM(IP9_31_28)   IP9_31_28       FM(IP10_31_28)  IP10_31_28      FM(IP11_31_28)  IP11_31_28 \
-\
-FM(IP12_3_0)   IP12_3_0        FM(IP13_3_0)    IP13_3_0        FM(IP14_3_0)    IP14_3_0        FM(IP15_3_0)    IP15_3_0 \
-FM(IP12_7_4)   IP12_7_4        FM(IP13_7_4)    IP13_7_4        FM(IP14_7_4)    IP14_7_4        FM(IP15_7_4)    IP15_7_4 \
-FM(IP12_11_8)  IP12_11_8       FM(IP13_11_8)   IP13_11_8       FM(IP14_11_8)   IP14_11_8       FM(IP15_11_8)   IP15_11_8 \
-FM(IP12_15_12) IP12_15_12      FM(IP13_15_12)  IP13_15_12      FM(IP14_15_12)  IP14_15_12      FM(IP15_15_12)  IP15_15_12 \
-FM(IP12_19_16) IP12_19_16      FM(IP13_19_16)  IP13_19_16      FM(IP14_19_16)  IP14_19_16      FM(IP15_19_16)  IP15_19_16 \
-FM(IP12_23_20) IP12_23_20      FM(IP13_23_20)  IP13_23_20      FM(IP14_23_20)  IP14_23_20      FM(IP15_23_20)  IP15_23_20 \
-FM(IP12_27_24) IP12_27_24      FM(IP13_27_24)  IP13_27_24      FM(IP14_27_24)  IP14_27_24      FM(IP15_27_24)  IP15_27_24 \
-FM(IP12_31_28) IP12_31_28      FM(IP13_31_28)  IP13_31_28      FM(IP14_31_28)  IP14_31_28      FM(IP15_31_28)  IP15_31_28 \
-\
-FM(IP16_3_0)   IP16_3_0        FM(IP17_3_0)    IP17_3_0 \
-FM(IP16_7_4)   IP16_7_4        FM(IP17_7_4)    IP17_7_4 \
-FM(IP16_11_8)  IP16_11_8 \
-FM(IP16_15_12) IP16_15_12 \
-FM(IP16_19_16) IP16_19_16 \
-FM(IP16_23_20) IP16_23_20 \
-FM(IP16_27_24) IP16_27_24 \
-FM(IP16_31_28) IP16_31_28
-
-/* MOD_SEL0 */                 /* 0 */                 /* 1 */                 /* 2 */                 /* 3 */                 /* 4 */                 /* 5 */                 /* 6 */                 /* 7 */
-#define MOD_SEL0_30_29         FM(SEL_MSIOF3_0)        FM(SEL_MSIOF3_1)        FM(SEL_MSIOF3_2)        FM(SEL_MSIOF3_3)
-#define MOD_SEL0_28_27         FM(SEL_MSIOF2_0)        FM(SEL_MSIOF2_1)        FM(SEL_MSIOF2_2)        FM(SEL_MSIOF2_3)
-#define MOD_SEL0_26_25_24      FM(SEL_MSIOF1_0)        FM(SEL_MSIOF1_1)        FM(SEL_MSIOF1_2)        FM(SEL_MSIOF1_3)        FM(SEL_MSIOF1_4)        FM(SEL_MSIOF1_5)        FM(SEL_MSIOF1_6)        F_(0, 0)
-#define MOD_SEL0_23            FM(SEL_LBSC_0)          FM(SEL_LBSC_1)
-#define MOD_SEL0_22            FM(SEL_IEBUS_0)         FM(SEL_IEBUS_1)
-#define MOD_SEL0_21_20         FM(SEL_I2C6_0)          FM(SEL_I2C6_1)          FM(SEL_I2C6_2)          F_(0, 0)
-#define MOD_SEL0_19            FM(SEL_I2C2_0)          FM(SEL_I2C2_1)
-#define MOD_SEL0_18            FM(SEL_I2C1_0)          FM(SEL_I2C1_1)
-#define MOD_SEL0_17            FM(SEL_HSCIF4_0)        FM(SEL_HSCIF4_1)
-#define MOD_SEL0_16_15         FM(SEL_HSCIF3_0)        FM(SEL_HSCIF3_1)        FM(SEL_HSCIF3_2)        FM(SEL_HSCIF3_3)
-#define MOD_SEL0_14            FM(SEL_HSCIF2_0)        FM(SEL_HSCIF2_1)
-#define MOD_SEL0_13            FM(SEL_HSCIF1_0)        FM(SEL_HSCIF1_1)
-#define MOD_SEL0_12            FM(SEL_FSO_0)           FM(SEL_FSO_1)
-#define MOD_SEL0_11            FM(SEL_FM_0)            FM(SEL_FM_1)
-#define MOD_SEL0_10            FM(SEL_ETHERAVB_0)      FM(SEL_ETHERAVB_1)
-#define MOD_SEL0_9             FM(SEL_DRIF3_0)         FM(SEL_DRIF3_1)
-#define MOD_SEL0_8             FM(SEL_DRIF2_0)         FM(SEL_DRIF2_1)
-#define MOD_SEL0_7_6           FM(SEL_DRIF1_0)         FM(SEL_DRIF1_1)         FM(SEL_DRIF1_2)         F_(0, 0)
-#define MOD_SEL0_5_4           FM(SEL_DRIF0_0)         FM(SEL_DRIF0_1)         FM(SEL_DRIF0_2)         F_(0, 0)
-#define MOD_SEL0_3             FM(SEL_CANFD0_0)        FM(SEL_CANFD0_1)
-#define MOD_SEL0_2_1           FM(SEL_ADG_0)           FM(SEL_ADG_1)           FM(SEL_ADG_2)           FM(SEL_ADG_3)
-
-/* MOD_SEL1 */                 /* 0 */                 /* 1 */                 /* 2 */                 /* 3 */                 /* 4 */                 /* 5 */                 /* 6 */                 /* 7 */
-#define MOD_SEL1_31_30         FM(SEL_TSIF1_0)         FM(SEL_TSIF1_1)         FM(SEL_TSIF1_2)         FM(SEL_TSIF1_3)
-#define MOD_SEL1_29_28_27      FM(SEL_TSIF0_0)         FM(SEL_TSIF0_1)         FM(SEL_TSIF0_2)         FM(SEL_TSIF0_3)         FM(SEL_TSIF0_4)         F_(0, 0)                F_(0, 0)                F_(0, 0)
-#define MOD_SEL1_26            FM(SEL_TIMER_TMU_0)     FM(SEL_TIMER_TMU_1)
-#define MOD_SEL1_25_24         FM(SEL_SSP1_1_0)        FM(SEL_SSP1_1_1)        FM(SEL_SSP1_1_2)        FM(SEL_SSP1_1_3)
-#define MOD_SEL1_23_22_21      FM(SEL_SSP1_0_0)        FM(SEL_SSP1_0_1)        FM(SEL_SSP1_0_2)        FM(SEL_SSP1_0_3)        FM(SEL_SSP1_0_4)        F_(0, 0)                F_(0, 0)                F_(0, 0)
-#define MOD_SEL1_20            FM(SEL_SSI_0)           FM(SEL_SSI_1)
-#define MOD_SEL1_19            FM(SEL_SPEED_PULSE_0)   FM(SEL_SPEED_PULSE_1)
-#define MOD_SEL1_18_17         FM(SEL_SIMCARD_0)       FM(SEL_SIMCARD_1)       FM(SEL_SIMCARD_2)       FM(SEL_SIMCARD_3)
-#define MOD_SEL1_16            FM(SEL_SDHI2_0)         FM(SEL_SDHI2_1)
-#define MOD_SEL1_15_14         FM(SEL_SCIF4_0)         FM(SEL_SCIF4_1)         FM(SEL_SCIF4_2)         F_(0, 0)
-#define MOD_SEL1_13            FM(SEL_SCIF3_0)         FM(SEL_SCIF3_1)
-#define MOD_SEL1_12            FM(SEL_SCIF2_0)         FM(SEL_SCIF2_1)
-#define MOD_SEL1_11            FM(SEL_SCIF1_0)         FM(SEL_SCIF1_1)
-#define MOD_SEL1_10            FM(SEL_SATA_0)          FM(SEL_SATA_1)
-#define MOD_SEL1_9             FM(SEL_REMOCON_0)       FM(SEL_REMOCON_1)
-#define MOD_SEL1_6             FM(SEL_RCAN0_0)         FM(SEL_RCAN0_1)
-#define MOD_SEL1_5             FM(SEL_PWM6_0)          FM(SEL_PWM6_1)
-#define MOD_SEL1_4             FM(SEL_PWM5_0)          FM(SEL_PWM5_1)
-#define MOD_SEL1_3             FM(SEL_PWM4_0)          FM(SEL_PWM4_1)
-#define MOD_SEL1_2             FM(SEL_PWM3_0)          FM(SEL_PWM3_1)
-#define MOD_SEL1_1             FM(SEL_PWM2_0)          FM(SEL_PWM2_1)
-#define MOD_SEL1_0             FM(SEL_PWM1_0)          FM(SEL_PWM1_1)
-
-/* MOD_SEL2 */                 /* 0 */                 /* 1 */                 /* 2 */                 /* 3 */
-#define MOD_SEL2_31            FM(I2C_SEL_5_0)         FM(I2C_SEL_5_1)
-#define MOD_SEL2_30            FM(I2C_SEL_3_0)         FM(I2C_SEL_3_1)
-#define MOD_SEL2_29            FM(I2C_SEL_0_0)         FM(I2C_SEL_0_1)
-#define MOD_SEL2_0             FM(SEL_VIN4_0)          FM(SEL_VIN4_1)
-
-#define PINMUX_MOD_SELS\
-\
-                       MOD_SEL1_31_30          MOD_SEL2_31 \
-MOD_SEL0_30_29                                 MOD_SEL2_30 \
-                       MOD_SEL1_29_28_27       MOD_SEL2_29 \
-MOD_SEL0_28_27 \
-\
-MOD_SEL0_26_25_24      MOD_SEL1_26 \
-                       MOD_SEL1_25_24 \
-\
-MOD_SEL0_23            MOD_SEL1_23_22_21 \
-MOD_SEL0_22 \
-MOD_SEL0_21_20 \
-                       MOD_SEL1_20 \
-MOD_SEL0_19            MOD_SEL1_19 \
-MOD_SEL0_18            MOD_SEL1_18_17 \
-MOD_SEL0_17 \
-MOD_SEL0_16_15         MOD_SEL1_16 \
-                       MOD_SEL1_15_14 \
-MOD_SEL0_14 \
-MOD_SEL0_13            MOD_SEL1_13 \
-MOD_SEL0_12            MOD_SEL1_12 \
-MOD_SEL0_11            MOD_SEL1_11 \
-MOD_SEL0_10            MOD_SEL1_10 \
-MOD_SEL0_9             MOD_SEL1_9 \
-MOD_SEL0_8 \
-MOD_SEL0_7_6 \
-                       MOD_SEL1_6 \
-MOD_SEL0_5_4           MOD_SEL1_5 \
-                       MOD_SEL1_4 \
-MOD_SEL0_3             MOD_SEL1_3 \
-MOD_SEL0_2_1           MOD_SEL1_2 \
-                       MOD_SEL1_1 \
-                       MOD_SEL1_0              MOD_SEL2_0
-
-/*
- * These pins are not able to be muxed but have other properties
- * that can be set, such as drive-strength or pull-up/pull-down enable.
- */
-#define PINMUX_STATIC \
-       FM(QSPI0_SPCLK) FM(QSPI0_SSL) FM(QSPI0_MOSI_IO0) FM(QSPI0_MISO_IO1) \
-       FM(QSPI0_IO2) FM(QSPI0_IO3) \
-       FM(QSPI1_SPCLK) FM(QSPI1_SSL) FM(QSPI1_MOSI_IO0) FM(QSPI1_MISO_IO1) \
-       FM(QSPI1_IO2) FM(QSPI1_IO3) \
-       FM(RPC_INT) FM(RPC_WP) FM(RPC_RESET) \
-       FM(AVB_TX_CTL) FM(AVB_TXC) FM(AVB_TD0) FM(AVB_TD1) FM(AVB_TD2) FM(AVB_TD3) \
-       FM(AVB_RX_CTL) FM(AVB_RXC) FM(AVB_RD0) FM(AVB_RD1) FM(AVB_RD2) FM(AVB_RD3) \
-       FM(AVB_TXCREFCLK) FM(AVB_MDIO) \
-       FM(CLKOUT) FM(PRESETOUT) \
-       FM(DU_DOTCLKIN0) FM(DU_DOTCLKIN1) FM(DU_DOTCLKIN2) FM(DU_DOTCLKIN3) \
-       FM(TMS) FM(TDO) FM(ASEBRK) FM(MLB_REF) FM(TDI) FM(TCK) FM(TRST) FM(EXTALR)
-
-#define PINMUX_PHYS \
-       FM(SCL0) FM(SDA0) FM(SCL3) FM(SDA3) FM(SCL5) FM(SDA5)
-
-enum {
-       PINMUX_RESERVED = 0,
-
-       PINMUX_DATA_BEGIN,
-       GP_ALL(DATA),
-       PINMUX_DATA_END,
-
-#define F_(x, y)
-#define FM(x)  FN_##x,
-       PINMUX_FUNCTION_BEGIN,
-       GP_ALL(FN),
-       PINMUX_GPSR
-       PINMUX_IPSR
-       PINMUX_MOD_SELS
-       PINMUX_FUNCTION_END,
-#undef F_
-#undef FM
-
-#define F_(x, y)
-#define FM(x)  x##_MARK,
-       PINMUX_MARK_BEGIN,
-       PINMUX_GPSR
-       PINMUX_IPSR
-       PINMUX_MOD_SELS
-       PINMUX_STATIC
-       PINMUX_PHYS
-       PINMUX_MARK_END,
-#undef F_
-#undef FM
-};
-
-static const u16 pinmux_data[] = {
-       PINMUX_DATA_GP_ALL(),
-
-       PINMUX_SINGLE(AVS1),
-       PINMUX_SINGLE(AVS2),
-       PINMUX_SINGLE(GP7_02),
-       PINMUX_SINGLE(GP7_03),
-       PINMUX_SINGLE(MSIOF0_RXD),
-       PINMUX_SINGLE(MSIOF0_SCK),
-       PINMUX_SINGLE(MSIOF0_TXD),
-       PINMUX_SINGLE(SD2_CMD),
-       PINMUX_SINGLE(SD3_CLK),
-       PINMUX_SINGLE(SD3_CMD),
-       PINMUX_SINGLE(SD3_DAT0),
-       PINMUX_SINGLE(SD3_DAT1),
-       PINMUX_SINGLE(SD3_DAT2),
-       PINMUX_SINGLE(SD3_DAT3),
-       PINMUX_SINGLE(SD3_DS),
-       PINMUX_SINGLE(SSI_SCK5),
-       PINMUX_SINGLE(SSI_SDATA5),
-       PINMUX_SINGLE(SSI_WS5),
-
-       /* IPSR0 */
-       PINMUX_IPSR_GPSR(IP0_3_0,       AVB_MDC),
-       PINMUX_IPSR_MSEL(IP0_3_0,       MSIOF2_SS2_C,           SEL_MSIOF2_2),
-
-       PINMUX_IPSR_GPSR(IP0_7_4,       AVB_MAGIC),
-       PINMUX_IPSR_MSEL(IP0_7_4,       MSIOF2_SS1_C,           SEL_MSIOF2_2),
-       PINMUX_IPSR_MSEL(IP0_7_4,       SCK4_A,                 SEL_SCIF4_0),
-
-       PINMUX_IPSR_GPSR(IP0_11_8,      AVB_PHY_INT),
-       PINMUX_IPSR_MSEL(IP0_11_8,      MSIOF2_SYNC_C,          SEL_MSIOF2_2),
-       PINMUX_IPSR_MSEL(IP0_11_8,      RX4_A,                  SEL_SCIF4_0),
-
-       PINMUX_IPSR_GPSR(IP0_15_12,     AVB_LINK),
-       PINMUX_IPSR_MSEL(IP0_15_12,     MSIOF2_SCK_C,           SEL_MSIOF2_2),
-       PINMUX_IPSR_MSEL(IP0_15_12,     TX4_A,                  SEL_SCIF4_0),
-
-       PINMUX_IPSR_PHYS_MSEL(IP0_19_16, AVB_AVTP_MATCH_A,      I2C_SEL_5_0,    SEL_ETHERAVB_0),
-       PINMUX_IPSR_PHYS_MSEL(IP0_19_16, MSIOF2_RXD_C,          I2C_SEL_5_0,    SEL_MSIOF2_2),
-       PINMUX_IPSR_PHYS_MSEL(IP0_19_16, CTS4_N_A,              I2C_SEL_5_0,    SEL_SCIF4_0),
-       PINMUX_IPSR_PHYS(IP0_19_16,     SCL5,                   I2C_SEL_5_1),
-
-       PINMUX_IPSR_PHYS_MSEL(IP0_23_20, AVB_AVTP_CAPTURE_A,    I2C_SEL_5_0,    SEL_ETHERAVB_0),
-       PINMUX_IPSR_PHYS_MSEL(IP0_23_20, MSIOF2_TXD_C,          I2C_SEL_5_0,    SEL_MSIOF2_2),
-       PINMUX_IPSR_PHYS_MSEL(IP0_23_20, RTS4_N_A,              I2C_SEL_5_0,    SEL_SCIF4_0),
-       PINMUX_IPSR_PHYS(IP0_23_20,     SDA5,                   I2C_SEL_5_1),
-
-       PINMUX_IPSR_GPSR(IP0_27_24,     IRQ0),
-       PINMUX_IPSR_GPSR(IP0_27_24,     QPOLB),
-       PINMUX_IPSR_GPSR(IP0_27_24,     DU_CDE),
-       PINMUX_IPSR_MSEL(IP0_27_24,     VI4_DATA0_B,            SEL_VIN4_1),
-       PINMUX_IPSR_MSEL(IP0_27_24,     CAN0_TX_B,              SEL_RCAN0_1),
-       PINMUX_IPSR_MSEL(IP0_27_24,     CANFD0_TX_B,            SEL_CANFD0_1),
-
-       PINMUX_IPSR_GPSR(IP0_31_28,     IRQ1),
-       PINMUX_IPSR_GPSR(IP0_31_28,     QPOLA),
-       PINMUX_IPSR_GPSR(IP0_31_28,     DU_DISP),
-       PINMUX_IPSR_MSEL(IP0_31_28,     VI4_DATA1_B,            SEL_VIN4_1),
-       PINMUX_IPSR_MSEL(IP0_31_28,     CAN0_RX_B,              SEL_RCAN0_1),
-       PINMUX_IPSR_MSEL(IP0_31_28,     CANFD0_RX_B,            SEL_CANFD0_1),
-
-       /* IPSR1 */
-       PINMUX_IPSR_GPSR(IP1_3_0,       IRQ2),
-       PINMUX_IPSR_GPSR(IP1_3_0,       QCPV_QDE),
-       PINMUX_IPSR_GPSR(IP1_3_0,       DU_EXODDF_DU_ODDF_DISP_CDE),
-       PINMUX_IPSR_MSEL(IP1_3_0,       VI4_DATA2_B,            SEL_VIN4_1),
-       PINMUX_IPSR_MSEL(IP1_3_0,       PWM3_B,                 SEL_PWM3_1),
-
-       PINMUX_IPSR_GPSR(IP1_7_4,       IRQ3),
-       PINMUX_IPSR_GPSR(IP1_7_4,       QSTVB_QVE),
-       PINMUX_IPSR_GPSR(IP1_7_4,       A25),
-       PINMUX_IPSR_GPSR(IP1_7_4,       DU_DOTCLKOUT1),
-       PINMUX_IPSR_MSEL(IP1_7_4,       VI4_DATA3_B,            SEL_VIN4_1),
-       PINMUX_IPSR_MSEL(IP1_7_4,       PWM4_B,                 SEL_PWM4_1),
-
-       PINMUX_IPSR_GPSR(IP1_11_8,      IRQ4),
-       PINMUX_IPSR_GPSR(IP1_11_8,      QSTH_QHS),
-       PINMUX_IPSR_GPSR(IP1_11_8,      A24),
-       PINMUX_IPSR_GPSR(IP1_11_8,      DU_EXHSYNC_DU_HSYNC),
-       PINMUX_IPSR_MSEL(IP1_11_8,      VI4_DATA4_B,            SEL_VIN4_1),
-       PINMUX_IPSR_MSEL(IP1_11_8,      PWM5_B,                 SEL_PWM5_1),
-
-       PINMUX_IPSR_GPSR(IP1_15_12,     IRQ5),
-       PINMUX_IPSR_GPSR(IP1_15_12,     QSTB_QHE),
-       PINMUX_IPSR_GPSR(IP1_15_12,     A23),
-       PINMUX_IPSR_GPSR(IP1_15_12,     DU_EXVSYNC_DU_VSYNC),
-       PINMUX_IPSR_MSEL(IP1_15_12,     VI4_DATA5_B,            SEL_VIN4_1),
-       PINMUX_IPSR_MSEL(IP1_15_12,     PWM6_B,                 SEL_PWM6_1),
-
-       PINMUX_IPSR_GPSR(IP1_19_16,     PWM0),
-       PINMUX_IPSR_GPSR(IP1_19_16,     AVB_AVTP_PPS),
-       PINMUX_IPSR_GPSR(IP1_19_16,     A22),
-       PINMUX_IPSR_MSEL(IP1_19_16,     VI4_DATA6_B,            SEL_VIN4_1),
-       PINMUX_IPSR_MSEL(IP1_19_16,     IECLK_B,                SEL_IEBUS_1),
-
-       PINMUX_IPSR_PHYS_MSEL(IP1_23_20, PWM1_A,                I2C_SEL_3_0,    SEL_PWM1_0),
-       PINMUX_IPSR_MSEL(IP1_23_20,     A21,                    I2C_SEL_3_0),
-       PINMUX_IPSR_PHYS_MSEL(IP1_23_20, HRX3_D,                I2C_SEL_3_0,    SEL_HSCIF3_3),
-       PINMUX_IPSR_PHYS_MSEL(IP1_23_20, VI4_DATA7_B,           I2C_SEL_3_0,    SEL_VIN4_1),
-       PINMUX_IPSR_PHYS_MSEL(IP1_23_20, IERX_B,                I2C_SEL_3_0,    SEL_IEBUS_1),
-       PINMUX_IPSR_PHYS(IP1_23_20,     SCL3,                   I2C_SEL_3_1),
-
-       PINMUX_IPSR_PHYS_MSEL(IP1_27_24, PWM2_A,                I2C_SEL_3_0,    SEL_PWM2_0),
-       PINMUX_IPSR_MSEL(IP1_27_24,     A20,                    I2C_SEL_3_0),
-       PINMUX_IPSR_PHYS_MSEL(IP1_27_24, HTX3_D,                I2C_SEL_3_0,    SEL_HSCIF3_3),
-       PINMUX_IPSR_PHYS_MSEL(IP1_27_24, IETX_B,                I2C_SEL_3_0,    SEL_IEBUS_1),
-       PINMUX_IPSR_PHYS(IP1_27_24,     SDA3,                   I2C_SEL_3_1),
-
-       PINMUX_IPSR_GPSR(IP1_31_28,     A0),
-       PINMUX_IPSR_GPSR(IP1_31_28,     LCDOUT16),
-       PINMUX_IPSR_MSEL(IP1_31_28,     MSIOF3_SYNC_B,          SEL_MSIOF3_1),
-       PINMUX_IPSR_GPSR(IP1_31_28,     VI4_DATA8),
-       PINMUX_IPSR_GPSR(IP1_31_28,     DU_DB0),
-       PINMUX_IPSR_MSEL(IP1_31_28,     PWM3_A,                 SEL_PWM3_0),
-
-       /* IPSR2 */
-       PINMUX_IPSR_GPSR(IP2_3_0,       A1),
-       PINMUX_IPSR_GPSR(IP2_3_0,       LCDOUT17),
-       PINMUX_IPSR_MSEL(IP2_3_0,       MSIOF3_TXD_B,           SEL_MSIOF3_1),
-       PINMUX_IPSR_GPSR(IP2_3_0,       VI4_DATA9),
-       PINMUX_IPSR_GPSR(IP2_3_0,       DU_DB1),
-       PINMUX_IPSR_MSEL(IP2_3_0,       PWM4_A,                 SEL_PWM4_0),
-
-       PINMUX_IPSR_GPSR(IP2_7_4,       A2),
-       PINMUX_IPSR_GPSR(IP2_7_4,       LCDOUT18),
-       PINMUX_IPSR_MSEL(IP2_7_4,       MSIOF3_SCK_B,           SEL_MSIOF3_1),
-       PINMUX_IPSR_GPSR(IP2_7_4,       VI4_DATA10),
-       PINMUX_IPSR_GPSR(IP2_7_4,       DU_DB2),
-       PINMUX_IPSR_MSEL(IP2_7_4,       PWM5_A,                 SEL_PWM5_0),
-
-       PINMUX_IPSR_GPSR(IP2_11_8,      A3),
-       PINMUX_IPSR_GPSR(IP2_11_8,      LCDOUT19),
-       PINMUX_IPSR_MSEL(IP2_11_8,      MSIOF3_RXD_B,           SEL_MSIOF3_1),
-       PINMUX_IPSR_GPSR(IP2_11_8,      VI4_DATA11),
-       PINMUX_IPSR_GPSR(IP2_11_8,      DU_DB3),
-       PINMUX_IPSR_MSEL(IP2_11_8,      PWM6_A,                 SEL_PWM6_0),
-
-       PINMUX_IPSR_GPSR(IP2_15_12,     A4),
-       PINMUX_IPSR_GPSR(IP2_15_12,     LCDOUT20),
-       PINMUX_IPSR_MSEL(IP2_15_12,     MSIOF3_SS1_B,           SEL_MSIOF3_1),
-       PINMUX_IPSR_GPSR(IP2_15_12,     VI4_DATA12),
-       PINMUX_IPSR_GPSR(IP2_15_12,     VI5_DATA12),
-       PINMUX_IPSR_GPSR(IP2_15_12,     DU_DB4),
-
-       PINMUX_IPSR_GPSR(IP2_19_16,     A5),
-       PINMUX_IPSR_GPSR(IP2_19_16,     LCDOUT21),
-       PINMUX_IPSR_MSEL(IP2_19_16,     MSIOF3_SS2_B,           SEL_MSIOF3_1),
-       PINMUX_IPSR_MSEL(IP2_19_16,     SCK4_B,                 SEL_SCIF4_1),
-       PINMUX_IPSR_GPSR(IP2_19_16,     VI4_DATA13),
-       PINMUX_IPSR_GPSR(IP2_19_16,     VI5_DATA13),
-       PINMUX_IPSR_GPSR(IP2_19_16,     DU_DB5),
-
-       PINMUX_IPSR_GPSR(IP2_23_20,     A6),
-       PINMUX_IPSR_GPSR(IP2_23_20,     LCDOUT22),
-       PINMUX_IPSR_MSEL(IP2_23_20,     MSIOF2_SS1_A,           SEL_MSIOF2_0),
-       PINMUX_IPSR_MSEL(IP2_23_20,     RX4_B,                  SEL_SCIF4_1),
-       PINMUX_IPSR_GPSR(IP2_23_20,     VI4_DATA14),
-       PINMUX_IPSR_GPSR(IP2_23_20,     VI5_DATA14),
-       PINMUX_IPSR_GPSR(IP2_23_20,     DU_DB6),
-
-       PINMUX_IPSR_GPSR(IP2_27_24,     A7),
-       PINMUX_IPSR_GPSR(IP2_27_24,     LCDOUT23),
-       PINMUX_IPSR_MSEL(IP2_27_24,     MSIOF2_SS2_A,           SEL_MSIOF2_0),
-       PINMUX_IPSR_MSEL(IP2_27_24,     TX4_B,                  SEL_SCIF4_1),
-       PINMUX_IPSR_GPSR(IP2_27_24,     VI4_DATA15),
-       PINMUX_IPSR_GPSR(IP2_27_24,     VI5_DATA15),
-       PINMUX_IPSR_GPSR(IP2_27_24,     DU_DB7),
-
-       PINMUX_IPSR_GPSR(IP2_31_28,     A8),
-       PINMUX_IPSR_MSEL(IP2_31_28,     RX3_B,                  SEL_SCIF3_1),
-       PINMUX_IPSR_MSEL(IP2_31_28,     MSIOF2_SYNC_A,          SEL_MSIOF2_0),
-       PINMUX_IPSR_MSEL(IP2_31_28,     HRX4_B,                 SEL_HSCIF4_1),
-       PINMUX_IPSR_MSEL(IP2_31_28,     SDA6_A,                 SEL_I2C6_0),
-       PINMUX_IPSR_MSEL(IP2_31_28,     AVB_AVTP_MATCH_B,       SEL_ETHERAVB_1),
-       PINMUX_IPSR_MSEL(IP2_31_28,     PWM1_B,                 SEL_PWM1_1),
-
-       /* IPSR3 */
-       PINMUX_IPSR_GPSR(IP3_3_0,       A9),
-       PINMUX_IPSR_MSEL(IP3_3_0,       MSIOF2_SCK_A,           SEL_MSIOF2_0),
-       PINMUX_IPSR_MSEL(IP3_3_0,       CTS4_N_B,               SEL_SCIF4_1),
-       PINMUX_IPSR_GPSR(IP3_3_0,       VI5_VSYNC_N),
-
-       PINMUX_IPSR_GPSR(IP3_7_4,       A10),
-       PINMUX_IPSR_MSEL(IP3_7_4,       MSIOF2_RXD_A,           SEL_MSIOF2_0),
-       PINMUX_IPSR_MSEL(IP3_7_4,       RTS4_N_B,               SEL_SCIF4_1),
-       PINMUX_IPSR_GPSR(IP3_7_4,       VI5_HSYNC_N),
-
-       PINMUX_IPSR_GPSR(IP3_11_8,      A11),
-       PINMUX_IPSR_MSEL(IP3_11_8,      TX3_B,                  SEL_SCIF3_1),
-       PINMUX_IPSR_MSEL(IP3_11_8,      MSIOF2_TXD_A,           SEL_MSIOF2_0),
-       PINMUX_IPSR_MSEL(IP3_11_8,      HTX4_B,                 SEL_HSCIF4_1),
-       PINMUX_IPSR_GPSR(IP3_11_8,      HSCK4),
-       PINMUX_IPSR_GPSR(IP3_11_8,      VI5_FIELD),
-       PINMUX_IPSR_MSEL(IP3_11_8,      SCL6_A,                 SEL_I2C6_0),
-       PINMUX_IPSR_MSEL(IP3_11_8,      AVB_AVTP_CAPTURE_B,     SEL_ETHERAVB_1),
-       PINMUX_IPSR_MSEL(IP3_11_8,      PWM2_B,                 SEL_PWM2_1),
-
-       PINMUX_IPSR_GPSR(IP3_15_12,     A12),
-       PINMUX_IPSR_GPSR(IP3_15_12,     LCDOUT12),
-       PINMUX_IPSR_MSEL(IP3_15_12,     MSIOF3_SCK_C,           SEL_MSIOF3_2),
-       PINMUX_IPSR_MSEL(IP3_15_12,     HRX4_A,                 SEL_HSCIF4_0),
-       PINMUX_IPSR_GPSR(IP3_15_12,     VI5_DATA8),
-       PINMUX_IPSR_GPSR(IP3_15_12,     DU_DG4),
-
-       PINMUX_IPSR_GPSR(IP3_19_16,     A13),
-       PINMUX_IPSR_GPSR(IP3_19_16,     LCDOUT13),
-       PINMUX_IPSR_MSEL(IP3_19_16,     MSIOF3_SYNC_C,          SEL_MSIOF3_2),
-       PINMUX_IPSR_MSEL(IP3_19_16,     HTX4_A,                 SEL_HSCIF4_0),
-       PINMUX_IPSR_GPSR(IP3_19_16,     VI5_DATA9),
-       PINMUX_IPSR_GPSR(IP3_19_16,     DU_DG5),
-
-       PINMUX_IPSR_GPSR(IP3_23_20,     A14),
-       PINMUX_IPSR_GPSR(IP3_23_20,     LCDOUT14),
-       PINMUX_IPSR_MSEL(IP3_23_20,     MSIOF3_RXD_C,           SEL_MSIOF3_2),
-       PINMUX_IPSR_GPSR(IP3_23_20,     HCTS4_N),
-       PINMUX_IPSR_GPSR(IP3_23_20,     VI5_DATA10),
-       PINMUX_IPSR_GPSR(IP3_23_20,     DU_DG6),
-
-       PINMUX_IPSR_GPSR(IP3_27_24,     A15),
-       PINMUX_IPSR_GPSR(IP3_27_24,     LCDOUT15),
-       PINMUX_IPSR_MSEL(IP3_27_24,     MSIOF3_TXD_C,           SEL_MSIOF3_2),
-       PINMUX_IPSR_GPSR(IP3_27_24,     HRTS4_N),
-       PINMUX_IPSR_GPSR(IP3_27_24,     VI5_DATA11),
-       PINMUX_IPSR_GPSR(IP3_27_24,     DU_DG7),
-
-       PINMUX_IPSR_GPSR(IP3_31_28,     A16),
-       PINMUX_IPSR_GPSR(IP3_31_28,     LCDOUT8),
-       PINMUX_IPSR_GPSR(IP3_31_28,     VI4_FIELD),
-       PINMUX_IPSR_GPSR(IP3_31_28,     DU_DG0),
-
-       /* IPSR4 */
-       PINMUX_IPSR_GPSR(IP4_3_0,       A17),
-       PINMUX_IPSR_GPSR(IP4_3_0,       LCDOUT9),
-       PINMUX_IPSR_GPSR(IP4_3_0,       VI4_VSYNC_N),
-       PINMUX_IPSR_GPSR(IP4_3_0,       DU_DG1),
-
-       PINMUX_IPSR_GPSR(IP4_7_4,       A18),
-       PINMUX_IPSR_GPSR(IP4_7_4,       LCDOUT10),
-       PINMUX_IPSR_GPSR(IP4_7_4,       VI4_HSYNC_N),
-       PINMUX_IPSR_GPSR(IP4_7_4,       DU_DG2),
-
-       PINMUX_IPSR_GPSR(IP4_11_8,      A19),
-       PINMUX_IPSR_GPSR(IP4_11_8,      LCDOUT11),
-       PINMUX_IPSR_GPSR(IP4_11_8,      VI4_CLKENB),
-       PINMUX_IPSR_GPSR(IP4_11_8,      DU_DG3),
-
-       PINMUX_IPSR_GPSR(IP4_15_12,     CS0_N),
-       PINMUX_IPSR_GPSR(IP4_15_12,     VI5_CLKENB),
-
-       PINMUX_IPSR_GPSR(IP4_19_16,     CS1_N_A26),
-       PINMUX_IPSR_GPSR(IP4_19_16,     VI5_CLK),
-       PINMUX_IPSR_MSEL(IP4_19_16,     EX_WAIT0_B,             SEL_LBSC_1),
-
-       PINMUX_IPSR_GPSR(IP4_23_20,     BS_N),
-       PINMUX_IPSR_GPSR(IP4_23_20,     QSTVA_QVS),
-       PINMUX_IPSR_MSEL(IP4_23_20,     MSIOF3_SCK_D,           SEL_MSIOF3_3),
-       PINMUX_IPSR_GPSR(IP4_23_20,     SCK3),
-       PINMUX_IPSR_GPSR(IP4_23_20,     HSCK3),
-       PINMUX_IPSR_GPSR(IP4_23_20,     CAN1_TX),
-       PINMUX_IPSR_GPSR(IP4_23_20,     CANFD1_TX),
-       PINMUX_IPSR_MSEL(IP4_23_20,     IETX_A,                 SEL_IEBUS_0),
-
-       PINMUX_IPSR_GPSR(IP4_27_24,     RD_N),
-       PINMUX_IPSR_MSEL(IP4_27_24,     MSIOF3_SYNC_D,          SEL_MSIOF3_3),
-       PINMUX_IPSR_MSEL(IP4_27_24,     RX3_A,                  SEL_SCIF3_0),
-       PINMUX_IPSR_MSEL(IP4_27_24,     HRX3_A,                 SEL_HSCIF3_0),
-       PINMUX_IPSR_MSEL(IP4_27_24,     CAN0_TX_A,              SEL_RCAN0_0),
-       PINMUX_IPSR_MSEL(IP4_27_24,     CANFD0_TX_A,            SEL_CANFD0_0),
-
-       PINMUX_IPSR_GPSR(IP4_31_28,     RD_WR_N),
-       PINMUX_IPSR_MSEL(IP4_31_28,     MSIOF3_RXD_D,           SEL_MSIOF3_3),
-       PINMUX_IPSR_MSEL(IP4_31_28,     TX3_A,                  SEL_SCIF3_0),
-       PINMUX_IPSR_MSEL(IP4_31_28,     HTX3_A,                 SEL_HSCIF3_0),
-       PINMUX_IPSR_MSEL(IP4_31_28,     CAN0_RX_A,              SEL_RCAN0_0),
-       PINMUX_IPSR_MSEL(IP4_31_28,     CANFD0_RX_A,            SEL_CANFD0_0),
-
-       /* IPSR5 */
-       PINMUX_IPSR_GPSR(IP5_3_0,       WE0_N),
-       PINMUX_IPSR_MSEL(IP5_3_0,       MSIOF3_TXD_D,           SEL_MSIOF3_3),
-       PINMUX_IPSR_GPSR(IP5_3_0,       CTS3_N),
-       PINMUX_IPSR_GPSR(IP5_3_0,       HCTS3_N),
-       PINMUX_IPSR_MSEL(IP5_3_0,       SCL6_B,                 SEL_I2C6_1),
-       PINMUX_IPSR_GPSR(IP5_3_0,       CAN_CLK),
-       PINMUX_IPSR_MSEL(IP5_3_0,       IECLK_A,                SEL_IEBUS_0),
-
-       PINMUX_IPSR_GPSR(IP5_7_4,       WE1_N),
-       PINMUX_IPSR_MSEL(IP5_7_4,       MSIOF3_SS1_D,           SEL_MSIOF3_3),
-       PINMUX_IPSR_GPSR(IP5_7_4,       RTS3_N),
-       PINMUX_IPSR_GPSR(IP5_7_4,       HRTS3_N),
-       PINMUX_IPSR_MSEL(IP5_7_4,       SDA6_B,                 SEL_I2C6_1),
-       PINMUX_IPSR_GPSR(IP5_7_4,       CAN1_RX),
-       PINMUX_IPSR_GPSR(IP5_7_4,       CANFD1_RX),
-       PINMUX_IPSR_MSEL(IP5_7_4,       IERX_A,                 SEL_IEBUS_0),
-
-       PINMUX_IPSR_MSEL(IP5_11_8,      EX_WAIT0_A,             SEL_LBSC_0),
-       PINMUX_IPSR_GPSR(IP5_11_8,      QCLK),
-       PINMUX_IPSR_GPSR(IP5_11_8,      VI4_CLK),
-       PINMUX_IPSR_GPSR(IP5_11_8,      DU_DOTCLKOUT0),
-
-       PINMUX_IPSR_GPSR(IP5_15_12,     D0),
-       PINMUX_IPSR_MSEL(IP5_15_12,     MSIOF2_SS1_B,           SEL_MSIOF2_1),
-       PINMUX_IPSR_MSEL(IP5_15_12,     MSIOF3_SCK_A,           SEL_MSIOF3_0),
-       PINMUX_IPSR_GPSR(IP5_15_12,     VI4_DATA16),
-       PINMUX_IPSR_GPSR(IP5_15_12,     VI5_DATA0),
-
-       PINMUX_IPSR_GPSR(IP5_19_16,     D1),
-       PINMUX_IPSR_MSEL(IP5_19_16,     MSIOF2_SS2_B,           SEL_MSIOF2_1),
-       PINMUX_IPSR_MSEL(IP5_19_16,     MSIOF3_SYNC_A,          SEL_MSIOF3_0),
-       PINMUX_IPSR_GPSR(IP5_19_16,     VI4_DATA17),
-       PINMUX_IPSR_GPSR(IP5_19_16,     VI5_DATA1),
-
-       PINMUX_IPSR_GPSR(IP5_23_20,     D2),
-       PINMUX_IPSR_MSEL(IP5_23_20,     MSIOF3_RXD_A,           SEL_MSIOF3_0),
-       PINMUX_IPSR_GPSR(IP5_23_20,     VI4_DATA18),
-       PINMUX_IPSR_GPSR(IP5_23_20,     VI5_DATA2),
-
-       PINMUX_IPSR_GPSR(IP5_27_24,     D3),
-       PINMUX_IPSR_MSEL(IP5_27_24,     MSIOF3_TXD_A,           SEL_MSIOF3_0),
-       PINMUX_IPSR_GPSR(IP5_27_24,     VI4_DATA19),
-       PINMUX_IPSR_GPSR(IP5_27_24,     VI5_DATA3),
-
-       PINMUX_IPSR_GPSR(IP5_31_28,     D4),
-       PINMUX_IPSR_MSEL(IP5_31_28,     MSIOF2_SCK_B,           SEL_MSIOF2_1),
-       PINMUX_IPSR_GPSR(IP5_31_28,     VI4_DATA20),
-       PINMUX_IPSR_GPSR(IP5_31_28,     VI5_DATA4),
-
-       /* IPSR6 */
-       PINMUX_IPSR_GPSR(IP6_3_0,       D5),
-       PINMUX_IPSR_MSEL(IP6_3_0,       MSIOF2_SYNC_B,          SEL_MSIOF2_1),
-       PINMUX_IPSR_GPSR(IP6_3_0,       VI4_DATA21),
-       PINMUX_IPSR_GPSR(IP6_3_0,       VI5_DATA5),
-
-       PINMUX_IPSR_GPSR(IP6_7_4,       D6),
-       PINMUX_IPSR_MSEL(IP6_7_4,       MSIOF2_RXD_B,           SEL_MSIOF2_1),
-       PINMUX_IPSR_GPSR(IP6_7_4,       VI4_DATA22),
-       PINMUX_IPSR_GPSR(IP6_7_4,       VI5_DATA6),
-
-       PINMUX_IPSR_GPSR(IP6_11_8,      D7),
-       PINMUX_IPSR_MSEL(IP6_11_8,      MSIOF2_TXD_B,           SEL_MSIOF2_1),
-       PINMUX_IPSR_GPSR(IP6_11_8,      VI4_DATA23),
-       PINMUX_IPSR_GPSR(IP6_11_8,      VI5_DATA7),
-
-       PINMUX_IPSR_GPSR(IP6_15_12,     D8),
-       PINMUX_IPSR_GPSR(IP6_15_12,     LCDOUT0),
-       PINMUX_IPSR_MSEL(IP6_15_12,     MSIOF2_SCK_D,           SEL_MSIOF2_3),
-       PINMUX_IPSR_MSEL(IP6_15_12,     SCK4_C,                 SEL_SCIF4_2),
-       PINMUX_IPSR_MSEL(IP6_15_12,     VI4_DATA0_A,            SEL_VIN4_0),
-       PINMUX_IPSR_GPSR(IP6_15_12,     DU_DR0),
-
-       PINMUX_IPSR_GPSR(IP6_19_16,     D9),
-       PINMUX_IPSR_GPSR(IP6_19_16,     LCDOUT1),
-       PINMUX_IPSR_MSEL(IP6_19_16,     MSIOF2_SYNC_D,          SEL_MSIOF2_3),
-       PINMUX_IPSR_MSEL(IP6_19_16,     VI4_DATA1_A,            SEL_VIN4_0),
-       PINMUX_IPSR_GPSR(IP6_19_16,     DU_DR1),
-
-       PINMUX_IPSR_GPSR(IP6_23_20,     D10),
-       PINMUX_IPSR_GPSR(IP6_23_20,     LCDOUT2),
-       PINMUX_IPSR_MSEL(IP6_23_20,     MSIOF2_RXD_D,           SEL_MSIOF2_3),
-       PINMUX_IPSR_MSEL(IP6_23_20,     HRX3_B,                 SEL_HSCIF3_1),
-       PINMUX_IPSR_MSEL(IP6_23_20,     VI4_DATA2_A,            SEL_VIN4_0),
-       PINMUX_IPSR_MSEL(IP6_23_20,     CTS4_N_C,               SEL_SCIF4_2),
-       PINMUX_IPSR_GPSR(IP6_23_20,     DU_DR2),
-
-       PINMUX_IPSR_GPSR(IP6_27_24,     D11),
-       PINMUX_IPSR_GPSR(IP6_27_24,     LCDOUT3),
-       PINMUX_IPSR_MSEL(IP6_27_24,     MSIOF2_TXD_D,           SEL_MSIOF2_3),
-       PINMUX_IPSR_MSEL(IP6_27_24,     HTX3_B,                 SEL_HSCIF3_1),
-       PINMUX_IPSR_MSEL(IP6_27_24,     VI4_DATA3_A,            SEL_VIN4_0),
-       PINMUX_IPSR_MSEL(IP6_27_24,     RTS4_N_C,               SEL_SCIF4_2),
-       PINMUX_IPSR_GPSR(IP6_27_24,     DU_DR3),
-
-       PINMUX_IPSR_GPSR(IP6_31_28,     D12),
-       PINMUX_IPSR_GPSR(IP6_31_28,     LCDOUT4),
-       PINMUX_IPSR_MSEL(IP6_31_28,     MSIOF2_SS1_D,           SEL_MSIOF2_3),
-       PINMUX_IPSR_MSEL(IP6_31_28,     RX4_C,                  SEL_SCIF4_2),
-       PINMUX_IPSR_MSEL(IP6_31_28,     VI4_DATA4_A,            SEL_VIN4_0),
-       PINMUX_IPSR_GPSR(IP6_31_28,     DU_DR4),
-
-       /* IPSR7 */
-       PINMUX_IPSR_GPSR(IP7_3_0,       D13),
-       PINMUX_IPSR_GPSR(IP7_3_0,       LCDOUT5),
-       PINMUX_IPSR_MSEL(IP7_3_0,       MSIOF2_SS2_D,           SEL_MSIOF2_3),
-       PINMUX_IPSR_MSEL(IP7_3_0,       TX4_C,                  SEL_SCIF4_2),
-       PINMUX_IPSR_MSEL(IP7_3_0,       VI4_DATA5_A,            SEL_VIN4_0),
-       PINMUX_IPSR_GPSR(IP7_3_0,       DU_DR5),
-
-       PINMUX_IPSR_GPSR(IP7_7_4,       D14),
-       PINMUX_IPSR_GPSR(IP7_7_4,       LCDOUT6),
-       PINMUX_IPSR_MSEL(IP7_7_4,       MSIOF3_SS1_A,           SEL_MSIOF3_0),
-       PINMUX_IPSR_MSEL(IP7_7_4,       HRX3_C,                 SEL_HSCIF3_2),
-       PINMUX_IPSR_MSEL(IP7_7_4,       VI4_DATA6_A,            SEL_VIN4_0),
-       PINMUX_IPSR_GPSR(IP7_7_4,       DU_DR6),
-       PINMUX_IPSR_MSEL(IP7_7_4,       SCL6_C,                 SEL_I2C6_2),
-
-       PINMUX_IPSR_GPSR(IP7_11_8,      D15),
-       PINMUX_IPSR_GPSR(IP7_11_8,      LCDOUT7),
-       PINMUX_IPSR_MSEL(IP7_11_8,      MSIOF3_SS2_A,           SEL_MSIOF3_0),
-       PINMUX_IPSR_MSEL(IP7_11_8,      HTX3_C,                 SEL_HSCIF3_2),
-       PINMUX_IPSR_MSEL(IP7_11_8,      VI4_DATA7_A,            SEL_VIN4_0),
-       PINMUX_IPSR_GPSR(IP7_11_8,      DU_DR7),
-       PINMUX_IPSR_MSEL(IP7_11_8,      SDA6_C,                 SEL_I2C6_2),
-
-       PINMUX_IPSR_GPSR(IP7_15_12,     FSCLKST),
-
-       PINMUX_IPSR_GPSR(IP7_19_16,     SD0_CLK),
-       PINMUX_IPSR_MSEL(IP7_19_16,     MSIOF1_SCK_E,           SEL_MSIOF1_4),
-       PINMUX_IPSR_MSEL(IP7_19_16,     STP_OPWM_0_B,           SEL_SSP1_0_1),
-
-       PINMUX_IPSR_GPSR(IP7_23_20,     SD0_CMD),
-       PINMUX_IPSR_MSEL(IP7_23_20,     MSIOF1_SYNC_E,          SEL_MSIOF1_4),
-       PINMUX_IPSR_MSEL(IP7_23_20,     STP_IVCXO27_0_B,        SEL_SSP1_0_1),
-
-       PINMUX_IPSR_GPSR(IP7_27_24,     SD0_DAT0),
-       PINMUX_IPSR_MSEL(IP7_27_24,     MSIOF1_RXD_E,           SEL_MSIOF1_4),
-       PINMUX_IPSR_MSEL(IP7_27_24,     TS_SCK0_B,              SEL_TSIF0_1),
-       PINMUX_IPSR_MSEL(IP7_27_24,     STP_ISCLK_0_B,          SEL_SSP1_0_1),
-
-       PINMUX_IPSR_GPSR(IP7_31_28,     SD0_DAT1),
-       PINMUX_IPSR_MSEL(IP7_31_28,     MSIOF1_TXD_E,           SEL_MSIOF1_4),
-       PINMUX_IPSR_MSEL(IP7_31_28,     TS_SPSYNC0_B,           SEL_TSIF0_1),
-       PINMUX_IPSR_MSEL(IP7_31_28,     STP_ISSYNC_0_B,         SEL_SSP1_0_1),
-
-       /* IPSR8 */
-       PINMUX_IPSR_GPSR(IP8_3_0,       SD0_DAT2),
-       PINMUX_IPSR_MSEL(IP8_3_0,       MSIOF1_SS1_E,           SEL_MSIOF1_4),
-       PINMUX_IPSR_MSEL(IP8_3_0,       TS_SDAT0_B,             SEL_TSIF0_1),
-       PINMUX_IPSR_MSEL(IP8_3_0,       STP_ISD_0_B,            SEL_SSP1_0_1),
-
-       PINMUX_IPSR_GPSR(IP8_7_4,       SD0_DAT3),
-       PINMUX_IPSR_MSEL(IP8_7_4,       MSIOF1_SS2_E,           SEL_MSIOF1_4),
-       PINMUX_IPSR_MSEL(IP8_7_4,       TS_SDEN0_B,             SEL_TSIF0_1),
-       PINMUX_IPSR_MSEL(IP8_7_4,       STP_ISEN_0_B,           SEL_SSP1_0_1),
-
-       PINMUX_IPSR_GPSR(IP8_11_8,      SD1_CLK),
-       PINMUX_IPSR_MSEL(IP8_11_8,      MSIOF1_SCK_G,           SEL_MSIOF1_6),
-       PINMUX_IPSR_MSEL(IP8_11_8,      SIM0_CLK_A,             SEL_SIMCARD_0),
-
-       PINMUX_IPSR_GPSR(IP8_15_12,     SD1_CMD),
-       PINMUX_IPSR_MSEL(IP8_15_12,     MSIOF1_SYNC_G,          SEL_MSIOF1_6),
-       PINMUX_IPSR_MSEL(IP8_15_12,     SIM0_D_A,               SEL_SIMCARD_0),
-       PINMUX_IPSR_MSEL(IP8_15_12,     STP_IVCXO27_1_B,        SEL_SSP1_1_1),
-
-       PINMUX_IPSR_GPSR(IP8_19_16,     SD1_DAT0),
-       PINMUX_IPSR_GPSR(IP8_19_16,     SD2_DAT4),
-       PINMUX_IPSR_MSEL(IP8_19_16,     MSIOF1_RXD_G,           SEL_MSIOF1_6),
-       PINMUX_IPSR_MSEL(IP8_19_16,     TS_SCK1_B,              SEL_TSIF1_1),
-       PINMUX_IPSR_MSEL(IP8_19_16,     STP_ISCLK_1_B,          SEL_SSP1_1_1),
-
-       PINMUX_IPSR_GPSR(IP8_23_20,     SD1_DAT1),
-       PINMUX_IPSR_GPSR(IP8_23_20,     SD2_DAT5),
-       PINMUX_IPSR_MSEL(IP8_23_20,     MSIOF1_TXD_G,           SEL_MSIOF1_6),
-       PINMUX_IPSR_MSEL(IP8_23_20,     TS_SPSYNC1_B,           SEL_TSIF1_1),
-       PINMUX_IPSR_MSEL(IP8_23_20,     STP_ISSYNC_1_B,         SEL_SSP1_1_1),
-
-       PINMUX_IPSR_GPSR(IP8_27_24,     SD1_DAT2),
-       PINMUX_IPSR_GPSR(IP8_27_24,     SD2_DAT6),
-       PINMUX_IPSR_MSEL(IP8_27_24,     MSIOF1_SS1_G,           SEL_MSIOF1_6),
-       PINMUX_IPSR_MSEL(IP8_27_24,     TS_SDAT1_B,             SEL_TSIF1_1),
-       PINMUX_IPSR_MSEL(IP8_27_24,     STP_ISD_1_B,            SEL_SSP1_1_1),
-
-       PINMUX_IPSR_GPSR(IP8_31_28,     SD1_DAT3),
-       PINMUX_IPSR_GPSR(IP8_31_28,     SD2_DAT7),
-       PINMUX_IPSR_MSEL(IP8_31_28,     MSIOF1_SS2_G,           SEL_MSIOF1_6),
-       PINMUX_IPSR_MSEL(IP8_31_28,     TS_SDEN1_B,             SEL_TSIF1_1),
-       PINMUX_IPSR_MSEL(IP8_31_28,     STP_ISEN_1_B,           SEL_SSP1_1_1),
-
-       /* IPSR9 */
-       PINMUX_IPSR_GPSR(IP9_3_0,       SD2_CLK),
-
-       PINMUX_IPSR_GPSR(IP9_7_4,       SD2_DAT0),
-
-       PINMUX_IPSR_GPSR(IP9_11_8,      SD2_DAT1),
-
-       PINMUX_IPSR_GPSR(IP9_15_12,     SD2_DAT2),
-
-       PINMUX_IPSR_GPSR(IP9_19_16,     SD2_DAT3),
-
-       PINMUX_IPSR_GPSR(IP9_23_20,     SD2_DS),
-       PINMUX_IPSR_MSEL(IP9_23_20,     SATA_DEVSLP_B,          SEL_SATA_1),
-
-       PINMUX_IPSR_GPSR(IP9_27_24,     SD3_DAT4),
-       PINMUX_IPSR_MSEL(IP9_27_24,     SD2_CD_A,               SEL_SDHI2_0),
-
-       PINMUX_IPSR_GPSR(IP9_31_28,     SD3_DAT5),
-       PINMUX_IPSR_MSEL(IP9_31_28,     SD2_WP_A,               SEL_SDHI2_0),
-
-       /* IPSR10 */
-       PINMUX_IPSR_GPSR(IP10_3_0,      SD3_DAT6),
-       PINMUX_IPSR_GPSR(IP10_3_0,      SD3_CD),
-
-       PINMUX_IPSR_GPSR(IP10_7_4,      SD3_DAT7),
-       PINMUX_IPSR_GPSR(IP10_7_4,      SD3_WP),
-
-       PINMUX_IPSR_GPSR(IP10_11_8,     SD0_CD),
-       PINMUX_IPSR_MSEL(IP10_11_8,     SCL2_B,                 SEL_I2C2_1),
-       PINMUX_IPSR_MSEL(IP10_11_8,     SIM0_RST_A,             SEL_SIMCARD_0),
-
-       PINMUX_IPSR_GPSR(IP10_15_12,    SD0_WP),
-       PINMUX_IPSR_MSEL(IP10_15_12,    SDA2_B,                 SEL_I2C2_1),
-
-       PINMUX_IPSR_MSEL(IP10_19_16,    SD1_CD,                 I2C_SEL_0_0),
-       PINMUX_IPSR_PHYS_MSEL(IP10_19_16, SIM0_CLK_B,           I2C_SEL_0_0,    SEL_SIMCARD_1),
-       PINMUX_IPSR_PHYS(IP10_19_16,    SCL0,                   I2C_SEL_0_1),
-
-       PINMUX_IPSR_MSEL(IP10_23_20,    SD1_WP,                 I2C_SEL_0_0),
-       PINMUX_IPSR_PHYS_MSEL(IP10_23_20, SIM0_D_B,             I2C_SEL_0_0,    SEL_SIMCARD_1),
-       PINMUX_IPSR_PHYS(IP10_23_20,    SDA0,                   I2C_SEL_0_1),
-
-       PINMUX_IPSR_GPSR(IP10_27_24,    SCK0),
-       PINMUX_IPSR_MSEL(IP10_27_24,    HSCK1_B,                SEL_HSCIF1_1),
-       PINMUX_IPSR_MSEL(IP10_27_24,    MSIOF1_SS2_B,           SEL_MSIOF1_1),
-       PINMUX_IPSR_MSEL(IP10_27_24,    AUDIO_CLKC_B,           SEL_ADG_1),
-       PINMUX_IPSR_MSEL(IP10_27_24,    SDA2_A,                 SEL_I2C2_0),
-       PINMUX_IPSR_MSEL(IP10_27_24,    SIM0_RST_B,             SEL_SIMCARD_1),
-       PINMUX_IPSR_MSEL(IP10_27_24,    STP_OPWM_0_C,           SEL_SSP1_0_2),
-       PINMUX_IPSR_MSEL(IP10_27_24,    RIF0_CLK_B,             SEL_DRIF0_1),
-       PINMUX_IPSR_GPSR(IP10_27_24,    ADICHS2),
-
-       PINMUX_IPSR_GPSR(IP10_31_28,    RX0),
-       PINMUX_IPSR_MSEL(IP10_31_28,    HRX1_B,                 SEL_HSCIF1_1),
-       PINMUX_IPSR_MSEL(IP10_31_28,    TS_SCK0_C,              SEL_TSIF0_2),
-       PINMUX_IPSR_MSEL(IP10_31_28,    STP_ISCLK_0_C,          SEL_SSP1_0_2),
-       PINMUX_IPSR_MSEL(IP10_31_28,    RIF0_D0_B,              SEL_DRIF0_1),
-
-       /* IPSR11 */
-       PINMUX_IPSR_GPSR(IP11_3_0,      TX0),
-       PINMUX_IPSR_MSEL(IP11_3_0,      HTX1_B,                 SEL_HSCIF1_1),
-       PINMUX_IPSR_MSEL(IP11_3_0,      TS_SPSYNC0_C,           SEL_TSIF0_2),
-       PINMUX_IPSR_MSEL(IP11_3_0,      STP_ISSYNC_0_C,         SEL_SSP1_0_2),
-       PINMUX_IPSR_MSEL(IP11_3_0,      RIF0_D1_B,              SEL_DRIF0_1),
-
-       PINMUX_IPSR_GPSR(IP11_7_4,      CTS0_N),
-       PINMUX_IPSR_MSEL(IP11_7_4,      HCTS1_N_B,              SEL_HSCIF1_1),
-       PINMUX_IPSR_MSEL(IP11_7_4,      MSIOF1_SYNC_B,          SEL_MSIOF1_1),
-       PINMUX_IPSR_MSEL(IP11_7_4,      TS_SPSYNC1_C,           SEL_TSIF1_2),
-       PINMUX_IPSR_MSEL(IP11_7_4,      STP_ISSYNC_1_C,         SEL_SSP1_1_2),
-       PINMUX_IPSR_MSEL(IP11_7_4,      RIF1_SYNC_B,            SEL_DRIF1_1),
-       PINMUX_IPSR_MSEL(IP11_7_4,      AUDIO_CLKOUT_C,         SEL_ADG_2),
-       PINMUX_IPSR_GPSR(IP11_7_4,      ADICS_SAMP),
-
-       PINMUX_IPSR_GPSR(IP11_11_8,     RTS0_N),
-       PINMUX_IPSR_MSEL(IP11_11_8,     HRTS1_N_B,              SEL_HSCIF1_1),
-       PINMUX_IPSR_MSEL(IP11_11_8,     MSIOF1_SS1_B,           SEL_MSIOF1_1),
-       PINMUX_IPSR_MSEL(IP11_11_8,     AUDIO_CLKA_B,           SEL_ADG_1),
-       PINMUX_IPSR_MSEL(IP11_11_8,     SCL2_A,                 SEL_I2C2_0),
-       PINMUX_IPSR_MSEL(IP11_11_8,     STP_IVCXO27_1_C,        SEL_SSP1_1_2),
-       PINMUX_IPSR_MSEL(IP11_11_8,     RIF0_SYNC_B,            SEL_DRIF0_1),
-       PINMUX_IPSR_GPSR(IP11_11_8,     ADICHS1),
-
-       PINMUX_IPSR_MSEL(IP11_15_12,    RX1_A,                  SEL_SCIF1_0),
-       PINMUX_IPSR_MSEL(IP11_15_12,    HRX1_A,                 SEL_HSCIF1_0),
-       PINMUX_IPSR_MSEL(IP11_15_12,    TS_SDAT0_C,             SEL_TSIF0_2),
-       PINMUX_IPSR_MSEL(IP11_15_12,    STP_ISD_0_C,            SEL_SSP1_0_2),
-       PINMUX_IPSR_MSEL(IP11_15_12,    RIF1_CLK_C,             SEL_DRIF1_2),
-
-       PINMUX_IPSR_MSEL(IP11_19_16,    TX1_A,                  SEL_SCIF1_0),
-       PINMUX_IPSR_MSEL(IP11_19_16,    HTX1_A,                 SEL_HSCIF1_0),
-       PINMUX_IPSR_MSEL(IP11_19_16,    TS_SDEN0_C,             SEL_TSIF0_2),
-       PINMUX_IPSR_MSEL(IP11_19_16,    STP_ISEN_0_C,           SEL_SSP1_0_2),
-       PINMUX_IPSR_MSEL(IP11_19_16,    RIF1_D0_C,              SEL_DRIF1_2),
-
-       PINMUX_IPSR_GPSR(IP11_23_20,    CTS1_N),
-       PINMUX_IPSR_MSEL(IP11_23_20,    HCTS1_N_A,              SEL_HSCIF1_0),
-       PINMUX_IPSR_MSEL(IP11_23_20,    MSIOF1_RXD_B,           SEL_MSIOF1_1),
-       PINMUX_IPSR_MSEL(IP11_23_20,    TS_SDEN1_C,             SEL_TSIF1_2),
-       PINMUX_IPSR_MSEL(IP11_23_20,    STP_ISEN_1_C,           SEL_SSP1_1_2),
-       PINMUX_IPSR_MSEL(IP11_23_20,    RIF1_D0_B,              SEL_DRIF1_1),
-       PINMUX_IPSR_GPSR(IP11_23_20,    ADIDATA),
-
-       PINMUX_IPSR_GPSR(IP11_27_24,    RTS1_N),
-       PINMUX_IPSR_MSEL(IP11_27_24,    HRTS1_N_A,              SEL_HSCIF1_0),
-       PINMUX_IPSR_MSEL(IP11_27_24,    MSIOF1_TXD_B,           SEL_MSIOF1_1),
-       PINMUX_IPSR_MSEL(IP11_27_24,    TS_SDAT1_C,             SEL_TSIF1_2),
-       PINMUX_IPSR_MSEL(IP11_27_24,    STP_ISD_1_C,            SEL_SSP1_1_2),
-       PINMUX_IPSR_MSEL(IP11_27_24,    RIF1_D1_B,              SEL_DRIF1_1),
-       PINMUX_IPSR_GPSR(IP11_27_24,    ADICHS0),
-
-       PINMUX_IPSR_GPSR(IP11_31_28,    SCK2),
-       PINMUX_IPSR_MSEL(IP11_31_28,    SCIF_CLK_B,             SEL_SCIF1_1),
-       PINMUX_IPSR_MSEL(IP11_31_28,    MSIOF1_SCK_B,           SEL_MSIOF1_1),
-       PINMUX_IPSR_MSEL(IP11_31_28,    TS_SCK1_C,              SEL_TSIF1_2),
-       PINMUX_IPSR_MSEL(IP11_31_28,    STP_ISCLK_1_C,          SEL_SSP1_1_2),
-       PINMUX_IPSR_MSEL(IP11_31_28,    RIF1_CLK_B,             SEL_DRIF1_1),
-       PINMUX_IPSR_GPSR(IP11_31_28,    ADICLK),
-
-       /* IPSR12 */
-       PINMUX_IPSR_MSEL(IP12_3_0,      TX2_A,                  SEL_SCIF2_0),
-       PINMUX_IPSR_MSEL(IP12_3_0,      SD2_CD_B,               SEL_SDHI2_1),
-       PINMUX_IPSR_MSEL(IP12_3_0,      SCL1_A,                 SEL_I2C1_0),
-       PINMUX_IPSR_MSEL(IP12_3_0,      FMCLK_A,                SEL_FM_0),
-       PINMUX_IPSR_MSEL(IP12_3_0,      RIF1_D1_C,              SEL_DRIF1_2),
-       PINMUX_IPSR_MSEL(IP12_3_0,      FSO_CFE_0_B,            SEL_FSO_1),
-
-       PINMUX_IPSR_MSEL(IP12_7_4,      RX2_A,                  SEL_SCIF2_0),
-       PINMUX_IPSR_MSEL(IP12_7_4,      SD2_WP_B,               SEL_SDHI2_1),
-       PINMUX_IPSR_MSEL(IP12_7_4,      SDA1_A,                 SEL_I2C1_0),
-       PINMUX_IPSR_MSEL(IP12_7_4,      FMIN_A,                 SEL_FM_0),
-       PINMUX_IPSR_MSEL(IP12_7_4,      RIF1_SYNC_C,            SEL_DRIF1_2),
-       PINMUX_IPSR_MSEL(IP12_7_4,      FSO_CFE_1_B,            SEL_FSO_1),
-
-       PINMUX_IPSR_GPSR(IP12_11_8,     HSCK0),
-       PINMUX_IPSR_MSEL(IP12_11_8,     MSIOF1_SCK_D,           SEL_MSIOF1_3),
-       PINMUX_IPSR_MSEL(IP12_11_8,     AUDIO_CLKB_A,           SEL_ADG_0),
-       PINMUX_IPSR_MSEL(IP12_11_8,     SSI_SDATA1_B,           SEL_SSI_1),
-       PINMUX_IPSR_MSEL(IP12_11_8,     TS_SCK0_D,              SEL_TSIF0_3),
-       PINMUX_IPSR_MSEL(IP12_11_8,     STP_ISCLK_0_D,          SEL_SSP1_0_3),
-       PINMUX_IPSR_MSEL(IP12_11_8,     RIF0_CLK_C,             SEL_DRIF0_2),
-
-       PINMUX_IPSR_GPSR(IP12_15_12,    HRX0),
-       PINMUX_IPSR_MSEL(IP12_15_12,    MSIOF1_RXD_D,           SEL_MSIOF1_3),
-       PINMUX_IPSR_MSEL(IP12_15_12,    SSI_SDATA2_B,           SEL_SSI_1),
-       PINMUX_IPSR_MSEL(IP12_15_12,    TS_SDEN0_D,             SEL_TSIF0_3),
-       PINMUX_IPSR_MSEL(IP12_15_12,    STP_ISEN_0_D,           SEL_SSP1_0_3),
-       PINMUX_IPSR_MSEL(IP12_15_12,    RIF0_D0_C,              SEL_DRIF0_2),
-
-       PINMUX_IPSR_GPSR(IP12_19_16,    HTX0),
-       PINMUX_IPSR_MSEL(IP12_19_16,    MSIOF1_TXD_D,           SEL_MSIOF1_3),
-       PINMUX_IPSR_MSEL(IP12_19_16,    SSI_SDATA9_B,           SEL_SSI_1),
-       PINMUX_IPSR_MSEL(IP12_19_16,    TS_SDAT0_D,             SEL_TSIF0_3),
-       PINMUX_IPSR_MSEL(IP12_19_16,    STP_ISD_0_D,            SEL_SSP1_0_3),
-       PINMUX_IPSR_MSEL(IP12_19_16,    RIF0_D1_C,              SEL_DRIF0_2),
-
-       PINMUX_IPSR_GPSR(IP12_23_20,    HCTS0_N),
-       PINMUX_IPSR_MSEL(IP12_23_20,    RX2_B,                  SEL_SCIF2_1),
-       PINMUX_IPSR_MSEL(IP12_23_20,    MSIOF1_SYNC_D,          SEL_MSIOF1_3),
-       PINMUX_IPSR_MSEL(IP12_23_20,    SSI_SCK9_A,             SEL_SSI_0),
-       PINMUX_IPSR_MSEL(IP12_23_20,    TS_SPSYNC0_D,           SEL_TSIF0_3),
-       PINMUX_IPSR_MSEL(IP12_23_20,    STP_ISSYNC_0_D,         SEL_SSP1_0_3),
-       PINMUX_IPSR_MSEL(IP12_23_20,    RIF0_SYNC_C,            SEL_DRIF0_2),
-       PINMUX_IPSR_MSEL(IP12_23_20,    AUDIO_CLKOUT1_A,        SEL_ADG_0),
-
-       PINMUX_IPSR_GPSR(IP12_27_24,    HRTS0_N),
-       PINMUX_IPSR_MSEL(IP12_27_24,    TX2_B,                  SEL_SCIF2_1),
-       PINMUX_IPSR_MSEL(IP12_27_24,    MSIOF1_SS1_D,           SEL_MSIOF1_3),
-       PINMUX_IPSR_MSEL(IP12_27_24,    SSI_WS9_A,              SEL_SSI_0),
-       PINMUX_IPSR_MSEL(IP12_27_24,    STP_IVCXO27_0_D,        SEL_SSP1_0_3),
-       PINMUX_IPSR_MSEL(IP12_27_24,    BPFCLK_A,               SEL_FM_0),
-       PINMUX_IPSR_MSEL(IP12_27_24,    AUDIO_CLKOUT2_A,        SEL_ADG_0),
-
-       PINMUX_IPSR_GPSR(IP12_31_28,    MSIOF0_SYNC),
-       PINMUX_IPSR_MSEL(IP12_31_28,    AUDIO_CLKOUT_A,         SEL_ADG_0),
-
-       /* IPSR13 */
-       PINMUX_IPSR_GPSR(IP13_3_0,      MSIOF0_SS1),
-       PINMUX_IPSR_GPSR(IP13_3_0,      RX5),
-       PINMUX_IPSR_MSEL(IP13_3_0,      AUDIO_CLKA_C,           SEL_ADG_2),
-       PINMUX_IPSR_MSEL(IP13_3_0,      SSI_SCK2_A,             SEL_SSI_0),
-       PINMUX_IPSR_MSEL(IP13_3_0,      STP_IVCXO27_0_C,        SEL_SSP1_0_2),
-       PINMUX_IPSR_MSEL(IP13_3_0,      AUDIO_CLKOUT3_A,        SEL_ADG_0),
-       PINMUX_IPSR_MSEL(IP13_3_0,      TCLK1_B,                SEL_TIMER_TMU_1),
-
-       PINMUX_IPSR_GPSR(IP13_7_4,      MSIOF0_SS2),
-       PINMUX_IPSR_GPSR(IP13_7_4,      TX5),
-       PINMUX_IPSR_MSEL(IP13_7_4,      MSIOF1_SS2_D,           SEL_MSIOF1_3),
-       PINMUX_IPSR_MSEL(IP13_7_4,      AUDIO_CLKC_A,           SEL_ADG_0),
-       PINMUX_IPSR_MSEL(IP13_7_4,      SSI_WS2_A,              SEL_SSI_0),
-       PINMUX_IPSR_MSEL(IP13_7_4,      STP_OPWM_0_D,           SEL_SSP1_0_3),
-       PINMUX_IPSR_MSEL(IP13_7_4,      AUDIO_CLKOUT_D,         SEL_ADG_3),
-       PINMUX_IPSR_MSEL(IP13_7_4,      SPEEDIN_B,              SEL_SPEED_PULSE_1),
-
-       PINMUX_IPSR_GPSR(IP13_11_8,     MLB_CLK),
-       PINMUX_IPSR_MSEL(IP13_11_8,     MSIOF1_SCK_F,           SEL_MSIOF1_5),
-       PINMUX_IPSR_MSEL(IP13_11_8,     SCL1_B,                 SEL_I2C1_1),
-
-       PINMUX_IPSR_GPSR(IP13_15_12,    MLB_SIG),
-       PINMUX_IPSR_MSEL(IP13_15_12,    RX1_B,                  SEL_SCIF1_1),
-       PINMUX_IPSR_MSEL(IP13_15_12,    MSIOF1_SYNC_F,          SEL_MSIOF1_5),
-       PINMUX_IPSR_MSEL(IP13_15_12,    SDA1_B,                 SEL_I2C1_1),
-
-       PINMUX_IPSR_GPSR(IP13_19_16,    MLB_DAT),
-       PINMUX_IPSR_MSEL(IP13_19_16,    TX1_B,                  SEL_SCIF1_1),
-       PINMUX_IPSR_MSEL(IP13_19_16,    MSIOF1_RXD_F,           SEL_MSIOF1_5),
-
-       PINMUX_IPSR_GPSR(IP13_23_20,    SSI_SCK01239),
-       PINMUX_IPSR_MSEL(IP13_23_20,    MSIOF1_TXD_F,           SEL_MSIOF1_5),
-
-       PINMUX_IPSR_GPSR(IP13_27_24,    SSI_WS01239),
-       PINMUX_IPSR_MSEL(IP13_27_24,    MSIOF1_SS1_F,           SEL_MSIOF1_5),
-
-       PINMUX_IPSR_GPSR(IP13_31_28,    SSI_SDATA0),
-       PINMUX_IPSR_MSEL(IP13_31_28,    MSIOF1_SS2_F,           SEL_MSIOF1_5),
-
-       /* IPSR14 */
-       PINMUX_IPSR_MSEL(IP14_3_0,      SSI_SDATA1_A,           SEL_SSI_0),
-
-       PINMUX_IPSR_MSEL(IP14_7_4,      SSI_SDATA2_A,           SEL_SSI_0),
-       PINMUX_IPSR_MSEL(IP14_7_4,      SSI_SCK1_B,             SEL_SSI_1),
-
-       PINMUX_IPSR_GPSR(IP14_11_8,     SSI_SCK349),
-       PINMUX_IPSR_MSEL(IP14_11_8,     MSIOF1_SS1_A,           SEL_MSIOF1_0),
-       PINMUX_IPSR_MSEL(IP14_11_8,     STP_OPWM_0_A,           SEL_SSP1_0_0),
-
-       PINMUX_IPSR_GPSR(IP14_15_12,    SSI_WS349),
-       PINMUX_IPSR_MSEL(IP14_15_12,    HCTS2_N_A,              SEL_HSCIF2_0),
-       PINMUX_IPSR_MSEL(IP14_15_12,    MSIOF1_SS2_A,           SEL_MSIOF1_0),
-       PINMUX_IPSR_MSEL(IP14_15_12,    STP_IVCXO27_0_A,        SEL_SSP1_0_0),
-
-       PINMUX_IPSR_GPSR(IP14_19_16,    SSI_SDATA3),
-       PINMUX_IPSR_MSEL(IP14_19_16,    HRTS2_N_A,              SEL_HSCIF2_0),
-       PINMUX_IPSR_MSEL(IP14_19_16,    MSIOF1_TXD_A,           SEL_MSIOF1_0),
-       PINMUX_IPSR_MSEL(IP14_19_16,    TS_SCK0_A,              SEL_TSIF0_0),
-       PINMUX_IPSR_MSEL(IP14_19_16,    STP_ISCLK_0_A,          SEL_SSP1_0_0),
-       PINMUX_IPSR_MSEL(IP14_19_16,    RIF0_D1_A,              SEL_DRIF0_0),
-       PINMUX_IPSR_MSEL(IP14_19_16,    RIF2_D0_A,              SEL_DRIF2_0),
-
-       PINMUX_IPSR_GPSR(IP14_23_20,    SSI_SCK4),
-       PINMUX_IPSR_MSEL(IP14_23_20,    HRX2_A,                 SEL_HSCIF2_0),
-       PINMUX_IPSR_MSEL(IP14_23_20,    MSIOF1_SCK_A,           SEL_MSIOF1_0),
-       PINMUX_IPSR_MSEL(IP14_23_20,    TS_SDAT0_A,             SEL_TSIF0_0),
-       PINMUX_IPSR_MSEL(IP14_23_20,    STP_ISD_0_A,            SEL_SSP1_0_0),
-       PINMUX_IPSR_MSEL(IP14_23_20,    RIF0_CLK_A,             SEL_DRIF0_0),
-       PINMUX_IPSR_MSEL(IP14_23_20,    RIF2_CLK_A,             SEL_DRIF2_0),
-
-       PINMUX_IPSR_GPSR(IP14_27_24,    SSI_WS4),
-       PINMUX_IPSR_MSEL(IP14_27_24,    HTX2_A,                 SEL_HSCIF2_0),
-       PINMUX_IPSR_MSEL(IP14_27_24,    MSIOF1_SYNC_A,          SEL_MSIOF1_0),
-       PINMUX_IPSR_MSEL(IP14_27_24,    TS_SDEN0_A,             SEL_TSIF0_0),
-       PINMUX_IPSR_MSEL(IP14_27_24,    STP_ISEN_0_A,           SEL_SSP1_0_0),
-       PINMUX_IPSR_MSEL(IP14_27_24,    RIF0_SYNC_A,            SEL_DRIF0_0),
-       PINMUX_IPSR_MSEL(IP14_27_24,    RIF2_SYNC_A,            SEL_DRIF2_0),
-
-       PINMUX_IPSR_GPSR(IP14_31_28,    SSI_SDATA4),
-       PINMUX_IPSR_MSEL(IP14_31_28,    HSCK2_A,                SEL_HSCIF2_0),
-       PINMUX_IPSR_MSEL(IP14_31_28,    MSIOF1_RXD_A,           SEL_MSIOF1_0),
-       PINMUX_IPSR_MSEL(IP14_31_28,    TS_SPSYNC0_A,           SEL_TSIF0_0),
-       PINMUX_IPSR_MSEL(IP14_31_28,    STP_ISSYNC_0_A,         SEL_SSP1_0_0),
-       PINMUX_IPSR_MSEL(IP14_31_28,    RIF0_D0_A,              SEL_DRIF0_0),
-       PINMUX_IPSR_MSEL(IP14_31_28,    RIF2_D1_A,              SEL_DRIF2_0),
-
-       /* IPSR15 */
-       PINMUX_IPSR_GPSR(IP15_3_0,      SSI_SCK6),
-       PINMUX_IPSR_GPSR(IP15_3_0,      USB2_PWEN),
-       PINMUX_IPSR_MSEL(IP15_3_0,      SIM0_RST_D,             SEL_SIMCARD_3),
-
-       PINMUX_IPSR_GPSR(IP15_7_4,      SSI_WS6),
-       PINMUX_IPSR_GPSR(IP15_7_4,      USB2_OVC),
-       PINMUX_IPSR_MSEL(IP15_7_4,      SIM0_D_D,               SEL_SIMCARD_3),
-
-       PINMUX_IPSR_GPSR(IP15_11_8,     SSI_SDATA6),
-       PINMUX_IPSR_MSEL(IP15_11_8,     SIM0_CLK_D,             SEL_SIMCARD_3),
-       PINMUX_IPSR_MSEL(IP15_11_8,     SATA_DEVSLP_A,          SEL_SATA_0),
-
-       PINMUX_IPSR_GPSR(IP15_15_12,    SSI_SCK78),
-       PINMUX_IPSR_MSEL(IP15_15_12,    HRX2_B,                 SEL_HSCIF2_1),
-       PINMUX_IPSR_MSEL(IP15_15_12,    MSIOF1_SCK_C,           SEL_MSIOF1_2),
-       PINMUX_IPSR_MSEL(IP15_15_12,    TS_SCK1_A,              SEL_TSIF1_0),
-       PINMUX_IPSR_MSEL(IP15_15_12,    STP_ISCLK_1_A,          SEL_SSP1_1_0),
-       PINMUX_IPSR_MSEL(IP15_15_12,    RIF1_CLK_A,             SEL_DRIF1_0),
-       PINMUX_IPSR_MSEL(IP15_15_12,    RIF3_CLK_A,             SEL_DRIF3_0),
-
-       PINMUX_IPSR_GPSR(IP15_19_16,    SSI_WS78),
-       PINMUX_IPSR_MSEL(IP15_19_16,    HTX2_B,                 SEL_HSCIF2_1),
-       PINMUX_IPSR_MSEL(IP15_19_16,    MSIOF1_SYNC_C,          SEL_MSIOF1_2),
-       PINMUX_IPSR_MSEL(IP15_19_16,    TS_SDAT1_A,             SEL_TSIF1_0),
-       PINMUX_IPSR_MSEL(IP15_19_16,    STP_ISD_1_A,            SEL_SSP1_1_0),
-       PINMUX_IPSR_MSEL(IP15_19_16,    RIF1_SYNC_A,            SEL_DRIF1_0),
-       PINMUX_IPSR_MSEL(IP15_19_16,    RIF3_SYNC_A,            SEL_DRIF3_0),
-
-       PINMUX_IPSR_GPSR(IP15_23_20,    SSI_SDATA7),
-       PINMUX_IPSR_MSEL(IP15_23_20,    HCTS2_N_B,              SEL_HSCIF2_1),
-       PINMUX_IPSR_MSEL(IP15_23_20,    MSIOF1_RXD_C,           SEL_MSIOF1_2),
-       PINMUX_IPSR_MSEL(IP15_23_20,    TS_SDEN1_A,             SEL_TSIF1_0),
-       PINMUX_IPSR_MSEL(IP15_23_20,    STP_ISEN_1_A,           SEL_SSP1_1_0),
-       PINMUX_IPSR_MSEL(IP15_23_20,    RIF1_D0_A,              SEL_DRIF1_0),
-       PINMUX_IPSR_MSEL(IP15_23_20,    RIF3_D0_A,              SEL_DRIF3_0),
-       PINMUX_IPSR_MSEL(IP15_23_20,    TCLK2_A,                SEL_TIMER_TMU_0),
-
-       PINMUX_IPSR_GPSR(IP15_27_24,    SSI_SDATA8),
-       PINMUX_IPSR_MSEL(IP15_27_24,    HRTS2_N_B,              SEL_HSCIF2_1),
-       PINMUX_IPSR_MSEL(IP15_27_24,    MSIOF1_TXD_C,           SEL_MSIOF1_2),
-       PINMUX_IPSR_MSEL(IP15_27_24,    TS_SPSYNC1_A,           SEL_TSIF1_0),
-       PINMUX_IPSR_MSEL(IP15_27_24,    STP_ISSYNC_1_A,         SEL_SSP1_1_0),
-       PINMUX_IPSR_MSEL(IP15_27_24,    RIF1_D1_A,              SEL_DRIF1_0),
-       PINMUX_IPSR_MSEL(IP15_27_24,    RIF3_D1_A,              SEL_DRIF3_0),
-
-       PINMUX_IPSR_MSEL(IP15_31_28,    SSI_SDATA9_A,           SEL_SSI_0),
-       PINMUX_IPSR_MSEL(IP15_31_28,    HSCK2_B,                SEL_HSCIF2_1),
-       PINMUX_IPSR_MSEL(IP15_31_28,    MSIOF1_SS1_C,           SEL_MSIOF1_2),
-       PINMUX_IPSR_MSEL(IP15_31_28,    HSCK1_A,                SEL_HSCIF1_0),
-       PINMUX_IPSR_MSEL(IP15_31_28,    SSI_WS1_B,              SEL_SSI_1),
-       PINMUX_IPSR_GPSR(IP15_31_28,    SCK1),
-       PINMUX_IPSR_MSEL(IP15_31_28,    STP_IVCXO27_1_A,        SEL_SSP1_1_0),
-       PINMUX_IPSR_GPSR(IP15_31_28,    SCK5),
-
-       /* IPSR16 */
-       PINMUX_IPSR_MSEL(IP16_3_0,      AUDIO_CLKA_A,           SEL_ADG_0),
-
-       PINMUX_IPSR_MSEL(IP16_7_4,      AUDIO_CLKB_B,           SEL_ADG_1),
-       PINMUX_IPSR_MSEL(IP16_7_4,      SCIF_CLK_A,             SEL_SCIF1_0),
-       PINMUX_IPSR_MSEL(IP16_7_4,      STP_IVCXO27_1_D,        SEL_SSP1_1_3),
-       PINMUX_IPSR_MSEL(IP16_7_4,      REMOCON_A,              SEL_REMOCON_0),
-       PINMUX_IPSR_MSEL(IP16_7_4,      TCLK1_A,                SEL_TIMER_TMU_0),
-
-       PINMUX_IPSR_GPSR(IP16_11_8,     USB0_PWEN),
-       PINMUX_IPSR_MSEL(IP16_11_8,     SIM0_RST_C,             SEL_SIMCARD_2),
-       PINMUX_IPSR_MSEL(IP16_11_8,     TS_SCK1_D,              SEL_TSIF1_3),
-       PINMUX_IPSR_MSEL(IP16_11_8,     STP_ISCLK_1_D,          SEL_SSP1_1_3),
-       PINMUX_IPSR_MSEL(IP16_11_8,     BPFCLK_B,               SEL_FM_1),
-       PINMUX_IPSR_MSEL(IP16_11_8,     RIF3_CLK_B,             SEL_DRIF3_1),
-
-       PINMUX_IPSR_GPSR(IP16_15_12,    USB0_OVC),
-       PINMUX_IPSR_MSEL(IP16_11_8,     SIM0_D_C,               SEL_SIMCARD_2),
-       PINMUX_IPSR_MSEL(IP16_11_8,     TS_SDAT1_D,             SEL_TSIF1_3),
-       PINMUX_IPSR_MSEL(IP16_11_8,     STP_ISD_1_D,            SEL_SSP1_1_3),
-       PINMUX_IPSR_MSEL(IP16_11_8,     RIF3_SYNC_B,            SEL_DRIF3_1),
-
-       PINMUX_IPSR_GPSR(IP16_19_16,    USB1_PWEN),
-       PINMUX_IPSR_MSEL(IP16_19_16,    SIM0_CLK_C,             SEL_SIMCARD_2),
-       PINMUX_IPSR_MSEL(IP16_19_16,    SSI_SCK1_A,             SEL_SSI_0),
-       PINMUX_IPSR_MSEL(IP16_19_16,    TS_SCK0_E,              SEL_TSIF0_4),
-       PINMUX_IPSR_MSEL(IP16_19_16,    STP_ISCLK_0_E,          SEL_SSP1_0_4),
-       PINMUX_IPSR_MSEL(IP16_19_16,    FMCLK_B,                SEL_FM_1),
-       PINMUX_IPSR_MSEL(IP16_19_16,    RIF2_CLK_B,             SEL_DRIF2_1),
-       PINMUX_IPSR_MSEL(IP16_19_16,    SPEEDIN_A,              SEL_SPEED_PULSE_0),
-
-       PINMUX_IPSR_GPSR(IP16_23_20,    USB1_OVC),
-       PINMUX_IPSR_MSEL(IP16_23_20,    MSIOF1_SS2_C,           SEL_MSIOF1_2),
-       PINMUX_IPSR_MSEL(IP16_23_20,    SSI_WS1_A,              SEL_SSI_0),
-       PINMUX_IPSR_MSEL(IP16_23_20,    TS_SDAT0_E,             SEL_TSIF0_4),
-       PINMUX_IPSR_MSEL(IP16_23_20,    STP_ISD_0_E,            SEL_SSP1_0_4),
-       PINMUX_IPSR_MSEL(IP16_23_20,    FMIN_B,                 SEL_FM_1),
-       PINMUX_IPSR_MSEL(IP16_23_20,    RIF2_SYNC_B,            SEL_DRIF2_1),
-       PINMUX_IPSR_MSEL(IP16_23_20,    REMOCON_B,              SEL_REMOCON_1),
-
-       PINMUX_IPSR_GPSR(IP16_27_24,    USB30_PWEN),
-       PINMUX_IPSR_MSEL(IP16_27_24,    AUDIO_CLKOUT_B,         SEL_ADG_1),
-       PINMUX_IPSR_MSEL(IP16_27_24,    SSI_SCK2_B,             SEL_SSI_1),
-       PINMUX_IPSR_MSEL(IP16_27_24,    TS_SDEN1_D,             SEL_TSIF1_3),
-       PINMUX_IPSR_MSEL(IP16_27_24,    STP_ISEN_1_D,           SEL_SSP1_1_3),
-       PINMUX_IPSR_MSEL(IP16_27_24,    STP_OPWM_0_E,           SEL_SSP1_0_4),
-       PINMUX_IPSR_MSEL(IP16_27_24,    RIF3_D0_B,              SEL_DRIF3_1),
-       PINMUX_IPSR_MSEL(IP16_27_24,    TCLK2_B,                SEL_TIMER_TMU_1),
-       PINMUX_IPSR_GPSR(IP16_27_24,    TPU0TO0),
-
-       PINMUX_IPSR_GPSR(IP16_31_28,    USB30_OVC),
-       PINMUX_IPSR_MSEL(IP16_31_28,    AUDIO_CLKOUT1_B,        SEL_ADG_1),
-       PINMUX_IPSR_MSEL(IP16_31_28,    SSI_WS2_B,              SEL_SSI_1),
-       PINMUX_IPSR_MSEL(IP16_31_28,    TS_SPSYNC1_D,           SEL_TSIF1_3),
-       PINMUX_IPSR_MSEL(IP16_31_28,    STP_ISSYNC_1_D,         SEL_SSP1_1_3),
-       PINMUX_IPSR_MSEL(IP16_31_28,    STP_IVCXO27_0_E,        SEL_SSP1_0_4),
-       PINMUX_IPSR_MSEL(IP16_31_28,    RIF3_D1_B,              SEL_DRIF3_1),
-       PINMUX_IPSR_MSEL(IP16_31_28,    FSO_TOE_B,              SEL_FSO_1),
-       PINMUX_IPSR_GPSR(IP16_31_28,    TPU0TO1),
-
-       /* IPSR17 */
-       PINMUX_IPSR_GPSR(IP17_3_0,      USB31_PWEN),
-       PINMUX_IPSR_MSEL(IP17_3_0,      AUDIO_CLKOUT2_B,        SEL_ADG_1),
-       PINMUX_IPSR_MSEL(IP17_3_0,      SSI_SCK9_B,             SEL_SSI_1),
-       PINMUX_IPSR_MSEL(IP17_3_0,      TS_SDEN0_E,             SEL_TSIF0_4),
-       PINMUX_IPSR_MSEL(IP17_3_0,      STP_ISEN_0_E,           SEL_SSP1_0_4),
-       PINMUX_IPSR_MSEL(IP17_3_0,      RIF2_D0_B,              SEL_DRIF2_1),
-       PINMUX_IPSR_GPSR(IP17_3_0,      TPU0TO2),
-
-       PINMUX_IPSR_GPSR(IP17_7_4,      USB31_OVC),
-       PINMUX_IPSR_MSEL(IP17_7_4,      AUDIO_CLKOUT3_B,        SEL_ADG_1),
-       PINMUX_IPSR_MSEL(IP17_7_4,      SSI_WS9_B,              SEL_SSI_1),
-       PINMUX_IPSR_MSEL(IP17_7_4,      TS_SPSYNC0_E,           SEL_TSIF0_4),
-       PINMUX_IPSR_MSEL(IP17_7_4,      STP_ISSYNC_0_E,         SEL_SSP1_0_4),
-       PINMUX_IPSR_MSEL(IP17_7_4,      RIF2_D1_B,              SEL_DRIF2_1),
-       PINMUX_IPSR_GPSR(IP17_7_4,      TPU0TO3),
-
-/*
- * Static pins can not be muxed between different functions but
- * still need mark entries in the pinmux list. Add each static
- * pin to the list without an associated function. The sh-pfc
- * core will do the right thing and skip trying to mux the pin
- * while still applying configuration to it.
- */
-#define FM(x)  PINMUX_DATA(x##_MARK, 0),
-       PINMUX_STATIC
-#undef FM
-};
-
-/*
- * Pins not associated with a GPIO port.
- */
-enum {
-       GP_ASSIGN_LAST(),
-       NOGP_ALL(),
-};
-
-static const struct sh_pfc_pin pinmux_pins[] = {
-       PINMUX_GPIO_GP_ALL(),
-       PINMUX_NOGP_ALL(),
-};
-
-/* - AUDIO CLOCK ------------------------------------------------------------ */
-static const unsigned int audio_clk_a_a_pins[] = {
-       /* CLK A */
-       RCAR_GP_PIN(6, 22),
-};
-static const unsigned int audio_clk_a_a_mux[] = {
-       AUDIO_CLKA_A_MARK,
-};
-static const unsigned int audio_clk_a_b_pins[] = {
-       /* CLK A */
-       RCAR_GP_PIN(5, 4),
-};
-static const unsigned int audio_clk_a_b_mux[] = {
-       AUDIO_CLKA_B_MARK,
-};
-static const unsigned int audio_clk_a_c_pins[] = {
-       /* CLK A */
-       RCAR_GP_PIN(5, 19),
-};
-static const unsigned int audio_clk_a_c_mux[] = {
-       AUDIO_CLKA_C_MARK,
-};
-static const unsigned int audio_clk_b_a_pins[] = {
-       /* CLK B */
-       RCAR_GP_PIN(5, 12),
-};
-static const unsigned int audio_clk_b_a_mux[] = {
-       AUDIO_CLKB_A_MARK,
-};
-static const unsigned int audio_clk_b_b_pins[] = {
-       /* CLK B */
-       RCAR_GP_PIN(6, 23),
-};
-static const unsigned int audio_clk_b_b_mux[] = {
-       AUDIO_CLKB_B_MARK,
-};
-static const unsigned int audio_clk_c_a_pins[] = {
-       /* CLK C */
-       RCAR_GP_PIN(5, 21),
-};
-static const unsigned int audio_clk_c_a_mux[] = {
-       AUDIO_CLKC_A_MARK,
-};
-static const unsigned int audio_clk_c_b_pins[] = {
-       /* CLK C */
-       RCAR_GP_PIN(5, 0),
-};
-static const unsigned int audio_clk_c_b_mux[] = {
-       AUDIO_CLKC_B_MARK,
-};
-static const unsigned int audio_clkout_a_pins[] = {
-       /* CLKOUT */
-       RCAR_GP_PIN(5, 18),
-};
-static const unsigned int audio_clkout_a_mux[] = {
-       AUDIO_CLKOUT_A_MARK,
-};
-static const unsigned int audio_clkout_b_pins[] = {
-       /* CLKOUT */
-       RCAR_GP_PIN(6, 28),
-};
-static const unsigned int audio_clkout_b_mux[] = {
-       AUDIO_CLKOUT_B_MARK,
-};
-static const unsigned int audio_clkout_c_pins[] = {
-       /* CLKOUT */
-       RCAR_GP_PIN(5, 3),
-};
-static const unsigned int audio_clkout_c_mux[] = {
-       AUDIO_CLKOUT_C_MARK,
-};
-static const unsigned int audio_clkout_d_pins[] = {
-       /* CLKOUT */
-       RCAR_GP_PIN(5, 21),
-};
-static const unsigned int audio_clkout_d_mux[] = {
-       AUDIO_CLKOUT_D_MARK,
-};
-static const unsigned int audio_clkout1_a_pins[] = {
-       /* CLKOUT1 */
-       RCAR_GP_PIN(5, 15),
-};
-static const unsigned int audio_clkout1_a_mux[] = {
-       AUDIO_CLKOUT1_A_MARK,
-};
-static const unsigned int audio_clkout1_b_pins[] = {
-       /* CLKOUT1 */
-       RCAR_GP_PIN(6, 29),
-};
-static const unsigned int audio_clkout1_b_mux[] = {
-       AUDIO_CLKOUT1_B_MARK,
-};
-static const unsigned int audio_clkout2_a_pins[] = {
-       /* CLKOUT2 */
-       RCAR_GP_PIN(5, 16),
-};
-static const unsigned int audio_clkout2_a_mux[] = {
-       AUDIO_CLKOUT2_A_MARK,
-};
-static const unsigned int audio_clkout2_b_pins[] = {
-       /* CLKOUT2 */
-       RCAR_GP_PIN(6, 30),
-};
-static const unsigned int audio_clkout2_b_mux[] = {
-       AUDIO_CLKOUT2_B_MARK,
-};
-
-static const unsigned int audio_clkout3_a_pins[] = {
-       /* CLKOUT3 */
-       RCAR_GP_PIN(5, 19),
-};
-static const unsigned int audio_clkout3_a_mux[] = {
-       AUDIO_CLKOUT3_A_MARK,
-};
-static const unsigned int audio_clkout3_b_pins[] = {
-       /* CLKOUT3 */
-       RCAR_GP_PIN(6, 31),
-};
-static const unsigned int audio_clkout3_b_mux[] = {
-       AUDIO_CLKOUT3_B_MARK,
-};
-
-/* - EtherAVB --------------------------------------------------------------- */
-static const unsigned int avb_link_pins[] = {
-       /* AVB_LINK */
-       RCAR_GP_PIN(2, 12),
-};
-static const unsigned int avb_link_mux[] = {
-       AVB_LINK_MARK,
-};
-static const unsigned int avb_magic_pins[] = {
-       /* AVB_MAGIC_ */
-       RCAR_GP_PIN(2, 10),
-};
-static const unsigned int avb_magic_mux[] = {
-       AVB_MAGIC_MARK,
-};
-static const unsigned int avb_phy_int_pins[] = {
-       /* AVB_PHY_INT */
-       RCAR_GP_PIN(2, 11),
-};
-static const unsigned int avb_phy_int_mux[] = {
-       AVB_PHY_INT_MARK,
-};
-static const unsigned int avb_mdio_pins[] = {
-       /* AVB_MDC, AVB_MDIO */
-       RCAR_GP_PIN(2, 9), PIN_AVB_MDIO,
-};
-static const unsigned int avb_mdio_mux[] = {
-       AVB_MDC_MARK, AVB_MDIO_MARK,
-};
-static const unsigned int avb_mii_pins[] = {
-       /*
-        * AVB_TX_CTL, AVB_TXC, AVB_TD0,
-        * AVB_TD1, AVB_TD2, AVB_TD3,
-        * AVB_RX_CTL, AVB_RXC, AVB_RD0,
-        * AVB_RD1, AVB_RD2, AVB_RD3,
-        * AVB_TXCREFCLK
-        */
-       PIN_AVB_TX_CTL, PIN_AVB_TXC, PIN_AVB_TD0,
-       PIN_AVB_TD1, PIN_AVB_TD2, PIN_AVB_TD3,
-       PIN_AVB_RX_CTL, PIN_AVB_RXC, PIN_AVB_RD0,
-       PIN_AVB_RD1, PIN_AVB_RD2, PIN_AVB_RD3,
-       PIN_AVB_TXCREFCLK,
-};
-static const unsigned int avb_mii_mux[] = {
-       AVB_TX_CTL_MARK, AVB_TXC_MARK, AVB_TD0_MARK,
-       AVB_TD1_MARK, AVB_TD2_MARK, AVB_TD3_MARK,
-       AVB_RX_CTL_MARK, AVB_RXC_MARK, AVB_RD0_MARK,
-       AVB_RD1_MARK, AVB_RD2_MARK, AVB_RD3_MARK,
-       AVB_TXCREFCLK_MARK,
-};
-static const unsigned int avb_avtp_pps_pins[] = {
-       /* AVB_AVTP_PPS */
-       RCAR_GP_PIN(2, 6),
-};
-static const unsigned int avb_avtp_pps_mux[] = {
-       AVB_AVTP_PPS_MARK,
-};
-static const unsigned int avb_avtp_match_a_pins[] = {
-       /* AVB_AVTP_MATCH_A */
-       RCAR_GP_PIN(2, 13),
-};
-static const unsigned int avb_avtp_match_a_mux[] = {
-       AVB_AVTP_MATCH_A_MARK,
-};
-static const unsigned int avb_avtp_capture_a_pins[] = {
-       /* AVB_AVTP_CAPTURE_A */
-       RCAR_GP_PIN(2, 14),
-};
-static const unsigned int avb_avtp_capture_a_mux[] = {
-       AVB_AVTP_CAPTURE_A_MARK,
-};
-static const unsigned int avb_avtp_match_b_pins[] = {
-       /*  AVB_AVTP_MATCH_B */
-       RCAR_GP_PIN(1, 8),
-};
-static const unsigned int avb_avtp_match_b_mux[] = {
-       AVB_AVTP_MATCH_B_MARK,
-};
-static const unsigned int avb_avtp_capture_b_pins[] = {
-       /* AVB_AVTP_CAPTURE_B */
-       RCAR_GP_PIN(1, 11),
-};
-static const unsigned int avb_avtp_capture_b_mux[] = {
-       AVB_AVTP_CAPTURE_B_MARK,
-};
-
-/* - CAN ------------------------------------------------------------------ */
-static const unsigned int can0_data_a_pins[] = {
-       /* TX, RX */
-       RCAR_GP_PIN(1, 23),     RCAR_GP_PIN(1, 24),
-};
-static const unsigned int can0_data_a_mux[] = {
-       CAN0_TX_A_MARK,         CAN0_RX_A_MARK,
-};
-static const unsigned int can0_data_b_pins[] = {
-       /* TX, RX */
-       RCAR_GP_PIN(2, 0),      RCAR_GP_PIN(2, 1),
-};
-static const unsigned int can0_data_b_mux[] = {
-       CAN0_TX_B_MARK,         CAN0_RX_B_MARK,
-};
-static const unsigned int can1_data_pins[] = {
-       /* TX, RX */
-       RCAR_GP_PIN(1, 22),     RCAR_GP_PIN(1, 26),
-};
-static const unsigned int can1_data_mux[] = {
-       CAN1_TX_MARK,           CAN1_RX_MARK,
-};
-
-/* - CAN Clock -------------------------------------------------------------- */
-static const unsigned int can_clk_pins[] = {
-       /* CLK */
-       RCAR_GP_PIN(1, 25),
-};
-static const unsigned int can_clk_mux[] = {
-       CAN_CLK_MARK,
-};
-
-/* - CAN FD --------------------------------------------------------------- */
-static const unsigned int canfd0_data_a_pins[] = {
-       /* TX, RX */
-       RCAR_GP_PIN(1, 23),     RCAR_GP_PIN(1, 24),
-};
-static const unsigned int canfd0_data_a_mux[] = {
-       CANFD0_TX_A_MARK,       CANFD0_RX_A_MARK,
-};
-static const unsigned int canfd0_data_b_pins[] = {
-       /* TX, RX */
-       RCAR_GP_PIN(2, 0),      RCAR_GP_PIN(2, 1),
-};
-static const unsigned int canfd0_data_b_mux[] = {
-       CANFD0_TX_B_MARK,       CANFD0_RX_B_MARK,
-};
-static const unsigned int canfd1_data_pins[] = {
-       /* TX, RX */
-       RCAR_GP_PIN(1, 22),     RCAR_GP_PIN(1, 26),
-};
-static const unsigned int canfd1_data_mux[] = {
-       CANFD1_TX_MARK,         CANFD1_RX_MARK,
-};
-
-/* - DRIF0 --------------------------------------------------------------- */
-static const unsigned int drif0_ctrl_a_pins[] = {
-       /* CLK, SYNC */
-       RCAR_GP_PIN(6, 8), RCAR_GP_PIN(6, 9),
-};
-static const unsigned int drif0_ctrl_a_mux[] = {
-       RIF0_CLK_A_MARK, RIF0_SYNC_A_MARK,
-};
-static const unsigned int drif0_data0_a_pins[] = {
-       /* D0 */
-       RCAR_GP_PIN(6, 10),
-};
-static const unsigned int drif0_data0_a_mux[] = {
-       RIF0_D0_A_MARK,
-};
-static const unsigned int drif0_data1_a_pins[] = {
-       /* D1 */
-       RCAR_GP_PIN(6, 7),
-};
-static const unsigned int drif0_data1_a_mux[] = {
-       RIF0_D1_A_MARK,
-};
-static const unsigned int drif0_ctrl_b_pins[] = {
-       /* CLK, SYNC */
-       RCAR_GP_PIN(5, 0), RCAR_GP_PIN(5, 4),
-};
-static const unsigned int drif0_ctrl_b_mux[] = {
-       RIF0_CLK_B_MARK, RIF0_SYNC_B_MARK,
-};
-static const unsigned int drif0_data0_b_pins[] = {
-       /* D0 */
-       RCAR_GP_PIN(5, 1),
-};
-static const unsigned int drif0_data0_b_mux[] = {
-       RIF0_D0_B_MARK,
-};
-static const unsigned int drif0_data1_b_pins[] = {
-       /* D1 */
-       RCAR_GP_PIN(5, 2),
-};
-static const unsigned int drif0_data1_b_mux[] = {
-       RIF0_D1_B_MARK,
-};
-static const unsigned int drif0_ctrl_c_pins[] = {
-       /* CLK, SYNC */
-       RCAR_GP_PIN(5, 12), RCAR_GP_PIN(5, 15),
-};
-static const unsigned int drif0_ctrl_c_mux[] = {
-       RIF0_CLK_C_MARK, RIF0_SYNC_C_MARK,
-};
-static const unsigned int drif0_data0_c_pins[] = {
-       /* D0 */
-       RCAR_GP_PIN(5, 13),
-};
-static const unsigned int drif0_data0_c_mux[] = {
-       RIF0_D0_C_MARK,
-};
-static const unsigned int drif0_data1_c_pins[] = {
-       /* D1 */
-       RCAR_GP_PIN(5, 14),
-};
-static const unsigned int drif0_data1_c_mux[] = {
-       RIF0_D1_C_MARK,
-};
-/* - DRIF1 --------------------------------------------------------------- */
-static const unsigned int drif1_ctrl_a_pins[] = {
-       /* CLK, SYNC */
-       RCAR_GP_PIN(6, 17), RCAR_GP_PIN(6, 18),
-};
-static const unsigned int drif1_ctrl_a_mux[] = {
-       RIF1_CLK_A_MARK, RIF1_SYNC_A_MARK,
-};
-static const unsigned int drif1_data0_a_pins[] = {
-       /* D0 */
-       RCAR_GP_PIN(6, 19),
-};
-static const unsigned int drif1_data0_a_mux[] = {
-       RIF1_D0_A_MARK,
-};
-static const unsigned int drif1_data1_a_pins[] = {
-       /* D1 */
-       RCAR_GP_PIN(6, 20),
-};
-static const unsigned int drif1_data1_a_mux[] = {
-       RIF1_D1_A_MARK,
-};
-static const unsigned int drif1_ctrl_b_pins[] = {
-       /* CLK, SYNC */
-       RCAR_GP_PIN(5, 9), RCAR_GP_PIN(5, 3),
-};
-static const unsigned int drif1_ctrl_b_mux[] = {
-       RIF1_CLK_B_MARK, RIF1_SYNC_B_MARK,
-};
-static const unsigned int drif1_data0_b_pins[] = {
-       /* D0 */
-       RCAR_GP_PIN(5, 7),
-};
-static const unsigned int drif1_data0_b_mux[] = {
-       RIF1_D0_B_MARK,
-};
-static const unsigned int drif1_data1_b_pins[] = {
-       /* D1 */
-       RCAR_GP_PIN(5, 8),
-};
-static const unsigned int drif1_data1_b_mux[] = {
-       RIF1_D1_B_MARK,
-};
-static const unsigned int drif1_ctrl_c_pins[] = {
-       /* CLK, SYNC */
-       RCAR_GP_PIN(5, 5), RCAR_GP_PIN(5, 11),
-};
-static const unsigned int drif1_ctrl_c_mux[] = {
-       RIF1_CLK_C_MARK, RIF1_SYNC_C_MARK,
-};
-static const unsigned int drif1_data0_c_pins[] = {
-       /* D0 */
-       RCAR_GP_PIN(5, 6),
-};
-static const unsigned int drif1_data0_c_mux[] = {
-       RIF1_D0_C_MARK,
-};
-static const unsigned int drif1_data1_c_pins[] = {
-       /* D1 */
-       RCAR_GP_PIN(5, 10),
-};
-static const unsigned int drif1_data1_c_mux[] = {
-       RIF1_D1_C_MARK,
-};
-/* - DRIF2 --------------------------------------------------------------- */
-static const unsigned int drif2_ctrl_a_pins[] = {
-       /* CLK, SYNC */
-       RCAR_GP_PIN(6, 8), RCAR_GP_PIN(6, 9),
-};
-static const unsigned int drif2_ctrl_a_mux[] = {
-       RIF2_CLK_A_MARK, RIF2_SYNC_A_MARK,
-};
-static const unsigned int drif2_data0_a_pins[] = {
-       /* D0 */
-       RCAR_GP_PIN(6, 7),
-};
-static const unsigned int drif2_data0_a_mux[] = {
-       RIF2_D0_A_MARK,
-};
-static const unsigned int drif2_data1_a_pins[] = {
-       /* D1 */
-       RCAR_GP_PIN(6, 10),
-};
-static const unsigned int drif2_data1_a_mux[] = {
-       RIF2_D1_A_MARK,
-};
-static const unsigned int drif2_ctrl_b_pins[] = {
-       /* CLK, SYNC */
-       RCAR_GP_PIN(6, 26), RCAR_GP_PIN(6, 27),
-};
-static const unsigned int drif2_ctrl_b_mux[] = {
-       RIF2_CLK_B_MARK, RIF2_SYNC_B_MARK,
-};
-static const unsigned int drif2_data0_b_pins[] = {
-       /* D0 */
-       RCAR_GP_PIN(6, 30),
-};
-static const unsigned int drif2_data0_b_mux[] = {
-       RIF2_D0_B_MARK,
-};
-static const unsigned int drif2_data1_b_pins[] = {
-       /* D1 */
-       RCAR_GP_PIN(6, 31),
-};
-static const unsigned int drif2_data1_b_mux[] = {
-       RIF2_D1_B_MARK,
-};
-/* - DRIF3 --------------------------------------------------------------- */
-static const unsigned int drif3_ctrl_a_pins[] = {
-       /* CLK, SYNC */
-       RCAR_GP_PIN(6, 17), RCAR_GP_PIN(6, 18),
-};
-static const unsigned int drif3_ctrl_a_mux[] = {
-       RIF3_CLK_A_MARK, RIF3_SYNC_A_MARK,
-};
-static const unsigned int drif3_data0_a_pins[] = {
-       /* D0 */
-       RCAR_GP_PIN(6, 19),
-};
-static const unsigned int drif3_data0_a_mux[] = {
-       RIF3_D0_A_MARK,
-};
-static const unsigned int drif3_data1_a_pins[] = {
-       /* D1 */
-       RCAR_GP_PIN(6, 20),
-};
-static const unsigned int drif3_data1_a_mux[] = {
-       RIF3_D1_A_MARK,
-};
-static const unsigned int drif3_ctrl_b_pins[] = {
-       /* CLK, SYNC */
-       RCAR_GP_PIN(6, 24), RCAR_GP_PIN(6, 25),
-};
-static const unsigned int drif3_ctrl_b_mux[] = {
-       RIF3_CLK_B_MARK, RIF3_SYNC_B_MARK,
-};
-static const unsigned int drif3_data0_b_pins[] = {
-       /* D0 */
-       RCAR_GP_PIN(6, 28),
-};
-static const unsigned int drif3_data0_b_mux[] = {
-       RIF3_D0_B_MARK,
-};
-static const unsigned int drif3_data1_b_pins[] = {
-       /* D1 */
-       RCAR_GP_PIN(6, 29),
-};
-static const unsigned int drif3_data1_b_mux[] = {
-       RIF3_D1_B_MARK,
-};
-
-/* - DU --------------------------------------------------------------------- */
-static const unsigned int du_rgb666_pins[] = {
-       /* R[7:2], G[7:2], B[7:2] */
-       RCAR_GP_PIN(0, 15), RCAR_GP_PIN(0, 14), RCAR_GP_PIN(0, 13),
-       RCAR_GP_PIN(0, 12), RCAR_GP_PIN(0, 11), RCAR_GP_PIN(0, 10),
-       RCAR_GP_PIN(1, 15), RCAR_GP_PIN(1, 14), RCAR_GP_PIN(1, 13),
-       RCAR_GP_PIN(1, 12), RCAR_GP_PIN(1, 19), RCAR_GP_PIN(1, 18),
-       RCAR_GP_PIN(1, 7),  RCAR_GP_PIN(1, 6),  RCAR_GP_PIN(1, 5),
-       RCAR_GP_PIN(1, 4),  RCAR_GP_PIN(1, 3),  RCAR_GP_PIN(1, 2),
-};
-static const unsigned int du_rgb666_mux[] = {
-       DU_DR7_MARK, DU_DR6_MARK, DU_DR5_MARK, DU_DR4_MARK,
-       DU_DR3_MARK, DU_DR2_MARK,
-       DU_DG7_MARK, DU_DG6_MARK, DU_DG5_MARK, DU_DG4_MARK,
-       DU_DG3_MARK, DU_DG2_MARK,
-       DU_DB7_MARK, DU_DB6_MARK, DU_DB5_MARK, DU_DB4_MARK,
-       DU_DB3_MARK, DU_DB2_MARK,
-};
-static const unsigned int du_rgb888_pins[] = {
-       /* R[7:0], G[7:0], B[7:0] */
-       RCAR_GP_PIN(0, 15), RCAR_GP_PIN(0, 14), RCAR_GP_PIN(0, 13),
-       RCAR_GP_PIN(0, 12), RCAR_GP_PIN(0, 11), RCAR_GP_PIN(0, 10),
-       RCAR_GP_PIN(0, 9),  RCAR_GP_PIN(0, 8),
-       RCAR_GP_PIN(1, 15), RCAR_GP_PIN(1, 14), RCAR_GP_PIN(1, 13),
-       RCAR_GP_PIN(1, 12), RCAR_GP_PIN(1, 19), RCAR_GP_PIN(1, 18),
-       RCAR_GP_PIN(1, 17), RCAR_GP_PIN(1, 16),
-       RCAR_GP_PIN(1, 7),  RCAR_GP_PIN(1, 6),  RCAR_GP_PIN(1, 5),
-       RCAR_GP_PIN(1, 4),  RCAR_GP_PIN(1, 3),  RCAR_GP_PIN(1, 2),
-       RCAR_GP_PIN(1, 1),  RCAR_GP_PIN(1, 0),
-};
-static const unsigned int du_rgb888_mux[] = {
-       DU_DR7_MARK, DU_DR6_MARK, DU_DR5_MARK, DU_DR4_MARK,
-       DU_DR3_MARK, DU_DR2_MARK, DU_DR1_MARK, DU_DR0_MARK,
-       DU_DG7_MARK, DU_DG6_MARK, DU_DG5_MARK, DU_DG4_MARK,
-       DU_DG3_MARK, DU_DG2_MARK, DU_DG1_MARK, DU_DG0_MARK,
-       DU_DB7_MARK, DU_DB6_MARK, DU_DB5_MARK, DU_DB4_MARK,
-       DU_DB3_MARK, DU_DB2_MARK, DU_DB1_MARK, DU_DB0_MARK,
-};
-static const unsigned int du_clk_out_0_pins[] = {
-       /* CLKOUT */
-       RCAR_GP_PIN(1, 27),
-};
-static const unsigned int du_clk_out_0_mux[] = {
-       DU_DOTCLKOUT0_MARK
-};
-static const unsigned int du_clk_out_1_pins[] = {
-       /* CLKOUT */
-       RCAR_GP_PIN(2, 3),
-};
-static const unsigned int du_clk_out_1_mux[] = {
-       DU_DOTCLKOUT1_MARK
-};
-static const unsigned int du_sync_pins[] = {
-       /* EXVSYNC/VSYNC, EXHSYNC/HSYNC */
-       RCAR_GP_PIN(2, 5), RCAR_GP_PIN(2, 4),
-};
-static const unsigned int du_sync_mux[] = {
-       DU_EXVSYNC_DU_VSYNC_MARK, DU_EXHSYNC_DU_HSYNC_MARK
-};
-static const unsigned int du_oddf_pins[] = {
-       /* EXDISP/EXODDF/EXCDE */
-       RCAR_GP_PIN(2, 2),
-};
-static const unsigned int du_oddf_mux[] = {
-       DU_EXODDF_DU_ODDF_DISP_CDE_MARK,
-};
-static const unsigned int du_cde_pins[] = {
-       /* CDE */
-       RCAR_GP_PIN(2, 0),
-};
-static const unsigned int du_cde_mux[] = {
-       DU_CDE_MARK,
-};
-static const unsigned int du_disp_pins[] = {
-       /* DISP */
-       RCAR_GP_PIN(2, 1),
-};
-static const unsigned int du_disp_mux[] = {
-       DU_DISP_MARK,
-};
-/* - HSCIF0 ----------------------------------------------------------------- */
-static const unsigned int hscif0_data_pins[] = {
-       /* RX, TX */
-       RCAR_GP_PIN(5, 13), RCAR_GP_PIN(5, 14),
-};
-static const unsigned int hscif0_data_mux[] = {
-       HRX0_MARK, HTX0_MARK,
-};
-static const unsigned int hscif0_clk_pins[] = {
-       /* SCK */
-       RCAR_GP_PIN(5, 12),
-};
-static const unsigned int hscif0_clk_mux[] = {
-       HSCK0_MARK,
-};
-static const unsigned int hscif0_ctrl_pins[] = {
-       /* RTS, CTS */
-       RCAR_GP_PIN(5, 16), RCAR_GP_PIN(5, 15),
-};
-static const unsigned int hscif0_ctrl_mux[] = {
-       HRTS0_N_MARK, HCTS0_N_MARK,
-};
-/* - HSCIF1 ----------------------------------------------------------------- */
-static const unsigned int hscif1_data_a_pins[] = {
-       /* RX, TX */
-       RCAR_GP_PIN(5, 5), RCAR_GP_PIN(5, 6),
-};
-static const unsigned int hscif1_data_a_mux[] = {
-       HRX1_A_MARK, HTX1_A_MARK,
-};
-static const unsigned int hscif1_clk_a_pins[] = {
-       /* SCK */
-       RCAR_GP_PIN(6, 21),
-};
-static const unsigned int hscif1_clk_a_mux[] = {
-       HSCK1_A_MARK,
-};
-static const unsigned int hscif1_ctrl_a_pins[] = {
-       /* RTS, CTS */
-       RCAR_GP_PIN(5, 8), RCAR_GP_PIN(5, 7),
-};
-static const unsigned int hscif1_ctrl_a_mux[] = {
-       HRTS1_N_A_MARK, HCTS1_N_A_MARK,
-};
-
-static const unsigned int hscif1_data_b_pins[] = {
-       /* RX, TX */
-       RCAR_GP_PIN(5, 1), RCAR_GP_PIN(5, 2),
-};
-static const unsigned int hscif1_data_b_mux[] = {
-       HRX1_B_MARK, HTX1_B_MARK,
-};
-static const unsigned int hscif1_clk_b_pins[] = {
-       /* SCK */
-       RCAR_GP_PIN(5, 0),
-};
-static const unsigned int hscif1_clk_b_mux[] = {
-       HSCK1_B_MARK,
-};
-static const unsigned int hscif1_ctrl_b_pins[] = {
-       /* RTS, CTS */
-       RCAR_GP_PIN(5, 4), RCAR_GP_PIN(5, 3),
-};
-static const unsigned int hscif1_ctrl_b_mux[] = {
-       HRTS1_N_B_MARK, HCTS1_N_B_MARK,
-};
-/* - HSCIF2 ----------------------------------------------------------------- */
-static const unsigned int hscif2_data_a_pins[] = {
-       /* RX, TX */
-       RCAR_GP_PIN(6, 8), RCAR_GP_PIN(6, 9),
-};
-static const unsigned int hscif2_data_a_mux[] = {
-       HRX2_A_MARK, HTX2_A_MARK,
-};
-static const unsigned int hscif2_clk_a_pins[] = {
-       /* SCK */
-       RCAR_GP_PIN(6, 10),
-};
-static const unsigned int hscif2_clk_a_mux[] = {
-       HSCK2_A_MARK,
-};
-static const unsigned int hscif2_ctrl_a_pins[] = {
-       /* RTS, CTS */
-       RCAR_GP_PIN(6, 7), RCAR_GP_PIN(6, 6),
-};
-static const unsigned int hscif2_ctrl_a_mux[] = {
-       HRTS2_N_A_MARK, HCTS2_N_A_MARK,
-};
-
-static const unsigned int hscif2_data_b_pins[] = {
-       /* RX, TX */
-       RCAR_GP_PIN(6, 17), RCAR_GP_PIN(6, 18),
-};
-static const unsigned int hscif2_data_b_mux[] = {
-       HRX2_B_MARK, HTX2_B_MARK,
-};
-static const unsigned int hscif2_clk_b_pins[] = {
-       /* SCK */
-       RCAR_GP_PIN(6, 21),
-};
-static const unsigned int hscif2_clk_b_mux[] = {
-       HSCK2_B_MARK,
-};
-static const unsigned int hscif2_ctrl_b_pins[] = {
-       /* RTS, CTS */
-       RCAR_GP_PIN(6, 20), RCAR_GP_PIN(6, 19),
-};
-static const unsigned int hscif2_ctrl_b_mux[] = {
-       HRTS2_N_B_MARK, HCTS2_N_B_MARK,
-};
-/* - HSCIF3 ----------------------------------------------------------------- */
-static const unsigned int hscif3_data_a_pins[] = {
-       /* RX, TX */
-       RCAR_GP_PIN(1, 23), RCAR_GP_PIN(1, 24),
-};
-static const unsigned int hscif3_data_a_mux[] = {
-       HRX3_A_MARK, HTX3_A_MARK,
-};
-static const unsigned int hscif3_clk_pins[] = {
-       /* SCK */
-       RCAR_GP_PIN(1, 22),
-};
-static const unsigned int hscif3_clk_mux[] = {
-       HSCK3_MARK,
-};
-static const unsigned int hscif3_ctrl_pins[] = {
-       /* RTS, CTS */
-       RCAR_GP_PIN(1, 26), RCAR_GP_PIN(1, 25),
-};
-static const unsigned int hscif3_ctrl_mux[] = {
-       HRTS3_N_MARK, HCTS3_N_MARK,
-};
-
-static const unsigned int hscif3_data_b_pins[] = {
-       /* RX, TX */
-       RCAR_GP_PIN(0, 10), RCAR_GP_PIN(0, 11),
-};
-static const unsigned int hscif3_data_b_mux[] = {
-       HRX3_B_MARK, HTX3_B_MARK,
-};
-static const unsigned int hscif3_data_c_pins[] = {
-       /* RX, TX */
-       RCAR_GP_PIN(0, 14), RCAR_GP_PIN(0, 15),
-};
-static const unsigned int hscif3_data_c_mux[] = {
-       HRX3_C_MARK, HTX3_C_MARK,
-};
-static const unsigned int hscif3_data_d_pins[] = {
-       /* RX, TX */
-       RCAR_GP_PIN(2, 7), RCAR_GP_PIN(2, 8),
-};
-static const unsigned int hscif3_data_d_mux[] = {
-       HRX3_D_MARK, HTX3_D_MARK,
-};
-/* - HSCIF4 ----------------------------------------------------------------- */
-static const unsigned int hscif4_data_a_pins[] = {
-       /* RX, TX */
-       RCAR_GP_PIN(1, 12), RCAR_GP_PIN(1, 13),
-};
-static const unsigned int hscif4_data_a_mux[] = {
-       HRX4_A_MARK, HTX4_A_MARK,
-};
-static const unsigned int hscif4_clk_pins[] = {
-       /* SCK */
-       RCAR_GP_PIN(1, 11),
-};
-static const unsigned int hscif4_clk_mux[] = {
-       HSCK4_MARK,
-};
-static const unsigned int hscif4_ctrl_pins[] = {
-       /* RTS, CTS */
-       RCAR_GP_PIN(1, 15), RCAR_GP_PIN(1, 14),
-};
-static const unsigned int hscif4_ctrl_mux[] = {
-       HRTS4_N_MARK, HCTS4_N_MARK,
-};
-
-static const unsigned int hscif4_data_b_pins[] = {
-       /* RX, TX */
-       RCAR_GP_PIN(1, 8), RCAR_GP_PIN(1, 11),
-};
-static const unsigned int hscif4_data_b_mux[] = {
-       HRX4_B_MARK, HTX4_B_MARK,
-};
-
-/* - I2C -------------------------------------------------------------------- */
-static const unsigned int i2c0_pins[] = {
-       /* SCL, SDA */
-       RCAR_GP_PIN(3, 14), RCAR_GP_PIN(3, 15),
-};
-
-static const unsigned int i2c0_mux[] = {
-       SCL0_MARK, SDA0_MARK,
-};
-
-static const unsigned int i2c1_a_pins[] = {
-       /* SDA, SCL */
-       RCAR_GP_PIN(5, 11), RCAR_GP_PIN(5, 10),
-};
-static const unsigned int i2c1_a_mux[] = {
-       SDA1_A_MARK, SCL1_A_MARK,
-};
-static const unsigned int i2c1_b_pins[] = {
-       /* SDA, SCL */
-       RCAR_GP_PIN(5, 24), RCAR_GP_PIN(5, 23),
-};
-static const unsigned int i2c1_b_mux[] = {
-       SDA1_B_MARK, SCL1_B_MARK,
-};
-static const unsigned int i2c2_a_pins[] = {
-       /* SDA, SCL */
-       RCAR_GP_PIN(5, 0), RCAR_GP_PIN(5, 4),
-};
-static const unsigned int i2c2_a_mux[] = {
-       SDA2_A_MARK, SCL2_A_MARK,
-};
-static const unsigned int i2c2_b_pins[] = {
-       /* SDA, SCL */
-       RCAR_GP_PIN(3, 13), RCAR_GP_PIN(3, 12),
-};
-static const unsigned int i2c2_b_mux[] = {
-       SDA2_B_MARK, SCL2_B_MARK,
-};
-
-static const unsigned int i2c3_pins[] = {
-       /* SCL, SDA */
-       RCAR_GP_PIN(2, 7), RCAR_GP_PIN(2, 8),
-};
-
-static const unsigned int i2c3_mux[] = {
-       SCL3_MARK, SDA3_MARK,
-};
-
-static const unsigned int i2c5_pins[] = {
-       /* SCL, SDA */
-       RCAR_GP_PIN(2, 13), RCAR_GP_PIN(2, 14),
-};
-
-static const unsigned int i2c5_mux[] = {
-       SCL5_MARK, SDA5_MARK,
-};
-
-static const unsigned int i2c6_a_pins[] = {
-       /* SDA, SCL */
-       RCAR_GP_PIN(1, 8), RCAR_GP_PIN(1, 11),
-};
-static const unsigned int i2c6_a_mux[] = {
-       SDA6_A_MARK, SCL6_A_MARK,
-};
-static const unsigned int i2c6_b_pins[] = {
-       /* SDA, SCL */
-       RCAR_GP_PIN(1, 26), RCAR_GP_PIN(1, 25),
-};
-static const unsigned int i2c6_b_mux[] = {
-       SDA6_B_MARK, SCL6_B_MARK,
-};
-static const unsigned int i2c6_c_pins[] = {
-       /* SDA, SCL */
-       RCAR_GP_PIN(0, 15), RCAR_GP_PIN(0, 14),
-};
-static const unsigned int i2c6_c_mux[] = {
-       SDA6_C_MARK, SCL6_C_MARK,
-};
-
-/* - INTC-EX ---------------------------------------------------------------- */
-static const unsigned int intc_ex_irq0_pins[] = {
-       /* IRQ0 */
-       RCAR_GP_PIN(2, 0),
-};
-static const unsigned int intc_ex_irq0_mux[] = {
-       IRQ0_MARK,
-};
-static const unsigned int intc_ex_irq1_pins[] = {
-       /* IRQ1 */
-       RCAR_GP_PIN(2, 1),
-};
-static const unsigned int intc_ex_irq1_mux[] = {
-       IRQ1_MARK,
-};
-static const unsigned int intc_ex_irq2_pins[] = {
-       /* IRQ2 */
-       RCAR_GP_PIN(2, 2),
-};
-static const unsigned int intc_ex_irq2_mux[] = {
-       IRQ2_MARK,
-};
-static const unsigned int intc_ex_irq3_pins[] = {
-       /* IRQ3 */
-       RCAR_GP_PIN(2, 3),
-};
-static const unsigned int intc_ex_irq3_mux[] = {
-       IRQ3_MARK,
-};
-static const unsigned int intc_ex_irq4_pins[] = {
-       /* IRQ4 */
-       RCAR_GP_PIN(2, 4),
-};
-static const unsigned int intc_ex_irq4_mux[] = {
-       IRQ4_MARK,
-};
-static const unsigned int intc_ex_irq5_pins[] = {
-       /* IRQ5 */
-       RCAR_GP_PIN(2, 5),
-};
-static const unsigned int intc_ex_irq5_mux[] = {
-       IRQ5_MARK,
-};
-
-/* - MLB+ ------------------------------------------------------------------- */
-static const unsigned int mlb_3pin_pins[] = {
-       RCAR_GP_PIN(5, 23), RCAR_GP_PIN(5, 24), RCAR_GP_PIN(5, 25),
-};
-static const unsigned int mlb_3pin_mux[] = {
-       MLB_CLK_MARK, MLB_SIG_MARK, MLB_DAT_MARK,
-};
-
-/* - MSIOF0 ----------------------------------------------------------------- */
-static const unsigned int msiof0_clk_pins[] = {
-       /* SCK */
-       RCAR_GP_PIN(5, 17),
-};
-static const unsigned int msiof0_clk_mux[] = {
-       MSIOF0_SCK_MARK,
-};
-static const unsigned int msiof0_sync_pins[] = {
-       /* SYNC */
-       RCAR_GP_PIN(5, 18),
-};
-static const unsigned int msiof0_sync_mux[] = {
-       MSIOF0_SYNC_MARK,
-};
-static const unsigned int msiof0_ss1_pins[] = {
-       /* SS1 */
-       RCAR_GP_PIN(5, 19),
-};
-static const unsigned int msiof0_ss1_mux[] = {
-       MSIOF0_SS1_MARK,
-};
-static const unsigned int msiof0_ss2_pins[] = {
-       /* SS2 */
-       RCAR_GP_PIN(5, 21),
-};
-static const unsigned int msiof0_ss2_mux[] = {
-       MSIOF0_SS2_MARK,
-};
-static const unsigned int msiof0_txd_pins[] = {
-       /* TXD */
-       RCAR_GP_PIN(5, 20),
-};
-static const unsigned int msiof0_txd_mux[] = {
-       MSIOF0_TXD_MARK,
-};
-static const unsigned int msiof0_rxd_pins[] = {
-       /* RXD */
-       RCAR_GP_PIN(5, 22),
-};
-static const unsigned int msiof0_rxd_mux[] = {
-       MSIOF0_RXD_MARK,
-};
-/* - MSIOF1 ----------------------------------------------------------------- */
-static const unsigned int msiof1_clk_a_pins[] = {
-       /* SCK */
-       RCAR_GP_PIN(6, 8),
-};
-static const unsigned int msiof1_clk_a_mux[] = {
-       MSIOF1_SCK_A_MARK,
-};
-static const unsigned int msiof1_sync_a_pins[] = {
-       /* SYNC */
-       RCAR_GP_PIN(6, 9),
-};
-static const unsigned int msiof1_sync_a_mux[] = {
-       MSIOF1_SYNC_A_MARK,
-};
-static const unsigned int msiof1_ss1_a_pins[] = {
-       /* SS1 */
-       RCAR_GP_PIN(6, 5),
-};
-static const unsigned int msiof1_ss1_a_mux[] = {
-       MSIOF1_SS1_A_MARK,
-};
-static const unsigned int msiof1_ss2_a_pins[] = {
-       /* SS2 */
-       RCAR_GP_PIN(6, 6),
-};
-static const unsigned int msiof1_ss2_a_mux[] = {
-       MSIOF1_SS2_A_MARK,
-};
-static const unsigned int msiof1_txd_a_pins[] = {
-       /* TXD */
-       RCAR_GP_PIN(6, 7),
-};
-static const unsigned int msiof1_txd_a_mux[] = {
-       MSIOF1_TXD_A_MARK,
-};
-static const unsigned int msiof1_rxd_a_pins[] = {
-       /* RXD */
-       RCAR_GP_PIN(6, 10),
-};
-static const unsigned int msiof1_rxd_a_mux[] = {
-       MSIOF1_RXD_A_MARK,
-};
-static const unsigned int msiof1_clk_b_pins[] = {
-       /* SCK */
-       RCAR_GP_PIN(5, 9),
-};
-static const unsigned int msiof1_clk_b_mux[] = {
-       MSIOF1_SCK_B_MARK,
-};
-static const unsigned int msiof1_sync_b_pins[] = {
-       /* SYNC */
-       RCAR_GP_PIN(5, 3),
-};
-static const unsigned int msiof1_sync_b_mux[] = {
-       MSIOF1_SYNC_B_MARK,
-};
-static const unsigned int msiof1_ss1_b_pins[] = {
-       /* SS1 */
-       RCAR_GP_PIN(5, 4),
-};
-static const unsigned int msiof1_ss1_b_mux[] = {
-       MSIOF1_SS1_B_MARK,
-};
-static const unsigned int msiof1_ss2_b_pins[] = {
-       /* SS2 */
-       RCAR_GP_PIN(5, 0),
-};
-static const unsigned int msiof1_ss2_b_mux[] = {
-       MSIOF1_SS2_B_MARK,
-};
-static const unsigned int msiof1_txd_b_pins[] = {
-       /* TXD */
-       RCAR_GP_PIN(5, 8),
-};
-static const unsigned int msiof1_txd_b_mux[] = {
-       MSIOF1_TXD_B_MARK,
-};
-static const unsigned int msiof1_rxd_b_pins[] = {
-       /* RXD */
-       RCAR_GP_PIN(5, 7),
-};
-static const unsigned int msiof1_rxd_b_mux[] = {
-       MSIOF1_RXD_B_MARK,
-};
-static const unsigned int msiof1_clk_c_pins[] = {
-       /* SCK */
-       RCAR_GP_PIN(6, 17),
-};
-static const unsigned int msiof1_clk_c_mux[] = {
-       MSIOF1_SCK_C_MARK,
-};
-static const unsigned int msiof1_sync_c_pins[] = {
-       /* SYNC */
-       RCAR_GP_PIN(6, 18),
-};
-static const unsigned int msiof1_sync_c_mux[] = {
-       MSIOF1_SYNC_C_MARK,
-};
-static const unsigned int msiof1_ss1_c_pins[] = {
-       /* SS1 */
-       RCAR_GP_PIN(6, 21),
-};
-static const unsigned int msiof1_ss1_c_mux[] = {
-       MSIOF1_SS1_C_MARK,
-};
-static const unsigned int msiof1_ss2_c_pins[] = {
-       /* SS2 */
-       RCAR_GP_PIN(6, 27),
-};
-static const unsigned int msiof1_ss2_c_mux[] = {
-       MSIOF1_SS2_C_MARK,
-};
-static const unsigned int msiof1_txd_c_pins[] = {
-       /* TXD */
-       RCAR_GP_PIN(6, 20),
-};
-static const unsigned int msiof1_txd_c_mux[] = {
-       MSIOF1_TXD_C_MARK,
-};
-static const unsigned int msiof1_rxd_c_pins[] = {
-       /* RXD */
-       RCAR_GP_PIN(6, 19),
-};
-static const unsigned int msiof1_rxd_c_mux[] = {
-       MSIOF1_RXD_C_MARK,
-};
-static const unsigned int msiof1_clk_d_pins[] = {
-       /* SCK */
-       RCAR_GP_PIN(5, 12),
-};
-static const unsigned int msiof1_clk_d_mux[] = {
-       MSIOF1_SCK_D_MARK,
-};
-static const unsigned int msiof1_sync_d_pins[] = {
-       /* SYNC */
-       RCAR_GP_PIN(5, 15),
-};
-static const unsigned int msiof1_sync_d_mux[] = {
-       MSIOF1_SYNC_D_MARK,
-};
-static const unsigned int msiof1_ss1_d_pins[] = {
-       /* SS1 */
-       RCAR_GP_PIN(5, 16),
-};
-static const unsigned int msiof1_ss1_d_mux[] = {
-       MSIOF1_SS1_D_MARK,
-};
-static const unsigned int msiof1_ss2_d_pins[] = {
-       /* SS2 */
-       RCAR_GP_PIN(5, 21),
-};
-static const unsigned int msiof1_ss2_d_mux[] = {
-       MSIOF1_SS2_D_MARK,
-};
-static const unsigned int msiof1_txd_d_pins[] = {
-       /* TXD */
-       RCAR_GP_PIN(5, 14),
-};
-static const unsigned int msiof1_txd_d_mux[] = {
-       MSIOF1_TXD_D_MARK,
-};
-static const unsigned int msiof1_rxd_d_pins[] = {
-       /* RXD */
-       RCAR_GP_PIN(5, 13),
-};
-static const unsigned int msiof1_rxd_d_mux[] = {
-       MSIOF1_RXD_D_MARK,
-};
-static const unsigned int msiof1_clk_e_pins[] = {
-       /* SCK */
-       RCAR_GP_PIN(3, 0),
-};
-static const unsigned int msiof1_clk_e_mux[] = {
-       MSIOF1_SCK_E_MARK,
-};
-static const unsigned int msiof1_sync_e_pins[] = {
-       /* SYNC */
-       RCAR_GP_PIN(3, 1),
-};
-static const unsigned int msiof1_sync_e_mux[] = {
-       MSIOF1_SYNC_E_MARK,
-};
-static const unsigned int msiof1_ss1_e_pins[] = {
-       /* SS1 */
-       RCAR_GP_PIN(3, 4),
-};
-static const unsigned int msiof1_ss1_e_mux[] = {
-       MSIOF1_SS1_E_MARK,
-};
-static const unsigned int msiof1_ss2_e_pins[] = {
-       /* SS2 */
-       RCAR_GP_PIN(3, 5),
-};
-static const unsigned int msiof1_ss2_e_mux[] = {
-       MSIOF1_SS2_E_MARK,
-};
-static const unsigned int msiof1_txd_e_pins[] = {
-       /* TXD */
-       RCAR_GP_PIN(3, 3),
-};
-static const unsigned int msiof1_txd_e_mux[] = {
-       MSIOF1_TXD_E_MARK,
-};
-static const unsigned int msiof1_rxd_e_pins[] = {
-       /* RXD */
-       RCAR_GP_PIN(3, 2),
-};
-static const unsigned int msiof1_rxd_e_mux[] = {
-       MSIOF1_RXD_E_MARK,
-};
-static const unsigned int msiof1_clk_f_pins[] = {
-       /* SCK */
-       RCAR_GP_PIN(5, 23),
-};
-static const unsigned int msiof1_clk_f_mux[] = {
-       MSIOF1_SCK_F_MARK,
-};
-static const unsigned int msiof1_sync_f_pins[] = {
-       /* SYNC */
-       RCAR_GP_PIN(5, 24),
-};
-static const unsigned int msiof1_sync_f_mux[] = {
-       MSIOF1_SYNC_F_MARK,
-};
-static const unsigned int msiof1_ss1_f_pins[] = {
-       /* SS1 */
-       RCAR_GP_PIN(6, 1),
-};
-static const unsigned int msiof1_ss1_f_mux[] = {
-       MSIOF1_SS1_F_MARK,
-};
-static const unsigned int msiof1_ss2_f_pins[] = {
-       /* SS2 */
-       RCAR_GP_PIN(6, 2),
-};
-static const unsigned int msiof1_ss2_f_mux[] = {
-       MSIOF1_SS2_F_MARK,
-};
-static const unsigned int msiof1_txd_f_pins[] = {
-       /* TXD */
-       RCAR_GP_PIN(6, 0),
-};
-static const unsigned int msiof1_txd_f_mux[] = {
-       MSIOF1_TXD_F_MARK,
-};
-static const unsigned int msiof1_rxd_f_pins[] = {
-       /* RXD */
-       RCAR_GP_PIN(5, 25),
-};
-static const unsigned int msiof1_rxd_f_mux[] = {
-       MSIOF1_RXD_F_MARK,
-};
-static const unsigned int msiof1_clk_g_pins[] = {
-       /* SCK */
-       RCAR_GP_PIN(3, 6),
-};
-static const unsigned int msiof1_clk_g_mux[] = {
-       MSIOF1_SCK_G_MARK,
-};
-static const unsigned int msiof1_sync_g_pins[] = {
-       /* SYNC */
-       RCAR_GP_PIN(3, 7),
-};
-static const unsigned int msiof1_sync_g_mux[] = {
-       MSIOF1_SYNC_G_MARK,
-};
-static const unsigned int msiof1_ss1_g_pins[] = {
-       /* SS1 */
-       RCAR_GP_PIN(3, 10),
-};
-static const unsigned int msiof1_ss1_g_mux[] = {
-       MSIOF1_SS1_G_MARK,
-};
-static const unsigned int msiof1_ss2_g_pins[] = {
-       /* SS2 */
-       RCAR_GP_PIN(3, 11),
-};
-static const unsigned int msiof1_ss2_g_mux[] = {
-       MSIOF1_SS2_G_MARK,
-};
-static const unsigned int msiof1_txd_g_pins[] = {
-       /* TXD */
-       RCAR_GP_PIN(3, 9),
-};
-static const unsigned int msiof1_txd_g_mux[] = {
-       MSIOF1_TXD_G_MARK,
-};
-static const unsigned int msiof1_rxd_g_pins[] = {
-       /* RXD */
-       RCAR_GP_PIN(3, 8),
-};
-static const unsigned int msiof1_rxd_g_mux[] = {
-       MSIOF1_RXD_G_MARK,
-};
-/* - MSIOF2 ----------------------------------------------------------------- */
-static const unsigned int msiof2_clk_a_pins[] = {
-       /* SCK */
-       RCAR_GP_PIN(1, 9),
-};
-static const unsigned int msiof2_clk_a_mux[] = {
-       MSIOF2_SCK_A_MARK,
-};
-static const unsigned int msiof2_sync_a_pins[] = {
-       /* SYNC */
-       RCAR_GP_PIN(1, 8),
-};
-static const unsigned int msiof2_sync_a_mux[] = {
-       MSIOF2_SYNC_A_MARK,
-};
-static const unsigned int msiof2_ss1_a_pins[] = {
-       /* SS1 */
-       RCAR_GP_PIN(1, 6),
-};
-static const unsigned int msiof2_ss1_a_mux[] = {
-       MSIOF2_SS1_A_MARK,
-};
-static const unsigned int msiof2_ss2_a_pins[] = {
-       /* SS2 */
-       RCAR_GP_PIN(1, 7),
-};
-static const unsigned int msiof2_ss2_a_mux[] = {
-       MSIOF2_SS2_A_MARK,
-};
-static const unsigned int msiof2_txd_a_pins[] = {
-       /* TXD */
-       RCAR_GP_PIN(1, 11),
-};
-static const unsigned int msiof2_txd_a_mux[] = {
-       MSIOF2_TXD_A_MARK,
-};
-static const unsigned int msiof2_rxd_a_pins[] = {
-       /* RXD */
-       RCAR_GP_PIN(1, 10),
-};
-static const unsigned int msiof2_rxd_a_mux[] = {
-       MSIOF2_RXD_A_MARK,
-};
-static const unsigned int msiof2_clk_b_pins[] = {
-       /* SCK */
-       RCAR_GP_PIN(0, 4),
-};
-static const unsigned int msiof2_clk_b_mux[] = {
-       MSIOF2_SCK_B_MARK,
-};
-static const unsigned int msiof2_sync_b_pins[] = {
-       /* SYNC */
-       RCAR_GP_PIN(0, 5),
-};
-static const unsigned int msiof2_sync_b_mux[] = {
-       MSIOF2_SYNC_B_MARK,
-};
-static const unsigned int msiof2_ss1_b_pins[] = {
-       /* SS1 */
-       RCAR_GP_PIN(0, 0),
-};
-static const unsigned int msiof2_ss1_b_mux[] = {
-       MSIOF2_SS1_B_MARK,
-};
-static const unsigned int msiof2_ss2_b_pins[] = {
-       /* SS2 */
-       RCAR_GP_PIN(0, 1),
-};
-static const unsigned int msiof2_ss2_b_mux[] = {
-       MSIOF2_SS2_B_MARK,
-};
-static const unsigned int msiof2_txd_b_pins[] = {
-       /* TXD */
-       RCAR_GP_PIN(0, 7),
-};
-static const unsigned int msiof2_txd_b_mux[] = {
-       MSIOF2_TXD_B_MARK,
-};
-static const unsigned int msiof2_rxd_b_pins[] = {
-       /* RXD */
-       RCAR_GP_PIN(0, 6),
-};
-static const unsigned int msiof2_rxd_b_mux[] = {
-       MSIOF2_RXD_B_MARK,
-};
-static const unsigned int msiof2_clk_c_pins[] = {
-       /* SCK */
-       RCAR_GP_PIN(2, 12),
-};
-static const unsigned int msiof2_clk_c_mux[] = {
-       MSIOF2_SCK_C_MARK,
-};
-static const unsigned int msiof2_sync_c_pins[] = {
-       /* SYNC */
-       RCAR_GP_PIN(2, 11),
-};
-static const unsigned int msiof2_sync_c_mux[] = {
-       MSIOF2_SYNC_C_MARK,
-};
-static const unsigned int msiof2_ss1_c_pins[] = {
-       /* SS1 */
-       RCAR_GP_PIN(2, 10),
-};
-static const unsigned int msiof2_ss1_c_mux[] = {
-       MSIOF2_SS1_C_MARK,
-};
-static const unsigned int msiof2_ss2_c_pins[] = {
-       /* SS2 */
-       RCAR_GP_PIN(2, 9),
-};
-static const unsigned int msiof2_ss2_c_mux[] = {
-       MSIOF2_SS2_C_MARK,
-};
-static const unsigned int msiof2_txd_c_pins[] = {
-       /* TXD */
-       RCAR_GP_PIN(2, 14),
-};
-static const unsigned int msiof2_txd_c_mux[] = {
-       MSIOF2_TXD_C_MARK,
-};
-static const unsigned int msiof2_rxd_c_pins[] = {
-       /* RXD */
-       RCAR_GP_PIN(2, 13),
-};
-static const unsigned int msiof2_rxd_c_mux[] = {
-       MSIOF2_RXD_C_MARK,
-};
-static const unsigned int msiof2_clk_d_pins[] = {
-       /* SCK */
-       RCAR_GP_PIN(0, 8),
-};
-static const unsigned int msiof2_clk_d_mux[] = {
-       MSIOF2_SCK_D_MARK,
-};
-static const unsigned int msiof2_sync_d_pins[] = {
-       /* SYNC */
-       RCAR_GP_PIN(0, 9),
-};
-static const unsigned int msiof2_sync_d_mux[] = {
-       MSIOF2_SYNC_D_MARK,
-};
-static const unsigned int msiof2_ss1_d_pins[] = {
-       /* SS1 */
-       RCAR_GP_PIN(0, 12),
-};
-static const unsigned int msiof2_ss1_d_mux[] = {
-       MSIOF2_SS1_D_MARK,
-};
-static const unsigned int msiof2_ss2_d_pins[] = {
-       /* SS2 */
-       RCAR_GP_PIN(0, 13),
-};
-static const unsigned int msiof2_ss2_d_mux[] = {
-       MSIOF2_SS2_D_MARK,
-};
-static const unsigned int msiof2_txd_d_pins[] = {
-       /* TXD */
-       RCAR_GP_PIN(0, 11),
-};
-static const unsigned int msiof2_txd_d_mux[] = {
-       MSIOF2_TXD_D_MARK,
-};
-static const unsigned int msiof2_rxd_d_pins[] = {
-       /* RXD */
-       RCAR_GP_PIN(0, 10),
-};
-static const unsigned int msiof2_rxd_d_mux[] = {
-       MSIOF2_RXD_D_MARK,
-};
-/* - MSIOF3 ----------------------------------------------------------------- */
-static const unsigned int msiof3_clk_a_pins[] = {
-       /* SCK */
-       RCAR_GP_PIN(0, 0),
-};
-static const unsigned int msiof3_clk_a_mux[] = {
-       MSIOF3_SCK_A_MARK,
-};
-static const unsigned int msiof3_sync_a_pins[] = {
-       /* SYNC */
-       RCAR_GP_PIN(0, 1),
-};
-static const unsigned int msiof3_sync_a_mux[] = {
-       MSIOF3_SYNC_A_MARK,
-};
-static const unsigned int msiof3_ss1_a_pins[] = {
-       /* SS1 */
-       RCAR_GP_PIN(0, 14),
-};
-static const unsigned int msiof3_ss1_a_mux[] = {
-       MSIOF3_SS1_A_MARK,
-};
-static const unsigned int msiof3_ss2_a_pins[] = {
-       /* SS2 */
-       RCAR_GP_PIN(0, 15),
-};
-static const unsigned int msiof3_ss2_a_mux[] = {
-       MSIOF3_SS2_A_MARK,
-};
-static const unsigned int msiof3_txd_a_pins[] = {
-       /* TXD */
-       RCAR_GP_PIN(0, 3),
-};
-static const unsigned int msiof3_txd_a_mux[] = {
-       MSIOF3_TXD_A_MARK,
-};
-static const unsigned int msiof3_rxd_a_pins[] = {
-       /* RXD */
-       RCAR_GP_PIN(0, 2),
-};
-static const unsigned int msiof3_rxd_a_mux[] = {
-       MSIOF3_RXD_A_MARK,
-};
-static const unsigned int msiof3_clk_b_pins[] = {
-       /* SCK */
-       RCAR_GP_PIN(1, 2),
-};
-static const unsigned int msiof3_clk_b_mux[] = {
-       MSIOF3_SCK_B_MARK,
-};
-static const unsigned int msiof3_sync_b_pins[] = {
-       /* SYNC */
-       RCAR_GP_PIN(1, 0),
-};
-static const unsigned int msiof3_sync_b_mux[] = {
-       MSIOF3_SYNC_B_MARK,
-};
-static const unsigned int msiof3_ss1_b_pins[] = {
-       /* SS1 */
-       RCAR_GP_PIN(1, 4),
-};
-static const unsigned int msiof3_ss1_b_mux[] = {
-       MSIOF3_SS1_B_MARK,
-};
-static const unsigned int msiof3_ss2_b_pins[] = {
-       /* SS2 */
-       RCAR_GP_PIN(1, 5),
-};
-static const unsigned int msiof3_ss2_b_mux[] = {
-       MSIOF3_SS2_B_MARK,
-};
-static const unsigned int msiof3_txd_b_pins[] = {
-       /* TXD */
-       RCAR_GP_PIN(1, 1),
-};
-static const unsigned int msiof3_txd_b_mux[] = {
-       MSIOF3_TXD_B_MARK,
-};
-static const unsigned int msiof3_rxd_b_pins[] = {
-       /* RXD */
-       RCAR_GP_PIN(1, 3),
-};
-static const unsigned int msiof3_rxd_b_mux[] = {
-       MSIOF3_RXD_B_MARK,
-};
-static const unsigned int msiof3_clk_c_pins[] = {
-       /* SCK */
-       RCAR_GP_PIN(1, 12),
-};
-static const unsigned int msiof3_clk_c_mux[] = {
-       MSIOF3_SCK_C_MARK,
-};
-static const unsigned int msiof3_sync_c_pins[] = {
-       /* SYNC */
-       RCAR_GP_PIN(1, 13),
-};
-static const unsigned int msiof3_sync_c_mux[] = {
-       MSIOF3_SYNC_C_MARK,
-};
-static const unsigned int msiof3_txd_c_pins[] = {
-       /* TXD */
-       RCAR_GP_PIN(1, 15),
-};
-static const unsigned int msiof3_txd_c_mux[] = {
-       MSIOF3_TXD_C_MARK,
-};
-static const unsigned int msiof3_rxd_c_pins[] = {
-       /* RXD */
-       RCAR_GP_PIN(1, 14),
-};
-static const unsigned int msiof3_rxd_c_mux[] = {
-       MSIOF3_RXD_C_MARK,
-};
-static const unsigned int msiof3_clk_d_pins[] = {
-       /* SCK */
-       RCAR_GP_PIN(1, 22),
-};
-static const unsigned int msiof3_clk_d_mux[] = {
-       MSIOF3_SCK_D_MARK,
-};
-static const unsigned int msiof3_sync_d_pins[] = {
-       /* SYNC */
-       RCAR_GP_PIN(1, 23),
-};
-static const unsigned int msiof3_sync_d_mux[] = {
-       MSIOF3_SYNC_D_MARK,
-};
-static const unsigned int msiof3_ss1_d_pins[] = {
-       /* SS1 */
-       RCAR_GP_PIN(1, 26),
-};
-static const unsigned int msiof3_ss1_d_mux[] = {
-       MSIOF3_SS1_D_MARK,
-};
-static const unsigned int msiof3_txd_d_pins[] = {
-       /* TXD */
-       RCAR_GP_PIN(1, 25),
-};
-static const unsigned int msiof3_txd_d_mux[] = {
-       MSIOF3_TXD_D_MARK,
-};
-static const unsigned int msiof3_rxd_d_pins[] = {
-       /* RXD */
-       RCAR_GP_PIN(1, 24),
-};
-static const unsigned int msiof3_rxd_d_mux[] = {
-       MSIOF3_RXD_D_MARK,
-};
-
-/* - PWM0 --------------------------------------------------------------------*/
-static const unsigned int pwm0_pins[] = {
-       /* PWM */
-       RCAR_GP_PIN(2, 6),
-};
-static const unsigned int pwm0_mux[] = {
-       PWM0_MARK,
-};
-/* - PWM1 --------------------------------------------------------------------*/
-static const unsigned int pwm1_a_pins[] = {
-       /* PWM */
-       RCAR_GP_PIN(2, 7),
-};
-static const unsigned int pwm1_a_mux[] = {
-       PWM1_A_MARK,
-};
-static const unsigned int pwm1_b_pins[] = {
-       /* PWM */
-       RCAR_GP_PIN(1, 8),
-};
-static const unsigned int pwm1_b_mux[] = {
-       PWM1_B_MARK,
-};
-/* - PWM2 --------------------------------------------------------------------*/
-static const unsigned int pwm2_a_pins[] = {
-       /* PWM */
-       RCAR_GP_PIN(2, 8),
-};
-static const unsigned int pwm2_a_mux[] = {
-       PWM2_A_MARK,
-};
-static const unsigned int pwm2_b_pins[] = {
-       /* PWM */
-       RCAR_GP_PIN(1, 11),
-};
-static const unsigned int pwm2_b_mux[] = {
-       PWM2_B_MARK,
-};
-/* - PWM3 --------------------------------------------------------------------*/
-static const unsigned int pwm3_a_pins[] = {
-       /* PWM */
-       RCAR_GP_PIN(1, 0),
-};
-static const unsigned int pwm3_a_mux[] = {
-       PWM3_A_MARK,
-};
-static const unsigned int pwm3_b_pins[] = {
-       /* PWM */
-       RCAR_GP_PIN(2, 2),
-};
-static const unsigned int pwm3_b_mux[] = {
-       PWM3_B_MARK,
-};
-/* - PWM4 --------------------------------------------------------------------*/
-static const unsigned int pwm4_a_pins[] = {
-       /* PWM */
-       RCAR_GP_PIN(1, 1),
-};
-static const unsigned int pwm4_a_mux[] = {
-       PWM4_A_MARK,
-};
-static const unsigned int pwm4_b_pins[] = {
-       /* PWM */
-       RCAR_GP_PIN(2, 3),
-};
-static const unsigned int pwm4_b_mux[] = {
-       PWM4_B_MARK,
-};
-/* - PWM5 --------------------------------------------------------------------*/
-static const unsigned int pwm5_a_pins[] = {
-       /* PWM */
-       RCAR_GP_PIN(1, 2),
-};
-static const unsigned int pwm5_a_mux[] = {
-       PWM5_A_MARK,
-};
-static const unsigned int pwm5_b_pins[] = {
-       /* PWM */
-       RCAR_GP_PIN(2, 4),
-};
-static const unsigned int pwm5_b_mux[] = {
-       PWM5_B_MARK,
-};
-/* - PWM6 --------------------------------------------------------------------*/
-static const unsigned int pwm6_a_pins[] = {
-       /* PWM */
-       RCAR_GP_PIN(1, 3),
-};
-static const unsigned int pwm6_a_mux[] = {
-       PWM6_A_MARK,
-};
-static const unsigned int pwm6_b_pins[] = {
-       /* PWM */
-       RCAR_GP_PIN(2, 5),
-};
-static const unsigned int pwm6_b_mux[] = {
-       PWM6_B_MARK,
-};
-
-/* - QSPI0 ------------------------------------------------------------------ */
-static const unsigned int qspi0_ctrl_pins[] = {
-       /* QSPI0_SPCLK, QSPI0_SSL */
-       PIN_QSPI0_SPCLK, PIN_QSPI0_SSL,
-};
-static const unsigned int qspi0_ctrl_mux[] = {
-       QSPI0_SPCLK_MARK, QSPI0_SSL_MARK,
-};
-static const unsigned int qspi0_data_pins[] = {
-       /* QSPI0_MOSI_IO0, QSPI0_MISO_IO1, QSPI0_IO2, QSPI0_IO3 */
-       PIN_QSPI0_MOSI_IO0, PIN_QSPI0_MISO_IO1, PIN_QSPI0_IO2, PIN_QSPI0_IO3,
-};
-static const unsigned int qspi0_data_mux[] = {
-       QSPI0_MOSI_IO0_MARK, QSPI0_MISO_IO1_MARK,
-       QSPI0_IO2_MARK, QSPI0_IO3_MARK,
-};
-/* - QSPI1 ------------------------------------------------------------------ */
-static const unsigned int qspi1_ctrl_pins[] = {
-       /* QSPI1_SPCLK, QSPI1_SSL */
-       PIN_QSPI1_SPCLK, PIN_QSPI1_SSL,
-};
-static const unsigned int qspi1_ctrl_mux[] = {
-       QSPI1_SPCLK_MARK, QSPI1_SSL_MARK,
-};
-static const unsigned int qspi1_data_pins[] = {
-       /* QSPI1_MOSI_IO0, QSPI1_MISO_IO1, QSPI1_IO2, QSPI1_IO3 */
-       PIN_QSPI1_MOSI_IO0, PIN_QSPI1_MISO_IO1, PIN_QSPI1_IO2, PIN_QSPI1_IO3,
-};
-static const unsigned int qspi1_data_mux[] = {
-       QSPI1_MOSI_IO0_MARK, QSPI1_MISO_IO1_MARK,
-       QSPI1_IO2_MARK, QSPI1_IO3_MARK,
-};
-
-/* - SATA --------------------------------------------------------------------*/
-static const unsigned int sata0_devslp_a_pins[] = {
-       /* DEVSLP */
-       RCAR_GP_PIN(6, 16),
-};
-static const unsigned int sata0_devslp_a_mux[] = {
-       SATA_DEVSLP_A_MARK,
-};
-static const unsigned int sata0_devslp_b_pins[] = {
-       /* DEVSLP */
-       RCAR_GP_PIN(4, 6),
-};
-static const unsigned int sata0_devslp_b_mux[] = {
-       SATA_DEVSLP_B_MARK,
-};
-
-/* - SCIF0 ------------------------------------------------------------------ */
-static const unsigned int scif0_data_pins[] = {
-       /* RX, TX */
-       RCAR_GP_PIN(5, 1), RCAR_GP_PIN(5, 2),
-};
-static const unsigned int scif0_data_mux[] = {
-       RX0_MARK, TX0_MARK,
-};
-static const unsigned int scif0_clk_pins[] = {
-       /* SCK */
-       RCAR_GP_PIN(5, 0),
-};
-static const unsigned int scif0_clk_mux[] = {
-       SCK0_MARK,
-};
-static const unsigned int scif0_ctrl_pins[] = {
-       /* RTS, CTS */
-       RCAR_GP_PIN(5, 4), RCAR_GP_PIN(5, 3),
-};
-static const unsigned int scif0_ctrl_mux[] = {
-       RTS0_N_MARK, CTS0_N_MARK,
-};
-/* - SCIF1 ------------------------------------------------------------------ */
-static const unsigned int scif1_data_a_pins[] = {
-       /* RX, TX */
-       RCAR_GP_PIN(5, 5), RCAR_GP_PIN(5, 6),
-};
-static const unsigned int scif1_data_a_mux[] = {
-       RX1_A_MARK, TX1_A_MARK,
-};
-static const unsigned int scif1_clk_pins[] = {
-       /* SCK */
-       RCAR_GP_PIN(6, 21),
-};
-static const unsigned int scif1_clk_mux[] = {
-       SCK1_MARK,
-};
-static const unsigned int scif1_ctrl_pins[] = {
-       /* RTS, CTS */
-       RCAR_GP_PIN(5, 8), RCAR_GP_PIN(5, 7),
-};
-static const unsigned int scif1_ctrl_mux[] = {
-       RTS1_N_MARK, CTS1_N_MARK,
-};
-
-static const unsigned int scif1_data_b_pins[] = {
-       /* RX, TX */
-       RCAR_GP_PIN(5, 24), RCAR_GP_PIN(5, 25),
-};
-static const unsigned int scif1_data_b_mux[] = {
-       RX1_B_MARK, TX1_B_MARK,
-};
-/* - SCIF2 ------------------------------------------------------------------ */
-static const unsigned int scif2_data_a_pins[] = {
-       /* RX, TX */
-       RCAR_GP_PIN(5, 11), RCAR_GP_PIN(5, 10),
-};
-static const unsigned int scif2_data_a_mux[] = {
-       RX2_A_MARK, TX2_A_MARK,
-};
-static const unsigned int scif2_clk_pins[] = {
-       /* SCK */
-       RCAR_GP_PIN(5, 9),
-};
-static const unsigned int scif2_clk_mux[] = {
-       SCK2_MARK,
-};
-static const unsigned int scif2_data_b_pins[] = {
-       /* RX, TX */
-       RCAR_GP_PIN(5, 15), RCAR_GP_PIN(5, 16),
-};
-static const unsigned int scif2_data_b_mux[] = {
-       RX2_B_MARK, TX2_B_MARK,
-};
-/* - SCIF3 ------------------------------------------------------------------ */
-static const unsigned int scif3_data_a_pins[] = {
-       /* RX, TX */
-       RCAR_GP_PIN(1, 23), RCAR_GP_PIN(1, 24),
-};
-static const unsigned int scif3_data_a_mux[] = {
-       RX3_A_MARK, TX3_A_MARK,
-};
-static const unsigned int scif3_clk_pins[] = {
-       /* SCK */
-       RCAR_GP_PIN(1, 22),
-};
-static const unsigned int scif3_clk_mux[] = {
-       SCK3_MARK,
-};
-static const unsigned int scif3_ctrl_pins[] = {
-       /* RTS, CTS */
-       RCAR_GP_PIN(1, 26), RCAR_GP_PIN(1, 25),
-};
-static const unsigned int scif3_ctrl_mux[] = {
-       RTS3_N_MARK, CTS3_N_MARK,
-};
-static const unsigned int scif3_data_b_pins[] = {
-       /* RX, TX */
-       RCAR_GP_PIN(1, 8), RCAR_GP_PIN(1, 11),
-};
-static const unsigned int scif3_data_b_mux[] = {
-       RX3_B_MARK, TX3_B_MARK,
-};
-/* - SCIF4 ------------------------------------------------------------------ */
-static const unsigned int scif4_data_a_pins[] = {
-       /* RX, TX */
-       RCAR_GP_PIN(2, 11), RCAR_GP_PIN(2, 12),
-};
-static const unsigned int scif4_data_a_mux[] = {
-       RX4_A_MARK, TX4_A_MARK,
-};
-static const unsigned int scif4_clk_a_pins[] = {
-       /* SCK */
-       RCAR_GP_PIN(2, 10),
-};
-static const unsigned int scif4_clk_a_mux[] = {
-       SCK4_A_MARK,
-};
-static const unsigned int scif4_ctrl_a_pins[] = {
-       /* RTS, CTS */
-       RCAR_GP_PIN(2, 14), RCAR_GP_PIN(2, 13),
-};
-static const unsigned int scif4_ctrl_a_mux[] = {
-       RTS4_N_A_MARK, CTS4_N_A_MARK,
-};
-static const unsigned int scif4_data_b_pins[] = {
-       /* RX, TX */
-       RCAR_GP_PIN(1, 6), RCAR_GP_PIN(1, 7),
-};
-static const unsigned int scif4_data_b_mux[] = {
-       RX4_B_MARK, TX4_B_MARK,
-};
-static const unsigned int scif4_clk_b_pins[] = {
-       /* SCK */
-       RCAR_GP_PIN(1, 5),
-};
-static const unsigned int scif4_clk_b_mux[] = {
-       SCK4_B_MARK,
-};
-static const unsigned int scif4_ctrl_b_pins[] = {
-       /* RTS, CTS */
-       RCAR_GP_PIN(1, 10), RCAR_GP_PIN(1, 9),
-};
-static const unsigned int scif4_ctrl_b_mux[] = {
-       RTS4_N_B_MARK, CTS4_N_B_MARK,
-};
-static const unsigned int scif4_data_c_pins[] = {
-       /* RX, TX */
-       RCAR_GP_PIN(0, 12), RCAR_GP_PIN(0, 13),
-};
-static const unsigned int scif4_data_c_mux[] = {
-       RX4_C_MARK, TX4_C_MARK,
-};
-static const unsigned int scif4_clk_c_pins[] = {
-       /* SCK */
-       RCAR_GP_PIN(0, 8),
-};
-static const unsigned int scif4_clk_c_mux[] = {
-       SCK4_C_MARK,
-};
-static const unsigned int scif4_ctrl_c_pins[] = {
-       /* RTS, CTS */
-       RCAR_GP_PIN(0, 11), RCAR_GP_PIN(0, 10),
-};
-static const unsigned int scif4_ctrl_c_mux[] = {
-       RTS4_N_C_MARK, CTS4_N_C_MARK,
-};
-/* - SCIF5 ------------------------------------------------------------------ */
-static const unsigned int scif5_data_pins[] = {
-       /* RX, TX */
-       RCAR_GP_PIN(5, 19), RCAR_GP_PIN(5, 21),
-};
-static const unsigned int scif5_data_mux[] = {
-       RX5_MARK, TX5_MARK,
-};
-static const unsigned int scif5_clk_pins[] = {
-       /* SCK */
-       RCAR_GP_PIN(6, 21),
-};
-static const unsigned int scif5_clk_mux[] = {
-       SCK5_MARK,
-};
-
-/* - SCIF Clock ------------------------------------------------------------- */
-static const unsigned int scif_clk_a_pins[] = {
-       /* SCIF_CLK */
-       RCAR_GP_PIN(6, 23),
-};
-static const unsigned int scif_clk_a_mux[] = {
-       SCIF_CLK_A_MARK,
-};
-static const unsigned int scif_clk_b_pins[] = {
-       /* SCIF_CLK */
-       RCAR_GP_PIN(5, 9),
-};
-static const unsigned int scif_clk_b_mux[] = {
-       SCIF_CLK_B_MARK,
-};
-
-/* - SDHI0 ------------------------------------------------------------------ */
-static const unsigned int sdhi0_data_pins[] = {
-       /* D[0:3] */
-       RCAR_GP_PIN(3, 2), RCAR_GP_PIN(3, 3),
-       RCAR_GP_PIN(3, 4), RCAR_GP_PIN(3, 5),
-};
-static const unsigned int sdhi0_data_mux[] = {
-       SD0_DAT0_MARK, SD0_DAT1_MARK,
-       SD0_DAT2_MARK, SD0_DAT3_MARK,
-};
-static const unsigned int sdhi0_ctrl_pins[] = {
-       /* CLK, CMD */
-       RCAR_GP_PIN(3, 0), RCAR_GP_PIN(3, 1),
-};
-static const unsigned int sdhi0_ctrl_mux[] = {
-       SD0_CLK_MARK, SD0_CMD_MARK,
-};
-static const unsigned int sdhi0_cd_pins[] = {
-       /* CD */
-       RCAR_GP_PIN(3, 12),
-};
-static const unsigned int sdhi0_cd_mux[] = {
-       SD0_CD_MARK,
-};
-static const unsigned int sdhi0_wp_pins[] = {
-       /* WP */
-       RCAR_GP_PIN(3, 13),
-};
-static const unsigned int sdhi0_wp_mux[] = {
-       SD0_WP_MARK,
-};
-/* - SDHI1 ------------------------------------------------------------------ */
-static const unsigned int sdhi1_data_pins[] = {
-       /* D[0:3] */
-       RCAR_GP_PIN(3, 8),  RCAR_GP_PIN(3, 9),
-       RCAR_GP_PIN(3, 10), RCAR_GP_PIN(3, 11),
-};
-static const unsigned int sdhi1_data_mux[] = {
-       SD1_DAT0_MARK, SD1_DAT1_MARK,
-       SD1_DAT2_MARK, SD1_DAT3_MARK,
-};
-static const unsigned int sdhi1_ctrl_pins[] = {
-       /* CLK, CMD */
-       RCAR_GP_PIN(3, 6), RCAR_GP_PIN(3, 7),
-};
-static const unsigned int sdhi1_ctrl_mux[] = {
-       SD1_CLK_MARK, SD1_CMD_MARK,
-};
-static const unsigned int sdhi1_cd_pins[] = {
-       /* CD */
-       RCAR_GP_PIN(3, 14),
-};
-static const unsigned int sdhi1_cd_mux[] = {
-       SD1_CD_MARK,
-};
-static const unsigned int sdhi1_wp_pins[] = {
-       /* WP */
-       RCAR_GP_PIN(3, 15),
-};
-static const unsigned int sdhi1_wp_mux[] = {
-       SD1_WP_MARK,
-};
-/* - SDHI2 ------------------------------------------------------------------ */
-static const unsigned int sdhi2_data_pins[] = {
-       /* D[0:7] */
-       RCAR_GP_PIN(4, 2),  RCAR_GP_PIN(4, 3),
-       RCAR_GP_PIN(4, 4),  RCAR_GP_PIN(4, 5),
-       RCAR_GP_PIN(3, 8),  RCAR_GP_PIN(3, 9),
-       RCAR_GP_PIN(3, 10), RCAR_GP_PIN(3, 11),
-};
-static const unsigned int sdhi2_data_mux[] = {
-       SD2_DAT0_MARK, SD2_DAT1_MARK,
-       SD2_DAT2_MARK, SD2_DAT3_MARK,
-       SD2_DAT4_MARK, SD2_DAT5_MARK,
-       SD2_DAT6_MARK, SD2_DAT7_MARK,
-};
-static const unsigned int sdhi2_ctrl_pins[] = {
-       /* CLK, CMD */
-       RCAR_GP_PIN(4, 0), RCAR_GP_PIN(4, 1),
-};
-static const unsigned int sdhi2_ctrl_mux[] = {
-       SD2_CLK_MARK, SD2_CMD_MARK,
-};
-static const unsigned int sdhi2_cd_a_pins[] = {
-       /* CD */
-       RCAR_GP_PIN(4, 13),
-};
-static const unsigned int sdhi2_cd_a_mux[] = {
-       SD2_CD_A_MARK,
-};
-static const unsigned int sdhi2_cd_b_pins[] = {
-       /* CD */
-       RCAR_GP_PIN(5, 10),
-};
-static const unsigned int sdhi2_cd_b_mux[] = {
-       SD2_CD_B_MARK,
-};
-static const unsigned int sdhi2_wp_a_pins[] = {
-       /* WP */
-       RCAR_GP_PIN(4, 14),
-};
-static const unsigned int sdhi2_wp_a_mux[] = {
-       SD2_WP_A_MARK,
-};
-static const unsigned int sdhi2_wp_b_pins[] = {
-       /* WP */
-       RCAR_GP_PIN(5, 11),
-};
-static const unsigned int sdhi2_wp_b_mux[] = {
-       SD2_WP_B_MARK,
-};
-static const unsigned int sdhi2_ds_pins[] = {
-       /* DS */
-       RCAR_GP_PIN(4, 6),
-};
-static const unsigned int sdhi2_ds_mux[] = {
-       SD2_DS_MARK,
-};
-/* - SDHI3 ------------------------------------------------------------------ */
-static const unsigned int sdhi3_data_pins[] = {
-       /* D[0:7] */
-       RCAR_GP_PIN(4, 9),  RCAR_GP_PIN(4, 10),
-       RCAR_GP_PIN(4, 11), RCAR_GP_PIN(4, 12),
-       RCAR_GP_PIN(4, 13), RCAR_GP_PIN(4, 14),
-       RCAR_GP_PIN(4, 15), RCAR_GP_PIN(4, 16),
-};
-static const unsigned int sdhi3_data_mux[] = {
-       SD3_DAT0_MARK, SD3_DAT1_MARK,
-       SD3_DAT2_MARK, SD3_DAT3_MARK,
-       SD3_DAT4_MARK, SD3_DAT5_MARK,
-       SD3_DAT6_MARK, SD3_DAT7_MARK,
-};
-static const unsigned int sdhi3_ctrl_pins[] = {
-       /* CLK, CMD */
-       RCAR_GP_PIN(4, 7), RCAR_GP_PIN(4, 8),
-};
-static const unsigned int sdhi3_ctrl_mux[] = {
-       SD3_CLK_MARK, SD3_CMD_MARK,
-};
-static const unsigned int sdhi3_cd_pins[] = {
-       /* CD */
-       RCAR_GP_PIN(4, 15),
-};
-static const unsigned int sdhi3_cd_mux[] = {
-       SD3_CD_MARK,
-};
-static const unsigned int sdhi3_wp_pins[] = {
-       /* WP */
-       RCAR_GP_PIN(4, 16),
-};
-static const unsigned int sdhi3_wp_mux[] = {
-       SD3_WP_MARK,
-};
-static const unsigned int sdhi3_ds_pins[] = {
-       /* DS */
-       RCAR_GP_PIN(4, 17),
-};
-static const unsigned int sdhi3_ds_mux[] = {
-       SD3_DS_MARK,
-};
-
-/* - SSI -------------------------------------------------------------------- */
-static const unsigned int ssi0_data_pins[] = {
-       /* SDATA */
-       RCAR_GP_PIN(6, 2),
-};
-static const unsigned int ssi0_data_mux[] = {
-       SSI_SDATA0_MARK,
-};
-static const unsigned int ssi01239_ctrl_pins[] = {
-       /* SCK, WS */
-       RCAR_GP_PIN(6, 0), RCAR_GP_PIN(6, 1),
-};
-static const unsigned int ssi01239_ctrl_mux[] = {
-       SSI_SCK01239_MARK, SSI_WS01239_MARK,
-};
-static const unsigned int ssi1_data_a_pins[] = {
-       /* SDATA */
-       RCAR_GP_PIN(6, 3),
-};
-static const unsigned int ssi1_data_a_mux[] = {
-       SSI_SDATA1_A_MARK,
-};
-static const unsigned int ssi1_data_b_pins[] = {
-       /* SDATA */
-       RCAR_GP_PIN(5, 12),
-};
-static const unsigned int ssi1_data_b_mux[] = {
-       SSI_SDATA1_B_MARK,
-};
-static const unsigned int ssi1_ctrl_a_pins[] = {
-       /* SCK, WS */
-       RCAR_GP_PIN(6, 26), RCAR_GP_PIN(6, 27),
-};
-static const unsigned int ssi1_ctrl_a_mux[] = {
-       SSI_SCK1_A_MARK, SSI_WS1_A_MARK,
-};
-static const unsigned int ssi1_ctrl_b_pins[] = {
-       /* SCK, WS */
-       RCAR_GP_PIN(6, 4), RCAR_GP_PIN(6, 21),
-};
-static const unsigned int ssi1_ctrl_b_mux[] = {
-       SSI_SCK1_B_MARK, SSI_WS1_B_MARK,
-};
-static const unsigned int ssi2_data_a_pins[] = {
-       /* SDATA */
-       RCAR_GP_PIN(6, 4),
-};
-static const unsigned int ssi2_data_a_mux[] = {
-       SSI_SDATA2_A_MARK,
-};
-static const unsigned int ssi2_data_b_pins[] = {
-       /* SDATA */
-       RCAR_GP_PIN(5, 13),
-};
-static const unsigned int ssi2_data_b_mux[] = {
-       SSI_SDATA2_B_MARK,
-};
-static const unsigned int ssi2_ctrl_a_pins[] = {
-       /* SCK, WS */
-       RCAR_GP_PIN(5, 19), RCAR_GP_PIN(5, 21),
-};
-static const unsigned int ssi2_ctrl_a_mux[] = {
-       SSI_SCK2_A_MARK, SSI_WS2_A_MARK,
-};
-static const unsigned int ssi2_ctrl_b_pins[] = {
-       /* SCK, WS */
-       RCAR_GP_PIN(6, 28), RCAR_GP_PIN(6, 29),
-};
-static const unsigned int ssi2_ctrl_b_mux[] = {
-       SSI_SCK2_B_MARK, SSI_WS2_B_MARK,
-};
-static const unsigned int ssi3_data_pins[] = {
-       /* SDATA */
-       RCAR_GP_PIN(6, 7),
-};
-static const unsigned int ssi3_data_mux[] = {
-       SSI_SDATA3_MARK,
-};
-static const unsigned int ssi349_ctrl_pins[] = {
-       /* SCK, WS */
-       RCAR_GP_PIN(6, 5), RCAR_GP_PIN(6, 6),
-};
-static const unsigned int ssi349_ctrl_mux[] = {
-       SSI_SCK349_MARK, SSI_WS349_MARK,
-};
-static const unsigned int ssi4_data_pins[] = {
-       /* SDATA */
-       RCAR_GP_PIN(6, 10),
-};
-static const unsigned int ssi4_data_mux[] = {
-       SSI_SDATA4_MARK,
-};
-static const unsigned int ssi4_ctrl_pins[] = {
-       /* SCK, WS */
-       RCAR_GP_PIN(6, 8), RCAR_GP_PIN(6, 9),
-};
-static const unsigned int ssi4_ctrl_mux[] = {
-       SSI_SCK4_MARK, SSI_WS4_MARK,
-};
-static const unsigned int ssi5_data_pins[] = {
-       /* SDATA */
-       RCAR_GP_PIN(6, 13),
-};
-static const unsigned int ssi5_data_mux[] = {
-       SSI_SDATA5_MARK,
-};
-static const unsigned int ssi5_ctrl_pins[] = {
-       /* SCK, WS */
-       RCAR_GP_PIN(6, 11), RCAR_GP_PIN(6, 12),
-};
-static const unsigned int ssi5_ctrl_mux[] = {
-       SSI_SCK5_MARK, SSI_WS5_MARK,
-};
-static const unsigned int ssi6_data_pins[] = {
-       /* SDATA */
-       RCAR_GP_PIN(6, 16),
-};
-static const unsigned int ssi6_data_mux[] = {
-       SSI_SDATA6_MARK,
-};
-static const unsigned int ssi6_ctrl_pins[] = {
-       /* SCK, WS */
-       RCAR_GP_PIN(6, 14), RCAR_GP_PIN(6, 15),
-};
-static const unsigned int ssi6_ctrl_mux[] = {
-       SSI_SCK6_MARK, SSI_WS6_MARK,
-};
-static const unsigned int ssi7_data_pins[] = {
-       /* SDATA */
-       RCAR_GP_PIN(6, 19),
-};
-static const unsigned int ssi7_data_mux[] = {
-       SSI_SDATA7_MARK,
-};
-static const unsigned int ssi78_ctrl_pins[] = {
-       /* SCK, WS */
-       RCAR_GP_PIN(6, 17), RCAR_GP_PIN(6, 18),
-};
-static const unsigned int ssi78_ctrl_mux[] = {
-       SSI_SCK78_MARK, SSI_WS78_MARK,
-};
-static const unsigned int ssi8_data_pins[] = {
-       /* SDATA */
-       RCAR_GP_PIN(6, 20),
-};
-static const unsigned int ssi8_data_mux[] = {
-       SSI_SDATA8_MARK,
-};
-static const unsigned int ssi9_data_a_pins[] = {
-       /* SDATA */
-       RCAR_GP_PIN(6, 21),
-};
-static const unsigned int ssi9_data_a_mux[] = {
-       SSI_SDATA9_A_MARK,
-};
-static const unsigned int ssi9_data_b_pins[] = {
-       /* SDATA */
-       RCAR_GP_PIN(5, 14),
-};
-static const unsigned int ssi9_data_b_mux[] = {
-       SSI_SDATA9_B_MARK,
-};
-static const unsigned int ssi9_ctrl_a_pins[] = {
-       /* SCK, WS */
-       RCAR_GP_PIN(5, 15), RCAR_GP_PIN(5, 16),
-};
-static const unsigned int ssi9_ctrl_a_mux[] = {
-       SSI_SCK9_A_MARK, SSI_WS9_A_MARK,
-};
-static const unsigned int ssi9_ctrl_b_pins[] = {
-       /* SCK, WS */
-       RCAR_GP_PIN(6, 30), RCAR_GP_PIN(6, 31),
-};
-static const unsigned int ssi9_ctrl_b_mux[] = {
-       SSI_SCK9_B_MARK, SSI_WS9_B_MARK,
-};
-
-/* - TMU -------------------------------------------------------------------- */
-static const unsigned int tmu_tclk1_a_pins[] = {
-       /* TCLK */
-       RCAR_GP_PIN(6, 23),
-};
-static const unsigned int tmu_tclk1_a_mux[] = {
-       TCLK1_A_MARK,
-};
-static const unsigned int tmu_tclk1_b_pins[] = {
-       /* TCLK */
-       RCAR_GP_PIN(5, 19),
-};
-static const unsigned int tmu_tclk1_b_mux[] = {
-       TCLK1_B_MARK,
-};
-static const unsigned int tmu_tclk2_a_pins[] = {
-       /* TCLK */
-       RCAR_GP_PIN(6, 19),
-};
-static const unsigned int tmu_tclk2_a_mux[] = {
-       TCLK2_A_MARK,
-};
-static const unsigned int tmu_tclk2_b_pins[] = {
-       /* TCLK */
-       RCAR_GP_PIN(6, 28),
-};
-static const unsigned int tmu_tclk2_b_mux[] = {
-       TCLK2_B_MARK,
-};
-
-/* - TPU ------------------------------------------------------------------- */
-static const unsigned int tpu_to0_pins[] = {
-       /* TPU0TO0 */
-       RCAR_GP_PIN(6, 28),
-};
-static const unsigned int tpu_to0_mux[] = {
-       TPU0TO0_MARK,
-};
-static const unsigned int tpu_to1_pins[] = {
-       /* TPU0TO1 */
-       RCAR_GP_PIN(6, 29),
-};
-static const unsigned int tpu_to1_mux[] = {
-       TPU0TO1_MARK,
-};
-static const unsigned int tpu_to2_pins[] = {
-       /* TPU0TO2 */
-       RCAR_GP_PIN(6, 30),
-};
-static const unsigned int tpu_to2_mux[] = {
-       TPU0TO2_MARK,
-};
-static const unsigned int tpu_to3_pins[] = {
-       /* TPU0TO3 */
-       RCAR_GP_PIN(6, 31),
-};
-static const unsigned int tpu_to3_mux[] = {
-       TPU0TO3_MARK,
-};
-
-/* - USB0 ------------------------------------------------------------------- */
-static const unsigned int usb0_pins[] = {
-       /* PWEN, OVC */
-       RCAR_GP_PIN(6, 24), RCAR_GP_PIN(6, 25),
-};
-static const unsigned int usb0_mux[] = {
-       USB0_PWEN_MARK, USB0_OVC_MARK,
-};
-/* - USB1 ------------------------------------------------------------------- */
-static const unsigned int usb1_pins[] = {
-       /* PWEN, OVC */
-       RCAR_GP_PIN(6, 26), RCAR_GP_PIN(6, 27),
-};
-static const unsigned int usb1_mux[] = {
-       USB1_PWEN_MARK, USB1_OVC_MARK,
-};
-/* - USB2 ------------------------------------------------------------------- */
-static const unsigned int usb2_pins[] = {
-       /* PWEN, OVC */
-       RCAR_GP_PIN(6, 14), RCAR_GP_PIN(6, 15),
-};
-static const unsigned int usb2_mux[] = {
-       USB2_PWEN_MARK, USB2_OVC_MARK,
-};
-
-/* - USB30 ------------------------------------------------------------------ */
-static const unsigned int usb30_pins[] = {
-       /* PWEN, OVC */
-       RCAR_GP_PIN(6, 28), RCAR_GP_PIN(6, 29),
-};
-static const unsigned int usb30_mux[] = {
-       USB30_PWEN_MARK, USB30_OVC_MARK,
-};
-/* - USB31 ------------------------------------------------------------------ */
-static const unsigned int usb31_pins[] = {
-       /* PWEN, OVC */
-       RCAR_GP_PIN(6, 30), RCAR_GP_PIN(6, 31),
-};
-static const unsigned int usb31_mux[] = {
-       USB31_PWEN_MARK, USB31_OVC_MARK,
-};
-
-/* - VIN4 ------------------------------------------------------------------- */
-static const unsigned int vin4_data18_a_pins[] = {
-       RCAR_GP_PIN(0, 10), RCAR_GP_PIN(0, 11),
-       RCAR_GP_PIN(0, 12), RCAR_GP_PIN(0, 13),
-       RCAR_GP_PIN(0, 14), RCAR_GP_PIN(0, 15),
-       RCAR_GP_PIN(1, 2), RCAR_GP_PIN(1, 3),
-       RCAR_GP_PIN(1, 4), RCAR_GP_PIN(1, 5),
-       RCAR_GP_PIN(1, 6), RCAR_GP_PIN(1, 7),
-       RCAR_GP_PIN(0, 2), RCAR_GP_PIN(0, 3),
-       RCAR_GP_PIN(0, 4), RCAR_GP_PIN(0, 5),
-       RCAR_GP_PIN(0, 6), RCAR_GP_PIN(0, 7),
-};
-static const unsigned int vin4_data18_a_mux[] = {
-       VI4_DATA2_A_MARK, VI4_DATA3_A_MARK,
-       VI4_DATA4_A_MARK, VI4_DATA5_A_MARK,
-       VI4_DATA6_A_MARK, VI4_DATA7_A_MARK,
-       VI4_DATA10_MARK, VI4_DATA11_MARK,
-       VI4_DATA12_MARK, VI4_DATA13_MARK,
-       VI4_DATA14_MARK, VI4_DATA15_MARK,
-       VI4_DATA18_MARK, VI4_DATA19_MARK,
-       VI4_DATA20_MARK, VI4_DATA21_MARK,
-       VI4_DATA22_MARK, VI4_DATA23_MARK,
-};
-static const unsigned int vin4_data18_b_pins[] = {
-       RCAR_GP_PIN(2, 2), RCAR_GP_PIN(2, 3),
-       RCAR_GP_PIN(2, 4), RCAR_GP_PIN(2, 5),
-       RCAR_GP_PIN(2, 6), RCAR_GP_PIN(2, 7),
-       RCAR_GP_PIN(1, 2), RCAR_GP_PIN(1, 3),
-       RCAR_GP_PIN(1, 4), RCAR_GP_PIN(1, 5),
-       RCAR_GP_PIN(1, 6), RCAR_GP_PIN(1, 7),
-       RCAR_GP_PIN(0, 2), RCAR_GP_PIN(0, 3),
-       RCAR_GP_PIN(0, 4), RCAR_GP_PIN(0, 5),
-       RCAR_GP_PIN(0, 6), RCAR_GP_PIN(0, 7),
-};
-static const unsigned int vin4_data18_b_mux[] = {
-       VI4_DATA2_B_MARK, VI4_DATA3_B_MARK,
-       VI4_DATA4_B_MARK, VI4_DATA5_B_MARK,
-       VI4_DATA6_B_MARK, VI4_DATA7_B_MARK,
-       VI4_DATA10_MARK, VI4_DATA11_MARK,
-       VI4_DATA12_MARK, VI4_DATA13_MARK,
-       VI4_DATA14_MARK, VI4_DATA15_MARK,
-       VI4_DATA18_MARK, VI4_DATA19_MARK,
-       VI4_DATA20_MARK, VI4_DATA21_MARK,
-       VI4_DATA22_MARK, VI4_DATA23_MARK,
-};
-static const unsigned int vin4_data_a_pins[] = {
-       RCAR_GP_PIN(0, 8), RCAR_GP_PIN(0, 9),
-       RCAR_GP_PIN(0, 10), RCAR_GP_PIN(0, 11),
-       RCAR_GP_PIN(0, 12), RCAR_GP_PIN(0, 13),
-       RCAR_GP_PIN(0, 14), RCAR_GP_PIN(0, 15),
-       RCAR_GP_PIN(1, 0), RCAR_GP_PIN(1, 1),
-       RCAR_GP_PIN(1, 2), RCAR_GP_PIN(1, 3),
-       RCAR_GP_PIN(1, 4), RCAR_GP_PIN(1, 5),
-       RCAR_GP_PIN(1, 6), RCAR_GP_PIN(1, 7),
-       RCAR_GP_PIN(0, 0), RCAR_GP_PIN(0, 1),
-       RCAR_GP_PIN(0, 2), RCAR_GP_PIN(0, 3),
-       RCAR_GP_PIN(0, 4), RCAR_GP_PIN(0, 5),
-       RCAR_GP_PIN(0, 6), RCAR_GP_PIN(0, 7),
-};
-static const unsigned int vin4_data_a_mux[] = {
-       VI4_DATA0_A_MARK, VI4_DATA1_A_MARK,
-       VI4_DATA2_A_MARK, VI4_DATA3_A_MARK,
-       VI4_DATA4_A_MARK, VI4_DATA5_A_MARK,
-       VI4_DATA6_A_MARK, VI4_DATA7_A_MARK,
-       VI4_DATA8_MARK,  VI4_DATA9_MARK,
-       VI4_DATA10_MARK, VI4_DATA11_MARK,
-       VI4_DATA12_MARK, VI4_DATA13_MARK,
-       VI4_DATA14_MARK, VI4_DATA15_MARK,
-       VI4_DATA16_MARK, VI4_DATA17_MARK,
-       VI4_DATA18_MARK, VI4_DATA19_MARK,
-       VI4_DATA20_MARK, VI4_DATA21_MARK,
-       VI4_DATA22_MARK, VI4_DATA23_MARK,
-};
-static const unsigned int vin4_data_b_pins[] = {
-       RCAR_GP_PIN(2, 0), RCAR_GP_PIN(2, 1),
-       RCAR_GP_PIN(2, 2), RCAR_GP_PIN(2, 3),
-       RCAR_GP_PIN(2, 4), RCAR_GP_PIN(2, 5),
-       RCAR_GP_PIN(2, 6), RCAR_GP_PIN(2, 7),
-       RCAR_GP_PIN(1, 0), RCAR_GP_PIN(1, 1),
-       RCAR_GP_PIN(1, 2), RCAR_GP_PIN(1, 3),
-       RCAR_GP_PIN(1, 4), RCAR_GP_PIN(1, 5),
-       RCAR_GP_PIN(1, 6), RCAR_GP_PIN(1, 7),
-       RCAR_GP_PIN(0, 0), RCAR_GP_PIN(0, 1),
-       RCAR_GP_PIN(0, 2), RCAR_GP_PIN(0, 3),
-       RCAR_GP_PIN(0, 4), RCAR_GP_PIN(0, 5),
-       RCAR_GP_PIN(0, 6), RCAR_GP_PIN(0, 7),
-};
-static const unsigned int vin4_data_b_mux[] = {
-       VI4_DATA0_B_MARK, VI4_DATA1_B_MARK,
-       VI4_DATA2_B_MARK, VI4_DATA3_B_MARK,
-       VI4_DATA4_B_MARK, VI4_DATA5_B_MARK,
-       VI4_DATA6_B_MARK, VI4_DATA7_B_MARK,
-       VI4_DATA8_MARK,  VI4_DATA9_MARK,
-       VI4_DATA10_MARK, VI4_DATA11_MARK,
-       VI4_DATA12_MARK, VI4_DATA13_MARK,
-       VI4_DATA14_MARK, VI4_DATA15_MARK,
-       VI4_DATA16_MARK, VI4_DATA17_MARK,
-       VI4_DATA18_MARK, VI4_DATA19_MARK,
-       VI4_DATA20_MARK, VI4_DATA21_MARK,
-       VI4_DATA22_MARK, VI4_DATA23_MARK,
-};
-static const unsigned int vin4_sync_pins[] = {
-       /* HSYNC#, VSYNC# */
-       RCAR_GP_PIN(1, 18), RCAR_GP_PIN(1, 17),
-};
-static const unsigned int vin4_sync_mux[] = {
-       VI4_HSYNC_N_MARK, VI4_VSYNC_N_MARK,
-};
-static const unsigned int vin4_field_pins[] = {
-       /* FIELD */
-       RCAR_GP_PIN(1, 16),
-};
-static const unsigned int vin4_field_mux[] = {
-       VI4_FIELD_MARK,
-};
-static const unsigned int vin4_clkenb_pins[] = {
-       /* CLKENB */
-       RCAR_GP_PIN(1, 19),
-};
-static const unsigned int vin4_clkenb_mux[] = {
-       VI4_CLKENB_MARK,
-};
-static const unsigned int vin4_clk_pins[] = {
-       /* CLK */
-       RCAR_GP_PIN(1, 27),
-};
-static const unsigned int vin4_clk_mux[] = {
-       VI4_CLK_MARK,
-};
-
-/* - VIN5 ------------------------------------------------------------------- */
-static const unsigned int vin5_data_pins[] = {
-       RCAR_GP_PIN(0, 0), RCAR_GP_PIN(0, 1),
-       RCAR_GP_PIN(0, 2), RCAR_GP_PIN(0, 3),
-       RCAR_GP_PIN(0, 4), RCAR_GP_PIN(0, 5),
-       RCAR_GP_PIN(0, 6), RCAR_GP_PIN(0, 7),
-       RCAR_GP_PIN(1, 12), RCAR_GP_PIN(1, 13),
-       RCAR_GP_PIN(1, 14), RCAR_GP_PIN(1, 15),
-       RCAR_GP_PIN(1, 4), RCAR_GP_PIN(1, 5),
-       RCAR_GP_PIN(1, 6), RCAR_GP_PIN(1, 7),
-};
-static const unsigned int vin5_data_mux[] = {
-       VI5_DATA0_MARK, VI5_DATA1_MARK,
-       VI5_DATA2_MARK, VI5_DATA3_MARK,
-       VI5_DATA4_MARK, VI5_DATA5_MARK,
-       VI5_DATA6_MARK, VI5_DATA7_MARK,
-       VI5_DATA8_MARK,  VI5_DATA9_MARK,
-       VI5_DATA10_MARK, VI5_DATA11_MARK,
-       VI5_DATA12_MARK, VI5_DATA13_MARK,
-       VI5_DATA14_MARK, VI5_DATA15_MARK,
-};
-static const unsigned int vin5_sync_pins[] = {
-       /* HSYNC#, VSYNC# */
-       RCAR_GP_PIN(1, 10), RCAR_GP_PIN(1, 9),
-};
-static const unsigned int vin5_sync_mux[] = {
-       VI5_HSYNC_N_MARK, VI5_VSYNC_N_MARK,
-};
-static const unsigned int vin5_field_pins[] = {
-       RCAR_GP_PIN(1, 11),
-};
-static const unsigned int vin5_field_mux[] = {
-       /* FIELD */
-       VI5_FIELD_MARK,
-};
-static const unsigned int vin5_clkenb_pins[] = {
-       RCAR_GP_PIN(1, 20),
-};
-static const unsigned int vin5_clkenb_mux[] = {
-       /* CLKENB */
-       VI5_CLKENB_MARK,
-};
-static const unsigned int vin5_clk_pins[] = {
-       RCAR_GP_PIN(1, 21),
-};
-static const unsigned int vin5_clk_mux[] = {
-       /* CLK */
-       VI5_CLK_MARK,
-};
-
-static const struct sh_pfc_pin_group pinmux_groups[] = {
-       SH_PFC_PIN_GROUP(audio_clk_a_a),
-       SH_PFC_PIN_GROUP(audio_clk_a_b),
-       SH_PFC_PIN_GROUP(audio_clk_a_c),
-       SH_PFC_PIN_GROUP(audio_clk_b_a),
-       SH_PFC_PIN_GROUP(audio_clk_b_b),
-       SH_PFC_PIN_GROUP(audio_clk_c_a),
-       SH_PFC_PIN_GROUP(audio_clk_c_b),
-       SH_PFC_PIN_GROUP(audio_clkout_a),
-       SH_PFC_PIN_GROUP(audio_clkout_b),
-       SH_PFC_PIN_GROUP(audio_clkout_c),
-       SH_PFC_PIN_GROUP(audio_clkout_d),
-       SH_PFC_PIN_GROUP(audio_clkout1_a),
-       SH_PFC_PIN_GROUP(audio_clkout1_b),
-       SH_PFC_PIN_GROUP(audio_clkout2_a),
-       SH_PFC_PIN_GROUP(audio_clkout2_b),
-       SH_PFC_PIN_GROUP(audio_clkout3_a),
-       SH_PFC_PIN_GROUP(audio_clkout3_b),
-       SH_PFC_PIN_GROUP(avb_link),
-       SH_PFC_PIN_GROUP(avb_magic),
-       SH_PFC_PIN_GROUP(avb_phy_int),
-       SH_PFC_PIN_GROUP_ALIAS(avb_mdc, avb_mdio),      /* Deprecated */
-       SH_PFC_PIN_GROUP(avb_mdio),
-       SH_PFC_PIN_GROUP(avb_mii),
-       SH_PFC_PIN_GROUP(avb_avtp_pps),
-       SH_PFC_PIN_GROUP(avb_avtp_match_a),
-       SH_PFC_PIN_GROUP(avb_avtp_capture_a),
-       SH_PFC_PIN_GROUP(avb_avtp_match_b),
-       SH_PFC_PIN_GROUP(avb_avtp_capture_b),
-       SH_PFC_PIN_GROUP(can0_data_a),
-       SH_PFC_PIN_GROUP(can0_data_b),
-       SH_PFC_PIN_GROUP(can1_data),
-       SH_PFC_PIN_GROUP(can_clk),
-       SH_PFC_PIN_GROUP(canfd0_data_a),
-       SH_PFC_PIN_GROUP(canfd0_data_b),
-       SH_PFC_PIN_GROUP(canfd1_data),
-       SH_PFC_PIN_GROUP(drif0_ctrl_a),
-       SH_PFC_PIN_GROUP(drif0_data0_a),
-       SH_PFC_PIN_GROUP(drif0_data1_a),
-       SH_PFC_PIN_GROUP(drif0_ctrl_b),
-       SH_PFC_PIN_GROUP(drif0_data0_b),
-       SH_PFC_PIN_GROUP(drif0_data1_b),
-       SH_PFC_PIN_GROUP(drif0_ctrl_c),
-       SH_PFC_PIN_GROUP(drif0_data0_c),
-       SH_PFC_PIN_GROUP(drif0_data1_c),
-       SH_PFC_PIN_GROUP(drif1_ctrl_a),
-       SH_PFC_PIN_GROUP(drif1_data0_a),
-       SH_PFC_PIN_GROUP(drif1_data1_a),
-       SH_PFC_PIN_GROUP(drif1_ctrl_b),
-       SH_PFC_PIN_GROUP(drif1_data0_b),
-       SH_PFC_PIN_GROUP(drif1_data1_b),
-       SH_PFC_PIN_GROUP(drif1_ctrl_c),
-       SH_PFC_PIN_GROUP(drif1_data0_c),
-       SH_PFC_PIN_GROUP(drif1_data1_c),
-       SH_PFC_PIN_GROUP(drif2_ctrl_a),
-       SH_PFC_PIN_GROUP(drif2_data0_a),
-       SH_PFC_PIN_GROUP(drif2_data1_a),
-       SH_PFC_PIN_GROUP(drif2_ctrl_b),
-       SH_PFC_PIN_GROUP(drif2_data0_b),
-       SH_PFC_PIN_GROUP(drif2_data1_b),
-       SH_PFC_PIN_GROUP(drif3_ctrl_a),
-       SH_PFC_PIN_GROUP(drif3_data0_a),
-       SH_PFC_PIN_GROUP(drif3_data1_a),
-       SH_PFC_PIN_GROUP(drif3_ctrl_b),
-       SH_PFC_PIN_GROUP(drif3_data0_b),
-       SH_PFC_PIN_GROUP(drif3_data1_b),
-       SH_PFC_PIN_GROUP(du_rgb666),
-       SH_PFC_PIN_GROUP(du_rgb888),
-       SH_PFC_PIN_GROUP(du_clk_out_0),
-       SH_PFC_PIN_GROUP(du_clk_out_1),
-       SH_PFC_PIN_GROUP(du_sync),
-       SH_PFC_PIN_GROUP(du_oddf),
-       SH_PFC_PIN_GROUP(du_cde),
-       SH_PFC_PIN_GROUP(du_disp),
-       SH_PFC_PIN_GROUP(hscif0_data),
-       SH_PFC_PIN_GROUP(hscif0_clk),
-       SH_PFC_PIN_GROUP(hscif0_ctrl),
-       SH_PFC_PIN_GROUP(hscif1_data_a),
-       SH_PFC_PIN_GROUP(hscif1_clk_a),
-       SH_PFC_PIN_GROUP(hscif1_ctrl_a),
-       SH_PFC_PIN_GROUP(hscif1_data_b),
-       SH_PFC_PIN_GROUP(hscif1_clk_b),
-       SH_PFC_PIN_GROUP(hscif1_ctrl_b),
-       SH_PFC_PIN_GROUP(hscif2_data_a),
-       SH_PFC_PIN_GROUP(hscif2_clk_a),
-       SH_PFC_PIN_GROUP(hscif2_ctrl_a),
-       SH_PFC_PIN_GROUP(hscif2_data_b),
-       SH_PFC_PIN_GROUP(hscif2_clk_b),
-       SH_PFC_PIN_GROUP(hscif2_ctrl_b),
-       SH_PFC_PIN_GROUP(hscif3_data_a),
-       SH_PFC_PIN_GROUP(hscif3_clk),
-       SH_PFC_PIN_GROUP(hscif3_ctrl),
-       SH_PFC_PIN_GROUP(hscif3_data_b),
-       SH_PFC_PIN_GROUP(hscif3_data_c),
-       SH_PFC_PIN_GROUP(hscif3_data_d),
-       SH_PFC_PIN_GROUP(hscif4_data_a),
-       SH_PFC_PIN_GROUP(hscif4_clk),
-       SH_PFC_PIN_GROUP(hscif4_ctrl),
-       SH_PFC_PIN_GROUP(hscif4_data_b),
-       SH_PFC_PIN_GROUP(i2c0),
-       SH_PFC_PIN_GROUP(i2c1_a),
-       SH_PFC_PIN_GROUP(i2c1_b),
-       SH_PFC_PIN_GROUP(i2c2_a),
-       SH_PFC_PIN_GROUP(i2c2_b),
-       SH_PFC_PIN_GROUP(i2c3),
-       SH_PFC_PIN_GROUP(i2c5),
-       SH_PFC_PIN_GROUP(i2c6_a),
-       SH_PFC_PIN_GROUP(i2c6_b),
-       SH_PFC_PIN_GROUP(i2c6_c),
-       SH_PFC_PIN_GROUP(intc_ex_irq0),
-       SH_PFC_PIN_GROUP(intc_ex_irq1),
-       SH_PFC_PIN_GROUP(intc_ex_irq2),
-       SH_PFC_PIN_GROUP(intc_ex_irq3),
-       SH_PFC_PIN_GROUP(intc_ex_irq4),
-       SH_PFC_PIN_GROUP(intc_ex_irq5),
-       SH_PFC_PIN_GROUP(mlb_3pin),
-       SH_PFC_PIN_GROUP(msiof0_clk),
-       SH_PFC_PIN_GROUP(msiof0_sync),
-       SH_PFC_PIN_GROUP(msiof0_ss1),
-       SH_PFC_PIN_GROUP(msiof0_ss2),
-       SH_PFC_PIN_GROUP(msiof0_txd),
-       SH_PFC_PIN_GROUP(msiof0_rxd),
-       SH_PFC_PIN_GROUP(msiof1_clk_a),
-       SH_PFC_PIN_GROUP(msiof1_sync_a),
-       SH_PFC_PIN_GROUP(msiof1_ss1_a),
-       SH_PFC_PIN_GROUP(msiof1_ss2_a),
-       SH_PFC_PIN_GROUP(msiof1_txd_a),
-       SH_PFC_PIN_GROUP(msiof1_rxd_a),
-       SH_PFC_PIN_GROUP(msiof1_clk_b),
-       SH_PFC_PIN_GROUP(msiof1_sync_b),
-       SH_PFC_PIN_GROUP(msiof1_ss1_b),
-       SH_PFC_PIN_GROUP(msiof1_ss2_b),
-       SH_PFC_PIN_GROUP(msiof1_txd_b),
-       SH_PFC_PIN_GROUP(msiof1_rxd_b),
-       SH_PFC_PIN_GROUP(msiof1_clk_c),
-       SH_PFC_PIN_GROUP(msiof1_sync_c),
-       SH_PFC_PIN_GROUP(msiof1_ss1_c),
-       SH_PFC_PIN_GROUP(msiof1_ss2_c),
-       SH_PFC_PIN_GROUP(msiof1_txd_c),
-       SH_PFC_PIN_GROUP(msiof1_rxd_c),
-       SH_PFC_PIN_GROUP(msiof1_clk_d),
-       SH_PFC_PIN_GROUP(msiof1_sync_d),
-       SH_PFC_PIN_GROUP(msiof1_ss1_d),
-       SH_PFC_PIN_GROUP(msiof1_ss2_d),
-       SH_PFC_PIN_GROUP(msiof1_txd_d),
-       SH_PFC_PIN_GROUP(msiof1_rxd_d),
-       SH_PFC_PIN_GROUP(msiof1_clk_e),
-       SH_PFC_PIN_GROUP(msiof1_sync_e),
-       SH_PFC_PIN_GROUP(msiof1_ss1_e),
-       SH_PFC_PIN_GROUP(msiof1_ss2_e),
-       SH_PFC_PIN_GROUP(msiof1_txd_e),
-       SH_PFC_PIN_GROUP(msiof1_rxd_e),
-       SH_PFC_PIN_GROUP(msiof1_clk_f),
-       SH_PFC_PIN_GROUP(msiof1_sync_f),
-       SH_PFC_PIN_GROUP(msiof1_ss1_f),
-       SH_PFC_PIN_GROUP(msiof1_ss2_f),
-       SH_PFC_PIN_GROUP(msiof1_txd_f),
-       SH_PFC_PIN_GROUP(msiof1_rxd_f),
-       SH_PFC_PIN_GROUP(msiof1_clk_g),
-       SH_PFC_PIN_GROUP(msiof1_sync_g),
-       SH_PFC_PIN_GROUP(msiof1_ss1_g),
-       SH_PFC_PIN_GROUP(msiof1_ss2_g),
-       SH_PFC_PIN_GROUP(msiof1_txd_g),
-       SH_PFC_PIN_GROUP(msiof1_rxd_g),
-       SH_PFC_PIN_GROUP(msiof2_clk_a),
-       SH_PFC_PIN_GROUP(msiof2_sync_a),
-       SH_PFC_PIN_GROUP(msiof2_ss1_a),
-       SH_PFC_PIN_GROUP(msiof2_ss2_a),
-       SH_PFC_PIN_GROUP(msiof2_txd_a),
-       SH_PFC_PIN_GROUP(msiof2_rxd_a),
-       SH_PFC_PIN_GROUP(msiof2_clk_b),
-       SH_PFC_PIN_GROUP(msiof2_sync_b),
-       SH_PFC_PIN_GROUP(msiof2_ss1_b),
-       SH_PFC_PIN_GROUP(msiof2_ss2_b),
-       SH_PFC_PIN_GROUP(msiof2_txd_b),
-       SH_PFC_PIN_GROUP(msiof2_rxd_b),
-       SH_PFC_PIN_GROUP(msiof2_clk_c),
-       SH_PFC_PIN_GROUP(msiof2_sync_c),
-       SH_PFC_PIN_GROUP(msiof2_ss1_c),
-       SH_PFC_PIN_GROUP(msiof2_ss2_c),
-       SH_PFC_PIN_GROUP(msiof2_txd_c),
-       SH_PFC_PIN_GROUP(msiof2_rxd_c),
-       SH_PFC_PIN_GROUP(msiof2_clk_d),
-       SH_PFC_PIN_GROUP(msiof2_sync_d),
-       SH_PFC_PIN_GROUP(msiof2_ss1_d),
-       SH_PFC_PIN_GROUP(msiof2_ss2_d),
-       SH_PFC_PIN_GROUP(msiof2_txd_d),
-       SH_PFC_PIN_GROUP(msiof2_rxd_d),
-       SH_PFC_PIN_GROUP(msiof3_clk_a),
-       SH_PFC_PIN_GROUP(msiof3_sync_a),
-       SH_PFC_PIN_GROUP(msiof3_ss1_a),
-       SH_PFC_PIN_GROUP(msiof3_ss2_a),
-       SH_PFC_PIN_GROUP(msiof3_txd_a),
-       SH_PFC_PIN_GROUP(msiof3_rxd_a),
-       SH_PFC_PIN_GROUP(msiof3_clk_b),
-       SH_PFC_PIN_GROUP(msiof3_sync_b),
-       SH_PFC_PIN_GROUP(msiof3_ss1_b),
-       SH_PFC_PIN_GROUP(msiof3_ss2_b),
-       SH_PFC_PIN_GROUP(msiof3_txd_b),
-       SH_PFC_PIN_GROUP(msiof3_rxd_b),
-       SH_PFC_PIN_GROUP(msiof3_clk_c),
-       SH_PFC_PIN_GROUP(msiof3_sync_c),
-       SH_PFC_PIN_GROUP(msiof3_txd_c),
-       SH_PFC_PIN_GROUP(msiof3_rxd_c),
-       SH_PFC_PIN_GROUP(msiof3_clk_d),
-       SH_PFC_PIN_GROUP(msiof3_sync_d),
-       SH_PFC_PIN_GROUP(msiof3_ss1_d),
-       SH_PFC_PIN_GROUP(msiof3_txd_d),
-       SH_PFC_PIN_GROUP(msiof3_rxd_d),
-       SH_PFC_PIN_GROUP(pwm0),
-       SH_PFC_PIN_GROUP(pwm1_a),
-       SH_PFC_PIN_GROUP(pwm1_b),
-       SH_PFC_PIN_GROUP(pwm2_a),
-       SH_PFC_PIN_GROUP(pwm2_b),
-       SH_PFC_PIN_GROUP(pwm3_a),
-       SH_PFC_PIN_GROUP(pwm3_b),
-       SH_PFC_PIN_GROUP(pwm4_a),
-       SH_PFC_PIN_GROUP(pwm4_b),
-       SH_PFC_PIN_GROUP(pwm5_a),
-       SH_PFC_PIN_GROUP(pwm5_b),
-       SH_PFC_PIN_GROUP(pwm6_a),
-       SH_PFC_PIN_GROUP(pwm6_b),
-       SH_PFC_PIN_GROUP(qspi0_ctrl),
-       BUS_DATA_PIN_GROUP(qspi0_data, 2),
-       BUS_DATA_PIN_GROUP(qspi0_data, 4),
-       SH_PFC_PIN_GROUP(qspi1_ctrl),
-       BUS_DATA_PIN_GROUP(qspi1_data, 2),
-       BUS_DATA_PIN_GROUP(qspi1_data, 4),
-       SH_PFC_PIN_GROUP(sata0_devslp_a),
-       SH_PFC_PIN_GROUP(sata0_devslp_b),
-       SH_PFC_PIN_GROUP(scif0_data),
-       SH_PFC_PIN_GROUP(scif0_clk),
-       SH_PFC_PIN_GROUP(scif0_ctrl),
-       SH_PFC_PIN_GROUP(scif1_data_a),
-       SH_PFC_PIN_GROUP(scif1_clk),
-       SH_PFC_PIN_GROUP(scif1_ctrl),
-       SH_PFC_PIN_GROUP(scif1_data_b),
-       SH_PFC_PIN_GROUP(scif2_data_a),
-       SH_PFC_PIN_GROUP(scif2_clk),
-       SH_PFC_PIN_GROUP(scif2_data_b),
-       SH_PFC_PIN_GROUP(scif3_data_a),
-       SH_PFC_PIN_GROUP(scif3_clk),
-       SH_PFC_PIN_GROUP(scif3_ctrl),
-       SH_PFC_PIN_GROUP(scif3_data_b),
-       SH_PFC_PIN_GROUP(scif4_data_a),
-       SH_PFC_PIN_GROUP(scif4_clk_a),
-       SH_PFC_PIN_GROUP(scif4_ctrl_a),
-       SH_PFC_PIN_GROUP(scif4_data_b),
-       SH_PFC_PIN_GROUP(scif4_clk_b),
-       SH_PFC_PIN_GROUP(scif4_ctrl_b),
-       SH_PFC_PIN_GROUP(scif4_data_c),
-       SH_PFC_PIN_GROUP(scif4_clk_c),
-       SH_PFC_PIN_GROUP(scif4_ctrl_c),
-       SH_PFC_PIN_GROUP(scif5_data),
-       SH_PFC_PIN_GROUP(scif5_clk),
-       SH_PFC_PIN_GROUP(scif_clk_a),
-       SH_PFC_PIN_GROUP(scif_clk_b),
-       BUS_DATA_PIN_GROUP(sdhi0_data, 1),
-       BUS_DATA_PIN_GROUP(sdhi0_data, 4),
-       SH_PFC_PIN_GROUP(sdhi0_ctrl),
-       SH_PFC_PIN_GROUP(sdhi0_cd),
-       SH_PFC_PIN_GROUP(sdhi0_wp),
-       BUS_DATA_PIN_GROUP(sdhi1_data, 1),
-       BUS_DATA_PIN_GROUP(sdhi1_data, 4),
-       SH_PFC_PIN_GROUP(sdhi1_ctrl),
-       SH_PFC_PIN_GROUP(sdhi1_cd),
-       SH_PFC_PIN_GROUP(sdhi1_wp),
-       BUS_DATA_PIN_GROUP(sdhi2_data, 1),
-       BUS_DATA_PIN_GROUP(sdhi2_data, 4),
-       BUS_DATA_PIN_GROUP(sdhi2_data, 8),
-       SH_PFC_PIN_GROUP(sdhi2_ctrl),
-       SH_PFC_PIN_GROUP(sdhi2_cd_a),
-       SH_PFC_PIN_GROUP(sdhi2_wp_a),
-       SH_PFC_PIN_GROUP(sdhi2_cd_b),
-       SH_PFC_PIN_GROUP(sdhi2_wp_b),
-       SH_PFC_PIN_GROUP(sdhi2_ds),
-       BUS_DATA_PIN_GROUP(sdhi3_data, 1),
-       BUS_DATA_PIN_GROUP(sdhi3_data, 4),
-       BUS_DATA_PIN_GROUP(sdhi3_data, 8),
-       SH_PFC_PIN_GROUP(sdhi3_ctrl),
-       SH_PFC_PIN_GROUP(sdhi3_cd),
-       SH_PFC_PIN_GROUP(sdhi3_wp),
-       SH_PFC_PIN_GROUP(sdhi3_ds),
-       SH_PFC_PIN_GROUP(ssi0_data),
-       SH_PFC_PIN_GROUP(ssi01239_ctrl),
-       SH_PFC_PIN_GROUP(ssi1_data_a),
-       SH_PFC_PIN_GROUP(ssi1_data_b),
-       SH_PFC_PIN_GROUP(ssi1_ctrl_a),
-       SH_PFC_PIN_GROUP(ssi1_ctrl_b),
-       SH_PFC_PIN_GROUP(ssi2_data_a),
-       SH_PFC_PIN_GROUP(ssi2_data_b),
-       SH_PFC_PIN_GROUP(ssi2_ctrl_a),
-       SH_PFC_PIN_GROUP(ssi2_ctrl_b),
-       SH_PFC_PIN_GROUP(ssi3_data),
-       SH_PFC_PIN_GROUP(ssi349_ctrl),
-       SH_PFC_PIN_GROUP(ssi4_data),
-       SH_PFC_PIN_GROUP(ssi4_ctrl),
-       SH_PFC_PIN_GROUP(ssi5_data),
-       SH_PFC_PIN_GROUP(ssi5_ctrl),
-       SH_PFC_PIN_GROUP(ssi6_data),
-       SH_PFC_PIN_GROUP(ssi6_ctrl),
-       SH_PFC_PIN_GROUP(ssi7_data),
-       SH_PFC_PIN_GROUP(ssi78_ctrl),
-       SH_PFC_PIN_GROUP(ssi8_data),
-       SH_PFC_PIN_GROUP(ssi9_data_a),
-       SH_PFC_PIN_GROUP(ssi9_data_b),
-       SH_PFC_PIN_GROUP(ssi9_ctrl_a),
-       SH_PFC_PIN_GROUP(ssi9_ctrl_b),
-       SH_PFC_PIN_GROUP(tmu_tclk1_a),
-       SH_PFC_PIN_GROUP(tmu_tclk1_b),
-       SH_PFC_PIN_GROUP(tmu_tclk2_a),
-       SH_PFC_PIN_GROUP(tmu_tclk2_b),
-       SH_PFC_PIN_GROUP(tpu_to0),
-       SH_PFC_PIN_GROUP(tpu_to1),
-       SH_PFC_PIN_GROUP(tpu_to2),
-       SH_PFC_PIN_GROUP(tpu_to3),
-       SH_PFC_PIN_GROUP(usb0),
-       SH_PFC_PIN_GROUP(usb1),
-       SH_PFC_PIN_GROUP(usb2),
-       SH_PFC_PIN_GROUP(usb30),
-       SH_PFC_PIN_GROUP(usb31),
-       BUS_DATA_PIN_GROUP(vin4_data, 8, _a),
-       BUS_DATA_PIN_GROUP(vin4_data, 10, _a),
-       BUS_DATA_PIN_GROUP(vin4_data, 12, _a),
-       BUS_DATA_PIN_GROUP(vin4_data, 16, _a),
-       SH_PFC_PIN_GROUP(vin4_data18_a),
-       BUS_DATA_PIN_GROUP(vin4_data, 20, _a),
-       BUS_DATA_PIN_GROUP(vin4_data, 24, _a),
-       BUS_DATA_PIN_GROUP(vin4_data, 8, _b),
-       BUS_DATA_PIN_GROUP(vin4_data, 10, _b),
-       BUS_DATA_PIN_GROUP(vin4_data, 12, _b),
-       BUS_DATA_PIN_GROUP(vin4_data, 16, _b),
-       SH_PFC_PIN_GROUP(vin4_data18_b),
-       BUS_DATA_PIN_GROUP(vin4_data, 20, _b),
-       BUS_DATA_PIN_GROUP(vin4_data, 24, _b),
-       SH_PFC_PIN_GROUP_SUBSET(vin4_g8, vin4_data_a, 8, 8),
-       SH_PFC_PIN_GROUP(vin4_sync),
-       SH_PFC_PIN_GROUP(vin4_field),
-       SH_PFC_PIN_GROUP(vin4_clkenb),
-       SH_PFC_PIN_GROUP(vin4_clk),
-       BUS_DATA_PIN_GROUP(vin5_data, 8),
-       BUS_DATA_PIN_GROUP(vin5_data, 10),
-       BUS_DATA_PIN_GROUP(vin5_data, 12),
-       BUS_DATA_PIN_GROUP(vin5_data, 16),
-       SH_PFC_PIN_GROUP_SUBSET(vin5_high8, vin5_data, 8, 8),
-       SH_PFC_PIN_GROUP(vin5_sync),
-       SH_PFC_PIN_GROUP(vin5_field),
-       SH_PFC_PIN_GROUP(vin5_clkenb),
-       SH_PFC_PIN_GROUP(vin5_clk),
-};
-
-static const char * const audio_clk_groups[] = {
-       "audio_clk_a_a",
-       "audio_clk_a_b",
-       "audio_clk_a_c",
-       "audio_clk_b_a",
-       "audio_clk_b_b",
-       "audio_clk_c_a",
-       "audio_clk_c_b",
-       "audio_clkout_a",
-       "audio_clkout_b",
-       "audio_clkout_c",
-       "audio_clkout_d",
-       "audio_clkout1_a",
-       "audio_clkout1_b",
-       "audio_clkout2_a",
-       "audio_clkout2_b",
-       "audio_clkout3_a",
-       "audio_clkout3_b",
-};
-
-static const char * const avb_groups[] = {
-       "avb_link",
-       "avb_magic",
-       "avb_phy_int",
-       "avb_mdc",      /* Deprecated, please use "avb_mdio" instead */
-       "avb_mdio",
-       "avb_mii",
-       "avb_avtp_pps",
-       "avb_avtp_match_a",
-       "avb_avtp_capture_a",
-       "avb_avtp_match_b",
-       "avb_avtp_capture_b",
-};
-
-static const char * const can0_groups[] = {
-       "can0_data_a",
-       "can0_data_b",
-};
-
-static const char * const can1_groups[] = {
-       "can1_data",
-};
-
-static const char * const can_clk_groups[] = {
-       "can_clk",
-};
-
-static const char * const canfd0_groups[] = {
-       "canfd0_data_a",
-       "canfd0_data_b",
-};
-
-static const char * const canfd1_groups[] = {
-       "canfd1_data",
-};
-
-static const char * const drif0_groups[] = {
-       "drif0_ctrl_a",
-       "drif0_data0_a",
-       "drif0_data1_a",
-       "drif0_ctrl_b",
-       "drif0_data0_b",
-       "drif0_data1_b",
-       "drif0_ctrl_c",
-       "drif0_data0_c",
-       "drif0_data1_c",
-};
-
-static const char * const drif1_groups[] = {
-       "drif1_ctrl_a",
-       "drif1_data0_a",
-       "drif1_data1_a",
-       "drif1_ctrl_b",
-       "drif1_data0_b",
-       "drif1_data1_b",
-       "drif1_ctrl_c",
-       "drif1_data0_c",
-       "drif1_data1_c",
-};
-
-static const char * const drif2_groups[] = {
-       "drif2_ctrl_a",
-       "drif2_data0_a",
-       "drif2_data1_a",
-       "drif2_ctrl_b",
-       "drif2_data0_b",
-       "drif2_data1_b",
-};
-
-static const char * const drif3_groups[] = {
-       "drif3_ctrl_a",
-       "drif3_data0_a",
-       "drif3_data1_a",
-       "drif3_ctrl_b",
-       "drif3_data0_b",
-       "drif3_data1_b",
-};
-
-static const char * const du_groups[] = {
-       "du_rgb666",
-       "du_rgb888",
-       "du_clk_out_0",
-       "du_clk_out_1",
-       "du_sync",
-       "du_oddf",
-       "du_cde",
-       "du_disp",
-};
-
-static const char * const hscif0_groups[] = {
-       "hscif0_data",
-       "hscif0_clk",
-       "hscif0_ctrl",
-};
-
-static const char * const hscif1_groups[] = {
-       "hscif1_data_a",
-       "hscif1_clk_a",
-       "hscif1_ctrl_a",
-       "hscif1_data_b",
-       "hscif1_clk_b",
-       "hscif1_ctrl_b",
-};
-
-static const char * const hscif2_groups[] = {
-       "hscif2_data_a",
-       "hscif2_clk_a",
-       "hscif2_ctrl_a",
-       "hscif2_data_b",
-       "hscif2_clk_b",
-       "hscif2_ctrl_b",
-};
-
-static const char * const hscif3_groups[] = {
-       "hscif3_data_a",
-       "hscif3_clk",
-       "hscif3_ctrl",
-       "hscif3_data_b",
-       "hscif3_data_c",
-       "hscif3_data_d",
-};
-
-static const char * const hscif4_groups[] = {
-       "hscif4_data_a",
-       "hscif4_clk",
-       "hscif4_ctrl",
-       "hscif4_data_b",
-};
-
-static const char * const i2c0_groups[] = {
-       "i2c0",
-};
-
-static const char * const i2c1_groups[] = {
-       "i2c1_a",
-       "i2c1_b",
-};
-
-static const char * const i2c2_groups[] = {
-       "i2c2_a",
-       "i2c2_b",
-};
-
-static const char * const i2c3_groups[] = {
-       "i2c3",
-};
-
-static const char * const i2c5_groups[] = {
-       "i2c5",
-};
-
-static const char * const i2c6_groups[] = {
-       "i2c6_a",
-       "i2c6_b",
-       "i2c6_c",
-};
-
-static const char * const intc_ex_groups[] = {
-       "intc_ex_irq0",
-       "intc_ex_irq1",
-       "intc_ex_irq2",
-       "intc_ex_irq3",
-       "intc_ex_irq4",
-       "intc_ex_irq5",
-};
-
-static const char * const mlb_3pin_groups[] = {
-       "mlb_3pin",
-};
-
-static const char * const msiof0_groups[] = {
-       "msiof0_clk",
-       "msiof0_sync",
-       "msiof0_ss1",
-       "msiof0_ss2",
-       "msiof0_txd",
-       "msiof0_rxd",
-};
-
-static const char * const msiof1_groups[] = {
-       "msiof1_clk_a",
-       "msiof1_sync_a",
-       "msiof1_ss1_a",
-       "msiof1_ss2_a",
-       "msiof1_txd_a",
-       "msiof1_rxd_a",
-       "msiof1_clk_b",
-       "msiof1_sync_b",
-       "msiof1_ss1_b",
-       "msiof1_ss2_b",
-       "msiof1_txd_b",
-       "msiof1_rxd_b",
-       "msiof1_clk_c",
-       "msiof1_sync_c",
-       "msiof1_ss1_c",
-       "msiof1_ss2_c",
-       "msiof1_txd_c",
-       "msiof1_rxd_c",
-       "msiof1_clk_d",
-       "msiof1_sync_d",
-       "msiof1_ss1_d",
-       "msiof1_ss2_d",
-       "msiof1_txd_d",
-       "msiof1_rxd_d",
-       "msiof1_clk_e",
-       "msiof1_sync_e",
-       "msiof1_ss1_e",
-       "msiof1_ss2_e",
-       "msiof1_txd_e",
-       "msiof1_rxd_e",
-       "msiof1_clk_f",
-       "msiof1_sync_f",
-       "msiof1_ss1_f",
-       "msiof1_ss2_f",
-       "msiof1_txd_f",
-       "msiof1_rxd_f",
-       "msiof1_clk_g",
-       "msiof1_sync_g",
-       "msiof1_ss1_g",
-       "msiof1_ss2_g",
-       "msiof1_txd_g",
-       "msiof1_rxd_g",
-};
-
-static const char * const msiof2_groups[] = {
-       "msiof2_clk_a",
-       "msiof2_sync_a",
-       "msiof2_ss1_a",
-       "msiof2_ss2_a",
-       "msiof2_txd_a",
-       "msiof2_rxd_a",
-       "msiof2_clk_b",
-       "msiof2_sync_b",
-       "msiof2_ss1_b",
-       "msiof2_ss2_b",
-       "msiof2_txd_b",
-       "msiof2_rxd_b",
-       "msiof2_clk_c",
-       "msiof2_sync_c",
-       "msiof2_ss1_c",
-       "msiof2_ss2_c",
-       "msiof2_txd_c",
-       "msiof2_rxd_c",
-       "msiof2_clk_d",
-       "msiof2_sync_d",
-       "msiof2_ss1_d",
-       "msiof2_ss2_d",
-       "msiof2_txd_d",
-       "msiof2_rxd_d",
-};
-
-static const char * const msiof3_groups[] = {
-       "msiof3_clk_a",
-       "msiof3_sync_a",
-       "msiof3_ss1_a",
-       "msiof3_ss2_a",
-       "msiof3_txd_a",
-       "msiof3_rxd_a",
-       "msiof3_clk_b",
-       "msiof3_sync_b",
-       "msiof3_ss1_b",
-       "msiof3_ss2_b",
-       "msiof3_txd_b",
-       "msiof3_rxd_b",
-       "msiof3_clk_c",
-       "msiof3_sync_c",
-       "msiof3_txd_c",
-       "msiof3_rxd_c",
-       "msiof3_clk_d",
-       "msiof3_sync_d",
-       "msiof3_ss1_d",
-       "msiof3_txd_d",
-       "msiof3_rxd_d",
-};
-
-static const char * const pwm0_groups[] = {
-       "pwm0",
-};
-
-static const char * const pwm1_groups[] = {
-       "pwm1_a",
-       "pwm1_b",
-};
-
-static const char * const pwm2_groups[] = {
-       "pwm2_a",
-       "pwm2_b",
-};
-
-static const char * const pwm3_groups[] = {
-       "pwm3_a",
-       "pwm3_b",
-};
-
-static const char * const pwm4_groups[] = {
-       "pwm4_a",
-       "pwm4_b",
-};
-
-static const char * const pwm5_groups[] = {
-       "pwm5_a",
-       "pwm5_b",
-};
-
-static const char * const pwm6_groups[] = {
-       "pwm6_a",
-       "pwm6_b",
-};
-
-static const char * const qspi0_groups[] = {
-       "qspi0_ctrl",
-       "qspi0_data2",
-       "qspi0_data4",
-};
-
-static const char * const qspi1_groups[] = {
-       "qspi1_ctrl",
-       "qspi1_data2",
-       "qspi1_data4",
-};
-
-static const char * const sata0_groups[] = {
-       "sata0_devslp_a",
-       "sata0_devslp_b",
-};
-
-static const char * const scif0_groups[] = {
-       "scif0_data",
-       "scif0_clk",
-       "scif0_ctrl",
-};
-
-static const char * const scif1_groups[] = {
-       "scif1_data_a",
-       "scif1_clk",
-       "scif1_ctrl",
-       "scif1_data_b",
-};
-
-static const char * const scif2_groups[] = {
-       "scif2_data_a",
-       "scif2_clk",
-       "scif2_data_b",
-};
-
-static const char * const scif3_groups[] = {
-       "scif3_data_a",
-       "scif3_clk",
-       "scif3_ctrl",
-       "scif3_data_b",
-};
-
-static const char * const scif4_groups[] = {
-       "scif4_data_a",
-       "scif4_clk_a",
-       "scif4_ctrl_a",
-       "scif4_data_b",
-       "scif4_clk_b",
-       "scif4_ctrl_b",
-       "scif4_data_c",
-       "scif4_clk_c",
-       "scif4_ctrl_c",
-};
-
-static const char * const scif5_groups[] = {
-       "scif5_data",
-       "scif5_clk",
-};
-
-static const char * const scif_clk_groups[] = {
-       "scif_clk_a",
-       "scif_clk_b",
-};
-
-static const char * const sdhi0_groups[] = {
-       "sdhi0_data1",
-       "sdhi0_data4",
-       "sdhi0_ctrl",
-       "sdhi0_cd",
-       "sdhi0_wp",
-};
-
-static const char * const sdhi1_groups[] = {
-       "sdhi1_data1",
-       "sdhi1_data4",
-       "sdhi1_ctrl",
-       "sdhi1_cd",
-       "sdhi1_wp",
-};
-
-static const char * const sdhi2_groups[] = {
-       "sdhi2_data1",
-       "sdhi2_data4",
-       "sdhi2_data8",
-       "sdhi2_ctrl",
-       "sdhi2_cd_a",
-       "sdhi2_wp_a",
-       "sdhi2_cd_b",
-       "sdhi2_wp_b",
-       "sdhi2_ds",
-};
-
-static const char * const sdhi3_groups[] = {
-       "sdhi3_data1",
-       "sdhi3_data4",
-       "sdhi3_data8",
-       "sdhi3_ctrl",
-       "sdhi3_cd",
-       "sdhi3_wp",
-       "sdhi3_ds",
-};
-
-static const char * const ssi_groups[] = {
-       "ssi0_data",
-       "ssi01239_ctrl",
-       "ssi1_data_a",
-       "ssi1_data_b",
-       "ssi1_ctrl_a",
-       "ssi1_ctrl_b",
-       "ssi2_data_a",
-       "ssi2_data_b",
-       "ssi2_ctrl_a",
-       "ssi2_ctrl_b",
-       "ssi3_data",
-       "ssi349_ctrl",
-       "ssi4_data",
-       "ssi4_ctrl",
-       "ssi5_data",
-       "ssi5_ctrl",
-       "ssi6_data",
-       "ssi6_ctrl",
-       "ssi7_data",
-       "ssi78_ctrl",
-       "ssi8_data",
-       "ssi9_data_a",
-       "ssi9_data_b",
-       "ssi9_ctrl_a",
-       "ssi9_ctrl_b",
-};
-
-static const char * const tmu_groups[] = {
-       "tmu_tclk1_a",
-       "tmu_tclk1_b",
-       "tmu_tclk2_a",
-       "tmu_tclk2_b",
-};
-
-static const char * const tpu_groups[] = {
-       "tpu_to0",
-       "tpu_to1",
-       "tpu_to2",
-       "tpu_to3",
-};
-
-static const char * const usb0_groups[] = {
-       "usb0",
-};
-
-static const char * const usb1_groups[] = {
-       "usb1",
-};
-
-static const char * const usb2_groups[] = {
-       "usb2",
-};
-
-static const char * const usb30_groups[] = {
-       "usb30",
-};
-
-static const char * const usb31_groups[] = {
-       "usb31",
-};
-
-static const char * const vin4_groups[] = {
-       "vin4_data8_a",
-       "vin4_data10_a",
-       "vin4_data12_a",
-       "vin4_data16_a",
-       "vin4_data18_a",
-       "vin4_data20_a",
-       "vin4_data24_a",
-       "vin4_data8_b",
-       "vin4_data10_b",
-       "vin4_data12_b",
-       "vin4_data16_b",
-       "vin4_data18_b",
-       "vin4_data20_b",
-       "vin4_data24_b",
-       "vin4_g8",
-       "vin4_sync",
-       "vin4_field",
-       "vin4_clkenb",
-       "vin4_clk",
-};
-
-static const char * const vin5_groups[] = {
-       "vin5_data8",
-       "vin5_data10",
-       "vin5_data12",
-       "vin5_data16",
-       "vin5_high8",
-       "vin5_sync",
-       "vin5_field",
-       "vin5_clkenb",
-       "vin5_clk",
-};
-
-static const struct sh_pfc_function pinmux_functions[] = {
-       SH_PFC_FUNCTION(audio_clk),
-       SH_PFC_FUNCTION(avb),
-       SH_PFC_FUNCTION(can0),
-       SH_PFC_FUNCTION(can1),
-       SH_PFC_FUNCTION(can_clk),
-       SH_PFC_FUNCTION(canfd0),
-       SH_PFC_FUNCTION(canfd1),
-       SH_PFC_FUNCTION(drif0),
-       SH_PFC_FUNCTION(drif1),
-       SH_PFC_FUNCTION(drif2),
-       SH_PFC_FUNCTION(drif3),
-       SH_PFC_FUNCTION(du),
-       SH_PFC_FUNCTION(hscif0),
-       SH_PFC_FUNCTION(hscif1),
-       SH_PFC_FUNCTION(hscif2),
-       SH_PFC_FUNCTION(hscif3),
-       SH_PFC_FUNCTION(hscif4),
-       SH_PFC_FUNCTION(i2c0),
-       SH_PFC_FUNCTION(i2c1),
-       SH_PFC_FUNCTION(i2c2),
-       SH_PFC_FUNCTION(i2c3),
-       SH_PFC_FUNCTION(i2c5),
-       SH_PFC_FUNCTION(i2c6),
-       SH_PFC_FUNCTION(intc_ex),
-       SH_PFC_FUNCTION(mlb_3pin),
-       SH_PFC_FUNCTION(msiof0),
-       SH_PFC_FUNCTION(msiof1),
-       SH_PFC_FUNCTION(msiof2),
-       SH_PFC_FUNCTION(msiof3),
-       SH_PFC_FUNCTION(pwm0),
-       SH_PFC_FUNCTION(pwm1),
-       SH_PFC_FUNCTION(pwm2),
-       SH_PFC_FUNCTION(pwm3),
-       SH_PFC_FUNCTION(pwm4),
-       SH_PFC_FUNCTION(pwm5),
-       SH_PFC_FUNCTION(pwm6),
-       SH_PFC_FUNCTION(qspi0),
-       SH_PFC_FUNCTION(qspi1),
-       SH_PFC_FUNCTION(sata0),
-       SH_PFC_FUNCTION(scif0),
-       SH_PFC_FUNCTION(scif1),
-       SH_PFC_FUNCTION(scif2),
-       SH_PFC_FUNCTION(scif3),
-       SH_PFC_FUNCTION(scif4),
-       SH_PFC_FUNCTION(scif5),
-       SH_PFC_FUNCTION(scif_clk),
-       SH_PFC_FUNCTION(sdhi0),
-       SH_PFC_FUNCTION(sdhi1),
-       SH_PFC_FUNCTION(sdhi2),
-       SH_PFC_FUNCTION(sdhi3),
-       SH_PFC_FUNCTION(ssi),
-       SH_PFC_FUNCTION(tmu),
-       SH_PFC_FUNCTION(tpu),
-       SH_PFC_FUNCTION(usb0),
-       SH_PFC_FUNCTION(usb1),
-       SH_PFC_FUNCTION(usb2),
-       SH_PFC_FUNCTION(usb30),
-       SH_PFC_FUNCTION(usb31),
-       SH_PFC_FUNCTION(vin4),
-       SH_PFC_FUNCTION(vin5),
-};
-
-static const struct pinmux_cfg_reg pinmux_config_regs[] = {
-#define F_(x, y)       FN_##y
-#define FM(x)          FN_##x
-       { PINMUX_CFG_REG_VAR("GPSR0", 0xe6060100, 32,
-                            GROUP(-16, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1,
-                                  1, 1, 1, 1, 1),
-                            GROUP(
-               /* GP0_31_16 RESERVED */
-               GP_0_15_FN,     GPSR0_15,
-               GP_0_14_FN,     GPSR0_14,
-               GP_0_13_FN,     GPSR0_13,
-               GP_0_12_FN,     GPSR0_12,
-               GP_0_11_FN,     GPSR0_11,
-               GP_0_10_FN,     GPSR0_10,
-               GP_0_9_FN,      GPSR0_9,
-               GP_0_8_FN,      GPSR0_8,
-               GP_0_7_FN,      GPSR0_7,
-               GP_0_6_FN,      GPSR0_6,
-               GP_0_5_FN,      GPSR0_5,
-               GP_0_4_FN,      GPSR0_4,
-               GP_0_3_FN,      GPSR0_3,
-               GP_0_2_FN,      GPSR0_2,
-               GP_0_1_FN,      GPSR0_1,
-               GP_0_0_FN,      GPSR0_0, ))
-       },
-       { PINMUX_CFG_REG("GPSR1", 0xe6060104, 32, 1, GROUP(
-               0, 0,
-               0, 0,
-               0, 0,
-               0, 0,
-               GP_1_27_FN,     GPSR1_27,
-               GP_1_26_FN,     GPSR1_26,
-               GP_1_25_FN,     GPSR1_25,
-               GP_1_24_FN,     GPSR1_24,
-               GP_1_23_FN,     GPSR1_23,
-               GP_1_22_FN,     GPSR1_22,
-               GP_1_21_FN,     GPSR1_21,
-               GP_1_20_FN,     GPSR1_20,
-               GP_1_19_FN,     GPSR1_19,
-               GP_1_18_FN,     GPSR1_18,
-               GP_1_17_FN,     GPSR1_17,
-               GP_1_16_FN,     GPSR1_16,
-               GP_1_15_FN,     GPSR1_15,
-               GP_1_14_FN,     GPSR1_14,
-               GP_1_13_FN,     GPSR1_13,
-               GP_1_12_FN,     GPSR1_12,
-               GP_1_11_FN,     GPSR1_11,
-               GP_1_10_FN,     GPSR1_10,
-               GP_1_9_FN,      GPSR1_9,
-               GP_1_8_FN,      GPSR1_8,
-               GP_1_7_FN,      GPSR1_7,
-               GP_1_6_FN,      GPSR1_6,
-               GP_1_5_FN,      GPSR1_5,
-               GP_1_4_FN,      GPSR1_4,
-               GP_1_3_FN,      GPSR1_3,
-               GP_1_2_FN,      GPSR1_2,
-               GP_1_1_FN,      GPSR1_1,
-               GP_1_0_FN,      GPSR1_0, ))
-       },
-       { PINMUX_CFG_REG_VAR("GPSR2", 0xe6060108, 32,
-                            GROUP(-17, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1,
-                                  1, 1, 1, 1),
-                            GROUP(
-               /* GP2_31_15 RESERVED */
-               GP_2_14_FN,     GPSR2_14,
-               GP_2_13_FN,     GPSR2_13,
-               GP_2_12_FN,     GPSR2_12,
-               GP_2_11_FN,     GPSR2_11,
-               GP_2_10_FN,     GPSR2_10,
-               GP_2_9_FN,      GPSR2_9,
-               GP_2_8_FN,      GPSR2_8,
-               GP_2_7_FN,      GPSR2_7,
-               GP_2_6_FN,      GPSR2_6,
-               GP_2_5_FN,      GPSR2_5,
-               GP_2_4_FN,      GPSR2_4,
-               GP_2_3_FN,      GPSR2_3,
-               GP_2_2_FN,      GPSR2_2,
-               GP_2_1_FN,      GPSR2_1,
-               GP_2_0_FN,      GPSR2_0, ))
-       },
-       { PINMUX_CFG_REG_VAR("GPSR3", 0xe606010c, 32,
-                            GROUP(-16, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1,
-                                  1, 1, 1, 1, 1),
-                            GROUP(
-               /* GP3_31_16 RESERVED */
-               GP_3_15_FN,     GPSR3_15,
-               GP_3_14_FN,     GPSR3_14,
-               GP_3_13_FN,     GPSR3_13,
-               GP_3_12_FN,     GPSR3_12,
-               GP_3_11_FN,     GPSR3_11,
-               GP_3_10_FN,     GPSR3_10,
-               GP_3_9_FN,      GPSR3_9,
-               GP_3_8_FN,      GPSR3_8,
-               GP_3_7_FN,      GPSR3_7,
-               GP_3_6_FN,      GPSR3_6,
-               GP_3_5_FN,      GPSR3_5,
-               GP_3_4_FN,      GPSR3_4,
-               GP_3_3_FN,      GPSR3_3,
-               GP_3_2_FN,      GPSR3_2,
-               GP_3_1_FN,      GPSR3_1,
-               GP_3_0_FN,      GPSR3_0, ))
-       },
-       { PINMUX_CFG_REG_VAR("GPSR4", 0xe6060110, 32,
-                            GROUP(-14, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1,
-                                  1, 1, 1, 1, 1, 1, 1),
-                            GROUP(
-               /* GP4_31_18 RESERVED */
-               GP_4_17_FN,     GPSR4_17,
-               GP_4_16_FN,     GPSR4_16,
-               GP_4_15_FN,     GPSR4_15,
-               GP_4_14_FN,     GPSR4_14,
-               GP_4_13_FN,     GPSR4_13,
-               GP_4_12_FN,     GPSR4_12,
-               GP_4_11_FN,     GPSR4_11,
-               GP_4_10_FN,     GPSR4_10,
-               GP_4_9_FN,      GPSR4_9,
-               GP_4_8_FN,      GPSR4_8,
-               GP_4_7_FN,      GPSR4_7,
-               GP_4_6_FN,      GPSR4_6,
-               GP_4_5_FN,      GPSR4_5,
-               GP_4_4_FN,      GPSR4_4,
-               GP_4_3_FN,      GPSR4_3,
-               GP_4_2_FN,      GPSR4_2,
-               GP_4_1_FN,      GPSR4_1,
-               GP_4_0_FN,      GPSR4_0, ))
-       },
-       { PINMUX_CFG_REG("GPSR5", 0xe6060114, 32, 1, GROUP(
-               0, 0,
-               0, 0,
-               0, 0,
-               0, 0,
-               0, 0,
-               0, 0,
-               GP_5_25_FN,     GPSR5_25,
-               GP_5_24_FN,     GPSR5_24,
-               GP_5_23_FN,     GPSR5_23,
-               GP_5_22_FN,     GPSR5_22,
-               GP_5_21_FN,     GPSR5_21,
-               GP_5_20_FN,     GPSR5_20,
-               GP_5_19_FN,     GPSR5_19,
-               GP_5_18_FN,     GPSR5_18,
-               GP_5_17_FN,     GPSR5_17,
-               GP_5_16_FN,     GPSR5_16,
-               GP_5_15_FN,     GPSR5_15,
-               GP_5_14_FN,     GPSR5_14,
-               GP_5_13_FN,     GPSR5_13,
-               GP_5_12_FN,     GPSR5_12,
-               GP_5_11_FN,     GPSR5_11,
-               GP_5_10_FN,     GPSR5_10,
-               GP_5_9_FN,      GPSR5_9,
-               GP_5_8_FN,      GPSR5_8,
-               GP_5_7_FN,      GPSR5_7,
-               GP_5_6_FN,      GPSR5_6,
-               GP_5_5_FN,      GPSR5_5,
-               GP_5_4_FN,      GPSR5_4,
-               GP_5_3_FN,      GPSR5_3,
-               GP_5_2_FN,      GPSR5_2,
-               GP_5_1_FN,      GPSR5_1,
-               GP_5_0_FN,      GPSR5_0, ))
-       },
-       { PINMUX_CFG_REG("GPSR6", 0xe6060118, 32, 1, GROUP(
-               GP_6_31_FN,     GPSR6_31,
-               GP_6_30_FN,     GPSR6_30,
-               GP_6_29_FN,     GPSR6_29,
-               GP_6_28_FN,     GPSR6_28,
-               GP_6_27_FN,     GPSR6_27,
-               GP_6_26_FN,     GPSR6_26,
-               GP_6_25_FN,     GPSR6_25,
-               GP_6_24_FN,     GPSR6_24,
-               GP_6_23_FN,     GPSR6_23,
-               GP_6_22_FN,     GPSR6_22,
-               GP_6_21_FN,     GPSR6_21,
-               GP_6_20_FN,     GPSR6_20,
-               GP_6_19_FN,     GPSR6_19,
-               GP_6_18_FN,     GPSR6_18,
-               GP_6_17_FN,     GPSR6_17,
-               GP_6_16_FN,     GPSR6_16,
-               GP_6_15_FN,     GPSR6_15,
-               GP_6_14_FN,     GPSR6_14,
-               GP_6_13_FN,     GPSR6_13,
-               GP_6_12_FN,     GPSR6_12,
-               GP_6_11_FN,     GPSR6_11,
-               GP_6_10_FN,     GPSR6_10,
-               GP_6_9_FN,      GPSR6_9,
-               GP_6_8_FN,      GPSR6_8,
-               GP_6_7_FN,      GPSR6_7,
-               GP_6_6_FN,      GPSR6_6,
-               GP_6_5_FN,      GPSR6_5,
-               GP_6_4_FN,      GPSR6_4,
-               GP_6_3_FN,      GPSR6_3,
-               GP_6_2_FN,      GPSR6_2,
-               GP_6_1_FN,      GPSR6_1,
-               GP_6_0_FN,      GPSR6_0, ))
-       },
-       { PINMUX_CFG_REG_VAR("GPSR7", 0xe606011c, 32,
-                            GROUP(-28, 1, 1, 1, 1),
-                            GROUP(
-               /* GP7_31_4 RESERVED */
-               GP_7_3_FN, GPSR7_3,
-               GP_7_2_FN, GPSR7_2,
-               GP_7_1_FN, GPSR7_1,
-               GP_7_0_FN, GPSR7_0, ))
-       },
-#undef F_
-#undef FM
-
-#define F_(x, y)       x,
-#define FM(x)          FN_##x,
-       { PINMUX_CFG_REG("IPSR0", 0xe6060200, 32, 4, GROUP(
-               IP0_31_28
-               IP0_27_24
-               IP0_23_20
-               IP0_19_16
-               IP0_15_12
-               IP0_11_8
-               IP0_7_4
-               IP0_3_0 ))
-       },
-       { PINMUX_CFG_REG("IPSR1", 0xe6060204, 32, 4, GROUP(
-               IP1_31_28
-               IP1_27_24
-               IP1_23_20
-               IP1_19_16
-               IP1_15_12
-               IP1_11_8
-               IP1_7_4
-               IP1_3_0 ))
-       },
-       { PINMUX_CFG_REG("IPSR2", 0xe6060208, 32, 4, GROUP(
-               IP2_31_28
-               IP2_27_24
-               IP2_23_20
-               IP2_19_16
-               IP2_15_12
-               IP2_11_8
-               IP2_7_4
-               IP2_3_0 ))
-       },
-       { PINMUX_CFG_REG("IPSR3", 0xe606020c, 32, 4, GROUP(
-               IP3_31_28
-               IP3_27_24
-               IP3_23_20
-               IP3_19_16
-               IP3_15_12
-               IP3_11_8
-               IP3_7_4
-               IP3_3_0 ))
-       },
-       { PINMUX_CFG_REG("IPSR4", 0xe6060210, 32, 4, GROUP(
-               IP4_31_28
-               IP4_27_24
-               IP4_23_20
-               IP4_19_16
-               IP4_15_12
-               IP4_11_8
-               IP4_7_4
-               IP4_3_0 ))
-       },
-       { PINMUX_CFG_REG("IPSR5", 0xe6060214, 32, 4, GROUP(
-               IP5_31_28
-               IP5_27_24
-               IP5_23_20
-               IP5_19_16
-               IP5_15_12
-               IP5_11_8
-               IP5_7_4
-               IP5_3_0 ))
-       },
-       { PINMUX_CFG_REG("IPSR6", 0xe6060218, 32, 4, GROUP(
-               IP6_31_28
-               IP6_27_24
-               IP6_23_20
-               IP6_19_16
-               IP6_15_12
-               IP6_11_8
-               IP6_7_4
-               IP6_3_0 ))
-       },
-       { PINMUX_CFG_REG("IPSR7", 0xe606021c, 32, 4, GROUP(
-               IP7_31_28
-               IP7_27_24
-               IP7_23_20
-               IP7_19_16
-               IP7_15_12
-               IP7_11_8
-               IP7_7_4
-               IP7_3_0 ))
-       },
-       { PINMUX_CFG_REG("IPSR8", 0xe6060220, 32, 4, GROUP(
-               IP8_31_28
-               IP8_27_24
-               IP8_23_20
-               IP8_19_16
-               IP8_15_12
-               IP8_11_8
-               IP8_7_4
-               IP8_3_0 ))
-       },
-       { PINMUX_CFG_REG("IPSR9", 0xe6060224, 32, 4, GROUP(
-               IP9_31_28
-               IP9_27_24
-               IP9_23_20
-               IP9_19_16
-               IP9_15_12
-               IP9_11_8
-               IP9_7_4
-               IP9_3_0 ))
-       },
-       { PINMUX_CFG_REG("IPSR10", 0xe6060228, 32, 4, GROUP(
-               IP10_31_28
-               IP10_27_24
-               IP10_23_20
-               IP10_19_16
-               IP10_15_12
-               IP10_11_8
-               IP10_7_4
-               IP10_3_0 ))
-       },
-       { PINMUX_CFG_REG("IPSR11", 0xe606022c, 32, 4, GROUP(
-               IP11_31_28
-               IP11_27_24
-               IP11_23_20
-               IP11_19_16
-               IP11_15_12
-               IP11_11_8
-               IP11_7_4
-               IP11_3_0 ))
-       },
-       { PINMUX_CFG_REG("IPSR12", 0xe6060230, 32, 4, GROUP(
-               IP12_31_28
-               IP12_27_24
-               IP12_23_20
-               IP12_19_16
-               IP12_15_12
-               IP12_11_8
-               IP12_7_4
-               IP12_3_0 ))
-       },
-       { PINMUX_CFG_REG("IPSR13", 0xe6060234, 32, 4, GROUP(
-               IP13_31_28
-               IP13_27_24
-               IP13_23_20
-               IP13_19_16
-               IP13_15_12
-               IP13_11_8
-               IP13_7_4
-               IP13_3_0 ))
-       },
-       { PINMUX_CFG_REG("IPSR14", 0xe6060238, 32, 4, GROUP(
-               IP14_31_28
-               IP14_27_24
-               IP14_23_20
-               IP14_19_16
-               IP14_15_12
-               IP14_11_8
-               IP14_7_4
-               IP14_3_0 ))
-       },
-       { PINMUX_CFG_REG("IPSR15", 0xe606023c, 32, 4, GROUP(
-               IP15_31_28
-               IP15_27_24
-               IP15_23_20
-               IP15_19_16
-               IP15_15_12
-               IP15_11_8
-               IP15_7_4
-               IP15_3_0 ))
-       },
-       { PINMUX_CFG_REG("IPSR16", 0xe6060240, 32, 4, GROUP(
-               IP16_31_28
-               IP16_27_24
-               IP16_23_20
-               IP16_19_16
-               IP16_15_12
-               IP16_11_8
-               IP16_7_4
-               IP16_3_0 ))
-       },
-       { PINMUX_CFG_REG_VAR("IPSR17", 0xe6060244, 32,
-                            GROUP(-24, 4, 4),
-                            GROUP(
-               /* IP17_31_8 RESERVED */
-               IP17_7_4
-               IP17_3_0 ))
-       },
-#undef F_
-#undef FM
-
-#define F_(x, y)       x,
-#define FM(x)          FN_##x,
-       { PINMUX_CFG_REG_VAR("MOD_SEL0", 0xe6060500, 32,
-                            GROUP(-1, 2, 2, 3, 1, 1, 2, 1, 1, 1, 2, 1,
-                                  1, 1, 1, 1, 1, 1, 2, 2, 1, 2, -1),
-                            GROUP(
-               /* RESERVED 31 */
-               MOD_SEL0_30_29
-               MOD_SEL0_28_27
-               MOD_SEL0_26_25_24
-               MOD_SEL0_23
-               MOD_SEL0_22
-               MOD_SEL0_21_20
-               MOD_SEL0_19
-               MOD_SEL0_18
-               MOD_SEL0_17
-               MOD_SEL0_16_15
-               MOD_SEL0_14
-               MOD_SEL0_13
-               MOD_SEL0_12
-               MOD_SEL0_11
-               MOD_SEL0_10
-               MOD_SEL0_9
-               MOD_SEL0_8
-               MOD_SEL0_7_6
-               MOD_SEL0_5_4
-               MOD_SEL0_3
-               MOD_SEL0_2_1
-               /* RESERVED 0 */ ))
-       },
-       { PINMUX_CFG_REG_VAR("MOD_SEL1", 0xe6060504, 32,
-                            GROUP(2, 3, 1, 2, 3, 1, 1, 2, 1, 2, 1, 1,
-                                  1, 1, 1, -2, 1, 1, 1, 1, 1, 1, 1),
-                            GROUP(
-               MOD_SEL1_31_30
-               MOD_SEL1_29_28_27
-               MOD_SEL1_26
-               MOD_SEL1_25_24
-               MOD_SEL1_23_22_21
-               MOD_SEL1_20
-               MOD_SEL1_19
-               MOD_SEL1_18_17
-               MOD_SEL1_16
-               MOD_SEL1_15_14
-               MOD_SEL1_13
-               MOD_SEL1_12
-               MOD_SEL1_11
-               MOD_SEL1_10
-               MOD_SEL1_9
-               /* RESERVED 8, 7 */
-               MOD_SEL1_6
-               MOD_SEL1_5
-               MOD_SEL1_4
-               MOD_SEL1_3
-               MOD_SEL1_2
-               MOD_SEL1_1
-               MOD_SEL1_0 ))
-       },
-       { PINMUX_CFG_REG_VAR("MOD_SEL2", 0xe6060508, 32,
-                            GROUP(1, 1, 1, -28, 1),
-                            GROUP(
-               MOD_SEL2_31
-               MOD_SEL2_30
-               MOD_SEL2_29
-               /* RESERVED 28-1 */
-               MOD_SEL2_0 ))
-       },
-       { },
-};
-
-static const struct pinmux_drive_reg pinmux_drive_regs[] = {
-       { PINMUX_DRIVE_REG("DRVCTRL0", 0xe6060300) {
-               { PIN_QSPI0_SPCLK,    28, 2 },  /* QSPI0_SPCLK */
-               { PIN_QSPI0_MOSI_IO0, 24, 2 },  /* QSPI0_MOSI_IO0 */
-               { PIN_QSPI0_MISO_IO1, 20, 2 },  /* QSPI0_MISO_IO1 */
-               { PIN_QSPI0_IO2,      16, 2 },  /* QSPI0_IO2 */
-               { PIN_QSPI0_IO3,      12, 2 },  /* QSPI0_IO3 */
-               { PIN_QSPI0_SSL,       8, 2 },  /* QSPI0_SSL */
-               { PIN_QSPI1_SPCLK,     4, 2 },  /* QSPI1_SPCLK */
-               { PIN_QSPI1_MOSI_IO0,  0, 2 },  /* QSPI1_MOSI_IO0 */
-       } },
-       { PINMUX_DRIVE_REG("DRVCTRL1", 0xe6060304) {
-               { PIN_QSPI1_MISO_IO1, 28, 2 },  /* QSPI1_MISO_IO1 */
-               { PIN_QSPI1_IO2,      24, 2 },  /* QSPI1_IO2 */
-               { PIN_QSPI1_IO3,      20, 2 },  /* QSPI1_IO3 */
-               { PIN_QSPI1_SSL,      16, 2 },  /* QSPI1_SSL */
-               { PIN_RPC_INT_N,      12, 2 },  /* RPC_INT# */
-               { PIN_RPC_WP_N,        8, 2 },  /* RPC_WP# */
-               { PIN_RPC_RESET_N,     4, 2 },  /* RPC_RESET# */
-               { PIN_AVB_RX_CTL,      0, 3 },  /* AVB_RX_CTL */
-       } },
-       { PINMUX_DRIVE_REG("DRVCTRL2", 0xe6060308) {
-               { PIN_AVB_RXC,        28, 3 },  /* AVB_RXC */
-               { PIN_AVB_RD0,        24, 3 },  /* AVB_RD0 */
-               { PIN_AVB_RD1,        20, 3 },  /* AVB_RD1 */
-               { PIN_AVB_RD2,        16, 3 },  /* AVB_RD2 */
-               { PIN_AVB_RD3,        12, 3 },  /* AVB_RD3 */
-               { PIN_AVB_TX_CTL,      8, 3 },  /* AVB_TX_CTL */
-               { PIN_AVB_TXC,         4, 3 },  /* AVB_TXC */
-               { PIN_AVB_TD0,         0, 3 },  /* AVB_TD0 */
-       } },
-       { PINMUX_DRIVE_REG("DRVCTRL3", 0xe606030c) {
-               { PIN_AVB_TD1,        28, 3 },  /* AVB_TD1 */
-               { PIN_AVB_TD2,        24, 3 },  /* AVB_TD2 */
-               { PIN_AVB_TD3,        20, 3 },  /* AVB_TD3 */
-               { PIN_AVB_TXCREFCLK,  16, 3 },  /* AVB_TXCREFCLK */
-               { PIN_AVB_MDIO,       12, 3 },  /* AVB_MDIO */
-               { RCAR_GP_PIN(2,  9),  8, 3 },  /* AVB_MDC */
-               { RCAR_GP_PIN(2, 10),  4, 3 },  /* AVB_MAGIC */
-               { RCAR_GP_PIN(2, 11),  0, 3 },  /* AVB_PHY_INT */
-       } },
-       { PINMUX_DRIVE_REG("DRVCTRL4", 0xe6060310) {
-               { RCAR_GP_PIN(2, 12), 28, 3 },  /* AVB_LINK */
-               { RCAR_GP_PIN(2, 13), 24, 3 },  /* AVB_AVTP_MATCH */
-               { RCAR_GP_PIN(2, 14), 20, 3 },  /* AVB_AVTP_CAPTURE */
-               { RCAR_GP_PIN(2,  0), 16, 3 },  /* IRQ0 */
-               { RCAR_GP_PIN(2,  1), 12, 3 },  /* IRQ1 */
-               { RCAR_GP_PIN(2,  2),  8, 3 },  /* IRQ2 */
-               { RCAR_GP_PIN(2,  3),  4, 3 },  /* IRQ3 */
-               { RCAR_GP_PIN(2,  4),  0, 3 },  /* IRQ4 */
-       } },
-       { PINMUX_DRIVE_REG("DRVCTRL5", 0xe6060314) {
-               { RCAR_GP_PIN(2,  5), 28, 3 },  /* IRQ5 */
-               { RCAR_GP_PIN(2,  6), 24, 3 },  /* PWM0 */
-               { RCAR_GP_PIN(2,  7), 20, 3 },  /* PWM1 */
-               { RCAR_GP_PIN(2,  8), 16, 3 },  /* PWM2 */
-               { RCAR_GP_PIN(1,  0), 12, 3 },  /* A0 */
-               { RCAR_GP_PIN(1,  1),  8, 3 },  /* A1 */
-               { RCAR_GP_PIN(1,  2),  4, 3 },  /* A2 */
-               { RCAR_GP_PIN(1,  3),  0, 3 },  /* A3 */
-       } },
-       { PINMUX_DRIVE_REG("DRVCTRL6", 0xe6060318) {
-               { RCAR_GP_PIN(1,  4), 28, 3 },  /* A4 */
-               { RCAR_GP_PIN(1,  5), 24, 3 },  /* A5 */
-               { RCAR_GP_PIN(1,  6), 20, 3 },  /* A6 */
-               { RCAR_GP_PIN(1,  7), 16, 3 },  /* A7 */
-               { RCAR_GP_PIN(1,  8), 12, 3 },  /* A8 */
-               { RCAR_GP_PIN(1,  9),  8, 3 },  /* A9 */
-               { RCAR_GP_PIN(1, 10),  4, 3 },  /* A10 */
-               { RCAR_GP_PIN(1, 11),  0, 3 },  /* A11 */
-       } },
-       { PINMUX_DRIVE_REG("DRVCTRL7", 0xe606031c) {
-               { RCAR_GP_PIN(1, 12), 28, 3 },  /* A12 */
-               { RCAR_GP_PIN(1, 13), 24, 3 },  /* A13 */
-               { RCAR_GP_PIN(1, 14), 20, 3 },  /* A14 */
-               { RCAR_GP_PIN(1, 15), 16, 3 },  /* A15 */
-               { RCAR_GP_PIN(1, 16), 12, 3 },  /* A16 */
-               { RCAR_GP_PIN(1, 17),  8, 3 },  /* A17 */
-               { RCAR_GP_PIN(1, 18),  4, 3 },  /* A18 */
-               { RCAR_GP_PIN(1, 19),  0, 3 },  /* A19 */
-       } },
-       { PINMUX_DRIVE_REG("DRVCTRL8", 0xe6060320) {
-               { PIN_CLKOUT,         28, 3 },  /* CLKOUT */
-               { RCAR_GP_PIN(1, 20), 24, 3 },  /* CS0 */
-               { RCAR_GP_PIN(1, 21), 20, 3 },  /* CS1_A26 */
-               { RCAR_GP_PIN(1, 22), 16, 3 },  /* BS */
-               { RCAR_GP_PIN(1, 23), 12, 3 },  /* RD */
-               { RCAR_GP_PIN(1, 24),  8, 3 },  /* RD_WR */
-               { RCAR_GP_PIN(1, 25),  4, 3 },  /* WE0 */
-               { RCAR_GP_PIN(1, 26),  0, 3 },  /* WE1 */
-       } },
-       { PINMUX_DRIVE_REG("DRVCTRL9", 0xe6060324) {
-               { RCAR_GP_PIN(1, 27), 28, 3 },  /* EX_WAIT0 */
-               { PIN_PRESETOUT_N,    24, 3 },  /* PRESETOUT# */
-               { RCAR_GP_PIN(0,  0), 20, 3 },  /* D0 */
-               { RCAR_GP_PIN(0,  1), 16, 3 },  /* D1 */
-               { RCAR_GP_PIN(0,  2), 12, 3 },  /* D2 */
-               { RCAR_GP_PIN(0,  3),  8, 3 },  /* D3 */
-               { RCAR_GP_PIN(0,  4),  4, 3 },  /* D4 */
-               { RCAR_GP_PIN(0,  5),  0, 3 },  /* D5 */
-       } },
-       { PINMUX_DRIVE_REG("DRVCTRL10", 0xe6060328) {
-               { RCAR_GP_PIN(0,  6), 28, 3 },  /* D6 */
-               { RCAR_GP_PIN(0,  7), 24, 3 },  /* D7 */
-               { RCAR_GP_PIN(0,  8), 20, 3 },  /* D8 */
-               { RCAR_GP_PIN(0,  9), 16, 3 },  /* D9 */
-               { RCAR_GP_PIN(0, 10), 12, 3 },  /* D10 */
-               { RCAR_GP_PIN(0, 11),  8, 3 },  /* D11 */
-               { RCAR_GP_PIN(0, 12),  4, 3 },  /* D12 */
-               { RCAR_GP_PIN(0, 13),  0, 3 },  /* D13 */
-       } },
-       { PINMUX_DRIVE_REG("DRVCTRL11", 0xe606032c) {
-               { RCAR_GP_PIN(0, 14), 28, 3 },  /* D14 */
-               { RCAR_GP_PIN(0, 15), 24, 3 },  /* D15 */
-               { RCAR_GP_PIN(7,  0), 20, 3 },  /* AVS1 */
-               { RCAR_GP_PIN(7,  1), 16, 3 },  /* AVS2 */
-               { RCAR_GP_PIN(7,  2), 12, 3 },  /* GP7_02 */
-               { RCAR_GP_PIN(7,  3),  8, 3 },  /* GP7_03 */
-               { PIN_DU_DOTCLKIN0,    4, 2 },  /* DU_DOTCLKIN0 */
-               { PIN_DU_DOTCLKIN1,    0, 2 },  /* DU_DOTCLKIN1 */
-       } },
-       { PINMUX_DRIVE_REG("DRVCTRL12", 0xe6060330) {
-               { PIN_DU_DOTCLKIN2,   28, 2 },  /* DU_DOTCLKIN2 */
-               { PIN_DU_DOTCLKIN3,   24, 2 },  /* DU_DOTCLKIN3 */
-               { PIN_FSCLKST_N,      20, 2 },  /* FSCLKST# */
-               { PIN_TMS,             4, 2 },  /* TMS */
-       } },
-       { PINMUX_DRIVE_REG("DRVCTRL13", 0xe6060334) {
-               { PIN_TDO,            28, 2 },  /* TDO */
-               { PIN_ASEBRK,         24, 2 },  /* ASEBRK */
-               { RCAR_GP_PIN(3,  0), 20, 3 },  /* SD0_CLK */
-               { RCAR_GP_PIN(3,  1), 16, 3 },  /* SD0_CMD */
-               { RCAR_GP_PIN(3,  2), 12, 3 },  /* SD0_DAT0 */
-               { RCAR_GP_PIN(3,  3),  8, 3 },  /* SD0_DAT1 */
-               { RCAR_GP_PIN(3,  4),  4, 3 },  /* SD0_DAT2 */
-               { RCAR_GP_PIN(3,  5),  0, 3 },  /* SD0_DAT3 */
-       } },
-       { PINMUX_DRIVE_REG("DRVCTRL14", 0xe6060338) {
-               { RCAR_GP_PIN(3,  6), 28, 3 },  /* SD1_CLK */
-               { RCAR_GP_PIN(3,  7), 24, 3 },  /* SD1_CMD */
-               { RCAR_GP_PIN(3,  8), 20, 3 },  /* SD1_DAT0 */
-               { RCAR_GP_PIN(3,  9), 16, 3 },  /* SD1_DAT1 */
-               { RCAR_GP_PIN(3, 10), 12, 3 },  /* SD1_DAT2 */
-               { RCAR_GP_PIN(3, 11),  8, 3 },  /* SD1_DAT3 */
-               { RCAR_GP_PIN(4,  0),  4, 3 },  /* SD2_CLK */
-               { RCAR_GP_PIN(4,  1),  0, 3 },  /* SD2_CMD */
-       } },
-       { PINMUX_DRIVE_REG("DRVCTRL15", 0xe606033c) {
-               { RCAR_GP_PIN(4,  2), 28, 3 },  /* SD2_DAT0 */
-               { RCAR_GP_PIN(4,  3), 24, 3 },  /* SD2_DAT1 */
-               { RCAR_GP_PIN(4,  4), 20, 3 },  /* SD2_DAT2 */
-               { RCAR_GP_PIN(4,  5), 16, 3 },  /* SD2_DAT3 */
-               { RCAR_GP_PIN(4,  6), 12, 3 },  /* SD2_DS */
-               { RCAR_GP_PIN(4,  7),  8, 3 },  /* SD3_CLK */
-               { RCAR_GP_PIN(4,  8),  4, 3 },  /* SD3_CMD */
-               { RCAR_GP_PIN(4,  9),  0, 3 },  /* SD3_DAT0 */
-       } },
-       { PINMUX_DRIVE_REG("DRVCTRL16", 0xe6060340) {
-               { RCAR_GP_PIN(4, 10), 28, 3 },  /* SD3_DAT1 */
-               { RCAR_GP_PIN(4, 11), 24, 3 },  /* SD3_DAT2 */
-               { RCAR_GP_PIN(4, 12), 20, 3 },  /* SD3_DAT3 */
-               { RCAR_GP_PIN(4, 13), 16, 3 },  /* SD3_DAT4 */
-               { RCAR_GP_PIN(4, 14), 12, 3 },  /* SD3_DAT5 */
-               { RCAR_GP_PIN(4, 15),  8, 3 },  /* SD3_DAT6 */
-               { RCAR_GP_PIN(4, 16),  4, 3 },  /* SD3_DAT7 */
-               { RCAR_GP_PIN(4, 17),  0, 3 },  /* SD3_DS */
-       } },
-       { PINMUX_DRIVE_REG("DRVCTRL17", 0xe6060344) {
-               { RCAR_GP_PIN(3, 12), 28, 3 },  /* SD0_CD */
-               { RCAR_GP_PIN(3, 13), 24, 3 },  /* SD0_WP */
-               { RCAR_GP_PIN(3, 14), 20, 3 },  /* SD1_CD */
-               { RCAR_GP_PIN(3, 15), 16, 3 },  /* SD1_WP */
-               { RCAR_GP_PIN(5,  0), 12, 3 },  /* SCK0 */
-               { RCAR_GP_PIN(5,  1),  8, 3 },  /* RX0 */
-               { RCAR_GP_PIN(5,  2),  4, 3 },  /* TX0 */
-               { RCAR_GP_PIN(5,  3),  0, 3 },  /* CTS0 */
-       } },
-       { PINMUX_DRIVE_REG("DRVCTRL18", 0xe6060348) {
-               { RCAR_GP_PIN(5,  4), 28, 3 },  /* RTS0 */
-               { RCAR_GP_PIN(5,  5), 24, 3 },  /* RX1 */
-               { RCAR_GP_PIN(5,  6), 20, 3 },  /* TX1 */
-               { RCAR_GP_PIN(5,  7), 16, 3 },  /* CTS1 */
-               { RCAR_GP_PIN(5,  8), 12, 3 },  /* RTS1 */
-               { RCAR_GP_PIN(5,  9),  8, 3 },  /* SCK2 */
-               { RCAR_GP_PIN(5, 10),  4, 3 },  /* TX2 */
-               { RCAR_GP_PIN(5, 11),  0, 3 },  /* RX2 */
-       } },
-       { PINMUX_DRIVE_REG("DRVCTRL19", 0xe606034c) {
-               { RCAR_GP_PIN(5, 12), 28, 3 },  /* HSCK0 */
-               { RCAR_GP_PIN(5, 13), 24, 3 },  /* HRX0 */
-               { RCAR_GP_PIN(5, 14), 20, 3 },  /* HTX0 */
-               { RCAR_GP_PIN(5, 15), 16, 3 },  /* HCTS0 */
-               { RCAR_GP_PIN(5, 16), 12, 3 },  /* HRTS0 */
-               { RCAR_GP_PIN(5, 17),  8, 3 },  /* MSIOF0_SCK */
-               { RCAR_GP_PIN(5, 18),  4, 3 },  /* MSIOF0_SYNC */
-               { RCAR_GP_PIN(5, 19),  0, 3 },  /* MSIOF0_SS1 */
-       } },
-       { PINMUX_DRIVE_REG("DRVCTRL20", 0xe6060350) {
-               { RCAR_GP_PIN(5, 20), 28, 3 },  /* MSIOF0_TXD */
-               { RCAR_GP_PIN(5, 21), 24, 3 },  /* MSIOF0_SS2 */
-               { RCAR_GP_PIN(5, 22), 20, 3 },  /* MSIOF0_RXD */
-               { RCAR_GP_PIN(5, 23), 16, 3 },  /* MLB_CLK */
-               { RCAR_GP_PIN(5, 24), 12, 3 },  /* MLB_SIG */
-               { RCAR_GP_PIN(5, 25),  8, 3 },  /* MLB_DAT */
-               { PIN_MLB_REF,         4, 3 },  /* MLB_REF */
-               { RCAR_GP_PIN(6,  0),  0, 3 },  /* SSI_SCK01239 */
-       } },
-       { PINMUX_DRIVE_REG("DRVCTRL21", 0xe6060354) {
-               { RCAR_GP_PIN(6,  1), 28, 3 },  /* SSI_WS01239 */
-               { RCAR_GP_PIN(6,  2), 24, 3 },  /* SSI_SDATA0 */
-               { RCAR_GP_PIN(6,  3), 20, 3 },  /* SSI_SDATA1 */
-               { RCAR_GP_PIN(6,  4), 16, 3 },  /* SSI_SDATA2 */
-               { RCAR_GP_PIN(6,  5), 12, 3 },  /* SSI_SCK349 */
-               { RCAR_GP_PIN(6,  6),  8, 3 },  /* SSI_WS349 */
-               { RCAR_GP_PIN(6,  7),  4, 3 },  /* SSI_SDATA3 */
-               { RCAR_GP_PIN(6,  8),  0, 3 },  /* SSI_SCK4 */
-       } },
-       { PINMUX_DRIVE_REG("DRVCTRL22", 0xe6060358) {
-               { RCAR_GP_PIN(6,  9), 28, 3 },  /* SSI_WS4 */
-               { RCAR_GP_PIN(6, 10), 24, 3 },  /* SSI_SDATA4 */
-               { RCAR_GP_PIN(6, 11), 20, 3 },  /* SSI_SCK5 */
-               { RCAR_GP_PIN(6, 12), 16, 3 },  /* SSI_WS5 */
-               { RCAR_GP_PIN(6, 13), 12, 3 },  /* SSI_SDATA5 */
-               { RCAR_GP_PIN(6, 14),  8, 3 },  /* SSI_SCK6 */
-               { RCAR_GP_PIN(6, 15),  4, 3 },  /* SSI_WS6 */
-               { RCAR_GP_PIN(6, 16),  0, 3 },  /* SSI_SDATA6 */
-       } },
-       { PINMUX_DRIVE_REG("DRVCTRL23", 0xe606035c) {
-               { RCAR_GP_PIN(6, 17), 28, 3 },  /* SSI_SCK78 */
-               { RCAR_GP_PIN(6, 18), 24, 3 },  /* SSI_WS78 */
-               { RCAR_GP_PIN(6, 19), 20, 3 },  /* SSI_SDATA7 */
-               { RCAR_GP_PIN(6, 20), 16, 3 },  /* SSI_SDATA8 */
-               { RCAR_GP_PIN(6, 21), 12, 3 },  /* SSI_SDATA9 */
-               { RCAR_GP_PIN(6, 22),  8, 3 },  /* AUDIO_CLKA */
-               { RCAR_GP_PIN(6, 23),  4, 3 },  /* AUDIO_CLKB */
-               { RCAR_GP_PIN(6, 24),  0, 3 },  /* USB0_PWEN */
-       } },
-       { PINMUX_DRIVE_REG("DRVCTRL24", 0xe6060360) {
-               { RCAR_GP_PIN(6, 25), 28, 3 },  /* USB0_OVC */
-               { RCAR_GP_PIN(6, 26), 24, 3 },  /* USB1_PWEN */
-               { RCAR_GP_PIN(6, 27), 20, 3 },  /* USB1_OVC */
-               { RCAR_GP_PIN(6, 28), 16, 3 },  /* USB30_PWEN */
-               { RCAR_GP_PIN(6, 29), 12, 3 },  /* USB30_OVC */
-               { RCAR_GP_PIN(6, 30),  8, 3 },  /* USB31_PWEN */
-               { RCAR_GP_PIN(6, 31),  4, 3 },  /* USB31_OVC */
-       } },
-       { },
-};
-
-enum ioctrl_regs {
-       POCCTRL,
-       TDSELCTRL,
-};
-
-static const struct pinmux_ioctrl_reg pinmux_ioctrl_regs[] = {
-       [POCCTRL] = { 0xe6060380, },
-       [TDSELCTRL] = { 0xe60603c0, },
-       { /* sentinel */ },
-};
-
-static int r8a77950_pin_to_pocctrl(unsigned int pin, u32 *pocctrl)
-{
-       int bit = -EINVAL;
-
-       *pocctrl = pinmux_ioctrl_regs[POCCTRL].reg;
-
-       if (pin >= RCAR_GP_PIN(3, 0) && pin <= RCAR_GP_PIN(3, 11))
-               bit = pin & 0x1f;
-
-       if (pin >= RCAR_GP_PIN(4, 0) && pin <= RCAR_GP_PIN(4, 17))
-               bit = (pin & 0x1f) + 12;
-
-       return bit;
-}
-
-static const struct pinmux_bias_reg pinmux_bias_regs[] = {
-       { PINMUX_BIAS_REG("PUEN0", 0xe6060400, "PUD0", 0xe6060440) {
-               [ 0] = PIN_QSPI0_SPCLK,         /* QSPI0_SPCLK */
-               [ 1] = PIN_QSPI0_MOSI_IO0,      /* QSPI0_MOSI_IO0 */
-               [ 2] = PIN_QSPI0_MISO_IO1,      /* QSPI0_MISO_IO1 */
-               [ 3] = PIN_QSPI0_IO2,           /* QSPI0_IO2 */
-               [ 4] = PIN_QSPI0_IO3,           /* QSPI0_IO3 */
-               [ 5] = PIN_QSPI0_SSL,           /* QSPI0_SSL */
-               [ 6] = PIN_QSPI1_SPCLK,         /* QSPI1_SPCLK */
-               [ 7] = PIN_QSPI1_MOSI_IO0,      /* QSPI1_MOSI_IO0 */
-               [ 8] = PIN_QSPI1_MISO_IO1,      /* QSPI1_MISO_IO1 */
-               [ 9] = PIN_QSPI1_IO2,           /* QSPI1_IO2 */
-               [10] = PIN_QSPI1_IO3,           /* QSPI1_IO3 */
-               [11] = PIN_QSPI1_SSL,           /* QSPI1_SSL */
-               [12] = PIN_RPC_INT_N,           /* RPC_INT# */
-               [13] = PIN_RPC_WP_N,            /* RPC_WP# */
-               [14] = PIN_RPC_RESET_N,         /* RPC_RESET# */
-               [15] = PIN_AVB_RX_CTL,          /* AVB_RX_CTL */
-               [16] = PIN_AVB_RXC,             /* AVB_RXC */
-               [17] = PIN_AVB_RD0,             /* AVB_RD0 */
-               [18] = PIN_AVB_RD1,             /* AVB_RD1 */
-               [19] = PIN_AVB_RD2,             /* AVB_RD2 */
-               [20] = PIN_AVB_RD3,             /* AVB_RD3 */
-               [21] = PIN_AVB_TX_CTL,          /* AVB_TX_CTL */
-               [22] = PIN_AVB_TXC,             /* AVB_TXC */
-               [23] = PIN_AVB_TD0,             /* AVB_TD0 */
-               [24] = PIN_AVB_TD1,             /* AVB_TD1 */
-               [25] = PIN_AVB_TD2,             /* AVB_TD2 */
-               [26] = PIN_AVB_TD3,             /* AVB_TD3 */
-               [27] = PIN_AVB_TXCREFCLK,       /* AVB_TXCREFCLK */
-               [28] = PIN_AVB_MDIO,            /* AVB_MDIO */
-               [29] = RCAR_GP_PIN(2,  9),      /* AVB_MDC */
-               [30] = RCAR_GP_PIN(2, 10),      /* AVB_MAGIC */
-               [31] = RCAR_GP_PIN(2, 11),      /* AVB_PHY_INT */
-       } },
-       { PINMUX_BIAS_REG("PUEN1", 0xe6060404, "PUD1", 0xe6060444) {
-               [ 0] = RCAR_GP_PIN(2, 12),      /* AVB_LINK */
-               [ 1] = RCAR_GP_PIN(2, 13),      /* AVB_AVTP_MATCH_A */
-               [ 2] = RCAR_GP_PIN(2, 14),      /* AVB_AVTP_CAPTURE_A */
-               [ 3] = RCAR_GP_PIN(2,  0),      /* IRQ0 */
-               [ 4] = RCAR_GP_PIN(2,  1),      /* IRQ1 */
-               [ 5] = RCAR_GP_PIN(2,  2),      /* IRQ2 */
-               [ 6] = RCAR_GP_PIN(2,  3),      /* IRQ3 */
-               [ 7] = RCAR_GP_PIN(2,  4),      /* IRQ4 */
-               [ 8] = RCAR_GP_PIN(2,  5),      /* IRQ5 */
-               [ 9] = RCAR_GP_PIN(2,  6),      /* PWM0 */
-               [10] = RCAR_GP_PIN(2,  7),      /* PWM1_A */
-               [11] = RCAR_GP_PIN(2,  8),      /* PWM2_A */
-               [12] = RCAR_GP_PIN(1,  0),      /* A0 */
-               [13] = RCAR_GP_PIN(1,  1),      /* A1 */
-               [14] = RCAR_GP_PIN(1,  2),      /* A2 */
-               [15] = RCAR_GP_PIN(1,  3),      /* A3 */
-               [16] = RCAR_GP_PIN(1,  4),      /* A4 */
-               [17] = RCAR_GP_PIN(1,  5),      /* A5 */
-               [18] = RCAR_GP_PIN(1,  6),      /* A6 */
-               [19] = RCAR_GP_PIN(1,  7),      /* A7 */
-               [20] = RCAR_GP_PIN(1,  8),      /* A8 */
-               [21] = RCAR_GP_PIN(1,  9),      /* A9 */
-               [22] = RCAR_GP_PIN(1, 10),      /* A10 */
-               [23] = RCAR_GP_PIN(1, 11),      /* A11 */
-               [24] = RCAR_GP_PIN(1, 12),      /* A12 */
-               [25] = RCAR_GP_PIN(1, 13),      /* A13 */
-               [26] = RCAR_GP_PIN(1, 14),      /* A14 */
-               [27] = RCAR_GP_PIN(1, 15),      /* A15 */
-               [28] = RCAR_GP_PIN(1, 16),      /* A16 */
-               [29] = RCAR_GP_PIN(1, 17),      /* A17 */
-               [30] = RCAR_GP_PIN(1, 18),      /* A18 */
-               [31] = RCAR_GP_PIN(1, 19),      /* A19 */
-       } },
-       { PINMUX_BIAS_REG("PUEN2", 0xe6060408, "PUD2", 0xe6060448) {
-               [ 0] = PIN_CLKOUT,              /* CLKOUT */
-               [ 1] = RCAR_GP_PIN(1, 20),      /* CS0_N */
-               [ 2] = RCAR_GP_PIN(1, 21),      /* CS1_N_A26 */
-               [ 3] = RCAR_GP_PIN(1, 22),      /* BS_N */
-               [ 4] = RCAR_GP_PIN(1, 23),      /* RD_N */
-               [ 5] = RCAR_GP_PIN(1, 24),      /* RD_WR_N */
-               [ 6] = RCAR_GP_PIN(1, 25),      /* WE0_N */
-               [ 7] = RCAR_GP_PIN(1, 26),      /* WE1_N */
-               [ 8] = RCAR_GP_PIN(1, 27),      /* EX_WAIT0_A */
-               [ 9] = PIN_PRESETOUT_N,         /* PRESETOUT# */
-               [10] = RCAR_GP_PIN(0,  0),      /* D0 */
-               [11] = RCAR_GP_PIN(0,  1),      /* D1 */
-               [12] = RCAR_GP_PIN(0,  2),      /* D2 */
-               [13] = RCAR_GP_PIN(0,  3),      /* D3 */
-               [14] = RCAR_GP_PIN(0,  4),      /* D4 */
-               [15] = RCAR_GP_PIN(0,  5),      /* D5 */
-               [16] = RCAR_GP_PIN(0,  6),      /* D6 */
-               [17] = RCAR_GP_PIN(0,  7),      /* D7 */
-               [18] = RCAR_GP_PIN(0,  8),      /* D8 */
-               [19] = RCAR_GP_PIN(0,  9),      /* D9 */
-               [20] = RCAR_GP_PIN(0, 10),      /* D10 */
-               [21] = RCAR_GP_PIN(0, 11),      /* D11 */
-               [22] = RCAR_GP_PIN(0, 12),      /* D12 */
-               [23] = RCAR_GP_PIN(0, 13),      /* D13 */
-               [24] = RCAR_GP_PIN(0, 14),      /* D14 */
-               [25] = RCAR_GP_PIN(0, 15),      /* D15 */
-               [26] = RCAR_GP_PIN(7,  0),      /* AVS1 */
-               [27] = RCAR_GP_PIN(7,  1),      /* AVS2 */
-               [28] = RCAR_GP_PIN(7,  2),      /* GP7_02 */
-               [29] = RCAR_GP_PIN(7,  3),      /* GP7_03 */
-               [30] = PIN_DU_DOTCLKIN0,        /* DU_DOTCLKIN0 */
-               [31] = PIN_DU_DOTCLKIN1,        /* DU_DOTCLKIN1 */
-       } },
-       { PINMUX_BIAS_REG("PUEN3", 0xe606040c, "PUD3", 0xe606044c) {
-               [ 0] = PIN_DU_DOTCLKIN2,        /* DU_DOTCLKIN2 */
-               [ 1] = PIN_DU_DOTCLKIN3,        /* DU_DOTCLKIN3 */
-               [ 2] = PIN_FSCLKST_N,           /* FSCLKST# */
-               [ 3] = PIN_EXTALR,              /* EXTALR*/
-               [ 4] = PIN_TRST_N,              /* TRST# */
-               [ 5] = PIN_TCK,                 /* TCK */
-               [ 6] = PIN_TMS,                 /* TMS */
-               [ 7] = PIN_TDI,                 /* TDI */
-               [ 8] = SH_PFC_PIN_NONE,
-               [ 9] = PIN_ASEBRK,              /* ASEBRK */
-               [10] = RCAR_GP_PIN(3,  0),      /* SD0_CLK */
-               [11] = RCAR_GP_PIN(3,  1),      /* SD0_CMD */
-               [12] = RCAR_GP_PIN(3,  2),      /* SD0_DAT0 */
-               [13] = RCAR_GP_PIN(3,  3),      /* SD0_DAT1 */
-               [14] = RCAR_GP_PIN(3,  4),      /* SD0_DAT2 */
-               [15] = RCAR_GP_PIN(3,  5),      /* SD0_DAT3 */
-               [16] = RCAR_GP_PIN(3,  6),      /* SD1_CLK */
-               [17] = RCAR_GP_PIN(3,  7),      /* SD1_CMD */
-               [18] = RCAR_GP_PIN(3,  8),      /* SD1_DAT0 */
-               [19] = RCAR_GP_PIN(3,  9),      /* SD1_DAT1 */
-               [20] = RCAR_GP_PIN(3, 10),      /* SD1_DAT2 */
-               [21] = RCAR_GP_PIN(3, 11),      /* SD1_DAT3 */
-               [22] = RCAR_GP_PIN(4,  0),      /* SD2_CLK */
-               [23] = RCAR_GP_PIN(4,  1),      /* SD2_CMD */
-               [24] = RCAR_GP_PIN(4,  2),      /* SD2_DAT0 */
-               [25] = RCAR_GP_PIN(4,  3),      /* SD2_DAT1 */
-               [26] = RCAR_GP_PIN(4,  4),      /* SD2_DAT2 */
-               [27] = RCAR_GP_PIN(4,  5),      /* SD2_DAT3 */
-               [28] = RCAR_GP_PIN(4,  6),      /* SD2_DS */
-               [29] = RCAR_GP_PIN(4,  7),      /* SD3_CLK */
-               [30] = RCAR_GP_PIN(4,  8),      /* SD3_CMD */
-               [31] = RCAR_GP_PIN(4,  9),      /* SD3_DAT0 */
-       } },
-       { PINMUX_BIAS_REG("PUEN4", 0xe6060410, "PUD4", 0xe6060450) {
-               [ 0] = RCAR_GP_PIN(4, 10),      /* SD3_DAT1 */
-               [ 1] = RCAR_GP_PIN(4, 11),      /* SD3_DAT2 */
-               [ 2] = RCAR_GP_PIN(4, 12),      /* SD3_DAT3 */
-               [ 3] = RCAR_GP_PIN(4, 13),      /* SD3_DAT4 */
-               [ 4] = RCAR_GP_PIN(4, 14),      /* SD3_DAT5 */
-               [ 5] = RCAR_GP_PIN(4, 15),      /* SD3_DAT6 */
-               [ 6] = RCAR_GP_PIN(4, 16),      /* SD3_DAT7 */
-               [ 7] = RCAR_GP_PIN(4, 17),      /* SD3_DS */
-               [ 8] = RCAR_GP_PIN(3, 12),      /* SD0_CD */
-               [ 9] = RCAR_GP_PIN(3, 13),      /* SD0_WP */
-               [10] = RCAR_GP_PIN(3, 14),      /* SD1_CD */
-               [11] = RCAR_GP_PIN(3, 15),      /* SD1_WP */
-               [12] = RCAR_GP_PIN(5,  0),      /* SCK0 */
-               [13] = RCAR_GP_PIN(5,  1),      /* RX0 */
-               [14] = RCAR_GP_PIN(5,  2),      /* TX0 */
-               [15] = RCAR_GP_PIN(5,  3),      /* CTS0_N */
-               [16] = RCAR_GP_PIN(5,  4),      /* RTS0_N */
-               [17] = RCAR_GP_PIN(5,  5),      /* RX1_A */
-               [18] = RCAR_GP_PIN(5,  6),      /* TX1_A */
-               [19] = RCAR_GP_PIN(5,  7),      /* CTS1_N */
-               [20] = RCAR_GP_PIN(5,  8),      /* RTS1_N */
-               [21] = RCAR_GP_PIN(5,  9),      /* SCK2 */
-               [22] = RCAR_GP_PIN(5, 10),      /* TX2_A */
-               [23] = RCAR_GP_PIN(5, 11),      /* RX2_A */
-               [24] = RCAR_GP_PIN(5, 12),      /* HSCK0 */
-               [25] = RCAR_GP_PIN(5, 13),      /* HRX0 */
-               [26] = RCAR_GP_PIN(5, 14),      /* HTX0 */
-               [27] = RCAR_GP_PIN(5, 15),      /* HCTS0_N */
-               [28] = RCAR_GP_PIN(5, 16),      /* HRTS0_N */
-               [29] = RCAR_GP_PIN(5, 17),      /* MSIOF0_SCK */
-               [30] = RCAR_GP_PIN(5, 18),      /* MSIOF0_SYNC */
-               [31] = RCAR_GP_PIN(5, 19),      /* MSIOF0_SS1 */
-       } },
-       { PINMUX_BIAS_REG("PUEN5", 0xe6060414, "PUD5", 0xe6060454) {
-               [ 0] = RCAR_GP_PIN(5, 20),      /* MSIOF0_TXD */
-               [ 1] = RCAR_GP_PIN(5, 21),      /* MSIOF0_SS2 */
-               [ 2] = RCAR_GP_PIN(5, 22),      /* MSIOF0_RXD */
-               [ 3] = RCAR_GP_PIN(5, 23),      /* MLB_CLK */
-               [ 4] = RCAR_GP_PIN(5, 24),      /* MLB_SIG */
-               [ 5] = RCAR_GP_PIN(5, 25),      /* MLB_DAT */
-               [ 6] = PIN_MLB_REF,             /* MLB_REF */
-               [ 7] = RCAR_GP_PIN(6,  0),      /* SSI_SCK01239 */
-               [ 8] = RCAR_GP_PIN(6,  1),      /* SSI_WS01239 */
-               [ 9] = RCAR_GP_PIN(6,  2),      /* SSI_SDATA0 */
-               [10] = RCAR_GP_PIN(6,  3),      /* SSI_SDATA1_A */
-               [11] = RCAR_GP_PIN(6,  4),      /* SSI_SDATA2_A */
-               [12] = RCAR_GP_PIN(6,  5),      /* SSI_SCK349 */
-               [13] = RCAR_GP_PIN(6,  6),      /* SSI_WS349 */
-               [14] = RCAR_GP_PIN(6,  7),      /* SSI_SDATA3 */
-               [15] = RCAR_GP_PIN(6,  8),      /* SSI_SCK4 */
-               [16] = RCAR_GP_PIN(6,  9),      /* SSI_WS4 */
-               [17] = RCAR_GP_PIN(6, 10),      /* SSI_SDATA4 */
-               [18] = RCAR_GP_PIN(6, 11),      /* SSI_SCK5 */
-               [19] = RCAR_GP_PIN(6, 12),      /* SSI_WS5 */
-               [20] = RCAR_GP_PIN(6, 13),      /* SSI_SDATA5 */
-               [21] = RCAR_GP_PIN(6, 14),      /* SSI_SCK6 */
-               [22] = RCAR_GP_PIN(6, 15),      /* SSI_WS6 */
-               [23] = RCAR_GP_PIN(6, 16),      /* SSI_SDATA6 */
-               [24] = RCAR_GP_PIN(6, 17),      /* SSI_SCK78 */
-               [25] = RCAR_GP_PIN(6, 18),      /* SSI_WS78 */
-               [26] = RCAR_GP_PIN(6, 19),      /* SSI_SDATA7 */
-               [27] = RCAR_GP_PIN(6, 20),      /* SSI_SDATA8 */
-               [28] = RCAR_GP_PIN(6, 21),      /* SSI_SDATA9_A */
-               [29] = RCAR_GP_PIN(6, 22),      /* AUDIO_CLKA_A */
-               [30] = RCAR_GP_PIN(6, 23),      /* AUDIO_CLKB_B */
-               [31] = RCAR_GP_PIN(6, 24),      /* USB0_PWEN */
-       } },
-       { PINMUX_BIAS_REG("PUEN6", 0xe6060418, "PUD6", 0xe6060458) {
-               [ 0] = RCAR_GP_PIN(6, 25),      /* USB0_OVC */
-               [ 1] = RCAR_GP_PIN(6, 26),      /* USB1_PWEN */
-               [ 2] = RCAR_GP_PIN(6, 27),      /* USB1_OVC */
-               [ 3] = RCAR_GP_PIN(6, 28),      /* USB30_PWEN */
-               [ 4] = RCAR_GP_PIN(6, 29),      /* USB30_OVC */
-               [ 5] = RCAR_GP_PIN(6, 30),      /* USB31_PWEN */
-               [ 6] = RCAR_GP_PIN(6, 31),      /* USB31_OVC */
-               [ 7] = SH_PFC_PIN_NONE,
-               [ 8] = SH_PFC_PIN_NONE,
-               [ 9] = SH_PFC_PIN_NONE,
-               [10] = SH_PFC_PIN_NONE,
-               [11] = SH_PFC_PIN_NONE,
-               [12] = SH_PFC_PIN_NONE,
-               [13] = SH_PFC_PIN_NONE,
-               [14] = SH_PFC_PIN_NONE,
-               [15] = SH_PFC_PIN_NONE,
-               [16] = SH_PFC_PIN_NONE,
-               [17] = SH_PFC_PIN_NONE,
-               [18] = SH_PFC_PIN_NONE,
-               [19] = SH_PFC_PIN_NONE,
-               [20] = SH_PFC_PIN_NONE,
-               [21] = SH_PFC_PIN_NONE,
-               [22] = SH_PFC_PIN_NONE,
-               [23] = SH_PFC_PIN_NONE,
-               [24] = SH_PFC_PIN_NONE,
-               [25] = SH_PFC_PIN_NONE,
-               [26] = SH_PFC_PIN_NONE,
-               [27] = SH_PFC_PIN_NONE,
-               [28] = SH_PFC_PIN_NONE,
-               [29] = SH_PFC_PIN_NONE,
-               [30] = SH_PFC_PIN_NONE,
-               [31] = SH_PFC_PIN_NONE,
-       } },
-       { /* sentinel */ },
-};
-
-static const struct sh_pfc_soc_operations r8a77950_pfc_ops = {
-       .pin_to_pocctrl = r8a77950_pin_to_pocctrl,
-       .get_bias = rcar_pinmux_get_bias,
-       .set_bias = rcar_pinmux_set_bias,
-};
-
-const struct sh_pfc_soc_info r8a77950_pinmux_info = {
-       .name = "r8a77950_pfc",
-       .ops = &r8a77950_pfc_ops,
-       .unlock_reg = 0xe6060000, /* PMMR */
-
-       .function = { PINMUX_FUNCTION_BEGIN, PINMUX_FUNCTION_END },
-
-       .pins = pinmux_pins,
-       .nr_pins = ARRAY_SIZE(pinmux_pins),
-       .groups = pinmux_groups,
-       .nr_groups = ARRAY_SIZE(pinmux_groups),
-       .functions = pinmux_functions,
-       .nr_functions = ARRAY_SIZE(pinmux_functions),
-
-       .cfg_regs = pinmux_config_regs,
-       .drive_regs = pinmux_drive_regs,
-       .bias_regs = pinmux_bias_regs,
-       .ioctrl_regs = pinmux_ioctrl_regs,
-
-       .pinmux_data = pinmux_data,
-       .pinmux_data_size = ARRAY_SIZE(pinmux_data),
-};
index d4d271dff055462da019d45ef97412b1375ebba5..a1d74f61fd8cce641eb25047fb5d8ca8f7d1bc68 100644 (file)
        PORT_GP_CFG_16(0, fn, sfx, CFG_FLAGS),  \
        PORT_GP_CFG_29(1, fn, sfx, CFG_FLAGS),  \
        PORT_GP_CFG_15(2, fn, sfx, CFG_FLAGS),  \
-       PORT_GP_CFG_12(3, fn, sfx, CFG_FLAGS | SH_PFC_PIN_CFG_IO_VOLTAGE),      \
+       PORT_GP_CFG_12(3, fn, sfx, CFG_FLAGS | SH_PFC_PIN_CFG_IO_VOLTAGE_18_33),        \
        PORT_GP_CFG_1(3, 12, fn, sfx, CFG_FLAGS),       \
        PORT_GP_CFG_1(3, 13, fn, sfx, CFG_FLAGS),       \
        PORT_GP_CFG_1(3, 14, fn, sfx, CFG_FLAGS),       \
        PORT_GP_CFG_1(3, 15, fn, sfx, CFG_FLAGS),       \
-       PORT_GP_CFG_18(4, fn, sfx, CFG_FLAGS | SH_PFC_PIN_CFG_IO_VOLTAGE),      \
+       PORT_GP_CFG_18(4, fn, sfx, CFG_FLAGS | SH_PFC_PIN_CFG_IO_VOLTAGE_18_33),        \
        PORT_GP_CFG_26(5, fn, sfx, CFG_FLAGS),  \
        PORT_GP_CFG_32(6, fn, sfx, CFG_FLAGS),  \
        PORT_GP_CFG_4(7, fn, sfx, CFG_FLAGS)
@@ -5610,7 +5610,7 @@ static const struct pinmux_cfg_reg pinmux_config_regs[] = {
                /* RESERVED 16-1 */
                MOD_SEL2_0 ))
        },
-       { },
+       { /* sentinel */ }
 };
 
 static const struct pinmux_drive_reg pinmux_drive_regs[] = {
@@ -5861,7 +5861,7 @@ static const struct pinmux_drive_reg pinmux_drive_regs[] = {
                { RCAR_GP_PIN(6, 30),  8, 3 },  /* GP6_30/USB2_CH3_PWEN */
                { RCAR_GP_PIN(6, 31),  4, 3 },  /* GP6_31/USB2_CH3_OVC */
        } },
-       { },
+       { /* sentinel */ }
 };
 
 enum ioctrl_regs {
@@ -5872,7 +5872,7 @@ enum ioctrl_regs {
 static const struct pinmux_ioctrl_reg pinmux_ioctrl_regs[] = {
        [POCCTRL] = { 0xe6060380, },
        [TDSELCTRL] = { 0xe60603c0, },
-       { /* sentinel */ },
+       { /* sentinel */ }
 };
 
 static int r8a77951_pin_to_pocctrl(unsigned int pin, u32 *pocctrl)
@@ -6129,7 +6129,7 @@ static const struct pinmux_bias_reg pinmux_bias_regs[] = {
                [30] = SH_PFC_PIN_NONE,
                [31] = SH_PFC_PIN_NONE,
        } },
-       { /* sentinel */ },
+       { /* sentinel */ }
 };
 
 static const struct sh_pfc_soc_operations r8a77951_pfc_ops = {
index a0096ef5e68dc6d64dc9b95b36575ada9f28af16..807834f319f07d8c1fcaa9b6223c1cbfe62f235b 100644 (file)
        PORT_GP_CFG_16(0, fn, sfx, CFG_FLAGS),  \
        PORT_GP_CFG_29(1, fn, sfx, CFG_FLAGS),  \
        PORT_GP_CFG_15(2, fn, sfx, CFG_FLAGS),  \
-       PORT_GP_CFG_12(3, fn, sfx, CFG_FLAGS | SH_PFC_PIN_CFG_IO_VOLTAGE),      \
+       PORT_GP_CFG_12(3, fn, sfx, CFG_FLAGS | SH_PFC_PIN_CFG_IO_VOLTAGE_18_33),        \
        PORT_GP_CFG_1(3, 12, fn, sfx, CFG_FLAGS),       \
        PORT_GP_CFG_1(3, 13, fn, sfx, CFG_FLAGS),       \
        PORT_GP_CFG_1(3, 14, fn, sfx, CFG_FLAGS),       \
        PORT_GP_CFG_1(3, 15, fn, sfx, CFG_FLAGS),       \
-       PORT_GP_CFG_18(4, fn, sfx, CFG_FLAGS | SH_PFC_PIN_CFG_IO_VOLTAGE),      \
+       PORT_GP_CFG_18(4, fn, sfx, CFG_FLAGS | SH_PFC_PIN_CFG_IO_VOLTAGE_18_33),        \
        PORT_GP_CFG_26(5, fn, sfx, CFG_FLAGS),  \
        PORT_GP_CFG_32(6, fn, sfx, CFG_FLAGS),  \
        PORT_GP_CFG_4(7, fn, sfx, CFG_FLAGS)
@@ -5565,7 +5565,7 @@ static const struct pinmux_cfg_reg pinmux_config_regs[] = {
                /* RESERVED 16-1 */
                MOD_SEL2_0 ))
        },
-       { },
+       { /* sentinel */ }
 };
 
 static const struct pinmux_drive_reg pinmux_drive_regs[] = {
@@ -5813,7 +5813,7 @@ static const struct pinmux_drive_reg pinmux_drive_regs[] = {
                { RCAR_GP_PIN(6, 30),  8, 3 },  /* GP6_30 */
                { RCAR_GP_PIN(6, 31),  4, 3 },  /* GP6_31 */
        } },
-       { },
+       { /* sentinel */ }
 };
 
 enum ioctrl_regs {
@@ -5824,7 +5824,7 @@ enum ioctrl_regs {
 static const struct pinmux_ioctrl_reg pinmux_ioctrl_regs[] = {
        [POCCTRL] = { 0xe6060380, },
        [TDSELCTRL] = { 0xe60603c0, },
-       { /* sentinel */ },
+       { /* sentinel */ }
 };
 
 static int r8a7796_pin_to_pocctrl(unsigned int pin, u32 *pocctrl)
@@ -6081,7 +6081,7 @@ static const struct pinmux_bias_reg pinmux_bias_regs[] = {
                [30] = SH_PFC_PIN_NONE,
                [31] = SH_PFC_PIN_NONE,
        } },
-       { /* sentinel */ },
+       { /* sentinel */ }
 };
 
 static const struct sh_pfc_soc_operations r8a7796_pfc_ops = {
index acd0bdf1301844ef1923c787626302921c727b45..e7c88a5d983f43437cf9ce6645bdb87575d14135 100644 (file)
        PORT_GP_CFG_16(0, fn, sfx, CFG_FLAGS),  \
        PORT_GP_CFG_29(1, fn, sfx, CFG_FLAGS),  \
        PORT_GP_CFG_15(2, fn, sfx, CFG_FLAGS),  \
-       PORT_GP_CFG_12(3, fn, sfx, CFG_FLAGS | SH_PFC_PIN_CFG_IO_VOLTAGE),      \
+       PORT_GP_CFG_12(3, fn, sfx, CFG_FLAGS | SH_PFC_PIN_CFG_IO_VOLTAGE_18_33),        \
        PORT_GP_CFG_1(3, 12, fn, sfx, CFG_FLAGS),       \
        PORT_GP_CFG_1(3, 13, fn, sfx, CFG_FLAGS),       \
        PORT_GP_CFG_1(3, 14, fn, sfx, CFG_FLAGS),       \
        PORT_GP_CFG_1(3, 15, fn, sfx, CFG_FLAGS),       \
-       PORT_GP_CFG_18(4, fn, sfx, CFG_FLAGS | SH_PFC_PIN_CFG_IO_VOLTAGE),      \
+       PORT_GP_CFG_18(4, fn, sfx, CFG_FLAGS | SH_PFC_PIN_CFG_IO_VOLTAGE_18_33),        \
        PORT_GP_CFG_26(5, fn, sfx, CFG_FLAGS),  \
        PORT_GP_CFG_32(6, fn, sfx, CFG_FLAGS),  \
        PORT_GP_CFG_4(7, fn, sfx, CFG_FLAGS)
@@ -5806,7 +5806,7 @@ static const struct pinmux_cfg_reg pinmux_config_regs[] = {
                /* RESERVED 16-1 */
                MOD_SEL2_0 ))
        },
-       { },
+       { /* sentinel */ }
 };
 
 static const struct pinmux_drive_reg pinmux_drive_regs[] = {
@@ -6054,7 +6054,7 @@ static const struct pinmux_drive_reg pinmux_drive_regs[] = {
                { RCAR_GP_PIN(6, 30),  8, 3 },  /* GP6_30 */
                { RCAR_GP_PIN(6, 31),  4, 3 },  /* GP6_31 */
        } },
-       { },
+       { /* sentinel */ }
 };
 
 enum ioctrl_regs {
@@ -6065,7 +6065,7 @@ enum ioctrl_regs {
 static const struct pinmux_ioctrl_reg pinmux_ioctrl_regs[] = {
        [POCCTRL] = { 0xe6060380, },
        [TDSELCTRL] = { 0xe60603c0, },
-       { /* sentinel */ },
+       { /* sentinel */ }
 };
 
 static int r8a77965_pin_to_pocctrl(unsigned int pin, u32 *pocctrl)
@@ -6322,7 +6322,7 @@ static const struct pinmux_bias_reg pinmux_bias_regs[] = {
                [30] = SH_PFC_PIN_NONE,
                [31] = SH_PFC_PIN_NONE,
        } },
-       { /* sentinel */ },
+       { /* sentinel */ }
 };
 
 static const struct sh_pfc_soc_operations r8a77965_pfc_ops = {
index 4a7803eaafaa8abf54ebf0074b6dc9b124609e81..5b66d7b1af9513375b2a3959b034cf4c05df1bb8 100644 (file)
 #include "sh_pfc.h"
 
 #define CPU_ALL_GP(fn, sfx)                                            \
-       PORT_GP_CFG_22(0, fn, sfx, SH_PFC_PIN_CFG_IO_VOLTAGE | SH_PFC_PIN_CFG_PULL_UP_DOWN),    \
+       PORT_GP_CFG_22(0, fn, sfx, SH_PFC_PIN_CFG_IO_VOLTAGE_18_33 | SH_PFC_PIN_CFG_PULL_UP_DOWN),      \
        PORT_GP_CFG_28(1, fn, sfx, SH_PFC_PIN_CFG_PULL_UP_DOWN),        \
-       PORT_GP_CFG_17(2, fn, sfx, SH_PFC_PIN_CFG_IO_VOLTAGE | SH_PFC_PIN_CFG_PULL_UP_DOWN),    \
-       PORT_GP_CFG_17(3, fn, sfx, SH_PFC_PIN_CFG_IO_VOLTAGE | SH_PFC_PIN_CFG_PULL_UP_DOWN),    \
+       PORT_GP_CFG_17(2, fn, sfx, SH_PFC_PIN_CFG_IO_VOLTAGE_18_33 | SH_PFC_PIN_CFG_PULL_UP_DOWN),      \
+       PORT_GP_CFG_17(3, fn, sfx, SH_PFC_PIN_CFG_IO_VOLTAGE_18_33 | SH_PFC_PIN_CFG_PULL_UP_DOWN),      \
        PORT_GP_CFG_6(4,  fn, sfx, SH_PFC_PIN_CFG_PULL_UP_DOWN),        \
        PORT_GP_CFG_15(5, fn, sfx, SH_PFC_PIN_CFG_PULL_UP_DOWN)
 
@@ -34,7 +34,8 @@
        PIN_NOGP_CFG(TCK, "TCK", fn, SH_PFC_PIN_CFG_PULL_UP),           \
        PIN_NOGP_CFG(TDI, "TDI", fn, SH_PFC_PIN_CFG_PULL_UP),           \
        PIN_NOGP_CFG(TMS, "TMS", fn, SH_PFC_PIN_CFG_PULL_UP),           \
-       PIN_NOGP_CFG(TRST_N, "TRST#", fn, SH_PFC_PIN_CFG_PULL_UP)
+       PIN_NOGP_CFG(TRST_N, "TRST#", fn, SH_PFC_PIN_CFG_PULL_UP),      \
+       PIN_NOGP_CFG(VDDQ_AVB0, "VDDQ_AVB0", fn, SH_PFC_PIN_CFG_IO_VOLTAGE_25_33)
 
 /*
  * F_() : just information
@@ -2342,7 +2343,7 @@ static const struct pinmux_cfg_reg pinmux_config_regs[] = {
                MOD_SEL0_1
                MOD_SEL0_0 ))
        },
-       { },
+       { /* sentinel */ }
 };
 
 enum ioctrl_regs {
@@ -2357,26 +2358,37 @@ static const struct pinmux_ioctrl_reg pinmux_ioctrl_regs[] = {
        [POCCTRL1] = { 0xe6060384 },
        [POCCTRL2] = { 0xe6060388 },
        [TDSELCTRL] = { 0xe60603c0, },
-       { /* sentinel */ },
+       { /* sentinel */ }
 };
 
 static int r8a77970_pin_to_pocctrl(unsigned int pin, u32 *pocctrl)
 {
        int bit = pin & 0x1f;
 
-       *pocctrl = pinmux_ioctrl_regs[POCCTRL0].reg;
-       if (pin >= RCAR_GP_PIN(0, 0) && pin <= RCAR_GP_PIN(0, 21))
+       switch (pin) {
+       case RCAR_GP_PIN(0, 0) ... RCAR_GP_PIN(0, 21):
+               *pocctrl = pinmux_ioctrl_regs[POCCTRL0].reg;
                return bit;
-       if (pin >= RCAR_GP_PIN(2, 0) && pin <= RCAR_GP_PIN(2, 9))
+
+       case RCAR_GP_PIN(2, 0) ... RCAR_GP_PIN(2, 9):
+               *pocctrl = pinmux_ioctrl_regs[POCCTRL0].reg;
                return bit + 22;
 
-       *pocctrl = pinmux_ioctrl_regs[POCCTRL1].reg;
-       if (pin >= RCAR_GP_PIN(2, 10) && pin <= RCAR_GP_PIN(2, 16))
+       case RCAR_GP_PIN(2, 10) ... RCAR_GP_PIN(2, 16):
+               *pocctrl = pinmux_ioctrl_regs[POCCTRL1].reg;
                return bit - 10;
-       if (pin >= RCAR_GP_PIN(3, 0) && pin <= RCAR_GP_PIN(3, 16))
+
+       case RCAR_GP_PIN(3, 0) ... RCAR_GP_PIN(3, 16):
+               *pocctrl = pinmux_ioctrl_regs[POCCTRL1].reg;
                return bit + 7;
 
-       return -EINVAL;
+       case PIN_VDDQ_AVB0:
+               *pocctrl = pinmux_ioctrl_regs[POCCTRL2].reg;
+               return 0;
+
+       default:
+               return -EINVAL;
+       }
 }
 
 static const struct pinmux_bias_reg pinmux_bias_regs[] = {
index ac03309c5c0c9756778f3d448be3c1519ba85c5a..384faa0d6937b1bf4de21edea1971c08b438ac86 100644 (file)
 #include "sh_pfc.h"
 
 #define CPU_ALL_GP(fn, sfx)    \
-       PORT_GP_CFG_22(0, fn, sfx, SH_PFC_PIN_CFG_IO_VOLTAGE | SH_PFC_PIN_CFG_PULL_UP_DOWN),    \
+       PORT_GP_CFG_22(0, fn, sfx, SH_PFC_PIN_CFG_IO_VOLTAGE_18_33 | SH_PFC_PIN_CFG_PULL_UP_DOWN),      \
        PORT_GP_CFG_28(1, fn, sfx, SH_PFC_PIN_CFG_PULL_UP_DOWN),        \
-       PORT_GP_CFG_30(2, fn, sfx, SH_PFC_PIN_CFG_IO_VOLTAGE | SH_PFC_PIN_CFG_PULL_UP_DOWN),    \
-       PORT_GP_CFG_17(3, fn, sfx, SH_PFC_PIN_CFG_IO_VOLTAGE | SH_PFC_PIN_CFG_PULL_UP_DOWN), \
+       PORT_GP_CFG_30(2, fn, sfx, SH_PFC_PIN_CFG_IO_VOLTAGE_18_33 | SH_PFC_PIN_CFG_PULL_UP_DOWN),      \
+       PORT_GP_CFG_17(3, fn, sfx, SH_PFC_PIN_CFG_IO_VOLTAGE_18_33 | SH_PFC_PIN_CFG_PULL_UP_DOWN), \
        PORT_GP_CFG_25(4, fn, sfx, SH_PFC_PIN_CFG_PULL_UP_DOWN),        \
        PORT_GP_CFG_15(5, fn, sfx, SH_PFC_PIN_CFG_PULL_UP_DOWN)
 
@@ -35,7 +35,9 @@
        PIN_NOGP_CFG(EXTALR, "EXTALR", fn, SH_PFC_PIN_CFG_PULL_UP_DOWN),        \
        PIN_NOGP_CFG(FSCLKST, "FSCLKST", fn, SH_PFC_PIN_CFG_PULL_UP_DOWN),      \
        PIN_NOGP_CFG(FSCLKST_N, "FSCLKST#", fn, SH_PFC_PIN_CFG_PULL_UP_DOWN),   \
-       PIN_NOGP_CFG(PRESETOUT_N, "PRESETOUT#", fn, SH_PFC_PIN_CFG_PULL_UP_DOWN)
+       PIN_NOGP_CFG(PRESETOUT_N, "PRESETOUT#", fn, SH_PFC_PIN_CFG_PULL_UP_DOWN), \
+       PIN_NOGP_CFG(VDDQ_AVB, "VDDQ_AVB", fn, SH_PFC_PIN_CFG_IO_VOLTAGE_25_33), \
+       PIN_NOGP_CFG(VDDQ_GE, "VDDQ_GE", fn, SH_PFC_PIN_CFG_IO_VOLTAGE_25_33)
 
 /*
  * F_() : just information
@@ -2813,7 +2815,7 @@ static const struct pinmux_cfg_reg pinmux_config_regs[] = {
                MOD_SEL0_1
                MOD_SEL0_0 ))
        },
-       { },
+       { /* sentinel */ }
 };
 
 enum ioctrl_regs {
@@ -2830,31 +2832,46 @@ static const struct pinmux_ioctrl_reg pinmux_ioctrl_regs[] = {
        [POCCTRL2] = { 0xe6060388, },
        [POCCTRL3] = { 0xe606038c, },
        [TDSELCTRL] = { 0xe60603c0, },
-       { /* sentinel */ },
+       { /* sentinel */ }
 };
 
 static int r8a77980_pin_to_pocctrl(unsigned int pin, u32 *pocctrl)
 {
        int bit = pin & 0x1f;
 
-       *pocctrl = pinmux_ioctrl_regs[POCCTRL0].reg;
-       if (pin >= RCAR_GP_PIN(0, 0) && pin <= RCAR_GP_PIN(0, 21))
+       switch (pin) {
+       case RCAR_GP_PIN(0, 0) ... RCAR_GP_PIN(0, 21):
+               *pocctrl = pinmux_ioctrl_regs[POCCTRL0].reg;
                return bit;
-       else if (pin >= RCAR_GP_PIN(2, 0) && pin <= RCAR_GP_PIN(2, 9))
+
+       case RCAR_GP_PIN(2, 0) ... RCAR_GP_PIN(2, 9):
+               *pocctrl = pinmux_ioctrl_regs[POCCTRL0].reg;
                return bit + 22;
 
-       *pocctrl = pinmux_ioctrl_regs[POCCTRL1].reg;
-       if (pin >= RCAR_GP_PIN(2, 10) && pin <= RCAR_GP_PIN(2, 16))
+       case RCAR_GP_PIN(2, 10) ... RCAR_GP_PIN(2, 16):
+               *pocctrl = pinmux_ioctrl_regs[POCCTRL1].reg;
                return bit - 10;
-       if ((pin >= RCAR_GP_PIN(2, 17) && pin <= RCAR_GP_PIN(2, 24)) ||
-           (pin >= RCAR_GP_PIN(3,  0) && pin <= RCAR_GP_PIN(3, 16)))
+
+       case RCAR_GP_PIN(2, 17) ... RCAR_GP_PIN(2, 24):
+       case RCAR_GP_PIN(3,  0) ... RCAR_GP_PIN(3, 16):
+               *pocctrl = pinmux_ioctrl_regs[POCCTRL1].reg;
                return bit + 7;
 
-       *pocctrl = pinmux_ioctrl_regs[POCCTRL2].reg;
-       if (pin >= RCAR_GP_PIN(2, 25) && pin <= RCAR_GP_PIN(2, 29))
+       case RCAR_GP_PIN(2, 25) ... RCAR_GP_PIN(2, 29):
+               *pocctrl = pinmux_ioctrl_regs[POCCTRL2].reg;
                return pin - 25;
 
-       return -EINVAL;
+       case PIN_VDDQ_AVB:
+               *pocctrl = pinmux_ioctrl_regs[POCCTRL3].reg;
+               return 0;
+
+       case PIN_VDDQ_GE:
+               *pocctrl = pinmux_ioctrl_regs[POCCTRL3].reg;
+               return 1;
+
+       default:
+               return -EINVAL;
+       }
 }
 
 static const struct pinmux_bias_reg pinmux_bias_regs[] = {
index b0936962fad709f1c5bb50ca493e83c35eedb104..262390dd7d67a1015e79880ea55f39ef196b14b8 100644 (file)
        PORT_GP_CFG_18(0, fn, sfx, CFG_FLAGS), \
        PORT_GP_CFG_23(1, fn, sfx, CFG_FLAGS), \
        PORT_GP_CFG_26(2, fn, sfx, CFG_FLAGS), \
-       PORT_GP_CFG_12(3, fn, sfx, CFG_FLAGS | SH_PFC_PIN_CFG_IO_VOLTAGE | SH_PFC_PIN_CFG_DRIVE_STRENGTH), \
+       PORT_GP_CFG_12(3, fn, sfx, CFG_FLAGS | SH_PFC_PIN_CFG_IO_VOLTAGE_18_33 | SH_PFC_PIN_CFG_DRIVE_STRENGTH), \
        PORT_GP_CFG_1(3, 12, fn, sfx, CFG_FLAGS), \
        PORT_GP_CFG_1(3, 13, fn, sfx, CFG_FLAGS), \
        PORT_GP_CFG_1(3, 14, fn, sfx, CFG_FLAGS), \
        PORT_GP_CFG_1(3, 15, fn, sfx, CFG_FLAGS), \
-       PORT_GP_CFG_11(4, fn, sfx, CFG_FLAGS | SH_PFC_PIN_CFG_IO_VOLTAGE | SH_PFC_PIN_CFG_DRIVE_STRENGTH), \
+       PORT_GP_CFG_11(4, fn, sfx, CFG_FLAGS | SH_PFC_PIN_CFG_IO_VOLTAGE_18_33 | SH_PFC_PIN_CFG_DRIVE_STRENGTH), \
        PORT_GP_CFG_20(5, fn, sfx, CFG_FLAGS), \
        PORT_GP_CFG_9(6, fn, sfx, CFG_FLAGS), \
        PORT_GP_CFG_1(6, 9, fn, sfx, SH_PFC_PIN_CFG_PULL_UP), \
@@ -56,7 +56,8 @@
        PIN_NOGP_CFG(TCK, "TCK", fn, SH_PFC_PIN_CFG_PULL_UP),           \
        PIN_NOGP_CFG(TDI, "TDI", fn, SH_PFC_PIN_CFG_PULL_UP),           \
        PIN_NOGP_CFG(TMS, "TMS", fn, SH_PFC_PIN_CFG_PULL_UP),           \
-       PIN_NOGP_CFG(TRST_N, "TRST_N", fn, SH_PFC_PIN_CFG_PULL_UP)
+       PIN_NOGP_CFG(TRST_N, "TRST_N", fn, SH_PFC_PIN_CFG_PULL_UP),     \
+       PIN_NOGP_CFG(VDDQ_AVB0, "VDDQ_AVB0", fn, SH_PFC_PIN_CFG_IO_VOLTAGE_25_33)
 
 /*
  * F_() : just information
@@ -507,7 +508,8 @@ MOD_SEL0_1_0
        FM(AVB_TD3) \
        FM(PRESETOUT_N) FM(FSCLKST_N) FM(TRST_N) FM(TCK) FM(TMS) FM(TDI) \
        FM(ASEBRK) \
-       FM(MLB_REF)
+       FM(MLB_REF) \
+       FM(VDDQ_AVB0)
 
 enum {
        PINMUX_RESERVED = 0,
@@ -5002,7 +5004,7 @@ static const struct pinmux_cfg_reg pinmux_config_regs[] = {
                MOD_SEL1_4
                /* RESERVED 3, 2, 1, 0  */ ))
        },
-       { },
+       { /* sentinel */ }
 };
 
 static const struct pinmux_drive_reg pinmux_drive_regs[] = {
@@ -5035,33 +5037,40 @@ static const struct pinmux_drive_reg pinmux_drive_regs[] = {
                { RCAR_GP_PIN(4,  9), 17, 2 },  /* SD3_DAT7 */
                { RCAR_GP_PIN(4, 10), 14, 2 },  /* SD3_DS */
        } },
-       { },
+       { /* sentinel */ }
 };
 
 enum ioctrl_regs {
        POCCTRL0,
+       POCCTRL2,
        TDSELCTRL,
 };
 
 static const struct pinmux_ioctrl_reg pinmux_ioctrl_regs[] = {
        [POCCTRL0] = { 0xe6060380, },
+       [POCCTRL2] = { 0xe6060388, },
        [TDSELCTRL] = { 0xe60603c0, },
-       { /* sentinel */ },
+       { /* sentinel */ }
 };
 
 static int r8a77990_pin_to_pocctrl(unsigned int pin, u32 *pocctrl)
 {
-       int bit = -EINVAL;
+       switch (pin) {
+       case RCAR_GP_PIN(3, 0) ... RCAR_GP_PIN(3, 11):
+               *pocctrl = pinmux_ioctrl_regs[POCCTRL0].reg;
+               return pin & 0x1f;
 
-       *pocctrl = pinmux_ioctrl_regs[POCCTRL0].reg;
+       case RCAR_GP_PIN(4, 0) ... RCAR_GP_PIN(4, 10):
+               *pocctrl = pinmux_ioctrl_regs[POCCTRL0].reg;
+               return (pin & 0x1f) + 19;
 
-       if (pin >= RCAR_GP_PIN(3, 0) && pin <= RCAR_GP_PIN(3, 11))
-               bit = pin & 0x1f;
+       case PIN_VDDQ_AVB0:
+               *pocctrl = pinmux_ioctrl_regs[POCCTRL2].reg;
+               return 0;
 
-       if (pin >= RCAR_GP_PIN(4, 0) && pin <= RCAR_GP_PIN(4, 10))
-               bit = (pin & 0x1f) + 19;
-
-       return bit;
+       default:
+               return -EINVAL;
+       }
 }
 
 static const struct pinmux_bias_reg pinmux_bias_regs[] = {
@@ -5269,7 +5278,7 @@ static const struct pinmux_bias_reg pinmux_bias_regs[] = {
                [30] = RCAR_GP_PIN(6,  9),      /* USB30_OVC */
                [31] = RCAR_GP_PIN(6, 17),      /* USB30_PWEN */
        } },
-       { /* sentinel */ },
+       { /* sentinel */ }
 };
 
 static const struct sh_pfc_soc_operations r8a77990_pfc_ops = {
index d949ae59c757924d07b13b3ed15d38d040e66b91..298e7a07e4934e67832114f67453f1d9875ab30e 100644 (file)
@@ -21,7 +21,7 @@
        PORT_GP_CFG_9(0,  fn, sfx, SH_PFC_PIN_CFG_PULL_UP_DOWN),        \
        PORT_GP_CFG_32(1, fn, sfx, SH_PFC_PIN_CFG_PULL_UP_DOWN),        \
        PORT_GP_CFG_32(2, fn, sfx, SH_PFC_PIN_CFG_PULL_UP_DOWN),        \
-       PORT_GP_CFG_10(3, fn, sfx, SH_PFC_PIN_CFG_IO_VOLTAGE | SH_PFC_PIN_CFG_PULL_UP_DOWN),    \
+       PORT_GP_CFG_10(3, fn, sfx, SH_PFC_PIN_CFG_IO_VOLTAGE_18_33 | SH_PFC_PIN_CFG_PULL_UP_DOWN),      \
        PORT_GP_CFG_32(4, fn, sfx, SH_PFC_PIN_CFG_PULL_UP_DOWN),        \
        PORT_GP_CFG_21(5, fn, sfx, SH_PFC_PIN_CFG_PULL_UP_DOWN),        \
        PORT_GP_CFG_14(6, fn, sfx, SH_PFC_PIN_CFG_PULL_UP_DOWN)
@@ -34,7 +34,8 @@
        PIN_NOGP_CFG(TCK, "TCK", fn, SH_PFC_PIN_CFG_PULL_UP),           \
        PIN_NOGP_CFG(TDI, "TDI", fn, SH_PFC_PIN_CFG_PULL_UP),           \
        PIN_NOGP_CFG(TMS, "TMS", fn, SH_PFC_PIN_CFG_PULL_UP),           \
-       PIN_NOGP_CFG(TRST_N, "TRST#", fn, SH_PFC_PIN_CFG_PULL_UP)
+       PIN_NOGP_CFG(TRST_N, "TRST#", fn, SH_PFC_PIN_CFG_PULL_UP),      \
+       PIN_NOGP_CFG(VDDQ_AVB0, "VDDQ_AVB0", fn, SH_PFC_PIN_CFG_IO_VOLTAGE_25_33)
 
 /*
  * F_() : just information
@@ -2852,19 +2853,37 @@ static const struct pinmux_cfg_reg pinmux_config_regs[] = {
                MOD_SEL1_26
                /* RESERVED 25-0 */ ))
        },
-       { },
+       { /* sentinel */ }
+};
+
+enum ioctrl_regs {
+       POCCTRL0,
+       POCCTRL2,
+       TDSELCTRL,
+};
+
+static const struct pinmux_ioctrl_reg pinmux_ioctrl_regs[] = {
+       [POCCTRL0] = { 0xe6060380, },
+       [POCCTRL2] = { 0xe6060388, },
+       [TDSELCTRL] = { 0xe60603c0, },
+       { /* sentinel */ }
 };
 
+
 static int r8a77995_pin_to_pocctrl(unsigned int pin, u32 *pocctrl)
 {
-       int bit = -EINVAL;
-
-       *pocctrl = 0xe6060380;
+       switch (pin) {
+       case RCAR_GP_PIN(3, 0) ... RCAR_GP_PIN(3, 9):
+               *pocctrl = pinmux_ioctrl_regs[POCCTRL0].reg;
+               return 29 - (pin - RCAR_GP_PIN(3, 0));
 
-       if (pin >= RCAR_GP_PIN(3, 0) && pin <= RCAR_GP_PIN(3, 9))
-               bit = 29 - (pin - RCAR_GP_PIN(3, 0));
+       case PIN_VDDQ_AVB0:
+               *pocctrl = pinmux_ioctrl_regs[POCCTRL2].reg;
+               return 0;
 
-       return bit;
+       default:
+               return -EINVAL;
+       }
 }
 
 static const struct pinmux_bias_reg pinmux_bias_regs[] = {
@@ -3075,15 +3094,6 @@ static const struct pinmux_bias_reg pinmux_bias_regs[] = {
        { /* sentinel */ }
 };
 
-enum ioctrl_regs {
-       TDSELCTRL,
-};
-
-static const struct pinmux_ioctrl_reg pinmux_ioctrl_regs[] = {
-       [TDSELCTRL] = { 0xe60603c0, },
-       { /* sentinel */ },
-};
-
 static const struct pinmux_bias_reg *
 r8a77995_pin_to_bias_reg(const struct sh_pfc *pfc, unsigned int pin,
                         unsigned int *puen_bit, unsigned int *pud_bit)
index 760c83a8740bd8b3dfd173c69b495d75743bc56e..a01bc197d70695f123118e77cfa4c480b0e6c347 100644 (file)
@@ -696,16 +696,8 @@ static const u16 pinmux_data[] = {
        PINMUX_SINGLE(PCIE0_CLKREQ_N),
 
        PINMUX_SINGLE(AVB0_PHY_INT),
-       PINMUX_SINGLE(AVB0_MAGIC),
-       PINMUX_SINGLE(AVB0_MDC),
-       PINMUX_SINGLE(AVB0_MDIO),
-       PINMUX_SINGLE(AVB0_TXCREFCLK),
 
        PINMUX_SINGLE(AVB1_PHY_INT),
-       PINMUX_SINGLE(AVB1_MAGIC),
-       PINMUX_SINGLE(AVB1_MDC),
-       PINMUX_SINGLE(AVB1_MDIO),
-       PINMUX_SINGLE(AVB1_TXCREFCLK),
 
        PINMUX_SINGLE(AVB2_AVTP_PPS),
        PINMUX_SINGLE(AVB2_AVTP_CAPTURE),
@@ -3638,7 +3630,7 @@ static const struct pinmux_cfg_reg pinmux_config_regs[] = {
                MOD_SEL2_3_2
                /* RESERVED 1-0 */ ))
        },
-       { },
+       { /* sentinel */ }
 };
 
 static const struct pinmux_drive_reg pinmux_drive_regs[] = {
@@ -3943,7 +3935,7 @@ static const struct pinmux_drive_reg pinmux_drive_regs[] = {
                { RCAR_GP_PIN(9, 17),  4, 3 },  /* AVB5_LINK */
                { RCAR_GP_PIN(9, 16),  0, 3 },  /* AVB5_PHY_INT */
        } },
-       { },
+       { /* sentinel */ }
 };
 
 enum ioctrl_regs {
@@ -3970,7 +3962,7 @@ static const struct pinmux_ioctrl_reg pinmux_ioctrl_regs[] = {
        [POC8] = { 0xe60690a0, },
        [POC9] = { 0xe60698a0, },
        [TD1SEL0] = { 0xe6058124, },
-       { /* sentinel */ },
+       { /* sentinel */ }
 };
 
 static int r8a779a0_pin_to_pocctrl(unsigned int pin, u32 *pocctrl)
@@ -4357,7 +4349,7 @@ static const struct pinmux_bias_reg pinmux_bias_regs[] = {
                [30] = SH_PFC_PIN_NONE,
                [31] = SH_PFC_PIN_NONE,
        } },
-       { /* sentinel */ },
+       { /* sentinel */ }
 };
 
 static const struct sh_pfc_soc_operations r8a779a0_pfc_ops = {
index 417c357f16b194d581afb87016ac7e531f4c7fb3..16e722a4d18fa6351fa30955817d7f0eb8bfeed2 100644 (file)
@@ -1213,7 +1213,7 @@ static const unsigned int tsn1_avtp_pps_pins[] = {
        RCAR_GP_PIN(3, 13),
 };
 static const unsigned int tsn1_avtp_pps_mux[] = {
-       TSN0_AVTP_PPS_MARK,
+       TSN1_AVTP_PPS_MARK,
 };
 static const unsigned int tsn1_avtp_capture_a_pins[] = {
        /* TSN1_AVTP_CAPTURE_A */
@@ -1784,7 +1784,7 @@ static const struct pinmux_cfg_reg pinmux_config_regs[] = {
                MOD_SEL1_3_2
                MOD_SEL1_1_0))
        },
-       { /* sentinel */ },
+       { /* sentinel */ }
 };
 
 static const struct pinmux_drive_reg pinmux_drive_regs[] = {
@@ -1896,7 +1896,7 @@ static const struct pinmux_drive_reg pinmux_drive_regs[] = {
                { RCAR_GP_PIN(3, 17),  4, 3 },  /* TSN0_AVTP_MATCH_B */
                { RCAR_GP_PIN(3, 16),  0, 3 },  /* TSN0_AVTP_PPS */
        } },
-       { /* sentinel */ },
+       { /* sentinel */ }
 };
 
 enum ioctrl_regs {
@@ -1911,7 +1911,7 @@ static const struct pinmux_ioctrl_reg pinmux_ioctrl_regs[] = {
        [POC1] = { 0xe60508a0, },
        [POC3] = { 0xe60518a0, },
        [TD0SEL1] = { 0xe6050920, },
-       { /* sentinel */ },
+       { /* sentinel */ }
 };
 
 static int r8a779f0_pin_to_pocctrl(unsigned int pin, u32 *pocctrl)
@@ -2070,7 +2070,7 @@ static const struct pinmux_bias_reg pinmux_bias_regs[] = {
                [30] = SH_PFC_PIN_NONE,
                [31] = SH_PFC_PIN_NONE,
        } },
-       { /* sentinel */ },
+       { /* sentinel */ }
 };
 
 static const struct sh_pfc_soc_operations r8a779f0_pfc_ops = {
index bf7fcce2d9c6b2a10b16fa7ff33043447af3bc76..acdea6ac152531c3851ce923b3bfdf0ed2f94c6c 100644 (file)
        PORT_GP_CFG_21(7,       fn, sfx, CFG_FLAGS),                                    \
        PORT_GP_CFG_14(8,       fn, sfx, CFG_FLAGS | SH_PFC_PIN_CFG_IO_VOLTAGE_18_33)
 
+#define CPU_ALL_NOGP(fn)                                                               \
+       PIN_NOGP_CFG(VDDQ_AVB0, "VDDQ_AVB0", fn, SH_PFC_PIN_CFG_IO_VOLTAGE_18_25),      \
+       PIN_NOGP_CFG(VDDQ_AVB1, "VDDQ_AVB1", fn, SH_PFC_PIN_CFG_IO_VOLTAGE_18_25),      \
+       PIN_NOGP_CFG(VDDQ_AVB2, "VDDQ_AVB2", fn, SH_PFC_PIN_CFG_IO_VOLTAGE_18_25),      \
+       PIN_NOGP_CFG(VDDQ_TSN0, "VDDQ_TSN0", fn, SH_PFC_PIN_CFG_IO_VOLTAGE_18_25)
+
 /* GPSR0 */
 #define GPSR0_18       F_(MSIOF2_RXD,          IP2SR0_11_8)
 #define GPSR0_17       F_(MSIOF2_SCK,          IP2SR0_7_4)
 #define GPSR3_0                F_(MMC_SD_D1,           IP0SR3_3_0)
 
 /* GPSR4 */
-#define GPSR4_24       FM(AVS1)
-#define GPSR4_23       FM(AVS0)
-#define GPSR4_22       FM(PCIE1_CLKREQ_N)
-#define GPSR4_21       FM(PCIE0_CLKREQ_N)
-#define GPSR4_20       FM(TSN0_TXCREFCLK)
-#define GPSR4_19       FM(TSN0_TD2)
-#define GPSR4_18       FM(TSN0_TD3)
-#define GPSR4_17       FM(TSN0_RD2)
-#define GPSR4_16       FM(TSN0_RD3)
-#define GPSR4_15       FM(TSN0_TD0)
-#define GPSR4_14       FM(TSN0_TD1)
-#define GPSR4_13       FM(TSN0_RD1)
-#define GPSR4_12       FM(TSN0_TXC)
-#define GPSR4_11       FM(TSN0_RXC)
-#define GPSR4_10       FM(TSN0_RD0)
-#define GPSR4_9                FM(TSN0_TX_CTL)
-#define GPSR4_8                FM(TSN0_AVTP_PPS0)
-#define GPSR4_7                FM(TSN0_RX_CTL)
-#define GPSR4_6                FM(TSN0_AVTP_CAPTURE)
-#define GPSR4_5                FM(TSN0_AVTP_MATCH)
-#define GPSR4_4                FM(TSN0_LINK)
-#define GPSR4_3                FM(TSN0_PHY_INT)
-#define GPSR4_2                FM(TSN0_AVTP_PPS1)
-#define GPSR4_1                FM(TSN0_MDC)
-#define GPSR4_0                FM(TSN0_MDIO)
+#define GPSR4_24       F_(AVS1,                IP3SR4_3_0)
+#define GPSR4_23       F_(AVS0,                IP2SR4_31_28)
+#define GPSR4_22       F_(PCIE1_CLKREQ_N,      IP2SR4_27_24)
+#define GPSR4_21       F_(PCIE0_CLKREQ_N,      IP2SR4_23_20)
+#define GPSR4_20       F_(TSN0_TXCREFCLK,      IP2SR4_19_16)
+#define GPSR4_19       F_(TSN0_TD2,            IP2SR4_15_12)
+#define GPSR4_18       F_(TSN0_TD3,            IP2SR4_11_8)
+#define GPSR4_17       F_(TSN0_RD2,            IP2SR4_7_4)
+#define GPSR4_16       F_(TSN0_RD3,            IP2SR4_3_0)
+#define GPSR4_15       F_(TSN0_TD0,            IP1SR4_31_28)
+#define GPSR4_14       F_(TSN0_TD1,            IP1SR4_27_24)
+#define GPSR4_13       F_(TSN0_RD1,            IP1SR4_23_20)
+#define GPSR4_12       F_(TSN0_TXC,            IP1SR4_19_16)
+#define GPSR4_11       F_(TSN0_RXC,            IP1SR4_15_12)
+#define GPSR4_10       F_(TSN0_RD0,            IP1SR4_11_8)
+#define GPSR4_9                F_(TSN0_TX_CTL,         IP1SR4_7_4)
+#define GPSR4_8                F_(TSN0_AVTP_PPS0,      IP1SR4_3_0)
+#define GPSR4_7                F_(TSN0_RX_CTL,         IP0SR4_31_28)
+#define GPSR4_6                F_(TSN0_AVTP_CAPTURE,   IP0SR4_27_24)
+#define GPSR4_5                F_(TSN0_AVTP_MATCH,     IP0SR4_23_20)
+#define GPSR4_4                F_(TSN0_LINK,           IP0SR4_19_16)
+#define GPSR4_3                F_(TSN0_PHY_INT,        IP0SR4_15_12)
+#define GPSR4_2                F_(TSN0_AVTP_PPS1,      IP0SR4_11_8)
+#define GPSR4_1                F_(TSN0_MDC,            IP0SR4_7_4)
+#define GPSR4_0                F_(TSN0_MDIO,           IP0SR4_3_0)
 
 /* GPSR 5 */
-#define GPSR5_20       FM(AVB2_RX_CTL)
-#define GPSR5_19       FM(AVB2_TX_CTL)
-#define GPSR5_18       FM(AVB2_RXC)
-#define GPSR5_17       FM(AVB2_RD0)
-#define GPSR5_16       FM(AVB2_TXC)
-#define GPSR5_15       FM(AVB2_TD0)
-#define GPSR5_14       FM(AVB2_RD1)
-#define GPSR5_13       FM(AVB2_RD2)
-#define GPSR5_12       FM(AVB2_TD1)
-#define GPSR5_11       FM(AVB2_TD2)
-#define GPSR5_10       FM(AVB2_MDIO)
-#define GPSR5_9                FM(AVB2_RD3)
-#define GPSR5_8                FM(AVB2_TD3)
-#define GPSR5_7                FM(AVB2_TXCREFCLK)
-#define GPSR5_6                FM(AVB2_MDC)
-#define GPSR5_5                FM(AVB2_MAGIC)
-#define GPSR5_4                FM(AVB2_PHY_INT)
-#define GPSR5_3                FM(AVB2_LINK)
-#define GPSR5_2                FM(AVB2_AVTP_MATCH)
-#define GPSR5_1                FM(AVB2_AVTP_CAPTURE)
-#define GPSR5_0                FM(AVB2_AVTP_PPS)
+#define GPSR5_20       F_(AVB2_RX_CTL,         IP2SR5_19_16)
+#define GPSR5_19       F_(AVB2_TX_CTL,         IP2SR5_15_12)
+#define GPSR5_18       F_(AVB2_RXC,            IP2SR5_11_8)
+#define GPSR5_17       F_(AVB2_RD0,            IP2SR5_7_4)
+#define GPSR5_16       F_(AVB2_TXC,            IP2SR5_3_0)
+#define GPSR5_15       F_(AVB2_TD0,            IP1SR5_31_28)
+#define GPSR5_14       F_(AVB2_RD1,            IP1SR5_27_24)
+#define GPSR5_13       F_(AVB2_RD2,            IP1SR5_23_20)
+#define GPSR5_12       F_(AVB2_TD1,            IP1SR5_19_16)
+#define GPSR5_11       F_(AVB2_TD2,            IP1SR5_15_12)
+#define GPSR5_10       F_(AVB2_MDIO,           IP1SR5_11_8)
+#define GPSR5_9                F_(AVB2_RD3,            IP1SR5_7_4)
+#define GPSR5_8                F_(AVB2_TD3,            IP1SR5_3_0)
+#define GPSR5_7                F_(AVB2_TXCREFCLK,      IP0SR5_31_28)
+#define GPSR5_6                F_(AVB2_MDC,            IP0SR5_27_24)
+#define GPSR5_5                F_(AVB2_MAGIC,          IP0SR5_23_20)
+#define GPSR5_4                F_(AVB2_PHY_INT,        IP0SR5_19_16)
+#define GPSR5_3                F_(AVB2_LINK,           IP0SR5_15_12)
+#define GPSR5_2                F_(AVB2_AVTP_MATCH,     IP0SR5_11_8)
+#define GPSR5_1                F_(AVB2_AVTP_CAPTURE,   IP0SR5_7_4)
+#define GPSR5_0                F_(AVB2_AVTP_PPS,       IP0SR5_3_0)
 
 /* GPSR 6 */
 #define GPSR6_20       F_(AVB1_TXCREFCLK,      IP2SR6_19_16)
 #define GPSR8_0                F_(SCL0,                IP0SR8_3_0)
 
 /* SR0 */
-/* IP0SR0 */           /* 0 */                 /* 1 */                 /* 2 */         /* 3            4        5        6        7        8        9        A        B        C        D        E        F */
-#define IP0SR0_3_0     F_(0, 0)                FM(ERROROUTC_B)         FM(TCLK2_A)     F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
-#define IP0SR0_7_4     F_(0, 0)                FM(MSIOF3_SS1)          F_(0, 0)        F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
-#define IP0SR0_11_8    F_(0, 0)                FM(MSIOF3_SS2)          F_(0, 0)        F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
-#define IP0SR0_15_12   FM(IRQ3)                FM(MSIOF3_SCK)          F_(0, 0)        F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
-#define IP0SR0_19_16   FM(IRQ2)                FM(MSIOF3_TXD)          F_(0, 0)        F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
-#define IP0SR0_23_20   FM(IRQ1)                FM(MSIOF3_RXD)          F_(0, 0)        F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
-#define IP0SR0_27_24   FM(IRQ0)                FM(MSIOF3_SYNC)         F_(0, 0)        F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
-#define IP0SR0_31_28   FM(MSIOF5_SS2)          F_(0, 0)                F_(0, 0)        F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
-
-/* IP1SR0 */           /* 0 */                 /* 1 */                 /* 2 */         /* 3            4        5        6        7        8        9        A        B        C        D        E        F */
-#define IP1SR0_3_0     FM(MSIOF5_SS1)          F_(0, 0)                F_(0, 0)        F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
-#define IP1SR0_7_4     FM(MSIOF5_SYNC)         F_(0, 0)                F_(0, 0)        F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
-#define IP1SR0_11_8    FM(MSIOF5_TXD)          F_(0, 0)                F_(0, 0)        F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
-#define IP1SR0_15_12   FM(MSIOF5_SCK)          F_(0, 0)                F_(0, 0)        F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
-#define IP1SR0_19_16   FM(MSIOF5_RXD)          F_(0, 0)                F_(0, 0)        F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
-#define IP1SR0_23_20   FM(MSIOF2_SS2)          FM(TCLK1)               FM(IRQ2_A)      F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
-#define IP1SR0_27_24   FM(MSIOF2_SS1)          FM(HTX1)                FM(TX1)         F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
-#define IP1SR0_31_28   FM(MSIOF2_SYNC)         FM(HRX1)                FM(RX1)         F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
-
-/* IP2SR0 */           /* 0 */                 /* 1 */                 /* 2 */         /* 3            4        5        6        7        8        9        A        B        C        D        E        F */
-#define IP2SR0_3_0     FM(MSIOF2_TXD)          FM(HCTS1_N)             FM(CTS1_N)      F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
-#define IP2SR0_7_4     FM(MSIOF2_SCK)          FM(HRTS1_N)             FM(RTS1_N)      F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
-#define IP2SR0_11_8    FM(MSIOF2_RXD)          FM(HSCK1)               FM(SCK1)        F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+/* IP0SR0 */           /* 0 */                 /* 1 */                 /* 2 */                 /* 3            4        5        6        7        8        9        A        B        C        D        E        F */
+#define IP0SR0_3_0     F_(0, 0)                FM(ERROROUTC_N_B)       FM(TCLK2_A)             F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define IP0SR0_7_4     F_(0, 0)                FM(MSIOF3_SS1)          F_(0, 0)                F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define IP0SR0_11_8    F_(0, 0)                FM(MSIOF3_SS2)          F_(0, 0)                F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define IP0SR0_15_12   FM(IRQ3)                FM(MSIOF3_SCK)          F_(0, 0)                F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define IP0SR0_19_16   FM(IRQ2)                FM(MSIOF3_TXD)          F_(0, 0)                F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define IP0SR0_23_20   FM(IRQ1)                FM(MSIOF3_RXD)          F_(0, 0)                F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define IP0SR0_27_24   FM(IRQ0)                FM(MSIOF3_SYNC)         F_(0, 0)                F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define IP0SR0_31_28   FM(MSIOF5_SS2)          F_(0, 0)                F_(0, 0)                F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+
+/* IP1SR0 */           /* 0 */                 /* 1 */                 /* 2 */                 /* 3            4        5        6        7        8        9        A        B        C        D        E        F */
+#define IP1SR0_3_0     FM(MSIOF5_SS1)          F_(0, 0)                F_(0, 0)                F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define IP1SR0_7_4     FM(MSIOF5_SYNC)         F_(0, 0)                F_(0, 0)                F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define IP1SR0_11_8    FM(MSIOF5_TXD)          F_(0, 0)                F_(0, 0)                F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define IP1SR0_15_12   FM(MSIOF5_SCK)          F_(0, 0)                F_(0, 0)                F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define IP1SR0_19_16   FM(MSIOF5_RXD)          F_(0, 0)                F_(0, 0)                F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define IP1SR0_23_20   FM(MSIOF2_SS2)          FM(TCLK1)               FM(IRQ2_A)              F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define IP1SR0_27_24   FM(MSIOF2_SS1)          FM(HTX1)                FM(TX1)                 F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define IP1SR0_31_28   FM(MSIOF2_SYNC)         FM(HRX1)                FM(RX1)                 F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+
+/* IP2SR0 */           /* 0 */                 /* 1 */                 /* 2 */                 /* 3            4        5        6        7        8        9        A        B        C        D        E        F */
+#define IP2SR0_3_0     FM(MSIOF2_TXD)          FM(HCTS1_N)             FM(CTS1_N)              F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define IP2SR0_7_4     FM(MSIOF2_SCK)          FM(HRTS1_N)             FM(RTS1_N)              F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define IP2SR0_11_8    FM(MSIOF2_RXD)          FM(HSCK1)               FM(SCK1)                F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
 
 /* SR1 */
-/* IP0SR1 */           /* 0 */                 /* 1 */                 /* 2 */         /* 3            4        5        6        7        8        9        A        B        C        D        E        F */
-#define IP0SR1_3_0     FM(MSIOF1_SS2)          FM(HTX3_A)              FM(TX3)         F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
-#define IP0SR1_7_4     FM(MSIOF1_SS1)          FM(HCTS3_N_A)           FM(RX3)         F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
-#define IP0SR1_11_8    FM(MSIOF1_SYNC)         FM(HRTS3_N_A)           FM(RTS3_N)      F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
-#define IP0SR1_15_12   FM(MSIOF1_SCK)          FM(HSCK3_A)             FM(CTS3_N)      F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
-#define IP0SR1_19_16   FM(MSIOF1_TXD)          FM(HRX3_A)              FM(SCK3)        F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
-#define IP0SR1_23_20   FM(MSIOF1_RXD)          F_(0, 0)                F_(0, 0)        F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
-#define IP0SR1_27_24   FM(MSIOF0_SS2)          FM(HTX1_X)              FM(TX1_X)       F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
-#define IP0SR1_31_28   FM(MSIOF0_SS1)          FM(HRX1_X)              FM(RX1_X)       F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
-
-/* IP1SR1 */           /* 0 */                 /* 1 */                 /* 2 */         /* 3            4        5        6        7        8        9        A        B        C        D        E        F */
-#define IP1SR1_3_0     FM(MSIOF0_SYNC)         FM(HCTS1_N_X)           FM(CTS1_N_X)    FM(CANFD5_TX_B) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
-#define IP1SR1_7_4     FM(MSIOF0_TXD)          FM(HRTS1_N_X)           FM(RTS1_N_X)    FM(CANFD5_RX_B) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
-#define IP1SR1_11_8    FM(MSIOF0_SCK)          FM(HSCK1_X)             FM(SCK1_X)      F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
-#define IP1SR1_15_12   FM(MSIOF0_RXD)          F_(0, 0)                F_(0, 0)        F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
-#define IP1SR1_19_16   FM(HTX0)                FM(TX0)                 F_(0, 0)        F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
-#define IP1SR1_23_20   FM(HCTS0_N)             FM(CTS0_N)              FM(PWM8_A)      F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
-#define IP1SR1_27_24   FM(HRTS0_N)             FM(RTS0_N)              FM(PWM9_A)      F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
-#define IP1SR1_31_28   FM(HSCK0)               FM(SCK0)                FM(PWM0_A)      F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
-
-/* IP2SR1 */           /* 0 */                 /* 1 */                 /* 2 */         /* 3            4        5        6        7        8        9        A        B        C        D        E        F */
-#define IP2SR1_3_0     FM(HRX0)                FM(RX0)                 F_(0, 0)        F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
-#define IP2SR1_7_4     FM(SCIF_CLK)            FM(IRQ4_A)              F_(0, 0)        F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
-#define IP2SR1_11_8    FM(SSI_SCK)             FM(TCLK3)               F_(0, 0)        F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
-#define IP2SR1_15_12   FM(SSI_WS)              FM(TCLK4)               F_(0, 0)        F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
-#define IP2SR1_19_16   FM(SSI_SD)              FM(IRQ0_A)              F_(0, 0)        F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
-#define IP2SR1_23_20   FM(AUDIO_CLKOUT)        FM(IRQ1_A)              F_(0, 0)        F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
-#define IP2SR1_27_24   FM(AUDIO_CLKIN)         FM(PWM3_A)              F_(0, 0)        F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
-#define IP2SR1_31_28   F_(0, 0)                FM(TCLK2)               FM(MSIOF4_SS1)  FM(IRQ3_B)      F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
-
-/* IP3SR1 */           /* 0 */                 /* 1 */                 /* 2 */         /* 3            4        5        6        7        8        9        A        B        C        D        E        F */
-#define IP3SR1_3_0     FM(HRX3)                FM(SCK3_A)              FM(MSIOF4_SS2)  F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
-#define IP3SR1_7_4     FM(HSCK3)               FM(CTS3_N_A)            FM(MSIOF4_SCK)  FM(TPU0TO0_A)   F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
-#define IP3SR1_11_8    FM(HRTS3_N)             FM(RTS3_N_A)            FM(MSIOF4_TXD)  FM(TPU0TO1_A)   F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
-#define IP3SR1_15_12   FM(HCTS3_N)             FM(RX3_A)               FM(MSIOF4_RXD)  F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
-#define IP3SR1_19_16   FM(HTX3)                FM(TX3_A)               FM(MSIOF4_SYNC) F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+/* IP0SR1 */           /* 0 */                 /* 1 */                 /* 2 */                 /* 3            4        5        6        7        8        9        A        B        C        D        E        F */
+#define IP0SR1_3_0     FM(MSIOF1_SS2)          FM(HTX3_A)              FM(TX3)                 F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define IP0SR1_7_4     FM(MSIOF1_SS1)          FM(HCTS3_N_A)           FM(RX3)                 F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define IP0SR1_11_8    FM(MSIOF1_SYNC)         FM(HRTS3_N_A)           FM(RTS3_N)              F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define IP0SR1_15_12   FM(MSIOF1_SCK)          FM(HSCK3_A)             FM(CTS3_N)              F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define IP0SR1_19_16   FM(MSIOF1_TXD)          FM(HRX3_A)              FM(SCK3)                F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define IP0SR1_23_20   FM(MSIOF1_RXD)          F_(0, 0)                F_(0, 0)                F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define IP0SR1_27_24   FM(MSIOF0_SS2)          FM(HTX1_X)              FM(TX1_X)               F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define IP0SR1_31_28   FM(MSIOF0_SS1)          FM(HRX1_X)              FM(RX1_X)               F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+
+/* IP1SR1 */           /* 0 */                 /* 1 */                 /* 2 */                 /* 3            4        5        6        7        8        9        A        B        C        D        E        F */
+#define IP1SR1_3_0     FM(MSIOF0_SYNC)         FM(HCTS1_N_X)           FM(CTS1_N_X)            FM(CANFD5_TX_B) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define IP1SR1_7_4     FM(MSIOF0_TXD)          FM(HRTS1_N_X)           FM(RTS1_N_X)            FM(CANFD5_RX_B) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define IP1SR1_11_8    FM(MSIOF0_SCK)          FM(HSCK1_X)             FM(SCK1_X)              F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define IP1SR1_15_12   FM(MSIOF0_RXD)          F_(0, 0)                F_(0, 0)                F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define IP1SR1_19_16   FM(HTX0)                FM(TX0)                 F_(0, 0)                F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define IP1SR1_23_20   FM(HCTS0_N)             FM(CTS0_N)              FM(PWM8_A)              F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define IP1SR1_27_24   FM(HRTS0_N)             FM(RTS0_N)              FM(PWM9_A)              F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define IP1SR1_31_28   FM(HSCK0)               FM(SCK0)                FM(PWM0_A)              F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+
+/* IP2SR1 */           /* 0 */                 /* 1 */                 /* 2 */                 /* 3            4        5        6        7        8        9        A        B        C        D        E        F */
+#define IP2SR1_3_0     FM(HRX0)                FM(RX0)                 F_(0, 0)                F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define IP2SR1_7_4     FM(SCIF_CLK)            FM(IRQ4_A)              F_(0, 0)                F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define IP2SR1_11_8    FM(SSI_SCK)             FM(TCLK3)               F_(0, 0)                F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define IP2SR1_15_12   FM(SSI_WS)              FM(TCLK4)               F_(0, 0)                F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define IP2SR1_19_16   FM(SSI_SD)              FM(IRQ0_A)              F_(0, 0)                F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define IP2SR1_23_20   FM(AUDIO_CLKOUT)        FM(IRQ1_A)              F_(0, 0)                F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define IP2SR1_27_24   FM(AUDIO_CLKIN)         FM(PWM3_A)              F_(0, 0)                F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define IP2SR1_31_28   F_(0, 0)                FM(TCLK2)               FM(MSIOF4_SS1)          FM(IRQ3_B)      F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+
+/* IP3SR1 */           /* 0 */                 /* 1 */                 /* 2 */                 /* 3            4        5        6        7        8        9        A        B        C        D        E        F */
+#define IP3SR1_3_0     FM(HRX3)                FM(SCK3_A)              FM(MSIOF4_SS2)          F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define IP3SR1_7_4     FM(HSCK3)               FM(CTS3_N_A)            FM(MSIOF4_SCK)          FM(TPU0TO0_A)   F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define IP3SR1_11_8    FM(HRTS3_N)             FM(RTS3_N_A)            FM(MSIOF4_TXD)          FM(TPU0TO1_A)   F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define IP3SR1_15_12   FM(HCTS3_N)             FM(RX3_A)               FM(MSIOF4_RXD)          F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define IP3SR1_19_16   FM(HTX3)                FM(TX3_A)               FM(MSIOF4_SYNC)         F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
 
 /* SR2 */
-/* IP0SR2 */           /* 0 */                 /* 1 */                 /* 2 */         /* 3            4        5        6        7        8        9        A        B        C        D        E        F */
-#define IP0SR2_3_0     FM(FXR_TXDA)            FM(CANFD1_TX)           FM(TPU0TO2_A)   F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
-#define IP0SR2_7_4     FM(FXR_TXENA_N)         FM(CANFD1_RX)           FM(TPU0TO3_A)   F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
-#define IP0SR2_11_8    FM(RXDA_EXTFXR)         FM(CANFD5_TX)           FM(IRQ5)        F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
-#define IP0SR2_15_12   FM(CLK_EXTFXR)          FM(CANFD5_RX)           FM(IRQ4_B)      F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
-#define IP0SR2_19_16   FM(RXDB_EXTFXR)         F_(0, 0)                F_(0, 0)        F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
-#define IP0SR2_23_20   FM(FXR_TXENB_N)         F_(0, 0)                F_(0, 0)        F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
-#define IP0SR2_27_24   FM(FXR_TXDB)            F_(0, 0)                F_(0, 0)        F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
-#define IP0SR2_31_28   FM(TPU0TO1)             FM(CANFD6_TX)           F_(0, 0)        FM(TCLK2_B)     F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
-
-/* IP1SR2 */           /* 0 */                 /* 1 */                 /* 2 */         /* 3            4        5        6        7        8        9        A        B        C        D        E        F */
-#define IP1SR2_3_0     FM(TPU0TO0)             FM(CANFD6_RX)           F_(0, 0)        FM(TCLK1_A)     F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
-#define IP1SR2_7_4     FM(CAN_CLK)             FM(FXR_TXENA_N_X)       F_(0, 0)        F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
-#define IP1SR2_11_8    FM(CANFD0_TX)           FM(FXR_TXENB_N_X)       F_(0, 0)        F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
-#define IP1SR2_15_12   FM(CANFD0_RX)           FM(STPWT_EXTFXR)        F_(0, 0)        F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
-#define IP1SR2_19_16   FM(CANFD2_TX)           FM(TPU0TO2)             F_(0, 0)        FM(TCLK3_A)     F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
-#define IP1SR2_23_20   FM(CANFD2_RX)           FM(TPU0TO3)             FM(PWM1_B)      FM(TCLK4_A)     F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
-#define IP1SR2_27_24   FM(CANFD3_TX)           F_(0, 0)                FM(PWM2_B)      F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
-#define IP1SR2_31_28   FM(CANFD3_RX)           F_(0, 0)                FM(PWM3_B)      F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
-
-/* IP2SR2 */           /* 0 */                 /* 1 */                 /* 2 */         /* 3            4        5        6        7        8        9        A        B        C        D        E        F */
-#define IP2SR2_3_0     FM(CANFD4_TX)           F_(0, 0)                FM(PWM4)        F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
-#define IP2SR2_7_4     FM(CANFD4_RX)           F_(0, 0)                FM(PWM5)        F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
-#define IP2SR2_11_8    FM(CANFD7_TX)           F_(0, 0)                FM(PWM6)        F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
-#define IP2SR2_15_12   FM(CANFD7_RX)           F_(0, 0)                FM(PWM7)        F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+/* IP0SR2 */           /* 0 */                 /* 1 */                 /* 2 */                 /* 3            4        5        6        7        8        9        A        B        C        D        E        F */
+#define IP0SR2_3_0     FM(FXR_TXDA)            FM(CANFD1_TX)           FM(TPU0TO2_A)           F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define IP0SR2_7_4     FM(FXR_TXENA_N)         FM(CANFD1_RX)           FM(TPU0TO3_A)           F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define IP0SR2_11_8    FM(RXDA_EXTFXR)         FM(CANFD5_TX)           FM(IRQ5)                F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define IP0SR2_15_12   FM(CLK_EXTFXR)          FM(CANFD5_RX)           FM(IRQ4_B)              F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define IP0SR2_19_16   FM(RXDB_EXTFXR)         F_(0, 0)                F_(0, 0)                F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define IP0SR2_23_20   FM(FXR_TXENB_N)         F_(0, 0)                F_(0, 0)                F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define IP0SR2_27_24   FM(FXR_TXDB)            F_(0, 0)                F_(0, 0)                F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define IP0SR2_31_28   FM(TPU0TO1)             FM(CANFD6_TX)           F_(0, 0)                FM(TCLK2_B)     F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+
+/* IP1SR2 */           /* 0 */                 /* 1 */                 /* 2 */                 /* 3            4        5        6        7        8        9        A        B        C        D        E        F */
+#define IP1SR2_3_0     FM(TPU0TO0)             FM(CANFD6_RX)           F_(0, 0)                FM(TCLK1_A)     F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define IP1SR2_7_4     FM(CAN_CLK)             FM(FXR_TXENA_N_X)       F_(0, 0)                F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define IP1SR2_11_8    FM(CANFD0_TX)           FM(FXR_TXENB_N_X)       F_(0, 0)                F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define IP1SR2_15_12   FM(CANFD0_RX)           FM(STPWT_EXTFXR)        F_(0, 0)                F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define IP1SR2_19_16   FM(CANFD2_TX)           FM(TPU0TO2)             F_(0, 0)                FM(TCLK3_A)     F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define IP1SR2_23_20   FM(CANFD2_RX)           FM(TPU0TO3)             FM(PWM1_B)              FM(TCLK4_A)     F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define IP1SR2_27_24   FM(CANFD3_TX)           F_(0, 0)                FM(PWM2_B)              F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define IP1SR2_31_28   FM(CANFD3_RX)           F_(0, 0)                FM(PWM3_B)              F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+
+/* IP2SR2 */           /* 0 */                 /* 1 */                 /* 2 */                 /* 3            4        5        6        7        8        9        A        B        C        D        E        F */
+#define IP2SR2_3_0     FM(CANFD4_TX)           F_(0, 0)                FM(PWM4)                F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define IP2SR2_7_4     FM(CANFD4_RX)           F_(0, 0)                FM(PWM5)                F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define IP2SR2_11_8    FM(CANFD7_TX)           F_(0, 0)                FM(PWM6)                F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define IP2SR2_15_12   FM(CANFD7_RX)           F_(0, 0)                FM(PWM7)                F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
 
 /* SR3 */
-/* IP0SR3 */           /* 0 */                 /* 1 */                 /* 2 */         /* 3            4        5        6        7        8        9        A        B        C        D        E        F */
-#define IP0SR3_3_0     FM(MMC_SD_D1)           F_(0, 0)                F_(0, 0)        F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
-#define IP0SR3_7_4     FM(MMC_SD_D0)           F_(0, 0)                F_(0, 0)        F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
-#define IP0SR3_11_8    FM(MMC_SD_D2)           F_(0, 0)                F_(0, 0)        F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
-#define IP0SR3_15_12   FM(MMC_SD_CLK)          F_(0, 0)                F_(0, 0)        F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
-#define IP0SR3_19_16   FM(MMC_DS)              F_(0, 0)                F_(0, 0)        F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
-#define IP0SR3_23_20   FM(MMC_SD_D3)           F_(0, 0)                F_(0, 0)        F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
-#define IP0SR3_27_24   FM(MMC_D5)              F_(0, 0)                F_(0, 0)        F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
-#define IP0SR3_31_28   FM(MMC_D4)              F_(0, 0)                F_(0, 0)        F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
-
-/* IP1SR3 */           /* 0 */                 /* 1 */                 /* 2 */         /* 3            4        5        6        7        8        9        A        B        C        D        E        F */
-#define IP1SR3_3_0     FM(MMC_D7)              F_(0, 0)                F_(0, 0)        F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
-#define IP1SR3_7_4     FM(MMC_D6)              F_(0, 0)                F_(0, 0)        F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
-#define IP1SR3_11_8    FM(MMC_SD_CMD)          F_(0, 0)                F_(0, 0)        F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
-#define IP1SR3_15_12   FM(SD_CD)               F_(0, 0)                F_(0, 0)        F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
-#define IP1SR3_19_16   FM(SD_WP)               F_(0, 0)                F_(0, 0)        F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
-#define IP1SR3_23_20   FM(IPC_CLKIN)           FM(IPC_CLKEN_IN)        FM(PWM1_A)      FM(TCLK3_X)     F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
-#define IP1SR3_27_24   FM(IPC_CLKOUT)          FM(IPC_CLKEN_OUT)       FM(ERROROUTC_A) FM(TCLK4_X)     F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
-#define IP1SR3_31_28   FM(QSPI0_SSL)           F_(0, 0)                F_(0, 0)        F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
-
-/* IP2SR3 */           /* 0 */                 /* 1 */                 /* 2 */         /* 3            4        5        6        7        8        9        A        B        C        D        E        F */
-#define IP2SR3_3_0     FM(QSPI0_IO3)           F_(0, 0)                F_(0, 0)        F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
-#define IP2SR3_7_4     FM(QSPI0_IO2)           F_(0, 0)                F_(0, 0)        F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
-#define IP2SR3_11_8    FM(QSPI0_MISO_IO1)      F_(0, 0)                F_(0, 0)        F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
-#define IP2SR3_15_12   FM(QSPI0_MOSI_IO0)      F_(0, 0)                F_(0, 0)        F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
-#define IP2SR3_19_16   FM(QSPI0_SPCLK)         F_(0, 0)                F_(0, 0)        F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
-#define IP2SR3_23_20   FM(QSPI1_MOSI_IO0)      F_(0, 0)                F_(0, 0)        F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
-#define IP2SR3_27_24   FM(QSPI1_SPCLK)         F_(0, 0)                F_(0, 0)        F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
-#define IP2SR3_31_28   FM(QSPI1_MISO_IO1)      F_(0, 0)                F_(0, 0)        F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
-
-/* IP3SR3 */           /* 0 */                 /* 1 */                 /* 2 */         /* 3            4        5        6        7        8        9        A        B        C        D        E        F */
-#define IP3SR3_3_0     FM(QSPI1_IO2)           F_(0, 0)                F_(0, 0)        F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
-#define IP3SR3_7_4     FM(QSPI1_SSL)           F_(0, 0)                F_(0, 0)        F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
-#define IP3SR3_11_8    FM(QSPI1_IO3)           F_(0, 0)                F_(0, 0)        F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
-#define IP3SR3_15_12   FM(RPC_RESET_N)         F_(0, 0)                F_(0, 0)        F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
-#define IP3SR3_19_16   FM(RPC_WP_N)            F_(0, 0)                F_(0, 0)        F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
-#define IP3SR3_23_20   FM(RPC_INT_N)           F_(0, 0)                F_(0, 0)        F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+/* IP0SR3 */           /* 0 */                 /* 1 */                 /* 2 */                 /* 3            4        5        6        7        8        9        A        B        C        D        E        F */
+#define IP0SR3_3_0     FM(MMC_SD_D1)           F_(0, 0)                F_(0, 0)                F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define IP0SR3_7_4     FM(MMC_SD_D0)           F_(0, 0)                F_(0, 0)                F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define IP0SR3_11_8    FM(MMC_SD_D2)           F_(0, 0)                F_(0, 0)                F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define IP0SR3_15_12   FM(MMC_SD_CLK)          F_(0, 0)                F_(0, 0)                F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define IP0SR3_19_16   FM(MMC_DS)              F_(0, 0)                F_(0, 0)                F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define IP0SR3_23_20   FM(MMC_SD_D3)           F_(0, 0)                F_(0, 0)                F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define IP0SR3_27_24   FM(MMC_D5)              F_(0, 0)                F_(0, 0)                F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define IP0SR3_31_28   FM(MMC_D4)              F_(0, 0)                F_(0, 0)                F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+
+/* IP1SR3 */           /* 0 */                 /* 1 */                 /* 2 */                 /* 3            4        5        6        7        8        9        A        B        C        D        E        F */
+#define IP1SR3_3_0     FM(MMC_D7)              F_(0, 0)                F_(0, 0)                F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define IP1SR3_7_4     FM(MMC_D6)              F_(0, 0)                F_(0, 0)                F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define IP1SR3_11_8    FM(MMC_SD_CMD)          F_(0, 0)                F_(0, 0)                F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define IP1SR3_15_12   FM(SD_CD)               F_(0, 0)                F_(0, 0)                F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define IP1SR3_19_16   FM(SD_WP)               F_(0, 0)                F_(0, 0)                F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define IP1SR3_23_20   FM(IPC_CLKIN)           FM(IPC_CLKEN_IN)        FM(PWM1_A)              FM(TCLK3_X)     F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define IP1SR3_27_24   FM(IPC_CLKOUT)          FM(IPC_CLKEN_OUT)       FM(ERROROUTC_N_A)       FM(TCLK4_X)     F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define IP1SR3_31_28   FM(QSPI0_SSL)           F_(0, 0)                F_(0, 0)                F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+
+/* IP2SR3 */           /* 0 */                 /* 1 */                 /* 2 */                 /* 3            4        5        6        7        8        9        A        B        C        D        E        F */
+#define IP2SR3_3_0     FM(QSPI0_IO3)           F_(0, 0)                F_(0, 0)                F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define IP2SR3_7_4     FM(QSPI0_IO2)           F_(0, 0)                F_(0, 0)                F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define IP2SR3_11_8    FM(QSPI0_MISO_IO1)      F_(0, 0)                F_(0, 0)                F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define IP2SR3_15_12   FM(QSPI0_MOSI_IO0)      F_(0, 0)                F_(0, 0)                F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define IP2SR3_19_16   FM(QSPI0_SPCLK)         F_(0, 0)                F_(0, 0)                F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define IP2SR3_23_20   FM(QSPI1_MOSI_IO0)      F_(0, 0)                F_(0, 0)                F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define IP2SR3_27_24   FM(QSPI1_SPCLK)         F_(0, 0)                F_(0, 0)                F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define IP2SR3_31_28   FM(QSPI1_MISO_IO1)      F_(0, 0)                F_(0, 0)                F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+
+/* IP3SR3 */           /* 0 */                 /* 1 */                 /* 2 */                 /* 3            4        5        6        7        8        9        A        B        C        D        E        F */
+#define IP3SR3_3_0     FM(QSPI1_IO2)           F_(0, 0)                F_(0, 0)                F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define IP3SR3_7_4     FM(QSPI1_SSL)           F_(0, 0)                F_(0, 0)                F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define IP3SR3_11_8    FM(QSPI1_IO3)           F_(0, 0)                F_(0, 0)                F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define IP3SR3_15_12   FM(RPC_RESET_N)         F_(0, 0)                F_(0, 0)                F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define IP3SR3_19_16   FM(RPC_WP_N)            F_(0, 0)                F_(0, 0)                F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define IP3SR3_23_20   FM(RPC_INT_N)           F_(0, 0)                F_(0, 0)                F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+
+/* SR4 */
+/* IP0SR4 */           /* 0 */                 /* 1 */                 /* 2 */                 /* 3            4        5        6        7        8        9        A        B        C        D        E        F */
+#define IP0SR4_3_0     FM(TSN0_MDIO)           F_(0, 0)                F_(0, 0)                F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define IP0SR4_7_4     FM(TSN0_MDC)            F_(0, 0)                F_(0, 0)                F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define IP0SR4_11_8    FM(TSN0_AVTP_PPS1)      F_(0, 0)                F_(0, 0)                F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define IP0SR4_15_12   FM(TSN0_PHY_INT)        F_(0, 0)                F_(0, 0)                F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define IP0SR4_19_16   FM(TSN0_LINK)           F_(0, 0)                F_(0, 0)                F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define IP0SR4_23_20   FM(TSN0_AVTP_MATCH)     F_(0, 0)                F_(0, 0)                F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define IP0SR4_27_24   FM(TSN0_AVTP_CAPTURE)   F_(0, 0)                F_(0, 0)                F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define IP0SR4_31_28   FM(TSN0_RX_CTL)         F_(0, 0)                F_(0, 0)                F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+
+/* IP1SR4 */           /* 0 */                 /* 1 */                 /* 2 */                 /* 3            4        5        6        7        8        9        A        B        C        D        E        F */
+#define IP1SR4_3_0     FM(TSN0_AVTP_PPS0)      F_(0, 0)                F_(0, 0)                F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define IP1SR4_7_4     FM(TSN0_TX_CTL)         F_(0, 0)                F_(0, 0)                F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define IP1SR4_11_8    FM(TSN0_RD0)            F_(0, 0)                F_(0, 0)                F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define IP1SR4_15_12   FM(TSN0_RXC)            F_(0, 0)                F_(0, 0)                F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define IP1SR4_19_16   FM(TSN0_TXC)            F_(0, 0)                F_(0, 0)                F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define IP1SR4_23_20   FM(TSN0_RD1)            F_(0, 0)                F_(0, 0)                F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define IP1SR4_27_24   FM(TSN0_TD1)            F_(0, 0)                F_(0, 0)                F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define IP1SR4_31_28   FM(TSN0_TD0)            F_(0, 0)                F_(0, 0)                F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+
+/* IP2SR4 */           /* 0 */                 /* 1 */                 /* 2 */                 /* 3            4        5        6        7        8        9        A        B        C        D        E        F */
+#define IP2SR4_3_0     FM(TSN0_RD3)            F_(0, 0)                F_(0, 0)                F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define IP2SR4_7_4     FM(TSN0_RD2)            F_(0, 0)                F_(0, 0)                F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define IP2SR4_11_8    FM(TSN0_TD3)            F_(0, 0)                F_(0, 0)                F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define IP2SR4_15_12   FM(TSN0_TD2)            F_(0, 0)                F_(0, 0)                F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define IP2SR4_19_16   FM(TSN0_TXCREFCLK)      F_(0, 0)                F_(0, 0)                F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define IP2SR4_23_20   FM(PCIE0_CLKREQ_N)      F_(0, 0)                F_(0, 0)                F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define IP2SR4_27_24   FM(PCIE1_CLKREQ_N)      F_(0, 0)                F_(0, 0)                F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define IP2SR4_31_28   FM(AVS0)                F_(0, 0)                F_(0, 0)                F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+
+/* IP3SR4 */           /* 0 */                 /* 1 */                 /* 2 */                 /* 3            4        5        6        7        8        9        A        B        C        D        E        F */
+#define IP3SR4_3_0     FM(AVS1)                F_(0, 0)                F_(0, 0)                F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+
+/* SR5 */
+/* IP0SR5 */           /* 0 */                 /* 1 */                 /* 2 */                 /* 3            4        5        6        7        8        9        A        B        C        D        E        F */
+#define IP0SR5_3_0     FM(AVB2_AVTP_PPS)       F_(0, 0)                F_(0, 0)                F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define IP0SR5_7_4     FM(AVB2_AVTP_CAPTURE)   F_(0, 0)                F_(0, 0)                F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define IP0SR5_11_8    FM(AVB2_AVTP_MATCH)     F_(0, 0)                F_(0, 0)                F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define IP0SR5_15_12   FM(AVB2_LINK)           F_(0, 0)                F_(0, 0)                F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define IP0SR5_19_16   FM(AVB2_PHY_INT)        F_(0, 0)                F_(0, 0)                F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define IP0SR5_23_20   FM(AVB2_MAGIC)          F_(0, 0)                F_(0, 0)                F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define IP0SR5_27_24   FM(AVB2_MDC)            F_(0, 0)                F_(0, 0)                F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define IP0SR5_31_28   FM(AVB2_TXCREFCLK)      F_(0, 0)                F_(0, 0)                F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+
+/* IP1SR5 */           /* 0 */                 /* 1 */                 /* 2 */                 /* 3            4        5        6        7        8        9        A        B        C        D        E        F */
+#define IP1SR5_3_0     FM(AVB2_TD3)            F_(0, 0)                F_(0, 0)                F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define IP1SR5_7_4     FM(AVB2_RD3)            F_(0, 0)                F_(0, 0)                F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define IP1SR5_11_8    FM(AVB2_MDIO)           F_(0, 0)                F_(0, 0)                F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define IP1SR5_15_12   FM(AVB2_TD2)            F_(0, 0)                F_(0, 0)                F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define IP1SR5_19_16   FM(AVB2_TD1)            F_(0, 0)                F_(0, 0)                F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define IP1SR5_23_20   FM(AVB2_RD2)            F_(0, 0)                F_(0, 0)                F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define IP1SR5_27_24   FM(AVB2_RD1)            F_(0, 0)                F_(0, 0)                F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define IP1SR5_31_28   FM(AVB2_TD0)            F_(0, 0)                F_(0, 0)                F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+
+/* IP2SR5 */           /* 0 */                 /* 1 */                 /* 2 */                 /* 3            4        5        6        7        8        9        A        B        C        D        E        F */
+#define IP2SR5_3_0     FM(AVB2_TXC)            F_(0, 0)                F_(0, 0)                F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define IP2SR5_7_4     FM(AVB2_RD0)            F_(0, 0)                F_(0, 0)                F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define IP2SR5_11_8    FM(AVB2_RXC)            F_(0, 0)                F_(0, 0)                F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define IP2SR5_15_12   FM(AVB2_TX_CTL)         F_(0, 0)                F_(0, 0)                F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define IP2SR5_19_16   FM(AVB2_RX_CTL)         F_(0, 0)                F_(0, 0)                F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
 
 /* SR6 */
-/* IP0SR6 */           /* 0 */                 /* 1 */                 /* 2 */         /* 3            4        5        6        7        8        9        A        B        C        D        E        F */
-#define IP0SR6_3_0     FM(AVB1_MDIO)           F_(0, 0)                F_(0, 0)        F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
-#define IP0SR6_7_4     FM(AVB1_MAGIC)          F_(0, 0)                F_(0, 0)        F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
-#define IP0SR6_11_8    FM(AVB1_MDC)            F_(0, 0)                F_(0, 0)        F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
-#define IP0SR6_15_12   FM(AVB1_PHY_INT)        F_(0, 0)                F_(0, 0)        F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
-#define IP0SR6_19_16   FM(AVB1_LINK)           FM(AVB1_MII_TX_ER)      F_(0, 0)        F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
-#define IP0SR6_23_20   FM(AVB1_AVTP_MATCH)     FM(AVB1_MII_RX_ER)      F_(0, 0)        F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
-#define IP0SR6_27_24   FM(AVB1_TXC)            FM(AVB1_MII_TXC)        F_(0, 0)        F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
-#define IP0SR6_31_28   FM(AVB1_TX_CTL)         FM(AVB1_MII_TX_EN)      F_(0, 0)        F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
-
-/* IP1SR6 */           /* 0 */                 /* 1 */                 /* 2 */         /* 3            4        5        6        7        8        9        A        B        C        D        E        F */
-#define IP1SR6_3_0     FM(AVB1_RXC)            FM(AVB1_MII_RXC)        F_(0, 0)        F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
-#define IP1SR6_7_4     FM(AVB1_RX_CTL)         FM(AVB1_MII_RX_DV)      F_(0, 0)        F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
-#define IP1SR6_11_8    FM(AVB1_AVTP_PPS)       FM(AVB1_MII_COL)        F_(0, 0)        F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
-#define IP1SR6_15_12   FM(AVB1_AVTP_CAPTURE)   FM(AVB1_MII_CRS)        F_(0, 0)        F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
-#define IP1SR6_19_16   FM(AVB1_TD1)            FM(AVB1_MII_TD1)        F_(0, 0)        F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
-#define IP1SR6_23_20   FM(AVB1_TD0)            FM(AVB1_MII_TD0)        F_(0, 0)        F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
-#define IP1SR6_27_24   FM(AVB1_RD1)            FM(AVB1_MII_RD1)        F_(0, 0)        F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
-#define IP1SR6_31_28   FM(AVB1_RD0)            FM(AVB1_MII_RD0)        F_(0, 0)        F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
-
-/* IP2SR6 */           /* 0 */                 /* 1 */                 /* 2 */         /* 3            4        5        6        7        8        9        A        B        C        D        E        F */
-#define IP2SR6_3_0     FM(AVB1_TD2)            FM(AVB1_MII_TD2)        F_(0, 0)        F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
-#define IP2SR6_7_4     FM(AVB1_RD2)            FM(AVB1_MII_RD2)        F_(0, 0)        F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
-#define IP2SR6_11_8    FM(AVB1_TD3)            FM(AVB1_MII_TD3)        F_(0, 0)        F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
-#define IP2SR6_15_12   FM(AVB1_RD3)            FM(AVB1_MII_RD3)        F_(0, 0)        F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
-#define IP2SR6_19_16   FM(AVB1_TXCREFCLK)      F_(0, 0)                F_(0, 0)        F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+/* IP0SR6 */           /* 0 */                 /* 1 */                 /* 2 */                 /* 3            4        5        6        7        8        9        A        B        C        D        E        F */
+#define IP0SR6_3_0     FM(AVB1_MDIO)           F_(0, 0)                F_(0, 0)                F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define IP0SR6_7_4     FM(AVB1_MAGIC)          F_(0, 0)                F_(0, 0)                F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define IP0SR6_11_8    FM(AVB1_MDC)            F_(0, 0)                F_(0, 0)                F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define IP0SR6_15_12   FM(AVB1_PHY_INT)        F_(0, 0)                F_(0, 0)                F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define IP0SR6_19_16   FM(AVB1_LINK)           FM(AVB1_MII_TX_ER)      F_(0, 0)                F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define IP0SR6_23_20   FM(AVB1_AVTP_MATCH)     FM(AVB1_MII_RX_ER)      F_(0, 0)                F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define IP0SR6_27_24   FM(AVB1_TXC)            FM(AVB1_MII_TXC)        F_(0, 0)                F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define IP0SR6_31_28   FM(AVB1_TX_CTL)         FM(AVB1_MII_TX_EN)      F_(0, 0)                F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+
+/* IP1SR6 */           /* 0 */                 /* 1 */                 /* 2 */                 /* 3            4        5        6        7        8        9        A        B        C        D        E        F */
+#define IP1SR6_3_0     FM(AVB1_RXC)            FM(AVB1_MII_RXC)        F_(0, 0)                F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define IP1SR6_7_4     FM(AVB1_RX_CTL)         FM(AVB1_MII_RX_DV)      F_(0, 0)                F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define IP1SR6_11_8    FM(AVB1_AVTP_PPS)       FM(AVB1_MII_COL)        F_(0, 0)                F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define IP1SR6_15_12   FM(AVB1_AVTP_CAPTURE)   FM(AVB1_MII_CRS)        F_(0, 0)                F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define IP1SR6_19_16   FM(AVB1_TD1)            FM(AVB1_MII_TD1)        F_(0, 0)                F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define IP1SR6_23_20   FM(AVB1_TD0)            FM(AVB1_MII_TD0)        F_(0, 0)                F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define IP1SR6_27_24   FM(AVB1_RD1)            FM(AVB1_MII_RD1)        F_(0, 0)                F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define IP1SR6_31_28   FM(AVB1_RD0)            FM(AVB1_MII_RD0)        F_(0, 0)                F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+
+/* IP2SR6 */           /* 0 */                 /* 1 */                 /* 2 */                 /* 3            4        5        6        7        8        9        A        B        C        D        E        F */
+#define IP2SR6_3_0     FM(AVB1_TD2)            FM(AVB1_MII_TD2)        F_(0, 0)                F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define IP2SR6_7_4     FM(AVB1_RD2)            FM(AVB1_MII_RD2)        F_(0, 0)                F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define IP2SR6_11_8    FM(AVB1_TD3)            FM(AVB1_MII_TD3)        F_(0, 0)                F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define IP2SR6_15_12   FM(AVB1_RD3)            FM(AVB1_MII_RD3)        F_(0, 0)                F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define IP2SR6_19_16   FM(AVB1_TXCREFCLK)      F_(0, 0)                F_(0, 0)                F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
 
 /* SR7 */
-/* IP0SR7 */           /* 0 */                 /* 1 */                 /* 2 */         /* 3            4        5        6        7        8        9        A        B        C        D        E        F */
-#define IP0SR7_3_0     FM(AVB0_AVTP_PPS)       FM(AVB0_MII_COL)        F_(0, 0)        F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
-#define IP0SR7_7_4     FM(AVB0_AVTP_CAPTURE)   FM(AVB0_MII_CRS)        F_(0, 0)        F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
-#define IP0SR7_11_8    FM(AVB0_AVTP_MATCH)     FM(AVB0_MII_RX_ER)      FM(CC5_OSCOUT)  F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
-#define IP0SR7_15_12   FM(AVB0_TD3)            FM(AVB0_MII_TD3)        F_(0, 0)        F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
-#define IP0SR7_19_16   FM(AVB0_LINK)           FM(AVB0_MII_TX_ER)      F_(0, 0)        F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
-#define IP0SR7_23_20   FM(AVB0_PHY_INT)        F_(0, 0)                F_(0, 0)        F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
-#define IP0SR7_27_24   FM(AVB0_TD2)            FM(AVB0_MII_TD2)        F_(0, 0)        F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
-#define IP0SR7_31_28   FM(AVB0_TD1)            FM(AVB0_MII_TD1)        F_(0, 0)        F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
-
-/* IP1SR7 */           /* 0 */                 /* 1 */                 /* 2 */         /* 3            4        5        6        7        8        9        A        B        C        D        E        F */
-#define IP1SR7_3_0     FM(AVB0_RD3)            FM(AVB0_MII_RD3)        F_(0, 0)        F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
-#define IP1SR7_7_4     FM(AVB0_TXCREFCLK)      F_(0, 0)                F_(0, 0)        F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
-#define IP1SR7_11_8    FM(AVB0_MAGIC)          F_(0, 0)                F_(0, 0)        F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
-#define IP1SR7_15_12   FM(AVB0_TD0)            FM(AVB0_MII_TD0)        F_(0, 0)        F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
-#define IP1SR7_19_16   FM(AVB0_RD2)            FM(AVB0_MII_RD2)        F_(0, 0)        F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
-#define IP1SR7_23_20   FM(AVB0_MDC)            F_(0, 0)                F_(0, 0)        F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
-#define IP1SR7_27_24   FM(AVB0_MDIO)           F_(0, 0)                F_(0, 0)        F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
-#define IP1SR7_31_28   FM(AVB0_TXC)            FM(AVB0_MII_TXC)        F_(0, 0)        F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
-
-/* IP2SR7 */           /* 0 */                 /* 1 */                 /* 2 */         /* 3            4        5        6        7        8        9        A        B        C        D        E        F */
-#define IP2SR7_3_0     FM(AVB0_TX_CTL)         FM(AVB0_MII_TX_EN)      F_(0, 0)        F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
-#define IP2SR7_7_4     FM(AVB0_RD1)            FM(AVB0_MII_RD1)        F_(0, 0)        F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
-#define IP2SR7_11_8    FM(AVB0_RD0)            FM(AVB0_MII_RD0)        F_(0, 0)        F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
-#define IP2SR7_15_12   FM(AVB0_RXC)            FM(AVB0_MII_RXC)        F_(0, 0)        F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
-#define IP2SR7_19_16   FM(AVB0_RX_CTL)         FM(AVB0_MII_RX_DV)      F_(0, 0)        F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+/* IP0SR7 */           /* 0 */                 /* 1 */                 /* 2 */                 /* 3            4        5        6        7        8        9        A        B        C        D        E        F */
+#define IP0SR7_3_0     FM(AVB0_AVTP_PPS)       FM(AVB0_MII_COL)        F_(0, 0)                F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define IP0SR7_7_4     FM(AVB0_AVTP_CAPTURE)   FM(AVB0_MII_CRS)        F_(0, 0)                F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define IP0SR7_11_8    FM(AVB0_AVTP_MATCH)     FM(AVB0_MII_RX_ER)      FM(CC5_OSCOUT)          F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define IP0SR7_15_12   FM(AVB0_TD3)            FM(AVB0_MII_TD3)        F_(0, 0)                F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define IP0SR7_19_16   FM(AVB0_LINK)           FM(AVB0_MII_TX_ER)      F_(0, 0)                F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define IP0SR7_23_20   FM(AVB0_PHY_INT)        F_(0, 0)                F_(0, 0)                F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define IP0SR7_27_24   FM(AVB0_TD2)            FM(AVB0_MII_TD2)        F_(0, 0)                F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define IP0SR7_31_28   FM(AVB0_TD1)            FM(AVB0_MII_TD1)        F_(0, 0)                F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+
+/* IP1SR7 */           /* 0 */                 /* 1 */                 /* 2 */                 /* 3            4        5        6        7        8        9        A        B        C        D        E        F */
+#define IP1SR7_3_0     FM(AVB0_RD3)            FM(AVB0_MII_RD3)        F_(0, 0)                F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define IP1SR7_7_4     FM(AVB0_TXCREFCLK)      F_(0, 0)                F_(0, 0)                F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define IP1SR7_11_8    FM(AVB0_MAGIC)          F_(0, 0)                F_(0, 0)                F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define IP1SR7_15_12   FM(AVB0_TD0)            FM(AVB0_MII_TD0)        F_(0, 0)                F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define IP1SR7_19_16   FM(AVB0_RD2)            FM(AVB0_MII_RD2)        F_(0, 0)                F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define IP1SR7_23_20   FM(AVB0_MDC)            F_(0, 0)                F_(0, 0)                F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define IP1SR7_27_24   FM(AVB0_MDIO)           F_(0, 0)                F_(0, 0)                F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define IP1SR7_31_28   FM(AVB0_TXC)            FM(AVB0_MII_TXC)        F_(0, 0)                F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+
+/* IP2SR7 */           /* 0 */                 /* 1 */                 /* 2 */                 /* 3            4        5        6        7        8        9        A        B        C        D        E        F */
+#define IP2SR7_3_0     FM(AVB0_TX_CTL)         FM(AVB0_MII_TX_EN)      F_(0, 0)                F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define IP2SR7_7_4     FM(AVB0_RD1)            FM(AVB0_MII_RD1)        F_(0, 0)                F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define IP2SR7_11_8    FM(AVB0_RD0)            FM(AVB0_MII_RD0)        F_(0, 0)                F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define IP2SR7_15_12   FM(AVB0_RXC)            FM(AVB0_MII_RXC)        F_(0, 0)                F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define IP2SR7_19_16   FM(AVB0_RX_CTL)         FM(AVB0_MII_RX_DV)      F_(0, 0)                F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
 
 /* SR8 */
-/* IP0SR8 */           /* 0 */                 /* 1 */                 /* 2 */         /* 3            4        5        6        7        8        9        A        B        C        D        E        F */
-#define IP0SR8_3_0     FM(SCL0)                F_(0, 0)                F_(0, 0)        F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
-#define IP0SR8_7_4     FM(SDA0)                F_(0, 0)                F_(0, 0)        F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
-#define IP0SR8_11_8    FM(SCL1)                F_(0, 0)                F_(0, 0)        F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
-#define IP0SR8_15_12   FM(SDA1)                F_(0, 0)                F_(0, 0)        F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
-#define IP0SR8_19_16   FM(SCL2)                F_(0, 0)                F_(0, 0)        F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
-#define IP0SR8_23_20   FM(SDA2)                F_(0, 0)                F_(0, 0)        F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
-#define IP0SR8_27_24   FM(SCL3)                F_(0, 0)                F_(0, 0)        F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
-#define IP0SR8_31_28   FM(SDA3)                F_(0, 0)                F_(0, 0)        F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
-
-/* IP1SR8 */           /* 0 */                 /* 1 */                 /* 2 */         /* 3            4        5        6        7        8        9        A        B        C        D        E        F */
-#define IP1SR8_3_0     FM(SCL4)                FM(HRX2)                FM(SCK4)        F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
-#define IP1SR8_7_4     FM(SDA4)                FM(HTX2)                FM(CTS4_N)      F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
-#define IP1SR8_11_8    FM(SCL5)                FM(HRTS2_N)             FM(RTS4_N)      F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
-#define IP1SR8_15_12   FM(SDA5)                FM(SCIF_CLK2)           F_(0, 0)        F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
-#define IP1SR8_19_16   F_(0, 0)                FM(HCTS2_N)             FM(TX4)         F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
-#define IP1SR8_23_20   F_(0, 0)                FM(HSCK2)               FM(RX4)         F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+/* IP0SR8 */           /* 0 */                 /* 1 */                 /* 2 */                 /* 3            4        5        6        7        8        9        A        B        C        D        E        F */
+#define IP0SR8_3_0     FM(SCL0)                F_(0, 0)                F_(0, 0)                F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define IP0SR8_7_4     FM(SDA0)                F_(0, 0)                F_(0, 0)                F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define IP0SR8_11_8    FM(SCL1)                F_(0, 0)                F_(0, 0)                F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define IP0SR8_15_12   FM(SDA1)                F_(0, 0)                F_(0, 0)                F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define IP0SR8_19_16   FM(SCL2)                F_(0, 0)                F_(0, 0)                F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define IP0SR8_23_20   FM(SDA2)                F_(0, 0)                F_(0, 0)                F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define IP0SR8_27_24   FM(SCL3)                F_(0, 0)                F_(0, 0)                F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define IP0SR8_31_28   FM(SDA3)                F_(0, 0)                F_(0, 0)                F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+
+/* IP1SR8 */           /* 0 */                 /* 1 */                 /* 2 */                 /* 3            4        5        6        7        8        9        A        B        C        D        E        F */
+#define IP1SR8_3_0     FM(SCL4)                FM(HRX2)                FM(SCK4)                F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define IP1SR8_7_4     FM(SDA4)                FM(HTX2)                FM(CTS4_N)              F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define IP1SR8_11_8    FM(SCL5)                FM(HRTS2_N)             FM(RTS4_N)              F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define IP1SR8_15_12   FM(SDA5)                FM(SCIF_CLK2)           F_(0, 0)                F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define IP1SR8_19_16   F_(0, 0)                FM(HCTS2_N)             FM(TX4)                 F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define IP1SR8_23_20   F_(0, 0)                FM(HSCK2)               FM(RX4)                 F_(0, 0)        F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
 
 #define PINMUX_GPSR    \
                                                GPSR3_29                                                                                        \
@@ -542,6 +610,24 @@ FM(IP0SR3_23_20)   IP0SR3_23_20    FM(IP1SR3_23_20)        IP1SR3_23_20    FM(IP2SR3_23_20)        IP2
 FM(IP0SR3_27_24)       IP0SR3_27_24    FM(IP1SR3_27_24)        IP1SR3_27_24    FM(IP2SR3_27_24)        IP2SR3_27_24                                            \
 FM(IP0SR3_31_28)       IP0SR3_31_28    FM(IP1SR3_31_28)        IP1SR3_31_28    FM(IP2SR3_31_28)        IP2SR3_31_28                                            \
 \
+FM(IP0SR4_3_0)         IP0SR4_3_0      FM(IP1SR4_3_0)          IP1SR4_3_0      FM(IP2SR4_3_0)          IP2SR4_3_0      FM(IP3SR4_3_0)          IP3SR4_3_0      \
+FM(IP0SR4_7_4)         IP0SR4_7_4      FM(IP1SR4_7_4)          IP1SR4_7_4      FM(IP2SR4_7_4)          IP2SR4_7_4      \
+FM(IP0SR4_11_8)                IP0SR4_11_8     FM(IP1SR4_11_8)         IP1SR4_11_8     FM(IP2SR4_11_8)         IP2SR4_11_8     \
+FM(IP0SR4_15_12)       IP0SR4_15_12    FM(IP1SR4_15_12)        IP1SR4_15_12    FM(IP2SR4_15_12)        IP2SR4_15_12    \
+FM(IP0SR4_19_16)       IP0SR4_19_16    FM(IP1SR4_19_16)        IP1SR4_19_16    FM(IP2SR4_19_16)        IP2SR4_19_16    \
+FM(IP0SR4_23_20)       IP0SR4_23_20    FM(IP1SR4_23_20)        IP1SR4_23_20    FM(IP2SR4_23_20)        IP2SR4_23_20    \
+FM(IP0SR4_27_24)       IP0SR4_27_24    FM(IP1SR4_27_24)        IP1SR4_27_24    FM(IP2SR4_27_24)        IP2SR4_27_24    \
+FM(IP0SR4_31_28)       IP0SR4_31_28    FM(IP1SR4_31_28)        IP1SR4_31_28    FM(IP2SR4_31_28)        IP2SR4_31_28    \
+\
+FM(IP0SR5_3_0)         IP0SR5_3_0      FM(IP1SR5_3_0)          IP1SR5_3_0      FM(IP2SR5_3_0)          IP2SR5_3_0      \
+FM(IP0SR5_7_4)         IP0SR5_7_4      FM(IP1SR5_7_4)          IP1SR5_7_4      FM(IP2SR5_7_4)          IP2SR5_7_4      \
+FM(IP0SR5_11_8)                IP0SR5_11_8     FM(IP1SR5_11_8)         IP1SR5_11_8     FM(IP2SR5_11_8)         IP2SR5_11_8     \
+FM(IP0SR5_15_12)       IP0SR5_15_12    FM(IP1SR5_15_12)        IP1SR5_15_12    FM(IP2SR5_15_12)        IP2SR5_15_12    \
+FM(IP0SR5_19_16)       IP0SR5_19_16    FM(IP1SR5_19_16)        IP1SR5_19_16    FM(IP2SR5_19_16)        IP2SR5_19_16    \
+FM(IP0SR5_23_20)       IP0SR5_23_20    FM(IP1SR5_23_20)        IP1SR5_23_20    \
+FM(IP0SR5_27_24)       IP0SR5_27_24    FM(IP1SR5_27_24)        IP1SR5_27_24    \
+FM(IP0SR5_31_28)       IP0SR5_31_28    FM(IP1SR5_31_28)        IP1SR5_31_28    \
+\
 FM(IP0SR6_3_0)         IP0SR6_3_0      FM(IP1SR6_3_0)          IP1SR6_3_0      FM(IP2SR6_3_0)          IP2SR6_3_0      \
 FM(IP0SR6_7_4)         IP0SR6_7_4      FM(IP1SR6_7_4)          IP1SR6_7_4      FM(IP2SR6_7_4)          IP2SR6_7_4      \
 FM(IP0SR6_11_8)                IP0SR6_11_8     FM(IP1SR6_11_8)         IP1SR6_11_8     FM(IP2SR6_11_8)         IP2SR6_11_8     \
@@ -569,54 +655,6 @@ FM(IP0SR8_23_20)   IP0SR8_23_20    FM(IP1SR8_23_20)        IP1SR8_23_20    \
 FM(IP0SR8_27_24)       IP0SR8_27_24    \
 FM(IP0SR8_31_28)       IP0SR8_31_28
 
-/* MOD_SEL4 */                 /* 0 */                         /* 1 */
-#define MOD_SEL4_19            FM(SEL_TSN0_TD2_0)              FM(SEL_TSN0_TD2_1)
-#define MOD_SEL4_18            FM(SEL_TSN0_TD3_0)              FM(SEL_TSN0_TD3_1)
-#define MOD_SEL4_15            FM(SEL_TSN0_TD0_0)              FM(SEL_TSN0_TD0_1)
-#define MOD_SEL4_14            FM(SEL_TSN0_TD1_0)              FM(SEL_TSN0_TD1_1)
-#define MOD_SEL4_12            FM(SEL_TSN0_TXC_0)              FM(SEL_TSN0_TXC_1)
-#define MOD_SEL4_9             FM(SEL_TSN0_TX_CTL_0)           FM(SEL_TSN0_TX_CTL_1)
-#define MOD_SEL4_8             FM(SEL_TSN0_AVTP_PPS0_0)        FM(SEL_TSN0_AVTP_PPS0_1)
-#define MOD_SEL4_5             FM(SEL_TSN0_AVTP_MATCH_0)       FM(SEL_TSN0_AVTP_MATCH_1)
-#define MOD_SEL4_2             FM(SEL_TSN0_AVTP_PPS1_0)        FM(SEL_TSN0_AVTP_PPS1_1)
-#define MOD_SEL4_1             FM(SEL_TSN0_MDC_0)              FM(SEL_TSN0_MDC_1)
-
-/* MOD_SEL5 */                 /* 0 */                         /* 1 */
-#define MOD_SEL5_19            FM(SEL_AVB2_TX_CTL_0)           FM(SEL_AVB2_TX_CTL_1)
-#define MOD_SEL5_16            FM(SEL_AVB2_TXC_0)              FM(SEL_AVB2_TXC_1)
-#define MOD_SEL5_15            FM(SEL_AVB2_TD0_0)              FM(SEL_AVB2_TD0_1)
-#define MOD_SEL5_12            FM(SEL_AVB2_TD1_0)              FM(SEL_AVB2_TD1_1)
-#define MOD_SEL5_11            FM(SEL_AVB2_TD2_0)              FM(SEL_AVB2_TD2_1)
-#define MOD_SEL5_8             FM(SEL_AVB2_TD3_0)              FM(SEL_AVB2_TD3_1)
-#define MOD_SEL5_6             FM(SEL_AVB2_MDC_0)              FM(SEL_AVB2_MDC_1)
-#define MOD_SEL5_5             FM(SEL_AVB2_MAGIC_0)            FM(SEL_AVB2_MAGIC_1)
-#define MOD_SEL5_2             FM(SEL_AVB2_AVTP_MATCH_0)       FM(SEL_AVB2_AVTP_MATCH_1)
-#define MOD_SEL5_0             FM(SEL_AVB2_AVTP_PPS_0)         FM(SEL_AVB2_AVTP_PPS_1)
-
-/* MOD_SEL6 */                 /* 0 */                         /* 1 */
-#define MOD_SEL6_18            FM(SEL_AVB1_TD3_0)              FM(SEL_AVB1_TD3_1)
-#define MOD_SEL6_16            FM(SEL_AVB1_TD2_0)              FM(SEL_AVB1_TD2_1)
-#define MOD_SEL6_13            FM(SEL_AVB1_TD0_0)              FM(SEL_AVB1_TD0_1)
-#define MOD_SEL6_12            FM(SEL_AVB1_TD1_0)              FM(SEL_AVB1_TD1_1)
-#define MOD_SEL6_10            FM(SEL_AVB1_AVTP_PPS_0)         FM(SEL_AVB1_AVTP_PPS_1)
-#define MOD_SEL6_7             FM(SEL_AVB1_TX_CTL_0)           FM(SEL_AVB1_TX_CTL_1)
-#define MOD_SEL6_6             FM(SEL_AVB1_TXC_0)              FM(SEL_AVB1_TXC_1)
-#define MOD_SEL6_5             FM(SEL_AVB1_AVTP_MATCH_0)       FM(SEL_AVB1_AVTP_MATCH_1)
-#define MOD_SEL6_2             FM(SEL_AVB1_MDC_0)              FM(SEL_AVB1_MDC_1)
-#define MOD_SEL6_1             FM(SEL_AVB1_MAGIC_0)            FM(SEL_AVB1_MAGIC_1)
-
-/* MOD_SEL7 */                 /* 0 */                         /* 1 */
-#define MOD_SEL7_16            FM(SEL_AVB0_TX_CTL_0)           FM(SEL_AVB0_TX_CTL_1)
-#define MOD_SEL7_15            FM(SEL_AVB0_TXC_0)              FM(SEL_AVB0_TXC_1)
-#define MOD_SEL7_13            FM(SEL_AVB0_MDC_0)              FM(SEL_AVB0_MDC_1)
-#define MOD_SEL7_11            FM(SEL_AVB0_TD0_0)              FM(SEL_AVB0_TD0_1)
-#define MOD_SEL7_10            FM(SEL_AVB0_MAGIC_0)            FM(SEL_AVB0_MAGIC_1)
-#define MOD_SEL7_7             FM(SEL_AVB0_TD1_0)              FM(SEL_AVB0_TD1_1)
-#define MOD_SEL7_6             FM(SEL_AVB0_TD2_0)              FM(SEL_AVB0_TD2_1)
-#define MOD_SEL7_3             FM(SEL_AVB0_TD3_0)              FM(SEL_AVB0_TD3_1)
-#define MOD_SEL7_2             FM(SEL_AVB0_AVTP_MATCH_0)       FM(SEL_AVB0_AVTP_MATCH_1)
-#define MOD_SEL7_0             FM(SEL_AVB0_AVTP_PPS_0)         FM(SEL_AVB0_AVTP_PPS_1)
-
 /* MOD_SEL8 */                 /* 0 */                         /* 1 */
 #define MOD_SEL8_11            FM(SEL_SDA5_0)                  FM(SEL_SDA5_1)
 #define MOD_SEL8_10            FM(SEL_SCL5_0)                  FM(SEL_SCL5_1)
@@ -633,26 +671,18 @@ FM(IP0SR8_31_28)  IP0SR8_31_28
 
 #define PINMUX_MOD_SELS \
 \
-MOD_SEL4_19            MOD_SEL5_19                                                                             \
-MOD_SEL4_18                                    MOD_SEL6_18                                                     \
-                                                                                                               \
-                       MOD_SEL5_16             MOD_SEL6_16             MOD_SEL7_16                             \
-MOD_SEL4_15            MOD_SEL5_15                                     MOD_SEL7_15                             \
-MOD_SEL4_14                                                                                                    \
-                                               MOD_SEL6_13             MOD_SEL7_13                             \
-MOD_SEL4_12            MOD_SEL5_12             MOD_SEL6_12                                                     \
-                       MOD_SEL5_11                                     MOD_SEL7_11             MOD_SEL8_11     \
-                                               MOD_SEL6_10             MOD_SEL7_10             MOD_SEL8_10     \
-MOD_SEL4_9                                                                                     MOD_SEL8_9      \
-MOD_SEL4_8             MOD_SEL5_8                                                              MOD_SEL8_8      \
-                                               MOD_SEL6_7              MOD_SEL7_7              MOD_SEL8_7      \
-                       MOD_SEL5_6              MOD_SEL6_6              MOD_SEL7_6              MOD_SEL8_6      \
-MOD_SEL4_5             MOD_SEL5_5              MOD_SEL6_5                                      MOD_SEL8_5      \
-                                                                                               MOD_SEL8_4      \
-                                                                       MOD_SEL7_3              MOD_SEL8_3      \
-MOD_SEL4_2             MOD_SEL5_2              MOD_SEL6_2              MOD_SEL7_2              MOD_SEL8_2      \
-MOD_SEL4_1                                     MOD_SEL6_1                                      MOD_SEL8_1      \
-                       MOD_SEL5_0                                      MOD_SEL7_0              MOD_SEL8_0
+MOD_SEL8_11    \
+MOD_SEL8_10    \
+MOD_SEL8_9     \
+MOD_SEL8_8     \
+MOD_SEL8_7     \
+MOD_SEL8_6     \
+MOD_SEL8_5     \
+MOD_SEL8_4     \
+MOD_SEL8_3     \
+MOD_SEL8_2     \
+MOD_SEL8_1     \
+MOD_SEL8_0
 
 enum {
        PINMUX_RESERVED = 0,
@@ -686,61 +716,8 @@ enum {
 static const u16 pinmux_data[] = {
        PINMUX_DATA_GP_ALL(),
 
-       PINMUX_SINGLE(AVS1),
-       PINMUX_SINGLE(AVS0),
-       PINMUX_SINGLE(PCIE1_CLKREQ_N),
-       PINMUX_SINGLE(PCIE0_CLKREQ_N),
-
-       /* TSN0 without MODSEL4 */
-       PINMUX_SINGLE(TSN0_TXCREFCLK),
-       PINMUX_SINGLE(TSN0_RD2),
-       PINMUX_SINGLE(TSN0_RD3),
-       PINMUX_SINGLE(TSN0_RD1),
-       PINMUX_SINGLE(TSN0_RXC),
-       PINMUX_SINGLE(TSN0_RD0),
-       PINMUX_SINGLE(TSN0_RX_CTL),
-       PINMUX_SINGLE(TSN0_AVTP_CAPTURE),
-       PINMUX_SINGLE(TSN0_LINK),
-       PINMUX_SINGLE(TSN0_PHY_INT),
-       PINMUX_SINGLE(TSN0_MDIO),
-       /* TSN0 with MODSEL4 */
-       PINMUX_IPSR_NOGM(0, TSN0_TD2,           SEL_TSN0_TD2_1),
-       PINMUX_IPSR_NOGM(0, TSN0_TD3,           SEL_TSN0_TD3_1),
-       PINMUX_IPSR_NOGM(0, TSN0_TD0,           SEL_TSN0_TD0_1),
-       PINMUX_IPSR_NOGM(0, TSN0_TD1,           SEL_TSN0_TD1_1),
-       PINMUX_IPSR_NOGM(0, TSN0_TXC,           SEL_TSN0_TXC_1),
-       PINMUX_IPSR_NOGM(0, TSN0_TX_CTL,        SEL_TSN0_TX_CTL_1),
-       PINMUX_IPSR_NOGM(0, TSN0_AVTP_PPS0,     SEL_TSN0_AVTP_PPS0_1),
-       PINMUX_IPSR_NOGM(0, TSN0_AVTP_MATCH,    SEL_TSN0_AVTP_MATCH_1),
-       PINMUX_IPSR_NOGM(0, TSN0_AVTP_PPS1,     SEL_TSN0_AVTP_PPS1_1),
-       PINMUX_IPSR_NOGM(0, TSN0_MDC,           SEL_TSN0_MDC_1),
-
-       /* TSN0 without MODSEL5 */
-       PINMUX_SINGLE(AVB2_RX_CTL),
-       PINMUX_SINGLE(AVB2_RXC),
-       PINMUX_SINGLE(AVB2_RD0),
-       PINMUX_SINGLE(AVB2_RD1),
-       PINMUX_SINGLE(AVB2_RD2),
-       PINMUX_SINGLE(AVB2_MDIO),
-       PINMUX_SINGLE(AVB2_RD3),
-       PINMUX_SINGLE(AVB2_TXCREFCLK),
-       PINMUX_SINGLE(AVB2_PHY_INT),
-       PINMUX_SINGLE(AVB2_LINK),
-       PINMUX_SINGLE(AVB2_AVTP_CAPTURE),
-       /* TSN0 with MODSEL5 */
-       PINMUX_IPSR_NOGM(0, AVB2_TX_CTL,        SEL_AVB2_TX_CTL_1),
-       PINMUX_IPSR_NOGM(0, AVB2_TXC,           SEL_AVB2_TXC_1),
-       PINMUX_IPSR_NOGM(0, AVB2_TD0,           SEL_AVB2_TD0_1),
-       PINMUX_IPSR_NOGM(0, AVB2_TD1,           SEL_AVB2_TD1_1),
-       PINMUX_IPSR_NOGM(0, AVB2_TD2,           SEL_AVB2_TD2_1),
-       PINMUX_IPSR_NOGM(0, AVB2_TD3,           SEL_AVB2_TD3_1),
-       PINMUX_IPSR_NOGM(0, AVB2_MDC,           SEL_AVB2_MDC_1),
-       PINMUX_IPSR_NOGM(0, AVB2_MAGIC,         SEL_AVB2_MAGIC_1),
-       PINMUX_IPSR_NOGM(0, AVB2_AVTP_MATCH,    SEL_AVB2_AVTP_MATCH_1),
-       PINMUX_IPSR_NOGM(0, AVB2_AVTP_PPS,      SEL_AVB2_AVTP_PPS_1),
-
        /* IP0SR0 */
-       PINMUX_IPSR_GPSR(IP0SR0_3_0,    ERROROUTC_B),
+       PINMUX_IPSR_GPSR(IP0SR0_3_0,    ERROROUTC_N_B),
        PINMUX_IPSR_GPSR(IP0SR0_3_0,    TCLK2_A),
 
        PINMUX_IPSR_GPSR(IP0SR0_7_4,    MSIOF3_SS1),
@@ -1006,7 +983,7 @@ static const u16 pinmux_data[] = {
 
        PINMUX_IPSR_GPSR(IP1SR3_27_24,  IPC_CLKOUT),
        PINMUX_IPSR_GPSR(IP1SR3_27_24,  IPC_CLKEN_OUT),
-       PINMUX_IPSR_GPSR(IP1SR3_27_24,  ERROROUTC_A),
+       PINMUX_IPSR_GPSR(IP1SR3_27_24,  ERROROUTC_N_A),
        PINMUX_IPSR_GPSR(IP1SR3_27_24,  TCLK4_X),
 
        PINMUX_IPSR_GPSR(IP1SR3_31_28,  QSPI0_SSL),
@@ -1029,26 +1006,86 @@ static const u16 pinmux_data[] = {
        PINMUX_IPSR_GPSR(IP3SR3_19_16,  RPC_WP_N),
        PINMUX_IPSR_GPSR(IP3SR3_23_20,  RPC_INT_N),
 
+       /* IP0SR4 */
+       PINMUX_IPSR_GPSR(IP0SR4_3_0,    TSN0_MDIO),
+       PINMUX_IPSR_GPSR(IP0SR4_7_4,    TSN0_MDC),
+       PINMUX_IPSR_GPSR(IP0SR4_11_8,   TSN0_AVTP_PPS1),
+       PINMUX_IPSR_GPSR(IP0SR4_15_12,  TSN0_PHY_INT),
+       PINMUX_IPSR_GPSR(IP0SR4_19_16,  TSN0_LINK),
+       PINMUX_IPSR_GPSR(IP0SR4_23_20,  TSN0_AVTP_MATCH),
+       PINMUX_IPSR_GPSR(IP0SR4_27_24,  TSN0_AVTP_CAPTURE),
+       PINMUX_IPSR_GPSR(IP0SR4_31_28,  TSN0_RX_CTL),
+
+       /* IP1SR4 */
+       PINMUX_IPSR_GPSR(IP1SR4_3_0,    TSN0_AVTP_PPS0),
+       PINMUX_IPSR_GPSR(IP1SR4_7_4,    TSN0_TX_CTL),
+       PINMUX_IPSR_GPSR(IP1SR4_11_8,   TSN0_RD0),
+       PINMUX_IPSR_GPSR(IP1SR4_15_12,  TSN0_RXC),
+       PINMUX_IPSR_GPSR(IP1SR4_19_16,  TSN0_TXC),
+       PINMUX_IPSR_GPSR(IP1SR4_23_20,  TSN0_RD1),
+       PINMUX_IPSR_GPSR(IP1SR4_27_24,  TSN0_TD1),
+       PINMUX_IPSR_GPSR(IP1SR4_31_28,  TSN0_TD0),
+
+       /* IP2SR4 */
+       PINMUX_IPSR_GPSR(IP2SR4_3_0,    TSN0_RD3),
+       PINMUX_IPSR_GPSR(IP2SR4_7_4,    TSN0_RD2),
+       PINMUX_IPSR_GPSR(IP2SR4_11_8,   TSN0_TD3),
+       PINMUX_IPSR_GPSR(IP2SR4_15_12,  TSN0_TD2),
+       PINMUX_IPSR_GPSR(IP2SR4_19_16,  TSN0_TXCREFCLK),
+       PINMUX_IPSR_GPSR(IP2SR4_23_20,  PCIE0_CLKREQ_N),
+       PINMUX_IPSR_GPSR(IP2SR4_27_24,  PCIE1_CLKREQ_N),
+       PINMUX_IPSR_GPSR(IP2SR4_31_28,  AVS0),
+
+       /* IP3SR4 */
+       PINMUX_IPSR_GPSR(IP3SR4_3_0,    AVS1),
+
+       /* IP0SR5 */
+       PINMUX_IPSR_GPSR(IP0SR5_3_0,    AVB2_AVTP_PPS),
+       PINMUX_IPSR_GPSR(IP0SR5_7_4,    AVB2_AVTP_CAPTURE),
+       PINMUX_IPSR_GPSR(IP0SR5_11_8,   AVB2_AVTP_MATCH),
+       PINMUX_IPSR_GPSR(IP0SR5_15_12,  AVB2_LINK),
+       PINMUX_IPSR_GPSR(IP0SR5_19_16,  AVB2_PHY_INT),
+       PINMUX_IPSR_GPSR(IP0SR5_23_20,  AVB2_MAGIC),
+       PINMUX_IPSR_GPSR(IP0SR5_27_24,  AVB2_MDC),
+       PINMUX_IPSR_GPSR(IP0SR5_31_28,  AVB2_TXCREFCLK),
+
+       /* IP1SR5 */
+       PINMUX_IPSR_GPSR(IP1SR5_3_0,    AVB2_TD3),
+       PINMUX_IPSR_GPSR(IP1SR5_7_4,    AVB2_RD3),
+       PINMUX_IPSR_GPSR(IP1SR5_11_8,   AVB2_MDIO),
+       PINMUX_IPSR_GPSR(IP1SR5_15_12,  AVB2_TD2),
+       PINMUX_IPSR_GPSR(IP1SR5_19_16,  AVB2_TD1),
+       PINMUX_IPSR_GPSR(IP1SR5_23_20,  AVB2_RD2),
+       PINMUX_IPSR_GPSR(IP1SR5_27_24,  AVB2_RD1),
+       PINMUX_IPSR_GPSR(IP1SR5_31_28,  AVB2_TD0),
+
+       /* IP2SR5 */
+       PINMUX_IPSR_GPSR(IP2SR5_3_0,    AVB2_TXC),
+       PINMUX_IPSR_GPSR(IP2SR5_7_4,    AVB2_RD0),
+       PINMUX_IPSR_GPSR(IP2SR5_11_8,   AVB2_RXC),
+       PINMUX_IPSR_GPSR(IP2SR5_15_12,  AVB2_TX_CTL),
+       PINMUX_IPSR_GPSR(IP2SR5_19_16,  AVB2_RX_CTL),
+
        /* IP0SR6 */
        PINMUX_IPSR_GPSR(IP0SR6_3_0,    AVB1_MDIO),
 
-       PINMUX_IPSR_MSEL(IP0SR6_7_4,    AVB1_MAGIC,             SEL_AVB1_MAGIC_1),
+       PINMUX_IPSR_GPSR(IP0SR6_7_4,    AVB1_MAGIC),
 
-       PINMUX_IPSR_MSEL(IP0SR6_11_8,   AVB1_MDC,               SEL_AVB1_MDC_1),
+       PINMUX_IPSR_GPSR(IP0SR6_11_8,   AVB1_MDC),
 
        PINMUX_IPSR_GPSR(IP0SR6_15_12,  AVB1_PHY_INT),
 
        PINMUX_IPSR_GPSR(IP0SR6_19_16,  AVB1_LINK),
        PINMUX_IPSR_GPSR(IP0SR6_19_16,  AVB1_MII_TX_ER),
 
-       PINMUX_IPSR_MSEL(IP0SR6_23_20,  AVB1_AVTP_MATCH,        SEL_AVB1_AVTP_MATCH_1),
-       PINMUX_IPSR_MSEL(IP0SR6_23_20,  AVB1_MII_RX_ER,         SEL_AVB1_AVTP_MATCH_0),
+       PINMUX_IPSR_GPSR(IP0SR6_23_20,  AVB1_AVTP_MATCH),
+       PINMUX_IPSR_GPSR(IP0SR6_23_20,  AVB1_MII_RX_ER),
 
-       PINMUX_IPSR_MSEL(IP0SR6_27_24,  AVB1_TXC,               SEL_AVB1_TXC_1),
-       PINMUX_IPSR_MSEL(IP0SR6_27_24,  AVB1_MII_TXC,           SEL_AVB1_TXC_0),
+       PINMUX_IPSR_GPSR(IP0SR6_27_24,  AVB1_TXC),
+       PINMUX_IPSR_GPSR(IP0SR6_27_24,  AVB1_MII_TXC),
 
-       PINMUX_IPSR_MSEL(IP0SR6_31_28,  AVB1_TX_CTL,            SEL_AVB1_TX_CTL_1),
-       PINMUX_IPSR_MSEL(IP0SR6_31_28,  AVB1_MII_TX_EN,         SEL_AVB1_TX_CTL_0),
+       PINMUX_IPSR_GPSR(IP0SR6_31_28,  AVB1_TX_CTL),
+       PINMUX_IPSR_GPSR(IP0SR6_31_28,  AVB1_MII_TX_EN),
 
        /* IP1SR6 */
        PINMUX_IPSR_GPSR(IP1SR6_3_0,    AVB1_RXC),
@@ -1057,17 +1094,17 @@ static const u16 pinmux_data[] = {
        PINMUX_IPSR_GPSR(IP1SR6_7_4,    AVB1_RX_CTL),
        PINMUX_IPSR_GPSR(IP1SR6_7_4,    AVB1_MII_RX_DV),
 
-       PINMUX_IPSR_MSEL(IP1SR6_11_8,   AVB1_AVTP_PPS,          SEL_AVB1_AVTP_PPS_1),
-       PINMUX_IPSR_MSEL(IP1SR6_11_8,   AVB1_MII_COL,           SEL_AVB1_AVTP_PPS_0),
+       PINMUX_IPSR_GPSR(IP1SR6_11_8,   AVB1_AVTP_PPS),
+       PINMUX_IPSR_GPSR(IP1SR6_11_8,   AVB1_MII_COL),
 
        PINMUX_IPSR_GPSR(IP1SR6_15_12,  AVB1_AVTP_CAPTURE),
        PINMUX_IPSR_GPSR(IP1SR6_15_12,  AVB1_MII_CRS),
 
-       PINMUX_IPSR_MSEL(IP1SR6_19_16,  AVB1_TD1,               SEL_AVB1_TD1_1),
-       PINMUX_IPSR_MSEL(IP1SR6_19_16,  AVB1_MII_TD1,           SEL_AVB1_TD1_0),
+       PINMUX_IPSR_GPSR(IP1SR6_19_16,  AVB1_TD1),
+       PINMUX_IPSR_GPSR(IP1SR6_19_16,  AVB1_MII_TD1),
 
-       PINMUX_IPSR_MSEL(IP1SR6_23_20,  AVB1_TD0,               SEL_AVB1_TD0_1),
-       PINMUX_IPSR_MSEL(IP1SR6_23_20,  AVB1_MII_TD0,           SEL_AVB1_TD0_0),
+       PINMUX_IPSR_GPSR(IP1SR6_23_20,  AVB1_TD0),
+       PINMUX_IPSR_GPSR(IP1SR6_23_20,  AVB1_MII_TD0),
 
        PINMUX_IPSR_GPSR(IP1SR6_27_24,  AVB1_RD1),
        PINMUX_IPSR_GPSR(IP1SR6_27_24,  AVB1_MII_RD1),
@@ -1076,14 +1113,14 @@ static const u16 pinmux_data[] = {
        PINMUX_IPSR_GPSR(IP1SR6_31_28,  AVB1_MII_RD0),
 
        /* IP2SR6 */
-       PINMUX_IPSR_MSEL(IP2SR6_3_0,    AVB1_TD2,               SEL_AVB1_TD2_1),
-       PINMUX_IPSR_MSEL(IP2SR6_3_0,    AVB1_MII_TD2,           SEL_AVB1_TD2_0),
+       PINMUX_IPSR_GPSR(IP2SR6_3_0,    AVB1_TD2),
+       PINMUX_IPSR_GPSR(IP2SR6_3_0,    AVB1_MII_TD2),
 
        PINMUX_IPSR_GPSR(IP2SR6_7_4,    AVB1_RD2),
        PINMUX_IPSR_GPSR(IP2SR6_7_4,    AVB1_MII_RD2),
 
-       PINMUX_IPSR_MSEL(IP2SR6_11_8,   AVB1_TD3,               SEL_AVB1_TD3_1),
-       PINMUX_IPSR_MSEL(IP2SR6_11_8,   AVB1_MII_TD3,           SEL_AVB1_TD3_0),
+       PINMUX_IPSR_GPSR(IP2SR6_11_8,   AVB1_TD3),
+       PINMUX_IPSR_GPSR(IP2SR6_11_8,   AVB1_MII_TD3),
 
        PINMUX_IPSR_GPSR(IP2SR6_15_12,  AVB1_RD3),
        PINMUX_IPSR_GPSR(IP2SR6_15_12,  AVB1_MII_RD3),
@@ -1091,29 +1128,29 @@ static const u16 pinmux_data[] = {
        PINMUX_IPSR_GPSR(IP2SR6_19_16,  AVB1_TXCREFCLK),
 
        /* IP0SR7 */
-       PINMUX_IPSR_MSEL(IP0SR7_3_0,    AVB0_AVTP_PPS,          SEL_AVB0_AVTP_PPS_1),
-       PINMUX_IPSR_MSEL(IP0SR7_3_0,    AVB0_MII_COL,           SEL_AVB0_AVTP_PPS_0),
+       PINMUX_IPSR_GPSR(IP0SR7_3_0,    AVB0_AVTP_PPS),
+       PINMUX_IPSR_GPSR(IP0SR7_3_0,    AVB0_MII_COL),
 
        PINMUX_IPSR_GPSR(IP0SR7_7_4,    AVB0_AVTP_CAPTURE),
        PINMUX_IPSR_GPSR(IP0SR7_7_4,    AVB0_MII_CRS),
 
-       PINMUX_IPSR_MSEL(IP0SR7_11_8,   AVB0_AVTP_MATCH,        SEL_AVB0_AVTP_MATCH_1),
-       PINMUX_IPSR_MSEL(IP0SR7_11_8,   AVB0_MII_RX_ER,         SEL_AVB0_AVTP_MATCH_0),
-       PINMUX_IPSR_MSEL(IP0SR7_11_8,   CC5_OSCOUT,             SEL_AVB0_AVTP_MATCH_0),
+       PINMUX_IPSR_GPSR(IP0SR7_11_8,   AVB0_AVTP_MATCH),
+       PINMUX_IPSR_GPSR(IP0SR7_11_8,   AVB0_MII_RX_ER),
+       PINMUX_IPSR_GPSR(IP0SR7_11_8,   CC5_OSCOUT),
 
-       PINMUX_IPSR_MSEL(IP0SR7_15_12,  AVB0_TD3,               SEL_AVB0_TD3_1),
-       PINMUX_IPSR_MSEL(IP0SR7_15_12,  AVB0_MII_TD3,           SEL_AVB0_TD3_0),
+       PINMUX_IPSR_GPSR(IP0SR7_15_12,  AVB0_TD3),
+       PINMUX_IPSR_GPSR(IP0SR7_15_12,  AVB0_MII_TD3),
 
        PINMUX_IPSR_GPSR(IP0SR7_19_16,  AVB0_LINK),
        PINMUX_IPSR_GPSR(IP0SR7_19_16,  AVB0_MII_TX_ER),
 
        PINMUX_IPSR_GPSR(IP0SR7_23_20,  AVB0_PHY_INT),
 
-       PINMUX_IPSR_MSEL(IP0SR7_27_24,  AVB0_TD2,               SEL_AVB0_TD2_1),
-       PINMUX_IPSR_MSEL(IP0SR7_27_24,  AVB0_MII_TD2,           SEL_AVB0_TD2_0),
+       PINMUX_IPSR_GPSR(IP0SR7_27_24,  AVB0_TD2),
+       PINMUX_IPSR_GPSR(IP0SR7_27_24,  AVB0_MII_TD2),
 
-       PINMUX_IPSR_MSEL(IP0SR7_31_28,  AVB0_TD1,               SEL_AVB0_TD1_1),
-       PINMUX_IPSR_MSEL(IP0SR7_31_28,  AVB0_MII_TD1,           SEL_AVB0_TD1_0),
+       PINMUX_IPSR_GPSR(IP0SR7_31_28,  AVB0_TD1),
+       PINMUX_IPSR_GPSR(IP0SR7_31_28,  AVB0_MII_TD1),
 
        /* IP1SR7 */
        PINMUX_IPSR_GPSR(IP1SR7_3_0,    AVB0_RD3),
@@ -1121,24 +1158,24 @@ static const u16 pinmux_data[] = {
 
        PINMUX_IPSR_GPSR(IP1SR7_7_4,    AVB0_TXCREFCLK),
 
-       PINMUX_IPSR_MSEL(IP1SR7_11_8,   AVB0_MAGIC,             SEL_AVB0_MAGIC_1),
+       PINMUX_IPSR_GPSR(IP1SR7_11_8,   AVB0_MAGIC),
 
-       PINMUX_IPSR_MSEL(IP1SR7_15_12,  AVB0_TD0,               SEL_AVB0_TD0_1),
-       PINMUX_IPSR_MSEL(IP1SR7_15_12,  AVB0_MII_TD0,           SEL_AVB0_TD0_0),
+       PINMUX_IPSR_GPSR(IP1SR7_15_12,  AVB0_TD0),
+       PINMUX_IPSR_GPSR(IP1SR7_15_12,  AVB0_MII_TD0),
 
        PINMUX_IPSR_GPSR(IP1SR7_19_16,  AVB0_RD2),
        PINMUX_IPSR_GPSR(IP1SR7_19_16,  AVB0_MII_RD2),
 
-       PINMUX_IPSR_MSEL(IP1SR7_23_20,  AVB0_MDC,               SEL_AVB0_MDC_1),
+       PINMUX_IPSR_GPSR(IP1SR7_23_20,  AVB0_MDC),
 
        PINMUX_IPSR_GPSR(IP1SR7_27_24,  AVB0_MDIO),
 
-       PINMUX_IPSR_MSEL(IP1SR7_31_28,  AVB0_TXC,               SEL_AVB0_TXC_1),
-       PINMUX_IPSR_MSEL(IP1SR7_31_28,  AVB0_MII_TXC,           SEL_AVB0_TXC_0),
+       PINMUX_IPSR_GPSR(IP1SR7_31_28,  AVB0_TXC),
+       PINMUX_IPSR_GPSR(IP1SR7_31_28,  AVB0_MII_TXC),
 
        /* IP2SR7 */
-       PINMUX_IPSR_MSEL(IP2SR7_3_0,    AVB0_TX_CTL,            SEL_AVB0_TX_CTL_1),
-       PINMUX_IPSR_MSEL(IP2SR7_3_0,    AVB0_MII_TX_EN,         SEL_AVB0_TX_CTL_0),
+       PINMUX_IPSR_GPSR(IP2SR7_3_0,    AVB0_TX_CTL),
+       PINMUX_IPSR_GPSR(IP2SR7_3_0,    AVB0_MII_TX_EN),
 
        PINMUX_IPSR_GPSR(IP2SR7_7_4,    AVB0_RD1),
        PINMUX_IPSR_GPSR(IP2SR7_7_4,    AVB0_MII_RD1),
@@ -1190,10 +1227,28 @@ static const u16 pinmux_data[] = {
  */
 enum {
        GP_ASSIGN_LAST(),
+       NOGP_ALL(),
 };
 
 static const struct sh_pfc_pin pinmux_pins[] = {
        PINMUX_GPIO_GP_ALL(),
+       PINMUX_NOGP_ALL(),
+};
+
+/* - AUDIO CLOCK ----------------------------------------- */
+static const unsigned int audio_clkin_pins[] = {
+       /* CLK IN */
+       RCAR_GP_PIN(1, 22),
+};
+static const unsigned int audio_clkin_mux[] = {
+       AUDIO_CLKIN_MARK,
+};
+static const unsigned int audio_clkout_pins[] = {
+       /* CLK OUT */
+       RCAR_GP_PIN(1, 21),
+};
+static const unsigned int audio_clkout_mux[] = {
+       AUDIO_CLKOUT_MARK,
 };
 
 /* - AVB0 ------------------------------------------------ */
@@ -2329,6 +2384,22 @@ static const unsigned int scif_clk_mux[] = {
        SCIF_CLK_MARK,
 };
 
+/* - SSI ------------------------------------------------- */
+static const unsigned int ssi_data_pins[] = {
+       /* SSI_SD */
+       RCAR_GP_PIN(1, 20),
+};
+static const unsigned int ssi_data_mux[] = {
+       SSI_SD_MARK,
+};
+static const unsigned int ssi_ctrl_pins[] = {
+       /* SSI_SCK,  SSI_WS */
+       RCAR_GP_PIN(1, 18), RCAR_GP_PIN(1, 19),
+};
+static const unsigned int ssi_ctrl_mux[] = {
+       SSI_SCK_MARK, SSI_WS_MARK,
+};
+
 /* - TPU ------------------------------------------------------------------- */
 static const unsigned int tpu_to0_pins[] = {
        /* TPU0TO0 */
@@ -2461,6 +2532,9 @@ static const unsigned int tsn0_avtp_match_mux[] = {
 };
 
 static const struct sh_pfc_pin_group pinmux_groups[] = {
+       SH_PFC_PIN_GROUP(audio_clkin),
+       SH_PFC_PIN_GROUP(audio_clkout),
+
        SH_PFC_PIN_GROUP(avb0_link),
        SH_PFC_PIN_GROUP(avb0_magic),
        SH_PFC_PIN_GROUP(avb0_phy_int),
@@ -2621,6 +2695,9 @@ static const struct sh_pfc_pin_group pinmux_groups[] = {
        SH_PFC_PIN_GROUP(scif4_ctrl),
        SH_PFC_PIN_GROUP(scif_clk),
 
+       SH_PFC_PIN_GROUP(ssi_data),
+       SH_PFC_PIN_GROUP(ssi_ctrl),
+
        SH_PFC_PIN_GROUP(tpu_to0),              /* suffix might be updated */
        SH_PFC_PIN_GROUP(tpu_to0_a),            /* suffix might be updated */
        SH_PFC_PIN_GROUP(tpu_to1),              /* suffix might be updated */
@@ -2640,6 +2717,11 @@ static const struct sh_pfc_pin_group pinmux_groups[] = {
        SH_PFC_PIN_GROUP(tsn0_avtp_match),
 };
 
+static const char * const audio_clk_groups[] = {
+       "audio_clkin",
+       "audio_clkout",
+};
+
 static const char * const avb0_groups[] = {
        "avb0_link",
        "avb0_magic",
@@ -2933,6 +3015,11 @@ static const char * const scif_clk_groups[] = {
        "scif_clk",
 };
 
+static const char * const ssi_groups[] = {
+       "ssi_data",
+       "ssi_ctrl",
+};
+
 static const char * const tpu_groups[] = {
        /* suffix might be updated */
        "tpu_to0",
@@ -2957,6 +3044,8 @@ static const char * const tsn0_groups[] = {
 };
 
 static const struct sh_pfc_function pinmux_functions[] = {
+       SH_PFC_FUNCTION(audio_clk),
+
        SH_PFC_FUNCTION(avb0),
        SH_PFC_FUNCTION(avb1),
        SH_PFC_FUNCTION(avb2),
@@ -3014,6 +3103,8 @@ static const struct sh_pfc_function pinmux_functions[] = {
        SH_PFC_FUNCTION(scif4),
        SH_PFC_FUNCTION(scif_clk),
 
+       SH_PFC_FUNCTION(ssi),
+
        SH_PFC_FUNCTION(tpu),
 
        SH_PFC_FUNCTION(tsn0),
@@ -3419,6 +3510,82 @@ static const struct pinmux_cfg_reg pinmux_config_regs[] = {
                IP3SR3_7_4
                IP3SR3_3_0))
        },
+       { PINMUX_CFG_REG_VAR("IP0SR4", 0xE6060060, 32,
+                            GROUP(4, 4, 4, 4, 4, 4, 4, 4),
+                            GROUP(
+               IP0SR4_31_28
+               IP0SR4_27_24
+               IP0SR4_23_20
+               IP0SR4_19_16
+               IP0SR4_15_12
+               IP0SR4_11_8
+               IP0SR4_7_4
+               IP0SR4_3_0))
+       },
+       { PINMUX_CFG_REG_VAR("IP1SR4", 0xE6060064, 32,
+                            GROUP(4, 4, 4, 4, 4, 4, 4, 4),
+                            GROUP(
+               IP1SR4_31_28
+               IP1SR4_27_24
+               IP1SR4_23_20
+               IP1SR4_19_16
+               IP1SR4_15_12
+               IP1SR4_11_8
+               IP1SR4_7_4
+               IP1SR4_3_0))
+       },
+       { PINMUX_CFG_REG_VAR("IP2SR4", 0xE6060068, 32,
+                            GROUP(4, 4, 4, 4, 4, 4, 4, 4),
+                            GROUP(
+               IP2SR4_31_28
+               IP2SR4_27_24
+               IP2SR4_23_20
+               IP2SR4_19_16
+               IP2SR4_15_12
+               IP2SR4_11_8
+               IP2SR4_7_4
+               IP2SR4_3_0))
+       },
+       { PINMUX_CFG_REG_VAR("IP3SR4", 0xE606006C, 32,
+                            GROUP(-28, 4),
+                            GROUP(
+               /* IP3SR4_31_4 RESERVED */
+               IP3SR4_3_0))
+       },
+       { PINMUX_CFG_REG_VAR("IP0SR5", 0xE6060860, 32,
+                            GROUP(4, 4, 4, 4, 4, 4, 4, 4),
+                            GROUP(
+               IP0SR5_31_28
+               IP0SR5_27_24
+               IP0SR5_23_20
+               IP0SR5_19_16
+               IP0SR5_15_12
+               IP0SR5_11_8
+               IP0SR5_7_4
+               IP0SR5_3_0))
+       },
+       { PINMUX_CFG_REG_VAR("IP1SR5", 0xE6060864, 32,
+                            GROUP(4, 4, 4, 4, 4, 4, 4, 4),
+                            GROUP(
+               IP1SR5_31_28
+               IP1SR5_27_24
+               IP1SR5_23_20
+               IP1SR5_19_16
+               IP1SR5_15_12
+               IP1SR5_11_8
+               IP1SR5_7_4
+               IP1SR5_3_0))
+       },
+       { PINMUX_CFG_REG_VAR("IP2SR5", 0xE6060868, 32,
+                            GROUP(-12, 4, 4, 4, 4, 4),
+                            GROUP(
+               /* IP2SR5_31_20 RESERVED */
+               IP2SR5_19_16
+               IP2SR5_15_12
+               IP2SR5_11_8
+               IP2SR5_7_4
+               IP2SR5_3_0))
+       },
        { PINMUX_CFG_REG("IP0SR6", 0xE6061060, 32, 4, GROUP(
                IP0SR6_31_28
                IP0SR6_27_24
@@ -3505,95 +3672,6 @@ static const struct pinmux_cfg_reg pinmux_config_regs[] = {
 
 #define F_(x, y)       x,
 #define FM(x)          FN_##x,
-       { PINMUX_CFG_REG_VAR("MOD_SEL4", 0xE6060100, 32,
-                            GROUP(-12, 1, 1, -2, 1, 1, -1, 1, -2, 1, 1, -2, 1,
-                                  -2, 1, 1, -1),
-                            GROUP(
-               /* RESERVED 31-20 */
-               MOD_SEL4_19
-               MOD_SEL4_18
-               /* RESERVED 17-16 */
-               MOD_SEL4_15
-               MOD_SEL4_14
-               /* RESERVED 13 */
-               MOD_SEL4_12
-               /* RESERVED 11-10 */
-               MOD_SEL4_9
-               MOD_SEL4_8
-               /* RESERVED 7-6 */
-               MOD_SEL4_5
-               /* RESERVED 4-3 */
-               MOD_SEL4_2
-               MOD_SEL4_1
-               /* RESERVED 0 */
-               ))
-       },
-       { PINMUX_CFG_REG_VAR("MOD_SEL5", 0xE6060900, 32,
-                            GROUP(-12, 1, -2, 1, 1, -2, 1, 1, -2, 1, -1,
-                                  1, 1, -2, 1, -1, 1),
-                            GROUP(
-               /* RESERVED 31-20 */
-               MOD_SEL5_19
-               /* RESERVED 18-17 */
-               MOD_SEL5_16
-               MOD_SEL5_15
-               /* RESERVED 14-13 */
-               MOD_SEL5_12
-               MOD_SEL5_11
-               /* RESERVED 10-9 */
-               MOD_SEL5_8
-               /* RESERVED 7 */
-               MOD_SEL5_6
-               MOD_SEL5_5
-               /* RESERVED 4-3 */
-               MOD_SEL5_2
-               /* RESERVED 1 */
-               MOD_SEL5_0))
-       },
-       { PINMUX_CFG_REG_VAR("MOD_SEL6", 0xE6061100, 32,
-                            GROUP(-13, 1, -1, 1, -2, 1, 1,
-                                  -1, 1, -2, 1, 1, 1, -2, 1, 1, -1),
-                            GROUP(
-               /* RESERVED 31-19 */
-               MOD_SEL6_18
-               /* RESERVED 17 */
-               MOD_SEL6_16
-               /* RESERVED 15-14 */
-               MOD_SEL6_13
-               MOD_SEL6_12
-               /* RESERVED 11 */
-               MOD_SEL6_10
-               /* RESERVED 9-8 */
-               MOD_SEL6_7
-               MOD_SEL6_6
-               MOD_SEL6_5
-               /* RESERVED 4-3 */
-               MOD_SEL6_2
-               MOD_SEL6_1
-               /* RESERVED 0 */
-               ))
-       },
-       { PINMUX_CFG_REG_VAR("MOD_SEL7", 0xE6061900, 32,
-                            GROUP(-15, 1, 1, -1, 1, -1, 1, 1, -2, 1, 1,
-                                  -2, 1, 1, -1, 1),
-                            GROUP(
-               /* RESERVED 31-17 */
-               MOD_SEL7_16
-               MOD_SEL7_15
-               /* RESERVED 14 */
-               MOD_SEL7_13
-               /* RESERVED 12 */
-               MOD_SEL7_11
-               MOD_SEL7_10
-               /* RESERVED 9-8 */
-               MOD_SEL7_7
-               MOD_SEL7_6
-               /* RESERVED 5-4 */
-               MOD_SEL7_3
-               MOD_SEL7_2
-               /* RESERVED 1 */
-               MOD_SEL7_0))
-       },
        { PINMUX_CFG_REG_VAR("MOD_SEL8", 0xE6068100, 32,
                             GROUP(-20, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1),
                             GROUP(
@@ -3611,7 +3689,7 @@ static const struct pinmux_cfg_reg pinmux_config_regs[] = {
                MOD_SEL8_1
                MOD_SEL8_0))
        },
-       { },
+       { /* sentinel */ }
 };
 
 static const struct pinmux_drive_reg pinmux_drive_regs[] = {
@@ -3873,7 +3951,7 @@ static const struct pinmux_drive_reg pinmux_drive_regs[] = {
                { RCAR_GP_PIN(8,  9),  4, 3 },  /* SDA4 */
                { RCAR_GP_PIN(8,  8),  0, 3 },  /* SCL4 */
        } },
-       { },
+       { /* sentinel */ }
 };
 
 enum ioctrl_regs {
@@ -3896,30 +3974,49 @@ static const struct pinmux_ioctrl_reg pinmux_ioctrl_regs[] = {
        [POC6]          = { 0xE60610A0, },
        [POC7]          = { 0xE60618A0, },
        [POC8]          = { 0xE60680A0, },
-       { /* sentinel */ },
+       { /* sentinel */ }
 };
 
 static int r8a779g0_pin_to_pocctrl(unsigned int pin, u32 *pocctrl)
 {
        int bit = pin & 0x1f;
 
-       *pocctrl = pinmux_ioctrl_regs[POC0].reg;
-       if (pin >= RCAR_GP_PIN(0, 0) && pin <= RCAR_GP_PIN(0, 18))
+       switch (pin) {
+       case RCAR_GP_PIN(0, 0) ... RCAR_GP_PIN(0, 18):
+               *pocctrl = pinmux_ioctrl_regs[POC0].reg;
                return bit;
 
-       *pocctrl = pinmux_ioctrl_regs[POC1].reg;
-       if (pin >= RCAR_GP_PIN(1, 0) && pin <= RCAR_GP_PIN(1, 22))
+       case RCAR_GP_PIN(1, 0) ... RCAR_GP_PIN(1, 22):
+               *pocctrl = pinmux_ioctrl_regs[POC1].reg;
                return bit;
 
-       *pocctrl = pinmux_ioctrl_regs[POC3].reg;
-       if (pin >= RCAR_GP_PIN(3, 0) && pin <= RCAR_GP_PIN(3, 12))
+       case RCAR_GP_PIN(3, 0) ... RCAR_GP_PIN(3, 12):
+               *pocctrl = pinmux_ioctrl_regs[POC3].reg;
                return bit;
 
-       *pocctrl = pinmux_ioctrl_regs[POC8].reg;
-       if (pin >= RCAR_GP_PIN(8, 0) && pin <= RCAR_GP_PIN(8, 13))
+       case PIN_VDDQ_TSN0:
+               *pocctrl = pinmux_ioctrl_regs[POC4].reg;
+               return 0;
+
+       case PIN_VDDQ_AVB2:
+               *pocctrl = pinmux_ioctrl_regs[POC5].reg;
+               return 0;
+
+       case PIN_VDDQ_AVB1:
+               *pocctrl = pinmux_ioctrl_regs[POC6].reg;
+               return 0;
+
+       case PIN_VDDQ_AVB0:
+               *pocctrl = pinmux_ioctrl_regs[POC7].reg;
+               return 0;
+
+       case RCAR_GP_PIN(8, 0) ... RCAR_GP_PIN(8, 13):
+               *pocctrl = pinmux_ioctrl_regs[POC8].reg;
                return bit;
 
-       return -EINVAL;
+       default:
+               return -EINVAL;
+       }
 }
 
 static const struct pinmux_bias_reg pinmux_bias_regs[] = {
@@ -4229,7 +4326,7 @@ static const struct pinmux_bias_reg pinmux_bias_regs[] = {
                [30] = SH_PFC_PIN_NONE,
                [31] = SH_PFC_PIN_NONE,
        } },
-       { /* sentinel */ },
+       { /* sentinel */ }
 };
 
 static const struct sh_pfc_soc_operations r8a779g0_pin_ops = {
index 19735746b1bb215749f780adffe1a82825840bca..640564db2c0b6f010f8fc248b8c5f3ff75538cf0 100644 (file)
@@ -1509,7 +1509,7 @@ static const struct pinmux_cfg_reg pinmux_config_regs[] = {
                PF0MD_00, PF0MD_01, PF0MD_10, PF0MD_11,
                0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0 ))
        },
-       {}
+       { /* sentinel */ }
 };
 
 static const struct pinmux_data_reg pinmux_data_regs[] = {
@@ -1555,7 +1555,7 @@ static const struct pinmux_data_reg pinmux_data_regs[] = {
                PF7_DATA, PF6_DATA, PF5_DATA, PF4_DATA,
                PF3_DATA, PF2_DATA, PF1_DATA, PF0_DATA ))
        },
-       { },
+       { /* sentinel */ }
 };
 
 const struct sh_pfc_soc_info sh7203_pinmux_info = {
index 30096925a70c5d88501978e388eeae4548bed3c9..8417c4243ddacf8dc33b56557c454770c84f6aa8 100644 (file)
@@ -2031,7 +2031,7 @@ static const struct pinmux_cfg_reg pinmux_config_regs[] = {
                PK1_IN, PK1_OUT,
                PK0_IN, PK0_OUT ))
        },
-       {}
+       { /* sentinel */ }
 };
 
 static const struct pinmux_data_reg pinmux_data_regs[] = {
@@ -2109,7 +2109,7 @@ static const struct pinmux_data_reg pinmux_data_regs[] = {
                PK7_DATA, PK6_DATA, PK5_DATA, PK4_DATA,
                PK3_DATA, PK2_DATA, PK1_DATA, PK0_DATA ))
        },
-       { }
+       { /* sentinel */ }
 };
 
 const struct sh_pfc_soc_info sh7264_pinmux_info = {
index f59f558d75ae253e0cb0b8fdd03378589b9370dd..3569093f17ae63a445f13e6a0e471f518cdb5353 100644 (file)
@@ -2749,8 +2749,7 @@ static const struct pinmux_cfg_reg pinmux_config_regs[] = {
                PJ1_IN, PJ1_OUT,
                PJ0_IN, PJ0_OUT ))
        },
-
-       {}
+       { /* sentinel */ }
 };
 
 static const struct pinmux_data_reg pinmux_data_regs[] = {
@@ -2828,8 +2827,7 @@ static const struct pinmux_data_reg pinmux_data_regs[] = {
                PJ7_DATA, PJ6_DATA, PJ5_DATA, PJ4_DATA,
                PJ3_DATA, PJ2_DATA, PJ1_DATA, PJ0_DATA ))
        },
-
-       { }
+       { /* sentinel */ }
 };
 
 const struct sh_pfc_soc_info sh7269_pinmux_info = {
index 4f54dfd5a9674916e3ee66a1d5cb07bb7d7ac8b7..ca5adf2095be31673754b4063ac6e76d622f2935 100644 (file)
@@ -3876,7 +3876,7 @@ static const struct pinmux_cfg_reg pinmux_config_regs[] = {
                        /* RESERVED [1] */
                ))
        },
-       { },
+       { /* sentinel */ }
 };
 
 static const struct pinmux_data_reg pinmux_data_regs[] = {
@@ -3980,7 +3980,7 @@ static const struct pinmux_data_reg pinmux_data_regs[] = {
                        PORT295_DATA, PORT294_DATA, PORT293_DATA, PORT292_DATA,
                        PORT291_DATA, PORT290_DATA, PORT289_DATA, PORT288_DATA ))
        },
-       { },
+       { /* sentinel */ }
 };
 
 static const struct pinmux_irq pinmux_irqs[] = {
index 6eedcc5bbb4d6705dbf762024d1ba55a6c23bbfb..91434743fb1c435232acf6188a9279ae9a7e23e1 100644 (file)
@@ -1103,7 +1103,7 @@ static const struct pinmux_cfg_reg pinmux_config_regs[] = {
                PTV1_FN, PTV1_OUT, 0, PTV1_IN,
                PTV0_FN, PTV0_OUT, 0, PTV0_IN ))
        },
-       {}
+       { /* sentinel */ }
 };
 
 static const struct pinmux_data_reg pinmux_data_regs[] = {
@@ -1179,7 +1179,7 @@ static const struct pinmux_data_reg pinmux_data_regs[] = {
                0, 0, 0, PTV4_DATA,
                PTV3_DATA, PTV2_DATA, PTV1_DATA, PTV0_DATA ))
        },
-       { },
+       { /* sentinel */ }
 };
 
 const struct sh_pfc_soc_info sh7720_pinmux_info = {
index 4b82ac2c5e91d787eeca8daca48d640e1d995db1..54b4625b52cf03430f25092c9033f85e75a35be1 100644 (file)
@@ -1585,7 +1585,7 @@ static const struct pinmux_cfg_reg pinmux_config_regs[] = {
                MSELB8_RGB, MSELB8_SYS,
                /* RESERVED [8] */ ))
        },
-       {}
+       { /* sentinel */ }
 };
 
 static const struct pinmux_data_reg pinmux_data_regs[] = {
@@ -1681,7 +1681,7 @@ static const struct pinmux_data_reg pinmux_data_regs[] = {
                0, 0, PTZ5_DATA, PTZ4_DATA,
                PTZ3_DATA, PTZ2_DATA, PTZ1_DATA, PTZ0_DATA ))
        },
-       { },
+       { /* sentinel */ }
 };
 
 const struct sh_pfc_soc_info sh7722_pinmux_info = {
index 95344281966e6eb09514cdad655418097b1c44d1..c1abdec9bf1d60df76910484dd17d54d7c6fb107 100644 (file)
@@ -1784,7 +1784,7 @@ static const struct pinmux_cfg_reg pinmux_config_regs[] = {
                PSD3_PSD2_FN1, PSD3_PSD2_FN2, 0, 0,
                PSD1_PSD0_FN1, PSD1_PSD0_FN2, 0, 0 ))
        },
-       {}
+       { /* sentinel */ }
 };
 
 static const struct pinmux_data_reg pinmux_data_regs[] = {
@@ -1880,7 +1880,7 @@ static const struct pinmux_data_reg pinmux_data_regs[] = {
                PTZ7_DATA, PTZ6_DATA, PTZ5_DATA, PTZ4_DATA,
                PTZ3_DATA, PTZ2_DATA, PTZ1_DATA, PTZ0_DATA ))
        },
-       { },
+       { /* sentinel */ }
 };
 
 const struct sh_pfc_soc_info sh7723_pinmux_info = {
index 26517ad26a0fd1b849f9de3a518e1419e8f2f233..5148a3460cc6f0b4a62f16328f41e8e7b18010dd 100644 (file)
@@ -2059,7 +2059,7 @@ static const struct pinmux_cfg_reg pinmux_config_regs[] = {
                PSE1_0,  PSE1_1,
                PSE0_0,  PSE0_1))
        },
-       {}
+       { /* sentinel */ }
 };
 
 static const struct pinmux_data_reg pinmux_data_regs[] = {
@@ -2155,7 +2155,7 @@ static const struct pinmux_data_reg pinmux_data_regs[] = {
                PTZ7_DATA, PTZ6_DATA, PTZ5_DATA, PTZ4_DATA,
                PTZ3_DATA, PTZ2_DATA, PTZ1_DATA, PTZ0_DATA ))
        },
-       { },
+       { /* sentinel */ }
 };
 
 const struct sh_pfc_soc_info sh7724_pinmux_info = {
index 106a500ad13d160e1fb848a7a44a538e9debc4b1..a0a5d8b94086f0b9260f56bde050079feb276d71 100644 (file)
@@ -2366,7 +2366,7 @@ static const struct pinmux_cfg_reg pinmux_config_regs[] = {
                GP_5_1_IN, GP_5_1_OUT,
                GP_5_0_IN, GP_5_0_OUT ))
        },
-       { },
+       { /* sentinel */ }
 };
 
 static const struct pinmux_data_reg pinmux_data_regs[] = {
@@ -2383,7 +2383,7 @@ static const struct pinmux_data_reg pinmux_data_regs[] = {
                GP_5_7_DATA, GP_5_6_DATA, GP_5_5_DATA, GP_5_4_DATA,
                GP_5_3_DATA, GP_5_2_DATA, GP_5_1_DATA, GP_5_0_DATA ))
        },
-       { },
+       { /* sentinel */ }
 };
 
 const struct sh_pfc_soc_info sh7734_pinmux_info = {
index 0d7857d7efefb47b7dcc48b1dfb46e8bc56740d4..817b22c3e6395d3d6485e6543258905258a63310 100644 (file)
@@ -2089,7 +2089,7 @@ static const struct pinmux_cfg_reg pinmux_config_regs[] = {
                PS8_8_FN1, PS8_8_FN2,
                /* RESERVED [8] */ ))
        },
-       {}
+       { /* sentinel */ }
 };
 
 static const struct pinmux_data_reg pinmux_data_regs[] = {
@@ -2197,7 +2197,7 @@ static const struct pinmux_data_reg pinmux_data_regs[] = {
                PTZ7_DATA, PTZ6_DATA, PTZ5_DATA, PTZ4_DATA,
                PTZ3_DATA, PTZ2_DATA, PTZ1_DATA, PTZ0_DATA ))
        },
-       { },
+       { /* sentinel */ }
 };
 
 const struct sh_pfc_soc_info sh7757_pinmux_info = {
index 126b663bb6eb3abe6ccab4c5d34b4723e68066fe..0b6fbbac7c6dfc9405cd980b83baed4d887f4462 100644 (file)
@@ -1168,7 +1168,7 @@ static const struct pinmux_cfg_reg pinmux_config_regs[] = {
                P2MSEL1_0, P2MSEL1_1,
                P2MSEL0_0, P2MSEL0_1 ))
        },
-       {}
+       { /* sentinel */ }
 };
 
 static const struct pinmux_data_reg pinmux_data_regs[] = {
@@ -1236,7 +1236,7 @@ static const struct pinmux_data_reg pinmux_data_regs[] = {
                0, 0, 0, 0,
                PR3_DATA, PR2_DATA, PR1_DATA, PR0_DATA ))
        },
-       { },
+       { /* sentinel */ }
 };
 
 const struct sh_pfc_soc_info sh7785_pinmux_info = {
index f09f4a76901088b4c42fd46162717d662feeee6e..a1ff39c5424d12443efdea21ca9cf93e67f52208 100644 (file)
@@ -747,7 +747,7 @@ static const struct pinmux_cfg_reg pinmux_config_regs[] = {
                P2MSEL1_0,  P2MSEL1_1,
                P2MSEL0_0,  P2MSEL0_1 ))
        },
-       {}
+       { /* sentinel */ }
 };
 
 static const struct pinmux_data_reg pinmux_data_regs[] = {
@@ -787,7 +787,7 @@ static const struct pinmux_data_reg pinmux_data_regs[] = {
                PJ7_DATA, PJ6_DATA, PJ5_DATA, PJ4_DATA,
                PJ3_DATA, PJ2_DATA, PJ1_DATA, 0 ))
        },
-       { },
+       { /* sentinel */ }
 };
 
 const struct sh_pfc_soc_info sh7786_pinmux_info = {
index 96a65d83774f16a7d845c2c0594a288b9f7df2a5..e2ba5e3b9ec3f3178263f8c8f4c7f630cb0bc4a4 100644 (file)
@@ -502,7 +502,7 @@ static const struct pinmux_cfg_reg pinmux_config_regs[] = {
                PH1_FN, PH1_OUT, PH1_IN, 0,
                PH0_FN, PH0_OUT, PH0_IN, 0, ))
        },
-       { },
+       { /* sentinel */ }
 };
 
 static const struct pinmux_data_reg pinmux_data_regs[] = {
@@ -538,7 +538,7 @@ static const struct pinmux_data_reg pinmux_data_regs[] = {
                0, 0, PH5_DATA, PH4_DATA,
                PH3_DATA, PH2_DATA, PH1_DATA, PH0_DATA, ))
        },
-       { },
+       { /* sentinel */ }
 };
 
 const struct sh_pfc_soc_info shx3_pinmux_info = {
index 48173355a040aa10d1edcd778d04ca03f8dd5afa..68c7af5d86bc7ce67dd2e442d3cfc0255ed6e81f 100644 (file)
@@ -1388,7 +1388,7 @@ static const struct of_device_id rza1_pinctrl_of_match[] = {
                .compatible     = "renesas,r7s72102-ports",
                .data           = &rza1l_pmx_conf,
        },
-       { }
+       { /* sentinel */ }
 };
 
 static struct platform_driver rza1_pinctrl_driver = {
index d73741651419faa8d96d9cd8bf9db9dac6673a6e..374b9f2813243bd8578f74123fde98e17f13af78 100644 (file)
@@ -931,7 +931,7 @@ static int rzn1_pinctrl_remove(struct platform_device *pdev)
 
 static const struct of_device_id rzn1_pinctrl_match[] = {
        { .compatible = "renesas,rzn1-pinctrl", },
-       {}
+       { /* sentinel */ }
 };
 MODULE_DEVICE_TABLE(of, rzn1_pinctrl_match);
 
index b7414780031990e2aba2e74f6eeddc623f290d6f..4d9d58fc1356ff53500ee46c622bb27cbb22f647 100644 (file)
@@ -40,10 +40,6 @@ struct sh_pfc_pinctrl {
 
        struct pinctrl_pin_desc *pins;
        struct sh_pfc_pin_config *configs;
-
-       const char *func_prop_name;
-       const char *groups_prop_name;
-       const char *pins_prop_name;
 };
 
 static int sh_pfc_get_groups_count(struct pinctrl_dev *pctldev)
@@ -120,27 +116,10 @@ static int sh_pfc_dt_subnode_to_map(struct pinctrl_dev *pctldev,
        const char *pin;
        int ret;
 
-       /* Support both the old Renesas-specific properties and the new standard
-        * properties. Mixing old and new properties isn't allowed, neither
-        * inside a subnode nor across subnodes.
-        */
-       if (!pmx->func_prop_name) {
-               if (of_find_property(np, "groups", NULL) ||
-                   of_find_property(np, "pins", NULL)) {
-                       pmx->func_prop_name = "function";
-                       pmx->groups_prop_name = "groups";
-                       pmx->pins_prop_name = "pins";
-               } else {
-                       pmx->func_prop_name = "renesas,function";
-                       pmx->groups_prop_name = "renesas,groups";
-                       pmx->pins_prop_name = "renesas,pins";
-               }
-       }
-
        /* Parse the function and configuration properties. At least a function
         * or one configuration must be specified.
         */
-       ret = of_property_read_string(np, pmx->func_prop_name, &function);
+       ret = of_property_read_string(np, "function", &function);
        if (ret < 0 && ret != -EINVAL) {
                dev_err(dev, "Invalid function in DT\n");
                return ret;
@@ -158,7 +137,7 @@ static int sh_pfc_dt_subnode_to_map(struct pinctrl_dev *pctldev,
        }
 
        /* Count the number of pins and groups and reallocate mappings. */
-       ret = of_property_count_strings(np, pmx->pins_prop_name);
+       ret = of_property_count_strings(np, "pins");
        if (ret == -EINVAL) {
                num_pins = 0;
        } else if (ret < 0) {
@@ -168,7 +147,7 @@ static int sh_pfc_dt_subnode_to_map(struct pinctrl_dev *pctldev,
                num_pins = ret;
        }
 
-       ret = of_property_count_strings(np, pmx->groups_prop_name);
+       ret = of_property_count_strings(np, "groups");
        if (ret == -EINVAL) {
                num_groups = 0;
        } else if (ret < 0) {
@@ -199,7 +178,7 @@ static int sh_pfc_dt_subnode_to_map(struct pinctrl_dev *pctldev,
        *num_maps = nmaps;
 
        /* Iterate over pins and groups and create the mappings. */
-       of_property_for_each_string(np, pmx->groups_prop_name, prop, group) {
+       of_property_for_each_string(np, "groups", prop, group) {
                if (function) {
                        maps[idx].type = PIN_MAP_TYPE_MUX_GROUP;
                        maps[idx].data.mux.group = group;
@@ -223,7 +202,7 @@ static int sh_pfc_dt_subnode_to_map(struct pinctrl_dev *pctldev,
                goto done;
        }
 
-       of_property_for_each_string(np, pmx->pins_prop_name, prop, pin) {
+       of_property_for_each_string(np, "pins", prop, pin) {
                ret = sh_pfc_map_add_config(&maps[idx], pin,
                                            PIN_MAP_TYPE_CONFIGS_PIN,
                                            configs, num_configs);
@@ -580,7 +559,7 @@ static bool sh_pfc_pinconf_validate(struct sh_pfc *pfc, unsigned int _pin,
                return pin->configs & SH_PFC_PIN_CFG_DRIVE_STRENGTH;
 
        case PIN_CONFIG_POWER_SOURCE:
-               return pin->configs & SH_PFC_PIN_CFG_IO_VOLTAGE;
+               return pin->configs & SH_PFC_PIN_CFG_IO_VOLTAGE_MASK;
 
        default:
                return false;
@@ -633,7 +612,7 @@ static int sh_pfc_pinconf_get(struct pinctrl_dev *pctldev, unsigned _pin,
        case PIN_CONFIG_POWER_SOURCE: {
                int idx = sh_pfc_get_pin_index(pfc, _pin);
                const struct sh_pfc_pin *pin = &pfc->info->pins[idx];
-               unsigned int lower_voltage;
+               unsigned int mode, lo, hi;
                u32 pocctrl, val;
                int bit;
 
@@ -646,10 +625,11 @@ static int sh_pfc_pinconf_get(struct pinctrl_dev *pctldev, unsigned _pin,
 
                val = sh_pfc_read(pfc, pocctrl);
 
-               lower_voltage = (pin->configs & SH_PFC_PIN_VOLTAGE_25_33) ?
-                       2500 : 1800;
+               mode = pin->configs & SH_PFC_PIN_CFG_IO_VOLTAGE_MASK;
+               lo = mode <= SH_PFC_PIN_CFG_IO_VOLTAGE_18_33 ? 1800 : 2500;
+               hi = mode >= SH_PFC_PIN_CFG_IO_VOLTAGE_18_33 ? 3300 : 2500;
 
-               arg = (val & BIT(bit)) ? 3300 : lower_voltage;
+               arg = (val & BIT(bit)) ? hi : lo;
                break;
        }
 
@@ -705,7 +685,7 @@ static int sh_pfc_pinconf_set(struct pinctrl_dev *pctldev, unsigned _pin,
                        unsigned int mV = pinconf_to_config_argument(configs[i]);
                        int idx = sh_pfc_get_pin_index(pfc, _pin);
                        const struct sh_pfc_pin *pin = &pfc->info->pins[idx];
-                       unsigned int lower_voltage;
+                       unsigned int mode, lo, hi;
                        u32 pocctrl, val;
                        int bit;
 
@@ -716,15 +696,16 @@ static int sh_pfc_pinconf_set(struct pinctrl_dev *pctldev, unsigned _pin,
                        if (WARN(bit < 0, "invalid pin %#x", _pin))
                                return bit;
 
-                       lower_voltage = (pin->configs & SH_PFC_PIN_VOLTAGE_25_33) ?
-                               2500 : 1800;
+                       mode = pin->configs & SH_PFC_PIN_CFG_IO_VOLTAGE_MASK;
+                       lo = mode <= SH_PFC_PIN_CFG_IO_VOLTAGE_18_33 ? 1800 : 2500;
+                       hi = mode >= SH_PFC_PIN_CFG_IO_VOLTAGE_18_33 ? 3300 : 2500;
 
-                       if (mV != lower_voltage && mV != 3300)
+                       if (mV != lo && mV != hi)
                                return -EINVAL;
 
                        spin_lock_irqsave(&pfc->lock, flags);
                        val = sh_pfc_read(pfc, pocctrl);
-                       if (mV == 3300)
+                       if (mV == hi)
                                val |= BIT(bit);
                        else
                                val &= ~BIT(bit);
index 0fcb29ab0c845812c9de53eb3b2645203aa2f3db..8dc7a66009ad842cdd068c5252975442aed8d0ea 100644 (file)
@@ -29,16 +29,13 @@ enum {
 #define SH_PFC_PIN_CFG_PULL_DOWN       (1 << 3)
 #define SH_PFC_PIN_CFG_PULL_UP_DOWN    (SH_PFC_PIN_CFG_PULL_UP | \
                                         SH_PFC_PIN_CFG_PULL_DOWN)
-#define SH_PFC_PIN_CFG_IO_VOLTAGE      (1 << 4)
-#define SH_PFC_PIN_CFG_DRIVE_STRENGTH  (1 << 5)
 
-#define SH_PFC_PIN_VOLTAGE_18_33       (0 << 6)
-#define SH_PFC_PIN_VOLTAGE_25_33       (1 << 6)
+#define SH_PFC_PIN_CFG_IO_VOLTAGE_MASK GENMASK(5, 4)
+#define SH_PFC_PIN_CFG_IO_VOLTAGE_18_25        (1 << 4)
+#define SH_PFC_PIN_CFG_IO_VOLTAGE_18_33        (2 << 4)
+#define SH_PFC_PIN_CFG_IO_VOLTAGE_25_33        (3 << 4)
 
-#define SH_PFC_PIN_CFG_IO_VOLTAGE_18_33        (SH_PFC_PIN_CFG_IO_VOLTAGE | \
-                                        SH_PFC_PIN_VOLTAGE_18_33)
-#define SH_PFC_PIN_CFG_IO_VOLTAGE_25_33        (SH_PFC_PIN_CFG_IO_VOLTAGE | \
-                                        SH_PFC_PIN_VOLTAGE_25_33)
+#define SH_PFC_PIN_CFG_DRIVE_STRENGTH  (1 << 6)
 
 #define SH_PFC_PIN_CFG_NO_GPIO         (1 << 31)
 
@@ -314,7 +311,6 @@ extern const struct sh_pfc_soc_info r8a7791_pinmux_info;
 extern const struct sh_pfc_soc_info r8a7792_pinmux_info;
 extern const struct sh_pfc_soc_info r8a7793_pinmux_info;
 extern const struct sh_pfc_soc_info r8a7794_pinmux_info;
-extern const struct sh_pfc_soc_info r8a77950_pinmux_info;
 extern const struct sh_pfc_soc_info r8a77951_pinmux_info;
 extern const struct sh_pfc_soc_info r8a77960_pinmux_info;
 extern const struct sh_pfc_soc_info r8a77961_pinmux_info;
index ada401ef4342695b5920fe83263203d36c45f105..722681e0b89b784fbe90dc50f712bf978089b7e0 100644 (file)
@@ -301,6 +301,7 @@ static void plgpio_irq_disable(struct irq_data *d)
        spin_lock_irqsave(&plgpio->lock, flags);
        plgpio_reg_set(plgpio->regmap, offset, plgpio->regs.ie);
        spin_unlock_irqrestore(&plgpio->lock, flags);
+       gpiochip_disable_irq(gc, irqd_to_hwirq(d));
 }
 
 static void plgpio_irq_enable(struct irq_data *d)
@@ -317,6 +318,7 @@ static void plgpio_irq_enable(struct irq_data *d)
                        return;
        }
 
+       gpiochip_enable_irq(gc, irqd_to_hwirq(d));
        spin_lock_irqsave(&plgpio->lock, flags);
        plgpio_reg_reset(plgpio->regmap, offset, plgpio->regs.ie);
        spin_unlock_irqrestore(&plgpio->lock, flags);
@@ -356,11 +358,13 @@ static int plgpio_irq_set_type(struct irq_data *d, unsigned trigger)
        return 0;
 }
 
-static struct irq_chip plgpio_irqchip = {
+static const struct irq_chip plgpio_irqchip = {
        .name           = "PLGPIO",
        .irq_enable     = plgpio_irq_enable,
        .irq_disable    = plgpio_irq_disable,
        .irq_set_type   = plgpio_irq_set_type,
+       .flags          = IRQCHIP_IMMUTABLE,
+       GPIOCHIP_IRQ_RESOURCE_HELPERS,
 };
 
 static void plgpio_irq_handler(struct irq_desc *desc)
@@ -595,7 +599,7 @@ static int plgpio_probe(struct platform_device *pdev)
                struct gpio_irq_chip *girq;
 
                girq = &plgpio->chip.irq;
-               girq->chip = &plgpio_irqchip;
+               gpio_irq_chip_set_chip(girq, &plgpio_irqchip);
                girq->parent_handler = plgpio_irq_handler;
                girq->num_parents = 1;
                girq->parents = devm_kcalloc(&pdev->dev, 1,
index 04ace4c7bd5826ed7eaa4db68d5345841093223c..4b97bd00191bcc48b2a08e9b28c32a16c0138ed5 100644 (file)
@@ -1374,7 +1374,7 @@ static struct irq_domain *stm32_pctrl_get_irq_domain(struct platform_device *pde
        struct device_node *parent;
        struct irq_domain *domain;
 
-       if (!of_find_property(np, "interrupt-parent", NULL))
+       if (!of_property_present(np, "interrupt-parent"))
                return NULL;
 
        parent = of_irq_find_parent(np);
index f35179eceb4e0504a26e8e63bdd0f7762e3c4680..1dc1882cbdd78f21039e58790807a0cefabaebdd 100644 (file)
@@ -224,16 +224,16 @@ static int sunxi_pctrl_get_group_pins(struct pinctrl_dev *pctldev,
 
 static bool sunxi_pctrl_has_bias_prop(struct device_node *node)
 {
-       return of_find_property(node, "bias-pull-up", NULL) ||
-               of_find_property(node, "bias-pull-down", NULL) ||
-               of_find_property(node, "bias-disable", NULL) ||
-               of_find_property(node, "allwinner,pull", NULL);
+       return of_property_present(node, "bias-pull-up") ||
+               of_property_present(node, "bias-pull-down") ||
+               of_property_present(node, "bias-disable") ||
+               of_property_present(node, "allwinner,pull");
 }
 
 static bool sunxi_pctrl_has_drive_prop(struct device_node *node)
 {
-       return of_find_property(node, "drive-strength", NULL) ||
-               of_find_property(node, "allwinner,drive", NULL);
+       return of_property_present(node, "drive-strength") ||
+               of_property_present(node, "allwinner,drive");
 }
 
 static int sunxi_pctrl_parse_bias_prop(struct device_node *node)
@@ -241,13 +241,13 @@ static int sunxi_pctrl_parse_bias_prop(struct device_node *node)
        u32 val;
 
        /* Try the new style binding */
-       if (of_find_property(node, "bias-pull-up", NULL))
+       if (of_property_present(node, "bias-pull-up"))
                return PIN_CONFIG_BIAS_PULL_UP;
 
-       if (of_find_property(node, "bias-pull-down", NULL))
+       if (of_property_present(node, "bias-pull-down"))
                return PIN_CONFIG_BIAS_PULL_DOWN;
 
-       if (of_find_property(node, "bias-disable", NULL))
+       if (of_property_present(node, "bias-disable"))
                return PIN_CONFIG_BIAS_DISABLE;
 
        /* And fall back to the old binding */
@@ -1424,7 +1424,7 @@ static int sunxi_pinctrl_setup_debounce(struct sunxi_pinctrl *pctl,
                return 0;
 
        /* If we don't have any setup, bail out */
-       if (!of_find_property(node, "input-debounce", NULL))
+       if (!of_property_present(node, "input-debounce"))
                return 0;
 
        losc = devm_clk_get(pctl->dev, "losc");