OSDN Git Service

pinctrl: nomadik: Drop U8540/9540 support
authorLinus Walleij <linus.walleij@linaro.org>
Thu, 22 Mar 2018 10:12:54 +0000 (11:12 +0100)
committerLinus Walleij <linus.walleij@linaro.org>
Fri, 23 Mar 2018 02:38:14 +0000 (03:38 +0100)
The U8540 was an evolved version of the U8500, but it was never
mass produced or put into products, only reference designs exist.
The upstream support was never completed and it is unlikely that
this will happen so drop the support for now to simplify
maintenance of the U8500.

Cc: Loic Pallardy <loic.pallardy@st.com>
Signed-off-by: Linus Walleij <linus.walleij@linaro.org>
drivers/pinctrl/nomadik/Kconfig
drivers/pinctrl/nomadik/Makefile
drivers/pinctrl/nomadik/pinctrl-ab8540.c [deleted file]
drivers/pinctrl/nomadik/pinctrl-ab9540.c [deleted file]
drivers/pinctrl/nomadik/pinctrl-abx500.c
drivers/pinctrl/nomadik/pinctrl-abx500.h
drivers/pinctrl/nomadik/pinctrl-nomadik-db8540.c [deleted file]

index f4fcebf..c3efe7d 100644 (file)
@@ -11,14 +11,6 @@ config PINCTRL_AB8500
        bool "AB8500 pin controller driver"
        depends on PINCTRL_ABX500 && ARCH_U8500
 
-config PINCTRL_AB8540
-       bool "AB8540 pin controller driver"
-       depends on PINCTRL_ABX500 && ARCH_U8500
-
-config PINCTRL_AB9540
-       bool "AB9540 pin controller driver"
-       depends on PINCTRL_ABX500 && ARCH_U8500
-
 config PINCTRL_AB8505
        bool "AB8505 pin controller driver"
        depends on PINCTRL_ABX500 && ARCH_U8500
@@ -44,8 +36,4 @@ config PINCTRL_DB8500
        bool "DB8500 pin controller driver"
        depends on PINCTRL_NOMADIK && ARCH_U8500
 
-config PINCTRL_DB8540
-       bool "DB8540 pin controller driver"
-       depends on PINCTRL_NOMADIK && ARCH_U8500
-
 endif
index bf8b751..dd10d49 100644 (file)
@@ -2,10 +2,7 @@
 # Nomadik family pin control drivers
 obj-$(CONFIG_PINCTRL_ABX500)   += pinctrl-abx500.o
 obj-$(CONFIG_PINCTRL_AB8500)   += pinctrl-ab8500.o
-obj-$(CONFIG_PINCTRL_AB8540)   += pinctrl-ab8540.o
-obj-$(CONFIG_PINCTRL_AB9540)   += pinctrl-ab9540.o
 obj-$(CONFIG_PINCTRL_AB8505)   += pinctrl-ab8505.o
 obj-$(CONFIG_PINCTRL_NOMADIK)  += pinctrl-nomadik.o
 obj-$(CONFIG_PINCTRL_STN8815)  += pinctrl-nomadik-stn8815.o
 obj-$(CONFIG_PINCTRL_DB8500)   += pinctrl-nomadik-db8500.o
-obj-$(CONFIG_PINCTRL_DB8540)   += pinctrl-nomadik-db8540.o
diff --git a/drivers/pinctrl/nomadik/pinctrl-ab8540.c b/drivers/pinctrl/nomadik/pinctrl-ab8540.c
deleted file mode 100644 (file)
index 9867535..0000000
+++ /dev/null
@@ -1,408 +0,0 @@
-/*
- * Copyright (C) ST-Ericsson SA 2012
- *
- * Author: Patrice Chotard <patrice.chotard@stericsson.com> for ST-Ericsson.
- *
- * This program is free software; you can redistribute it and/or modify
- * it under the terms of the GNU General Public License version 2 as
- * published by the Free Software Foundation.
- */
-
-#include <linux/kernel.h>
-#include <linux/gpio.h>
-#include <linux/pinctrl/pinctrl.h>
-#include <linux/mfd/abx500/ab8500.h>
-#include "pinctrl-abx500.h"
-
-/* All the pins that can be used for GPIO and some other functions */
-#define ABX500_GPIO(offset)            (offset)
-
-#define AB8540_PIN_J16         ABX500_GPIO(1)
-#define AB8540_PIN_D17         ABX500_GPIO(2)
-#define AB8540_PIN_C12         ABX500_GPIO(3)
-#define AB8540_PIN_G12         ABX500_GPIO(4)
-/* hole */
-#define AB8540_PIN_D16         ABX500_GPIO(14)
-#define AB8540_PIN_F15         ABX500_GPIO(15)
-#define AB8540_PIN_J8          ABX500_GPIO(16)
-#define AB8540_PIN_K16         ABX500_GPIO(17)
-#define AB8540_PIN_G15         ABX500_GPIO(18)
-#define AB8540_PIN_F17         ABX500_GPIO(19)
-#define AB8540_PIN_E17         ABX500_GPIO(20)
-/* hole */
-#define AB8540_PIN_AA16                ABX500_GPIO(27)
-#define AB8540_PIN_W18         ABX500_GPIO(28)
-#define AB8540_PIN_Y15         ABX500_GPIO(29)
-#define AB8540_PIN_W16         ABX500_GPIO(30)
-#define AB8540_PIN_V15         ABX500_GPIO(31)
-#define AB8540_PIN_W17         ABX500_GPIO(32)
-/* hole */
-#define AB8540_PIN_D12         ABX500_GPIO(42)
-#define AB8540_PIN_P4          ABX500_GPIO(43)
-#define AB8540_PIN_AB1         ABX500_GPIO(44)
-#define AB8540_PIN_K7          ABX500_GPIO(45)
-#define AB8540_PIN_L7          ABX500_GPIO(46)
-#define AB8540_PIN_G10         ABX500_GPIO(47)
-#define AB8540_PIN_K12         ABX500_GPIO(48)
-/* hole */
-#define AB8540_PIN_N8          ABX500_GPIO(51)
-#define AB8540_PIN_P12         ABX500_GPIO(52)
-#define AB8540_PIN_K8          ABX500_GPIO(53)
-#define AB8540_PIN_J11         ABX500_GPIO(54)
-#define AB8540_PIN_AC2         ABX500_GPIO(55)
-#define AB8540_PIN_AB2         ABX500_GPIO(56)
-
-/* indicates the highest GPIO number */
-#define AB8540_GPIO_MAX_NUMBER 56
-
-/*
- * The names of the pins are denoted by GPIO number and ball name, even
- * though they can be used for other things than GPIO, this is the first
- * column in the table of the data sheet and often used on schematics and
- * such.
- */
-static const struct pinctrl_pin_desc ab8540_pins[] = {
-       PINCTRL_PIN(AB8540_PIN_J16, "GPIO1_J16"),
-       PINCTRL_PIN(AB8540_PIN_D17, "GPIO2_D17"),
-       PINCTRL_PIN(AB8540_PIN_C12, "GPIO3_C12"),
-       PINCTRL_PIN(AB8540_PIN_G12, "GPIO4_G12"),
-       /* hole */
-       PINCTRL_PIN(AB8540_PIN_D16, "GPIO14_D16"),
-       PINCTRL_PIN(AB8540_PIN_F15, "GPIO15_F15"),
-       PINCTRL_PIN(AB8540_PIN_J8, "GPIO16_J8"),
-       PINCTRL_PIN(AB8540_PIN_K16, "GPIO17_K16"),
-       PINCTRL_PIN(AB8540_PIN_G15, "GPIO18_G15"),
-       PINCTRL_PIN(AB8540_PIN_F17, "GPIO19_F17"),
-       PINCTRL_PIN(AB8540_PIN_E17, "GPIO20_E17"),
-       /* hole */
-       PINCTRL_PIN(AB8540_PIN_AA16, "GPIO27_AA16"),
-       PINCTRL_PIN(AB8540_PIN_W18, "GPIO28_W18"),
-       PINCTRL_PIN(AB8540_PIN_Y15, "GPIO29_Y15"),
-       PINCTRL_PIN(AB8540_PIN_W16, "GPIO30_W16"),
-       PINCTRL_PIN(AB8540_PIN_V15, "GPIO31_V15"),
-       PINCTRL_PIN(AB8540_PIN_W17, "GPIO32_W17"),
-       /* hole */
-       PINCTRL_PIN(AB8540_PIN_D12, "GPIO42_D12"),
-       PINCTRL_PIN(AB8540_PIN_P4, "GPIO43_P4"),
-       PINCTRL_PIN(AB8540_PIN_AB1, "GPIO44_AB1"),
-       PINCTRL_PIN(AB8540_PIN_K7, "GPIO45_K7"),
-       PINCTRL_PIN(AB8540_PIN_L7, "GPIO46_L7"),
-       PINCTRL_PIN(AB8540_PIN_G10, "GPIO47_G10"),
-       PINCTRL_PIN(AB8540_PIN_K12, "GPIO48_K12"),
-       /* hole */
-       PINCTRL_PIN(AB8540_PIN_N8, "GPIO51_N8"),
-       PINCTRL_PIN(AB8540_PIN_P12, "GPIO52_P12"),
-       PINCTRL_PIN(AB8540_PIN_K8, "GPIO53_K8"),
-       PINCTRL_PIN(AB8540_PIN_J11, "GPIO54_J11"),
-       PINCTRL_PIN(AB8540_PIN_AC2, "GPIO55_AC2"),
-       PINCTRL_PIN(AB8540_PIN_AB2, "GPIO56_AB2"),
-};
-
-/*
- * Maps local GPIO offsets to local pin numbers
- */
-static const struct abx500_pinrange ab8540_pinranges[] = {
-       ABX500_PINRANGE(1, 4, ABX500_ALT_A),
-       ABX500_PINRANGE(14, 7, ABX500_ALT_A),
-       ABX500_PINRANGE(27, 6, ABX500_ALT_A),
-       ABX500_PINRANGE(42, 7, ABX500_ALT_A),
-       ABX500_PINRANGE(51, 6, ABX500_ALT_A),
-};
-
-/*
- * Read the pin group names like this:
- * sysclkreq2_d_1 = first groups of pins for sysclkreq2 on default function
- *
- * The groups are arranged as sets per altfunction column, so we can
- * mux in one group at a time by selecting the same altfunction for them
- * all. When functions require pins on different altfunctions, you need
- * to combine several groups.
- */
-
-/* default column */
-static const unsigned sysclkreq2_d_1_pins[] = { AB8540_PIN_J16 };
-static const unsigned sysclkreq3_d_1_pins[] = { AB8540_PIN_D17 };
-static const unsigned sysclkreq4_d_1_pins[] = { AB8540_PIN_C12 };
-static const unsigned sysclkreq6_d_1_pins[] = { AB8540_PIN_G12 };
-static const unsigned pwmout1_d_1_pins[] = { AB8540_PIN_D16 };
-static const unsigned pwmout2_d_1_pins[] = { AB8540_PIN_F15 };
-static const unsigned pwmout3_d_1_pins[] = { AB8540_PIN_J8 };
-
-/* audio data interface 1*/
-static const unsigned adi1_d_1_pins[] = { AB8540_PIN_K16, AB8540_PIN_G15,
-                                       AB8540_PIN_F17, AB8540_PIN_E17 };
-/* Digital microphone 1 and 2 */
-static const unsigned dmic12_d_1_pins[] = { AB8540_PIN_AA16, AB8540_PIN_W18 };
-/* Digital microphone 3 and 4 */
-static const unsigned dmic34_d_1_pins[] = { AB8540_PIN_Y15, AB8540_PIN_W16 };
-/* Digital microphone 5 and 6 */
-static const unsigned dmic56_d_1_pins[] = { AB8540_PIN_V15, AB8540_PIN_W17 };
-static const unsigned sysclkreq5_d_1_pins[] = { AB8540_PIN_D12 };
-static const unsigned batremn_d_1_pins[] = { AB8540_PIN_P4 };
-static const unsigned service_d_1_pins[] = { AB8540_PIN_AB1 };
-static const unsigned pwrctrl0_d_1_pins[] = { AB8540_PIN_K7 };
-static const unsigned pwrctrl1_d_1_pins[] = { AB8540_PIN_L7 };
-static const unsigned pwmextvibra1_d_1_pins[] = { AB8540_PIN_G10 };
-static const unsigned pwmextvibra2_d_1_pins[] = { AB8540_PIN_K12 };
-static const unsigned gpio1_vbat_d_1_pins[] = { AB8540_PIN_N8 };
-static const unsigned gpio2_vbat_d_1_pins[] = { AB8540_PIN_P12 };
-static const unsigned gpio3_vbat_d_1_pins[] = { AB8540_PIN_K8 };
-static const unsigned gpio4_vbat_d_1_pins[] = { AB8540_PIN_J11 };
-static const unsigned pdmclkdat_d_1_pins[] = { AB8540_PIN_AC2, AB8540_PIN_AB2 };
-
-/* Altfunction A column */
-static const unsigned gpio1_a_1_pins[] = { AB8540_PIN_J16 };
-static const unsigned gpio2_a_1_pins[] = { AB8540_PIN_D17 };
-static const unsigned gpio3_a_1_pins[] = { AB8540_PIN_C12 };
-static const unsigned gpio4_a_1_pins[] = { AB8540_PIN_G12 };
-static const unsigned gpio14_a_1_pins[] = { AB8540_PIN_D16 };
-static const unsigned gpio15_a_1_pins[] = { AB8540_PIN_F15 };
-static const unsigned gpio16_a_1_pins[] = { AB8540_PIN_J8 };
-static const unsigned gpio17_a_1_pins[] = { AB8540_PIN_K16 };
-static const unsigned gpio18_a_1_pins[] = { AB8540_PIN_G15 };
-static const unsigned gpio19_a_1_pins[] = { AB8540_PIN_F17 };
-static const unsigned gpio20_a_1_pins[] = { AB8540_PIN_E17 };
-static const unsigned gpio27_a_1_pins[] = { AB8540_PIN_AA16 };
-static const unsigned gpio28_a_1_pins[] = { AB8540_PIN_W18 };
-static const unsigned gpio29_a_1_pins[] = { AB8540_PIN_Y15 };
-static const unsigned gpio30_a_1_pins[] = { AB8540_PIN_W16 };
-static const unsigned gpio31_a_1_pins[] = { AB8540_PIN_V15 };
-static const unsigned gpio32_a_1_pins[] = { AB8540_PIN_W17 };
-static const unsigned gpio42_a_1_pins[] = { AB8540_PIN_D12 };
-static const unsigned gpio43_a_1_pins[] = { AB8540_PIN_P4 };
-static const unsigned gpio44_a_1_pins[] = { AB8540_PIN_AB1 };
-static const unsigned gpio45_a_1_pins[] = { AB8540_PIN_K7 };
-static const unsigned gpio46_a_1_pins[] = { AB8540_PIN_L7 };
-static const unsigned gpio47_a_1_pins[] = { AB8540_PIN_G10 };
-static const unsigned gpio48_a_1_pins[] = { AB8540_PIN_K12 };
-static const unsigned gpio51_a_1_pins[] = { AB8540_PIN_N8 };
-static const unsigned gpio52_a_1_pins[] = { AB8540_PIN_P12 };
-static const unsigned gpio53_a_1_pins[] = { AB8540_PIN_K8 };
-static const unsigned gpio54_a_1_pins[] = { AB8540_PIN_J11 };
-static const unsigned gpio55_a_1_pins[] = { AB8540_PIN_AC2 };
-static const unsigned gpio56_a_1_pins[] = { AB8540_PIN_AB2 };
-
-#define AB8540_PIN_GROUP(a, b) { .name = #a, .pins = a##_pins,         \
-                       .npins = ARRAY_SIZE(a##_pins), .altsetting = b }
-
-static const struct abx500_pingroup ab8540_groups[] = {
-       /* default column */
-       AB8540_PIN_GROUP(sysclkreq2_d_1, ABX500_DEFAULT),
-       AB8540_PIN_GROUP(sysclkreq3_d_1, ABX500_DEFAULT),
-       AB8540_PIN_GROUP(sysclkreq4_d_1, ABX500_DEFAULT),
-       AB8540_PIN_GROUP(sysclkreq6_d_1, ABX500_DEFAULT),
-       AB8540_PIN_GROUP(pwmout1_d_1, ABX500_DEFAULT),
-       AB8540_PIN_GROUP(pwmout2_d_1, ABX500_DEFAULT),
-       AB8540_PIN_GROUP(pwmout3_d_1, ABX500_DEFAULT),
-       AB8540_PIN_GROUP(adi1_d_1, ABX500_DEFAULT),
-       AB8540_PIN_GROUP(dmic12_d_1, ABX500_DEFAULT),
-       AB8540_PIN_GROUP(dmic34_d_1, ABX500_DEFAULT),
-       AB8540_PIN_GROUP(dmic56_d_1, ABX500_DEFAULT),
-       AB8540_PIN_GROUP(sysclkreq5_d_1, ABX500_DEFAULT),
-       AB8540_PIN_GROUP(batremn_d_1, ABX500_DEFAULT),
-       AB8540_PIN_GROUP(service_d_1, ABX500_DEFAULT),
-       AB8540_PIN_GROUP(pwrctrl0_d_1, ABX500_DEFAULT),
-       AB8540_PIN_GROUP(pwrctrl1_d_1, ABX500_DEFAULT),
-       AB8540_PIN_GROUP(pwmextvibra1_d_1, ABX500_DEFAULT),
-       AB8540_PIN_GROUP(pwmextvibra2_d_1, ABX500_DEFAULT),
-       AB8540_PIN_GROUP(gpio1_vbat_d_1, ABX500_DEFAULT),
-       AB8540_PIN_GROUP(gpio2_vbat_d_1, ABX500_DEFAULT),
-       AB8540_PIN_GROUP(gpio3_vbat_d_1, ABX500_DEFAULT),
-       AB8540_PIN_GROUP(gpio4_vbat_d_1, ABX500_DEFAULT),
-       AB8540_PIN_GROUP(pdmclkdat_d_1, ABX500_DEFAULT),
-       /* Altfunction A column */
-       AB8540_PIN_GROUP(gpio1_a_1, ABX500_ALT_A),
-       AB8540_PIN_GROUP(gpio2_a_1, ABX500_ALT_A),
-       AB8540_PIN_GROUP(gpio3_a_1, ABX500_ALT_A),
-       AB8540_PIN_GROUP(gpio4_a_1, ABX500_ALT_A),
-       AB8540_PIN_GROUP(gpio14_a_1, ABX500_ALT_A),
-       AB8540_PIN_GROUP(gpio15_a_1, ABX500_ALT_A),
-       AB8540_PIN_GROUP(gpio16_a_1, ABX500_ALT_A),
-       AB8540_PIN_GROUP(gpio17_a_1, ABX500_ALT_A),
-       AB8540_PIN_GROUP(gpio18_a_1, ABX500_ALT_A),
-       AB8540_PIN_GROUP(gpio19_a_1, ABX500_ALT_A),
-       AB8540_PIN_GROUP(gpio20_a_1, ABX500_ALT_A),
-       AB8540_PIN_GROUP(gpio27_a_1, ABX500_ALT_A),
-       AB8540_PIN_GROUP(gpio28_a_1, ABX500_ALT_A),
-       AB8540_PIN_GROUP(gpio29_a_1, ABX500_ALT_A),
-       AB8540_PIN_GROUP(gpio30_a_1, ABX500_ALT_A),
-       AB8540_PIN_GROUP(gpio31_a_1, ABX500_ALT_A),
-       AB8540_PIN_GROUP(gpio32_a_1, ABX500_ALT_A),
-       AB8540_PIN_GROUP(gpio42_a_1, ABX500_ALT_A),
-       AB8540_PIN_GROUP(gpio43_a_1, ABX500_ALT_A),
-       AB8540_PIN_GROUP(gpio44_a_1, ABX500_ALT_A),
-       AB8540_PIN_GROUP(gpio45_a_1, ABX500_ALT_A),
-       AB8540_PIN_GROUP(gpio46_a_1, ABX500_ALT_A),
-       AB8540_PIN_GROUP(gpio47_a_1, ABX500_ALT_A),
-       AB8540_PIN_GROUP(gpio48_a_1, ABX500_ALT_A),
-       AB8540_PIN_GROUP(gpio51_a_1, ABX500_ALT_A),
-       AB8540_PIN_GROUP(gpio52_a_1, ABX500_ALT_A),
-       AB8540_PIN_GROUP(gpio53_a_1, ABX500_ALT_A),
-       AB8540_PIN_GROUP(gpio54_a_1, ABX500_ALT_A),
-       AB8540_PIN_GROUP(gpio55_a_1, ABX500_ALT_A),
-       AB8540_PIN_GROUP(gpio56_a_1, ABX500_ALT_A),
-};
-
-/* We use this macro to define the groups applicable to a function */
-#define AB8540_FUNC_GROUPS(a, b...)       \
-static const char * const a##_groups[] = { b };
-
-AB8540_FUNC_GROUPS(sysclkreq, "sysclkreq2_d_1", "sysclkreq3_d_1",
-               "sysclkreq4_d_1", "sysclkreq5_d_1", "sysclkreq6_d_1");
-AB8540_FUNC_GROUPS(gpio, "gpio1_a_1", "gpio2_a_1", "gpio3_a_1", "gpio4_a_1",
-               "gpio14_a_1", "gpio15_a_1", "gpio16_a_1", "gpio17_a_1",
-               "gpio18_a_1", "gpio19_a_1", "gpio20_a_1", "gpio27_a_1",
-               "gpio28_a_1", "gpio29_a_1", "gpio30_a_1", "gpio31_a_1",
-               "gpio32_a_1", "gpio42_a_1", "gpio43_a_1", "gpio44_a_1",
-               "gpio45_a_1", "gpio46_a_1", "gpio47_a_1", "gpio48_a_1",
-               "gpio51_a_1", "gpio52_a_1", "gpio53_a_1", "gpio54_a_1",
-               "gpio55_a_1", "gpio56_a_1");
-AB8540_FUNC_GROUPS(pwmout, "pwmout1_d_1", "pwmout2_d_1", "pwmout3_d_1");
-AB8540_FUNC_GROUPS(adi1, "adi1_d_1");
-AB8540_FUNC_GROUPS(dmic, "dmic12_d_1", "dmic34_d_1", "dmic56_d_1");
-AB8540_FUNC_GROUPS(batremn, "batremn_d_1");
-AB8540_FUNC_GROUPS(service, "service_d_1");
-AB8540_FUNC_GROUPS(pwrctrl, "pwrctrl0_d_1", "pwrctrl1_d_1");
-AB8540_FUNC_GROUPS(pwmextvibra, "pwmextvibra1_d_1", "pwmextvibra2_d_1");
-AB8540_FUNC_GROUPS(gpio_vbat, "gpio1_vbat_d_1", "gpio2_vbat_d_1",
-               "gpio3_vbat_d_1", "gpio4_vbat_d_1");
-AB8540_FUNC_GROUPS(pdm, "pdmclkdat_d_1");
-
-#define FUNCTION(fname)                                        \
-       {                                               \
-               .name = #fname,                         \
-               .groups = fname##_groups,               \
-               .ngroups = ARRAY_SIZE(fname##_groups),  \
-       }
-
-static const struct abx500_function ab8540_functions[] = {
-       FUNCTION(sysclkreq),
-       FUNCTION(gpio),
-       FUNCTION(pwmout),
-       FUNCTION(adi1),
-       FUNCTION(dmic),
-       FUNCTION(batremn),
-       FUNCTION(service),
-       FUNCTION(pwrctrl),
-       FUNCTION(pwmextvibra),
-       FUNCTION(gpio_vbat),
-       FUNCTION(pdm),
-};
-
-/*
- * this table translates what's is in the AB8540 specification regarding the
- * balls alternate functions (as for DB, default, ALT_A, ALT_B and ALT_C).
- * ALTERNATE_FUNCTIONS(GPIO_NUMBER, GPIOSEL bit, ALTERNATFUNC bit1,
- * ALTERNATEFUNC bit2, ALTA val, ALTB val, ALTC val),
- * AB8540 only supports DEFAULT and ALTA functions, so ALTERNATFUNC
- * registers is not used
- *
- */
-
-static struct
-alternate_functions ab8540_alternate_functions[AB8540_GPIO_MAX_NUMBER + 1] = {
-       /* GPIOSEL1 - bit 4-7 reserved */
-       ALTERNATE_FUNCTIONS(0, UNUSED, UNUSED, UNUSED, 0, 0, 0), /* no GPIO0 */
-       ALTERNATE_FUNCTIONS(1,      0, UNUSED, UNUSED, 0, 0, 0), /* GPIO1, altA controlled by bit 0 */
-       ALTERNATE_FUNCTIONS(2,      1, UNUSED, UNUSED, 0, 0, 0), /* GPIO2, altA controlled by bit 1 */
-       ALTERNATE_FUNCTIONS(3,      2, UNUSED, UNUSED, 0, 0, 0), /* GPIO3, altA controlled by bit 2*/
-       ALTERNATE_FUNCTIONS(4,      3, UNUSED, UNUSED, 0, 0, 0), /* GPIO4, altA controlled by bit 3*/
-       ALTERNATE_FUNCTIONS(5, UNUSED, UNUSED, UNUSED, 0, 0, 0), /* no GPIO5 */
-       ALTERNATE_FUNCTIONS(6, UNUSED, UNUSED, UNUSED, 0, 0, 0), /* no GPIO6 */
-       ALTERNATE_FUNCTIONS(7, UNUSED, UNUSED, UNUSED, 0, 0, 0), /* no GPIO7 */
-       ALTERNATE_FUNCTIONS(8, UNUSED, UNUSED, UNUSED, 0, 0, 0), /* no GPIO8 */
-       /* GPIOSEL2 - bit 0-4 reserved */
-       ALTERNATE_FUNCTIONS(9,  UNUSED, UNUSED, UNUSED, 0, 0, 0), /* no GPIO9 */
-       ALTERNATE_FUNCTIONS(10, UNUSED, UNUSED, UNUSED, 0, 0, 0), /* no GPIO10 */
-       ALTERNATE_FUNCTIONS(11, UNUSED, UNUSED, UNUSED, 0, 0, 0), /* no GPIO11 */
-       ALTERNATE_FUNCTIONS(12, UNUSED, UNUSED, UNUSED, 0, 0, 0), /* no GPIO12 */
-       ALTERNATE_FUNCTIONS(13, UNUSED, UNUSED, UNUSED, 0, 0, 0), /* no GPIO13 */
-       ALTERNATE_FUNCTIONS(14,      5, UNUSED, UNUSED, 0, 0, 0), /* GPIO14, altA controlled by bit 5 */
-       ALTERNATE_FUNCTIONS(15,      6, UNUSED, UNUSED, 0, 0, 0), /* GPIO15, altA controlled by bit 6 */
-       ALTERNATE_FUNCTIONS(16,      7, UNUSED, UNUSED, 0, 0, 0), /* GPIO16, altA controlled by bit 7 */
-       /* GPIOSEL3 - bit 4-7 reserved */
-       ALTERNATE_FUNCTIONS(17,      0, UNUSED, UNUSED, 0, 0, 0), /* GPIO17, altA controlled by bit 0 */
-       ALTERNATE_FUNCTIONS(18,      1, UNUSED, UNUSED, 0, 0, 0), /* GPIO18, altA controlled by bit 1 */
-       ALTERNATE_FUNCTIONS(19,      2, UNUSED, UNUSED, 0, 0, 0), /* GPIO19, altA controlled by bit 2 */
-       ALTERNATE_FUNCTIONS(20,      3, UNUSED, UNUSED, 0, 0, 0), /* GPIO20, altA controlled by bit 3 */
-       ALTERNATE_FUNCTIONS(21, UNUSED, UNUSED, UNUSED, 0, 0, 0), /* no GPIO21 */
-       ALTERNATE_FUNCTIONS(22, UNUSED, UNUSED, UNUSED, 0, 0, 0), /* no GPIO22 */
-       ALTERNATE_FUNCTIONS(23, UNUSED, UNUSED, UNUSED, 0, 0, 0), /* no GPIO23 */
-       ALTERNATE_FUNCTIONS(24, UNUSED, UNUSED, UNUSED, 0, 0, 0), /* no GPIO24 */
-       /* GPIOSEL4 - bit 0-1 reserved */
-       ALTERNATE_FUNCTIONS(25, UNUSED, UNUSED, UNUSED, 0, 0, 0), /* no GPIO25 */
-       ALTERNATE_FUNCTIONS(26, UNUSED, UNUSED, UNUSED, 0, 0, 0), /* no GPIO26 */
-       ALTERNATE_FUNCTIONS(27,      2, UNUSED, UNUSED, 0, 0, 0), /* GPIO27, altA controlled by bit 2 */
-       ALTERNATE_FUNCTIONS(28,      3, UNUSED, UNUSED, 0, 0, 0), /* GPIO28, altA controlled by bit 3 */
-       ALTERNATE_FUNCTIONS(29,      4, UNUSED, UNUSED, 0, 0, 0), /* GPIO29, altA controlled by bit 4 */
-       ALTERNATE_FUNCTIONS(30,      5, UNUSED, UNUSED, 0, 0, 0), /* GPIO30, altA controlled by bit 5 */
-       ALTERNATE_FUNCTIONS(31,      6, UNUSED, UNUSED, 0, 0, 0), /* GPIO31, altA controlled by bit 6 */
-       ALTERNATE_FUNCTIONS(32,      7, UNUSED, UNUSED, 0, 0, 0), /* GPIO32, altA controlled by bit 7 */
-       /* GPIOSEL5 - bit 0-7 reserved */
-       ALTERNATE_FUNCTIONS(33, UNUSED, UNUSED, UNUSED, 0, 0, 0), /* no GPIO33 */
-       ALTERNATE_FUNCTIONS(34, UNUSED, UNUSED, UNUSED, 0, 0, 0), /* no GPIO34 */
-       ALTERNATE_FUNCTIONS(35, UNUSED, UNUSED, UNUSED, 0, 0, 0), /* no GPIO35 */
-       ALTERNATE_FUNCTIONS(36, UNUSED, UNUSED, UNUSED, 0, 0, 0), /* no GPIO36 */
-       ALTERNATE_FUNCTIONS(37, UNUSED, UNUSED, UNUSED, 0, 0, 0), /* no GPIO37 */
-       ALTERNATE_FUNCTIONS(38, UNUSED, UNUSED, UNUSED, 0, 0, 0), /* no GPIO38 */
-       ALTERNATE_FUNCTIONS(39, UNUSED, UNUSED, UNUSED, 0, 0, 0), /* no GPIO39 */
-       ALTERNATE_FUNCTIONS(40, UNUSED, UNUSED, UNUSED, 0, 0, 0), /* no GPIO40 */
-       /* GPIOSEL6 - bit 0 reserved */
-       ALTERNATE_FUNCTIONS(41, UNUSED, UNUSED, UNUSED, 0, 0, 0), /* no GPIO41 */
-       ALTERNATE_FUNCTIONS(42,      1, UNUSED, UNUSED, 0, 0, 0), /* GPIO42, altA controlled by bit 1 */
-       ALTERNATE_FUNCTIONS(43,      2, UNUSED, UNUSED, 0, 0, 0), /* GPIO43, altA controlled by bit 2 */
-       ALTERNATE_FUNCTIONS(44,      3, UNUSED, UNUSED, 0, 0, 0), /* GPIO44, altA controlled by bit 3 */
-       ALTERNATE_FUNCTIONS(45,      4, UNUSED, UNUSED, 0, 0, 0), /* GPIO45, altA controlled by bit 4 */
-       ALTERNATE_FUNCTIONS(46,      5, UNUSED, UNUSED, 0, 0, 0), /* GPIO46, altA controlled by bit 5 */
-       ALTERNATE_FUNCTIONS(47,      6, UNUSED, UNUSED, 0, 0, 0), /* GPIO47, altA controlled by bit 6 */
-       ALTERNATE_FUNCTIONS(48,      7, UNUSED, UNUSED, 0, 0, 0), /* GPIO48, altA controlled by bit 7 */
-       /* GPIOSEL7 - bit 0-1 reserved */
-       ALTERNATE_FUNCTIONS(49, UNUSED, UNUSED, UNUSED, 0, 0, 0), /* no GPIO49 */
-       ALTERNATE_FUNCTIONS(50, UNUSED, UNUSED, UNUSED, 0, 0, 0), /* no GPIO50 */
-       ALTERNATE_FUNCTIONS(51,      2, UNUSED, UNUSED, 0, 0, 0), /* GPIO51, altA controlled by bit 2 */
-       ALTERNATE_FUNCTIONS(52,      3, UNUSED, UNUSED, 0, 0, 0), /* GPIO52, altA controlled by bit 3 */
-       ALTERNATE_FUNCTIONS(53,      4, UNUSED, UNUSED, 0, 0, 0), /* GPIO53, altA controlled by bit 4 */
-       ALTERNATE_FUNCTIONS(54,      5, UNUSED, UNUSED, 0, 0, 0), /* GPIO54, altA controlled by bit 5 */
-       ALTERNATE_FUNCTIONS(55,      6, UNUSED, UNUSED, 0, 0, 0), /* GPIO55, altA controlled by bit 6 */
-       ALTERNATE_FUNCTIONS(56,      7, UNUSED, UNUSED, 0, 0, 0), /* GPIO56, altA controlled by bit 7 */
-};
-
-static struct pullud ab8540_pullud = {
-       .first_pin = 51,        /* GPIO1_VBAT */
-       .last_pin = 54,         /* GPIO4_VBAT */
-};
-
-/*
- * For AB8540 Only some GPIOs are interrupt capable:
- *     GPIO43 to GPIO44
- *     GPIO51 to GPIO54
- */
-static struct abx500_gpio_irq_cluster ab8540_gpio_irq_cluster[] = {
-       GPIO_IRQ_CLUSTER(43, 43, AB8540_INT_GPIO43F),
-       GPIO_IRQ_CLUSTER(44, 44, AB8540_INT_GPIO44F),
-       GPIO_IRQ_CLUSTER(51, 54, AB9540_INT_GPIO51R),
-};
-
-static struct abx500_pinctrl_soc_data ab8540_soc = {
-       .gpio_ranges = ab8540_pinranges,
-       .gpio_num_ranges = ARRAY_SIZE(ab8540_pinranges),
-       .pins = ab8540_pins,
-       .npins = ARRAY_SIZE(ab8540_pins),
-       .functions = ab8540_functions,
-       .nfunctions = ARRAY_SIZE(ab8540_functions),
-       .groups = ab8540_groups,
-       .ngroups = ARRAY_SIZE(ab8540_groups),
-       .alternate_functions = ab8540_alternate_functions,
-       .pullud = &ab8540_pullud,
-       .gpio_irq_cluster = ab8540_gpio_irq_cluster,
-       .ngpio_irq_cluster = ARRAY_SIZE(ab8540_gpio_irq_cluster),
-       .irq_gpio_rising_offset = AB8540_INT_GPIO43R,
-       .irq_gpio_falling_offset = AB8540_INT_GPIO43F,
-       .irq_gpio_factor = 2,
-};
-
-void
-abx500_pinctrl_ab8540_init(struct abx500_pinctrl_soc_data **soc)
-{
-       *soc = &ab8540_soc;
-}
diff --git a/drivers/pinctrl/nomadik/pinctrl-ab9540.c b/drivers/pinctrl/nomadik/pinctrl-ab9540.c
deleted file mode 100644 (file)
index 1a281ca..0000000
+++ /dev/null
@@ -1,486 +0,0 @@
-/*
- * Copyright (C) ST-Ericsson SA 2012
- *
- * Author: Patrice Chotard <patrice.chotard@stericsson.com> for ST-Ericsson.
- *
- * This program is free software; you can redistribute it and/or modify
- * it under the terms of the GNU General Public License version 2 as
- * published by the Free Software Foundation.
- */
-
-#include <linux/kernel.h>
-#include <linux/gpio.h>
-#include <linux/pinctrl/pinctrl.h>
-#include <linux/mfd/abx500/ab8500.h>
-#include "pinctrl-abx500.h"
-
-/* All the pins that can be used for GPIO and some other functions */
-#define ABX500_GPIO(offset)            (offset)
-
-#define AB9540_PIN_R4          ABX500_GPIO(1)
-#define AB9540_PIN_V3          ABX500_GPIO(2)
-#define AB9540_PIN_T4          ABX500_GPIO(3)
-#define AB9540_PIN_T5          ABX500_GPIO(4)
-/* hole */
-#define AB9540_PIN_B18         ABX500_GPIO(10)
-#define AB9540_PIN_C18         ABX500_GPIO(11)
-/* hole */
-#define AB9540_PIN_D18         ABX500_GPIO(13)
-#define AB9540_PIN_B19         ABX500_GPIO(14)
-#define AB9540_PIN_C19         ABX500_GPIO(15)
-#define AB9540_PIN_D19         ABX500_GPIO(16)
-#define AB9540_PIN_R3          ABX500_GPIO(17)
-#define AB9540_PIN_T2          ABX500_GPIO(18)
-#define AB9540_PIN_U2          ABX500_GPIO(19)
-#define AB9540_PIN_V2          ABX500_GPIO(20)
-#define AB9540_PIN_N17         ABX500_GPIO(21)
-#define AB9540_PIN_N16         ABX500_GPIO(22)
-#define AB9540_PIN_M19         ABX500_GPIO(23)
-#define AB9540_PIN_T3          ABX500_GPIO(24)
-#define AB9540_PIN_W2          ABX500_GPIO(25)
-/* hole */
-#define AB9540_PIN_H4          ABX500_GPIO(27)
-#define AB9540_PIN_F1          ABX500_GPIO(28)
-#define AB9540_PIN_F4          ABX500_GPIO(29)
-#define AB9540_PIN_F2          ABX500_GPIO(30)
-#define AB9540_PIN_E4          ABX500_GPIO(31)
-#define AB9540_PIN_F3          ABX500_GPIO(32)
-/* hole */
-#define AB9540_PIN_J13         ABX500_GPIO(34)
-/* hole */
-#define AB9540_PIN_L17         ABX500_GPIO(40)
-#define AB9540_PIN_L16         ABX500_GPIO(41)
-#define AB9540_PIN_W3          ABX500_GPIO(42)
-#define AB9540_PIN_N4          ABX500_GPIO(50)
-#define AB9540_PIN_G12         ABX500_GPIO(51)
-#define AB9540_PIN_E17         ABX500_GPIO(52)
-#define AB9540_PIN_D11         ABX500_GPIO(53)
-#define AB9540_PIN_M18         ABX500_GPIO(54)
-
-/* indicates the highest GPIO number */
-#define AB9540_GPIO_MAX_NUMBER 54
-
-/*
- * The names of the pins are denoted by GPIO number and ball name, even
- * though they can be used for other things than GPIO, this is the first
- * column in the table of the data sheet and often used on schematics and
- * such.
- */
-static const struct pinctrl_pin_desc ab9540_pins[] = {
-       PINCTRL_PIN(AB9540_PIN_R4, "GPIO1_R4"),
-       PINCTRL_PIN(AB9540_PIN_V3, "GPIO2_V3"),
-       PINCTRL_PIN(AB9540_PIN_T4, "GPIO3_T4"),
-       PINCTRL_PIN(AB9540_PIN_T5, "GPIO4_T5"),
-       /* hole */
-       PINCTRL_PIN(AB9540_PIN_B18, "GPIO10_B18"),
-       PINCTRL_PIN(AB9540_PIN_C18, "GPIO11_C18"),
-       /* hole */
-       PINCTRL_PIN(AB9540_PIN_D18, "GPIO13_D18"),
-       PINCTRL_PIN(AB9540_PIN_B19, "GPIO14_B19"),
-       PINCTRL_PIN(AB9540_PIN_C19, "GPIO15_C19"),
-       PINCTRL_PIN(AB9540_PIN_D19, "GPIO16_D19"),
-       PINCTRL_PIN(AB9540_PIN_R3, "GPIO17_R3"),
-       PINCTRL_PIN(AB9540_PIN_T2, "GPIO18_T2"),
-       PINCTRL_PIN(AB9540_PIN_U2, "GPIO19_U2"),
-       PINCTRL_PIN(AB9540_PIN_V2, "GPIO20_V2"),
-       PINCTRL_PIN(AB9540_PIN_N17, "GPIO21_N17"),
-       PINCTRL_PIN(AB9540_PIN_N16, "GPIO22_N16"),
-       PINCTRL_PIN(AB9540_PIN_M19, "GPIO23_M19"),
-       PINCTRL_PIN(AB9540_PIN_T3, "GPIO24_T3"),
-       PINCTRL_PIN(AB9540_PIN_W2, "GPIO25_W2"),
-       /* hole */
-       PINCTRL_PIN(AB9540_PIN_H4, "GPIO27_H4"),
-       PINCTRL_PIN(AB9540_PIN_F1, "GPIO28_F1"),
-       PINCTRL_PIN(AB9540_PIN_F4, "GPIO29_F4"),
-       PINCTRL_PIN(AB9540_PIN_F2, "GPIO30_F2"),
-       PINCTRL_PIN(AB9540_PIN_E4, "GPIO31_E4"),
-       PINCTRL_PIN(AB9540_PIN_F3, "GPIO32_F3"),
-       /* hole */
-       PINCTRL_PIN(AB9540_PIN_J13, "GPIO34_J13"),
-       /* hole */
-       PINCTRL_PIN(AB9540_PIN_L17, "GPIO40_L17"),
-       PINCTRL_PIN(AB9540_PIN_L16, "GPIO41_L16"),
-       PINCTRL_PIN(AB9540_PIN_W3, "GPIO42_W3"),
-       PINCTRL_PIN(AB9540_PIN_N4, "GPIO50_N4"),
-       PINCTRL_PIN(AB9540_PIN_G12, "GPIO51_G12"),
-       PINCTRL_PIN(AB9540_PIN_E17, "GPIO52_E17"),
-       PINCTRL_PIN(AB9540_PIN_D11, "GPIO53_D11"),
-       PINCTRL_PIN(AB9540_PIN_M18, "GPIO60_M18"),
-};
-
-/*
- * Maps local GPIO offsets to local pin numbers
- */
-static const struct abx500_pinrange ab9540_pinranges[] = {
-       ABX500_PINRANGE(1, 4, ABX500_ALT_A),
-       ABX500_PINRANGE(10, 2, ABX500_DEFAULT),
-       ABX500_PINRANGE(13, 1, ABX500_DEFAULT),
-       ABX500_PINRANGE(14, 12, ABX500_ALT_A),
-       ABX500_PINRANGE(27, 6, ABX500_ALT_A),
-       ABX500_PINRANGE(34, 1, ABX500_ALT_A),
-       ABX500_PINRANGE(40, 3, ABX500_ALT_A),
-       ABX500_PINRANGE(50, 1, ABX500_DEFAULT),
-       ABX500_PINRANGE(51, 3, ABX500_ALT_A),
-       ABX500_PINRANGE(54, 1, ABX500_DEFAULT),
-};
-
-/*
- * Read the pin group names like this:
- * sysclkreq2_d_1 = first groups of pins for sysclkreq2 on default function
- *
- * The groups are arranged as sets per altfunction column, so we can
- * mux in one group at a time by selecting the same altfunction for them
- * all. When functions require pins on different altfunctions, you need
- * to combine several groups.
- */
-
-/* default column */
-static const unsigned sysclkreq2_d_1_pins[] = { AB9540_PIN_R4 };
-static const unsigned sysclkreq3_d_1_pins[] = { AB9540_PIN_V3 };
-static const unsigned sysclkreq4_d_1_pins[] = { AB9540_PIN_T4 };
-static const unsigned sysclkreq6_d_1_pins[] = { AB9540_PIN_T5 };
-static const unsigned gpio10_d_1_pins[] = { AB9540_PIN_B18 };
-static const unsigned gpio11_d_1_pins[] = { AB9540_PIN_C18 };
-static const unsigned gpio13_d_1_pins[] = { AB9540_PIN_D18 };
-static const unsigned pwmout1_d_1_pins[] = { AB9540_PIN_B19 };
-static const unsigned pwmout2_d_1_pins[] = { AB9540_PIN_C19 };
-static const unsigned pwmout3_d_1_pins[] = { AB9540_PIN_D19 };
-/* audio data interface 1*/
-static const unsigned adi1_d_1_pins[] = { AB9540_PIN_R3, AB9540_PIN_T2,
-                                       AB9540_PIN_U2, AB9540_PIN_V2 };
-/* USBUICC */
-static const unsigned usbuicc_d_1_pins[] = { AB9540_PIN_N17, AB9540_PIN_N16,
-                                       AB9540_PIN_M19 };
-static const unsigned sysclkreq7_d_1_pins[] = { AB9540_PIN_T3 };
-static const unsigned sysclkreq8_d_1_pins[] = { AB9540_PIN_W2 };
-/* Digital microphone 1 and 2 */
-static const unsigned dmic12_d_1_pins[] = { AB9540_PIN_H4, AB9540_PIN_F1 };
-/* Digital microphone 3 and 4 */
-static const unsigned dmic34_d_1_pins[] = { AB9540_PIN_F4, AB9540_PIN_F2 };
-/* Digital microphone 5 and 6 */
-static const unsigned dmic56_d_1_pins[] = { AB9540_PIN_E4, AB9540_PIN_F3 };
-static const unsigned extcpena_d_1_pins[] = { AB9540_PIN_J13 };
-/* modem SDA/SCL */
-static const unsigned modsclsda_d_1_pins[] = { AB9540_PIN_L17, AB9540_PIN_L16 };
-static const unsigned sysclkreq5_d_1_pins[] = { AB9540_PIN_W3 };
-static const unsigned gpio50_d_1_pins[] = { AB9540_PIN_N4 };
-static const unsigned batremn_d_1_pins[] = { AB9540_PIN_G12 };
-static const unsigned resethw_d_1_pins[] = { AB9540_PIN_E17 };
-static const unsigned service_d_1_pins[] = { AB9540_PIN_D11 };
-static const unsigned gpio60_d_1_pins[] = { AB9540_PIN_M18 };
-
-/* Altfunction A column */
-static const unsigned gpio1_a_1_pins[] = { AB9540_PIN_R4 };
-static const unsigned gpio2_a_1_pins[] = { AB9540_PIN_V3 };
-static const unsigned gpio3_a_1_pins[] = { AB9540_PIN_T4 };
-static const unsigned gpio4_a_1_pins[] = { AB9540_PIN_T5 };
-static const unsigned hiqclkena_a_1_pins[] = { AB9540_PIN_B18 };
-static const unsigned pdmclk_a_1_pins[] = { AB9540_PIN_C18 };
-static const unsigned uartdata_a_1_pins[] = { AB9540_PIN_D18, AB9540_PIN_N4 };
-static const unsigned gpio14_a_1_pins[] = { AB9540_PIN_B19 };
-static const unsigned gpio15_a_1_pins[] = { AB9540_PIN_C19 };
-static const unsigned gpio16_a_1_pins[] = { AB9540_PIN_D19 };
-static const unsigned gpio17_a_1_pins[] = { AB9540_PIN_R3 };
-static const unsigned gpio18_a_1_pins[] = { AB9540_PIN_T2 };
-static const unsigned gpio19_a_1_pins[] = { AB9540_PIN_U2 };
-static const unsigned gpio20_a_1_pins[] = { AB9540_PIN_V2 };
-static const unsigned gpio21_a_1_pins[] = { AB9540_PIN_N17 };
-static const unsigned gpio22_a_1_pins[] = { AB9540_PIN_N16 };
-static const unsigned gpio23_a_1_pins[] = { AB9540_PIN_M19 };
-static const unsigned gpio24_a_1_pins[] = { AB9540_PIN_T3 };
-static const unsigned gpio25_a_1_pins[] = { AB9540_PIN_W2 };
-static const unsigned gpio27_a_1_pins[] = { AB9540_PIN_H4 };
-static const unsigned gpio28_a_1_pins[] = { AB9540_PIN_F1 };
-static const unsigned gpio29_a_1_pins[] = { AB9540_PIN_F4 };
-static const unsigned gpio30_a_1_pins[] = { AB9540_PIN_F2 };
-static const unsigned gpio31_a_1_pins[] = { AB9540_PIN_E4 };
-static const unsigned gpio32_a_1_pins[] = { AB9540_PIN_F3 };
-static const unsigned gpio34_a_1_pins[] = { AB9540_PIN_J13 };
-static const unsigned gpio40_a_1_pins[] = { AB9540_PIN_L17 };
-static const unsigned gpio41_a_1_pins[] = { AB9540_PIN_L16 };
-static const unsigned gpio42_a_1_pins[] = { AB9540_PIN_W3 };
-static const unsigned gpio51_a_1_pins[] = { AB9540_PIN_G12 };
-static const unsigned gpio52_a_1_pins[] = { AB9540_PIN_E17 };
-static const unsigned gpio53_a_1_pins[] = { AB9540_PIN_D11 };
-static const unsigned usbuiccpd_a_1_pins[] = { AB9540_PIN_M18 };
-
-/* Altfunction B colum */
-static const unsigned pdmdata_b_1_pins[] = { AB9540_PIN_B18 };
-static const unsigned pwmextvibra1_b_1_pins[] = { AB9540_PIN_D18 };
-static const unsigned pwmextvibra2_b_1_pins[] = { AB9540_PIN_N4 };
-
-/* Altfunction C column */
-static const unsigned usbvdat_c_1_pins[] = { AB9540_PIN_D18 };
-
-#define AB9540_PIN_GROUP(a, b) { .name = #a, .pins = a##_pins,         \
-                       .npins = ARRAY_SIZE(a##_pins), .altsetting = b }
-
-static const struct abx500_pingroup ab9540_groups[] = {
-       /* default column */
-       AB9540_PIN_GROUP(sysclkreq2_d_1, ABX500_DEFAULT),
-       AB9540_PIN_GROUP(sysclkreq3_d_1, ABX500_DEFAULT),
-       AB9540_PIN_GROUP(sysclkreq4_d_1, ABX500_DEFAULT),
-       AB9540_PIN_GROUP(sysclkreq6_d_1, ABX500_DEFAULT),
-       AB9540_PIN_GROUP(gpio10_d_1, ABX500_DEFAULT),
-       AB9540_PIN_GROUP(gpio11_d_1, ABX500_DEFAULT),
-       AB9540_PIN_GROUP(gpio13_d_1, ABX500_DEFAULT),
-       AB9540_PIN_GROUP(pwmout1_d_1, ABX500_DEFAULT),
-       AB9540_PIN_GROUP(pwmout2_d_1, ABX500_DEFAULT),
-       AB9540_PIN_GROUP(pwmout3_d_1, ABX500_DEFAULT),
-       AB9540_PIN_GROUP(adi1_d_1, ABX500_DEFAULT),
-       AB9540_PIN_GROUP(usbuicc_d_1, ABX500_DEFAULT),
-       AB9540_PIN_GROUP(sysclkreq7_d_1, ABX500_DEFAULT),
-       AB9540_PIN_GROUP(sysclkreq8_d_1, ABX500_DEFAULT),
-       AB9540_PIN_GROUP(dmic12_d_1, ABX500_DEFAULT),
-       AB9540_PIN_GROUP(dmic34_d_1, ABX500_DEFAULT),
-       AB9540_PIN_GROUP(dmic56_d_1, ABX500_DEFAULT),
-       AB9540_PIN_GROUP(extcpena_d_1, ABX500_DEFAULT),
-       AB9540_PIN_GROUP(modsclsda_d_1, ABX500_DEFAULT),
-       AB9540_PIN_GROUP(sysclkreq5_d_1, ABX500_DEFAULT),
-       AB9540_PIN_GROUP(gpio50_d_1, ABX500_DEFAULT),
-       AB9540_PIN_GROUP(batremn_d_1, ABX500_DEFAULT),
-       AB9540_PIN_GROUP(resethw_d_1, ABX500_DEFAULT),
-       AB9540_PIN_GROUP(service_d_1, ABX500_DEFAULT),
-       AB9540_PIN_GROUP(gpio60_d_1, ABX500_DEFAULT),
-
-       /* Altfunction A column */
-       AB9540_PIN_GROUP(gpio1_a_1, ABX500_ALT_A),
-       AB9540_PIN_GROUP(gpio2_a_1, ABX500_ALT_A),
-       AB9540_PIN_GROUP(gpio3_a_1, ABX500_ALT_A),
-       AB9540_PIN_GROUP(gpio4_a_1, ABX500_ALT_A),
-       AB9540_PIN_GROUP(hiqclkena_a_1, ABX500_ALT_A),
-       AB9540_PIN_GROUP(pdmclk_a_1, ABX500_ALT_A),
-       AB9540_PIN_GROUP(uartdata_a_1, ABX500_ALT_A),
-       AB9540_PIN_GROUP(gpio14_a_1, ABX500_ALT_A),
-       AB9540_PIN_GROUP(gpio15_a_1, ABX500_ALT_A),
-       AB9540_PIN_GROUP(gpio16_a_1, ABX500_ALT_A),
-       AB9540_PIN_GROUP(gpio17_a_1, ABX500_ALT_A),
-       AB9540_PIN_GROUP(gpio18_a_1, ABX500_ALT_A),
-       AB9540_PIN_GROUP(gpio19_a_1, ABX500_ALT_A),
-       AB9540_PIN_GROUP(gpio20_a_1, ABX500_ALT_A),
-       AB9540_PIN_GROUP(gpio21_a_1, ABX500_ALT_A),
-       AB9540_PIN_GROUP(gpio22_a_1, ABX500_ALT_A),
-       AB9540_PIN_GROUP(gpio23_a_1, ABX500_ALT_A),
-       AB9540_PIN_GROUP(gpio24_a_1, ABX500_ALT_A),
-       AB9540_PIN_GROUP(gpio25_a_1, ABX500_ALT_A),
-       AB9540_PIN_GROUP(gpio27_a_1, ABX500_ALT_A),
-       AB9540_PIN_GROUP(gpio28_a_1, ABX500_ALT_A),
-       AB9540_PIN_GROUP(gpio29_a_1, ABX500_ALT_A),
-       AB9540_PIN_GROUP(gpio30_a_1, ABX500_ALT_A),
-       AB9540_PIN_GROUP(gpio31_a_1, ABX500_ALT_A),
-       AB9540_PIN_GROUP(gpio32_a_1, ABX500_ALT_A),
-       AB9540_PIN_GROUP(gpio34_a_1, ABX500_ALT_A),
-       AB9540_PIN_GROUP(gpio40_a_1, ABX500_ALT_A),
-       AB9540_PIN_GROUP(gpio41_a_1, ABX500_ALT_A),
-       AB9540_PIN_GROUP(gpio42_a_1, ABX500_ALT_A),
-       AB9540_PIN_GROUP(gpio51_a_1, ABX500_ALT_A),
-       AB9540_PIN_GROUP(gpio52_a_1, ABX500_ALT_A),
-       AB9540_PIN_GROUP(gpio53_a_1, ABX500_ALT_A),
-       AB9540_PIN_GROUP(usbuiccpd_a_1, ABX500_ALT_A),
-
-       /* Altfunction B column */
-       AB9540_PIN_GROUP(pdmdata_b_1, ABX500_ALT_B),
-       AB9540_PIN_GROUP(pwmextvibra1_b_1, ABX500_ALT_B),
-       AB9540_PIN_GROUP(pwmextvibra2_b_1, ABX500_ALT_B),
-
-       /* Altfunction C column */
-       AB9540_PIN_GROUP(usbvdat_c_1, ABX500_ALT_C),
-};
-
-/* We use this macro to define the groups applicable to a function */
-#define AB9540_FUNC_GROUPS(a, b...)       \
-static const char * const a##_groups[] = { b };
-
-AB9540_FUNC_GROUPS(sysclkreq, "sysclkreq2_d_1", "sysclkreq3_d_1",
-               "sysclkreq4_d_1", "sysclkreq5_d_1", "sysclkreq6_d_1",
-               "sysclkreq7_d_1", "sysclkreq8_d_1");
-AB9540_FUNC_GROUPS(gpio, "gpio1_a_1", "gpio2_a_1", "gpio3_a_1", "gpio4_a_1",
-               "gpio10_d_1", "gpio11_d_1", "gpio13_d_1", "gpio14_a_1",
-               "gpio15_a_1", "gpio16_a_1", "gpio17_a_1", "gpio18_a_1",
-               "gpio19_a_1", "gpio20_a_1", "gpio21_a_1", "gpio22_a_1",
-               "gpio23_a_1", "gpio24_a_1", "gpio25_a_1", "gpio27_a_1",
-               "gpio28_a_1", "gpio29_a_1", "gpio30_a_1", "gpio31_a_1",
-               "gpio32_a_1", "gpio34_a_1", "gpio40_a_1", "gpio41_a_1",
-               "gpio42_a_1", "gpio50_d_1", "gpio51_a_1", "gpio52_a_1",
-               "gpio53_a_1", "gpio60_d_1");
-AB9540_FUNC_GROUPS(pwmout, "pwmout1_d_1", "pwmout2_d_1", "pwmout3_d_1");
-AB9540_FUNC_GROUPS(adi1, "adi1_d_1");
-AB9540_FUNC_GROUPS(usbuicc, "usbuicc_d_1", "usbuiccpd_a_1");
-AB9540_FUNC_GROUPS(dmic, "dmic12_d_1", "dmic34_d_1", "dmic56_d_1");
-AB9540_FUNC_GROUPS(extcpena, "extcpena_d_1");
-AB9540_FUNC_GROUPS(modsclsda, "modsclsda_d_1");
-AB9540_FUNC_GROUPS(batremn, "batremn_d_1");
-AB9540_FUNC_GROUPS(resethw, "resethw_d_1");
-AB9540_FUNC_GROUPS(service, "service_d_1");
-AB9540_FUNC_GROUPS(hiqclkena, "hiqclkena_a_1");
-AB9540_FUNC_GROUPS(pdm, "pdmdata_b_1", "pdmclk_a_1");
-AB9540_FUNC_GROUPS(uartdata, "uartdata_a_1");
-AB9540_FUNC_GROUPS(pwmextvibra, "pwmextvibra1_b_1", "pwmextvibra2_b_1");
-AB9540_FUNC_GROUPS(usbvdat, "usbvdat_c_1");
-
-#define FUNCTION(fname)                                        \
-       {                                               \
-               .name = #fname,                         \
-               .groups = fname##_groups,               \
-               .ngroups = ARRAY_SIZE(fname##_groups),  \
-       }
-
-static const struct abx500_function ab9540_functions[] = {
-       FUNCTION(sysclkreq),
-       FUNCTION(gpio),
-       FUNCTION(pwmout),
-       FUNCTION(adi1),
-       FUNCTION(usbuicc),
-       FUNCTION(dmic),
-       FUNCTION(extcpena),
-       FUNCTION(modsclsda),
-       FUNCTION(batremn),
-       FUNCTION(resethw),
-       FUNCTION(service),
-       FUNCTION(hiqclkena),
-       FUNCTION(pdm),
-       FUNCTION(uartdata),
-       FUNCTION(pwmextvibra),
-       FUNCTION(usbvdat),
-};
-
-/*
- * this table translates what's is in the AB9540 specification regarding the
- * balls alternate functions (as for DB, default, ALT_A, ALT_B and ALT_C).
- * ALTERNATE_FUNCTIONS(GPIO_NUMBER, GPIOSEL bit, ALTERNATFUNC bit1,
- * ALTERNATEFUNC bit2, ALTA val, ALTB val, ALTC val),
- *
- * example :
- *
- *     ALTERNATE_FUNCTIONS(13,     4,      3,      4, 1, 0, 2),
- *     means that pin AB9540_PIN_D18 (pin 13) supports 4 mux (default/ALT_A,
- *     ALT_B and ALT_C), so GPIOSEL and ALTERNATFUNC registers are used to
- *     select the mux. ALTA, ALTB and ALTC val indicates values to write in
- *     ALTERNATFUNC register. We need to specifies these values as SOC
- *     designers didn't apply the same logic on how to select mux in the
- *     ABx500 family.
- *
- *     As this pins supports at least ALT_B mux, default mux is
- *     selected by writing 1 in GPIOSEL bit :
- *
- *             | GPIOSEL bit=4 | alternatfunc bit2=4 | alternatfunc bit1=3
- *     default |       1       |          0          |          0
- *     alt_A   |       0       |          0          |          1
- *     alt_B   |       0       |          0          |          0
- *     alt_C   |       0       |          1          |          0
- *
- *     ALTERNATE_FUNCTIONS(1,      0, UNUSED, UNUSED),
- *     means that pin AB9540_PIN_R4 (pin 1) supports 2 mux, so only GPIOSEL
- *     register is used to select the mux. As this pins doesn't support at
- *     least ALT_B mux, default mux is by writing 0 in GPIOSEL bit :
- *
- *             | GPIOSEL bit=0 | alternatfunc bit2=  | alternatfunc bit1=
- *     default |       0       |          0          |          0
- *     alt_A   |       1       |          0          |          0
- */
-
-static struct
-alternate_functions ab9540alternate_functions[AB9540_GPIO_MAX_NUMBER + 1] = {
-       /* GPIOSEL1 - bits 4-7 are reserved */
-       ALTERNATE_FUNCTIONS(0, UNUSED, UNUSED, UNUSED, 0, 0, 0), /* no GPIO0 */
-       ALTERNATE_FUNCTIONS(1,      0, UNUSED, UNUSED, 0, 0, 0), /* GPIO1, altA controlled by bit 0 */
-       ALTERNATE_FUNCTIONS(2,      1, UNUSED, UNUSED, 0, 0, 0), /* GPIO2, altA controlled by bit 1 */
-       ALTERNATE_FUNCTIONS(3,      2, UNUSED, UNUSED, 0, 0, 0), /* GPIO3, altA controlled by bit 2*/
-       ALTERNATE_FUNCTIONS(4,      3, UNUSED, UNUSED, 0, 0, 0), /* GPIO4, altA controlled by bit 3*/
-       ALTERNATE_FUNCTIONS(5, UNUSED, UNUSED, UNUSED, 0, 0, 0), /* no GPIO5 */
-       ALTERNATE_FUNCTIONS(6, UNUSED, UNUSED, UNUSED, 0, 0, 0), /* no GPIO6 */
-       ALTERNATE_FUNCTIONS(7, UNUSED, UNUSED, UNUSED, 0, 0, 0), /* no GPIO7 */
-       ALTERNATE_FUNCTIONS(8, UNUSED, UNUSED, UNUSED, 0, 0, 0), /* no GPIO8 */
-       /* GPIOSEL2 - bits 0 and 3 are reserved */
-       ALTERNATE_FUNCTIONS(9, UNUSED, UNUSED, UNUSED, 0, 0, 0), /* no GPIO9 */
-       ALTERNATE_FUNCTIONS(10,      1,      0, UNUSED, 1, 0, 0), /* GPIO10, altA and altB controlled by bit 0 */
-       ALTERNATE_FUNCTIONS(11,      2,      1, UNUSED, 0, 0, 0), /* GPIO11, altA controlled by bit 1 */
-       ALTERNATE_FUNCTIONS(12, UNUSED, UNUSED, UNUSED, 0, 0, 0), /* no GPIO12 */
-       ALTERNATE_FUNCTIONS(13,      4,      3,      4, 1, 0, 2), /* GPIO13, altA altB and altC controlled by bit 3 and 4 */
-       ALTERNATE_FUNCTIONS(14,      5, UNUSED, UNUSED, 0, 0, 0), /* GPIO14, altA controlled by bit 5 */
-       ALTERNATE_FUNCTIONS(15,      6, UNUSED, UNUSED, 0, 0, 0), /* GPIO15, altA controlled by bit 6 */
-       ALTERNATE_FUNCTIONS(16,      7, UNUSED, UNUSED, 0, 0, 0), /* GPIO16, altA controlled by bit 7 */
-       /* GPIOSEL3 - bit 1-3 reserved
-        * pins 17 to 20 are special case, only bit 0 is used to select
-        * alternate function for these 4 pins.
-        * bits 1 to 3 are reserved
-        */
-       ALTERNATE_FUNCTIONS(17,      0, UNUSED, UNUSED, 0, 0, 0), /* GPIO17, altA controlled by bit 0 */
-       ALTERNATE_FUNCTIONS(18,      0, UNUSED, UNUSED, 0, 0, 0), /* GPIO18, altA controlled by bit 0 */
-       ALTERNATE_FUNCTIONS(19,      0, UNUSED, UNUSED, 0, 0, 0), /* GPIO19, altA controlled by bit 0 */
-       ALTERNATE_FUNCTIONS(20,      0, UNUSED, UNUSED, 0, 0, 0), /* GPIO20, altA controlled by bit 0 */
-       ALTERNATE_FUNCTIONS(21,      4, UNUSED, UNUSED, 0, 0, 0), /* GPIO21, altA controlled by bit 4 */
-       ALTERNATE_FUNCTIONS(22,      5, UNUSED, UNUSED, 0, 0, 0), /* GPIO22, altA controlled by bit 5 */
-       ALTERNATE_FUNCTIONS(23,      6, UNUSED, UNUSED, 0, 0, 0), /* GPIO23, altA controlled by bit 6 */
-       ALTERNATE_FUNCTIONS(24,      7, UNUSED, UNUSED, 0, 0, 0), /* GPIO24, altA controlled by bit 7 */
-       /* GPIOSEL4 - bit 1 reserved */
-       ALTERNATE_FUNCTIONS(25,      0, UNUSED, UNUSED, 0, 0, 0), /* GPIO25, altA controlled by bit 0 */
-       ALTERNATE_FUNCTIONS(26, UNUSED, UNUSED, UNUSED, 0, 0, 0), /* no GPIO26 */
-       ALTERNATE_FUNCTIONS(27,      2, UNUSED, UNUSED, 0, 0, 0), /* GPIO27, altA controlled by bit 2 */
-       ALTERNATE_FUNCTIONS(28,      3, UNUSED, UNUSED, 0, 0, 0), /* GPIO28, altA controlled by bit 3 */
-       ALTERNATE_FUNCTIONS(29,      4, UNUSED, UNUSED, 0, 0, 0), /* GPIO29, altA controlled by bit 4 */
-       ALTERNATE_FUNCTIONS(30,      5, UNUSED, UNUSED, 0, 0, 0), /* GPIO30, altA controlled by bit 5 */
-       ALTERNATE_FUNCTIONS(31,      6, UNUSED, UNUSED, 0, 0, 0), /* GPIO31, altA controlled by bit 6 */
-       ALTERNATE_FUNCTIONS(32,      7, UNUSED, UNUSED, 0, 0, 0), /* GPIO32, altA controlled by bit 7 */
-       /* GPIOSEL5 - bit 0, 2-6 are reserved */
-       ALTERNATE_FUNCTIONS(33, UNUSED, UNUSED, UNUSED, 0, 0, 0), /* no GPIO33 */
-       ALTERNATE_FUNCTIONS(34,      1, UNUSED, UNUSED, 0, 0, 0), /* GPIO34, altA controlled by bit 1 */
-       ALTERNATE_FUNCTIONS(35, UNUSED, UNUSED, UNUSED, 0, 0, 0), /* no GPIO35 */
-       ALTERNATE_FUNCTIONS(36, UNUSED, UNUSED, UNUSED, 0, 0, 0), /* no GPIO36 */
-       ALTERNATE_FUNCTIONS(37, UNUSED, UNUSED, UNUSED, 0, 0, 0), /* no GPIO37 */
-       ALTERNATE_FUNCTIONS(38, UNUSED, UNUSED, UNUSED, 0, 0, 0), /* no GPIO38 */
-       ALTERNATE_FUNCTIONS(39, UNUSED, UNUSED, UNUSED, 0, 0, 0), /* no GPIO39 */
-       ALTERNATE_FUNCTIONS(40,      7, UNUSED, UNUSED, 0, 0, 0), /* GPIO40, altA controlled by bit 7 */
-       /* GPIOSEL6 - bit 2-7 are reserved */
-       ALTERNATE_FUNCTIONS(41,      0, UNUSED, UNUSED, 0, 0, 0), /* GPIO41, altA controlled by bit 0 */
-       ALTERNATE_FUNCTIONS(42,      1, UNUSED, UNUSED, 0, 0, 0), /* GPIO42, altA controlled by bit 1 */
-       ALTERNATE_FUNCTIONS(43, UNUSED, UNUSED, UNUSED, 0, 0, 0), /* no GPIO43 */
-       ALTERNATE_FUNCTIONS(44, UNUSED, UNUSED, UNUSED, 0, 0, 0), /* no GPIO44 */
-       ALTERNATE_FUNCTIONS(45, UNUSED, UNUSED, UNUSED, 0, 0, 0), /* no GPIO45 */
-       ALTERNATE_FUNCTIONS(46, UNUSED, UNUSED, UNUSED, 0, 0, 0), /* no GPIO46 */
-       ALTERNATE_FUNCTIONS(47, UNUSED, UNUSED, UNUSED, 0, 0, 0), /* no GPIO47 */
-       ALTERNATE_FUNCTIONS(48, UNUSED, UNUSED, UNUSED, 0, 0, 0), /* no GPIO48 */
-       /*
-        * GPIOSEL7 - bit 0 and 6-7 are reserved
-        * special case with GPIO60, wich is located at offset 5 of gpiosel7
-        * don't know why it has been called GPIO60 in AB9540 datasheet,
-        * GPIO54 would be logical..., so at SOC point of view we consider
-        * GPIO60 = GPIO54
-        */
-       ALTERNATE_FUNCTIONS(49,      0, UNUSED, UNUSED, 0, 0, 0), /* no GPIO49 */
-       ALTERNATE_FUNCTIONS(50,      1,      2, UNUSED, 1, 0, 0), /* GPIO50, altA and altB controlled by bit 1 */
-       ALTERNATE_FUNCTIONS(51,      2, UNUSED, UNUSED, 0, 0, 0), /* GPIO51, altA controlled by bit 2 */
-       ALTERNATE_FUNCTIONS(52,      3, UNUSED, UNUSED, 0, 0, 0), /* GPIO52, altA controlled by bit 3 */
-       ALTERNATE_FUNCTIONS(53,      4, UNUSED, UNUSED, 0, 0, 0), /* GPIO53, altA controlled by bit 4 */
-       ALTERNATE_FUNCTIONS(54,      5, UNUSED, UNUSED, 0, 0, 0), /* GPIO54 = GPIO60, altA controlled by bit 5 */
-};
-
-static struct abx500_gpio_irq_cluster ab9540_gpio_irq_cluster[] = {
-       GPIO_IRQ_CLUSTER(10, 13, AB8500_INT_GPIO10R),
-       GPIO_IRQ_CLUSTER(24, 25, AB8500_INT_GPIO24R),
-       GPIO_IRQ_CLUSTER(40, 41, AB8500_INT_GPIO40R),
-       GPIO_IRQ_CLUSTER(50, 54, AB9540_INT_GPIO50R),
-};
-
-static struct abx500_pinctrl_soc_data ab9540_soc = {
-       .gpio_ranges = ab9540_pinranges,
-       .gpio_num_ranges = ARRAY_SIZE(ab9540_pinranges),
-       .pins = ab9540_pins,
-       .npins = ARRAY_SIZE(ab9540_pins),
-       .functions = ab9540_functions,
-       .nfunctions = ARRAY_SIZE(ab9540_functions),
-       .groups = ab9540_groups,
-       .ngroups = ARRAY_SIZE(ab9540_groups),
-       .alternate_functions = ab9540alternate_functions,
-       .gpio_irq_cluster = ab9540_gpio_irq_cluster,
-       .ngpio_irq_cluster = ARRAY_SIZE(ab9540_gpio_irq_cluster),
-       .irq_gpio_rising_offset = AB8500_INT_GPIO6R,
-       .irq_gpio_falling_offset = AB8500_INT_GPIO6F,
-       .irq_gpio_factor = 1,
-};
-
-void
-abx500_pinctrl_ab9540_init(struct abx500_pinctrl_soc_data **soc)
-{
-       *soc = &ab9540_soc;
-}
index d56a49e..aa592ef 100644 (file)
 #include "../pinctrl-utils.h"
 
 /*
- * The AB9540 and AB8540 GPIO support are extended versions
- * of the AB8500 GPIO support.
- * The AB9540 supports an additional (7th) register so that
- * more GPIO may be configured and used.
- * The AB8540 supports 4 new gpios (GPIOx_VBAT) that have
- * internal pull-up and pull-down capabilities.
- */
-
-/*
  * GPIO registers offset
  * Bank: 0x10
  */
@@ -56,7 +47,6 @@
 #define AB8500_GPIO_SEL4_REG   0x03
 #define AB8500_GPIO_SEL5_REG   0x04
 #define AB8500_GPIO_SEL6_REG   0x05
-#define AB9540_GPIO_SEL7_REG   0x06
 
 #define AB8500_GPIO_DIR1_REG   0x10
 #define AB8500_GPIO_DIR2_REG   0x11
@@ -64,7 +54,6 @@
 #define AB8500_GPIO_DIR4_REG   0x13
 #define AB8500_GPIO_DIR5_REG   0x14
 #define AB8500_GPIO_DIR6_REG   0x15
-#define AB9540_GPIO_DIR7_REG   0x16
 
 #define AB8500_GPIO_OUT1_REG   0x20
 #define AB8500_GPIO_OUT2_REG   0x21
@@ -72,7 +61,6 @@
 #define AB8500_GPIO_OUT4_REG   0x23
 #define AB8500_GPIO_OUT5_REG   0x24
 #define AB8500_GPIO_OUT6_REG   0x25
-#define AB9540_GPIO_OUT7_REG   0x26
 
 #define AB8500_GPIO_PUD1_REG   0x30
 #define AB8500_GPIO_PUD2_REG   0x31
@@ -80,7 +68,6 @@
 #define AB8500_GPIO_PUD4_REG   0x33
 #define AB8500_GPIO_PUD5_REG   0x34
 #define AB8500_GPIO_PUD6_REG   0x35
-#define AB9540_GPIO_PUD7_REG   0x36
 
 #define AB8500_GPIO_IN1_REG    0x40
 #define AB8500_GPIO_IN2_REG    0x41
 #define AB8500_GPIO_IN4_REG    0x43
 #define AB8500_GPIO_IN5_REG    0x44
 #define AB8500_GPIO_IN6_REG    0x45
-#define AB9540_GPIO_IN7_REG    0x46
-#define AB8540_GPIO_VINSEL_REG 0x47
-#define AB8540_GPIO_PULL_UPDOWN_REG    0x48
 #define AB8500_GPIO_ALTFUN_REG 0x50
-#define AB8540_GPIO_PULL_UPDOWN_MASK   0x03
-#define AB8540_GPIO_VINSEL_MASK        0x03
-#define AB8540_GPIOX_VBAT_START        51
-#define AB8540_GPIOX_VBAT_END  54
 
 #define ABX500_GPIO_INPUT      0
 #define ABX500_GPIO_OUTPUT     1
@@ -192,94 +172,11 @@ static void abx500_gpio_set(struct gpio_chip *chip, unsigned offset, int val)
                dev_err(pct->dev, "%s write failed (%d)\n", __func__, ret);
 }
 
-#ifdef CONFIG_DEBUG_FS
-static int abx500_get_pull_updown(struct abx500_pinctrl *pct, int offset,
-                                 enum abx500_gpio_pull_updown *pull_updown)
-{
-       u8 pos;
-       u8 val;
-       int ret;
-       struct pullud *pullud;
-
-       if (!pct->soc->pullud) {
-               dev_err(pct->dev, "%s AB chip doesn't support pull up/down feature",
-                               __func__);
-               ret = -EPERM;
-               goto out;
-       }
-
-       pullud = pct->soc->pullud;
-
-       if ((offset < pullud->first_pin)
-               || (offset > pullud->last_pin)) {
-               ret = -EINVAL;
-               goto out;
-       }
-
-       ret = abx500_get_register_interruptible(pct->dev,
-                       AB8500_MISC, AB8540_GPIO_PULL_UPDOWN_REG, &val);
-
-       pos = (offset - pullud->first_pin) << 1;
-       *pull_updown = (val >> pos) & AB8540_GPIO_PULL_UPDOWN_MASK;
-
-out:
-       if (ret < 0)
-               dev_err(pct->dev, "%s failed (%d)\n", __func__, ret);
-
-       return ret;
-}
-#endif
-
-static int abx500_set_pull_updown(struct abx500_pinctrl *pct,
-                                 int offset, enum abx500_gpio_pull_updown val)
-{
-       u8 pos;
-       int ret;
-       struct pullud *pullud;
-
-       if (!pct->soc->pullud) {
-               dev_err(pct->dev, "%s AB chip doesn't support pull up/down feature",
-                               __func__);
-               ret = -EPERM;
-               goto out;
-       }
-
-       pullud = pct->soc->pullud;
-
-       if ((offset < pullud->first_pin)
-               || (offset > pullud->last_pin)) {
-               ret = -EINVAL;
-               goto out;
-       }
-       pos = (offset - pullud->first_pin) << 1;
-
-       ret = abx500_mask_and_set_register_interruptible(pct->dev,
-                       AB8500_MISC, AB8540_GPIO_PULL_UPDOWN_REG,
-                       AB8540_GPIO_PULL_UPDOWN_MASK << pos, val << pos);
-
-out:
-       if (ret < 0)
-               dev_err(pct->dev, "%s failed (%d)\n", __func__, ret);
-
-       return ret;
-}
-
-static bool abx500_pullud_supported(struct gpio_chip *chip, unsigned gpio)
-{
-       struct abx500_pinctrl *pct = gpiochip_get_data(chip);
-       struct pullud *pullud = pct->soc->pullud;
-
-       return (pullud &&
-               gpio >= pullud->first_pin &&
-               gpio <= pullud->last_pin);
-}
-
 static int abx500_gpio_direction_output(struct gpio_chip *chip,
                                        unsigned offset,
                                        int val)
 {
        struct abx500_pinctrl *pct = gpiochip_get_data(chip);
-       unsigned gpio;
        int ret;
 
        /* set direction as output */
@@ -295,16 +192,7 @@ static int abx500_gpio_direction_output(struct gpio_chip *chip,
                                AB8500_GPIO_PUD1_REG,
                                offset,
                                ABX500_GPIO_PULL_NONE);
-       if (ret < 0)
-               goto out;
 
-       /* if supported, disable both pull down and pull up */
-       gpio = offset + 1;
-       if (abx500_pullud_supported(chip, gpio)) {
-               ret = abx500_set_pull_updown(pct,
-                               gpio,
-                               ABX500_GPIO_PULL_NONE);
-       }
 out:
        if (ret < 0) {
                dev_err(pct->dev, "%s failed (%d)\n", __func__, ret);
@@ -570,7 +458,6 @@ static void abx500_gpio_dbg_show_one(struct seq_file *s,
        int mode = -1;
        bool is_out;
        bool pd;
-       enum abx500_gpio_pull_updown pud = 0;
        int ret;
 
        const char *modes[] = {
@@ -597,20 +484,12 @@ static void abx500_gpio_dbg_show_one(struct seq_file *s,
                   is_out ? "out" : "in ");
 
        if (!is_out) {
-               if (abx500_pullud_supported(chip, offset)) {
-                       ret = abx500_get_pull_updown(pct, offset, &pud);
-                       if (ret < 0)
-                               goto out;
-
-                       seq_printf(s, " %-9s", pull_up_down[pud]);
-               } else {
-                       ret = abx500_gpio_get_bit(chip, AB8500_GPIO_PUD1_REG,
-                                       gpio_offset, &pd);
-                       if (ret < 0)
-                               goto out;
+               ret = abx500_gpio_get_bit(chip, AB8500_GPIO_PUD1_REG,
+                               gpio_offset, &pd);
+               if (ret < 0)
+                       goto out;
 
-                       seq_printf(s, " %-9s", pull_up_down[pd]);
-               }
+               seq_printf(s, " %-9s", pull_up_down[pd]);
        } else
                seq_printf(s, " %-9s", chip->get(chip, offset) ? "hi" : "lo");
 
@@ -994,23 +873,11 @@ static int abx500_pin_config_set(struct pinctrl_dev *pctldev,
                        ret = abx500_gpio_direction_input(chip, offset);
                        if (ret < 0)
                                goto out;
-                       /*
-                        * Some chips only support pull down, while some
-                        * actually support both pull up and pull down. Such
-                        * chips have a "pullud" range specified for the pins
-                        * that support both features. If the pin is not
-                        * within that range, we fall back to the old bit set
-                        * that only support pull down.
-                        */
-                       if (abx500_pullud_supported(chip, pin))
-                               ret = abx500_set_pull_updown(pct,
-                                       pin,
-                                       ABX500_GPIO_PULL_NONE);
-                       else
-                               /* Chip only supports pull down */
-                               ret = abx500_gpio_set_bits(chip,
-                                       AB8500_GPIO_PUD1_REG, offset,
-                                       ABX500_GPIO_PULL_NONE);
+
+                       /* Chip only supports pull down */
+                       ret = abx500_gpio_set_bits(chip,
+                               AB8500_GPIO_PUD1_REG, offset,
+                               ABX500_GPIO_PULL_NONE);
                        break;
 
                case PIN_CONFIG_BIAS_PULL_DOWN:
@@ -1020,25 +887,13 @@ static int abx500_pin_config_set(struct pinctrl_dev *pctldev,
                        /*
                         * if argument = 1 set the pull down
                         * else clear the pull down
-                        * Some chips only support pull down, while some
-                        * actually support both pull up and pull down. Such
-                        * chips have a "pullud" range specified for the pins
-                        * that support both features. If the pin is not
-                        * within that range, we fall back to the old bit set
-                        * that only support pull down.
+                        * Chip only supports pull down
                         */
-                       if (abx500_pullud_supported(chip, pin))
-                               ret = abx500_set_pull_updown(pct,
-                                       pin,
-                                       argument ? ABX500_GPIO_PULL_DOWN :
-                                       ABX500_GPIO_PULL_NONE);
-                       else
-                               /* Chip only supports pull down */
-                               ret = abx500_gpio_set_bits(chip,
-                               AB8500_GPIO_PUD1_REG,
-                                       offset,
-                                       argument ? ABX500_GPIO_PULL_DOWN :
-                                       ABX500_GPIO_PULL_NONE);
+                       ret = abx500_gpio_set_bits(chip,
+                       AB8500_GPIO_PUD1_REG,
+                               offset,
+                               argument ? ABX500_GPIO_PULL_DOWN :
+                               ABX500_GPIO_PULL_NONE);
                        break;
 
                case PIN_CONFIG_BIAS_PULL_UP:
@@ -1050,18 +905,6 @@ static int abx500_pin_config_set(struct pinctrl_dev *pctldev,
                         * else clear the pull up
                         */
                        ret = abx500_gpio_direction_input(chip, offset);
-                       /*
-                        * Some chips only support pull down, while some
-                        * actually support both pull up and pull down. Such
-                        * chips have a "pullud" range specified for the pins
-                        * that support both features. If the pin is not
-                        * within that range, do nothing
-                        */
-                       if (abx500_pullud_supported(chip, pin))
-                               ret = abx500_set_pull_updown(pct,
-                                       pin,
-                                       argument ? ABX500_GPIO_PULL_UP :
-                                       ABX500_GPIO_PULL_NONE);
                        break;
 
                case PIN_CONFIG_OUTPUT:
@@ -1136,8 +979,6 @@ static int abx500_get_gpio_num(struct abx500_pinctrl_soc_data *soc)
 static const struct of_device_id abx500_gpio_match[] = {
        { .compatible = "stericsson,ab8500-gpio", .data = (void *)PINCTRL_AB8500, },
        { .compatible = "stericsson,ab8505-gpio", .data = (void *)PINCTRL_AB8505, },
-       { .compatible = "stericsson,ab8540-gpio", .data = (void *)PINCTRL_AB8540, },
-       { .compatible = "stericsson,ab9540-gpio", .data = (void *)PINCTRL_AB9540, },
        { }
 };
 
@@ -1177,12 +1018,6 @@ static int abx500_gpio_probe(struct platform_device *pdev)
        case PINCTRL_AB8500:
                abx500_pinctrl_ab8500_init(&pct->soc);
                break;
-       case PINCTRL_AB8540:
-               abx500_pinctrl_ab8540_init(&pct->soc);
-               break;
-       case PINCTRL_AB9540:
-               abx500_pinctrl_ab9540_init(&pct->soc);
-               break;
        case PINCTRL_AB8505:
                abx500_pinctrl_ab8505_init(&pct->soc);
                break;
index 43f9b71..90bb12f 100644 (file)
@@ -4,9 +4,7 @@
 
 /* Package definitions */
 #define PINCTRL_AB8500 0
-#define PINCTRL_AB8540 1
-#define PINCTRL_AB9540 2
-#define PINCTRL_AB8505 3
+#define PINCTRL_AB8505 1
 
 /* pins alternate function */
 enum abx500_pin_func {
@@ -96,17 +94,6 @@ struct alternate_functions {
        u8 altc_val;
 };
 
-/**
- * struct pullud - specific pull up/down feature
- * @first_pin:         The pin number of the first pins which support
- *                     specific pull up/down
- * @last_pin:          The pin number of the last pins
- */
-struct pullud {
-       unsigned first_pin;
-       unsigned last_pin;
-};
-
 #define GPIO_IRQ_CLUSTER(a, b, c)      \
 {                                      \
        .start = a,                     \
@@ -162,8 +149,6 @@ struct abx500_pinrange {
  * @ngroups:           The number of entries in @groups.
  * @alternate_functions: array describing pins which supports alternate and
  *                     how to set it.
- * @pullud:            array describing pins which supports pull up/down
- *                     specific registers.
  * @gpio_irq_cluster:  An array of GPIO interrupt capable for this SoC
  * @ngpio_irq_cluster: The number of GPIO inetrrupt capable for this SoC
  * @irq_gpio_rising_offset: Interrupt offset used as base to compute specific
@@ -184,7 +169,6 @@ struct abx500_pinctrl_soc_data {
        const struct abx500_pingroup *groups;
        unsigned ngroups;
        struct alternate_functions *alternate_functions;
-       struct pullud *pullud;
        struct abx500_gpio_irq_cluster *gpio_irq_cluster;
        unsigned ngpio_irq_cluster;
        int irq_gpio_rising_offset;
@@ -205,32 +189,6 @@ abx500_pinctrl_ab8500_init(struct abx500_pinctrl_soc_data **soc)
 
 #endif
 
-#ifdef CONFIG_PINCTRL_AB8540
-
-void abx500_pinctrl_ab8540_init(struct abx500_pinctrl_soc_data **soc);
-
-#else
-
-static inline void
-abx500_pinctrl_ab8540_init(struct abx500_pinctrl_soc_data **soc)
-{
-}
-
-#endif
-
-#ifdef CONFIG_PINCTRL_AB9540
-
-void abx500_pinctrl_ab9540_init(struct abx500_pinctrl_soc_data **soc);
-
-#else
-
-static inline void
-abx500_pinctrl_ab9540_init(struct abx500_pinctrl_soc_data **soc)
-{
-}
-
-#endif
-
 #ifdef CONFIG_PINCTRL_AB8505
 
 void abx500_pinctrl_ab8505_init(struct abx500_pinctrl_soc_data **soc);
diff --git a/drivers/pinctrl/nomadik/pinctrl-nomadik-db8540.c b/drivers/pinctrl/nomadik/pinctrl-nomadik-db8540.c
deleted file mode 100644 (file)
index ae3ac7b..0000000
+++ /dev/null
@@ -1,1243 +0,0 @@
-// SPDX-License-Identifier: GPL-2.0
-#include <linux/kernel.h>
-#include <linux/pinctrl/pinctrl.h>
-#include "pinctrl-nomadik.h"
-
-/* All the pins that can be used for GPIO and some other functions */
-#define _GPIO(offset)          (offset)
-
-#define DB8540_PIN_AH6         _GPIO(0)
-#define DB8540_PIN_AG7         _GPIO(1)
-#define DB8540_PIN_AF2         _GPIO(2)
-#define DB8540_PIN_AD3         _GPIO(3)
-#define DB8540_PIN_AF6         _GPIO(4)
-#define DB8540_PIN_AG6         _GPIO(5)
-#define DB8540_PIN_AD5         _GPIO(6)
-#define DB8540_PIN_AF7         _GPIO(7)
-#define DB8540_PIN_AG5         _GPIO(8)
-#define DB8540_PIN_AH5         _GPIO(9)
-#define DB8540_PIN_AE4         _GPIO(10)
-#define DB8540_PIN_AD1         _GPIO(11)
-#define DB8540_PIN_AD2         _GPIO(12)
-#define DB8540_PIN_AC2         _GPIO(13)
-#define DB8540_PIN_AC4         _GPIO(14)
-#define DB8540_PIN_AC3         _GPIO(15)
-#define DB8540_PIN_AH7         _GPIO(16)
-#define DB8540_PIN_AE7         _GPIO(17)
-/* Hole */
-#define DB8540_PIN_AF8         _GPIO(22)
-#define DB8540_PIN_AH11                _GPIO(23)
-#define DB8540_PIN_AG11                _GPIO(24)
-#define DB8540_PIN_AF11                _GPIO(25)
-#define DB8540_PIN_AH10                _GPIO(26)
-#define DB8540_PIN_AG10                _GPIO(27)
-#define DB8540_PIN_AF10                _GPIO(28)
-/* Hole */
-#define DB8540_PIN_AD4         _GPIO(33)
-#define DB8540_PIN_AF3         _GPIO(34)
-#define DB8540_PIN_AF5         _GPIO(35)
-#define DB8540_PIN_AG4         _GPIO(36)
-#define DB8540_PIN_AF9         _GPIO(37)
-#define DB8540_PIN_AE8         _GPIO(38)
-/* Hole */
-#define DB8540_PIN_M26         _GPIO(64)
-#define DB8540_PIN_M25         _GPIO(65)
-#define DB8540_PIN_M27         _GPIO(66)
-#define DB8540_PIN_N25         _GPIO(67)
-/* Hole */
-#define DB8540_PIN_M28         _GPIO(70)
-#define DB8540_PIN_N26         _GPIO(71)
-#define DB8540_PIN_M22         _GPIO(72)
-#define DB8540_PIN_N22         _GPIO(73)
-#define DB8540_PIN_N27         _GPIO(74)
-#define DB8540_PIN_N28         _GPIO(75)
-#define DB8540_PIN_P22         _GPIO(76)
-#define DB8540_PIN_P28         _GPIO(77)
-#define DB8540_PIN_P26         _GPIO(78)
-#define DB8540_PIN_T22         _GPIO(79)
-#define DB8540_PIN_R27         _GPIO(80)
-#define DB8540_PIN_P27         _GPIO(81)
-#define DB8540_PIN_R26         _GPIO(82)
-#define DB8540_PIN_R25         _GPIO(83)
-#define DB8540_PIN_U22         _GPIO(84)
-#define DB8540_PIN_T27         _GPIO(85)
-#define DB8540_PIN_T25         _GPIO(86)
-#define DB8540_PIN_T26         _GPIO(87)
-/* Hole */
-#define DB8540_PIN_AF20                _GPIO(116)
-#define DB8540_PIN_AG21                _GPIO(117)
-#define DB8540_PIN_AH19                _GPIO(118)
-#define DB8540_PIN_AE19                _GPIO(119)
-#define DB8540_PIN_AG18                _GPIO(120)
-#define DB8540_PIN_AH17                _GPIO(121)
-#define DB8540_PIN_AF19                _GPIO(122)
-#define DB8540_PIN_AF18                _GPIO(123)
-#define DB8540_PIN_AE18                _GPIO(124)
-#define DB8540_PIN_AG17                _GPIO(125)
-#define DB8540_PIN_AF17                _GPIO(126)
-#define DB8540_PIN_AE17                _GPIO(127)
-#define DB8540_PIN_AC27                _GPIO(128)
-#define DB8540_PIN_AD27                _GPIO(129)
-#define DB8540_PIN_AE28                _GPIO(130)
-#define DB8540_PIN_AG26                _GPIO(131)
-#define DB8540_PIN_AF25                _GPIO(132)
-#define DB8540_PIN_AE27                _GPIO(133)
-#define DB8540_PIN_AF27                _GPIO(134)
-#define DB8540_PIN_AG28                _GPIO(135)
-#define DB8540_PIN_AF28                _GPIO(136)
-#define DB8540_PIN_AG25                _GPIO(137)
-#define DB8540_PIN_AG24                _GPIO(138)
-#define DB8540_PIN_AD25                _GPIO(139)
-#define DB8540_PIN_AH25                _GPIO(140)
-#define DB8540_PIN_AF26                _GPIO(141)
-#define DB8540_PIN_AF23                _GPIO(142)
-#define DB8540_PIN_AG23                _GPIO(143)
-#define DB8540_PIN_AE25                _GPIO(144)
-#define DB8540_PIN_AH24                _GPIO(145)
-#define DB8540_PIN_AJ25                _GPIO(146)
-#define DB8540_PIN_AG27                _GPIO(147)
-#define DB8540_PIN_AH23                _GPIO(148)
-#define DB8540_PIN_AE26                _GPIO(149)
-#define DB8540_PIN_AE24                _GPIO(150)
-#define DB8540_PIN_AJ24                _GPIO(151)
-#define DB8540_PIN_AE21                _GPIO(152)
-#define DB8540_PIN_AG22                _GPIO(153)
-#define DB8540_PIN_AF21                _GPIO(154)
-#define DB8540_PIN_AF24                _GPIO(155)
-#define DB8540_PIN_AH22                _GPIO(156)
-#define DB8540_PIN_AJ23                _GPIO(157)
-#define DB8540_PIN_AH21                _GPIO(158)
-#define DB8540_PIN_AG20                _GPIO(159)
-#define DB8540_PIN_AE23                _GPIO(160)
-#define DB8540_PIN_AH20                _GPIO(161)
-#define DB8540_PIN_AG19                _GPIO(162)
-#define DB8540_PIN_AF22                _GPIO(163)
-#define DB8540_PIN_AJ21                _GPIO(164)
-#define DB8540_PIN_AD26                _GPIO(165)
-#define DB8540_PIN_AD28                _GPIO(166)
-#define DB8540_PIN_AC28                _GPIO(167)
-#define DB8540_PIN_AC26                _GPIO(168)
-/* Hole */
-#define DB8540_PIN_J3          _GPIO(192)
-#define DB8540_PIN_H1          _GPIO(193)
-#define DB8540_PIN_J2          _GPIO(194)
-#define DB8540_PIN_H2          _GPIO(195)
-#define DB8540_PIN_H3          _GPIO(196)
-#define DB8540_PIN_H4          _GPIO(197)
-#define DB8540_PIN_G2          _GPIO(198)
-#define DB8540_PIN_G3          _GPIO(199)
-#define DB8540_PIN_G4          _GPIO(200)
-#define DB8540_PIN_F2          _GPIO(201)
-#define DB8540_PIN_C6          _GPIO(202)
-#define DB8540_PIN_B6          _GPIO(203)
-#define DB8540_PIN_B7          _GPIO(204)
-#define DB8540_PIN_A7          _GPIO(205)
-#define DB8540_PIN_D7          _GPIO(206)
-#define DB8540_PIN_D8          _GPIO(207)
-#define DB8540_PIN_F3          _GPIO(208)
-#define DB8540_PIN_E2          _GPIO(209)
-#define DB8540_PIN_C7          _GPIO(210)
-#define DB8540_PIN_B8          _GPIO(211)
-#define DB8540_PIN_C10         _GPIO(212)
-#define DB8540_PIN_C8          _GPIO(213)
-#define DB8540_PIN_C9          _GPIO(214)
-/* Hole */
-#define DB8540_PIN_B9          _GPIO(219)
-#define DB8540_PIN_A10         _GPIO(220)
-#define DB8540_PIN_D9          _GPIO(221)
-#define DB8540_PIN_B11         _GPIO(222)
-#define DB8540_PIN_B10         _GPIO(223)
-#define DB8540_PIN_E10         _GPIO(224)
-#define DB8540_PIN_B12         _GPIO(225)
-#define DB8540_PIN_D10         _GPIO(226)
-#define DB8540_PIN_D11         _GPIO(227)
-#define DB8540_PIN_AJ6         _GPIO(228)
-#define DB8540_PIN_B13         _GPIO(229)
-#define DB8540_PIN_C12         _GPIO(230)
-#define DB8540_PIN_B14         _GPIO(231)
-#define DB8540_PIN_E11         _GPIO(232)
-/* Hole */
-#define DB8540_PIN_D12         _GPIO(256)
-#define DB8540_PIN_D15         _GPIO(257)
-#define DB8540_PIN_C13         _GPIO(258)
-#define DB8540_PIN_C14         _GPIO(259)
-#define DB8540_PIN_C18         _GPIO(260)
-#define DB8540_PIN_C16         _GPIO(261)
-#define DB8540_PIN_B16         _GPIO(262)
-#define DB8540_PIN_D18         _GPIO(263)
-#define DB8540_PIN_C15         _GPIO(264)
-#define DB8540_PIN_C17         _GPIO(265)
-#define DB8540_PIN_B17         _GPIO(266)
-#define DB8540_PIN_D17         _GPIO(267)
-
-/*
- * The names of the pins are denoted by GPIO number and ball name, even
- * though they can be used for other things than GPIO, this is the first
- * column in the table of the data sheet and often used on schematics and
- * such.
- */
-static const struct pinctrl_pin_desc nmk_db8540_pins[] = {
-       PINCTRL_PIN(DB8540_PIN_AH6, "GPIO0_AH6"),
-       PINCTRL_PIN(DB8540_PIN_AG7, "GPIO1_AG7"),
-       PINCTRL_PIN(DB8540_PIN_AF2, "GPIO2_AF2"),
-       PINCTRL_PIN(DB8540_PIN_AD3, "GPIO3_AD3"),
-       PINCTRL_PIN(DB8540_PIN_AF6, "GPIO4_AF6"),
-       PINCTRL_PIN(DB8540_PIN_AG6, "GPIO5_AG6"),
-       PINCTRL_PIN(DB8540_PIN_AD5, "GPIO6_AD5"),
-       PINCTRL_PIN(DB8540_PIN_AF7, "GPIO7_AF7"),
-       PINCTRL_PIN(DB8540_PIN_AG5, "GPIO8_AG5"),
-       PINCTRL_PIN(DB8540_PIN_AH5, "GPIO9_AH5"),
-       PINCTRL_PIN(DB8540_PIN_AE4, "GPIO10_AE4"),
-       PINCTRL_PIN(DB8540_PIN_AD1, "GPIO11_AD1"),
-       PINCTRL_PIN(DB8540_PIN_AD2, "GPIO12_AD2"),
-       PINCTRL_PIN(DB8540_PIN_AC2, "GPIO13_AC2"),
-       PINCTRL_PIN(DB8540_PIN_AC4, "GPIO14_AC4"),
-       PINCTRL_PIN(DB8540_PIN_AC3, "GPIO15_AC3"),
-       PINCTRL_PIN(DB8540_PIN_AH7, "GPIO16_AH7"),
-       PINCTRL_PIN(DB8540_PIN_AE7, "GPIO17_AE7"),
-       /* Hole */
-       PINCTRL_PIN(DB8540_PIN_AF8, "GPIO22_AF8"),
-       PINCTRL_PIN(DB8540_PIN_AH11, "GPIO23_AH11"),
-       PINCTRL_PIN(DB8540_PIN_AG11, "GPIO24_AG11"),
-       PINCTRL_PIN(DB8540_PIN_AF11, "GPIO25_AF11"),
-       PINCTRL_PIN(DB8540_PIN_AH10, "GPIO26_AH10"),
-       PINCTRL_PIN(DB8540_PIN_AG10, "GPIO27_AG10"),
-       PINCTRL_PIN(DB8540_PIN_AF10, "GPIO28_AF10"),
-       /* Hole */
-       PINCTRL_PIN(DB8540_PIN_AD4, "GPIO33_AD4"),
-       PINCTRL_PIN(DB8540_PIN_AF3, "GPIO34_AF3"),
-       PINCTRL_PIN(DB8540_PIN_AF5, "GPIO35_AF5"),
-       PINCTRL_PIN(DB8540_PIN_AG4, "GPIO36_AG4"),
-       PINCTRL_PIN(DB8540_PIN_AF9, "GPIO37_AF9"),
-       PINCTRL_PIN(DB8540_PIN_AE8, "GPIO38_AE8"),
-       /* Hole */
-       PINCTRL_PIN(DB8540_PIN_M26, "GPIO64_M26"),
-       PINCTRL_PIN(DB8540_PIN_M25, "GPIO65_M25"),
-       PINCTRL_PIN(DB8540_PIN_M27, "GPIO66_M27"),
-       PINCTRL_PIN(DB8540_PIN_N25, "GPIO67_N25"),
-       /* Hole */
-       PINCTRL_PIN(DB8540_PIN_M28, "GPIO70_M28"),
-       PINCTRL_PIN(DB8540_PIN_N26, "GPIO71_N26"),
-       PINCTRL_PIN(DB8540_PIN_M22, "GPIO72_M22"),
-       PINCTRL_PIN(DB8540_PIN_N22, "GPIO73_N22"),
-       PINCTRL_PIN(DB8540_PIN_N27, "GPIO74_N27"),
-       PINCTRL_PIN(DB8540_PIN_N28, "GPIO75_N28"),
-       PINCTRL_PIN(DB8540_PIN_P22, "GPIO76_P22"),
-       PINCTRL_PIN(DB8540_PIN_P28, "GPIO77_P28"),
-       PINCTRL_PIN(DB8540_PIN_P26, "GPIO78_P26"),
-       PINCTRL_PIN(DB8540_PIN_T22, "GPIO79_T22"),
-       PINCTRL_PIN(DB8540_PIN_R27, "GPIO80_R27"),
-       PINCTRL_PIN(DB8540_PIN_P27, "GPIO81_P27"),
-       PINCTRL_PIN(DB8540_PIN_R26, "GPIO82_R26"),
-       PINCTRL_PIN(DB8540_PIN_R25, "GPIO83_R25"),
-       PINCTRL_PIN(DB8540_PIN_U22, "GPIO84_U22"),
-       PINCTRL_PIN(DB8540_PIN_T27, "GPIO85_T27"),
-       PINCTRL_PIN(DB8540_PIN_T25, "GPIO86_T25"),
-       PINCTRL_PIN(DB8540_PIN_T26, "GPIO87_T26"),
-       /* Hole */
-       PINCTRL_PIN(DB8540_PIN_AF20, "GPIO116_AF20"),
-       PINCTRL_PIN(DB8540_PIN_AG21, "GPIO117_AG21"),
-       PINCTRL_PIN(DB8540_PIN_AH19, "GPIO118_AH19"),
-       PINCTRL_PIN(DB8540_PIN_AE19, "GPIO119_AE19"),
-       PINCTRL_PIN(DB8540_PIN_AG18, "GPIO120_AG18"),
-       PINCTRL_PIN(DB8540_PIN_AH17, "GPIO121_AH17"),
-       PINCTRL_PIN(DB8540_PIN_AF19, "GPIO122_AF19"),
-       PINCTRL_PIN(DB8540_PIN_AF18, "GPIO123_AF18"),
-       PINCTRL_PIN(DB8540_PIN_AE18, "GPIO124_AE18"),
-       PINCTRL_PIN(DB8540_PIN_AG17, "GPIO125_AG17"),
-       PINCTRL_PIN(DB8540_PIN_AF17, "GPIO126_AF17"),
-       PINCTRL_PIN(DB8540_PIN_AE17, "GPIO127_AE17"),
-       PINCTRL_PIN(DB8540_PIN_AC27, "GPIO128_AC27"),
-       PINCTRL_PIN(DB8540_PIN_AD27, "GPIO129_AD27"),
-       PINCTRL_PIN(DB8540_PIN_AE28, "GPIO130_AE28"),
-       PINCTRL_PIN(DB8540_PIN_AG26, "GPIO131_AG26"),
-       PINCTRL_PIN(DB8540_PIN_AF25, "GPIO132_AF25"),
-       PINCTRL_PIN(DB8540_PIN_AE27, "GPIO133_AE27"),
-       PINCTRL_PIN(DB8540_PIN_AF27, "GPIO134_AF27"),
-       PINCTRL_PIN(DB8540_PIN_AG28, "GPIO135_AG28"),
-       PINCTRL_PIN(DB8540_PIN_AF28, "GPIO136_AF28"),
-       PINCTRL_PIN(DB8540_PIN_AG25, "GPIO137_AG25"),
-       PINCTRL_PIN(DB8540_PIN_AG24, "GPIO138_AG24"),
-       PINCTRL_PIN(DB8540_PIN_AD25, "GPIO139_AD25"),
-       PINCTRL_PIN(DB8540_PIN_AH25, "GPIO140_AH25"),
-       PINCTRL_PIN(DB8540_PIN_AF26, "GPIO141_AF26"),
-       PINCTRL_PIN(DB8540_PIN_AF23, "GPIO142_AF23"),
-       PINCTRL_PIN(DB8540_PIN_AG23, "GPIO143_AG23"),
-       PINCTRL_PIN(DB8540_PIN_AE25, "GPIO144_AE25"),
-       PINCTRL_PIN(DB8540_PIN_AH24, "GPIO145_AH24"),
-       PINCTRL_PIN(DB8540_PIN_AJ25, "GPIO146_AJ25"),
-       PINCTRL_PIN(DB8540_PIN_AG27, "GPIO147_AG27"),
-       PINCTRL_PIN(DB8540_PIN_AH23, "GPIO148_AH23"),
-       PINCTRL_PIN(DB8540_PIN_AE26, "GPIO149_AE26"),
-       PINCTRL_PIN(DB8540_PIN_AE24, "GPIO150_AE24"),
-       PINCTRL_PIN(DB8540_PIN_AJ24, "GPIO151_AJ24"),
-       PINCTRL_PIN(DB8540_PIN_AE21, "GPIO152_AE21"),
-       PINCTRL_PIN(DB8540_PIN_AG22, "GPIO153_AG22"),
-       PINCTRL_PIN(DB8540_PIN_AF21, "GPIO154_AF21"),
-       PINCTRL_PIN(DB8540_PIN_AF24, "GPIO155_AF24"),
-       PINCTRL_PIN(DB8540_PIN_AH22, "GPIO156_AH22"),
-       PINCTRL_PIN(DB8540_PIN_AJ23, "GPIO157_AJ23"),
-       PINCTRL_PIN(DB8540_PIN_AH21, "GPIO158_AH21"),
-       PINCTRL_PIN(DB8540_PIN_AG20, "GPIO159_AG20"),
-       PINCTRL_PIN(DB8540_PIN_AE23, "GPIO160_AE23"),
-       PINCTRL_PIN(DB8540_PIN_AH20, "GPIO161_AH20"),
-       PINCTRL_PIN(DB8540_PIN_AG19, "GPIO162_AG19"),
-       PINCTRL_PIN(DB8540_PIN_AF22, "GPIO163_AF22"),
-       PINCTRL_PIN(DB8540_PIN_AJ21, "GPIO164_AJ21"),
-       PINCTRL_PIN(DB8540_PIN_AD26, "GPIO165_AD26"),
-       PINCTRL_PIN(DB8540_PIN_AD28, "GPIO166_AD28"),
-       PINCTRL_PIN(DB8540_PIN_AC28, "GPIO167_AC28"),
-       PINCTRL_PIN(DB8540_PIN_AC26, "GPIO168_AC26"),
-       /* Hole */
-       PINCTRL_PIN(DB8540_PIN_J3, "GPIO192_J3"),
-       PINCTRL_PIN(DB8540_PIN_H1, "GPIO193_H1"),
-       PINCTRL_PIN(DB8540_PIN_J2, "GPIO194_J2"),
-       PINCTRL_PIN(DB8540_PIN_H2, "GPIO195_H2"),
-       PINCTRL_PIN(DB8540_PIN_H3, "GPIO196_H3"),
-       PINCTRL_PIN(DB8540_PIN_H4, "GPIO197_H4"),
-       PINCTRL_PIN(DB8540_PIN_G2, "GPIO198_G2"),
-       PINCTRL_PIN(DB8540_PIN_G3, "GPIO199_G3"),
-       PINCTRL_PIN(DB8540_PIN_G4, "GPIO200_G4"),
-       PINCTRL_PIN(DB8540_PIN_F2, "GPIO201_F2"),
-       PINCTRL_PIN(DB8540_PIN_C6, "GPIO202_C6"),
-       PINCTRL_PIN(DB8540_PIN_B6, "GPIO203_B6"),
-       PINCTRL_PIN(DB8540_PIN_B7, "GPIO204_B7"),
-       PINCTRL_PIN(DB8540_PIN_A7, "GPIO205_A7"),
-       PINCTRL_PIN(DB8540_PIN_D7, "GPIO206_D7"),
-       PINCTRL_PIN(DB8540_PIN_D8, "GPIO207_D8"),
-       PINCTRL_PIN(DB8540_PIN_F3, "GPIO208_F3"),
-       PINCTRL_PIN(DB8540_PIN_E2, "GPIO209_E2"),
-       PINCTRL_PIN(DB8540_PIN_C7, "GPIO210_C7"),
-       PINCTRL_PIN(DB8540_PIN_B8, "GPIO211_B8"),
-       PINCTRL_PIN(DB8540_PIN_C10, "GPIO212_C10"),
-       PINCTRL_PIN(DB8540_PIN_C8, "GPIO213_C8"),
-       PINCTRL_PIN(DB8540_PIN_C9, "GPIO214_C9"),
-       /* Hole */
-       PINCTRL_PIN(DB8540_PIN_B9, "GPIO219_B9"),
-       PINCTRL_PIN(DB8540_PIN_A10, "GPIO220_A10"),
-       PINCTRL_PIN(DB8540_PIN_D9, "GPIO221_D9"),
-       PINCTRL_PIN(DB8540_PIN_B11, "GPIO222_B11"),
-       PINCTRL_PIN(DB8540_PIN_B10, "GPIO223_B10"),
-       PINCTRL_PIN(DB8540_PIN_E10, "GPIO224_E10"),
-       PINCTRL_PIN(DB8540_PIN_B12, "GPIO225_B12"),
-       PINCTRL_PIN(DB8540_PIN_D10, "GPIO226_D10"),
-       PINCTRL_PIN(DB8540_PIN_D11, "GPIO227_D11"),
-       PINCTRL_PIN(DB8540_PIN_AJ6, "GPIO228_AJ6"),
-       PINCTRL_PIN(DB8540_PIN_B13, "GPIO229_B13"),
-       PINCTRL_PIN(DB8540_PIN_C12, "GPIO230_C12"),
-       PINCTRL_PIN(DB8540_PIN_B14, "GPIO231_B14"),
-       PINCTRL_PIN(DB8540_PIN_E11, "GPIO232_E11"),
-       /* Hole */
-       PINCTRL_PIN(DB8540_PIN_D12, "GPIO256_D12"),
-       PINCTRL_PIN(DB8540_PIN_D15, "GPIO257_D15"),
-       PINCTRL_PIN(DB8540_PIN_C13, "GPIO258_C13"),
-       PINCTRL_PIN(DB8540_PIN_C14, "GPIO259_C14"),
-       PINCTRL_PIN(DB8540_PIN_C18, "GPIO260_C18"),
-       PINCTRL_PIN(DB8540_PIN_C16, "GPIO261_C16"),
-       PINCTRL_PIN(DB8540_PIN_B16, "GPIO262_B16"),
-       PINCTRL_PIN(DB8540_PIN_D18, "GPIO263_D18"),
-       PINCTRL_PIN(DB8540_PIN_C15, "GPIO264_C15"),
-       PINCTRL_PIN(DB8540_PIN_C17, "GPIO265_C17"),
-       PINCTRL_PIN(DB8540_PIN_B17, "GPIO266_B17"),
-       PINCTRL_PIN(DB8540_PIN_D17, "GPIO267_D17"),
-};
-
-/*
- * Read the pin group names like this:
- * u0_a_1    = first groups of pins for uart0 on alt function a
- * i2c2_b_2  = second group of pins for i2c2 on alt function b
- *
- * The groups are arranged as sets per altfunction column, so we can
- * mux in one group at a time by selecting the same altfunction for them
- * all. When functions require pins on different altfunctions, you need
- * to combine several groups.
- */
-
-/* Altfunction A column */
-static const unsigned u0_a_1_pins[] = { DB8540_PIN_AH6, DB8540_PIN_AG7,
-                                       DB8540_PIN_AF2, DB8540_PIN_AD3 };
-static const unsigned u1rxtx_a_1_pins[] = { DB8540_PIN_AF6, DB8540_PIN_AG6 };
-static const unsigned u1ctsrts_a_1_pins[] = { DB8540_PIN_AD5, DB8540_PIN_AF7 };
-/* Image processor I2C line, this is driven by image processor firmware */
-static const unsigned ipi2c_a_1_pins[] = { DB8540_PIN_AG5, DB8540_PIN_AH5 };
-static const unsigned ipi2c_a_2_pins[] = { DB8540_PIN_AE4, DB8540_PIN_AD1 };
-/* MSP0 can only be on these pins, but TXD and RXD can be flipped */
-static const unsigned msp0txrx_a_1_pins[] = { DB8540_PIN_AD2, DB8540_PIN_AC3 };
-static const unsigned msp0tfstck_a_1_pins[] = { DB8540_PIN_AC2,
-       DB8540_PIN_AC4 };
-static const unsigned msp0rfsrck_a_1_pins[] = { DB8540_PIN_AH7,
-       DB8540_PIN_AE7 };
-/* Basic pins of the MMC/SD card 0 interface */
-static const unsigned mc0_a_1_pins[] = { DB8540_PIN_AH11, DB8540_PIN_AG11,
-       DB8540_PIN_AF11, DB8540_PIN_AH10, DB8540_PIN_AG10, DB8540_PIN_AF10};
-/* MSP1 can only be on these pins, but TXD and RXD can be flipped */
-static const unsigned msp1txrx_a_1_pins[] = { DB8540_PIN_AD4, DB8540_PIN_AG4 };
-static const unsigned msp1_a_1_pins[] = { DB8540_PIN_AF3, DB8540_PIN_AF5 };
-
-static const unsigned modobsclk_a_1_pins[] = { DB8540_PIN_AF9 };
-static const unsigned clkoutreq_a_1_pins[] = { DB8540_PIN_AE8 };
-/* LCD interface */
-static const unsigned lcdb_a_1_pins[] = { DB8540_PIN_M26, DB8540_PIN_M25,
-       DB8540_PIN_M27, DB8540_PIN_N25 };
-static const unsigned lcdvsi0_a_1_pins[] = { DB8540_PIN_AJ24 };
-static const unsigned lcdvsi1_a_1_pins[] = { DB8540_PIN_AE21 };
-static const unsigned lcd_d0_d7_a_1_pins[] = { DB8540_PIN_M28, DB8540_PIN_N26,
-       DB8540_PIN_M22, DB8540_PIN_N22, DB8540_PIN_N27, DB8540_PIN_N28,
-       DB8540_PIN_P22, DB8540_PIN_P28 };
-/* D8 thru D11 often used as TVOUT lines */
-static const unsigned lcd_d8_d11_a_1_pins[] = { DB8540_PIN_P26, DB8540_PIN_T22,
-       DB8540_PIN_R27, DB8540_PIN_P27 };
-static const unsigned lcd_d12_d23_a_1_pins[] = { DB8540_PIN_R26, DB8540_PIN_R25,
-       DB8540_PIN_U22, DB8540_PIN_T27, DB8540_PIN_AG22, DB8540_PIN_AF21,
-       DB8540_PIN_AF24, DB8540_PIN_AH22, DB8540_PIN_AJ23, DB8540_PIN_AH21,
-       DB8540_PIN_AG20, DB8540_PIN_AE23 };
-static const unsigned kp_a_1_pins[] = { DB8540_PIN_AH20, DB8540_PIN_AG19,
-       DB8540_PIN_AF22, DB8540_PIN_AJ21, DB8540_PIN_T25, DB8540_PIN_T26 };
-/* MC2 has 8 data lines and no direction control, so only for (e)MMC */
-static const unsigned mc2_a_1_pins[] = { DB8540_PIN_AC27, DB8540_PIN_AD27,
-       DB8540_PIN_AE28, DB8540_PIN_AG26, DB8540_PIN_AF25, DB8540_PIN_AE27,
-       DB8540_PIN_AF27, DB8540_PIN_AG28, DB8540_PIN_AF28, DB8540_PIN_AG25,
-       DB8540_PIN_AG24 };
-static const unsigned ssp1_a_1_pins[] = {  DB8540_PIN_AD25, DB8540_PIN_AH25,
-       DB8540_PIN_AF26, DB8540_PIN_AF23 };
-static const unsigned ssp0_a_1_pins[] = { DB8540_PIN_AG23, DB8540_PIN_AE25,
-       DB8540_PIN_AH24, DB8540_PIN_AJ25 };
-static const unsigned i2c0_a_1_pins[] = { DB8540_PIN_AG27, DB8540_PIN_AH23 };
-/*
- * Image processor GPIO pins are named "ipgpio" and have their own
- * numberspace
- */
-static const unsigned ipgpio0_a_1_pins[] = { DB8540_PIN_AE26 };
-static const unsigned ipgpio1_a_1_pins[] = { DB8540_PIN_AE24 };
-/* modem i2s interface */
-static const unsigned modi2s_a_1_pins[] = { DB8540_PIN_AD26, DB8540_PIN_AD28,
-       DB8540_PIN_AC28, DB8540_PIN_AC26 };
-static const unsigned spi2_a_1_pins[] = { DB8540_PIN_AF20, DB8540_PIN_AG21,
-       DB8540_PIN_AH19, DB8540_PIN_AE19 };
-static const unsigned u2txrx_a_1_pins[] = { DB8540_PIN_AG18, DB8540_PIN_AH17 };
-static const unsigned u2ctsrts_a_1_pins[] = { DB8540_PIN_AF19,
-       DB8540_PIN_AF18 };
-static const unsigned modsmb_a_1_pins[] = { DB8540_PIN_AF17, DB8540_PIN_AE17 };
-static const unsigned msp2sck_a_1_pins[] = { DB8540_PIN_J3 };
-static const unsigned msp2txdtcktfs_a_1_pins[] = { DB8540_PIN_H1, DB8540_PIN_J2,
-       DB8540_PIN_H2 };
-static const unsigned msp2rxd_a_1_pins[] = { DB8540_PIN_H3 };
-static const unsigned mc4_a_1_pins[] = { DB8540_PIN_H4, DB8540_PIN_G2,
-       DB8540_PIN_G3, DB8540_PIN_G4, DB8540_PIN_F2, DB8540_PIN_C6,
-       DB8540_PIN_B6, DB8540_PIN_B7, DB8540_PIN_A7, DB8540_PIN_D7,
-       DB8540_PIN_D8 };
-static const unsigned mc1_a_1_pins[] = { DB8540_PIN_F3, DB8540_PIN_E2,
-       DB8540_PIN_C7, DB8540_PIN_B8, DB8540_PIN_C10, DB8540_PIN_C8,
-       DB8540_PIN_C9 };
-/* mc1_a_2_pins exclude MC1_FBCLK */
-static const unsigned mc1_a_2_pins[] = { DB8540_PIN_F3,        DB8540_PIN_C7,
-       DB8540_PIN_B8, DB8540_PIN_C10, DB8540_PIN_C8,
-       DB8540_PIN_C9 };
-static const unsigned hsir_a_1_pins[] = { DB8540_PIN_B9, DB8540_PIN_A10,
-       DB8540_PIN_D9 };
-static const unsigned hsit_a_1_pins[] = { DB8540_PIN_B11, DB8540_PIN_B10,
-       DB8540_PIN_E10, DB8540_PIN_B12, DB8540_PIN_D10 };
-static const unsigned hsit_a_2_pins[] = { DB8540_PIN_B11, DB8540_PIN_B10,
-       DB8540_PIN_E10, DB8540_PIN_B12 };
-static const unsigned clkout1_a_1_pins[] = { DB8540_PIN_D11 };
-static const unsigned clkout1_a_2_pins[] = { DB8540_PIN_B13 };
-static const unsigned clkout2_a_1_pins[] = { DB8540_PIN_AJ6 };
-static const unsigned clkout2_a_2_pins[] = { DB8540_PIN_C12 };
-static const unsigned msp4_a_1_pins[] = { DB8540_PIN_B14, DB8540_PIN_E11 };
-static const unsigned usb_a_1_pins[] = { DB8540_PIN_D12, DB8540_PIN_D15,
-       DB8540_PIN_C13, DB8540_PIN_C14, DB8540_PIN_C18, DB8540_PIN_C16,
-       DB8540_PIN_B16, DB8540_PIN_D18, DB8540_PIN_C15, DB8540_PIN_C17,
-       DB8540_PIN_B17, DB8540_PIN_D17 };
-/* Altfunction B colum */
-static const unsigned apetrig_b_1_pins[] = { DB8540_PIN_AH6, DB8540_PIN_AG7 };
-static const unsigned modtrig_b_1_pins[] = { DB8540_PIN_AF2, DB8540_PIN_AD3 };
-static const unsigned i2c4_b_1_pins[] = { DB8540_PIN_AF6, DB8540_PIN_AG6 };
-static const unsigned i2c1_b_1_pins[] = { DB8540_PIN_AD5, DB8540_PIN_AF7 };
-static const unsigned i2c2_b_1_pins[] = { DB8540_PIN_AG5, DB8540_PIN_AH5 };
-static const unsigned i2c2_b_2_pins[] = { DB8540_PIN_AE4, DB8540_PIN_AD1 };
-static const unsigned msp0txrx_b_1_pins[] = { DB8540_PIN_AD2, DB8540_PIN_AC3 };
-static const unsigned i2c1_b_2_pins[] = { DB8540_PIN_AH7, DB8540_PIN_AE7 };
-static const unsigned stmmod_b_1_pins[] = { DB8540_PIN_AH11, DB8540_PIN_AF11,
-       DB8540_PIN_AH10, DB8540_PIN_AG10, DB8540_PIN_AF10 };
-static const unsigned moduartstmmux_b_1_pins[] = { DB8540_PIN_AG11 };
-static const unsigned msp1txrx_b_1_pins[] = { DB8540_PIN_AD4, DB8540_PIN_AG4 };
-static const unsigned kp_b_1_pins[] = { DB8540_PIN_AJ24, DB8540_PIN_AE21,
-       DB8540_PIN_M26, DB8540_PIN_M25, DB8540_PIN_M27, DB8540_PIN_N25,
-       DB8540_PIN_M28, DB8540_PIN_N26, DB8540_PIN_M22, DB8540_PIN_N22,
-       DB8540_PIN_N27, DB8540_PIN_N28, DB8540_PIN_P22, DB8540_PIN_P28,
-       DB8540_PIN_P26, DB8540_PIN_T22, DB8540_PIN_R27, DB8540_PIN_P27,
-       DB8540_PIN_R26, DB8540_PIN_R25 };
-static const unsigned u2txrx_b_1_pins[] = { DB8540_PIN_U22, DB8540_PIN_T27 };
-static const unsigned sm_b_1_pins[] = { DB8540_PIN_AG22, DB8540_PIN_AF21,
-       DB8540_PIN_AF24, DB8540_PIN_AH22, DB8540_PIN_AJ23, DB8540_PIN_AH21,
-       DB8540_PIN_AG20, DB8540_PIN_AE23, DB8540_PIN_AH20, DB8540_PIN_AF22,
-       DB8540_PIN_AJ21, DB8540_PIN_AC27, DB8540_PIN_AD27, DB8540_PIN_AE28,
-       DB8540_PIN_AG26, DB8540_PIN_AF25, DB8540_PIN_AE27, DB8540_PIN_AF27,
-       DB8540_PIN_AG28, DB8540_PIN_AF28, DB8540_PIN_AG25, DB8540_PIN_AG24,
-       DB8540_PIN_AD25 };
-static const unsigned smcs0_b_1_pins[] = { DB8540_PIN_AG19 };
-static const unsigned smcs1_b_1_pins[] = { DB8540_PIN_AE26 };
-static const unsigned ipgpio7_b_1_pins[] = { DB8540_PIN_AH25 };
-static const unsigned ipgpio2_b_1_pins[] = { DB8540_PIN_AF26 };
-static const unsigned ipgpio3_b_1_pins[] = { DB8540_PIN_AF23 };
-static const unsigned i2c6_b_1_pins[] = { DB8540_PIN_AG23, DB8540_PIN_AE25 };
-static const unsigned i2c5_b_1_pins[] = { DB8540_PIN_AH24, DB8540_PIN_AJ25 };
-static const unsigned u3txrx_b_1_pins[] = { DB8540_PIN_AF20, DB8540_PIN_AG21 };
-static const unsigned u3ctsrts_b_1_pins[] = { DB8540_PIN_AH19,
-       DB8540_PIN_AE19 };
-static const unsigned i2c5_b_2_pins[] = { DB8540_PIN_AG18, DB8540_PIN_AH17 };
-static const unsigned i2c4_b_2_pins[] = { DB8540_PIN_AF19, DB8540_PIN_AF18 };
-static const unsigned u4txrx_b_1_pins[] = { DB8540_PIN_AE18, DB8540_PIN_AG17 };
-static const unsigned u4ctsrts_b_1_pins[] = { DB8540_PIN_AF17,
-       DB8540_PIN_AE17 };
-static const unsigned ddrtrig_b_1_pins[] = { DB8540_PIN_J3 };
-static const unsigned msp4_b_1_pins[] = { DB8540_PIN_H3 };
-static const unsigned pwl_b_1_pins[] = { DB8540_PIN_C6 };
-static const unsigned spi1_b_1_pins[] = { DB8540_PIN_E2, DB8540_PIN_C10,
-       DB8540_PIN_C8, DB8540_PIN_C9 };
-static const unsigned mc3_b_1_pins[] = { DB8540_PIN_B9, DB8540_PIN_A10,
-       DB8540_PIN_D9, DB8540_PIN_B11, DB8540_PIN_B10, DB8540_PIN_E10,
-       DB8540_PIN_B12 };
-static const unsigned pwl_b_2_pins[] = { DB8540_PIN_D10 };
-static const unsigned pwl_b_3_pins[] = { DB8540_PIN_B13 };
-static const unsigned pwl_b_4_pins[] = { DB8540_PIN_C12 };
-static const unsigned u2txrx_b_2_pins[] = { DB8540_PIN_B17, DB8540_PIN_D17 };
-
-/* Altfunction C column */
-static const unsigned ipgpio6_c_1_pins[] = { DB8540_PIN_AG6 };
-static const unsigned ipgpio0_c_1_pins[] = { DB8540_PIN_AD5 };
-static const unsigned ipgpio1_c_1_pins[] = { DB8540_PIN_AF7 };
-static const unsigned ipgpio3_c_1_pins[] = { DB8540_PIN_AE4 };
-static const unsigned ipgpio2_c_1_pins[] = { DB8540_PIN_AD1 };
-static const unsigned u0_c_1_pins[] = { DB8540_PIN_AD4, DB8540_PIN_AF3,
-       DB8540_PIN_AF5, DB8540_PIN_AG4 };
-static const unsigned smcleale_c_1_pins[] = { DB8540_PIN_AJ24,
-       DB8540_PIN_AE21 };
-static const unsigned ipgpio4_c_1_pins[] = { DB8540_PIN_M26 };
-static const unsigned ipgpio5_c_1_pins[] = { DB8540_PIN_M25 };
-static const unsigned ipgpio6_c_2_pins[] = { DB8540_PIN_M27 };
-static const unsigned ipgpio7_c_1_pins[] = { DB8540_PIN_N25 };
-static const unsigned stmape_c_1_pins[] = { DB8540_PIN_M28, DB8540_PIN_N26,
-       DB8540_PIN_M22, DB8540_PIN_N22, DB8540_PIN_N27 };
-static const unsigned u2rxtx_c_1_pins[] = { DB8540_PIN_N28, DB8540_PIN_P22 };
-static const unsigned modobsresout_c_1_pins[] = { DB8540_PIN_P28 };
-static const unsigned ipgpio2_c_2_pins[] = { DB8540_PIN_P26 };
-static const unsigned ipgpio3_c_2_pins[] = { DB8540_PIN_T22 };
-static const unsigned ipgpio4_c_2_pins[] = { DB8540_PIN_R27 };
-static const unsigned ipgpio5_c_2_pins[] = { DB8540_PIN_P27 };
-static const unsigned modaccgpo_c_1_pins[] = { DB8540_PIN_R26, DB8540_PIN_R25,
-       DB8540_PIN_U22 };
-static const unsigned modobspwrrst_c_1_pins[] = { DB8540_PIN_T27 };
-static const unsigned mc5_c_1_pins[] = { DB8540_PIN_AG22, DB8540_PIN_AF21,
-       DB8540_PIN_AF24, DB8540_PIN_AH22, DB8540_PIN_AJ23, DB8540_PIN_AH21,
-       DB8540_PIN_AG20, DB8540_PIN_AE23, DB8540_PIN_AH20, DB8540_PIN_AF22,
-       DB8540_PIN_AJ21};
-static const unsigned smps0_c_1_pins[] = { DB8540_PIN_AG19 };
-static const unsigned moduart1_c_1_pins[] = { DB8540_PIN_T25, DB8540_PIN_T26 };
-static const unsigned mc2rstn_c_1_pins[] = { DB8540_PIN_AE28 };
-static const unsigned i2c5_c_1_pins[] = { DB8540_PIN_AG28, DB8540_PIN_AF28 };
-static const unsigned ipgpio0_c_2_pins[] = { DB8540_PIN_AG25 };
-static const unsigned ipgpio1_c_2_pins[] = { DB8540_PIN_AG24 };
-static const unsigned kp_c_1_pins[] = { DB8540_PIN_AD25, DB8540_PIN_AH25,
-       DB8540_PIN_AF26, DB8540_PIN_AF23 };
-static const unsigned modrf_c_1_pins[] = { DB8540_PIN_AG23, DB8540_PIN_AE25,
-       DB8540_PIN_AH24 };
-static const unsigned smps1_c_1_pins[] = { DB8540_PIN_AE26 };
-static const unsigned i2c5_c_2_pins[] = { DB8540_PIN_AH19, DB8540_PIN_AE19 };
-static const unsigned u4ctsrts_c_1_pins[] = { DB8540_PIN_AG18,
-       DB8540_PIN_AH17 };
-static const unsigned u3rxtx_c_1_pins[] = { DB8540_PIN_AF19, DB8540_PIN_AF18 };
-static const unsigned msp4_c_1_pins[] = { DB8540_PIN_J3 };
-static const unsigned mc4rstn_c_1_pins[] = { DB8540_PIN_C6 };
-static const unsigned spi0_c_1_pins[] = { DB8540_PIN_A10, DB8540_PIN_B10,
-       DB8540_PIN_E10, DB8540_PIN_B12 };
-static const unsigned i2c3_c_1_pins[] = { DB8540_PIN_B13, DB8540_PIN_C12 };
-
-/* Other alt C1 column */
-static const unsigned spi3_oc1_1_pins[] = { DB8540_PIN_AG5, DB8540_PIN_AH5,
-       DB8540_PIN_AE4, DB8540_PIN_AD1 };
-static const unsigned stmape_oc1_1_pins[] = { DB8540_PIN_AH11, DB8540_PIN_AF11,
-       DB8540_PIN_AH10, DB8540_PIN_AG10, DB8540_PIN_AF10 };
-static const unsigned u2_oc1_1_pins[] = { DB8540_PIN_AG11 };
-static const unsigned remap0_oc1_1_pins[] = { DB8540_PIN_AJ24 };
-static const unsigned remap1_oc1_1_pins[] = { DB8540_PIN_AE21 };
-static const unsigned modobsrefclk_oc1_1_pins[] = { DB8540_PIN_M26 };
-static const unsigned modobspwrctrl_oc1_1_pins[] = { DB8540_PIN_M25 };
-static const unsigned modobsclkout_oc1_1_pins[] = { DB8540_PIN_M27 };
-static const unsigned moduart1_oc1_1_pins[] = { DB8540_PIN_N25 };
-static const unsigned modprcmudbg_oc1_1_pins[] = { DB8540_PIN_M28,
-       DB8540_PIN_N26, DB8540_PIN_M22, DB8540_PIN_N22, DB8540_PIN_N27,
-       DB8540_PIN_P22, DB8540_PIN_P28, DB8540_PIN_P26, DB8540_PIN_T22,
-       DB8540_PIN_R26, DB8540_PIN_R25, DB8540_PIN_U22, DB8540_PIN_T27,
-       DB8540_PIN_AH20, DB8540_PIN_AG19, DB8540_PIN_AF22, DB8540_PIN_AJ21,
-       DB8540_PIN_T25};
-static const unsigned modobsresout_oc1_1_pins[] = { DB8540_PIN_N28 };
-static const unsigned modaccgpo_oc1_1_pins[] = { DB8540_PIN_R27, DB8540_PIN_P27,
-       DB8540_PIN_T26 };
-static const unsigned kp_oc1_1_pins[] = { DB8540_PIN_AG22, DB8540_PIN_AF21,
-       DB8540_PIN_AF24, DB8540_PIN_AH22, DB8540_PIN_AJ23, DB8540_PIN_AH21,
-       DB8540_PIN_AG20, DB8540_PIN_AE23 };
-static const unsigned modxmip_oc1_1_pins[] = { DB8540_PIN_AD25, DB8540_PIN_AH25,
-       DB8540_PIN_AG23, DB8540_PIN_AE25 };
-static const unsigned i2c6_oc1_1_pins[] = { DB8540_PIN_AE26, DB8540_PIN_AE24 };
-static const unsigned u2txrx_oc1_1_pins[] = { DB8540_PIN_B7, DB8540_PIN_A7 };
-static const unsigned u2ctsrts_oc1_1_pins[] = { DB8540_PIN_D7, DB8540_PIN_D8 };
-
-/* Other alt C2 column */
-static const unsigned sbag_oc2_1_pins[] = { DB8540_PIN_AH11, DB8540_PIN_AG11,
-       DB8540_PIN_AF11, DB8540_PIN_AH10, DB8540_PIN_AG10, DB8540_PIN_AF10 };
-static const unsigned hxclk_oc2_1_pins[] = { DB8540_PIN_M25 };
-static const unsigned modaccuart_oc2_1_pins[] = { DB8540_PIN_N25 };
-static const unsigned stmmod_oc2_1_pins[] = { DB8540_PIN_M28, DB8540_PIN_N26,
-       DB8540_PIN_M22, DB8540_PIN_N22, DB8540_PIN_N27 };
-static const unsigned moduartstmmux_oc2_1_pins[] = { DB8540_PIN_N28 };
-static const unsigned hxgpio_oc2_1_pins[] = { DB8540_PIN_P22, DB8540_PIN_P28,
-       DB8540_PIN_P26, DB8540_PIN_T22, DB8540_PIN_R27, DB8540_PIN_P27,
-       DB8540_PIN_R26, DB8540_PIN_R25 };
-static const unsigned sbag_oc2_2_pins[] = { DB8540_PIN_U22, DB8540_PIN_T27,
-       DB8540_PIN_AG22, DB8540_PIN_AF21, DB8540_PIN_AF24, DB8540_PIN_AH22 };
-static const unsigned modobsservice_oc2_1_pins[] = { DB8540_PIN_AJ23 };
-static const unsigned moduart0_oc2_1_pins[] = { DB8540_PIN_AG20,
-       DB8540_PIN_AE23 };
-static const unsigned stmape_oc2_1_pins[] = { DB8540_PIN_AH20, DB8540_PIN_AG19,
-       DB8540_PIN_AF22, DB8540_PIN_AJ21, DB8540_PIN_T25 };
-static const unsigned u2_oc2_1_pins[] = { DB8540_PIN_T26, DB8540_PIN_AH21 };
-static const unsigned modxmip_oc2_1_pins[] = { DB8540_PIN_AE26,
-       DB8540_PIN_AE24 };
-
-/* Other alt C3 column */
-static const unsigned modaccgpo_oc3_1_pins[] = { DB8540_PIN_AG11 };
-static const unsigned tpui_oc3_1_pins[] = { DB8540_PIN_M26, DB8540_PIN_M25,
-       DB8540_PIN_M27, DB8540_PIN_N25, DB8540_PIN_M28, DB8540_PIN_N26,
-       DB8540_PIN_M22, DB8540_PIN_N22, DB8540_PIN_N27, DB8540_PIN_N28,
-       DB8540_PIN_P22, DB8540_PIN_P28, DB8540_PIN_P26, DB8540_PIN_T22,
-       DB8540_PIN_R27, DB8540_PIN_P27, DB8540_PIN_R26, DB8540_PIN_R25,
-       DB8540_PIN_U22, DB8540_PIN_T27, DB8540_PIN_AG22, DB8540_PIN_AF21,
-       DB8540_PIN_AF24, DB8540_PIN_AH22, DB8540_PIN_AJ23, DB8540_PIN_AH21,
-       DB8540_PIN_AG20, DB8540_PIN_AE23, DB8540_PIN_AH20, DB8540_PIN_AG19,
-       DB8540_PIN_AF22, DB8540_PIN_AJ21, DB8540_PIN_T25, DB8540_PIN_T26 };
-
-/* Other alt C4 column */
-static const unsigned hwobs_oc4_1_pins[] = { DB8540_PIN_M26, DB8540_PIN_M25,
-       DB8540_PIN_M27, DB8540_PIN_N25, DB8540_PIN_M28, DB8540_PIN_N26,
-       DB8540_PIN_M22, DB8540_PIN_N22, DB8540_PIN_N27, DB8540_PIN_N28,
-       DB8540_PIN_P22, DB8540_PIN_P28, DB8540_PIN_P26, DB8540_PIN_T22,
-       DB8540_PIN_R27, DB8540_PIN_P27, DB8540_PIN_R26, DB8540_PIN_R25 };
-static const unsigned moduart1txrx_oc4_1_pins[] = { DB8540_PIN_U22,
-       DB8540_PIN_T27 };
-static const unsigned moduart1rtscts_oc4_1_pins[] = { DB8540_PIN_AG22,
-       DB8540_PIN_AF21 };
-static const unsigned modaccuarttxrx_oc4_1_pins[] = { DB8540_PIN_AF24,
-       DB8540_PIN_AH22 };
-static const unsigned modaccuartrtscts_oc4_1_pins[] = { DB8540_PIN_AJ23,
-       DB8540_PIN_AH21 };
-static const unsigned stmmod_oc4_1_pins[] = { DB8540_PIN_AH20, DB8540_PIN_AG19,
-       DB8540_PIN_AF22, DB8540_PIN_AJ21, DB8540_PIN_T25 };
-static const unsigned moduartstmmux_oc4_1_pins[] = { DB8540_PIN_T26 };
-
-#define DB8540_PIN_GROUP(a, b) { .name = #a, .pins = a##_pins,         \
-                       .npins = ARRAY_SIZE(a##_pins), .altsetting = b }
-
-static const struct nmk_pingroup nmk_db8540_groups[] = {
-       /* Altfunction A column */
-       DB8540_PIN_GROUP(u0_a_1, NMK_GPIO_ALT_A),
-       DB8540_PIN_GROUP(u1rxtx_a_1, NMK_GPIO_ALT_A),
-       DB8540_PIN_GROUP(u1ctsrts_a_1, NMK_GPIO_ALT_A),
-       DB8540_PIN_GROUP(ipi2c_a_1, NMK_GPIO_ALT_A),
-       DB8540_PIN_GROUP(ipi2c_a_2, NMK_GPIO_ALT_A),
-       DB8540_PIN_GROUP(msp0txrx_a_1, NMK_GPIO_ALT_A),
-       DB8540_PIN_GROUP(msp0tfstck_a_1, NMK_GPIO_ALT_A),
-       DB8540_PIN_GROUP(msp0rfsrck_a_1, NMK_GPIO_ALT_A),
-       DB8540_PIN_GROUP(mc0_a_1, NMK_GPIO_ALT_A),
-       DB8540_PIN_GROUP(msp1txrx_a_1, NMK_GPIO_ALT_A),
-       DB8540_PIN_GROUP(msp1_a_1, NMK_GPIO_ALT_A),
-       DB8540_PIN_GROUP(modobsclk_a_1, NMK_GPIO_ALT_A),
-       DB8540_PIN_GROUP(clkoutreq_a_1, NMK_GPIO_ALT_A),
-       DB8540_PIN_GROUP(lcdb_a_1, NMK_GPIO_ALT_A),
-       DB8540_PIN_GROUP(lcdvsi0_a_1, NMK_GPIO_ALT_A),
-       DB8540_PIN_GROUP(lcdvsi1_a_1, NMK_GPIO_ALT_A),
-       DB8540_PIN_GROUP(lcd_d0_d7_a_1, NMK_GPIO_ALT_A),
-       DB8540_PIN_GROUP(lcd_d8_d11_a_1, NMK_GPIO_ALT_A),
-       DB8540_PIN_GROUP(lcd_d12_d23_a_1, NMK_GPIO_ALT_A),
-       DB8540_PIN_GROUP(kp_a_1, NMK_GPIO_ALT_A),
-       DB8540_PIN_GROUP(mc2_a_1, NMK_GPIO_ALT_A),
-       DB8540_PIN_GROUP(ssp1_a_1, NMK_GPIO_ALT_A),
-       DB8540_PIN_GROUP(ssp0_a_1, NMK_GPIO_ALT_A),
-       DB8540_PIN_GROUP(i2c0_a_1, NMK_GPIO_ALT_A),
-       DB8540_PIN_GROUP(ipgpio0_a_1, NMK_GPIO_ALT_A),
-       DB8540_PIN_GROUP(ipgpio1_a_1, NMK_GPIO_ALT_A),
-       DB8540_PIN_GROUP(modi2s_a_1, NMK_GPIO_ALT_A),
-       DB8540_PIN_GROUP(spi2_a_1, NMK_GPIO_ALT_A),
-       DB8540_PIN_GROUP(u2txrx_a_1, NMK_GPIO_ALT_A),
-       DB8540_PIN_GROUP(u2ctsrts_a_1, NMK_GPIO_ALT_A),
-       DB8540_PIN_GROUP(modsmb_a_1, NMK_GPIO_ALT_A),
-       DB8540_PIN_GROUP(msp2sck_a_1, NMK_GPIO_ALT_A),
-       DB8540_PIN_GROUP(msp2txdtcktfs_a_1, NMK_GPIO_ALT_A),
-       DB8540_PIN_GROUP(msp2rxd_a_1, NMK_GPIO_ALT_A),
-       DB8540_PIN_GROUP(mc4_a_1, NMK_GPIO_ALT_A),
-       DB8540_PIN_GROUP(mc1_a_1, NMK_GPIO_ALT_A),
-       DB8540_PIN_GROUP(hsir_a_1, NMK_GPIO_ALT_A),
-       DB8540_PIN_GROUP(hsit_a_1, NMK_GPIO_ALT_A),
-       DB8540_PIN_GROUP(hsit_a_2, NMK_GPIO_ALT_A),
-       DB8540_PIN_GROUP(clkout1_a_1, NMK_GPIO_ALT_A),
-       DB8540_PIN_GROUP(clkout1_a_2, NMK_GPIO_ALT_A),
-       DB8540_PIN_GROUP(clkout2_a_1, NMK_GPIO_ALT_A),
-       DB8540_PIN_GROUP(clkout2_a_2, NMK_GPIO_ALT_A),
-       DB8540_PIN_GROUP(msp4_a_1, NMK_GPIO_ALT_A),
-       DB8540_PIN_GROUP(usb_a_1, NMK_GPIO_ALT_A),
-       /* Altfunction B column */
-       DB8540_PIN_GROUP(apetrig_b_1, NMK_GPIO_ALT_B),
-       DB8540_PIN_GROUP(modtrig_b_1, NMK_GPIO_ALT_B),
-       DB8540_PIN_GROUP(i2c4_b_1, NMK_GPIO_ALT_B),
-       DB8540_PIN_GROUP(i2c1_b_1, NMK_GPIO_ALT_B),
-       DB8540_PIN_GROUP(i2c2_b_1, NMK_GPIO_ALT_B),
-       DB8540_PIN_GROUP(i2c2_b_2, NMK_GPIO_ALT_B),
-       DB8540_PIN_GROUP(msp0txrx_b_1, NMK_GPIO_ALT_B),
-       DB8540_PIN_GROUP(i2c1_b_2, NMK_GPIO_ALT_B),
-       DB8540_PIN_GROUP(stmmod_b_1, NMK_GPIO_ALT_B),
-       DB8540_PIN_GROUP(moduartstmmux_b_1, NMK_GPIO_ALT_B),
-       DB8540_PIN_GROUP(msp1txrx_b_1, NMK_GPIO_ALT_B),
-       DB8540_PIN_GROUP(kp_b_1, NMK_GPIO_ALT_B),
-       DB8540_PIN_GROUP(u2txrx_b_1, NMK_GPIO_ALT_B),
-       DB8540_PIN_GROUP(sm_b_1, NMK_GPIO_ALT_B),
-       DB8540_PIN_GROUP(smcs0_b_1, NMK_GPIO_ALT_B),
-       DB8540_PIN_GROUP(smcs1_b_1, NMK_GPIO_ALT_B),
-       DB8540_PIN_GROUP(ipgpio7_b_1, NMK_GPIO_ALT_B),
-       DB8540_PIN_GROUP(ipgpio2_b_1, NMK_GPIO_ALT_B),
-       DB8540_PIN_GROUP(ipgpio3_b_1, NMK_GPIO_ALT_B),
-       DB8540_PIN_GROUP(i2c6_b_1, NMK_GPIO_ALT_B),
-       DB8540_PIN_GROUP(i2c5_b_1, NMK_GPIO_ALT_B),
-       DB8540_PIN_GROUP(u3txrx_b_1, NMK_GPIO_ALT_B),
-       DB8540_PIN_GROUP(u3ctsrts_b_1, NMK_GPIO_ALT_B),
-       DB8540_PIN_GROUP(i2c5_b_2, NMK_GPIO_ALT_B),
-       DB8540_PIN_GROUP(i2c4_b_2, NMK_GPIO_ALT_B),
-       DB8540_PIN_GROUP(u4txrx_b_1, NMK_GPIO_ALT_B),
-       DB8540_PIN_GROUP(u4ctsrts_b_1, NMK_GPIO_ALT_B),
-       DB8540_PIN_GROUP(ddrtrig_b_1, NMK_GPIO_ALT_B),
-       DB8540_PIN_GROUP(msp4_b_1, NMK_GPIO_ALT_B),
-       DB8540_PIN_GROUP(pwl_b_1, NMK_GPIO_ALT_B),
-       DB8540_PIN_GROUP(spi1_b_1, NMK_GPIO_ALT_B),
-       DB8540_PIN_GROUP(mc3_b_1, NMK_GPIO_ALT_B),
-       DB8540_PIN_GROUP(pwl_b_2, NMK_GPIO_ALT_B),
-       DB8540_PIN_GROUP(pwl_b_3, NMK_GPIO_ALT_B),
-       DB8540_PIN_GROUP(pwl_b_4, NMK_GPIO_ALT_B),
-       DB8540_PIN_GROUP(u2txrx_b_2, NMK_GPIO_ALT_B),
-       /* Altfunction C column */
-       DB8540_PIN_GROUP(ipgpio6_c_1, NMK_GPIO_ALT_C),
-       DB8540_PIN_GROUP(ipgpio0_c_1, NMK_GPIO_ALT_C),
-       DB8540_PIN_GROUP(ipgpio1_c_1, NMK_GPIO_ALT_C),
-       DB8540_PIN_GROUP(ipgpio3_c_1, NMK_GPIO_ALT_C),
-       DB8540_PIN_GROUP(ipgpio2_c_1, NMK_GPIO_ALT_C),
-       DB8540_PIN_GROUP(u0_c_1, NMK_GPIO_ALT_C),
-       DB8540_PIN_GROUP(smcleale_c_1, NMK_GPIO_ALT_C),
-       DB8540_PIN_GROUP(ipgpio4_c_1, NMK_GPIO_ALT_C),
-       DB8540_PIN_GROUP(ipgpio5_c_1, NMK_GPIO_ALT_C),
-       DB8540_PIN_GROUP(ipgpio6_c_2, NMK_GPIO_ALT_C),
-       DB8540_PIN_GROUP(ipgpio7_c_1, NMK_GPIO_ALT_C),
-       DB8540_PIN_GROUP(stmape_c_1, NMK_GPIO_ALT_C),
-       DB8540_PIN_GROUP(u2rxtx_c_1, NMK_GPIO_ALT_C),
-       DB8540_PIN_GROUP(modobsresout_c_1, NMK_GPIO_ALT_C),
-       DB8540_PIN_GROUP(ipgpio2_c_2, NMK_GPIO_ALT_C),
-       DB8540_PIN_GROUP(ipgpio3_c_2, NMK_GPIO_ALT_C),
-       DB8540_PIN_GROUP(ipgpio4_c_2, NMK_GPIO_ALT_C),
-       DB8540_PIN_GROUP(ipgpio5_c_2, NMK_GPIO_ALT_C),
-       DB8540_PIN_GROUP(modaccgpo_c_1, NMK_GPIO_ALT_C),
-       DB8540_PIN_GROUP(modobspwrrst_c_1, NMK_GPIO_ALT_C),
-       DB8540_PIN_GROUP(mc5_c_1, NMK_GPIO_ALT_C),
-       DB8540_PIN_GROUP(smps0_c_1, NMK_GPIO_ALT_C),
-       DB8540_PIN_GROUP(moduart1_c_1, NMK_GPIO_ALT_C),
-       DB8540_PIN_GROUP(mc2rstn_c_1, NMK_GPIO_ALT_C),
-       DB8540_PIN_GROUP(i2c5_c_1, NMK_GPIO_ALT_C),
-       DB8540_PIN_GROUP(ipgpio0_c_2, NMK_GPIO_ALT_C),
-       DB8540_PIN_GROUP(ipgpio1_c_2, NMK_GPIO_ALT_C),
-       DB8540_PIN_GROUP(kp_c_1, NMK_GPIO_ALT_C),
-       DB8540_PIN_GROUP(modrf_c_1, NMK_GPIO_ALT_C),
-       DB8540_PIN_GROUP(smps1_c_1, NMK_GPIO_ALT_C),
-       DB8540_PIN_GROUP(i2c5_c_2, NMK_GPIO_ALT_C),
-       DB8540_PIN_GROUP(u4ctsrts_c_1, NMK_GPIO_ALT_C),
-       DB8540_PIN_GROUP(u3rxtx_c_1, NMK_GPIO_ALT_C),
-       DB8540_PIN_GROUP(msp4_c_1, NMK_GPIO_ALT_C),
-       DB8540_PIN_GROUP(mc4rstn_c_1, NMK_GPIO_ALT_C),
-       DB8540_PIN_GROUP(spi0_c_1, NMK_GPIO_ALT_C),
-       DB8540_PIN_GROUP(i2c3_c_1, NMK_GPIO_ALT_C),
-
-       /* Other alt C1 column */
-       DB8540_PIN_GROUP(spi3_oc1_1, NMK_GPIO_ALT_C1),
-       DB8540_PIN_GROUP(stmape_oc1_1, NMK_GPIO_ALT_C1),
-       DB8540_PIN_GROUP(u2_oc1_1, NMK_GPIO_ALT_C1),
-       DB8540_PIN_GROUP(remap0_oc1_1, NMK_GPIO_ALT_C1),
-       DB8540_PIN_GROUP(remap1_oc1_1, NMK_GPIO_ALT_C1),
-       DB8540_PIN_GROUP(modobsrefclk_oc1_1, NMK_GPIO_ALT_C1),
-       DB8540_PIN_GROUP(modobspwrctrl_oc1_1, NMK_GPIO_ALT_C1),
-       DB8540_PIN_GROUP(modobsclkout_oc1_1, NMK_GPIO_ALT_C1),
-       DB8540_PIN_GROUP(moduart1_oc1_1, NMK_GPIO_ALT_C1),
-       DB8540_PIN_GROUP(modprcmudbg_oc1_1, NMK_GPIO_ALT_C1),
-       DB8540_PIN_GROUP(modobsresout_oc1_1, NMK_GPIO_ALT_C1),
-       DB8540_PIN_GROUP(modaccgpo_oc1_1, NMK_GPIO_ALT_C1),
-       DB8540_PIN_GROUP(kp_oc1_1, NMK_GPIO_ALT_C1),
-       DB8540_PIN_GROUP(modxmip_oc1_1, NMK_GPIO_ALT_C1),
-       DB8540_PIN_GROUP(i2c6_oc1_1, NMK_GPIO_ALT_C1),
-       DB8540_PIN_GROUP(u2txrx_oc1_1, NMK_GPIO_ALT_C1),
-       DB8540_PIN_GROUP(u2ctsrts_oc1_1, NMK_GPIO_ALT_C1),
-
-       /* Other alt C2 column */
-       DB8540_PIN_GROUP(sbag_oc2_1, NMK_GPIO_ALT_C2),
-       DB8540_PIN_GROUP(hxclk_oc2_1, NMK_GPIO_ALT_C2),
-       DB8540_PIN_GROUP(modaccuart_oc2_1, NMK_GPIO_ALT_C2),
-       DB8540_PIN_GROUP(stmmod_oc2_1, NMK_GPIO_ALT_C2),
-       DB8540_PIN_GROUP(moduartstmmux_oc2_1, NMK_GPIO_ALT_C2),
-       DB8540_PIN_GROUP(hxgpio_oc2_1, NMK_GPIO_ALT_C2),
-       DB8540_PIN_GROUP(sbag_oc2_2, NMK_GPIO_ALT_C2),
-       DB8540_PIN_GROUP(modobsservice_oc2_1, NMK_GPIO_ALT_C2),
-       DB8540_PIN_GROUP(moduart0_oc2_1, NMK_GPIO_ALT_C2),
-       DB8540_PIN_GROUP(stmape_oc2_1, NMK_GPIO_ALT_C2),
-       DB8540_PIN_GROUP(u2_oc2_1, NMK_GPIO_ALT_C2),
-       DB8540_PIN_GROUP(modxmip_oc2_1, NMK_GPIO_ALT_C2),
-
-       /* Other alt C3 column */
-       DB8540_PIN_GROUP(modaccgpo_oc3_1, NMK_GPIO_ALT_C3),
-       DB8540_PIN_GROUP(tpui_oc3_1, NMK_GPIO_ALT_C3),
-
-       /* Other alt C4 column */
-       DB8540_PIN_GROUP(hwobs_oc4_1, NMK_GPIO_ALT_C4),
-       DB8540_PIN_GROUP(moduart1txrx_oc4_1, NMK_GPIO_ALT_C4),
-       DB8540_PIN_GROUP(moduart1rtscts_oc4_1, NMK_GPIO_ALT_C4),
-       DB8540_PIN_GROUP(modaccuarttxrx_oc4_1, NMK_GPIO_ALT_C4),
-       DB8540_PIN_GROUP(modaccuartrtscts_oc4_1, NMK_GPIO_ALT_C4),
-       DB8540_PIN_GROUP(stmmod_oc4_1, NMK_GPIO_ALT_C4),
-       DB8540_PIN_GROUP(moduartstmmux_oc4_1, NMK_GPIO_ALT_C4),
-
-};
-
-/* We use this macro to define the groups applicable to a function */
-#define DB8540_FUNC_GROUPS(a, b...)       \
-static const char * const a##_groups[] = { b };
-
-DB8540_FUNC_GROUPS(apetrig, "apetrig_b_1");
-DB8540_FUNC_GROUPS(clkout, "clkoutreq_a_1", "clkout1_a_1", "clkout1_a_2",
-               "clkout2_a_1", "clkout2_a_2");
-DB8540_FUNC_GROUPS(ddrtrig, "ddrtrig_b_1");
-DB8540_FUNC_GROUPS(hsi, "hsir_a_1", "hsit_a_1", "hsit_a_2");
-DB8540_FUNC_GROUPS(hwobs, "hwobs_oc4_1");
-DB8540_FUNC_GROUPS(hx, "hxclk_oc2_1", "hxgpio_oc2_1");
-DB8540_FUNC_GROUPS(i2c0, "i2c0_a_1");
-DB8540_FUNC_GROUPS(i2c1, "i2c1_b_1", "i2c1_b_2");
-DB8540_FUNC_GROUPS(i2c2, "i2c2_b_1", "i2c2_b_2");
-DB8540_FUNC_GROUPS(i2c3, "i2c3_c_1", "i2c4_b_1");
-DB8540_FUNC_GROUPS(i2c4, "i2c4_b_2");
-DB8540_FUNC_GROUPS(i2c5, "i2c5_b_1", "i2c5_b_2", "i2c5_c_1", "i2c5_c_2");
-DB8540_FUNC_GROUPS(i2c6, "i2c6_b_1", "i2c6_oc1_1");
-/* The image processor has 8 GPIO pins that can be muxed out */
-DB8540_FUNC_GROUPS(ipgpio, "ipgpio0_a_1", "ipgpio0_c_1", "ipgpio0_c_2",
-               "ipgpio1_a_1", "ipgpio1_c_1", "ipgpio1_c_2",
-               "ipgpio2_b_1", "ipgpio2_c_1", "ipgpio2_c_2",
-               "ipgpio3_b_1", "ipgpio3_c_1", "ipgpio3_c_2",
-               "ipgpio4_c_1", "ipgpio4_c_2",
-               "ipgpio5_c_1", "ipgpio5_c_2",
-               "ipgpio6_c_1", "ipgpio6_c_2",
-               "ipgpio7_b_1", "ipgpio7_c_1");
-DB8540_FUNC_GROUPS(ipi2c, "ipi2c_a_1", "ipi2c_a_2");
-DB8540_FUNC_GROUPS(kp, "kp_a_1", "kp_b_1", "kp_c_1", "kp_oc1_1");
-DB8540_FUNC_GROUPS(lcd, "lcd_d0_d7_a_1", "lcd_d12_d23_a_1", "lcd_d8_d11_a_1",
-               "lcdvsi0_a_1", "lcdvsi1_a_1");
-DB8540_FUNC_GROUPS(lcdb, "lcdb_a_1");
-DB8540_FUNC_GROUPS(mc0, "mc0_a_1");
-DB8540_FUNC_GROUPS(mc1, "mc1_a_1", "mc1_a_2");
-DB8540_FUNC_GROUPS(mc2, "mc2_a_1", "mc2rstn_c_1");
-DB8540_FUNC_GROUPS(mc3, "mc3_b_1");
-DB8540_FUNC_GROUPS(mc4, "mc4_a_1", "mc4rstn_c_1");
-DB8540_FUNC_GROUPS(mc5, "mc5_c_1");
-DB8540_FUNC_GROUPS(modaccgpo, "modaccgpo_c_1", "modaccgpo_oc1_1",
-               "modaccgpo_oc3_1");
-DB8540_FUNC_GROUPS(modaccuart, "modaccuart_oc2_1", "modaccuarttxrx_oc4_1",
-               "modaccuartrtccts_oc4_1");
-DB8540_FUNC_GROUPS(modi2s, "modi2s_a_1");
-DB8540_FUNC_GROUPS(modobs, "modobsclk_a_1", "modobsclkout_oc1_1",
-               "modobspwrctrl_oc1_1", "modobspwrrst_c_1",
-               "modobsrefclk_oc1_1", "modobsresout_c_1",
-               "modobsresout_oc1_1", "modobsservice_oc2_1");
-DB8540_FUNC_GROUPS(modprcmudbg, "modprcmudbg_oc1_1");
-DB8540_FUNC_GROUPS(modrf, "modrf_c_1");
-DB8540_FUNC_GROUPS(modsmb, "modsmb_a_1");
-DB8540_FUNC_GROUPS(modtrig, "modtrig_b_1");
-DB8540_FUNC_GROUPS(moduart, "moduart1_c_1", "moduart1_oc1_1",
-               "moduart1txrx_oc4_1", "moduart1rtscts_oc4_1", "moduart0_oc2_1");
-DB8540_FUNC_GROUPS(moduartstmmux, "moduartstmmux_b_1", "moduartstmmux_oc2_1",
-               "moduartstmmux_oc4_1");
-DB8540_FUNC_GROUPS(modxmip, "modxmip_oc1_1", "modxmip_oc2_1");
-/*
- * MSP0 can only be on a certain set of pins, but the TX/RX pins can be
- * switched around by selecting the altfunction A or B.
- */
-DB8540_FUNC_GROUPS(msp0, "msp0rfsrck_a_1", "msp0tfstck_a_1", "msp0txrx_a_1",
-               "msp0txrx_b_1");
-DB8540_FUNC_GROUPS(msp1, "msp1_a_1", "msp1txrx_a_1", "msp1txrx_b_1");
-DB8540_FUNC_GROUPS(msp2, "msp2sck_a_1", "msp2txdtcktfs_a_1", "msp2rxd_a_1");
-DB8540_FUNC_GROUPS(msp4, "msp4_a_1", "msp4_b_1", "msp4_c_1");
-DB8540_FUNC_GROUPS(pwl, "pwl_b_1", "pwl_b_2", "pwl_b_3", "pwl_b_4");
-DB8540_FUNC_GROUPS(remap, "remap0_oc1_1", "remap1_oc1_1");
-DB8540_FUNC_GROUPS(sbag, "sbag_oc2_1", "sbag_oc2_2");
-/* Select between CS0 on alt B or PS1 on alt C */
-DB8540_FUNC_GROUPS(sm, "sm_b_1", "smcleale_c_1", "smcs0_b_1", "smcs1_b_1",
-               "smps0_c_1", "smps1_c_1");
-DB8540_FUNC_GROUPS(spi0, "spi0_c_1");
-DB8540_FUNC_GROUPS(spi1, "spi1_b_1");
-DB8540_FUNC_GROUPS(spi2, "spi2_a_1");
-DB8540_FUNC_GROUPS(spi3, "spi3_oc1_1");
-DB8540_FUNC_GROUPS(ssp0, "ssp0_a_1");
-DB8540_FUNC_GROUPS(ssp1, "ssp1_a_1");
-DB8540_FUNC_GROUPS(stmape, "stmape_c_1", "stmape_oc1_1", "stmape_oc2_1");
-DB8540_FUNC_GROUPS(stmmod, "stmmod_b_1", "stmmod_oc2_1", "stmmod_oc4_1");
-DB8540_FUNC_GROUPS(tpui, "tpui_oc3_1");
-DB8540_FUNC_GROUPS(u0, "u0_a_1", "u0_c_1");
-DB8540_FUNC_GROUPS(u1, "u1ctsrts_a_1", "u1rxtx_a_1");
-DB8540_FUNC_GROUPS(u2, "u2_oc1_1", "u2_oc2_1", "u2ctsrts_a_1", "u2ctsrts_oc1_1",
-               "u2rxtx_c_1", "u2txrx_a_1", "u2txrx_b_1", "u2txrx_b_2",
-               "u2txrx_oc1_1");
-DB8540_FUNC_GROUPS(u3, "u3ctsrts_b_1", "u3rxtx_c_1", "u3txrxa_b_1");
-DB8540_FUNC_GROUPS(u4, "u4ctsrts_b_1", "u4ctsrts_c_1", "u4txrx_b_1");
-DB8540_FUNC_GROUPS(usb, "usb_a_1");
-
-
-#define FUNCTION(fname)                                        \
-       {                                               \
-               .name = #fname,                         \
-               .groups = fname##_groups,               \
-               .ngroups = ARRAY_SIZE(fname##_groups),  \
-       }
-
-static const struct nmk_function nmk_db8540_functions[] = {
-       FUNCTION(apetrig),
-       FUNCTION(clkout),
-       FUNCTION(ddrtrig),
-       FUNCTION(hsi),
-       FUNCTION(hwobs),
-       FUNCTION(hx),
-       FUNCTION(i2c0),
-       FUNCTION(i2c1),
-       FUNCTION(i2c2),
-       FUNCTION(i2c3),
-       FUNCTION(i2c4),
-       FUNCTION(i2c5),
-       FUNCTION(i2c6),
-       FUNCTION(ipgpio),
-       FUNCTION(ipi2c),
-       FUNCTION(kp),
-       FUNCTION(lcd),
-       FUNCTION(lcdb),
-       FUNCTION(mc0),
-       FUNCTION(mc1),
-       FUNCTION(mc2),
-       FUNCTION(mc3),
-       FUNCTION(mc4),
-       FUNCTION(mc5),
-       FUNCTION(modaccgpo),
-       FUNCTION(modaccuart),
-       FUNCTION(modi2s),
-       FUNCTION(modobs),
-       FUNCTION(modprcmudbg),
-       FUNCTION(modrf),
-       FUNCTION(modsmb),
-       FUNCTION(modtrig),
-       FUNCTION(moduart),
-       FUNCTION(modxmip),
-       FUNCTION(msp0),
-       FUNCTION(msp1),
-       FUNCTION(msp2),
-       FUNCTION(msp4),
-       FUNCTION(pwl),
-       FUNCTION(remap),
-       FUNCTION(sbag),
-       FUNCTION(sm),
-       FUNCTION(spi0),
-       FUNCTION(spi1),
-       FUNCTION(spi2),
-       FUNCTION(spi3),
-       FUNCTION(ssp0),
-       FUNCTION(ssp1),
-       FUNCTION(stmape),
-       FUNCTION(stmmod),
-       FUNCTION(tpui),
-       FUNCTION(u0),
-       FUNCTION(u1),
-       FUNCTION(u2),
-       FUNCTION(u3),
-       FUNCTION(u4),
-       FUNCTION(usb)
-};
-
-static const struct prcm_gpiocr_altcx_pin_desc db8540_altcx_pins[] = {
-       PRCM_GPIOCR_ALTCX(8,    true, PRCM_IDX_GPIOCR1, 20,     /* SPI3_CLK */
-                               false, 0, 0,
-                               false, 0, 0,
-                               false, 0, 0
-       ),
-       PRCM_GPIOCR_ALTCX(9,    true, PRCM_IDX_GPIOCR1, 20,     /* SPI3_RXD */
-                               false, 0, 0,
-                               false, 0, 0,
-                               false, 0, 0
-       ),
-       PRCM_GPIOCR_ALTCX(10,   true, PRCM_IDX_GPIOCR1, 20,     /* SPI3_FRM */
-                               false, 0, 0,
-                               false, 0, 0,
-                               false, 0, 0
-       ),
-       PRCM_GPIOCR_ALTCX(11,   true, PRCM_IDX_GPIOCR1, 20,     /* SPI3_TXD */
-                               false, 0, 0,
-                               false, 0, 0,
-                               false, 0, 0
-       ),
-       PRCM_GPIOCR_ALTCX(23,   true, PRCM_IDX_GPIOCR1, 9,      /* STMAPE_CLK_a */
-                               true, PRCM_IDX_GPIOCR2, 10,     /* SBAG_CLK_a */
-                               false, 0, 0,
-                               false, 0, 0
-       ),
-       PRCM_GPIOCR_ALTCX(24,   true, PRCM_IDX_GPIOCR3, 30,     /* U2_RXD_g */
-                               true, PRCM_IDX_GPIOCR2, 10,     /* SBAG_VAL_a */
-                               false, 0, 0,
-                               false, 0, 0
-       ),
-       PRCM_GPIOCR_ALTCX(25,   true, PRCM_IDX_GPIOCR1, 9,      /* STMAPE_DAT_a[0] */
-                               true, PRCM_IDX_GPIOCR2, 10,     /* SBAG_D_a[0] */
-                               false, 0, 0,
-                               false, 0, 0
-       ),
-       PRCM_GPIOCR_ALTCX(26,   true, PRCM_IDX_GPIOCR1, 9,      /* STMAPE_DAT_a[1] */
-                               true, PRCM_IDX_GPIOCR2, 10,     /* SBAG_D_a[1] */
-                               false, 0, 0,
-                               false, 0, 0
-       ),
-       PRCM_GPIOCR_ALTCX(27,   true, PRCM_IDX_GPIOCR1, 9,      /* STMAPE_DAT_a[2] */
-                               true, PRCM_IDX_GPIOCR2, 10,     /* SBAG_D_a[2] */
-                               false, 0, 0,
-                               false, 0, 0
-       ),
-       PRCM_GPIOCR_ALTCX(28,   true, PRCM_IDX_GPIOCR1, 9,      /* STMAPE_DAT_a[3] */
-                               true, PRCM_IDX_GPIOCR2, 10,     /* SBAG_D_a[3] */
-                               false, 0, 0,
-                               false, 0, 0
-       ),
-       PRCM_GPIOCR_ALTCX(64,   true, PRCM_IDX_GPIOCR1, 15,     /* MODOBS_REFCLK_REQ */
-                               false, 0, 0,
-                               true, PRCM_IDX_GPIOCR1, 2,      /* TPIU_CTL */
-                               true, PRCM_IDX_GPIOCR2, 23      /* HW_OBS_APE_PRCMU[17] */
-       ),
-       PRCM_GPIOCR_ALTCX(65,   true, PRCM_IDX_GPIOCR1, 19,     /* MODOBS_PWRCTRL0 */
-                               true, PRCM_IDX_GPIOCR1, 24,     /* Hx_CLK */
-                               true, PRCM_IDX_GPIOCR1, 2,      /* TPIU_CLK */
-                               true, PRCM_IDX_GPIOCR2, 24      /* HW_OBS_APE_PRCMU[16] */
-       ),
-       PRCM_GPIOCR_ALTCX(66,   true, PRCM_IDX_GPIOCR1, 15,     /* MODOBS_CLKOUT1 */
-                               false, 0, 0,
-                               true, PRCM_IDX_GPIOCR1, 2,      /* TPIU_D[15] */
-                               true, PRCM_IDX_GPIOCR2, 25      /* HW_OBS_APE_PRCMU[15] */
-       ),
-       PRCM_GPIOCR_ALTCX(67,   true, PRCM_IDX_GPIOCR1, 1,      /* MODUART1_TXD_a */
-                               true, PRCM_IDX_GPIOCR1, 6,      /* MODACCUART_TXD_a */
-                               true, PRCM_IDX_GPIOCR1, 2,      /* TPIU_D[14] */
-                               true, PRCM_IDX_GPIOCR2, 26      /* HW_OBS_APE_PRCMU[14] */
-       ),
-       PRCM_GPIOCR_ALTCX(70,   true, PRCM_IDX_GPIOCR3, 6,      /* MOD_PRCMU_DEBUG[17] */
-                               true, PRCM_IDX_GPIOCR1, 10,     /* STMMOD_CLK_b */
-                               true, PRCM_IDX_GPIOCR1, 2,      /* TPIU_D[13] */
-                               true, PRCM_IDX_GPIOCR2, 27      /* HW_OBS_APE_PRCMU[13] */
-       ),
-       PRCM_GPIOCR_ALTCX(71,   true, PRCM_IDX_GPIOCR3, 6,      /* MOD_PRCMU_DEBUG[16] */
-                               true, PRCM_IDX_GPIOCR1, 10,     /* STMMOD_DAT_b[3] */
-                               true, PRCM_IDX_GPIOCR1, 2,      /* TPIU_D[12] */
-                               true, PRCM_IDX_GPIOCR2, 27      /* HW_OBS_APE_PRCMU[12] */
-       ),
-       PRCM_GPIOCR_ALTCX(72,   true, PRCM_IDX_GPIOCR3, 6,      /* MOD_PRCMU_DEBUG[15] */
-                               true, PRCM_IDX_GPIOCR1, 10,     /* STMMOD_DAT_b[2] */
-                               true, PRCM_IDX_GPIOCR1, 2,      /* TPIU_D[11] */
-                               true, PRCM_IDX_GPIOCR2, 27      /* HW_OBS_APE_PRCMU[11] */
-       ),
-       PRCM_GPIOCR_ALTCX(73,   true, PRCM_IDX_GPIOCR3, 6,      /* MOD_PRCMU_DEBUG[14] */
-                               true, PRCM_IDX_GPIOCR1, 10,     /* STMMOD_DAT_b[1] */
-                               true, PRCM_IDX_GPIOCR1, 2,      /* TPIU_D[10] */
-                               true, PRCM_IDX_GPIOCR2, 27      /* HW_OBS_APE_PRCMU[10] */
-       ),
-       PRCM_GPIOCR_ALTCX(74,   true, PRCM_IDX_GPIOCR3, 6,      /* MOD_PRCMU_DEBUG[13] */
-                               true, PRCM_IDX_GPIOCR1, 10,     /* STMMOD_DAT_b[0] */
-                               true, PRCM_IDX_GPIOCR1, 2,      /* TPIU_D[9] */
-                               true, PRCM_IDX_GPIOCR2, 27      /* HW_OBS_APE_PRCMU[9] */
-       ),
-       PRCM_GPIOCR_ALTCX(75,   true, PRCM_IDX_GPIOCR1, 12,     /* MODOBS_RESOUT0_N */
-                               true, PRCM_IDX_GPIOCR2, 1,      /* MODUART_STMMUX_RXD_b */
-                               true, PRCM_IDX_GPIOCR1, 2,      /* TPIU_D[8] */
-                               true, PRCM_IDX_GPIOCR2, 28      /* HW_OBS_APE_PRCMU[8] */
-       ),
-       PRCM_GPIOCR_ALTCX(76,   true, PRCM_IDX_GPIOCR3, 7,      /* MOD_PRCMU_DEBUG[12] */
-                               true, PRCM_IDX_GPIOCR1, 25,     /* Hx_GPIO[7] */
-                               true, PRCM_IDX_GPIOCR1, 2,      /* TPIU_D[7] */
-                               true, PRCM_IDX_GPIOCR2, 29      /* HW_OBS_APE_PRCMU[7] */
-       ),
-       PRCM_GPIOCR_ALTCX(77,   true, PRCM_IDX_GPIOCR3, 7,      /* MOD_PRCMU_DEBUG[11] */
-                               true, PRCM_IDX_GPIOCR1, 25,     /* Hx_GPIO[6] */
-                               true, PRCM_IDX_GPIOCR1, 2,      /* TPIU_D[6] */
-                               true, PRCM_IDX_GPIOCR2, 29      /* HW_OBS_APE_PRCMU[6] */
-       ),
-       PRCM_GPIOCR_ALTCX(78,   true, PRCM_IDX_GPIOCR3, 7,      /* MOD_PRCMU_DEBUG[10] */
-                               true, PRCM_IDX_GPIOCR1, 25,     /* Hx_GPIO[5] */
-                               true, PRCM_IDX_GPIOCR1, 2,      /* TPIU_D[5] */
-                               true, PRCM_IDX_GPIOCR2, 29      /* HW_OBS_APE_PRCMU[5] */
-       ),
-       PRCM_GPIOCR_ALTCX(79,   true, PRCM_IDX_GPIOCR3, 7,      /* MOD_PRCMU_DEBUG[9] */
-                               true, PRCM_IDX_GPIOCR1, 25,     /* Hx_GPIO[4] */
-                               true, PRCM_IDX_GPIOCR1, 2,      /* TPIU_D[4] */
-                               true, PRCM_IDX_GPIOCR2, 29      /* HW_OBS_APE_PRCMU[4] */
-       ),
-       PRCM_GPIOCR_ALTCX(80,   true, PRCM_IDX_GPIOCR1, 26,     /* MODACC_GPO[0] */
-                               true, PRCM_IDX_GPIOCR1, 25,     /* Hx_GPIO[3] */
-                               true, PRCM_IDX_GPIOCR1, 2,      /* TPIU_D[3] */
-                               true, PRCM_IDX_GPIOCR2, 30      /* HW_OBS_APE_PRCMU[3] */
-       ),
-       PRCM_GPIOCR_ALTCX(81,   true, PRCM_IDX_GPIOCR2, 17,     /* MODACC_GPO[1] */
-                               true, PRCM_IDX_GPIOCR1, 25,     /* Hx_GPIO[2] */
-                               true, PRCM_IDX_GPIOCR1, 2,      /* TPIU_D[2] */
-                               true, PRCM_IDX_GPIOCR2, 30      /* HW_OBS_APE_PRCMU[2] */
-       ),
-       PRCM_GPIOCR_ALTCX(82,   true, PRCM_IDX_GPIOCR3, 8,      /* MOD_PRCMU_DEBUG[8] */
-                               true, PRCM_IDX_GPIOCR1, 25,     /* Hx_GPIO[1] */
-                               true, PRCM_IDX_GPIOCR1, 2,      /* TPIU_D[1] */
-                               true, PRCM_IDX_GPIOCR2, 31      /* HW_OBS_APE_PRCMU[1] */
-       ),
-       PRCM_GPIOCR_ALTCX(83,   true, PRCM_IDX_GPIOCR3, 8,      /* MOD_PRCMU_DEBUG[7] */
-                               true, PRCM_IDX_GPIOCR1, 25,     /* Hx_GPIO[0] */
-                               true, PRCM_IDX_GPIOCR1, 2,      /* TPIU_D[0] */
-                               true, PRCM_IDX_GPIOCR2, 31      /* HW_OBS_APE_PRCMU[0] */
-       ),
-       PRCM_GPIOCR_ALTCX(84,   true, PRCM_IDX_GPIOCR3, 9,      /* MOD_PRCMU_DEBUG[6] */
-                               true, PRCM_IDX_GPIOCR1, 8,      /* SBAG_CLK_b */
-                               true, PRCM_IDX_GPIOCR1, 3,      /* TPIU_D[23] */
-                               true, PRCM_IDX_GPIOCR1, 16      /* MODUART1_RXD_b */
-       ),
-       PRCM_GPIOCR_ALTCX(85,   true, PRCM_IDX_GPIOCR3, 9,      /* MOD_PRCMU_DEBUG[5] */
-                               true, PRCM_IDX_GPIOCR1, 8,      /* SBAG_D_b[3] */
-                               true, PRCM_IDX_GPIOCR1, 3,      /* TPIU_D[22] */
-                               true, PRCM_IDX_GPIOCR1, 16      /* MODUART1_TXD_b */
-       ),
-       PRCM_GPIOCR_ALTCX(86,   true, PRCM_IDX_GPIOCR3, 9,      /* MOD_PRCMU_DEBUG[0] */
-                               true, PRCM_IDX_GPIOCR2, 18,     /* STMAPE_DAT_b[0] */
-                               true, PRCM_IDX_GPIOCR1, 14,     /* TPIU_D[25] */
-                               true, PRCM_IDX_GPIOCR1, 11      /* STMMOD_DAT_c[0] */
-       ),
-       PRCM_GPIOCR_ALTCX(87,   true, PRCM_IDX_GPIOCR3, 0,      /* MODACC_GPO_a[5] */
-                               true, PRCM_IDX_GPIOCR2, 3,      /* U2_RXD_c */
-                               true, PRCM_IDX_GPIOCR1, 4,      /* TPIU_D[24] */
-                               true, PRCM_IDX_GPIOCR1, 21      /* MODUART_STMMUX_RXD_c */
-       ),
-       PRCM_GPIOCR_ALTCX(151,  true, PRCM_IDX_GPIOCR1, 18,     /* REMAP0 */
-                               false, 0, 0,
-                               false, 0, 0,
-                               false, 0, 0
-       ),
-       PRCM_GPIOCR_ALTCX(152,  true, PRCM_IDX_GPIOCR1, 18,     /* REMAP1 */
-                               false, 0, 0,
-                               false, 0, 0,
-                               false, 0, 0
-       ),
-       PRCM_GPIOCR_ALTCX(153,  true, PRCM_IDX_GPIOCR3, 2,      /* KP_O_b[6] */
-                               true, PRCM_IDX_GPIOCR1, 8,      /* SBAG_D_b[2] */
-                               true, PRCM_IDX_GPIOCR1, 3,      /* TPIU_D[21] */
-                               true, PRCM_IDX_GPIOCR1, 0       /* MODUART1_RTS */
-       ),
-       PRCM_GPIOCR_ALTCX(154,  true, PRCM_IDX_GPIOCR3, 2,      /* KP_I_b[6] */
-                               true, PRCM_IDX_GPIOCR1, 8,      /* SBAG_D_b[1] */
-                               true, PRCM_IDX_GPIOCR1, 3,      /* TPIU_D[20] */
-                               true, PRCM_IDX_GPIOCR1, 0       /* MODUART1_CTS */
-       ),
-       PRCM_GPIOCR_ALTCX(155,  true, PRCM_IDX_GPIOCR3, 3,      /* KP_O_b[5] */
-                               true, PRCM_IDX_GPIOCR1, 8,      /* SBAG_D_b[0] */
-                               true, PRCM_IDX_GPIOCR1, 3,      /* TPIU_D[19] */
-                               true, PRCM_IDX_GPIOCR1, 5       /* MODACCUART_RXD_c */
-       ),
-       PRCM_GPIOCR_ALTCX(156,  true, PRCM_IDX_GPIOCR3, 3,      /* KP_O_b[4] */
-                               true, PRCM_IDX_GPIOCR1, 8,      /* SBAG_VAL_b */
-                               true, PRCM_IDX_GPIOCR1, 3,      /* TPIU_D[18] */
-                               true, PRCM_IDX_GPIOCR1, 5       /* MODACCUART_TXD_b */
-       ),
-       PRCM_GPIOCR_ALTCX(157,  true, PRCM_IDX_GPIOCR3, 4,      /* KP_I_b[5] */
-                               true, PRCM_IDX_GPIOCR1, 23,     /* MODOBS_SERVICE_N */
-                               true, PRCM_IDX_GPIOCR1, 3,      /* TPIU_D[17] */
-                               true, PRCM_IDX_GPIOCR1, 14      /* MODACCUART_RTS */
-       ),
-       PRCM_GPIOCR_ALTCX(158,  true, PRCM_IDX_GPIOCR3, 4,      /* KP_I_b[4] */
-                               true, PRCM_IDX_GPIOCR2, 0,      /* U2_TXD_c */
-                               true, PRCM_IDX_GPIOCR1, 3,      /* TPIU_D[16] */
-                               true, PRCM_IDX_GPIOCR1, 14      /* MODACCUART_CTS */
-       ),
-       PRCM_GPIOCR_ALTCX(159,  true, PRCM_IDX_GPIOCR3, 5,      /* KP_O_b[3] */
-                               true, PRCM_IDX_GPIOCR3, 10,     /* MODUART0_RXD */
-                               true, PRCM_IDX_GPIOCR1, 4,      /* TPIU_D[31] */
-                               false, 0, 0
-       ),
-       PRCM_GPIOCR_ALTCX(160,  true, PRCM_IDX_GPIOCR3, 5,      /* KP_I_b[3] */
-                               true, PRCM_IDX_GPIOCR3, 10,     /* MODUART0_TXD */
-                               true, PRCM_IDX_GPIOCR1, 4,      /* TPIU_D[30] */
-                               false, 0, 0
-       ),
-       PRCM_GPIOCR_ALTCX(161,  true, PRCM_IDX_GPIOCR3, 9,      /* MOD_PRCMU_DEBUG[4] */
-                               true, PRCM_IDX_GPIOCR2, 18,     /* STMAPE_CLK_b */
-                               true, PRCM_IDX_GPIOCR1, 4,      /* TPIU_D[29] */
-                               true, PRCM_IDX_GPIOCR1, 11      /* STMMOD_CLK_c */
-       ),
-       PRCM_GPIOCR_ALTCX(162,  true, PRCM_IDX_GPIOCR3, 9,      /* MOD_PRCMU_DEBUG[3] */
-                               true, PRCM_IDX_GPIOCR2, 18,     /* STMAPE_DAT_b[3] */
-                               true, PRCM_IDX_GPIOCR1, 4,      /* TPIU_D[28] */
-                               true, PRCM_IDX_GPIOCR1, 11      /* STMMOD_DAT_c[3] */
-       ),
-       PRCM_GPIOCR_ALTCX(163,  true, PRCM_IDX_GPIOCR3, 9,      /* MOD_PRCMU_DEBUG[2] */
-                               true, PRCM_IDX_GPIOCR2, 18,     /* STMAPE_DAT_b[2] */
-                               true, PRCM_IDX_GPIOCR1, 4,      /* TPIU_D[27] */
-                               true, PRCM_IDX_GPIOCR1, 11      /* STMMOD_DAT_c[2] */
-       ),
-       PRCM_GPIOCR_ALTCX(164,  true, PRCM_IDX_GPIOCR3, 9,      /* MOD_PRCMU_DEBUG[1] */
-                               true, PRCM_IDX_GPIOCR2, 18,     /* STMAPE_DAT_b[1] */
-                               true, PRCM_IDX_GPIOCR1, 4,      /* TPIU_D[26] */
-                               true, PRCM_IDX_GPIOCR1, 11      /* STMMOD_DAT_c[1] */
-       ),
-       PRCM_GPIOCR_ALTCX(204,  true, PRCM_IDX_GPIOCR2, 2,      /* U2_RXD_f */
-                               false, 0, 0,
-                               false, 0, 0,
-                               false, 0, 0
-       ),
-       PRCM_GPIOCR_ALTCX(205,  true, PRCM_IDX_GPIOCR2, 2,      /* U2_TXD_f */
-                               false, 0, 0,
-                               false, 0, 0,
-                               false, 0, 0
-       ),
-       PRCM_GPIOCR_ALTCX(206,  true, PRCM_IDX_GPIOCR2, 2,      /* U2_CTSn_b */
-                               false, 0, 0,
-                               false, 0, 0,
-                               false, 0, 0
-       ),
-       PRCM_GPIOCR_ALTCX(207,  true, PRCM_IDX_GPIOCR2, 2,      /* U2_RTSn_b */
-                               false, 0, 0,
-                               false, 0, 0,
-                               false, 0, 0
-       ),
-};
-
-static const u16 db8540_prcm_gpiocr_regs[] = {
-       [PRCM_IDX_GPIOCR1] = 0x138,
-       [PRCM_IDX_GPIOCR2] = 0x574,
-       [PRCM_IDX_GPIOCR3] = 0x2bc,
-};
-
-static const struct nmk_pinctrl_soc_data nmk_db8540_soc = {
-       .pins = nmk_db8540_pins,
-       .npins = ARRAY_SIZE(nmk_db8540_pins),
-       .functions = nmk_db8540_functions,
-       .nfunctions = ARRAY_SIZE(nmk_db8540_functions),
-       .groups = nmk_db8540_groups,
-       .ngroups = ARRAY_SIZE(nmk_db8540_groups),
-       .altcx_pins = db8540_altcx_pins,
-       .npins_altcx = ARRAY_SIZE(db8540_altcx_pins),
-       .prcm_gpiocr_registers = db8540_prcm_gpiocr_regs,
-};
-
-void nmk_pinctrl_db8540_init(const struct nmk_pinctrl_soc_data **soc)
-{
-       *soc = &nmk_db8540_soc;
-}