[PATCH 4/4] pinctrl: renesas: Add initial R8A78000 R-Car X5H PFC tables

Marek Vasut marek.vasut+renesas at mailbox.org
Mon Oct 27 17:53:54 CET 2025


From: Huy Bui <huy.bui.wm at renesas.com>

Add initial pin control tables for the Renesas R-Car X5H R8A78000 SoC.
This SoC is the first one which includes custom DRV register handling,
different from previous generations due to change in DRV register bit
layout.

Signed-off-by: Huy Bui <huy.bui.wm at renesas.com>
Signed-off-by: Khanh Le <khanh.le.xr at renesas.com>
Signed-off-by: Hai Pham <hai.pham.ud at renesas.com>
Signed-off-by: Marek Vasut <marek.vasut+renesas at mailbox.org>
---
Cc: Hai Pham <hai.pham.ud at renesas.com>
Cc: Huy Bui <huy.bui.wm at renesas.com>
Cc: Khanh Le <khanh.le.xr at renesas.com>
Cc: Nobuhiro Iwamatsu <iwamatsu at nigauri.org>
Cc: Tam Nguyen <tam.nguyen.xa at renesas.com>
Cc: Tom Rini <trini at konsulko.com>
Cc: u-boot at lists.denx.de
---
 drivers/pinctrl/renesas/Kconfig        |    6 +
 drivers/pinctrl/renesas/Makefile       |    1 +
 drivers/pinctrl/renesas/pfc-r8a78000.c | 5254 ++++++++++++++++++++++++
 drivers/pinctrl/renesas/pfc.c          |    9 +
 drivers/pinctrl/renesas/sh_pfc.h       |    1 +
 5 files changed, 5271 insertions(+)
 create mode 100644 drivers/pinctrl/renesas/pfc-r8a78000.c

diff --git a/drivers/pinctrl/renesas/Kconfig b/drivers/pinctrl/renesas/Kconfig
index e4a4c91304a..ac40b31dbfa 100644
--- a/drivers/pinctrl/renesas/Kconfig
+++ b/drivers/pinctrl/renesas/Kconfig
@@ -148,6 +148,12 @@ config PINCTRL_PFC_R8A779H0
 	help
 	  Support pin multiplexing control on Renesas R-Car Gen4 R8A779H0 SoCs.
 
+config PINCTRL_PFC_R8A78000
+	bool "Renesas R-Car Gen5 R8A78000 pin control driver"
+	depends on PINCTRL_PFC
+	help
+	  Support pin multiplexing control on Renesas R-Car Gen5 R8A78000 SoCs.
+
 config PINCTRL_RZA1
 	bool "Renesas RZ/A1 R7S72100 pin control driver"
 	depends on CPU_RZA1
diff --git a/drivers/pinctrl/renesas/Makefile b/drivers/pinctrl/renesas/Makefile
index a5810dc0f10..f9ac5eabf09 100644
--- a/drivers/pinctrl/renesas/Makefile
+++ b/drivers/pinctrl/renesas/Makefile
@@ -20,6 +20,7 @@ obj-$(CONFIG_PINCTRL_PFC_R8A779A0) += pfc-r8a779a0.o
 obj-$(CONFIG_PINCTRL_PFC_R8A779F0) += pfc-r8a779f0.o
 obj-$(CONFIG_PINCTRL_PFC_R8A779G0) += pfc-r8a779g0.o
 obj-$(CONFIG_PINCTRL_PFC_R8A779H0) += pfc-r8a779h0.o
+obj-$(CONFIG_PINCTRL_PFC_R8A78000) += pfc-r8a78000.o
 obj-$(CONFIG_PINCTRL_RZA1) += pinctrl-rza1.o
 obj-$(CONFIG_PINCTRL_RZN1) += pinctrl-rzn1.o
 obj-$(CONFIG_PINCTRL_RZG2L) += rzg2l-pfc.o
diff --git a/drivers/pinctrl/renesas/pfc-r8a78000.c b/drivers/pinctrl/renesas/pfc-r8a78000.c
new file mode 100644
index 00000000000..cb6a18ee229
--- /dev/null
+++ b/drivers/pinctrl/renesas/pfc-r8a78000.c
@@ -0,0 +1,5254 @@
+// SPDX-License-Identifier: GPL-2.0-only
+/*
+ * R8A78000 processor support - PFC hardware block.
+ *
+ * Copyright (C) 2025 Renesas Electronics Corp.
+ *
+ */
+
+#include <dm.h>
+#include <errno.h>
+#include <bitfield.h>
+#include <dm/pinctrl.h>
+#include <linux/bitops.h>
+#include <linux/kernel.h>
+
+#include "sh_pfc.h"
+
+#define CFG_FLAGS (SH_PFC_PIN_CFG_DRIVE_STRENGTH | SH_PFC_PIN_CFG_PULL_UP_DOWN)
+
+#define CPU_ALL_GP(fn, sfx)				\
+	PORT_GP_CFG_28(0,	fn, sfx, CFG_FLAGS),	\
+	PORT_GP_CFG_22(1,	fn, sfx, CFG_FLAGS),	\
+	PORT_GP_CFG_29(2,	fn, sfx, CFG_FLAGS),	\
+	PORT_GP_CFG_17(3,	fn, sfx, CFG_FLAGS),	\
+	PORT_GP_CFG_16(4,	fn, sfx, CFG_FLAGS),	\
+	PORT_GP_CFG_23(5,	fn, sfx, CFG_FLAGS),	\
+	PORT_GP_CFG_31(6,	fn, sfx, CFG_FLAGS),	\
+	PORT_GP_CFG_31(7,	fn, sfx, CFG_FLAGS),	\
+	PORT_GP_CFG_16(8,	fn, sfx, CFG_FLAGS),	\
+	PORT_GP_CFG_1(8, 26,	fn, sfx, CFG_FLAGS),	\
+	PORT_GP_CFG_1(8, 27,	fn, sfx, CFG_FLAGS),	\
+	PORT_GP_CFG_1(8, 28,	fn, sfx, CFG_FLAGS),	\
+	PORT_GP_CFG_1(8, 29,	fn, sfx, CFG_FLAGS),	\
+	PORT_GP_CFG_1(8, 30,	fn, sfx, CFG_FLAGS),	\
+	PORT_GP_CFG_1(8, 31,	fn, sfx, CFG_FLAGS),	\
+	PORT_GP_CFG_17(9,	fn, sfx, CFG_FLAGS),	\
+	PORT_GP_CFG_14(10,	fn, sfx, CFG_FLAGS)
+
+/*
+ * F_() : just information
+ * FM() : macro for FN_xxx / xxx_MARK
+ */
+
+/* GPSR0 */
+#define GPSR0_27	F_(DP2_HOTPLUG,		GRP0_27_FUNC)
+#define GPSR0_26	F_(DP1_HOTPLUG,		GRP0_26_FUNC)
+#define GPSR0_25	F_(DP0_HOTPLUG,		GRP0_25_FUNC)
+#define GPSR0_24	F_(MSIOF1_SS2_A,	GRP0_24_FUNC)
+#define GPSR0_23	F_(MSIOF1_SS1_A,	GRP0_23_FUNC)
+#define GPSR0_22	F_(MSIOF1_SYNC_A,	GRP0_22_FUNC)
+#define GPSR0_21	F_(MSIOF1_RXD_A,	GRP0_21_FUNC)
+#define GPSR0_20	F_(MSIOF1_TXD_A,	GRP0_20_FUNC)
+#define GPSR0_19	F_(MSIOF1_SCK_A,	GRP0_19_FUNC)
+#define GPSR0_18	F_(MSIOF0_SS2,		GRP0_18_FUNC)
+#define GPSR0_17	F_(MSIOF0_SS1,		GRP0_17_FUNC)
+#define GPSR0_16	F_(MSIOF0_SYNC,		GRP0_16_FUNC)
+#define GPSR0_15	F_(MSIOF0_RXD,		GRP0_15_FUNC)
+#define GPSR0_14	F_(MSIOF0_TXD,		GRP0_14_FUNC)
+#define GPSR0_13	F_(MSIOF0_SCK,		GRP0_13_FUNC)
+#define GPSR0_12	F_(RXDB_EXTFXR_A,	GRP0_12_FUNC)
+#define GPSR0_11	F_(FXR_TXENB_N_A,	GRP0_11_FUNC)
+#define GPSR0_10	F_(FXR_TXDB_A,		GRP0_10_FUNC)
+#define GPSR0_9		F_(RXDA_EXTFXR_A,	GRP0_9_FUNC)
+#define GPSR0_8		F_(FXR_TXENA_N_A,	GRP0_8_FUNC)
+#define GPSR0_7		F_(FXR_TXDA_A,		GRP0_7_FUNC)
+#define GPSR0_6		F_(CLK_EXTFXR_A,	GRP0_6_FUNC)
+#define GPSR0_5		F_(FXR_CLKOUT2_A,	GRP0_5_FUNC)
+#define GPSR0_4		F_(FXR_CLKOUT1_A,	GRP0_4_FUNC)
+#define GPSR0_3		F_(STPWT_EXTFXR_A,	GRP0_3_FUNC)
+#define GPSR0_2		F_(GP0_02,		GRP0_2_FUNC)
+#define GPSR0_1		F_(GP0_01,		GRP0_1_FUNC)
+#define GPSR0_0		F_(GP0_00,		GRP0_0_FUNC)
+
+/* GPSR1 */
+#define GPSR1_21	F_(RLIN33TX,		GRP1_21_FUNC)
+#define GPSR1_20	F_(RLIN33RX_INTP19,	GRP1_20_FUNC)
+#define GPSR1_19	F_(RLIN32TX,		GRP1_19_FUNC)
+#define GPSR1_18	F_(RLIN32RX_INTP18,	GRP1_18_FUNC)
+#define GPSR1_17	F_(RLIN31TX,		GRP1_17_FUNC)
+#define GPSR1_16	F_(RLIN31RX_INTP17,	GRP1_16_FUNC)
+#define GPSR1_15	F_(RLIN30TX,		GRP1_15_FUNC)
+#define GPSR1_14	F_(RLIN30RX_INTP16,	GRP1_14_FUNC)
+#define GPSR1_13	F_(CAN6TX,		GRP1_13_FUNC)
+#define GPSR1_12	F_(CAN6RX_INTP6,	GRP1_12_FUNC)
+#define GPSR1_11	F_(CAN5TX,		GRP1_11_FUNC)
+#define GPSR1_10	F_(CAN5RX_INTP5,	GRP1_10_FUNC)
+#define GPSR1_9		F_(CAN4TX,		GRP1_9_FUNC)
+#define GPSR1_8		F_(CAN4RX_INTP4,	GRP1_8_FUNC)
+#define GPSR1_7		F_(CAN3TX,		GRP1_7_FUNC)
+#define GPSR1_6		F_(CAN3RX_INTP3,	GRP1_6_FUNC)
+#define GPSR1_5		F_(CAN2TX,		GRP1_5_FUNC)
+#define GPSR1_4		F_(CAN2RX_INTP2,	GRP1_4_FUNC)
+#define GPSR1_3		F_(CAN1TX,		GRP1_3_FUNC)
+#define GPSR1_2		F_(CAN1RX_INTP1,	GRP1_2_FUNC)
+#define GPSR1_1		F_(CAN0TX,		GRP1_1_FUNC)
+#define GPSR1_0		F_(CAN0RX_INTP0,	GRP1_0_FUNC)
+
+/* GPSR2 */
+#define GPSR2_28	F_(INTP34_B,		GRP2_28_FUNC)
+#define GPSR2_27	F_(TAUD1O3,		GRP2_27_FUNC)
+#define GPSR2_26	F_(TAUD1O2,		GRP2_26_FUNC)
+#define GPSR2_25	F_(TAUD1O1,		GRP2_25_FUNC)
+#define GPSR2_24	F_(TAUD1O0,		GRP2_24_FUNC)
+#define GPSR2_23	F_(EXTCLK0O_B,		GRP2_23_FUNC)
+#define GPSR2_22	F_(AVS1,		GRP2_22_FUNC)
+#define GPSR2_21	F_(AVS0,		GRP2_21_FUNC)
+#define GPSR2_20	F_(SDA0,		GRP2_20_FUNC)
+#define GPSR2_19	F_(SCL0,		GRP2_19_FUNC)
+#define GPSR2_18	F_(INTP33_B,		GRP2_18_FUNC)
+#define GPSR2_17	F_(INTP32_B,		GRP2_17_FUNC)
+#define GPSR2_16	F_(CAN_CLK,		GRP2_16_FUNC)
+#define GPSR2_15	F_(CAN15TX_B,		GRP2_15_FUNC)
+#define GPSR2_14	F_(CAN15RX_INTP15_B,	GRP2_14_FUNC)
+#define GPSR2_13	F_(CAN14TX_B,		GRP2_13_FUNC)
+#define GPSR2_12	F_(CAN14RX_INTP14_B,	GRP2_12_FUNC)
+#define GPSR2_11	F_(CAN13TX_B,		GRP2_11_FUNC)
+#define GPSR2_10	F_(CAN13RX_INTP13_B,	GRP2_10_FUNC)
+#define GPSR2_9		F_(CAN12TX_B,		GRP2_9_FUNC)
+#define GPSR2_8		F_(CAN12RX_INTP12_B,	GRP2_8_FUNC)
+#define GPSR2_7		F_(RLIN37TX_B,		GRP2_7_FUNC)
+#define GPSR2_6		F_(RLIN37RX_INTP23_B,	GRP2_6_FUNC)
+#define GPSR2_5		F_(RLIN36TX_B,		GRP2_5_FUNC)
+#define GPSR2_4		F_(RLIN36RX_INTP22_B,	GRP2_4_FUNC)
+#define GPSR2_3		F_(RLIN35TX_B,		GRP2_3_FUNC)
+#define GPSR2_2		F_(RLIN35RX_INTP21_B,	GRP2_2_FUNC)
+#define GPSR2_1		F_(RLIN34TX_B,		GRP2_1_FUNC)
+#define GPSR2_0		F_(RLIN34RX_INTP20_B,	GRP2_0_FUNC)
+
+/* GPSR3 */
+#define GPSR3_16	F_(ERRORIN_N,		GRP3_16_FUNC)
+#define GPSR3_15	F_(ERROROUT_N,		GRP3_15_FUNC)
+#define GPSR3_14	F_(QSPI1_SSL,		GRP3_14_FUNC)
+#define GPSR3_13	F_(QSPI1_IO3,		GRP3_13_FUNC)
+#define GPSR3_12	F_(QSPI1_IO2,		GRP3_12_FUNC)
+#define GPSR3_11	F_(QSPI1_MISO_IO1,	GRP3_11_FUNC)
+#define GPSR3_10	F_(QSPI1_MOSI_IO0,	GRP3_10_FUNC)
+#define GPSR3_9		F_(QSPI1_SPCLK,		GRP3_9_FUNC)
+#define GPSR3_8		F_(RPC_INT_N,		GRP3_8_FUNC)
+#define GPSR3_7		F_(RPC_WP_N,		GRP3_7_FUNC)
+#define GPSR3_6		F_(RPC_RESET_N,		GRP3_6_FUNC)
+#define GPSR3_5		F_(QSPI0_SSL,		GRP3_5_FUNC)
+#define GPSR3_4		F_(QSPI0_IO3,		GRP3_4_FUNC)
+#define GPSR3_3		F_(QSPI0_IO2,		GRP3_3_FUNC)
+#define GPSR3_2		F_(QSPI0_MISO_IO1,	GRP3_2_FUNC)
+#define GPSR3_1		F_(QSPI0_MOSI_IO0,	GRP3_1_FUNC)
+#define GPSR3_0		F_(QSPI0_SPCLK,		GRP3_0_FUNC)
+
+/* GPSR4 */
+#define GPSR4_15	F_(PCIE61_CLKREQ_N,	GRP4_15_FUNC)
+#define GPSR4_14	F_(PCIE60_CLKREQ_N,	GRP4_14_FUNC)
+#define GPSR4_13	F_(ERRORIN_N,		GRP4_13_FUNC)
+#define GPSR4_12	F_(SD0_CD,		GRP4_12_FUNC)
+#define GPSR4_11	F_(SD0_WP,		GRP4_11_FUNC)
+#define GPSR4_10	F_(MMC0_DS,		GRP4_10_FUNC)
+#define GPSR4_9		F_(MMC0_D7,		GRP4_9_FUNC)
+#define GPSR4_8		F_(MMC0_D6,		GRP4_8_FUNC)
+#define GPSR4_7		F_(MMC0_D5,		GRP4_7_FUNC)
+#define GPSR4_6		F_(MMC0_D4,		GRP4_6_FUNC)
+#define GPSR4_5		F_(MMC0_SD_D3,		GRP4_5_FUNC)
+#define GPSR4_4		F_(MMC0_SD_D2,		GRP4_4_FUNC)
+#define GPSR4_3		F_(MMC0_SD_D1,		GRP4_3_FUNC)
+#define GPSR4_2		F_(MMC0_SD_D0,		GRP4_2_FUNC)
+#define GPSR4_1		F_(MMC0_SD_CMD,		GRP4_1_FUNC)
+#define GPSR4_0		F_(MMC0_SD_CLK,		GRP4_0_FUNC)
+
+/* GPSR5 */
+#define GPSR5_22	F_(TPU0TO3,		GRP5_22_FUNC)
+#define GPSR5_21	F_(TPU0TO2,		GRP5_21_FUNC)
+#define GPSR5_20	F_(TPU0TO1,		GRP5_20_FUNC)
+#define GPSR5_19	F_(TPU0TO0,		GRP5_19_FUNC)
+#define GPSR5_18	F_(TCLK4,		GRP5_18_FUNC)
+#define GPSR5_17	F_(TCLK3,		GRP5_17_FUNC)
+#define GPSR5_16	F_(TCLK2,		GRP5_16_FUNC)
+#define GPSR5_15	F_(TCLK1,		GRP5_15_FUNC)
+#define GPSR5_14	F_(IRQ3_A,		GRP5_14_FUNC)
+#define GPSR5_13	F_(IRQ2_A,		GRP5_13_FUNC)
+#define GPSR5_12	F_(IRQ1_A,		GRP5_12_FUNC)
+#define GPSR5_11	F_(IRQ0_A,		GRP5_11_FUNC)
+#define GPSR5_10	F_(HSCK1,		GRP5_10_FUNC)
+#define GPSR5_9		F_(HCTS1_N,		GRP5_9_FUNC)
+#define GPSR5_8		F_(HRTS1_N,		GRP5_8_FUNC)
+#define GPSR5_7		F_(HRX1,		GRP5_7_FUNC)
+#define GPSR5_6		F_(HTX1,		GRP5_6_FUNC)
+#define GPSR5_5		F_(SCIF_CLK,		GRP5_5_FUNC)
+#define GPSR5_4		F_(HSCK0,		GRP5_4_FUNC)
+#define GPSR5_3		F_(HCTS0_N,		GRP5_3_FUNC)
+#define GPSR5_2		F_(HRTS0_N,		GRP5_2_FUNC)
+#define GPSR5_1		F_(HRX0,		GRP5_1_FUNC)
+#define GPSR5_0		F_(HTX0,		GRP5_0_FUNC)
+
+/* GPSR6 */
+#define GPSR6_30	F_(AUDIO1_CLKOUT1,	GRP6_30_FUNC)
+#define GPSR6_29	F_(AUDIO1_CLKOUT0,	GRP6_29_FUNC)
+#define GPSR6_28	F_(SSI2_SD,		GRP6_28_FUNC)
+#define GPSR6_27	F_(SSI2_WS,		GRP6_27_FUNC)
+#define GPSR6_26	F_(SSI2_SCK,		GRP6_26_FUNC)
+#define GPSR6_25	F_(AUDIO0_CLKOUT3,	GRP6_25_FUNC)
+#define GPSR6_24	F_(AUDIO0_CLKOUT2,	GRP6_24_FUNC)
+#define GPSR6_23	F_(SSI1_SD,		GRP6_23_FUNC)
+#define GPSR6_22	F_(SSI1_WS,		GRP6_22_FUNC)
+#define GPSR6_21	F_(SSI1_SCK,		GRP6_21_FUNC)
+#define GPSR6_20	F_(AUDIO0_CLKOUT1,	GRP6_20_FUNC)
+#define GPSR6_19	F_(AUDIO0_CLKOUT0,	GRP6_19_FUNC)
+#define GPSR6_18	F_(SSI0_SD,		GRP6_18_FUNC)
+#define GPSR6_17	F_(SSI0_WS,		GRP6_17_FUNC)
+#define GPSR6_16	F_(SSI0_SCK,		GRP6_16_FUNC)
+#define GPSR6_15	F_(MSIOF4_SS2_B,	GRP6_15_FUNC)
+#define GPSR6_14	F_(MSIOF4_SS1_B,	GRP6_14_FUNC)
+#define GPSR6_13	F_(MSIOF4_SYNC_B,	GRP6_13_FUNC)
+#define GPSR6_12	F_(MSIOF4_RXD_B,	GRP6_12_FUNC)
+#define GPSR6_11	F_(MSIOF4_TXD_B,	GRP6_11_FUNC)
+#define GPSR6_10	F_(MSIOF4_SCK_B,	GRP6_10_FUNC)
+#define GPSR6_9		F_(MSIOF7_SS2_A,	GRP6_9_FUNC)
+#define GPSR6_8		F_(MSIOF7_SS1_A,	GRP6_8_FUNC)
+#define GPSR6_7		F_(MSIOF7_SYNC_A,	GRP6_7_FUNC)
+#define GPSR6_6		F_(MSIOF7_RXD_A,	GRP6_6_FUNC)
+#define GPSR6_5		F_(MSIOF7_TXD_A,	GRP6_5_FUNC)
+#define GPSR6_4		F_(MSIOF7_SCK_A,	GRP6_4_FUNC)
+#define GPSR6_3		F_(RIF6_CLK,		GRP6_3_FUNC)
+#define GPSR6_2		F_(RIF6_SYNC,		GRP6_2_FUNC)
+#define GPSR6_1		F_(RIF6_D1,		GRP6_1_FUNC)
+#define GPSR6_0		F_(RIF6_D0,		GRP6_0_FUNC)
+
+/* GPSR7 */
+#define GPSR7_30	F_(MSIOF6_SS2_B,	GRP7_30_FUNC)
+#define GPSR7_29	F_(MSIOF6_SS1_B,	GRP7_29_FUNC)
+#define GPSR7_28	F_(MSIOF6_SYNC_B,	GRP7_28_FUNC)
+#define GPSR7_27	F_(MSIOF6_RXD_B,	GRP7_27_FUNC)
+#define GPSR7_26	F_(MSIOF6_TXD_B,	GRP7_26_FUNC)
+#define GPSR7_25	F_(MSIOF6_SCK_B,	GRP7_25_FUNC)
+#define GPSR7_24	F_(MSIOF5_SS2,		GRP7_24_FUNC)
+#define GPSR7_23	F_(MSIOF5_SS1,		GRP7_23_FUNC)
+#define GPSR7_22	F_(MSIOF5_SYNC,		GRP7_22_FUNC)
+#define GPSR7_21	F_(MSIOF5_RXD,		GRP7_21_FUNC)
+#define GPSR7_20	F_(MSIOF5_TXD,		GRP7_20_FUNC)
+#define GPSR7_19	F_(GP07_19,		GRP7_19_FUNC)
+#define GPSR7_18	F_(GP07_18,		GRP7_18_FUNC)
+#define GPSR7_17	F_(MSIOF5_SCK,		GRP7_17_FUNC)
+#define GPSR7_16	F_(AUDIO_CLKC_A,	GRP7_16_FUNC)
+#define GPSR7_15	F_(SSI6_SD,		GRP7_15_FUNC)
+#define GPSR7_14	F_(SSI6_WS,		GRP7_14_FUNC)
+#define GPSR7_13	F_(SSI6_SCK,		GRP7_13_FUNC)
+#define GPSR7_12	F_(AUDIO_CLKB_A,	GRP7_12_FUNC)
+#define GPSR7_11	F_(SSI5_SD,		GRP7_11_FUNC)
+#define GPSR7_10	F_(SSI5_WS,		GRP7_10_FUNC)
+#define GPSR7_9		F_(SSI5_SCK,		GRP7_9_FUNC)
+#define GPSR7_8		F_(AUDIO_CLKA_A,	GRP7_8_FUNC)
+#define GPSR7_7		F_(SSI4_SD,		GRP7_7_FUNC)
+#define GPSR7_6		F_(SSI4_WS,		GRP7_6_FUNC)
+#define GPSR7_5		F_(SSI4_SCK,		GRP7_5_FUNC)
+#define GPSR7_4		F_(AUDIO1_CLKOUT3,	GRP7_4_FUNC)
+#define GPSR7_3		F_(AUDIO1_CLKOUT2,	GRP7_3_FUNC)
+#define GPSR7_2		F_(SSI3_SD,		GRP7_2_FUNC)
+#define GPSR7_1		F_(SSI3_WS,		GRP7_1_FUNC)
+#define GPSR7_0		F_(SSI3_SCK,		GRP7_0_FUNC)
+
+/* GPSR8 */
+#define GPSR8_31	F_(S3DA2,		GRP8_31_FUNC)
+#define GPSR8_30	F_(S3CL2,		GRP8_30_FUNC)
+#define GPSR8_29	F_(S3DA1,		GRP8_29_FUNC)
+#define GPSR8_28	F_(S3CL1,		GRP8_28_FUNC)
+#define GPSR8_27	F_(S3DA0,		GRP8_27_FUNC)
+#define GPSR8_26	F_(S3CL0,		GRP8_26_FUNC)
+#define GPSR8_15	F_(SDA8,		GRP8_15_FUNC)
+#define GPSR8_14	F_(SCL8,		GRP8_14_FUNC)
+#define GPSR8_13	F_(SDA7,		GRP8_13_FUNC)
+#define GPSR8_12	F_(SCL7,		GRP8_12_FUNC)
+#define GPSR8_11	F_(SDA6,		GRP8_11_FUNC)
+#define GPSR8_10	F_(SCL6,		GRP8_10_FUNC)
+#define GPSR8_9		F_(SDA5,		GRP8_9_FUNC)
+#define GPSR8_8		F_(SCL5,		GRP8_8_FUNC)
+#define GPSR8_7		F_(SDA4,		GRP8_7_FUNC)
+#define GPSR8_6		F_(SCL4,		GRP8_6_FUNC)
+#define GPSR8_5		F_(SDA3,		GRP8_5_FUNC)
+#define GPSR8_4		F_(SCL3,		GRP8_4_FUNC)
+#define GPSR8_3		F_(SDA2,		GRP8_3_FUNC)
+#define GPSR8_2		F_(SCL2,		GRP8_2_FUNC)
+#define GPSR8_1		F_(SDA1,		GRP8_1_FUNC)
+#define GPSR8_0		F_(SCL1,		GRP8_0_FUNC)
+
+/* GPSR9 */
+#define GPSR9_16	F_(RSW3_MATCH,		GRP9_16_FUNC)
+#define GPSR9_15	F_(RSW3_CAPTURE,	GRP9_15_FUNC)
+#define GPSR9_14	F_(RSW3_PPS,		GRP9_14_FUNC)
+#define GPSR9_13	F_(ETH10G0_PHYINT,	GRP9_13_FUNC)
+#define GPSR9_12	F_(ETH10G0_LINK,	GRP9_12_FUNC)
+#define GPSR9_11	F_(ETH10G0_MDC,		GRP9_11_FUNC)
+#define GPSR9_10	F_(ETH10G0_MDIO,	GRP9_10_FUNC)
+#define GPSR9_9		F_(ETH25G0_PHYINT,	GRP9_9_FUNC)
+#define GPSR9_8		F_(ETH25G0_LINK,	GRP9_8_FUNC)
+#define GPSR9_7		F_(ETH25G0_MDC,		GRP9_7_FUNC)
+#define GPSR9_6		F_(ETH25G0_MDIO,	GRP9_6_FUNC)
+#define GPSR9_5		F_(ETHES4_MATCH,	GRP9_5_FUNC)
+#define GPSR9_4		F_(ETHES4_CAPTURE,	GRP9_4_FUNC)
+#define GPSR9_3		F_(ETHES4_PPS,		GRP9_3_FUNC)
+#define GPSR9_2		F_(ETHES0_MATCH,	GRP9_2_FUNC)
+#define GPSR9_1		F_(ETHES0_CAPTURE,	GRP9_1_FUNC)
+#define GPSR9_0		F_(ETHES0_PPS,		GRP9_0_FUNC)
+
+/* GPSR10 */
+#define GPSR10_13	F_(PCIE41_CLKREQ_N,	GRP10_13_FUNC)
+#define GPSR10_12	F_(PCIE40_CLKREQ_N,	GRP10_12_FUNC)
+#define GPSR10_11	F_(USB3_VBUS_VALID,	GRP10_11_FUNC)
+#define GPSR10_10	F_(USB3_OVC,		GRP10_10_FUNC)
+#define GPSR10_9	F_(USB3_PWEN,		GRP10_9_FUNC)
+#define GPSR10_8	F_(USB2_VBUS_VALID,	GRP10_8_FUNC)
+#define GPSR10_7	F_(USB2_OVC,		GRP10_7_FUNC)
+#define GPSR10_6	F_(USB2_PWEN,		GRP10_6_FUNC)
+#define GPSR10_5	F_(USB1_VBUS_VALID,	GRP10_5_FUNC)
+#define GPSR10_4	F_(USB1_OVC,		GRP10_4_FUNC)
+#define GPSR10_3	F_(USB1_PWEN,		GRP10_3_FUNC)
+#define GPSR10_2	F_(USB0_VBUS_VALID,	GRP10_2_FUNC)
+#define GPSR10_1	F_(USB0_OVC,		GRP10_1_FUNC)
+#define GPSR10_0	F_(USB0_PWEN,		GRP10_0_FUNC)
+
+/* Group0 Functions */	/* 0 */			/* 1 */			/* 2 */			/* 3			4	 5	  6	   7	    8	     9	      A	       B	C	 D	  E	   F */
+#define GRP0_27_FUNC	FM(DP2_HOTPLUG)		F_(0, 0)		F_(0, 0)		F_(0, 0)		F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define GRP0_26_FUNC	FM(DP1_HOTPLUG)		F_(0, 0)		F_(0, 0)		F_(0, 0)		F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define GRP0_25_FUNC	FM(DP0_HOTPLUG)		F_(0, 0)		F_(0, 0)		F_(0, 0)		F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define GRP0_24_FUNC	FM(MSIOF1_SS2_A)	FM(TAUD0O13)		F_(0, 0)		F_(0, 0)		F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define GRP0_23_FUNC	FM(MSIOF1_SS1_A)	FM(TAUD0O12)		F_(0, 0)		F_(0, 0)		F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define GRP0_22_FUNC	FM(MSIOF1_SYNC_A)	FM(TAUD0O11)		F_(0, 0)		F_(0, 0)		F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define GRP0_21_FUNC	FM(MSIOF1_RXD_A)	FM(TAUD0O10)		F_(0, 0)		F_(0, 0)		F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define GRP0_20_FUNC	FM(MSIOF1_TXD_A)	FM(TAUD0O9)		F_(0, 0)		F_(0, 0)		F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define GRP0_19_FUNC	FM(MSIOF1_SCK_A)	FM(TAUD0O8)		F_(0, 0)		F_(0, 0)		F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define GRP0_18_FUNC	FM(MSIOF0_SS2)		FM(TAUD0O7)		F_(0, 0)		F_(0, 0)		F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define GRP0_17_FUNC	FM(MSIOF0_SS1)		FM(TAUD0O6)		F_(0, 0)		F_(0, 0)		F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define GRP0_16_FUNC	FM(MSIOF0_SYNC)		FM(TAUD0O5)		F_(0, 0)		F_(0, 0)		F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define GRP0_15_FUNC	FM(MSIOF0_RXD)		FM(TAUD0O4)		F_(0, 0)		F_(0, 0)		F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define GRP0_14_FUNC	FM(MSIOF0_TXD)		FM(TAUD0O3)		F_(0, 0)		F_(0, 0)		F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define GRP0_13_FUNC	FM(MSIOF0_SCK)		FM(TAUD0O2)		F_(0, 0)		F_(0, 0)		F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define GRP0_12_FUNC	FM(RXDB_EXTFXR_A)	FM(CAN11TX)		FM(RLIN311TX)		FM(RTCA0OUT_A)		F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define GRP0_11_FUNC	FM(FXR_TXENB_N_A)	FM(CAN11RX_INTP11)	FM(RLIN311RX_INTP27)	FM(EXTCLK0O_A)		F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define GRP0_10_FUNC	FM(FXR_TXDB_A)		FM(CAN10TX)		FM(RLIN310TX)		F_(0, 0)		F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define GRP0_9_FUNC	FM(RXDA_EXTFXR_A)	FM(CAN10RX_INTP10)	FM(RLIN310RX_INTP26)	F_(0, 0)		F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define GRP0_8_FUNC	FM(FXR_TXENA_N_A)	FM(CAN9TX)		FM(RLIN39TX)		FM(TAUD1O15)		F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define GRP0_7_FUNC	FM(FXR_TXDA_A)		FM(CAN9RX_INTP9)	FM(RLIN39RX_INTP25)	FM(TAUD1O14)		F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define GRP0_6_FUNC	FM(CLK_EXTFXR_A)	FM(CAN8TX)		FM(RLIN38TX)		FM(TAUD1O13)		F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define GRP0_5_FUNC	FM(FXR_CLKOUT2_A)	FM(CAN8RX_INTP8)	FM(RLIN38RX_INTP24)	FM(TAUD1O12)		F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define GRP0_4_FUNC	FM(FXR_CLKOUT1_A)	FM(CAN7TX)		FM(RLIN315TX_A)		FM(TAUD1O11)		F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define GRP0_3_FUNC	FM(STPWT_EXTFXR_A)	FM(CAN7RX_INTP7)	FM(RLIN315RX_INTP31_A)	FM(TAUD1O10)		F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define GRP0_2_FUNC	F_(0, 0)		F_(0, 0)		F_(0, 0)		F_(0, 0)		F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define GRP0_1_FUNC	F_(0, 0)		F_(0, 0)		F_(0, 0)		F_(0, 0)		F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define GRP0_0_FUNC	F_(0, 0)		F_(0, 0)		F_(0, 0)		F_(0, 0)		F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+
+/* Group1 Functions */	/* 0 */			/* 1 */			/* 2 */			/* 3			4	 5	  6	   7	    8	     9	      A	       B	C	 D	  E	   F */
+#define GRP1_21_FUNC	FM(RLIN33TX)		FM(TAUJ1I3_TAUJ1O3)	FM(CAN15TX_A)		F_(0, 0)		F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define GRP1_20_FUNC	FM(RLIN33RX_INTP19)	FM(TAUJ1I2_TAUJ1O2)	FM(CAN15RX_INTP15_A)	F_(0, 0)		F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define GRP1_19_FUNC	FM(RLIN32TX)		FM(TAUJ1I1_TAUJ1O1)	FM(CAN14TX_A)		FM(NMI1_A)		F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define GRP1_18_FUNC	FM(RLIN32RX_INTP18)	FM(TAUJ1I0_TAUJ1O0)	FM(CAN14RX_INTP14_A)	FM(INTP34_A)		F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define GRP1_17_FUNC	FM(RLIN31TX)		FM(TAUJ3I3_TAUJ3O3)	FM(CAN13TX_A)		FM(INTP33_A)		F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define GRP1_16_FUNC	FM(RLIN31RX_INTP17)	FM(TAUJ3I2_TAUJ3O2)	FM(CAN13RX_INTP13_A)	FM(INTP32_A)		F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define GRP1_15_FUNC	FM(RLIN30TX)		FM(TAUJ3I1_TAUJ3O1)	FM(CAN12TX_A)		F_(0, 0)		F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define GRP1_14_FUNC	FM(RLIN30RX_INTP16)	FM(TAUJ3I0_TAUJ3O0)	FM(CAN12RX_INTP12_A)	F_(0, 0)		F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define GRP1_13_FUNC	FM(CAN6TX)		FM(RLIN314TX_A)		FM(TAUD1O9)		F_(0, 0)		F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define GRP1_12_FUNC	FM(CAN6RX_INTP6)	FM(RLIN314RX_INTP30_A)	FM(TAUD1O8)		F_(0, 0)		F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define GRP1_11_FUNC	FM(CAN5TX)		FM(RLIN313TX_A)		FM(MSIOF3_SS2)		FM(RXDB_EXTFXR_B)	F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define GRP1_10_FUNC	FM(CAN5RX_INTP5)	FM(RLIN313RX_INTP29_A)	FM(MSIOF3_SS1)		FM(FXR_TXENB_N_B)	F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define GRP1_9_FUNC	FM(CAN4TX)		FM(RLIN312TX_A)		FM(MSIOF3_SYNC)		FM(FXR_TXDB_B)		F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define GRP1_8_FUNC	FM(CAN4RX_INTP4)	FM(RLIN312RX_INTP28_A)	FM(MSIOF3_RXD)		FM(RXDA_EXTFXR_B)	F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define GRP1_7_FUNC	FM(CAN3TX)		FM(RLIN37TX_A)		FM(MSIOF3_TXD)		FM(FXR_TXENA_N_B)	F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define GRP1_6_FUNC	FM(CAN3RX_INTP3)	FM(RLIN37RX_INTP23_A)	FM(MSIOF3_SCK)		FM(FXR_TXDA_B)		F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define GRP1_5_FUNC	FM(CAN2TX)		FM(RLIN36TX_A)		FM(MSIOF2_SS2)		FM(CLK_EXTFXR_B)	F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define GRP1_4_FUNC	FM(CAN2RX_INTP2)	FM(RLIN36RX_INTP22_A)	FM(MSIOF2_SS1)		FM(FXR_CLKOUT2_B)	F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define GRP1_3_FUNC	FM(CAN1TX)		FM(RLIN35TX_A)		FM(MSIOF2_SYNC)		FM(FXR_CLKOUT1_B)	F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define GRP1_2_FUNC	FM(CAN1RX_INTP1)	FM(RLIN35RX_INTP21_A)	FM(MSIOF2_RXD)		FM(STPWT_EXTFXR_B)	F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define GRP1_1_FUNC	FM(CAN0TX)		FM(RLIN34TX_A)		FM(MSIOF2_TXD)		F_(0, 0)		F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define GRP1_0_FUNC	FM(CAN0RX_INTP0)	FM(RLIN34RX_INTP20_A)	FM(MSIOF2_SCK)		F_(0, 0)		F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+
+/* Group2 Functions */	/* 0 */			/* 1 */			/* 2 */			/* 3			4	 5	  6	   7	    8	     9	      A	       B	C	 D	  E	   F */
+#define GRP2_28_FUNC	FM(INTP34_B)		F_(0, 0)		F_(0, 0)		F_(0, 0)		F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define GRP2_27_FUNC	FM(TAUD1O3)		F_(0, 0)		F_(0, 0)		F_(0, 0)		F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define GRP2_26_FUNC	FM(TAUD1O2)		F_(0, 0)		F_(0, 0)		F_(0, 0)		F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define GRP2_25_FUNC	FM(TAUD1O1)		F_(0, 0)		F_(0, 0)		F_(0, 0)		F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define GRP2_24_FUNC	FM(TAUD1O0)		F_(0, 0)		F_(0, 0)		F_(0, 0)		F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define GRP2_23_FUNC	FM(EXTCLK0O_B)		F_(0, 0)		F_(0, 0)		F_(0, 0)		F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define GRP2_22_FUNC	FM(AVS1)		F_(0, 0)		F_(0, 0)		F_(0, 0)		F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define GRP2_21_FUNC	FM(AVS0)		F_(0, 0)		F_(0, 0)		F_(0, 0)		F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define GRP2_20_FUNC	FM(SDA0)		F_(0, 0)		F_(0, 0)		F_(0, 0)		F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define GRP2_19_FUNC	FM(SCL0)		F_(0, 0)		F_(0, 0)		F_(0, 0)		F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define GRP2_18_FUNC	FM(INTP33_B)		FM(TAUD0O1)		F_(0, 0)		F_(0, 0)		F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define GRP2_17_FUNC	FM(INTP32_B)		FM(TAUD0O0)		F_(0, 0)		F_(0, 0)		F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define GRP2_16_FUNC	FM(CAN_CLK)		F_(0, 0)		F_(0, 0)		F_(0, 0)		F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define GRP2_15_FUNC	FM(CAN15TX_B)		FM(RLIN315TX_B)		F_(0, 0)		F_(0, 0)		F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define GRP2_14_FUNC	FM(CAN15RX_B_INTP15)	FM(RLIN315RX_INTP31_B)	F_(0, 0)		F_(0, 0)		F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define GRP2_13_FUNC	FM(CAN14TX_B)		FM(RLIN314TX_B)		F_(0, 0)		F_(0, 0)		F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define GRP2_12_FUNC	FM(CAN14RX_B_INTP14)	FM(RLIN314RX_INTP30_B)	F_(0, 0)		F_(0, 0)		F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define GRP2_11_FUNC	FM(CAN13TX_B)		FM(RLIN313TX)		F_(0, 0)		FM(CANXL1_TX)		F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define GRP2_10_FUNC	FM(CAN13RX_B_INTP13)	FM(RLIN313RX_INTP29_B)	F_(0, 0)		FM(CANXL1_RX)		F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define GRP2_9_FUNC	FM(CAN12TX_B)		FM(RLIN312TX)		FM(TAUD1O7)		FM(CANXL0_TX)		F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define GRP2_8_FUNC	FM(CAN12RX_B_INTP12)	FM(RLIN312RX_INTP28_B)	FM(TAUD1O6)		FM(CANXL0_RX)		F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define GRP2_7_FUNC	FM(RLIN37TX_B)		FM(RTCA0OUT_B)		FM(TAUD1O5)		F_(0, 0)		F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define GRP2_6_FUNC	FM(RLIN37RX_B_INTP23)	F_(0, 0)		FM(TAUD1O4)		F_(0, 0)		F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define GRP2_5_FUNC	FM(RLIN36TX_B)		FM(MSIOF1_SS2_B)	F_(0, 0)		F_(0, 0)		F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define GRP2_4_FUNC	FM(RLIN36RX_B_INTP22)	FM(MSIOF1_SS1_B)	F_(0, 0)		FM(CTIACK)		F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define GRP2_3_FUNC	FM(RLIN35TX_B)		FM(MSIOF1_SYN_B)	F_(0, 0)		FM(CTIREQ)		F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define GRP2_2_FUNC	FM(RLIN35RX_B_INTP21)	FM(MSIOF1_RXD_B)	F_(0, 0)		F_(0, 0)		F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define GRP2_1_FUNC	FM(RLIN34TX_B)		FM(MSIOF1_TXD_B)	FM(TAUD0O15)		F_(0, 0)		F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define GRP2_0_FUNC	FM(RLIN34RX_B_INTP20)	FM(MSIOF1_SCK_B)	FM(TAUD0O14)		F_(0, 0)		F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+
+
+/* Group3 Functions */	/* 0 */			/* 1 */			/* 2 */			/* 3			4	 5	  6	   7	    8	     9	      A	       B	C	 D	  E	   F */
+#define GRP3_16_FUNC	FM(ERRORIN0_N)		F_(0, 0)		F_(0, 0)		F_(0, 0)		F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define GRP3_15_FUNC	FM(ERROROUT_N)		F_(0, 0)		F_(0, 0)		F_(0, 0)		F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define GRP3_14_FUNC	FM(QSPI1_SSL)		F_(0, 0)		F_(0, 0)		F_(0, 0)		F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define GRP3_13_FUNC	FM(QSPI1_IO3)		F_(0, 0)		F_(0, 0)		F_(0, 0)		F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define GRP3_12_FUNC	FM(QSPI1_IO2)		F_(0, 0)		F_(0, 0)		F_(0, 0)		F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define GRP3_11_FUNC	FM(QSPI1_MISO_IO1)	F_(0, 0)		F_(0, 0)		F_(0, 0)		F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define GRP3_10_FUNC	FM(QSPI1_MOSI_IO0)	F_(0, 0)		F_(0, 0)		F_(0, 0)		F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define GRP3_9_FUNC	FM(QSPI1_SPCLK)		F_(0, 0)		F_(0, 0)		F_(0, 0)		F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define GRP3_8_FUNC	FM(RPC_INT_N)		F_(0, 0)		F_(0, 0)		F_(0, 0)		F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define GRP3_7_FUNC	FM(RPC_WP_N)		F_(0, 0)		F_(0, 0)		F_(0, 0)		F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define GRP3_6_FUNC	FM(RPC_RESET_N)		F_(0, 0)		F_(0, 0)		F_(0, 0)		F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define GRP3_5_FUNC	FM(QSPI0_SSL)		F_(0, 0)		F_(0, 0)		F_(0, 0)		F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define GRP3_4_FUNC	FM(QSPI0_IO3)		F_(0, 0)		F_(0, 0)		F_(0, 0)		F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define GRP3_3_FUNC	FM(QSPI0_IO2)		F_(0, 0)		F_(0, 0)		F_(0, 0)		F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define GRP3_2_FUNC	FM(QSPI0_MISO_IO1)	F_(0, 0)		F_(0, 0)		F_(0, 0)		F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define GRP3_1_FUNC	FM(QSPI0_MOSI_IO0)	F_(0, 0)		F_(0, 0)		F_(0, 0)		F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define GRP3_0_FUNC	FM(QSPI0_SPCLK)		F_(0, 0)		F_(0, 0)		F_(0, 0)		F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+
+/* Group4 Functions */	/* 0 */			/* 1 */			/* 2 */			/* 3			4	 5	  6	   7	    8	     9	      A	       B	C	 D	  E	   F */
+#define GRP4_15_FUNC	FM(PCIE61_CLKREQ_N)	F_(0, 0)		F_(0, 0)		F_(0, 0)		F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define GRP4_14_FUNC	FM(PCIE60_CLKREQ_N)	F_(0, 0)		F_(0, 0)		F_(0, 0)		F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define GRP4_13_FUNC	FM(ERRORIN1_N)		F_(0, 0)		F_(0, 0)		F_(0, 0)		F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define GRP4_12_FUNC	FM(SD0_CD)		F_(0, 0)		F_(0, 0)		F_(0, 0)		F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define GRP4_11_FUNC	FM(SD0_WP)		F_(0, 0)		F_(0, 0)		F_(0, 0)		F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define GRP4_10_FUNC	FM(MMC0_DS)		F_(0, 0)		F_(0, 0)		F_(0, 0)		F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define GRP4_9_FUNC	FM(MMC0_D7)		F_(0, 0)		F_(0, 0)		F_(0, 0)		F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define GRP4_8_FUNC	FM(MMC0_D6)		F_(0, 0)		F_(0, 0)		F_(0, 0)		F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define GRP4_7_FUNC	FM(MMC0_D5)		F_(0, 0)		F_(0, 0)		F_(0, 0)		F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define GRP4_6_FUNC	FM(MMC0_D4)		F_(0, 0)		F_(0, 0)		F_(0, 0)		F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define GRP4_5_FUNC	FM(MMC0_SD_D3)		F_(0, 0)		F_(0, 0)		F_(0, 0)		F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define GRP4_4_FUNC	FM(MMC0_SD_D2)		F_(0, 0)		F_(0, 0)		F_(0, 0)		F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define GRP4_3_FUNC	FM(MMC0_SD_D1)		F_(0, 0)		F_(0, 0)		F_(0, 0)		F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define GRP4_2_FUNC	FM(MMC0_SD_D0)		F_(0, 0)		F_(0, 0)		F_(0, 0)		F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define GRP4_1_FUNC	FM(MMC0_SD_CMD)		F_(0, 0)		F_(0, 0)		F_(0, 0)		F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define GRP4_0_FUNC	FM(MMC0_SD_CLK)		F_(0, 0)		F_(0, 0)		F_(0, 0)		F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+
+/* Group5 Functions */	/* 0 */			/* 1 */			/* 2 */			/* 3			4	 5	  6	   7	    8	     9	      A	       B	C	 D	  E	   F */
+#define GRP5_22_FUNC	FM(TPU0TO3)		FM(SSI9_WS)		F_(0, 0)		F_(0, 0)		F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define GRP5_21_FUNC	FM(TPU0TO2)		FM(SSI9_SCK)		F_(0, 0)		F_(0, 0)		F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define GRP5_20_FUNC	FM(TPU0TO1)		FM(PWM5)		F_(0, 0)		F_(0, 0)		F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define GRP5_19_FUNC	FM(TPU0TO0)		FM(PWM4)		F_(0, 0)		F_(0, 0)		F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define GRP5_18_FUNC	FM(TCLK4)		FM(PWM3)		FM(SSI19_SD)		F_(0, 0)		F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define GRP5_17_FUNC	FM(TCLK3)		FM(PWM2)		FM(SSI19_WS)		F_(0, 0)		F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define GRP5_16_FUNC	FM(TCLK2)		FM(PWM1)		FM(SSI19_SCK)		F_(0, 0)		F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define GRP5_15_FUNC	FM(TCLK1)		FM(PWM0_A)		FM(SSI18_SD)		F_(0, 0)		F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define GRP5_14_FUNC	FM(IRQ3_A)		F_(0, 0)		F_(0, 0)		FM(RIF7_D1)		F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define GRP5_13_FUNC	FM(IRQ2_A)		FM(SSI17_SD)		F_(0, 0)		FM(RIF7_D0)		F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define GRP5_12_FUNC	FM(IRQ1_A)		FM(SSI17_WS)		F_(0, 0)		FM(RIF7_SYNC)		F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define GRP5_11_FUNC	FM(IRQ0_A)		FM(SSI17_SCK)		F_(0, 0)		FM(RIF7_CLK)		F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define GRP5_10_FUNC	FM(HSCK1)		FM(SCK1)		FM(SSI13_SCK)		FM(RIF0_CLK_B)		F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define GRP5_9_FUNC	FM(HCTS1_N)		FM(CTS1_N)		F_(0, 0)		F_(0, 0)		F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define GRP5_8_FUNC	FM(HRTS1_N)		FM(RTS1_N)		FM(RIF0_SYNC_B)		FM(SSI16_SD)		F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define GRP5_7_FUNC	FM(HRX1)		FM(RX1)			F_(0, 0)		FM(SSI16_WS)		F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define GRP5_6_FUNC	FM(HTX1)		FM(TX1)			F_(0, 0)		FM(SSI16_SCK)		F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define GRP5_5_FUNC	FM(SCIF_CLK)		F_(0, 0)		F_(0, 0)		F_(0, 0)		F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define GRP5_4_FUNC	FM(HSCK0)		FM(SCK0)		F_(0, 0)		FM(SSI15_SD)		F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define GRP5_3_FUNC	FM(HCTS0_N)		FM(CTS0_N)		FM(IRQ1_B)		FM(SSI15_WS)		F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define GRP5_2_FUNC	FM(HRTS0_N)		FM(RTS0_N)		FM(IRQ0_B)		FM(SSI15_SCK)		F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define GRP5_1_FUNC	FM(HRX0)		FM(RX0)			FM(SSI13_SD)		FM(RIF0_D1_B)		F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define GRP5_0_FUNC	FM(HTX0)		FM(TX0)			FM(SSI13_WS)		FM(RIF0_D0_B)		F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+
+/* Group6 Functions */	/* 0 */			/* 1 */			/* 2 */			/* 3				4	 5	  6	   7	    8	     9	      A	       B	C	 D	  E	   F */
+#define GRP6_30_FUNC	FM(AUDIO1_CLKOUT1)	FM(MSIOF7_RXD_B)	FM(RIF5_CLK)		F_(0, 0)		F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define GRP6_29_FUNC	FM(AUDIO1_CLKOUT0)	FM(MSIOF7_TXD_B)	F_(0, 0)		F_(0, 0)		F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define GRP6_28_FUNC	FM(SSI2_SD)		FM(MSIOF7_SCK_B)	FM(RIF5_SYNC)		F_(0, 0)		F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define GRP6_27_FUNC	FM(SSI2_WS)		F_(0, 0)		FM(RIF1_D1_A)		F_(0, 0)		F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define GRP6_26_FUNC	FM(SSI2_SCK)		F_(0, 0)		FM(RIF1_D0_A)		F_(0, 0)		F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define GRP6_25_FUNC	FM(AUDIO0_CLKOUT3)	F_(0, 0)		FM(RIF1_CLK_A)		F_(0, 0)		F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define GRP6_24_FUNC	FM(AUDIO0_CLKOUT2)	F_(0, 0)		FM(RIF2_D1)		F_(0, 0)		F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define GRP6_23_FUNC	FM(SSI1_SD)		F_(0, 0)		FM(HCTS3_N)		FM(CTS3_N)		F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define GRP6_22_FUNC	FM(SSI1_WS)		F_(0, 0)		FM(HRTS3_N)		FM(RTS3_N)		F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define GRP6_21_FUNC	FM(SSI1_SCK)		FM(MSIOF4_SS2_A)	FM(HSCK3)		FM(SCK3)		F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define GRP6_20_FUNC	FM(AUDIO0_CLKOUT1)	FM(MSIOF4_SS1_A)	FM(RIF2_D0)		F_(0, 0)		F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define GRP6_19_FUNC	FM(AUDIO0_CLKOUT0)	FM(MSIOF4_SYNC_A)	FM(RIF2_SYNC)		F_(0, 0)		F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define GRP6_18_FUNC	FM(SSI0_SD)		FM(MSIOF4_RXD_A)	FM(HRX3)		FM(RX3)			F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define GRP6_17_FUNC	FM(SSI0_WS)		FM(MSIOF4_TXD_A)	FM(HTX3)		FM(TX3)			F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define GRP6_16_FUNC	FM(SSI0_SCK)		FM(MSIOF4_SCK_A)	F_(0, 0)		F_(0, 0)		F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define GRP6_15_FUNC	FM(MSIOF4_SS2_B)	FM(SSI14_SD)		F_(0, 0)		F_(0, 0)		F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define GRP6_14_FUNC	FM(MSIOF4_SS1_B)	FM(SSI12_SD)		F_(0, 0)		F_(0, 0)		F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define GRP6_13_FUNC	FM(MSIOF4_SYNC_B)	FM(SSI12_WS)		F_(0, 0)		F_(0, 0)		F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define GRP6_12_FUNC	FM(MSIOF4_RXD_B)	F_(0, 0)		FM(AUDIO_CLKC_B)	F_(0, 0)		F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define GRP6_11_FUNC	FM(MSIOF4_TXD_B)	FM(SSI12_SCK)		F_(0, 0)		FM(RIF1_SYNC_A)		F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define GRP6_10_FUNC	FM(MSIOF4_SCK_B)	F_(0, 0)		FM(AUDIO_CLKB_B)	F_(0, 0)		F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define GRP6_9_FUNC	FM(MSIOF7_SS2_A)	FM(SSI14_WS)		F_(0, 0)		F_(0, 0)		F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define GRP6_8_FUNC	FM(MSIOF7_SS1_A)	FM(SSI14_SCK)		F_(0, 0)		F_(0, 0)		F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define GRP6_7_FUNC	FM(MSIOF7_SYNC_A)	FM(RIF1_D1_B)		FM(SSI11_SD)		F_(0, 0)		F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define GRP6_6_FUNC	FM(MSIOF7_RXD_A)	FM(RIF1_D0_B)		FM(SSI11_WS)		F_(0, 0)		F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define GRP6_5_FUNC	FM(MSIOF7_TXD_A)	FM(RIF1_SYNC_B)		FM(SSI11_SCK)		F_(0, 0)		F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define GRP6_4_FUNC	FM(MSIOF7_SCK_A)	FM(RIF1_CLK_B)		FM(AUDIO_CLKA_B)	F_(0, 0)		F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define GRP6_3_FUNC	FM(RIF6_CLK)		FM(SSI10_SD)		F_(0, 0)		F_(0, 0)		F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define GRP6_2_FUNC	FM(RIF6_SYNC)		FM(SSI10_WS)		F_(0, 0)		F_(0, 0)		F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define GRP6_1_FUNC	FM(RIF6_D1)		FM(SSI10_SCK)		F_(0, 0)		F_(0, 0)		F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define GRP6_0_FUNC	FM(RIF6_D0)		FM(SSI9_SD)		F_(0, 0)		F_(0, 0)		F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+
+/* Group7 Functions */	/* 0 */			/* 1 */			/* 2 */			/* 3			4	 5	  6	   7	    8	     9	      A	       B	C	 D	  E	   F */
+#define GRP7_30_FUNC	FM(MSIOF6_SS2_B)	FM(HRX2_B)		FM(RX4_B)		F_(0, 0)		F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define GRP7_29_FUNC	FM(MSIOF6_SS1_B)	FM(SSI7_SD)		F_(0, 0)		F_(0, 0)		F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define GRP7_28_FUNC	FM(MSIOF6_SYNC_B)	FM(SSI7_WS)		F_(0, 0)		F_(0, 0)		F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define GRP7_27_FUNC	FM(MSIOF6_RXD_B)	FM(SSI7_SCK)		F_(0, 0)		F_(0, 0)		F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define GRP7_26_FUNC	FM(MSIOF6_TXD_B)	FM(HTX2_B)		FM(TX4_B)		F_(0, 0)		F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define GRP7_25_FUNC	FM(MSIOF6_SCK_B)	FM(SSI8_SD)		F_(0, 0)		F_(0, 0)		F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define GRP7_24_FUNC	FM(MSIOF5_SS2)		FM(HCTS2_N_B)		FM(CTS4_N_B)		F_(0, 0)		F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define GRP7_23_FUNC	FM(MSIOF5_SS1)		FM(RIF0_SYNC_A)		F_(0, 0)		F_(0, 0)		F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define GRP7_22_FUNC	FM(MSIOF5_SYNC)		FM(HRTS2_N_B)		FM(RTS4_N_B)		F_(0, 0)		F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define GRP7_21_FUNC	FM(MSIOF5_RXD)		FM(RIF0_D1_A)		F_(0, 0)		F_(0, 0)		F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define GRP7_20_FUNC	FM(MSIOF5_TXD)		FM(HSCK2_B)		FM(SCK4_B)		F_(0, 0)		F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define GRP7_19_FUNC	F_(0, 0)		FM(MSIOF6_SS2_A)	F_(0, 0)		F_(0, 0)		F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define GRP7_18_FUNC	F_(0, 0)		FM(MSIOF6_SS1_A)	F_(0, 0)		F_(0, 0)		F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define GRP7_17_FUNC	FM(MSIOF5_SCK)		F_(0, 0)		F_(0, 0)		F_(0, 0)		F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define GRP7_16_FUNC	FM(AUDIO_CLKC_A)	F_(0, 0)		F_(0, 0)		F_(0, 0)		F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define GRP7_15_FUNC	FM(SSI6_SD)		FM(MSIOF6_RXD_A)	FM(RIF4_D1)		F_(0, 0)		F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define GRP7_14_FUNC	FM(SSI6_WS)		FM(MSIOF6_TXD_A)	FM(RIF4_D0)		F_(0, 0)		F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define GRP7_13_FUNC	FM(SSI6_SCK)		FM(MSIOF6_SCK_A)	FM(RIF4_SYNC)		F_(0, 0)		F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define GRP7_12_FUNC	FM(AUDIO_CLKB_A)	F_(0, 0)		F_(0, 0)		F_(0, 0)		F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define GRP7_11_FUNC	FM(SSI5_SD)		FM(MSIOF6_SYNC_A)	FM(RIF4_CLK)		F_(0, 0)		F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define GRP7_10_FUNC	FM(SSI5_WS)		FM(RIF3_SYNC)		F_(0, 0)		F_(0, 0)		F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define GRP7_9_FUNC	FM(SSI5_SCK)		FM(RIF3_CLK)		F_(0, 0)		F_(0, 0)		F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define GRP7_8_FUNC	FM(AUDIO_CLKA_A)	F_(0, 0)		F_(0, 0)		F_(0, 0)		F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define GRP7_7_FUNC	FM(SSI4_SD)		FM(RIF3_D1)		F_(0, 0)		F_(0, 0)		F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define GRP7_6_FUNC	FM(SSI4_WS)		FM(RIF3_D0)		F_(0, 0)		F_(0, 0)		F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define GRP7_5_FUNC	FM(SSI4_SCK)		FM(RIF2_CLK)		F_(0, 0)		F_(0, 0)		F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define GRP7_4_FUNC	FM(AUDIO1_CLKOUT3)	FM(RIF0_D0_A)		F_(0, 0)		F_(0, 0)		F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define GRP7_3_FUNC	FM(AUDIO1_CLKOUT2)	FM(RIF0_CLK_A)		F_(0, 0)		F_(0, 0)		F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define GRP7_2_FUNC	FM(SSI3_SD)		FM(MSIOF7_SS2_B)	F_(0, 0)		F_(0, 0)		F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define GRP7_1_FUNC	FM(SSI3_WS)		FM(MSIOF7_SS1_B)	FM(RIF5_D1)		F_(0, 0)		F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define GRP7_0_FUNC	FM(SSI3_SCK)		FM(MSIOF7_SYNC_B)	FM(RIF5_D0)		F_(0, 0)		F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+
+/* Group8 Functions */	/* 0 */			/* 1 */			/* 2 */			/* 3			4	 5	  6	   7	    8	     9	      A	       B	C	 D	  E	   F */
+#define GRP8_31_FUNC	FM(S3DA2)		F_(0, 0)		F_(0, 0)		F_(0, 0)		F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define GRP8_30_FUNC	FM(S3CL2)		F_(0, 0)		F_(0, 0)		F_(0, 0)		F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define GRP8_29_FUNC	FM(S3DA1)		F_(0, 0)		F_(0, 0)		F_(0, 0)		F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define GRP8_28_FUNC	FM(S3CL1)		F_(0, 0)		F_(0, 0)		F_(0, 0)		F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define GRP8_27_FUNC	FM(S3DA0)		F_(0, 0)		F_(0, 0)		F_(0, 0)		F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define GRP8_26_FUNC	FM(S3CL0)		F_(0, 0)		F_(0, 0)		F_(0, 0)		F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define GRP8_15_FUNC	FM(SDA8)		F_(0, 0)		F_(0, 0)		F_(0, 0)		F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define GRP8_14_FUNC	FM(SCL8)		F_(0, 0)		F_(0, 0)		F_(0, 0)		F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define GRP8_13_FUNC	FM(SDA7)		F_(0, 0)		F_(0, 0)		F_(0, 0)		F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define GRP8_12_FUNC	FM(SCL7)		F_(0, 0)		F_(0, 0)		F_(0, 0)		F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define GRP8_11_FUNC	FM(SDA6)		F_(0, 0)		F_(0, 0)		F_(0, 0)		F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define GRP8_10_FUNC	FM(SCL6)		F_(0, 0)		F_(0, 0)		F_(0, 0)		F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define GRP8_9_FUNC	FM(SDA5)		F_(0, 0)		F_(0, 0)		F_(0, 0)		F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define GRP8_8_FUNC	FM(SCL5)		F_(0, 0)		F_(0, 0)		F_(0, 0)		F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define GRP8_7_FUNC	FM(SDA4)		FM(HCTS2_N_A)		FM(CTS4_N_A)		FM(PWM7_B)		F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define GRP8_6_FUNC	FM(SCL4)		FM(HRTS2_N_A)		FM(RTS4_N_A)		FM(PWM9_B)		F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define GRP8_5_FUNC	FM(SDA3)		FM(HRX2_A)		FM(RX4_A)		FM(PWM8_B)		F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define GRP8_4_FUNC	FM(SCL3)		FM(HTX2_A)		FM(TX4_A)		FM(PWM6_B)		F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define GRP8_3_FUNC	FM(SDA2)		FM(HSCK2_A)		FM(SCK4_A)		F_(0, 0)		F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define GRP8_2_FUNC	FM(SCL2)		FM(PWM0_B)		F_(0, 0)		F_(0, 0)		F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define GRP8_1_FUNC	FM(SDA1)		F_(0, 0)		F_(0, 0)		F_(0, 0)		F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define GRP8_0_FUNC	FM(SCL1)		F_(0, 0)		F_(0, 0)		F_(0, 0)		F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+
+/* Group9 Functions */	/* 0 */			/* 1 */			/* 2 */			/* 3			4	 5	  6	   7	    8	     9	      A	       B	C	 D	  E	   F */
+#define GRP9_16_FUNC	FM(RSW3_MATCH)		F_(0, 0)		F_(0, 0)		FM(PWM9_A)		F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define GRP9_15_FUNC	FM(RSW3_CAPTURE)	F_(0, 0)		F_(0, 0)		FM(PWM8_A)		F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define GRP9_14_FUNC	FM(RSW3_PPS)		F_(0, 0)		F_(0, 0)		F_(0, 0)		F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define GRP9_13_FUNC	FM(ETH10G0_PHYINT)	FM(ETH10G1_PHYINT)	F_(0, 0)		F_(0, 0)		F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define GRP9_12_FUNC	FM(ETH10G0_LINK)	FM(ETH10G1_LINK)	F_(0, 0)		FM(PWM7_A)		F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define GRP9_11_FUNC	FM(ETH10G0_MDC)		FM(ETH10G1_MDC)		F_(0, 0)		FM(IRQ3_B)		F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define GRP9_10_FUNC	FM(ETH10G0_MDIO)	FM(ETH10G1_MDIO)	F_(0, 0)		FM(IRQ2_B)		F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define GRP9_9_FUNC	FM(ETH25G0_PHYINT)	FM(ETH25G1_PHYINT)	FM(ETH25G2_PHYINT)	F_(0, 0)		F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define GRP9_8_FUNC	FM(ETH25G0_LINK)	FM(ETH25G1_LINK)	FM(ETH25G2_LINK)	FM(PWM6_A)		F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define GRP9_7_FUNC	FM(ETH25G0_MDC)		FM(ETH25G1_MDC)		FM(ETH25G2_MDC)		F_(0, 0)		F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define GRP9_6_FUNC	FM(ETH25G0_MDIO)	FM(ETH25G1_MDIO)	FM(ETH25G2_MDIO)	F_(0, 0)		F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define GRP9_5_FUNC	FM(ETHES4_MATCH)	FM(ETHES5_MATCH)	FM(ETHES6_MATCH)	FM(ETHES7_MATCH)	F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define GRP9_4_FUNC	FM(ETHES4_CAPTURE)	FM(ETHES5_CAPTURE)	FM(ETHES6_CAPTURE)	FM(ETHES7_CAPTURE)	F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define GRP9_3_FUNC	FM(ETHES4_PPS)		FM(ETHES5_PPS)		FM(ETHES6_PPS)		FM(ETHES7_PPS)		F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define GRP9_2_FUNC	FM(ETHES0_MATCH)	FM(ETHES1_MATCH)	FM(ETHES2_MATCH)	FM(ETHES3_MATCH)	F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define GRP9_1_FUNC	FM(ETHES0_CAPTURE)	FM(ETHES1_CAPTURE)	FM(ETHES2_CAPTURE)	FM(ETHES3_CAPTURE)	F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define GRP9_0_FUNC	FM(ETHES0_PPS)		FM(ETHES1_PPS)		FM(ETHES2_PPS)		FM(ETHES3_PPS)		F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+
+/* Group10 Functions */	/* 0 */			/* 1 */			/* 2 */			/* 3			4	 5	  6	   7	    8	     9	      A	       B	C	 D	  E	   F */
+#define GRP10_13_FUNC	FM(PCIE41_CLKREQ_N)	F_(0, 0)		F_(0, 0)		F_(0, 0)		F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define GRP10_12_FUNC	FM(PCIE40_CLKREQ_N)	F_(0, 0)		F_(0, 0)		F_(0, 0)		F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define GRP10_11_FUNC	FM(USB3_VBUS_VALID)	F_(0, 0)		F_(0, 0)		F_(0, 0)		F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define GRP10_10_FUNC	FM(USB3_OVC)		F_(0, 0)		F_(0, 0)		F_(0, 0)		F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define GRP10_9_FUNC	FM(USB3_PWEN)		F_(0, 0)		F_(0, 0)		F_(0, 0)		F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define GRP10_8_FUNC	FM(USB2_VBUS_VALID)	F_(0, 0)		F_(0, 0)		F_(0, 0)		F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define GRP10_7_FUNC	FM(USB2_OVC)		F_(0, 0)		F_(0, 0)		F_(0, 0)		F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define GRP10_6_FUNC	FM(USB2_PWEN)		F_(0, 0)		F_(0, 0)		F_(0, 0)		F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define GRP10_5_FUNC	FM(USB1_VBUS_VALID)	F_(0, 0)		F_(0, 0)		F_(0, 0)		F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define GRP10_4_FUNC	FM(USB1_OVC)		F_(0, 0)		F_(0, 0)		F_(0, 0)		F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define GRP10_3_FUNC	FM(USB1_PWEN)		F_(0, 0)		F_(0, 0)		F_(0, 0)		F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define GRP10_2_FUNC	FM(USB0_VBUS_VALID)	F_(0, 0)		F_(0, 0)		F_(0, 0)		F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define GRP10_1_FUNC	FM(USB0_OVC)		F_(0, 0)		F_(0, 0)		F_(0, 0)		F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+#define GRP10_0_FUNC	FM(USB0_PWEN)		F_(0, 0)		F_(0, 0)		F_(0, 0)		F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0) F_(0, 0)
+
+#define PINMUX_GPSR	\
+/* GPSR0 */	/* GPSR1 */	/* GPSR2 */	/* GPSR3 */	/* GPSR4 */	/* GPSR5 */	/* GPSR6 */	/* GPSR7 */	/* GPSR8 */	/* GPSR9 */	/* GPSR10 */	\
+																GPSR8_31					\
+												GPSR6_30	GPSR7_30	GPSR8_30					\
+												GPSR6_29	GPSR7_29	GPSR8_29					\
+				GPSR2_28							GPSR6_28	GPSR7_28	GPSR8_28					\
+GPSR0_27			GPSR2_27							GPSR6_27	GPSR7_27	GPSR8_27					\
+GPSR0_26			GPSR2_26							GPSR6_26	GPSR7_26	GPSR8_26					\
+GPSR0_25			GPSR2_25							GPSR6_25	GPSR7_25							\
+GPSR0_24			GPSR2_24							GPSR6_24	GPSR7_24							\
+GPSR0_23			GPSR2_23							GPSR6_23	GPSR7_23							\
+GPSR0_22			GPSR2_22					GPSR5_22	GPSR6_22	GPSR7_22							\
+GPSR0_21	GPSR1_21	GPSR2_21					GPSR5_21	GPSR6_21	GPSR7_21							\
+GPSR0_20	GPSR1_20	GPSR2_20					GPSR5_20	GPSR6_20	GPSR7_20							\
+GPSR0_19	GPSR1_19	GPSR2_19					GPSR5_19	GPSR6_19	GPSR7_19							\
+GPSR0_18	GPSR1_18	GPSR2_18					GPSR5_18	GPSR6_18	GPSR7_18							\
+GPSR0_17	GPSR1_17	GPSR2_17					GPSR5_17	GPSR6_17	GPSR7_17							\
+GPSR0_16	GPSR1_16	GPSR2_16	GPSR3_16			GPSR5_16	GPSR6_16	GPSR7_16			GPSR9_16			\
+GPSR0_15	GPSR1_15	GPSR2_15	GPSR3_15	GPSR4_15	GPSR5_15	GPSR6_15	GPSR7_15	GPSR8_15	GPSR9_15			\
+GPSR0_14	GPSR1_14	GPSR2_14	GPSR3_14	GPSR4_14	GPSR5_14	GPSR6_14	GPSR7_14	GPSR8_14	GPSR9_14			\
+GPSR0_13	GPSR1_13	GPSR2_13	GPSR3_13	GPSR4_13	GPSR5_13	GPSR6_13	GPSR7_13	GPSR8_13	GPSR9_13	GPSR4_13	\
+GPSR0_12	GPSR1_12	GPSR2_12	GPSR3_12	GPSR4_12	GPSR5_12	GPSR6_12	GPSR7_12	GPSR8_12	GPSR9_12	GPSR4_12	\
+GPSR0_11	GPSR1_11	GPSR2_11	GPSR3_11	GPSR4_11	GPSR5_11	GPSR6_11	GPSR7_11	GPSR8_11	GPSR9_11	GPSR4_11	\
+GPSR0_10	GPSR1_10	GPSR2_10	GPSR3_10	GPSR4_10	GPSR5_10	GPSR6_10	GPSR7_10	GPSR8_10	GPSR9_10	GPSR4_10	\
+GPSR0_9		GPSR1_9		GPSR2_9		GPSR3_9		GPSR4_9		GPSR5_9		GPSR6_9		GPSR7_9		GPSR8_9		GPSR9_9		GPSR4_9		\
+GPSR0_8		GPSR1_8		GPSR2_8		GPSR3_8		GPSR4_8		GPSR5_8		GPSR6_8		GPSR7_8		GPSR8_8		GPSR9_8		GPSR4_8		\
+GPSR0_7		GPSR1_7		GPSR2_7		GPSR3_7		GPSR4_7		GPSR5_7		GPSR6_7		GPSR7_7		GPSR8_7		GPSR9_7		GPSR4_7		\
+GPSR0_6		GPSR1_6		GPSR2_6		GPSR3_6		GPSR4_6		GPSR5_6		GPSR6_6		GPSR7_6		GPSR8_6		GPSR9_6		GPSR4_6		\
+GPSR0_5		GPSR1_5		GPSR2_5		GPSR3_5		GPSR4_5		GPSR5_5		GPSR6_5		GPSR7_5		GPSR8_5		GPSR9_5		GPSR4_5		\
+GPSR0_4		GPSR1_4		GPSR2_4		GPSR3_4		GPSR4_4		GPSR5_4		GPSR6_4		GPSR7_4		GPSR8_4		GPSR9_4		GPSR4_4		\
+GPSR0_3		GPSR1_3		GPSR2_3		GPSR3_3		GPSR4_3		GPSR5_3		GPSR6_3		GPSR7_3		GPSR8_3		GPSR9_3		GPSR4_3		\
+GPSR0_2		GPSR1_2		GPSR2_2		GPSR3_2		GPSR4_2		GPSR5_2		GPSR6_2		GPSR7_2		GPSR8_2		GPSR9_2		GPSR4_2		\
+GPSR0_1		GPSR1_1		GPSR2_1		GPSR3_1		GPSR4_1		GPSR5_1		GPSR6_1		GPSR7_1		GPSR8_1		GPSR9_1		GPSR4_1		\
+GPSR0_0		GPSR1_0		GPSR2_0		GPSR3_0		GPSR4_0		GPSR5_0		GPSR6_0		GPSR7_0		GPSR8_0		GPSR9_0		GPSR4_0
+
+/* GRP0_FUNC */
+#define GRP0_FUNC 			\
+FM(GRP0_27_FUNC)	GRP0_27_FUNC	\
+FM(GRP0_26_FUNC)	GRP0_26_FUNC	\
+FM(GRP0_25_FUNC)	GRP0_25_FUNC	\
+FM(GRP0_24_FUNC)	GRP0_24_FUNC	\
+FM(GRP0_23_FUNC)	GRP0_23_FUNC	\
+FM(GRP0_22_FUNC)	GRP0_22_FUNC	\
+FM(GRP0_21_FUNC)	GRP0_21_FUNC	\
+FM(GRP0_20_FUNC)	GRP0_20_FUNC	\
+FM(GRP0_19_FUNC)	GRP0_19_FUNC	\
+FM(GRP0_18_FUNC)	GRP0_18_FUNC	\
+FM(GRP0_17_FUNC)	GRP0_17_FUNC	\
+FM(GRP0_16_FUNC)	GRP0_16_FUNC	\
+FM(GRP0_15_FUNC)	GRP0_15_FUNC	\
+FM(GRP0_14_FUNC)	GRP0_14_FUNC	\
+FM(GRP0_13_FUNC)	GRP0_13_FUNC	\
+FM(GRP0_12_FUNC)	GRP0_12_FUNC	\
+FM(GRP0_11_FUNC)	GRP0_11_FUNC	\
+FM(GRP0_10_FUNC)	GRP0_10_FUNC	\
+FM(GRP0_9_FUNC)		GRP0_9_FUNC	\
+FM(GRP0_8_FUNC)		GRP0_8_FUNC	\
+FM(GRP0_7_FUNC)		GRP0_7_FUNC	\
+FM(GRP0_6_FUNC)		GRP0_6_FUNC	\
+FM(GRP0_5_FUNC)		GRP0_5_FUNC	\
+FM(GRP0_4_FUNC)		GRP0_4_FUNC	\
+FM(GRP0_3_FUNC)		GRP0_3_FUNC	\
+FM(GRP0_2_FUNC)		GRP0_2_FUNC	\
+FM(GRP0_1_FUNC)		GRP0_1_FUNC	\
+FM(GRP0_0_FUNC)		GRP0_0_FUNC
+
+/* GRP1_FUNC */
+#define GRP1_FUNC 			\
+FM(GRP1_21_FUNC)	GRP1_21_FUNC	\
+FM(GRP1_20_FUNC)	GRP1_20_FUNC	\
+FM(GRP1_19_FUNC)	GRP1_19_FUNC	\
+FM(GRP1_18_FUNC)	GRP1_18_FUNC	\
+FM(GRP1_17_FUNC)	GRP1_17_FUNC	\
+FM(GRP1_16_FUNC)	GRP1_16_FUNC	\
+FM(GRP1_15_FUNC)	GRP1_15_FUNC	\
+FM(GRP1_14_FUNC)	GRP1_14_FUNC	\
+FM(GRP1_13_FUNC)	GRP1_13_FUNC	\
+FM(GRP1_12_FUNC)	GRP1_12_FUNC	\
+FM(GRP1_11_FUNC)	GRP1_11_FUNC	\
+FM(GRP1_10_FUNC)	GRP1_10_FUNC	\
+FM(GRP1_9_FUNC)		GRP1_9_FUNC	\
+FM(GRP1_8_FUNC)		GRP1_8_FUNC	\
+FM(GRP1_7_FUNC)		GRP1_7_FUNC	\
+FM(GRP1_6_FUNC)		GRP1_6_FUNC	\
+FM(GRP1_5_FUNC)		GRP1_5_FUNC	\
+FM(GRP1_4_FUNC)		GRP1_4_FUNC	\
+FM(GRP1_3_FUNC)		GRP1_3_FUNC	\
+FM(GRP1_2_FUNC)		GRP1_2_FUNC	\
+FM(GRP1_1_FUNC)		GRP1_1_FUNC	\
+FM(GRP1_0_FUNC)		GRP1_0_FUNC
+
+/* GRP2_FUNC */
+#define GRP2_FUNC 			\
+FM(GRP2_28_FUNC)	GRP2_28_FUNC	\
+FM(GRP2_27_FUNC)	GRP2_27_FUNC	\
+FM(GRP2_26_FUNC)	GRP2_26_FUNC	\
+FM(GRP2_25_FUNC)	GRP2_25_FUNC	\
+FM(GRP2_24_FUNC)	GRP2_24_FUNC	\
+FM(GRP2_23_FUNC)	GRP2_23_FUNC	\
+FM(GRP2_22_FUNC)	GRP2_22_FUNC	\
+FM(GRP2_21_FUNC)	GRP2_21_FUNC	\
+FM(GRP2_20_FUNC)	GRP2_20_FUNC	\
+FM(GRP2_19_FUNC)	GRP2_19_FUNC	\
+FM(GRP2_18_FUNC)	GRP2_18_FUNC	\
+FM(GRP2_17_FUNC)	GRP2_17_FUNC	\
+FM(GRP2_16_FUNC)	GRP2_16_FUNC	\
+FM(GRP2_15_FUNC)	GRP2_15_FUNC	\
+FM(GRP2_14_FUNC)	GRP2_14_FUNC	\
+FM(GRP2_13_FUNC)	GRP2_13_FUNC	\
+FM(GRP2_12_FUNC)	GRP2_12_FUNC	\
+FM(GRP2_11_FUNC)	GRP2_11_FUNC	\
+FM(GRP2_10_FUNC)	GRP2_10_FUNC	\
+FM(GRP2_9_FUNC)		GRP2_9_FUNC	\
+FM(GRP2_8_FUNC)		GRP2_8_FUNC	\
+FM(GRP2_7_FUNC)		GRP2_7_FUNC	\
+FM(GRP2_6_FUNC)		GRP2_6_FUNC	\
+FM(GRP2_5_FUNC)		GRP2_5_FUNC	\
+FM(GRP2_4_FUNC)		GRP2_4_FUNC	\
+FM(GRP2_3_FUNC)		GRP2_3_FUNC	\
+FM(GRP2_2_FUNC)		GRP2_2_FUNC	\
+FM(GRP2_1_FUNC)		GRP2_1_FUNC	\
+FM(GRP2_0_FUNC)		GRP2_0_FUNC
+
+/* GRP3_FUNC */
+#define GRP3_FUNC 			\
+FM(GRP3_16_FUNC)	GRP3_16_FUNC	\
+FM(GRP3_15_FUNC)	GRP3_15_FUNC	\
+FM(GRP3_14_FUNC)	GRP3_14_FUNC	\
+FM(GRP3_13_FUNC)	GRP3_13_FUNC	\
+FM(GRP3_12_FUNC)	GRP3_12_FUNC	\
+FM(GRP3_11_FUNC)	GRP3_11_FUNC	\
+FM(GRP3_10_FUNC)	GRP3_10_FUNC	\
+FM(GRP3_9_FUNC)		GRP3_9_FUNC	\
+FM(GRP3_8_FUNC)		GRP3_8_FUNC	\
+FM(GRP3_7_FUNC)		GRP3_7_FUNC	\
+FM(GRP3_6_FUNC)		GRP3_6_FUNC	\
+FM(GRP3_5_FUNC)		GRP3_5_FUNC	\
+FM(GRP3_4_FUNC)		GRP3_4_FUNC	\
+FM(GRP3_3_FUNC)		GRP3_3_FUNC	\
+FM(GRP3_2_FUNC)		GRP3_2_FUNC	\
+FM(GRP3_1_FUNC)		GRP3_1_FUNC	\
+FM(GRP3_0_FUNC)		GRP3_0_FUNC
+
+/* GRP4_FUNC */
+#define GRP4_FUNC 			\
+FM(GRP4_15_FUNC)	GRP4_15_FUNC	\
+FM(GRP4_14_FUNC)	GRP4_14_FUNC	\
+FM(GRP4_13_FUNC)	GRP4_13_FUNC	\
+FM(GRP4_12_FUNC)	GRP4_12_FUNC	\
+FM(GRP4_11_FUNC)	GRP4_11_FUNC	\
+FM(GRP4_10_FUNC)	GRP4_10_FUNC	\
+FM(GRP4_9_FUNC)		GRP4_9_FUNC	\
+FM(GRP4_8_FUNC)		GRP4_8_FUNC	\
+FM(GRP4_7_FUNC)		GRP4_7_FUNC	\
+FM(GRP4_6_FUNC)		GRP4_6_FUNC	\
+FM(GRP4_5_FUNC)		GRP4_5_FUNC	\
+FM(GRP4_4_FUNC)		GRP4_4_FUNC	\
+FM(GRP4_3_FUNC)		GRP4_3_FUNC	\
+FM(GRP4_2_FUNC)		GRP4_2_FUNC	\
+FM(GRP4_1_FUNC)		GRP4_1_FUNC	\
+FM(GRP4_0_FUNC)		GRP4_0_FUNC
+
+/* GRP5_FUNC */
+#define GRP5_FUNC 			\
+FM(GRP5_22_FUNC)	GRP5_22_FUNC	\
+FM(GRP5_21_FUNC)	GRP5_21_FUNC	\
+FM(GRP5_20_FUNC)	GRP5_20_FUNC	\
+FM(GRP5_19_FUNC)	GRP5_19_FUNC	\
+FM(GRP5_18_FUNC)	GRP5_18_FUNC	\
+FM(GRP5_17_FUNC)	GRP5_17_FUNC	\
+FM(GRP5_16_FUNC)	GRP5_16_FUNC	\
+FM(GRP5_15_FUNC)	GRP5_15_FUNC	\
+FM(GRP5_14_FUNC)	GRP5_14_FUNC	\
+FM(GRP5_13_FUNC)	GRP5_13_FUNC	\
+FM(GRP5_12_FUNC)	GRP5_12_FUNC	\
+FM(GRP5_11_FUNC)	GRP5_11_FUNC	\
+FM(GRP5_10_FUNC)	GRP5_10_FUNC	\
+FM(GRP5_9_FUNC)		GRP5_9_FUNC	\
+FM(GRP5_8_FUNC)		GRP5_8_FUNC	\
+FM(GRP5_7_FUNC)		GRP5_7_FUNC	\
+FM(GRP5_6_FUNC)		GRP5_6_FUNC	\
+FM(GRP5_5_FUNC)		GRP5_5_FUNC	\
+FM(GRP5_4_FUNC)		GRP5_4_FUNC	\
+FM(GRP5_3_FUNC)		GRP5_3_FUNC	\
+FM(GRP5_2_FUNC)		GRP5_2_FUNC	\
+FM(GRP5_1_FUNC)		GRP5_1_FUNC	\
+FM(GRP5_0_FUNC)		GRP5_0_FUNC
+
+/* GRP6_FUNC */
+#define GRP6_FUNC 			\
+FM(GRP6_30_FUNC)	GRP6_30_FUNC	\
+FM(GRP6_29_FUNC)	GRP6_29_FUNC	\
+FM(GRP6_28_FUNC)	GRP6_28_FUNC	\
+FM(GRP6_27_FUNC)	GRP6_27_FUNC	\
+FM(GRP6_26_FUNC)	GRP6_26_FUNC	\
+FM(GRP6_25_FUNC)	GRP6_25_FUNC	\
+FM(GRP6_24_FUNC)	GRP6_24_FUNC	\
+FM(GRP6_23_FUNC)	GRP6_23_FUNC	\
+FM(GRP6_22_FUNC)	GRP6_22_FUNC	\
+FM(GRP6_21_FUNC)	GRP6_21_FUNC	\
+FM(GRP6_20_FUNC)	GRP6_20_FUNC	\
+FM(GRP6_19_FUNC)	GRP6_19_FUNC	\
+FM(GRP6_18_FUNC)	GRP6_18_FUNC	\
+FM(GRP6_17_FUNC)	GRP6_17_FUNC	\
+FM(GRP6_16_FUNC)	GRP6_16_FUNC	\
+FM(GRP6_15_FUNC)	GRP6_15_FUNC	\
+FM(GRP6_14_FUNC)	GRP6_14_FUNC	\
+FM(GRP6_13_FUNC)	GRP6_13_FUNC	\
+FM(GRP6_12_FUNC)	GRP6_12_FUNC	\
+FM(GRP6_11_FUNC)	GRP6_11_FUNC	\
+FM(GRP6_10_FUNC)	GRP6_10_FUNC	\
+FM(GRP6_9_FUNC)		GRP6_9_FUNC	\
+FM(GRP6_8_FUNC)		GRP6_8_FUNC	\
+FM(GRP6_7_FUNC)		GRP6_7_FUNC	\
+FM(GRP6_6_FUNC)		GRP6_6_FUNC	\
+FM(GRP6_5_FUNC)		GRP6_5_FUNC	\
+FM(GRP6_4_FUNC)		GRP6_4_FUNC	\
+FM(GRP6_3_FUNC)		GRP6_3_FUNC	\
+FM(GRP6_2_FUNC)		GRP6_2_FUNC	\
+FM(GRP6_1_FUNC)		GRP6_1_FUNC	\
+FM(GRP6_0_FUNC)		GRP6_0_FUNC
+
+/* GRP7_FUNC */
+#define GRP7_FUNC 			\
+FM(GRP7_30_FUNC)	GRP7_30_FUNC	\
+FM(GRP7_29_FUNC)	GRP7_29_FUNC	\
+FM(GRP7_28_FUNC)	GRP7_28_FUNC	\
+FM(GRP7_27_FUNC)	GRP7_27_FUNC	\
+FM(GRP7_26_FUNC)	GRP7_26_FUNC	\
+FM(GRP7_25_FUNC)	GRP7_25_FUNC	\
+FM(GRP7_24_FUNC)	GRP7_24_FUNC	\
+FM(GRP7_23_FUNC)	GRP7_23_FUNC	\
+FM(GRP7_22_FUNC)	GRP7_22_FUNC	\
+FM(GRP7_21_FUNC)	GRP7_21_FUNC	\
+FM(GRP7_20_FUNC)	GRP7_20_FUNC	\
+FM(GRP7_19_FUNC)	GRP7_19_FUNC	\
+FM(GRP7_18_FUNC)	GRP7_18_FUNC	\
+FM(GRP7_17_FUNC)	GRP7_17_FUNC	\
+FM(GRP7_16_FUNC)	GRP7_16_FUNC	\
+FM(GRP7_15_FUNC)	GRP7_15_FUNC	\
+FM(GRP7_14_FUNC)	GRP7_14_FUNC	\
+FM(GRP7_13_FUNC)	GRP7_13_FUNC	\
+FM(GRP7_12_FUNC)	GRP7_12_FUNC	\
+FM(GRP7_11_FUNC)	GRP7_11_FUNC	\
+FM(GRP7_10_FUNC)	GRP7_10_FUNC	\
+FM(GRP7_9_FUNC)		GRP7_9_FUNC	\
+FM(GRP7_8_FUNC)		GRP7_8_FUNC	\
+FM(GRP7_7_FUNC)		GRP7_7_FUNC	\
+FM(GRP7_6_FUNC)		GRP7_6_FUNC	\
+FM(GRP7_5_FUNC)		GRP7_5_FUNC	\
+FM(GRP7_4_FUNC)		GRP7_4_FUNC	\
+FM(GRP7_3_FUNC)		GRP7_3_FUNC	\
+FM(GRP7_2_FUNC)		GRP7_2_FUNC	\
+FM(GRP7_1_FUNC)		GRP7_1_FUNC	\
+FM(GRP7_0_FUNC)		GRP7_0_FUNC
+
+/* GRP8_FUNC */
+#define GRP8_FUNC 			\
+FM(GRP8_31_FUNC)	GRP8_31_FUNC	\
+FM(GRP8_30_FUNC)	GRP8_30_FUNC	\
+FM(GRP8_29_FUNC)	GRP8_29_FUNC	\
+FM(GRP8_28_FUNC)	GRP8_28_FUNC	\
+FM(GRP8_27_FUNC)	GRP8_27_FUNC	\
+FM(GRP8_26_FUNC)	GRP8_26_FUNC	\
+FM(GRP8_15_FUNC)	GRP8_15_FUNC	\
+FM(GRP8_14_FUNC)	GRP8_14_FUNC	\
+FM(GRP8_13_FUNC)	GRP8_13_FUNC	\
+FM(GRP8_12_FUNC)	GRP8_12_FUNC	\
+FM(GRP8_11_FUNC)	GRP8_11_FUNC	\
+FM(GRP8_10_FUNC)	GRP8_10_FUNC	\
+FM(GRP8_9_FUNC)		GRP8_9_FUNC	\
+FM(GRP8_8_FUNC)		GRP8_8_FUNC	\
+FM(GRP8_7_FUNC)		GRP8_7_FUNC	\
+FM(GRP8_6_FUNC)		GRP8_6_FUNC	\
+FM(GRP8_5_FUNC)		GRP8_5_FUNC	\
+FM(GRP8_4_FUNC)		GRP8_4_FUNC	\
+FM(GRP8_3_FUNC)		GRP8_3_FUNC	\
+FM(GRP8_2_FUNC)		GRP8_2_FUNC	\
+FM(GRP8_1_FUNC)		GRP8_1_FUNC	\
+FM(GRP8_0_FUNC)		GRP8_0_FUNC
+
+/* GRP9_FUNC */
+#define GRP9_FUNC 			\
+FM(GRP9_16_FUNC)	GRP9_16_FUNC	\
+FM(GRP9_15_FUNC)	GRP9_15_FUNC	\
+FM(GRP9_14_FUNC)	GRP9_14_FUNC	\
+FM(GRP9_13_FUNC)	GRP9_13_FUNC	\
+FM(GRP9_12_FUNC)	GRP9_12_FUNC	\
+FM(GRP9_11_FUNC)	GRP9_11_FUNC	\
+FM(GRP9_10_FUNC)	GRP9_10_FUNC	\
+FM(GRP9_9_FUNC)		GRP9_9_FUNC	\
+FM(GRP9_8_FUNC)		GRP9_8_FUNC	\
+FM(GRP9_7_FUNC)		GRP9_7_FUNC	\
+FM(GRP9_6_FUNC)		GRP9_6_FUNC	\
+FM(GRP9_5_FUNC)		GRP9_5_FUNC	\
+FM(GRP9_4_FUNC)		GRP9_4_FUNC	\
+FM(GRP9_3_FUNC)		GRP9_3_FUNC	\
+FM(GRP9_2_FUNC)		GRP9_2_FUNC	\
+FM(GRP9_1_FUNC)		GRP9_1_FUNC	\
+FM(GRP9_0_FUNC)		GRP9_0_FUNC
+
+/* GRP10_FUNC */
+#define GRP10_FUNC 			\
+FM(GRP10_13_FUNC)	GRP10_13_FUNC	\
+FM(GRP10_12_FUNC)	GRP10_12_FUNC	\
+FM(GRP10_11_FUNC)	GRP10_11_FUNC	\
+FM(GRP10_10_FUNC)	GRP10_10_FUNC	\
+FM(GRP10_9_FUNC)	GRP10_9_FUNC	\
+FM(GRP10_8_FUNC)	GRP10_8_FUNC	\
+FM(GRP10_7_FUNC)	GRP10_7_FUNC	\
+FM(GRP10_6_FUNC)	GRP10_6_FUNC	\
+FM(GRP10_5_FUNC)	GRP10_5_FUNC	\
+FM(GRP10_4_FUNC)	GRP10_4_FUNC	\
+FM(GRP10_3_FUNC)	GRP10_3_FUNC	\
+FM(GRP10_2_FUNC)	GRP10_2_FUNC	\
+FM(GRP10_1_FUNC)	GRP10_1_FUNC	\
+FM(GRP10_0_FUNC)	GRP10_0_FUNC
+
+/* Mux all groups functions */
+#define PINMUX_GRP_FUNC		\
+GRP0_FUNC			\
+GRP1_FUNC			\
+GRP2_FUNC			\
+GRP3_FUNC			\
+GRP4_FUNC			\
+GRP5_FUNC			\
+GRP6_FUNC			\
+GRP7_FUNC			\
+GRP8_FUNC			\
+GRP9_FUNC			\
+GRP10_FUNC
+
+#define GP_ALTSEL(id, bank, pin)	\
+GP##bank##_ALTSEL##id##_##pin##_0,	\
+GP##bank##_ALTSEL##id##_##pin##_1,
+
+#define GP_ALTSEL_TYPE(id, bank)	\
+	GP_ALTSEL(id, bank, 31)		\
+	GP_ALTSEL(id, bank, 30)		\
+	GP_ALTSEL(id, bank, 29)		\
+	GP_ALTSEL(id, bank, 28)		\
+	GP_ALTSEL(id, bank, 27)		\
+	GP_ALTSEL(id, bank, 26)		\
+	GP_ALTSEL(id, bank, 25)		\
+	GP_ALTSEL(id, bank, 24)		\
+	GP_ALTSEL(id, bank, 23)		\
+	GP_ALTSEL(id, bank, 22)		\
+	GP_ALTSEL(id, bank, 21)		\
+	GP_ALTSEL(id, bank, 20)		\
+	GP_ALTSEL(id, bank, 19)		\
+	GP_ALTSEL(id, bank, 18)		\
+	GP_ALTSEL(id, bank, 17)		\
+	GP_ALTSEL(id, bank, 16)		\
+	GP_ALTSEL(id, bank, 15)		\
+	GP_ALTSEL(id, bank, 14)		\
+	GP_ALTSEL(id, bank, 13)		\
+	GP_ALTSEL(id, bank, 12)		\
+	GP_ALTSEL(id, bank, 11)		\
+	GP_ALTSEL(id, bank, 10)		\
+	GP_ALTSEL(id, bank,  9)		\
+	GP_ALTSEL(id, bank,  8)		\
+	GP_ALTSEL(id, bank,  7)		\
+	GP_ALTSEL(id, bank,  6)		\
+	GP_ALTSEL(id, bank,  5)		\
+	GP_ALTSEL(id, bank,  4)		\
+	GP_ALTSEL(id, bank,  3)		\
+	GP_ALTSEL(id, bank,  2)		\
+	GP_ALTSEL(id, bank,  1)		\
+	GP_ALTSEL(id, bank,  0)
+
+#define GP_ALTSEL0(bank)	GP_ALTSEL_TYPE(0, bank)
+#define GP_ALTSEL1(bank)	GP_ALTSEL_TYPE(1, bank)
+#define GP_ALTSEL2(bank)	GP_ALTSEL_TYPE(2, bank)
+#define GP_ALTSEL3(bank)	GP_ALTSEL_TYPE(3, bank)
+
+#define PINMUX_ALTSEL	\
+GP_ALTSEL0(0)	GP_ALTSEL0(1)	GP_ALTSEL0(2)	GP_ALTSEL0(3)	GP_ALTSEL0(4)	GP_ALTSEL0(5)	GP_ALTSEL0(6)	GP_ALTSEL0(7)	GP_ALTSEL0(8)	GP_ALTSEL0(9)	GP_ALTSEL0(10)	\
+GP_ALTSEL1(0)	GP_ALTSEL1(1)	GP_ALTSEL1(2)	GP_ALTSEL1(3)	GP_ALTSEL1(4)	GP_ALTSEL1(5)	GP_ALTSEL1(6)	GP_ALTSEL1(7)	GP_ALTSEL1(8)	GP_ALTSEL1(9)	GP_ALTSEL1(10)	\
+GP_ALTSEL2(0)	GP_ALTSEL2(1)	GP_ALTSEL2(2)	GP_ALTSEL2(3)	GP_ALTSEL2(4)	GP_ALTSEL2(5)	GP_ALTSEL2(6)	GP_ALTSEL2(7)	GP_ALTSEL2(8)	GP_ALTSEL2(9)	GP_ALTSEL2(10)	\
+GP_ALTSEL3(0)	GP_ALTSEL3(1)	GP_ALTSEL3(2)	GP_ALTSEL3(3)	GP_ALTSEL3(4)	GP_ALTSEL3(5)	GP_ALTSEL3(6)	GP_ALTSEL3(7)	GP_ALTSEL3(8)	GP_ALTSEL3(9)	GP_ALTSEL3(10)
+
+/* GP1_MODSEL */		/* 0 */			/* 1 */
+#define GP1_MODSEL_21		FM(SEL_TAUJ13_OUTPUT)	FM(SEL_TAUJ13_INPUT)
+#define GP1_MODSEL_20		FM(SEL_TAUJ12_OUTPUT)	FM(SEL_TAUJ12_INPUT)
+#define GP1_MODSEL_19		FM(SEL_TAUJ11_OUTPUT)	FM(SEL_TAUJ11_INPUT)
+#define GP1_MODSEL_18		FM(SEL_TAUJ10_OUTPUT)	FM(SEL_TAUJ10_INPUT)
+#define GP1_MODSEL_17		FM(SEL_TAUJ33_OUTPUT)	FM(SEL_TAUJ33_INPUT)
+#define GP1_MODSEL_16		FM(SEL_TAUJ32_OUTPUT)	FM(SEL_TAUJ32_INPUT)
+#define GP1_MODSEL_15		FM(SEL_TAUJ31_OUTPUT)	FM(SEL_TAUJ31_INPUT)
+#define GP1_MODSEL_14		FM(SEL_TAUJ30_OUTPUT)	FM(SEL_TAUJ30_INPUT)
+
+#define GP1_MODSEL	\
+GP1_MODSEL_21		\
+GP1_MODSEL_20		\
+GP1_MODSEL_19		\
+GP1_MODSEL_18		\
+GP1_MODSEL_17		\
+GP1_MODSEL_16		\
+GP1_MODSEL_15		\
+GP1_MODSEL_14
+
+/* GP2_MODSEL */		/* 0 */		/* 1 */
+#define GP2_MODSEL_20		FM(SEL_SDA0_0)	FM(SEL_SDA0_1)
+#define GP2_MODSEL_19		FM(SEL_SCL0_0)	FM(SEL_SCL0_1)
+
+#define GP2_MODSEL	\
+GP2_MODSEL_20		\
+GP2_MODSEL_19
+
+/* GP8_MODSEL */		/* 0 */		/* 1 */
+#define GP8_MODSEL_15		FM(SEL_SDA8_0)	FM(SEL_SDA8_1)
+#define GP8_MODSEL_14		FM(SEL_SCL8_0)	FM(SEL_SCL8_1)
+#define GP8_MODSEL_13		FM(SEL_SDA7_0)	FM(SEL_SDA7_1)
+#define GP8_MODSEL_12		FM(SEL_SCL7_0)	FM(SEL_SCL7_1)
+#define GP8_MODSEL_11		FM(SEL_SDA6_0)	FM(SEL_SDA6_1)
+#define GP8_MODSEL_10		FM(SEL_SCL6_0)	FM(SEL_SCL6_1)
+#define GP8_MODSEL_9		FM(SEL_SDA5_0)	FM(SEL_SDA5_1)
+#define GP8_MODSEL_8		FM(SEL_SCL5_0)	FM(SEL_SCL5_1)
+#define GP8_MODSEL_7		FM(SEL_SDA4_0)	FM(SEL_SDA4_1)
+#define GP8_MODSEL_6		FM(SEL_SCL4_0)	FM(SEL_SCL4_1)
+#define GP8_MODSEL_5		FM(SEL_SDA3_0)	FM(SEL_SDA3_1)
+#define GP8_MODSEL_4		FM(SEL_SCL3_0)	FM(SEL_SCL3_1)
+#define GP8_MODSEL_3		FM(SEL_SDA2_0)	FM(SEL_SDA2_1)
+#define GP8_MODSEL_2		FM(SEL_SCL2_0)	FM(SEL_SCL2_1)
+#define GP8_MODSEL_1		FM(SEL_SDA1_0)	FM(SEL_SDA1_1)
+#define GP8_MODSEL_0		FM(SEL_SCL1_0)	FM(SEL_SCL1_1)
+
+#define GP8_MODSEL	\
+GP8_MODSEL_15	\
+GP8_MODSEL_14	\
+GP8_MODSEL_13	\
+GP8_MODSEL_12	\
+GP8_MODSEL_11	\
+GP8_MODSEL_10	\
+GP8_MODSEL_9	\
+GP8_MODSEL_8	\
+GP8_MODSEL_7	\
+GP8_MODSEL_6	\
+GP8_MODSEL_5	\
+GP8_MODSEL_4	\
+GP8_MODSEL_3	\
+GP8_MODSEL_2	\
+GP8_MODSEL_1	\
+GP8_MODSEL_0
+
+#define PINMUX_MODSELS	\
+GP8_MODSEL		\
+GP2_MODSEL		\
+GP1_MODSEL
+
+enum {
+	PINMUX_RESERVED = 0,
+
+	PINMUX_DATA_BEGIN,
+	GP_ALL(DATA),
+	PINMUX_DATA_END,
+
+#define F_(x, y)
+#define FM(x)	FN_##x,
+	PINMUX_FUNCTION_BEGIN,
+	GP_ALL(FN),
+	PINMUX_GPSR
+	PINMUX_GRP_FUNC
+	PINMUX_ALTSEL
+	PINMUX_MODSELS
+	PINMUX_FUNCTION_END,
+#undef F_
+#undef FM
+
+#define F_(x, y)
+#define FM(x)	x##_MARK,
+	PINMUX_MARK_BEGIN,
+	PINMUX_GPSR
+	PINMUX_GRP_FUNC
+	PINMUX_MODSELS
+	PINMUX_MARK_END,
+#undef F_
+#undef FM
+};
+
+#define GP_ALTSEL_FUNC_0(bank, pin)		\
+	GP##bank##_ALTSEL0_##pin##_0,		\
+	GP##bank##_ALTSEL1_##pin##_0,		\
+	GP##bank##_ALTSEL2_##pin##_0,		\
+	GP##bank##_ALTSEL3_##pin##_0
+
+#define GP_ALTSEL_FUNC_1(bank, pin)		\
+	GP##bank##_ALTSEL0_##pin##_1,		\
+	GP##bank##_ALTSEL1_##pin##_0,		\
+	GP##bank##_ALTSEL2_##pin##_0,		\
+	GP##bank##_ALTSEL3_##pin##_0
+
+#define GP_ALTSEL_FUNC_2(bank, pin)		\
+	GP##bank##_ALTSEL0_##pin##_0,		\
+	GP##bank##_ALTSEL1_##pin##_1,		\
+	GP##bank##_ALTSEL2_##pin##_0,		\
+	GP##bank##_ALTSEL3_##pin##_0
+
+#define GP_ALTSEL_FUNC_3(bank, pin)		\
+	GP##bank##_ALTSEL0_##pin##_1,		\
+	GP##bank##_ALTSEL1_##pin##_1,		\
+	GP##bank##_ALTSEL2_##pin##_0,		\
+	GP##bank##_ALTSEL3_##pin##_0
+
+#define GP_ALTSEL_FUNC_4(bank, pin)		\
+	GP##bank##_ALTSEL0_##pin##_0,		\
+	GP##bank##_ALTSEL1_##pin##_0,		\
+	GP##bank##_ALTSEL2_##pin##_1,		\
+	GP##bank##_ALTSEL3_##pin##_0
+
+#define GP_ALTSEL_FUNC_5(bank, pin)		\
+	GP##bank##_ALTSEL0_##pin##_1,		\
+	GP##bank##_ALTSEL1_##pin##_0,		\
+	GP##bank##_ALTSEL2_##pin##_1,		\
+	GP##bank##_ALTSEL3_##pin##_0
+
+#define GP_ALTSEL_FUNC_6(bank, pin)		\
+	GP##bank##_ALTSEL0_##pin##_0,		\
+	GP##bank##_ALTSEL1_##pin##_1,		\
+	GP##bank##_ALTSEL2_##pin##_1,		\
+	GP##bank##_ALTSEL3_##pin##_0
+
+#define GP_ALTSEL_FUNC_7(bank, pin)		\
+	GP##bank##_ALTSEL0_##pin##_1,		\
+	GP##bank##_ALTSEL1_##pin##_1,		\
+	GP##bank##_ALTSEL2_##pin##_1,		\
+	GP##bank##_ALTSEL3_##pin##_0
+
+#define GP_ALTSEL_FUNC_8(bank, pin)		\
+	GP##bank##_ALTSEL0_##pin##_0,		\
+	GP##bank##_ALTSEL1_##pin##_0,		\
+	GP##bank##_ALTSEL2_##pin##_0,		\
+	GP##bank##_ALTSEL3_##pin##_1
+
+#define GP_ALTSEL_FUNC_9(bank, pin)		\
+	GP##bank##_ALTSEL0_##pin##_1,		\
+	GP##bank##_ALTSEL1_##pin##_0,		\
+	GP##bank##_ALTSEL2_##pin##_0,		\
+	GP##bank##_ALTSEL3_##pin##_1
+
+#define GP_ALTSEL_FUNC_10(bank, pin)		\
+	GP##bank##_ALTSEL0_##pin##_0,		\
+	GP##bank##_ALTSEL1_##pin##_1,		\
+	GP##bank##_ALTSEL2_##pin##_0,		\
+	GP##bank##_ALTSEL3_##pin##_1
+
+#define GP_ALTSEL_FUNC_11(bank, pin)		\
+	GP##bank##_ALTSEL0_##pin##_1,		\
+	GP##bank##_ALTSEL1_##pin##_1,		\
+	GP##bank##_ALTSEL2_##pin##_0,		\
+	GP##bank##_ALTSEL3_##pin##_1
+
+#define GP_ALTSEL_FUNC_12(bank, pin)		\
+	GP##bank##_ALTSEL0_##pin##_0,		\
+	GP##bank##_ALTSEL1_##pin##_0,		\
+	GP##bank##_ALTSEL2_##pin##_1,		\
+	GP##bank##_ALTSEL3_##pin##_1
+
+#define GP_ALTSEL_FUNC_13(bank, pin)		\
+	GP##bank##_ALTSEL0_##pin##_1,		\
+	GP##bank##_ALTSEL1_##pin##_0,		\
+	GP##bank##_ALTSEL2_##pin##_1,		\
+	GP##bank##_ALTSEL3_##pin##_1
+
+#define GP_ALTSEL_FUNC_14(bank, pin)		\
+	GP##bank##_ALTSEL0_##pin##_0,		\
+	GP##bank##_ALTSEL1_##pin##_1,		\
+	GP##bank##_ALTSEL2_##pin##_1,		\
+	GP##bank##_ALTSEL3_##pin##_1
+
+#define GP_ALTSEL_FUNC_15(bank, pin)		\
+	GP##bank##_ALTSEL0_##pin##_1,		\
+	GP##bank##_ALTSEL1_##pin##_1,		\
+	GP##bank##_ALTSEL2_##pin##_1,		\
+	GP##bank##_ALTSEL3_##pin##_1
+
+#define GP_ALTSEL_FUNC(bank, pin, func)		\
+	GP_ALTSEL_FUNC_##func(bank, pin)
+
+/* GP0 ALTSEL function 0 */
+#define ALT_DP2_HOTPLUG		GP_ALTSEL_FUNC(0, 27, 0)
+#define ALT_DP1_HOTPLUG		GP_ALTSEL_FUNC(0, 26, 0)
+#define ALT_DP0_HOTPLUG		GP_ALTSEL_FUNC(0, 25, 0)
+#define ALT_MSIOF1_SS2_A	GP_ALTSEL_FUNC(0, 24, 0)
+#define ALT_MSIOF1_SS1_A	GP_ALTSEL_FUNC(0, 23, 0)
+#define ALT_MSIOF1_SYNC_A	GP_ALTSEL_FUNC(0, 22, 0)
+#define ALT_MSIOF1_RXD_A	GP_ALTSEL_FUNC(0, 21, 0)
+#define ALT_MSIOF1_TXD_A	GP_ALTSEL_FUNC(0, 20, 0)
+#define ALT_MSIOF1_SCK_A	GP_ALTSEL_FUNC(0, 19, 0)
+#define ALT_MSIOF0_SS2		GP_ALTSEL_FUNC(0, 18, 0)
+#define ALT_MSIOF0_SS1		GP_ALTSEL_FUNC(0, 17, 0)
+#define ALT_MSIOF0_SYNC		GP_ALTSEL_FUNC(0, 16, 0)
+#define ALT_MSIOF0_RXD		GP_ALTSEL_FUNC(0, 15, 0)
+#define ALT_MSIOF0_TXD		GP_ALTSEL_FUNC(0, 14, 0)
+#define ALT_MSIOF0_SCK		GP_ALTSEL_FUNC(0, 13, 0)
+#define ALT_RXDB_EXTFXR_A	GP_ALTSEL_FUNC(0, 12, 0)
+#define ALT_FXR_TXENB_N_A	GP_ALTSEL_FUNC(0, 11, 0)
+#define ALT_FXR_TXDB_A		GP_ALTSEL_FUNC(0, 10, 0)
+#define ALT_RXDA_EXTFXR_A	GP_ALTSEL_FUNC(0, 9, 0)
+#define ALT_FXR_TXENA_N_A	GP_ALTSEL_FUNC(0, 8, 0)
+#define ALT_FXR_TXDA_A		GP_ALTSEL_FUNC(0, 7, 0)
+#define ALT_CLK_EXTFXR_A	GP_ALTSEL_FUNC(0, 6, 0)
+#define ALT_FXR_CLKOUT2_A	GP_ALTSEL_FUNC(0, 5, 0)
+#define ALT_FXR_CLKOUT1_A	GP_ALTSEL_FUNC(0, 4, 0)
+#define ALT_STPWT_EXTFXR_A	GP_ALTSEL_FUNC(0, 3, 0)
+
+/* GP0 ALTSEL function 1 */
+#define ALT_TAUD0O13		GP_ALTSEL_FUNC(0, 24, 1)
+#define ALT_TAUD0O12		GP_ALTSEL_FUNC(0, 23, 1)
+#define ALT_TAUD0O11		GP_ALTSEL_FUNC(0, 22, 1)
+#define ALT_TAUD0O10		GP_ALTSEL_FUNC(0, 21, 1)
+#define ALT_TAUD0O9		GP_ALTSEL_FUNC(0, 20, 1)
+#define ALT_TAUD0O8		GP_ALTSEL_FUNC(0, 19, 1)
+#define ALT_TAUD0O7		GP_ALTSEL_FUNC(0, 18, 1)
+#define ALT_TAUD0O6		GP_ALTSEL_FUNC(0, 17, 1)
+#define ALT_TAUD0O5		GP_ALTSEL_FUNC(0, 16, 1)
+#define ALT_TAUD0O4		GP_ALTSEL_FUNC(0, 15, 1)
+#define ALT_TAUD0O3		GP_ALTSEL_FUNC(0, 14, 1)
+#define ALT_TAUD0O2		GP_ALTSEL_FUNC(0, 13, 1)
+#define ALT_CAN11TX		GP_ALTSEL_FUNC(0, 12, 1)
+#define ALT_CAN11RX_INTP11	GP_ALTSEL_FUNC(0, 11, 1)
+#define ALT_CAN10TX		GP_ALTSEL_FUNC(0, 10, 1)
+#define ALT_CAN10RX_INTP10	GP_ALTSEL_FUNC(0, 9, 1)
+#define ALT_CAN9TX		GP_ALTSEL_FUNC(0, 8, 1)
+#define ALT_CAN9RX_INTP9	GP_ALTSEL_FUNC(0, 7, 1)
+#define ALT_CAN8TX		GP_ALTSEL_FUNC(0, 6, 1)
+#define ALT_CAN8RX_INTP8	GP_ALTSEL_FUNC(0, 5, 1)
+#define ALT_CAN7TX		GP_ALTSEL_FUNC(0, 4, 1)
+#define ALT_CAN7RX_INTP7	GP_ALTSEL_FUNC(0, 3, 1)
+
+/* GP0 ALTSEL function 2 */
+#define ALT_RLIN311TX		GP_ALTSEL_FUNC(0, 12, 2)
+#define ALT_RLIN311RX_INTP27	GP_ALTSEL_FUNC(0, 11, 2)
+#define ALT_RLIN310TX		GP_ALTSEL_FUNC(0, 10, 2)
+#define ALT_RLIN310RX_INTP26	GP_ALTSEL_FUNC(0, 9, 2)
+#define ALT_RLIN39TX		GP_ALTSEL_FUNC(0, 8, 2)
+#define ALT_RLIN39RX_INTP25	GP_ALTSEL_FUNC(0, 7, 2)
+#define ALT_RLIN38TX		GP_ALTSEL_FUNC(0, 6, 2)
+#define ALT_RLIN38RX_INTP24	GP_ALTSEL_FUNC(0, 5, 2)
+#define ALT_RLIN315TX_A		GP_ALTSEL_FUNC(0, 4, 2)
+#define ALT_RLIN315RX_INTP31_A	GP_ALTSEL_FUNC(0, 3, 2)
+
+/* GP0 ALTSEL function 3 */
+#define ALT_RTCA0OUT_A		GP_ALTSEL_FUNC(0, 12, 3)
+#define ALT_EXTCLK0O_A		GP_ALTSEL_FUNC(0, 11, 3)
+#define ALT_TAUD1O15		GP_ALTSEL_FUNC(0, 8, 3)
+#define ALT_TAUD1O14		GP_ALTSEL_FUNC(0, 7, 3)
+#define ALT_TAUD1O13		GP_ALTSEL_FUNC(0, 6, 3)
+#define ALT_TAUD1O12		GP_ALTSEL_FUNC(0, 5, 3)
+#define ALT_TAUD1O11		GP_ALTSEL_FUNC(0, 4, 3)
+#define ALT_TAUD1O10		GP_ALTSEL_FUNC(0, 3, 3)
+
+/* GP1 ALTSEL function 0 */
+#define ALT_RLIN33TX		GP_ALTSEL_FUNC(1, 21, 0)
+#define ALT_RLIN33RX_INTP19	GP_ALTSEL_FUNC(1, 20, 0)
+#define ALT_RLIN32TX		GP_ALTSEL_FUNC(1, 19, 0)
+#define ALT_RLIN32RX_INTP18	GP_ALTSEL_FUNC(1, 18, 0)
+#define ALT_RLIN31TX		GP_ALTSEL_FUNC(1, 17, 0)
+#define ALT_RLIN31RX_INTP17	GP_ALTSEL_FUNC(1, 16, 0)
+#define ALT_RLIN30TX		GP_ALTSEL_FUNC(1, 15, 0)
+#define ALT_RLIN30RX_INTP16	GP_ALTSEL_FUNC(1, 14, 0)
+#define ALT_CAN6TX		GP_ALTSEL_FUNC(1, 13, 0)
+#define ALT_CAN6RX_INTP6	GP_ALTSEL_FUNC(1, 12, 0)
+#define ALT_CAN5TX		GP_ALTSEL_FUNC(1, 11, 0)
+#define ALT_CAN5RX_INTP5	GP_ALTSEL_FUNC(1, 10, 0)
+#define ALT_CAN4TX		GP_ALTSEL_FUNC(1, 9, 0)
+#define ALT_CAN4RX_INTP4	GP_ALTSEL_FUNC(1, 8, 0)
+#define ALT_CAN3TX		GP_ALTSEL_FUNC(1, 7, 0)
+#define ALT_CAN3RX_INTP3	GP_ALTSEL_FUNC(1, 6, 0)
+#define ALT_CAN2TX		GP_ALTSEL_FUNC(1, 5, 0)
+#define ALT_CAN2RX_INTP2	GP_ALTSEL_FUNC(1, 4, 0)
+#define ALT_CAN1TX		GP_ALTSEL_FUNC(1, 3, 0)
+#define ALT_CAN1RX_INTP1	GP_ALTSEL_FUNC(1, 2, 0)
+#define ALT_CAN0TX		GP_ALTSEL_FUNC(1, 1, 0)
+#define ALT_CAN0RX_INTP0	GP_ALTSEL_FUNC(1, 0, 0)
+
+/* GP1 ALTSEL function 1 */
+#define ALT_TAUJ1I3_TAUJ1O3	GP_ALTSEL_FUNC(1, 21, 1)
+#define ALT_TAUJ1I2_TAUJ1O2	GP_ALTSEL_FUNC(1, 20, 1)
+#define ALT_TAUJ1I1_TAUJ1O1	GP_ALTSEL_FUNC(1, 19, 1)
+#define ALT_TAUJ1I0_TAUJ1O0	GP_ALTSEL_FUNC(1, 18, 1)
+#define ALT_TAUJ3I3_TAUJ3O3	GP_ALTSEL_FUNC(1, 17, 1)
+#define ALT_TAUJ3I2_TAUJ3O2	GP_ALTSEL_FUNC(1, 16, 1)
+#define ALT_TAUJ3I1_TAUJ3O1	GP_ALTSEL_FUNC(1, 15, 1)
+#define ALT_TAUJ3I0_TAUJ3O0	GP_ALTSEL_FUNC(1, 14, 1)
+#define ALT_RLIN314TX_A		GP_ALTSEL_FUNC(1, 13, 1)
+#define ALT_RLIN314RX_INTP30_A	GP_ALTSEL_FUNC(1, 12, 1)
+#define ALT_RLIN313TX_A		GP_ALTSEL_FUNC(1, 11, 1)
+#define ALT_RLIN313RX_INTP29_A	GP_ALTSEL_FUNC(1, 10, 1)
+#define ALT_RLIN312TX_A		GP_ALTSEL_FUNC(1, 9, 1)
+#define ALT_RLIN312RX_INTP28_A	GP_ALTSEL_FUNC(1, 8, 1)
+#define ALT_RLIN37TX_A		GP_ALTSEL_FUNC(1, 7, 1)
+#define ALT_RLIN37RX_INTP23_A	GP_ALTSEL_FUNC(1, 6, 1)
+#define ALT_RLIN36TX_A		GP_ALTSEL_FUNC(1, 5, 1)
+#define ALT_RLIN36RX_INTP22_A	GP_ALTSEL_FUNC(1, 4, 1)
+#define ALT_RLIN35TX_A		GP_ALTSEL_FUNC(1, 3, 1)
+#define ALT_RLIN35RX_INTP21_A	GP_ALTSEL_FUNC(1, 2, 1)
+#define ALT_RLIN34TX_A		GP_ALTSEL_FUNC(1, 1, 1)
+#define ALT_RLIN34RX_INTP20_A	GP_ALTSEL_FUNC(1, 0, 1)
+
+/* GP1 ALTSEL function 2 */
+#define ALT_CAN15TX_A		GP_ALTSEL_FUNC(1, 21, 2)
+#define ALT_CAN15RX_INTP15_A	GP_ALTSEL_FUNC(1, 20, 2)
+#define ALT_CAN14TX_A		GP_ALTSEL_FUNC(1, 19, 2)
+#define ALT_CAN14RX_INTP14_A	GP_ALTSEL_FUNC(1, 18, 2)
+#define ALT_CAN13TX_A		GP_ALTSEL_FUNC(1, 17, 2)
+#define ALT_CAN13RX_INTP13_A	GP_ALTSEL_FUNC(1, 16, 2)
+#define ALT_CAN12TX_A		GP_ALTSEL_FUNC(1, 15, 2)
+#define ALT_CAN12RX_INTP12_A	GP_ALTSEL_FUNC(1, 14, 2)
+#define ALT_TAUD1O9		GP_ALTSEL_FUNC(1, 13, 2)
+#define ALT_TAUD1O8		GP_ALTSEL_FUNC(1, 12, 2)
+#define ALT_MSIOF3_SS2		GP_ALTSEL_FUNC(1, 11, 2)
+#define ALT_MSIOF3_SS1		GP_ALTSEL_FUNC(1, 10, 2)
+#define ALT_MSIOF3_SYNC		GP_ALTSEL_FUNC(1, 9, 2)
+#define ALT_MSIOF3_RXD		GP_ALTSEL_FUNC(1, 8, 2)
+#define ALT_MSIOF3_TXD		GP_ALTSEL_FUNC(1, 7, 2)
+#define ALT_MSIOF3_SCK		GP_ALTSEL_FUNC(1, 6, 2)
+#define ALT_MSIOF2_SS2		GP_ALTSEL_FUNC(1, 5, 2)
+#define ALT_MSIOF2_SS1		GP_ALTSEL_FUNC(1, 4, 2)
+#define ALT_MSIOF2_SYNC		GP_ALTSEL_FUNC(1, 3, 2)
+#define ALT_MSIOF2_RXD		GP_ALTSEL_FUNC(1, 2, 2)
+#define ALT_MSIOF2_TXD		GP_ALTSEL_FUNC(1, 1, 2)
+#define ALT_MSIOF2_SCK		GP_ALTSEL_FUNC(1, 0, 2)
+
+/* GP1 ALTSEL function 3 */
+#define ALT_NMI1_A		GP_ALTSEL_FUNC(1, 19, 3)
+#define ALT_INTP34_A		GP_ALTSEL_FUNC(1, 18, 3)
+#define ALT_INTP33_A		GP_ALTSEL_FUNC(1, 17, 3)
+#define ALT_INTP32_A		GP_ALTSEL_FUNC(1, 16, 3)
+#define ALT_RXDB_EXTFXR_B	GP_ALTSEL_FUNC(1, 11, 3)
+#define ALT_FXR_TXENB_N_B	GP_ALTSEL_FUNC(1, 10, 3)
+#define ALT_FXR_TXDB_B		GP_ALTSEL_FUNC(1, 9, 3)
+#define ALT_RXDA_EXTFXR_B	GP_ALTSEL_FUNC(1, 8, 3)
+#define ALT_FXR_TXENA_N_B	GP_ALTSEL_FUNC(1, 7, 3)
+#define ALT_FXR_TXDA_B		GP_ALTSEL_FUNC(1, 6, 3)
+#define ALT_CLK_EXTFXR_B	GP_ALTSEL_FUNC(1, 5, 3)
+#define ALT_FXR_CLKOUT2_B	GP_ALTSEL_FUNC(1, 4, 3)
+#define ALT_FXR_CLKOUT1_B	GP_ALTSEL_FUNC(1, 3, 3)
+#define ALT_STPWT_EXTFXR_B	GP_ALTSEL_FUNC(1, 2, 3)
+
+/* GP2 ALTSEL function 0 */
+#define ALT_INTP34_B		GP_ALTSEL_FUNC(2, 28, 0)
+#define ALT_TAUD1O3		GP_ALTSEL_FUNC(2, 27, 0)
+#define ALT_TAUD1O2		GP_ALTSEL_FUNC(2, 26, 0)
+#define ALT_TAUD1O1		GP_ALTSEL_FUNC(2, 25, 0)
+#define ALT_TAUD1O0		GP_ALTSEL_FUNC(2, 24, 0)
+#define ALT_EXTCLK0O_B		GP_ALTSEL_FUNC(2, 23, 0)
+#define ALT_AVS1		GP_ALTSEL_FUNC(2, 22, 0)
+#define ALT_AVS0		GP_ALTSEL_FUNC(2, 21, 0)
+#define ALT_SDA0		GP_ALTSEL_FUNC(2, 20, 0)
+#define ALT_SCL0		GP_ALTSEL_FUNC(2, 19, 0)
+#define ALT_INTP33_B		GP_ALTSEL_FUNC(2, 18, 0)
+#define ALT_INTP32_B		GP_ALTSEL_FUNC(2, 17, 0)
+#define ALT_CAN_CLK		GP_ALTSEL_FUNC(2, 16, 0)
+#define ALT_CAN15TX_B		GP_ALTSEL_FUNC(2, 15, 0)
+#define ALT_CAN15RX_B_INTP15	GP_ALTSEL_FUNC(2, 14, 0)
+#define ALT_CAN14TX_B		GP_ALTSEL_FUNC(2, 13, 0)
+#define ALT_CAN14RX_B_INTP14	GP_ALTSEL_FUNC(2, 12, 0)
+#define ALT_CAN13TX_B		GP_ALTSEL_FUNC(2, 11, 0)
+#define ALT_CAN13RX_B_INTP13	GP_ALTSEL_FUNC(2, 10, 0)
+#define ALT_CAN12TX_B		GP_ALTSEL_FUNC(2, 9, 0)
+#define ALT_CAN12RX_B_INTP12	GP_ALTSEL_FUNC(2, 8, 0)
+#define ALT_RLIN37TX_B		GP_ALTSEL_FUNC(2, 7, 0)
+#define ALT_RLIN37RX_B_INTP23	GP_ALTSEL_FUNC(2, 6, 0)
+#define ALT_RLIN36TX_B		GP_ALTSEL_FUNC(2, 5, 0)
+#define ALT_RLIN36RX_B_INTP22	GP_ALTSEL_FUNC(2, 4, 0)
+#define ALT_RLIN35TX_B		GP_ALTSEL_FUNC(2, 3, 0)
+#define ALT_RLIN35RX_B_INTP21	GP_ALTSEL_FUNC(2, 2, 0)
+#define ALT_RLIN34TX_B		GP_ALTSEL_FUNC(2, 1, 0)
+#define ALT_RLIN34RX_B_INTP20	GP_ALTSEL_FUNC(2, 0, 0)
+
+/* GP2 ALTSEL function 1 */
+#define ALT_TAUD0O1		GP_ALTSEL_FUNC(2, 18, 1)
+#define ALT_TAUD0O0		GP_ALTSEL_FUNC(2, 17, 1)
+#define ALT_RLIN315TX_B		GP_ALTSEL_FUNC(2, 15, 1)
+#define ALT_RLIN315RX_INTP31_B	GP_ALTSEL_FUNC(2, 14, 1)
+#define ALT_RLIN314TX_B		GP_ALTSEL_FUNC(2, 13, 1)
+#define ALT_RLIN314RX_INTP30_B	GP_ALTSEL_FUNC(2, 12, 1)
+#define ALT_RLIN313TX		GP_ALTSEL_FUNC(2, 11, 1)
+#define ALT_RLIN313RX_INTP29_B	GP_ALTSEL_FUNC(2, 10, 1)
+#define ALT_RLIN312TX		GP_ALTSEL_FUNC(2, 9, 1)
+#define ALT_RLIN312RX_INTP28_B	GP_ALTSEL_FUNC(2, 8, 1)
+#define ALT_RTCA0OUT_B		GP_ALTSEL_FUNC(2, 7, 1)
+#define ALT_MSIOF1_SS2_B	GP_ALTSEL_FUNC(2, 5, 1)
+#define ALT_MSIOF1_SS1_B	GP_ALTSEL_FUNC(2, 4, 1)
+#define ALT_MSIOF1_SYN_B	GP_ALTSEL_FUNC(2, 3, 1)
+#define ALT_MSIOF1_RXD_B	GP_ALTSEL_FUNC(2, 2, 1)
+#define ALT_MSIOF1_TXD_B	GP_ALTSEL_FUNC(2, 1, 1)
+#define ALT_MSIOF1_SCK_B	GP_ALTSEL_FUNC(2, 0, 1)
+
+/* GP2 ALTSEL function 2 */
+#define ALT_TAUD1O7		GP_ALTSEL_FUNC(2, 9, 2)
+#define ALT_TAUD1O6		GP_ALTSEL_FUNC(2, 8, 2)
+#define ALT_TAUD1O5		GP_ALTSEL_FUNC(2, 7, 2)
+#define ALT_TAUD1O4		GP_ALTSEL_FUNC(2, 6, 2)
+#define ALT_TAUD0O15		GP_ALTSEL_FUNC(2, 1, 2)
+#define ALT_TAUD0O14		GP_ALTSEL_FUNC(2, 0, 2)
+
+/* GP2 ALTSEL function 3 */
+#define ALT_CANXL1_TX		GP_ALTSEL_FUNC(2, 11, 3)
+#define ALT_CANXL1_RX		GP_ALTSEL_FUNC(2, 10, 3)
+#define ALT_CANXL0_TX		GP_ALTSEL_FUNC(2, 9, 3)
+#define ALT_CANXL0_RX		GP_ALTSEL_FUNC(2, 8, 3)
+#define ALT_CTIACK		GP_ALTSEL_FUNC(2, 4, 3)
+#define ALT_CTIREQ		GP_ALTSEL_FUNC(2, 3, 3)
+
+/* GP3 ALTSEL function 0 */
+#define ALT_ERRORIN0_N		GP_ALTSEL_FUNC(3, 16, 0)
+#define ALT_ERROROUT_N		GP_ALTSEL_FUNC(3, 15, 0)
+#define ALT_QSPI1_SSL		GP_ALTSEL_FUNC(3, 14, 0)
+#define ALT_QSPI1_IO3		GP_ALTSEL_FUNC(3, 13, 0)
+#define ALT_QSPI1_IO2		GP_ALTSEL_FUNC(3, 12, 0)
+#define ALT_QSPI1_MISO_IO1	GP_ALTSEL_FUNC(3, 11, 0)
+#define ALT_QSPI1_MOSI_IO0	GP_ALTSEL_FUNC(3, 10, 0)
+#define ALT_QSPI1_SPCLK		GP_ALTSEL_FUNC(3, 9, 0)
+#define ALT_RPC_INT_N		GP_ALTSEL_FUNC(3, 8, 0)
+#define ALT_RPC_WP_N		GP_ALTSEL_FUNC(3, 7, 0)
+#define ALT_RPC_RESET_N		GP_ALTSEL_FUNC(3, 6, 0)
+#define ALT_QSPI0_SSL		GP_ALTSEL_FUNC(3, 5, 0)
+#define ALT_QSPI0_IO3		GP_ALTSEL_FUNC(3, 4, 0)
+#define ALT_QSPI0_IO2		GP_ALTSEL_FUNC(3, 3, 0)
+#define ALT_QSPI0_MISO_IO1	GP_ALTSEL_FUNC(3, 2, 0)
+#define ALT_QSPI0_MOSI_IO0	GP_ALTSEL_FUNC(3, 1, 0)
+#define ALT_QSPI0_SPCLK		GP_ALTSEL_FUNC(3, 0, 0)
+
+/* GP4 ALTSEL function 0 */
+#define ALT_PCIE61_CLKREQ_N	GP_ALTSEL_FUNC(4, 15, 0)
+#define ALT_PCIE60_CLKREQ_N	GP_ALTSEL_FUNC(4, 14, 0)
+#define ALT_ERRORIN1_N		GP_ALTSEL_FUNC(4, 13, 0)
+#define ALT_SD0_CD		GP_ALTSEL_FUNC(4, 12, 0)
+#define ALT_SD0_WP		GP_ALTSEL_FUNC(4, 11, 0)
+#define ALT_MMC0_DS		GP_ALTSEL_FUNC(4, 10, 0)
+#define ALT_MMC0_D7		GP_ALTSEL_FUNC(4, 9, 0)
+#define ALT_MMC0_D6		GP_ALTSEL_FUNC(4, 8, 0)
+#define ALT_MMC0_D5		GP_ALTSEL_FUNC(4, 7, 0)
+#define ALT_MMC0_D4		GP_ALTSEL_FUNC(4, 6, 0)
+#define ALT_MMC0_SD_D3		GP_ALTSEL_FUNC(4, 5, 0)
+#define ALT_MMC0_SD_D2		GP_ALTSEL_FUNC(4, 4, 0)
+#define ALT_MMC0_SD_D1		GP_ALTSEL_FUNC(4, 3, 0)
+#define ALT_MMC0_SD_D0		GP_ALTSEL_FUNC(4, 2, 0)
+#define ALT_MMC0_SD_CMD		GP_ALTSEL_FUNC(4, 1, 0)
+#define ALT_MMC0_SD_CLK		GP_ALTSEL_FUNC(4, 0, 0)
+
+/* GP5 ALTSEL function 0 */
+#define ALT_TPU0TO3		GP_ALTSEL_FUNC(5, 22, 0)
+#define ALT_TPU0TO2		GP_ALTSEL_FUNC(5, 21, 0)
+#define ALT_TPU0TO1		GP_ALTSEL_FUNC(5, 20, 0)
+#define ALT_TPU0TO0		GP_ALTSEL_FUNC(5, 19, 0)
+#define ALT_TCLK4		GP_ALTSEL_FUNC(5, 18, 0)
+#define ALT_TCLK3		GP_ALTSEL_FUNC(5, 17, 0)
+#define ALT_TCLK2		GP_ALTSEL_FUNC(5, 16, 0)
+#define ALT_TCLK1		GP_ALTSEL_FUNC(5, 15, 0)
+#define ALT_IRQ3_A		GP_ALTSEL_FUNC(5, 14, 0)
+#define ALT_IRQ2_A		GP_ALTSEL_FUNC(5, 13, 0)
+#define ALT_IRQ1_A		GP_ALTSEL_FUNC(5, 12, 0)
+#define ALT_IRQ0_A		GP_ALTSEL_FUNC(5, 11, 0)
+#define ALT_HSCK1		GP_ALTSEL_FUNC(5, 10, 0)
+#define ALT_HCTS1_N		GP_ALTSEL_FUNC(5, 9, 0)
+#define ALT_HRTS1_N		GP_ALTSEL_FUNC(5, 8, 0)
+#define ALT_HRX1		GP_ALTSEL_FUNC(5, 7, 0)
+#define ALT_HTX1		GP_ALTSEL_FUNC(5, 6, 0)
+#define ALT_SCIF_CLK		GP_ALTSEL_FUNC(5, 5, 0)
+#define ALT_HSCK0		GP_ALTSEL_FUNC(5, 4, 0)
+#define ALT_HCTS0_N		GP_ALTSEL_FUNC(5, 3, 0)
+#define ALT_HRTS0_N		GP_ALTSEL_FUNC(5, 2, 0)
+#define ALT_HRX0		GP_ALTSEL_FUNC(5, 1, 0)
+#define ALT_HTX0		GP_ALTSEL_FUNC(5, 0, 0)
+
+/* GP5 ALTSEL function 1 */
+#define ALT_SSI9_WS		GP_ALTSEL_FUNC(5, 22, 1)
+#define ALT_SSI9_SCK		GP_ALTSEL_FUNC(5, 21, 1)
+#define ALT_PWM5		GP_ALTSEL_FUNC(5, 20, 1)
+#define ALT_PWM4		GP_ALTSEL_FUNC(5, 19, 1)
+#define ALT_PWM3		GP_ALTSEL_FUNC(5, 18, 1)
+#define ALT_PWM2		GP_ALTSEL_FUNC(5, 17, 1)
+#define ALT_PWM1		GP_ALTSEL_FUNC(5, 16, 1)
+#define ALT_PWM0_A		GP_ALTSEL_FUNC(5, 15, 1)
+#define ALT_SSI17_SD		GP_ALTSEL_FUNC(5, 13, 1)
+#define ALT_SSI17_WS		GP_ALTSEL_FUNC(5, 12, 1)
+#define ALT_SSI17_SCK		GP_ALTSEL_FUNC(5, 11, 1)
+#define ALT_SCK1		GP_ALTSEL_FUNC(5, 10, 1)
+#define ALT_CTS1_N		GP_ALTSEL_FUNC(5, 9, 1)
+#define ALT_RTS1_N		GP_ALTSEL_FUNC(5, 8, 1)
+#define ALT_RX1			GP_ALTSEL_FUNC(5, 7, 1)
+#define ALT_TX1			GP_ALTSEL_FUNC(5, 6, 1)
+#define ALT_SCK0		GP_ALTSEL_FUNC(5, 4, 1)
+#define ALT_CTS0_N		GP_ALTSEL_FUNC(5, 3, 1)
+#define ALT_RTS0_N		GP_ALTSEL_FUNC(5, 2, 1)
+#define ALT_RX0			GP_ALTSEL_FUNC(5, 1, 1)
+#define ALT_TX0			GP_ALTSEL_FUNC(5, 0, 1)
+
+/* GP5 ALTSEL function 2 */
+#define ALT_SSI19_SD		GP_ALTSEL_FUNC(5, 18, 2)
+#define ALT_SSI19_WS		GP_ALTSEL_FUNC(5, 17, 2)
+#define ALT_SSI19_SCK		GP_ALTSEL_FUNC(5, 16, 2)
+#define ALT_SSI18_SD		GP_ALTSEL_FUNC(5, 15, 2)
+#define ALT_SSI13_SCK		GP_ALTSEL_FUNC(5, 10, 2)
+#define ALT_RIF0_SYNC_B		GP_ALTSEL_FUNC(5, 8, 2)
+#define ALT_IRQ1_B		GP_ALTSEL_FUNC(5, 3, 2)
+#define ALT_IRQ0_B		GP_ALTSEL_FUNC(5, 2, 2)
+#define ALT_SSI13_SD		GP_ALTSEL_FUNC(5, 1, 2)
+#define ALT_SSI13_WS		GP_ALTSEL_FUNC(5, 0, 2)
+
+/* GP5 ALTSEL function 3*/
+#define ALT_RIF7_D1		GP_ALTSEL_FUNC(5, 14, 3)
+#define ALT_RIF7_D0		GP_ALTSEL_FUNC(5, 13, 3)
+#define ALT_RIF7_SYNC		GP_ALTSEL_FUNC(5, 12, 3)
+#define ALT_RIF7_CLK		GP_ALTSEL_FUNC(5, 11, 3)
+#define ALT_RIF0_CLK_B		GP_ALTSEL_FUNC(5, 10, 3)
+#define ALT_SSI16_SD		GP_ALTSEL_FUNC(5, 8, 3)
+#define ALT_SSI16_WS		GP_ALTSEL_FUNC(5, 7, 3)
+#define ALT_SSI16_SCK		GP_ALTSEL_FUNC(5, 6, 3)
+#define ALT_SSI15_SD		GP_ALTSEL_FUNC(5, 4, 3)
+#define ALT_SSI15_WS		GP_ALTSEL_FUNC(5, 3, 3)
+#define ALT_SSI15_SCK		GP_ALTSEL_FUNC(5, 2, 3)
+#define ALT_RIF0_D1_B		GP_ALTSEL_FUNC(5, 1, 3)
+#define ALT_RIF0_D0_B		GP_ALTSEL_FUNC(5, 0, 3)
+
+/* GP6 ALTSEL function 0 */
+#define ALT_AUDIO1_CLKOUT1	GP_ALTSEL_FUNC(6, 30, 0)
+#define ALT_AUDIO1_CLKOUT0	GP_ALTSEL_FUNC(6, 29, 0)
+#define ALT_SSI2_SD		GP_ALTSEL_FUNC(6, 28, 0)
+#define ALT_SSI2_WS		GP_ALTSEL_FUNC(6, 27, 0)
+#define ALT_SSI2_SCK		GP_ALTSEL_FUNC(6, 26, 0)
+#define ALT_AUDIO0_CLKOUT3	GP_ALTSEL_FUNC(6, 25, 0)
+#define ALT_AUDIO0_CLKOUT2	GP_ALTSEL_FUNC(6, 24, 0)
+#define ALT_SSI1_SD		GP_ALTSEL_FUNC(6, 23, 0)
+#define ALT_SSI1_WS		GP_ALTSEL_FUNC(6, 22, 0)
+#define ALT_SSI1_SCK		GP_ALTSEL_FUNC(6, 21, 0)
+#define ALT_AUDIO0_CLKOUT1	GP_ALTSEL_FUNC(6, 20, 0)
+#define ALT_AUDIO0_CLKOUT0	GP_ALTSEL_FUNC(6, 19, 0)
+#define ALT_SSI0_SD		GP_ALTSEL_FUNC(6, 18, 0)
+#define ALT_SSI0_WS		GP_ALTSEL_FUNC(6, 17, 0)
+#define ALT_SSI0_SCK		GP_ALTSEL_FUNC(6, 16, 0)
+#define ALT_MSIOF4_SS2_B	GP_ALTSEL_FUNC(6, 15, 0)
+#define ALT_MSIOF4_SS1_B	GP_ALTSEL_FUNC(6, 14, 0)
+#define ALT_MSIOF4_SYNC_B	GP_ALTSEL_FUNC(6, 13, 0)
+#define ALT_MSIOF4_RXD_B	GP_ALTSEL_FUNC(6, 12, 0)
+#define ALT_MSIOF4_TXD_B	GP_ALTSEL_FUNC(6, 11, 0)
+#define ALT_MSIOF4_SCK_B	GP_ALTSEL_FUNC(6, 10, 0)
+#define ALT_MSIOF7_SS2_A	GP_ALTSEL_FUNC(6, 9, 0)
+#define ALT_MSIOF7_SS1_A	GP_ALTSEL_FUNC(6, 8, 0)
+#define ALT_MSIOF7_SYNC_A	GP_ALTSEL_FUNC(6, 7, 0)
+#define ALT_MSIOF7_RXD_A	GP_ALTSEL_FUNC(6, 6, 0)
+#define ALT_MSIOF7_TXD_A	GP_ALTSEL_FUNC(6, 5, 0)
+#define ALT_MSIOF7_SCK_A	GP_ALTSEL_FUNC(6, 4, 0)
+#define ALT_RIF6_CLK		GP_ALTSEL_FUNC(6, 3, 0)
+#define ALT_RIF6_SYNC		GP_ALTSEL_FUNC(6, 2, 0)
+#define ALT_RIF6_D1		GP_ALTSEL_FUNC(6, 1, 0)
+#define ALT_RIF6_D0		GP_ALTSEL_FUNC(6, 0, 0)
+
+/* GP6 ALTSEL function 1 */
+#define ALT_MSIOF7_RXD_B	GP_ALTSEL_FUNC(6, 30, 1)
+#define ALT_MSIOF7_TXD_B	GP_ALTSEL_FUNC(6, 29, 1)
+#define ALT_MSIOF7_SCK_B	GP_ALTSEL_FUNC(6, 28, 1)
+#define ALT_MSIOF4_SS2_A	GP_ALTSEL_FUNC(6, 21, 1)
+#define ALT_MSIOF4_SS1_A	GP_ALTSEL_FUNC(6, 20, 1)
+#define ALT_MSIOF4_SYNC_A	GP_ALTSEL_FUNC(6, 19, 1)
+#define ALT_MSIOF4_RXD_A	GP_ALTSEL_FUNC(6, 18, 1)
+#define ALT_MSIOF4_TXD_A	GP_ALTSEL_FUNC(6, 17, 1)
+#define ALT_MSIOF4_SCK_A	GP_ALTSEL_FUNC(6, 16, 1)
+#define ALT_SSI14_SD		GP_ALTSEL_FUNC(6, 15, 1)
+#define ALT_SSI12_SD		GP_ALTSEL_FUNC(6, 14, 1)
+#define ALT_SSI12_WS		GP_ALTSEL_FUNC(6, 13, 1)
+#define ALT_SSI12_SCK		GP_ALTSEL_FUNC(6, 11, 1)
+#define ALT_SSI14_WS		GP_ALTSEL_FUNC(6, 9, 1)
+#define ALT_SSI14_SCK		GP_ALTSEL_FUNC(6, 8, 1)
+#define ALT_RIF1_D1_B		GP_ALTSEL_FUNC(6, 7, 1)
+#define ALT_RIF1_D0_B		GP_ALTSEL_FUNC(6, 6, 1)
+#define ALT_RIF1_SYNC_B		GP_ALTSEL_FUNC(6, 5, 1)
+#define ALT_RIF1_CLK_B		GP_ALTSEL_FUNC(6, 4, 1)
+#define ALT_SSI10_SD		GP_ALTSEL_FUNC(6, 3, 1)
+#define ALT_SSI10_WS		GP_ALTSEL_FUNC(6, 2, 1)
+#define ALT_SSI10_SCK		GP_ALTSEL_FUNC(6, 1, 1)
+#define ALT_SSI9_SD		GP_ALTSEL_FUNC(6, 0, 1)
+
+/* GP6 ALTSEL function 2 */
+#define ALT_RIF5_CLK		GP_ALTSEL_FUNC(6, 30, 2)
+#define ALT_RIF5_SYNC		GP_ALTSEL_FUNC(6, 28, 2)
+#define ALT_RIF1_D1_A		GP_ALTSEL_FUNC(6, 27, 2)
+#define ALT_RIF1_D0_A		GP_ALTSEL_FUNC(6, 26, 2)
+#define ALT_RIF1_CLK_A		GP_ALTSEL_FUNC(6, 25, 2)
+#define ALT_RIF2_D1		GP_ALTSEL_FUNC(6, 24, 2)
+#define ALT_HCTS3_N		GP_ALTSEL_FUNC(6, 23, 2)
+#define ALT_HRTS3_N		GP_ALTSEL_FUNC(6, 22, 2)
+#define ALT_HSCK3		GP_ALTSEL_FUNC(6, 21, 2)
+#define ALT_RIF2_D0		GP_ALTSEL_FUNC(6, 20, 2)
+#define ALT_RIF2_SYNC		GP_ALTSEL_FUNC(6, 19, 2)
+#define ALT_HRX3		GP_ALTSEL_FUNC(6, 18, 2)
+#define ALT_HTX3		GP_ALTSEL_FUNC(6, 17, 2)
+#define ALT_AUDIO_CLKC_B	GP_ALTSEL_FUNC(6, 12, 2)
+#define ALT_AUDIO_CLKB_B	GP_ALTSEL_FUNC(6, 10, 2)
+#define ALT_SSI11_SD		GP_ALTSEL_FUNC(6, 7, 2)
+#define ALT_SSI11_WS		GP_ALTSEL_FUNC(6, 6, 2)
+#define ALT_SSI11_SCK		GP_ALTSEL_FUNC(6, 5, 2)
+#define ALT_AUDIO_CLKA_B	GP_ALTSEL_FUNC(6, 4, 2)
+
+/* GP6 ALTSEL function 3 */
+#define ALT_CTS3_N		GP_ALTSEL_FUNC(6, 22, 3)
+#define ALT_RTS3_N		GP_ALTSEL_FUNC(6, 22, 3)
+#define ALT_SCK3		GP_ALTSEL_FUNC(6, 21, 3)
+#define ALT_RX3			GP_ALTSEL_FUNC(6, 18, 3)
+#define ALT_TX3			GP_ALTSEL_FUNC(6, 17, 3)
+#define ALT_RIF1_SYNC_A		GP_ALTSEL_FUNC(6, 11, 3)
+
+/* GP7 ALTSEL function 0 */
+#define ALT_MSIOF6_SS2_B	GP_ALTSEL_FUNC(7, 30, 0)
+#define ALT_MSIOF6_SS1_B	GP_ALTSEL_FUNC(7, 29, 0)
+#define ALT_MSIOF6_SYNC_B	GP_ALTSEL_FUNC(7, 28, 0)
+#define ALT_MSIOF6_RXD_B	GP_ALTSEL_FUNC(7, 27, 0)
+#define ALT_MSIOF6_TXD_B	GP_ALTSEL_FUNC(7, 26, 0)
+#define ALT_MSIOF6_SCK_B	GP_ALTSEL_FUNC(7, 25, 0)
+#define ALT_MSIOF5_SS2		GP_ALTSEL_FUNC(7, 24, 0)
+#define ALT_MSIOF5_SS1		GP_ALTSEL_FUNC(7, 23, 0)
+#define ALT_MSIOF5_SYNC		GP_ALTSEL_FUNC(7, 22, 0)
+#define ALT_MSIOF5_RXD		GP_ALTSEL_FUNC(7, 21, 0)
+#define ALT_MSIOF5_TXD		GP_ALTSEL_FUNC(7, 20, 0)
+#define ALT_MSIOF5_SCK		GP_ALTSEL_FUNC(7, 17, 0)
+#define ALT_AUDIO_CLKC_A	GP_ALTSEL_FUNC(7, 16, 0)
+#define ALT_SSI6_SD		GP_ALTSEL_FUNC(7, 15, 0)
+#define ALT_SSI6_WS		GP_ALTSEL_FUNC(7, 14, 0)
+#define ALT_SSI6_SCK		GP_ALTSEL_FUNC(7, 13, 0)
+#define ALT_AUDIO_CLKB_A	GP_ALTSEL_FUNC(7, 12, 0)
+#define ALT_SSI5_SD		GP_ALTSEL_FUNC(7, 11, 0)
+#define ALT_SSI5_WS		GP_ALTSEL_FUNC(7, 10, 0)
+#define ALT_SSI5_SCK		GP_ALTSEL_FUNC(7, 9, 0)
+#define ALT_AUDIO_CLKA_A	GP_ALTSEL_FUNC(7, 8, 0)
+#define ALT_SSI4_SD		GP_ALTSEL_FUNC(7, 7, 0)
+#define ALT_SSI4_WS		GP_ALTSEL_FUNC(7, 6, 0)
+#define ALT_SSI4_SCK		GP_ALTSEL_FUNC(7, 5, 0)
+#define ALT_AUDIO1_CLKOUT3	GP_ALTSEL_FUNC(7, 4, 0)
+#define ALT_AUDIO1_CLKOUT2	GP_ALTSEL_FUNC(7, 3, 0)
+#define ALT_SSI3_SD		GP_ALTSEL_FUNC(7, 2, 0)
+#define ALT_SSI3_WS		GP_ALTSEL_FUNC(7, 1, 0)
+#define ALT_SSI3_SCK		GP_ALTSEL_FUNC(7, 0, 0)
+
+/* GP7 ALTSEL function 1 */
+#define ALT_HRX2_B		GP_ALTSEL_FUNC(7, 30, 1)
+#define ALT_SSI7_SD		GP_ALTSEL_FUNC(7, 29, 1)
+#define ALT_SSI7_WS		GP_ALTSEL_FUNC(7, 28, 1)
+#define ALT_SSI7_SCK		GP_ALTSEL_FUNC(7, 27, 1)
+#define ALT_HTX2_B		GP_ALTSEL_FUNC(7, 26, 1)
+#define ALT_SSI8_SD		GP_ALTSEL_FUNC(7, 25, 1)
+#define ALT_HCTS2_N_B		GP_ALTSEL_FUNC(7, 24, 1)
+#define ALT_RIF0_SYNC_A		GP_ALTSEL_FUNC(7, 23, 1)
+#define ALT_HRTS2_N_B		GP_ALTSEL_FUNC(7, 22, 1)
+#define ALT_RIF0_D1_A		GP_ALTSEL_FUNC(7, 21, 1)
+#define ALT_HSCK2_B		GP_ALTSEL_FUNC(7, 20, 1)
+#define ALT_MSIOF6_SS2_A	GP_ALTSEL_FUNC(7, 19, 1)
+#define ALT_MSIOF6_SS1_A	GP_ALTSEL_FUNC(7, 18, 1)
+#define ALT_MSIOF6_RXD_A	GP_ALTSEL_FUNC(7, 15, 1)
+#define ALT_MSIOF6_TXD_A	GP_ALTSEL_FUNC(7, 14, 1)
+#define ALT_MSIOF6_SCK_A	GP_ALTSEL_FUNC(7, 13, 1)
+#define ALT_MSIOF6_SYNC_A	GP_ALTSEL_FUNC(7, 11, 1)
+#define ALT_RIF3_SYNC		GP_ALTSEL_FUNC(7, 10, 1)
+#define ALT_RIF3_CLK		GP_ALTSEL_FUNC(7, 9, 1)
+#define ALT_RIF3_D1		GP_ALTSEL_FUNC(7, 7, 1)
+#define ALT_RIF3_D0		GP_ALTSEL_FUNC(7, 6, 1)
+#define ALT_RIF2_CLK		GP_ALTSEL_FUNC(7, 5, 1)
+#define ALT_RIF0_D0_A		GP_ALTSEL_FUNC(7, 4, 1)
+#define ALT_RIF0_CLK_A		GP_ALTSEL_FUNC(7, 3, 1)
+#define ALT_MSIOF7_SS2_B	GP_ALTSEL_FUNC(7, 2, 1)
+#define ALT_MSIOF7_SS1_B	GP_ALTSEL_FUNC(7, 1, 1)
+#define ALT_MSIOF7_SYNC_B	GP_ALTSEL_FUNC(7, 0, 1)
+
+/* GP7 ALTSEL function 2 */
+#define ALT_RX4_B		GP_ALTSEL_FUNC(7, 30, 2)
+#define ALT_TX4_B		GP_ALTSEL_FUNC(7, 26, 2)
+#define ALT_CTS4_N_B		GP_ALTSEL_FUNC(7, 24, 2)
+#define ALT_RTS4_N_B		GP_ALTSEL_FUNC(7, 22, 2)
+#define ALT_SCK4_B		GP_ALTSEL_FUNC(7, 20, 2)
+#define ALT_RIF4_D1		GP_ALTSEL_FUNC(7, 15, 2)
+#define ALT_RIF4_D0		GP_ALTSEL_FUNC(7, 14, 2)
+#define ALT_RIF4_SYNC		GP_ALTSEL_FUNC(7, 13, 2)
+#define ALT_RIF4_CLK		GP_ALTSEL_FUNC(7, 11, 2)
+#define ALT_RIF5_D1		GP_ALTSEL_FUNC(7, 1, 2)
+#define ALT_RIF5_D0		GP_ALTSEL_FUNC(7, 0, 2)
+
+/* GP8 ALTSEL function 0 */
+#define ALT_S3DA2		GP_ALTSEL_FUNC(8, 31, 0)
+#define ALT_S3CL2		GP_ALTSEL_FUNC(8, 30, 0)
+#define ALT_S3DA1		GP_ALTSEL_FUNC(8, 29, 0)
+#define ALT_S3CL1		GP_ALTSEL_FUNC(8, 28, 0)
+#define ALT_S3DA0		GP_ALTSEL_FUNC(8, 27, 0)
+#define ALT_S3CL0		GP_ALTSEL_FUNC(8, 26, 0)
+#define ALT_SDA8		GP_ALTSEL_FUNC(8, 15, 0)
+#define ALT_SCL8		GP_ALTSEL_FUNC(8, 14, 0)
+#define ALT_SDA7		GP_ALTSEL_FUNC(8, 13, 0)
+#define ALT_SCL7		GP_ALTSEL_FUNC(8, 12, 0)
+#define ALT_SDA6		GP_ALTSEL_FUNC(8, 11, 0)
+#define ALT_SCL6		GP_ALTSEL_FUNC(8, 10, 0)
+#define ALT_SDA5		GP_ALTSEL_FUNC(8, 9, 0)
+#define ALT_SCL5		GP_ALTSEL_FUNC(8, 8, 0)
+#define ALT_SDA4		GP_ALTSEL_FUNC(8, 7, 0)
+#define ALT_SCL4		GP_ALTSEL_FUNC(8, 6, 0)
+#define ALT_SDA3		GP_ALTSEL_FUNC(8, 5, 0)
+#define ALT_SCL3		GP_ALTSEL_FUNC(8, 4, 0)
+#define ALT_SDA2		GP_ALTSEL_FUNC(8, 3, 0)
+#define ALT_SCL2		GP_ALTSEL_FUNC(8, 2, 0)
+#define ALT_SDA1		GP_ALTSEL_FUNC(8, 1, 0)
+#define ALT_SCL1		GP_ALTSEL_FUNC(8, 0, 0)
+
+/* GP8 ALTSEL function 1 */
+#define ALT_HCTS2_N_A		GP_ALTSEL_FUNC(8, 7, 1)
+#define ALT_HRTS2_N_A		GP_ALTSEL_FUNC(8, 6, 1)
+#define ALT_HRX2_A		GP_ALTSEL_FUNC(8, 5, 1)
+#define ALT_HTX2_A		GP_ALTSEL_FUNC(8, 4, 1)
+#define ALT_HSCK2_A		GP_ALTSEL_FUNC(8, 3, 1)
+#define ALT_PWM0_B		GP_ALTSEL_FUNC(8, 2, 1)
+
+/* GP8 ALTSEL function 2 */
+#define ALT_CTS4_N_A		GP_ALTSEL_FUNC(8, 7, 2)
+#define ALT_RTS4_N_A		GP_ALTSEL_FUNC(8, 6, 2)
+#define ALT_RX4_A		GP_ALTSEL_FUNC(8, 5, 2)
+#define ALT_TX4_A		GP_ALTSEL_FUNC(8, 4, 2)
+#define ALT_SCK4_A		GP_ALTSEL_FUNC(8, 3, 2)
+
+/* GP8 ALTSEL function 3 */
+#define ALT_PWM7_B		GP_ALTSEL_FUNC(8, 7, 3)
+#define ALT_PWM9_B		GP_ALTSEL_FUNC(8, 6, 3)
+#define ALT_PWM8_B		GP_ALTSEL_FUNC(8, 5, 3)
+#define ALT_PWM6_B		GP_ALTSEL_FUNC(8, 4, 3)
+
+/* GP9 ALTSEL function 0 */
+#define ALT_RSW3_MATCH		GP_ALTSEL_FUNC(9, 16, 0)
+#define ALT_RSW3_CAPTURE	GP_ALTSEL_FUNC(9, 15, 0)
+#define ALT_RSW3_PPS		GP_ALTSEL_FUNC(9, 14, 0)
+#define ALT_ETH10G0_PHYINT	GP_ALTSEL_FUNC(9, 13, 0)
+#define ALT_ETH10G0_LINK	GP_ALTSEL_FUNC(9, 12, 0)
+#define ALT_ETH10G0_MDC		GP_ALTSEL_FUNC(9, 11, 0)
+#define ALT_ETH10G0_MDIO	GP_ALTSEL_FUNC(9, 10, 0)
+#define ALT_ETH25G0_PHYINT	GP_ALTSEL_FUNC(9, 9, 0)
+#define ALT_ETH25G0_LINK	GP_ALTSEL_FUNC(9, 8, 0)
+#define ALT_ETH25G0_MDC		GP_ALTSEL_FUNC(9, 7, 0)
+#define ALT_ETH25G0_MDIO	GP_ALTSEL_FUNC(9, 6, 0)
+#define ALT_ETHES4_MATCH	GP_ALTSEL_FUNC(9, 5, 0)
+#define ALT_ETHES4_CAPTURE	GP_ALTSEL_FUNC(9, 4, 0)
+#define ALT_ETHES4_PPS		GP_ALTSEL_FUNC(9, 3, 0)
+#define ALT_ETHES0_MATCH	GP_ALTSEL_FUNC(9, 2, 0)
+#define ALT_ETHES0_CAPTURE	GP_ALTSEL_FUNC(9, 1, 0)
+#define ALT_ETHES0_PPS		GP_ALTSEL_FUNC(9, 0, 0)
+
+/* GP9 ALTSEL function 1 */
+#define ALT_ETH10G1_PHYINT	GP_ALTSEL_FUNC(9, 13, 1)
+#define ALT_ETH10G1_LINK	GP_ALTSEL_FUNC(9, 12, 1)
+#define ALT_ETH10G1_MDC		GP_ALTSEL_FUNC(9, 11, 1)
+#define ALT_ETH10G1_MDIO	GP_ALTSEL_FUNC(9, 10, 1)
+#define ALT_ETH25G1_PHYINT	GP_ALTSEL_FUNC(9, 9, 1)
+#define ALT_ETH25G1_LINK	GP_ALTSEL_FUNC(9, 8, 1)
+#define ALT_ETH25G1_MDC		GP_ALTSEL_FUNC(9, 7, 1)
+#define ALT_ETH25G1_MDIO	GP_ALTSEL_FUNC(9, 6, 1)
+#define ALT_ETHES5_MATCH	GP_ALTSEL_FUNC(9, 5, 1)
+#define ALT_ETHES5_CAPTURE	GP_ALTSEL_FUNC(9, 4, 1)
+#define ALT_ETHES5_PPS		GP_ALTSEL_FUNC(9, 3, 1)
+#define ALT_ETHES1_MATCH	GP_ALTSEL_FUNC(9, 2, 1)
+#define ALT_ETHES1_CAPTURE	GP_ALTSEL_FUNC(9, 1, 1)
+#define ALT_ETHES1_PPS		GP_ALTSEL_FUNC(9, 0, 1)
+
+/* GP9 ALTSEL function 2 */
+#define ALT_ETH25G2_PHYINT	GP_ALTSEL_FUNC(9, 9, 2)
+#define ALT_ETH25G2_LINK	GP_ALTSEL_FUNC(9, 8, 2)
+#define ALT_ETH25G2_MDC		GP_ALTSEL_FUNC(9, 7, 2)
+#define ALT_ETH25G2_MDIO	GP_ALTSEL_FUNC(9, 6, 2)
+#define ALT_ETHES6_MATCH	GP_ALTSEL_FUNC(9, 5, 2)
+#define ALT_ETHES6_CAPTURE	GP_ALTSEL_FUNC(9, 4, 2)
+#define ALT_ETHES6_PPS		GP_ALTSEL_FUNC(9, 3, 2)
+#define ALT_ETHES2_MATCH	GP_ALTSEL_FUNC(9, 2, 2)
+#define ALT_ETHES2_CAPTURE	GP_ALTSEL_FUNC(9, 1, 2)
+#define ALT_ETHES2_PPS		GP_ALTSEL_FUNC(9, 0, 2)
+
+/* GP9 ALTSEL function 3 */
+#define ALT_PWM9_A		GP_ALTSEL_FUNC(9, 16, 0)
+#define ALT_PWM8_A		GP_ALTSEL_FUNC(9, 15, 0)
+#define ALT_PWM7_A		GP_ALTSEL_FUNC(9, 12, 0)
+#define ALT_IRQ3_B		GP_ALTSEL_FUNC(9, 11, 0)
+#define ALT_IRQ2_B		GP_ALTSEL_FUNC(9, 10, 0)
+#define ALT_PWM6_A		GP_ALTSEL_FUNC(9, 8, 0)
+#define ALT_ETHES7_MATCH	GP_ALTSEL_FUNC(9, 5, 0)
+#define ALT_ETHES7_CAPTURE	GP_ALTSEL_FUNC(9, 4, 0)
+#define ALT_ETHES7_PPS		GP_ALTSEL_FUNC(9, 3, 0)
+#define ALT_ETHES3_MATCH	GP_ALTSEL_FUNC(9, 2, 0)
+#define ALT_ETHES3_CAPTURE	GP_ALTSEL_FUNC(9, 1, 0)
+#define ALT_ETHES3_PPS		GP_ALTSEL_FUNC(9, 0, 0)
+
+/* GP10 ALTSEL function 0 */
+#define ALT_PCIE41_CLKREQ_N	GP_ALTSEL_FUNC(10, 13, 0)
+#define ALT_PCIE40_CLKREQ_N	GP_ALTSEL_FUNC(10, 12, 0)
+#define ALT_USB3_VBUS_VALID	GP_ALTSEL_FUNC(10, 11, 0)
+#define ALT_USB3_OVC		GP_ALTSEL_FUNC(10, 10, 0)
+#define ALT_USB3_PWEN		GP_ALTSEL_FUNC(10, 9, 0)
+#define ALT_USB2_VBUS_VALID	GP_ALTSEL_FUNC(10, 8, 0)
+#define ALT_USB2_OVC		GP_ALTSEL_FUNC(10, 7, 0)
+#define ALT_USB2_PWEN		GP_ALTSEL_FUNC(10, 6, 0)
+#define ALT_USB1_VBUS_VALID	GP_ALTSEL_FUNC(10, 5, 0)
+#define ALT_USB1_OVC		GP_ALTSEL_FUNC(10, 4, 0)
+#define ALT_USB1_PWEN		GP_ALTSEL_FUNC(10, 3, 0)
+#define ALT_USB0_VBUS_VALID	GP_ALTSEL_FUNC(10, 2, 0)
+#define ALT_USB0_OVC		GP_ALTSEL_FUNC(10, 1, 0)
+#define ALT_USB0_PWEN		GP_ALTSEL_FUNC(10, 0, 0)
+
+#define PINMUX_GFUNC_GPSR(grp_func, fn)	\
+fn##_MARK, ALT_##fn, FN_##grp_func, 0
+
+#define PINMUX_GFUNC_MSEL_GPSR(grp_func, fn, msel)	\
+fn##_MARK, ALT_##fn, FN_##msel, FN_##grp_func, 0
+
+#define PINMUX_GFUNC_MSELMARK_GPSR(grp_func, fn, msel)	\
+msel##_MARK, ALT_##fn, FN_##msel, FN_##grp_func, 0
+
+static const u16 pinmux_data[] = {
+	PINMUX_DATA_GP_ALL(),
+
+	/* Group0 Functions */
+	PINMUX_GFUNC_GPSR(GRP0_27_FUNC, DP2_HOTPLUG),
+
+	PINMUX_GFUNC_GPSR(GRP0_26_FUNC, DP1_HOTPLUG),
+
+	PINMUX_GFUNC_GPSR(GRP0_25_FUNC, DP0_HOTPLUG),
+
+	PINMUX_GFUNC_GPSR(GRP0_24_FUNC, MSIOF1_SS2_A),
+	PINMUX_GFUNC_GPSR(GRP0_24_FUNC, TAUD0O13),
+
+	PINMUX_GFUNC_GPSR(GRP0_23_FUNC, MSIOF1_SS1_A),
+	PINMUX_GFUNC_GPSR(GRP0_23_FUNC, TAUD0O12),
+
+	PINMUX_GFUNC_GPSR(GRP0_22_FUNC, MSIOF1_SYNC_A),
+	PINMUX_GFUNC_GPSR(GRP0_22_FUNC, TAUD0O11),
+
+	PINMUX_GFUNC_GPSR(GRP0_21_FUNC, MSIOF1_RXD_A),
+	PINMUX_GFUNC_GPSR(GRP0_21_FUNC, TAUD0O10),
+
+	PINMUX_GFUNC_GPSR(GRP0_20_FUNC, MSIOF1_TXD_A),
+	PINMUX_GFUNC_GPSR(GRP0_20_FUNC, TAUD0O9),
+
+	PINMUX_GFUNC_GPSR(GRP0_19_FUNC, MSIOF1_SCK_A),
+	PINMUX_GFUNC_GPSR(GRP0_19_FUNC, TAUD0O8),
+
+	PINMUX_GFUNC_GPSR(GRP0_18_FUNC, MSIOF0_SS2),
+	PINMUX_GFUNC_GPSR(GRP0_18_FUNC, TAUD0O7),
+
+	PINMUX_GFUNC_GPSR(GRP0_17_FUNC, MSIOF0_SS1),
+	PINMUX_GFUNC_GPSR(GRP0_17_FUNC, TAUD0O6),
+
+	PINMUX_GFUNC_GPSR(GRP0_16_FUNC, MSIOF0_SYNC),
+	PINMUX_GFUNC_GPSR(GRP0_16_FUNC, TAUD0O5),
+
+	PINMUX_GFUNC_GPSR(GRP0_15_FUNC, MSIOF0_RXD),
+	PINMUX_GFUNC_GPSR(GRP0_15_FUNC, TAUD0O4),
+
+	PINMUX_GFUNC_GPSR(GRP0_14_FUNC, MSIOF0_TXD),
+	PINMUX_GFUNC_GPSR(GRP0_14_FUNC, TAUD0O3),
+
+	PINMUX_GFUNC_GPSR(GRP0_13_FUNC, MSIOF0_SCK),
+	PINMUX_GFUNC_GPSR(GRP0_13_FUNC, TAUD0O2),
+
+	PINMUX_GFUNC_GPSR(GRP0_12_FUNC, RXDB_EXTFXR_A),
+	PINMUX_GFUNC_GPSR(GRP0_12_FUNC, CAN11TX),
+	PINMUX_GFUNC_GPSR(GRP0_12_FUNC, RLIN311TX),
+	PINMUX_GFUNC_GPSR(GRP0_12_FUNC, RTCA0OUT_A),
+
+	PINMUX_GFUNC_GPSR(GRP0_11_FUNC, FXR_TXENB_N_A),
+	PINMUX_GFUNC_GPSR(GRP0_11_FUNC, CAN11RX_INTP11),
+	PINMUX_GFUNC_GPSR(GRP0_11_FUNC, RLIN311RX_INTP27),
+	PINMUX_GFUNC_GPSR(GRP0_11_FUNC, EXTCLK0O_A),
+
+	PINMUX_GFUNC_GPSR(GRP0_10_FUNC, FXR_TXDB_A),
+	PINMUX_GFUNC_GPSR(GRP0_10_FUNC, CAN10TX),
+	PINMUX_GFUNC_GPSR(GRP0_10_FUNC, RLIN310TX),
+
+	PINMUX_GFUNC_GPSR(GRP0_9_FUNC, RXDA_EXTFXR_A),
+	PINMUX_GFUNC_GPSR(GRP0_9_FUNC, CAN10RX_INTP10),
+	PINMUX_GFUNC_GPSR(GRP0_9_FUNC, RLIN310RX_INTP26),
+
+	PINMUX_GFUNC_GPSR(GRP0_8_FUNC, FXR_TXENA_N_A),
+	PINMUX_GFUNC_GPSR(GRP0_8_FUNC, CAN9TX),
+	PINMUX_GFUNC_GPSR(GRP0_8_FUNC, RLIN39TX),
+	PINMUX_GFUNC_GPSR(GRP0_8_FUNC, TAUD1O15),
+
+	PINMUX_GFUNC_GPSR(GRP0_7_FUNC, FXR_TXDA_A),
+	PINMUX_GFUNC_GPSR(GRP0_7_FUNC, CAN9RX_INTP9),
+	PINMUX_GFUNC_GPSR(GRP0_7_FUNC, RLIN39RX_INTP25),
+	PINMUX_GFUNC_GPSR(GRP0_7_FUNC, TAUD1O14),
+
+	PINMUX_GFUNC_GPSR(GRP0_6_FUNC, CLK_EXTFXR_A),
+	PINMUX_GFUNC_GPSR(GRP0_6_FUNC, CAN8TX),
+	PINMUX_GFUNC_GPSR(GRP0_6_FUNC, RLIN38TX),
+	PINMUX_GFUNC_GPSR(GRP0_6_FUNC, TAUD1O13),
+
+	PINMUX_GFUNC_GPSR(GRP0_5_FUNC, FXR_CLKOUT2_A),
+	PINMUX_GFUNC_GPSR(GRP0_5_FUNC, CAN8RX_INTP8),
+	PINMUX_GFUNC_GPSR(GRP0_5_FUNC, RLIN38RX_INTP24),
+	PINMUX_GFUNC_GPSR(GRP0_5_FUNC, TAUD1O12),
+
+	PINMUX_GFUNC_GPSR(GRP0_4_FUNC, FXR_CLKOUT1_A),
+	PINMUX_GFUNC_GPSR(GRP0_4_FUNC, CAN7TX),
+	PINMUX_GFUNC_GPSR(GRP0_4_FUNC, RLIN315TX_A),
+	PINMUX_GFUNC_GPSR(GRP0_4_FUNC, TAUD1O11),
+
+	PINMUX_GFUNC_GPSR(GRP0_3_FUNC, STPWT_EXTFXR_A),
+	PINMUX_GFUNC_GPSR(GRP0_3_FUNC, CAN7RX_INTP7),
+	PINMUX_GFUNC_GPSR(GRP0_3_FUNC, RLIN315RX_INTP31_A),
+	PINMUX_GFUNC_GPSR(GRP0_3_FUNC, TAUD1O10),
+
+	/* Group1 Functions */
+	PINMUX_GFUNC_GPSR(GRP1_21_FUNC, RLIN33TX),
+	PINMUX_GFUNC_MSELMARK_GPSR(GRP1_21_FUNC, TAUJ1I3_TAUJ1O3, SEL_TAUJ13_OUTPUT),
+	PINMUX_GFUNC_MSELMARK_GPSR(GRP1_21_FUNC, TAUJ1I3_TAUJ1O3, SEL_TAUJ13_INPUT),
+	PINMUX_GFUNC_GPSR(GRP1_21_FUNC, CAN15TX_A),
+
+	PINMUX_GFUNC_GPSR(GRP1_20_FUNC, RLIN33RX_INTP19),
+	PINMUX_GFUNC_MSELMARK_GPSR(GRP1_20_FUNC, TAUJ1I2_TAUJ1O2, SEL_TAUJ12_OUTPUT),
+	PINMUX_GFUNC_MSELMARK_GPSR(GRP1_20_FUNC, TAUJ1I2_TAUJ1O2, SEL_TAUJ12_INPUT),
+	PINMUX_GFUNC_GPSR(GRP1_20_FUNC, CAN15RX_INTP15_A),
+
+	PINMUX_GFUNC_GPSR(GRP1_19_FUNC, RLIN32TX),
+	PINMUX_GFUNC_MSELMARK_GPSR(GRP1_19_FUNC, TAUJ1I1_TAUJ1O1, SEL_TAUJ11_OUTPUT),
+	PINMUX_GFUNC_MSELMARK_GPSR(GRP1_19_FUNC, TAUJ1I1_TAUJ1O1, SEL_TAUJ11_INPUT),
+	PINMUX_GFUNC_GPSR(GRP1_19_FUNC, CAN14TX_A),
+	PINMUX_GFUNC_GPSR(GRP1_19_FUNC, NMI1_A),
+
+	PINMUX_GFUNC_GPSR(GRP1_18_FUNC, RLIN32RX_INTP18),
+	PINMUX_GFUNC_MSELMARK_GPSR(GRP1_18_FUNC, TAUJ1I0_TAUJ1O0, SEL_TAUJ10_OUTPUT),
+	PINMUX_GFUNC_MSELMARK_GPSR(GRP1_18_FUNC, TAUJ1I0_TAUJ1O0, SEL_TAUJ10_INPUT),
+	PINMUX_GFUNC_GPSR(GRP1_18_FUNC, CAN14RX_INTP14_A),
+	PINMUX_GFUNC_GPSR(GRP1_18_FUNC, INTP34_A),
+
+	PINMUX_GFUNC_GPSR(GRP1_17_FUNC, RLIN31TX),
+	PINMUX_GFUNC_MSELMARK_GPSR(GRP1_17_FUNC, TAUJ3I3_TAUJ3O3, SEL_TAUJ33_OUTPUT),
+	PINMUX_GFUNC_MSELMARK_GPSR(GRP1_17_FUNC, TAUJ3I3_TAUJ3O3, SEL_TAUJ33_INPUT),
+	PINMUX_GFUNC_GPSR(GRP1_17_FUNC, CAN13TX_A),
+	PINMUX_GFUNC_GPSR(GRP1_17_FUNC, INTP33_A),
+
+	PINMUX_GFUNC_GPSR(GRP1_16_FUNC, RLIN31RX_INTP17),
+	PINMUX_GFUNC_MSELMARK_GPSR(GRP1_16_FUNC, TAUJ3I2_TAUJ3O2, SEL_TAUJ32_OUTPUT),
+	PINMUX_GFUNC_MSELMARK_GPSR(GRP1_16_FUNC, TAUJ3I2_TAUJ3O2, SEL_TAUJ32_INPUT),
+	PINMUX_GFUNC_GPSR(GRP1_16_FUNC, CAN13RX_INTP13_A),
+	PINMUX_GFUNC_GPSR(GRP1_16_FUNC, INTP32_A),
+
+	PINMUX_GFUNC_GPSR(GRP1_15_FUNC, RLIN30TX),
+	PINMUX_GFUNC_MSELMARK_GPSR(GRP1_15_FUNC, TAUJ3I1_TAUJ3O1, SEL_TAUJ31_OUTPUT),
+	PINMUX_GFUNC_MSELMARK_GPSR(GRP1_15_FUNC, TAUJ3I1_TAUJ3O1, SEL_TAUJ31_INPUT),
+	PINMUX_GFUNC_GPSR(GRP1_15_FUNC, CAN12TX_A),
+
+	PINMUX_GFUNC_GPSR(GRP1_14_FUNC, RLIN30RX_INTP16),
+	PINMUX_GFUNC_MSELMARK_GPSR(GRP1_14_FUNC, TAUJ3I0_TAUJ3O0, SEL_TAUJ30_OUTPUT),
+	PINMUX_GFUNC_MSELMARK_GPSR(GRP1_14_FUNC, TAUJ3I0_TAUJ3O0, SEL_TAUJ30_INPUT),
+	PINMUX_GFUNC_GPSR(GRP1_14_FUNC, CAN12RX_INTP12_A),
+
+	PINMUX_GFUNC_GPSR(GRP1_13_FUNC, CAN6TX),
+	PINMUX_GFUNC_GPSR(GRP1_13_FUNC, RLIN314TX_A),
+	PINMUX_GFUNC_GPSR(GRP1_13_FUNC, TAUD1O9),
+
+	PINMUX_GFUNC_GPSR(GRP1_12_FUNC, CAN6RX_INTP6),
+	PINMUX_GFUNC_GPSR(GRP1_12_FUNC, RLIN314RX_INTP30_A),
+	PINMUX_GFUNC_GPSR(GRP1_12_FUNC, TAUD1O8),
+
+	PINMUX_GFUNC_GPSR(GRP1_11_FUNC, CAN5TX),
+	PINMUX_GFUNC_GPSR(GRP1_11_FUNC, RLIN313TX_A),
+	PINMUX_GFUNC_GPSR(GRP1_11_FUNC, MSIOF3_SS2),
+	PINMUX_GFUNC_GPSR(GRP1_11_FUNC, RXDB_EXTFXR_B),
+
+	PINMUX_GFUNC_GPSR(GRP1_10_FUNC, CAN5RX_INTP5),
+	PINMUX_GFUNC_GPSR(GRP1_10_FUNC, RLIN313RX_INTP29_A),
+	PINMUX_GFUNC_GPSR(GRP1_10_FUNC, MSIOF3_SS1),
+	PINMUX_GFUNC_GPSR(GRP1_10_FUNC, FXR_TXENB_N_B),
+
+	PINMUX_GFUNC_GPSR(GRP1_9_FUNC, CAN4TX),
+	PINMUX_GFUNC_GPSR(GRP1_9_FUNC, RLIN312TX_A),
+	PINMUX_GFUNC_GPSR(GRP1_9_FUNC, MSIOF3_SYNC),
+	PINMUX_GFUNC_GPSR(GRP1_9_FUNC, FXR_TXDB_B),
+
+	PINMUX_GFUNC_GPSR(GRP1_8_FUNC, CAN4RX_INTP4),
+	PINMUX_GFUNC_GPSR(GRP1_8_FUNC, RLIN312RX_INTP28_A),
+	PINMUX_GFUNC_GPSR(GRP1_8_FUNC, MSIOF3_RXD),
+	PINMUX_GFUNC_GPSR(GRP1_8_FUNC, RXDA_EXTFXR_B),
+
+	PINMUX_GFUNC_GPSR(GRP1_7_FUNC, CAN3TX),
+	PINMUX_GFUNC_GPSR(GRP1_7_FUNC, RLIN37TX_A),
+	PINMUX_GFUNC_GPSR(GRP1_7_FUNC, MSIOF3_TXD),
+	PINMUX_GFUNC_GPSR(GRP1_7_FUNC, FXR_TXENA_N_B),
+
+	PINMUX_GFUNC_GPSR(GRP1_6_FUNC, CAN3RX_INTP3),
+	PINMUX_GFUNC_GPSR(GRP1_6_FUNC, RLIN37RX_INTP23_A),
+	PINMUX_GFUNC_GPSR(GRP1_6_FUNC, MSIOF3_SCK),
+	PINMUX_GFUNC_GPSR(GRP1_6_FUNC, FXR_TXDA_B),
+
+	PINMUX_GFUNC_GPSR(GRP1_5_FUNC, CAN2TX),
+	PINMUX_GFUNC_GPSR(GRP1_5_FUNC, RLIN36TX_A),
+	PINMUX_GFUNC_GPSR(GRP1_5_FUNC, MSIOF2_SS2),
+	PINMUX_GFUNC_GPSR(GRP1_5_FUNC, CLK_EXTFXR_B),
+
+	PINMUX_GFUNC_GPSR(GRP1_4_FUNC, CAN2RX_INTP2),
+	PINMUX_GFUNC_GPSR(GRP1_4_FUNC, RLIN36RX_INTP22_A),
+	PINMUX_GFUNC_GPSR(GRP1_4_FUNC, MSIOF2_SS1),
+	PINMUX_GFUNC_GPSR(GRP1_4_FUNC, FXR_CLKOUT2_B),
+
+	PINMUX_GFUNC_GPSR(GRP1_3_FUNC, CAN1TX),
+	PINMUX_GFUNC_GPSR(GRP1_3_FUNC, RLIN35TX_A),
+	PINMUX_GFUNC_GPSR(GRP1_3_FUNC, MSIOF2_SYNC),
+	PINMUX_GFUNC_GPSR(GRP1_3_FUNC, FXR_CLKOUT1_B),
+
+	PINMUX_GFUNC_GPSR(GRP1_2_FUNC, CAN1RX_INTP1),
+	PINMUX_GFUNC_GPSR(GRP1_2_FUNC, RLIN35RX_INTP21_A),
+	PINMUX_GFUNC_GPSR(GRP1_2_FUNC, MSIOF2_RXD),
+	PINMUX_GFUNC_GPSR(GRP1_2_FUNC, STPWT_EXTFXR_B),
+
+	PINMUX_GFUNC_GPSR(GRP1_1_FUNC, CAN0TX),
+	PINMUX_GFUNC_GPSR(GRP1_1_FUNC, RLIN34TX_A),
+	PINMUX_GFUNC_GPSR(GRP1_1_FUNC, MSIOF2_TXD),
+
+	PINMUX_GFUNC_GPSR(GRP1_0_FUNC, CAN0RX_INTP0),
+	PINMUX_GFUNC_GPSR(GRP1_0_FUNC, RLIN34RX_INTP20_A),
+	PINMUX_GFUNC_GPSR(GRP1_0_FUNC, MSIOF2_SCK),
+
+	/* Group2 Functions */
+	PINMUX_GFUNC_GPSR(GRP2_28_FUNC, INTP34_B),
+
+	PINMUX_GFUNC_GPSR(GRP2_27_FUNC, TAUD1O3),
+
+	PINMUX_GFUNC_GPSR(GRP2_26_FUNC, TAUD1O2),
+
+	PINMUX_GFUNC_GPSR(GRP2_25_FUNC, TAUD1O1),
+
+	PINMUX_GFUNC_GPSR(GRP2_24_FUNC, TAUD1O0),
+
+	PINMUX_GFUNC_GPSR(GRP2_23_FUNC, EXTCLK0O_B),
+
+	PINMUX_GFUNC_GPSR(GRP2_22_FUNC, AVS1),
+
+	PINMUX_GFUNC_GPSR(GRP2_21_FUNC, AVS0),
+
+	PINMUX_GFUNC_MSEL_GPSR(GRP2_20_FUNC, SDA0, SEL_SDA0_1),
+
+	PINMUX_GFUNC_MSEL_GPSR(GRP2_19_FUNC, SCL0, SEL_SCL0_1),
+
+	PINMUX_GFUNC_GPSR(GRP2_18_FUNC, INTP33_B),
+	PINMUX_GFUNC_GPSR(GRP2_18_FUNC, TAUD0O1),
+
+	PINMUX_GFUNC_GPSR(GRP2_17_FUNC, INTP32_B),
+	PINMUX_GFUNC_GPSR(GRP2_17_FUNC, TAUD0O0),
+
+	PINMUX_GFUNC_GPSR(GRP2_16_FUNC, CAN_CLK),
+
+	PINMUX_GFUNC_GPSR(GRP2_15_FUNC, CAN15TX_B),
+	PINMUX_GFUNC_GPSR(GRP2_15_FUNC, RLIN315TX_B),
+
+	PINMUX_GFUNC_GPSR(GRP2_14_FUNC, CAN15RX_B_INTP15),
+	PINMUX_GFUNC_GPSR(GRP2_14_FUNC, RLIN315RX_INTP31_B),
+
+	PINMUX_GFUNC_GPSR(GRP2_13_FUNC, CAN14TX_B),
+	PINMUX_GFUNC_GPSR(GRP2_13_FUNC, RLIN314TX_B),
+
+	PINMUX_GFUNC_GPSR(GRP2_12_FUNC, CAN14RX_B_INTP14),
+	PINMUX_GFUNC_GPSR(GRP2_12_FUNC, RLIN314RX_INTP30_B),
+
+	PINMUX_GFUNC_GPSR(GRP2_11_FUNC, CAN13TX_B),
+	PINMUX_GFUNC_GPSR(GRP2_11_FUNC, RLIN313TX),
+	PINMUX_GFUNC_GPSR(GRP2_11_FUNC, CANXL1_TX),
+
+	PINMUX_GFUNC_GPSR(GRP2_10_FUNC, CAN13RX_B_INTP13),
+	PINMUX_GFUNC_GPSR(GRP2_10_FUNC, RLIN313RX_INTP29_B),
+	PINMUX_GFUNC_GPSR(GRP2_10_FUNC, CANXL1_RX),
+
+	PINMUX_GFUNC_GPSR(GRP2_9_FUNC, CAN12TX_B),
+	PINMUX_GFUNC_GPSR(GRP2_9_FUNC, RLIN312TX),
+	PINMUX_GFUNC_GPSR(GRP2_9_FUNC, TAUD1O7),
+	PINMUX_GFUNC_GPSR(GRP2_9_FUNC, CANXL0_TX),
+
+	PINMUX_GFUNC_GPSR(GRP2_8_FUNC, CAN12RX_B_INTP12),
+	PINMUX_GFUNC_GPSR(GRP2_8_FUNC, RLIN312RX_INTP28_B),
+	PINMUX_GFUNC_GPSR(GRP2_8_FUNC, TAUD1O6),
+	PINMUX_GFUNC_GPSR(GRP2_8_FUNC, CANXL0_RX),
+
+	PINMUX_GFUNC_GPSR(GRP2_7_FUNC, RLIN37TX_B),
+	PINMUX_GFUNC_GPSR(GRP2_7_FUNC, RTCA0OUT_B),
+	PINMUX_GFUNC_GPSR(GRP2_7_FUNC, TAUD1O5),
+
+	PINMUX_GFUNC_GPSR(GRP2_6_FUNC, RLIN37RX_B_INTP23),
+	PINMUX_GFUNC_GPSR(GRP2_6_FUNC, TAUD1O4),
+
+	PINMUX_GFUNC_GPSR(GRP2_5_FUNC, RLIN36TX_B),
+	PINMUX_GFUNC_GPSR(GRP2_5_FUNC, MSIOF1_SS2_B),
+
+	PINMUX_GFUNC_GPSR(GRP2_4_FUNC, RLIN36RX_B_INTP22),
+	PINMUX_GFUNC_GPSR(GRP2_4_FUNC, MSIOF1_SS1_B),
+	PINMUX_GFUNC_GPSR(GRP2_4_FUNC, CTIACK),
+
+	PINMUX_GFUNC_GPSR(GRP2_3_FUNC, RLIN35TX_B),
+	PINMUX_GFUNC_GPSR(GRP2_3_FUNC, MSIOF1_SYN_B),
+	PINMUX_GFUNC_GPSR(GRP2_3_FUNC, CTIREQ),
+
+	PINMUX_GFUNC_GPSR(GRP2_2_FUNC, RLIN35RX_B_INTP21),
+	PINMUX_GFUNC_GPSR(GRP2_2_FUNC, MSIOF1_RXD_B),
+
+	PINMUX_GFUNC_GPSR(GRP2_1_FUNC, RLIN34TX_B),
+	PINMUX_GFUNC_GPSR(GRP2_1_FUNC, MSIOF1_TXD_B),
+	PINMUX_GFUNC_GPSR(GRP2_1_FUNC, TAUD0O15),
+
+	PINMUX_GFUNC_GPSR(GRP2_0_FUNC, RLIN34RX_B_INTP20),
+	PINMUX_GFUNC_GPSR(GRP2_0_FUNC, MSIOF1_SCK_B),
+	PINMUX_GFUNC_GPSR(GRP2_0_FUNC, TAUD0O14),
+
+	/* Group3 Functions */
+	PINMUX_GFUNC_GPSR(GRP3_16_FUNC, ERRORIN0_N),
+
+	PINMUX_GFUNC_GPSR(GRP3_15_FUNC, ERROROUT_N),
+
+	PINMUX_GFUNC_GPSR(GRP3_14_FUNC, QSPI1_SSL),
+
+	PINMUX_GFUNC_GPSR(GRP3_13_FUNC, QSPI1_IO3),
+
+	PINMUX_GFUNC_GPSR(GRP3_12_FUNC, QSPI1_IO2),
+
+	PINMUX_GFUNC_GPSR(GRP3_11_FUNC, QSPI1_MISO_IO1),
+
+	PINMUX_GFUNC_GPSR(GRP3_10_FUNC, QSPI1_MOSI_IO0),
+
+	PINMUX_GFUNC_GPSR(GRP3_9_FUNC, QSPI1_SPCLK),
+
+	PINMUX_GFUNC_GPSR(GRP3_8_FUNC, RPC_INT_N),
+
+	PINMUX_GFUNC_GPSR(GRP3_7_FUNC, RPC_WP_N),
+
+	PINMUX_GFUNC_GPSR(GRP3_6_FUNC, RPC_RESET_N),
+
+	PINMUX_GFUNC_GPSR(GRP3_5_FUNC, QSPI0_SSL),
+
+	PINMUX_GFUNC_GPSR(GRP3_4_FUNC, QSPI0_IO3),
+
+	PINMUX_GFUNC_GPSR(GRP3_3_FUNC, QSPI0_IO2),
+
+	PINMUX_GFUNC_GPSR(GRP3_2_FUNC, QSPI0_MISO_IO1),
+
+	PINMUX_GFUNC_GPSR(GRP3_1_FUNC, QSPI0_MOSI_IO0),
+
+	PINMUX_GFUNC_GPSR(GRP3_0_FUNC, QSPI0_SPCLK),
+
+	/* Group4 Functions */
+	PINMUX_GFUNC_GPSR(GRP4_15_FUNC, PCIE61_CLKREQ_N),
+
+	PINMUX_GFUNC_GPSR(GRP4_14_FUNC, PCIE60_CLKREQ_N),
+
+	PINMUX_GFUNC_GPSR(GRP4_13_FUNC, ERRORIN1_N),
+
+	PINMUX_GFUNC_GPSR(GRP4_12_FUNC, SD0_CD),
+
+	PINMUX_GFUNC_GPSR(GRP4_11_FUNC, SD0_WP),
+
+	PINMUX_GFUNC_GPSR(GRP4_10_FUNC, MMC0_DS),
+
+	PINMUX_GFUNC_GPSR(GRP4_9_FUNC, MMC0_D7),
+
+	PINMUX_GFUNC_GPSR(GRP4_8_FUNC, MMC0_D6),
+
+	PINMUX_GFUNC_GPSR(GRP4_7_FUNC, MMC0_D5),
+
+	PINMUX_GFUNC_GPSR(GRP4_6_FUNC, MMC0_D4),
+
+	PINMUX_GFUNC_GPSR(GRP4_5_FUNC, MMC0_SD_D3),
+
+	PINMUX_GFUNC_GPSR(GRP4_4_FUNC, MMC0_SD_D2),
+
+	PINMUX_GFUNC_GPSR(GRP4_3_FUNC, MMC0_SD_D1),
+
+	PINMUX_GFUNC_GPSR(GRP4_2_FUNC, MMC0_SD_D0),
+
+	PINMUX_GFUNC_GPSR(GRP4_1_FUNC, MMC0_SD_CMD),
+
+	PINMUX_GFUNC_GPSR(GRP4_0_FUNC, MMC0_SD_CLK),
+
+	/* Group5 Functions */
+	PINMUX_GFUNC_GPSR(GRP5_22_FUNC, TPU0TO3),
+	PINMUX_GFUNC_GPSR(GRP5_22_FUNC, SSI9_WS),
+
+	PINMUX_GFUNC_GPSR(GRP5_21_FUNC, TPU0TO2),
+	PINMUX_GFUNC_GPSR(GRP5_21_FUNC, SSI9_SCK),
+
+	PINMUX_GFUNC_GPSR(GRP5_20_FUNC, TPU0TO1),
+	PINMUX_GFUNC_GPSR(GRP5_20_FUNC, PWM5),
+
+	PINMUX_GFUNC_GPSR(GRP5_19_FUNC, TPU0TO0),
+	PINMUX_GFUNC_GPSR(GRP5_19_FUNC, PWM4),
+
+	PINMUX_GFUNC_GPSR(GRP5_18_FUNC, TCLK4),
+	PINMUX_GFUNC_GPSR(GRP5_18_FUNC, PWM3),
+	PINMUX_GFUNC_GPSR(GRP5_18_FUNC, SSI19_SD),
+
+	PINMUX_GFUNC_GPSR(GRP5_17_FUNC, TCLK3),
+	PINMUX_GFUNC_GPSR(GRP5_17_FUNC, PWM2),
+	PINMUX_GFUNC_GPSR(GRP5_17_FUNC, SSI19_WS),
+
+	PINMUX_GFUNC_GPSR(GRP5_16_FUNC, TCLK2),
+	PINMUX_GFUNC_GPSR(GRP5_16_FUNC, PWM1),
+	PINMUX_GFUNC_GPSR(GRP5_16_FUNC, SSI19_SCK),
+
+	PINMUX_GFUNC_GPSR(GRP5_15_FUNC, TCLK1),
+	PINMUX_GFUNC_GPSR(GRP5_15_FUNC, PWM0_A),
+	PINMUX_GFUNC_GPSR(GRP5_15_FUNC, SSI18_SD),
+
+	PINMUX_GFUNC_GPSR(GRP5_14_FUNC, IRQ3_A),
+	PINMUX_GFUNC_GPSR(GRP5_14_FUNC, RIF7_D1),
+
+	PINMUX_GFUNC_GPSR(GRP5_13_FUNC, IRQ2_A),
+	PINMUX_GFUNC_GPSR(GRP5_13_FUNC, SSI17_SD),
+	PINMUX_GFUNC_GPSR(GRP5_13_FUNC, RIF7_D0),
+
+	PINMUX_GFUNC_GPSR(GRP5_12_FUNC, IRQ1_A),
+	PINMUX_GFUNC_GPSR(GRP5_12_FUNC, SSI17_WS),
+	PINMUX_GFUNC_GPSR(GRP5_12_FUNC, RIF7_SYNC),
+
+	PINMUX_GFUNC_GPSR(GRP5_11_FUNC, IRQ0_A),
+	PINMUX_GFUNC_GPSR(GRP5_11_FUNC, SSI17_SCK),
+	PINMUX_GFUNC_GPSR(GRP5_11_FUNC, RIF7_CLK),
+
+	PINMUX_GFUNC_GPSR(GRP5_10_FUNC, HSCK1),
+	PINMUX_GFUNC_GPSR(GRP5_10_FUNC, SCK1),
+	PINMUX_GFUNC_GPSR(GRP5_10_FUNC, SSI13_SCK),
+	PINMUX_GFUNC_GPSR(GRP5_10_FUNC, RIF0_CLK_B),
+
+	PINMUX_GFUNC_GPSR(GRP5_9_FUNC, HCTS1_N),
+	PINMUX_GFUNC_GPSR(GRP5_9_FUNC, CTS1_N),
+
+	PINMUX_GFUNC_GPSR(GRP5_8_FUNC, HRTS1_N),
+	PINMUX_GFUNC_GPSR(GRP5_8_FUNC, RTS1_N),
+	PINMUX_GFUNC_GPSR(GRP5_8_FUNC, RIF0_SYNC_B),
+	PINMUX_GFUNC_GPSR(GRP5_8_FUNC, SSI16_SD),
+
+	PINMUX_GFUNC_GPSR(GRP5_7_FUNC, HRX1),
+	PINMUX_GFUNC_GPSR(GRP5_7_FUNC, RX1),
+	PINMUX_GFUNC_GPSR(GRP5_7_FUNC, SSI16_WS),
+
+	PINMUX_GFUNC_GPSR(GRP5_6_FUNC, HTX1),
+	PINMUX_GFUNC_GPSR(GRP5_6_FUNC, TX1),
+	PINMUX_GFUNC_GPSR(GRP5_6_FUNC, SSI16_SCK),
+
+	PINMUX_GFUNC_GPSR(GRP5_5_FUNC, SCIF_CLK),
+
+	PINMUX_GFUNC_GPSR(GRP5_4_FUNC, HSCK0),
+	PINMUX_GFUNC_GPSR(GRP5_4_FUNC, SCK0),
+	PINMUX_GFUNC_GPSR(GRP5_4_FUNC, SSI15_SD),
+
+	PINMUX_GFUNC_GPSR(GRP5_3_FUNC, HCTS0_N),
+	PINMUX_GFUNC_GPSR(GRP5_3_FUNC, CTS0_N),
+	PINMUX_GFUNC_GPSR(GRP5_3_FUNC, IRQ1_B),
+	PINMUX_GFUNC_GPSR(GRP5_3_FUNC, SSI15_WS),
+
+	PINMUX_GFUNC_GPSR(GRP5_2_FUNC, HRTS0_N),
+	PINMUX_GFUNC_GPSR(GRP5_2_FUNC, RTS0_N),
+	PINMUX_GFUNC_GPSR(GRP5_2_FUNC, IRQ0_B),
+	PINMUX_GFUNC_GPSR(GRP5_2_FUNC, SSI15_SCK),
+
+	PINMUX_GFUNC_GPSR(GRP5_1_FUNC, HRX0),
+	PINMUX_GFUNC_GPSR(GRP5_1_FUNC, RX0),
+	PINMUX_GFUNC_GPSR(GRP5_1_FUNC, SSI13_SD),
+	PINMUX_GFUNC_GPSR(GRP5_1_FUNC, RIF0_D1_B),
+
+	PINMUX_GFUNC_GPSR(GRP5_0_FUNC, HTX0),
+	PINMUX_GFUNC_GPSR(GRP5_0_FUNC, TX0),
+	PINMUX_GFUNC_GPSR(GRP5_0_FUNC, SSI13_WS),
+	PINMUX_GFUNC_GPSR(GRP5_0_FUNC, RIF0_D0_B),
+
+	/* Group6 Functions */
+	PINMUX_GFUNC_GPSR(GRP6_30_FUNC, AUDIO1_CLKOUT1),
+	PINMUX_GFUNC_GPSR(GRP6_30_FUNC, MSIOF7_RXD_B),
+	PINMUX_GFUNC_GPSR(GRP6_30_FUNC, RIF5_CLK),
+
+	PINMUX_GFUNC_GPSR(GRP6_29_FUNC, AUDIO1_CLKOUT0),
+	PINMUX_GFUNC_GPSR(GRP6_29_FUNC, MSIOF7_TXD_B),
+
+	PINMUX_GFUNC_GPSR(GRP6_28_FUNC, SSI2_SD),
+	PINMUX_GFUNC_GPSR(GRP6_28_FUNC, MSIOF7_SCK_B),
+	PINMUX_GFUNC_GPSR(GRP6_28_FUNC, RIF5_SYNC),
+
+	PINMUX_GFUNC_GPSR(GRP6_27_FUNC, SSI2_WS),
+	PINMUX_GFUNC_GPSR(GRP6_27_FUNC, RIF1_D1_A),
+
+	PINMUX_GFUNC_GPSR(GRP6_26_FUNC, SSI2_SCK),
+	PINMUX_GFUNC_GPSR(GRP6_26_FUNC, RIF1_D0_A),
+
+	PINMUX_GFUNC_GPSR(GRP6_25_FUNC, AUDIO0_CLKOUT3),
+	PINMUX_GFUNC_GPSR(GRP6_25_FUNC, RIF1_CLK_A),
+
+	PINMUX_GFUNC_GPSR(GRP6_24_FUNC, AUDIO0_CLKOUT2),
+	PINMUX_GFUNC_GPSR(GRP6_24_FUNC, RIF2_D1),
+
+	PINMUX_GFUNC_GPSR(GRP6_23_FUNC, SSI1_SD),
+	PINMUX_GFUNC_GPSR(GRP6_23_FUNC, HCTS3_N),
+	PINMUX_GFUNC_GPSR(GRP6_23_FUNC, CTS3_N),
+
+	PINMUX_GFUNC_GPSR(GRP6_22_FUNC, SSI1_WS),
+	PINMUX_GFUNC_GPSR(GRP6_22_FUNC, HRTS3_N),
+	PINMUX_GFUNC_GPSR(GRP6_22_FUNC, RTS3_N),
+
+	PINMUX_GFUNC_GPSR(GRP6_21_FUNC, SSI1_SCK),
+	PINMUX_GFUNC_GPSR(GRP6_21_FUNC, MSIOF4_SS2_A),
+	PINMUX_GFUNC_GPSR(GRP6_21_FUNC, HSCK3),
+	PINMUX_GFUNC_GPSR(GRP6_21_FUNC, SCK3),
+
+	PINMUX_GFUNC_GPSR(GRP6_20_FUNC, AUDIO0_CLKOUT1),
+	PINMUX_GFUNC_GPSR(GRP6_20_FUNC, MSIOF4_SS1_A),
+	PINMUX_GFUNC_GPSR(GRP6_20_FUNC, RIF2_D0),
+
+	PINMUX_GFUNC_GPSR(GRP6_19_FUNC, AUDIO0_CLKOUT0),
+	PINMUX_GFUNC_GPSR(GRP6_19_FUNC, MSIOF4_SYNC_A),
+	PINMUX_GFUNC_GPSR(GRP6_19_FUNC, RIF2_SYNC),
+
+	PINMUX_GFUNC_GPSR(GRP6_18_FUNC, SSI0_SD),
+	PINMUX_GFUNC_GPSR(GRP6_18_FUNC, MSIOF4_RXD_A),
+	PINMUX_GFUNC_GPSR(GRP6_18_FUNC, HRX3),
+	PINMUX_GFUNC_GPSR(GRP6_18_FUNC, RX3),
+
+	PINMUX_GFUNC_GPSR(GRP6_17_FUNC, SSI0_WS),
+	PINMUX_GFUNC_GPSR(GRP6_17_FUNC, MSIOF4_TXD_A),
+	PINMUX_GFUNC_GPSR(GRP6_17_FUNC, HTX3),
+	PINMUX_GFUNC_GPSR(GRP6_17_FUNC, TX3),
+
+	PINMUX_GFUNC_GPSR(GRP6_16_FUNC, SSI0_SCK),
+	PINMUX_GFUNC_GPSR(GRP6_16_FUNC, MSIOF4_SCK_A),
+
+	PINMUX_GFUNC_GPSR(GRP6_15_FUNC, MSIOF4_SS2_B),
+	PINMUX_GFUNC_GPSR(GRP6_15_FUNC, SSI14_SD),
+
+	PINMUX_GFUNC_GPSR(GRP6_14_FUNC, MSIOF4_SS1_B),
+	PINMUX_GFUNC_GPSR(GRP6_14_FUNC, SSI12_SD),
+
+	PINMUX_GFUNC_GPSR(GRP6_13_FUNC, MSIOF4_SYNC_B),
+	PINMUX_GFUNC_GPSR(GRP6_13_FUNC, SSI12_WS),
+
+	PINMUX_GFUNC_GPSR(GRP6_12_FUNC, MSIOF4_RXD_B),
+	PINMUX_GFUNC_GPSR(GRP6_12_FUNC, AUDIO_CLKC_B),
+
+	PINMUX_GFUNC_GPSR(GRP6_11_FUNC, MSIOF4_TXD_B),
+	PINMUX_GFUNC_GPSR(GRP6_11_FUNC, SSI12_SCK),
+	PINMUX_GFUNC_GPSR(GRP6_11_FUNC, RIF1_SYNC_A),
+
+	PINMUX_GFUNC_GPSR(GRP6_10_FUNC, MSIOF4_SCK_B),
+	PINMUX_GFUNC_GPSR(GRP6_10_FUNC, AUDIO_CLKB_B),
+
+	PINMUX_GFUNC_GPSR(GRP6_9_FUNC, MSIOF7_SS2_A),
+	PINMUX_GFUNC_GPSR(GRP6_9_FUNC, SSI14_WS),
+
+	PINMUX_GFUNC_GPSR(GRP6_8_FUNC, MSIOF7_SS1_A),
+	PINMUX_GFUNC_GPSR(GRP6_8_FUNC, SSI14_SCK),
+
+	PINMUX_GFUNC_GPSR(GRP6_7_FUNC, MSIOF7_SYNC_A),
+	PINMUX_GFUNC_GPSR(GRP6_7_FUNC, RIF1_D1_B),
+	PINMUX_GFUNC_GPSR(GRP6_7_FUNC, SSI11_SD),
+
+	PINMUX_GFUNC_GPSR(GRP6_6_FUNC, MSIOF7_RXD_A),
+	PINMUX_GFUNC_GPSR(GRP6_6_FUNC, RIF1_D0_B),
+	PINMUX_GFUNC_GPSR(GRP6_6_FUNC, SSI11_WS),
+
+	PINMUX_GFUNC_GPSR(GRP6_5_FUNC, MSIOF7_TXD_A),
+	PINMUX_GFUNC_GPSR(GRP6_5_FUNC, RIF1_SYNC_B),
+	PINMUX_GFUNC_GPSR(GRP6_5_FUNC, SSI11_SCK),
+
+	PINMUX_GFUNC_GPSR(GRP6_4_FUNC, MSIOF7_SCK_A),
+	PINMUX_GFUNC_GPSR(GRP6_4_FUNC, RIF1_CLK_B),
+	PINMUX_GFUNC_GPSR(GRP6_4_FUNC, AUDIO_CLKA_B),
+
+	PINMUX_GFUNC_GPSR(GRP6_3_FUNC, RIF6_CLK),
+	PINMUX_GFUNC_GPSR(GRP6_3_FUNC, SSI10_SD),
+
+	PINMUX_GFUNC_GPSR(GRP6_2_FUNC, RIF6_SYNC),
+	PINMUX_GFUNC_GPSR(GRP6_2_FUNC, SSI10_WS),
+
+	PINMUX_GFUNC_GPSR(GRP6_1_FUNC, RIF6_D1),
+	PINMUX_GFUNC_GPSR(GRP6_1_FUNC, SSI10_SCK),
+
+	PINMUX_GFUNC_GPSR(GRP6_0_FUNC, RIF6_D0),
+	PINMUX_GFUNC_GPSR(GRP6_0_FUNC, SSI9_SD),
+
+	/* Group7 Functions */
+	PINMUX_GFUNC_GPSR(GRP7_30_FUNC, MSIOF6_SS2_B),
+	PINMUX_GFUNC_GPSR(GRP7_30_FUNC, HRX2_B),
+	PINMUX_GFUNC_GPSR(GRP7_30_FUNC, RX4_B),
+
+	PINMUX_GFUNC_GPSR(GRP7_29_FUNC, MSIOF6_SS1_B),
+	PINMUX_GFUNC_GPSR(GRP7_29_FUNC, SSI7_SD),
+
+	PINMUX_GFUNC_GPSR(GRP7_28_FUNC, MSIOF6_SYNC_B),
+	PINMUX_GFUNC_GPSR(GRP7_28_FUNC, SSI7_WS),
+
+	PINMUX_GFUNC_GPSR(GRP7_27_FUNC, MSIOF6_RXD_B),
+	PINMUX_GFUNC_GPSR(GRP7_27_FUNC, SSI7_SCK),
+
+	PINMUX_GFUNC_GPSR(GRP7_26_FUNC, MSIOF6_TXD_B),
+	PINMUX_GFUNC_GPSR(GRP7_26_FUNC, HTX2_B),
+	PINMUX_GFUNC_GPSR(GRP7_26_FUNC, TX4_B),
+
+	PINMUX_GFUNC_GPSR(GRP7_25_FUNC, MSIOF6_SCK_B),
+	PINMUX_GFUNC_GPSR(GRP7_25_FUNC, SSI8_SD),
+
+	PINMUX_GFUNC_GPSR(GRP7_24_FUNC, MSIOF5_SS2),
+	PINMUX_GFUNC_GPSR(GRP7_24_FUNC, HCTS2_N_B),
+	PINMUX_GFUNC_GPSR(GRP7_24_FUNC, CTS4_N_B),
+
+	PINMUX_GFUNC_GPSR(GRP7_23_FUNC, MSIOF5_SS1),
+	PINMUX_GFUNC_GPSR(GRP7_23_FUNC, RIF0_SYNC_A),
+
+	PINMUX_GFUNC_GPSR(GRP7_22_FUNC, MSIOF5_SYNC),
+	PINMUX_GFUNC_GPSR(GRP7_22_FUNC, HRTS2_N_B),
+	PINMUX_GFUNC_GPSR(GRP7_22_FUNC, RTS4_N_B),
+
+	PINMUX_GFUNC_GPSR(GRP7_21_FUNC, MSIOF5_RXD),
+	PINMUX_GFUNC_GPSR(GRP7_21_FUNC, RIF0_D1_A),
+
+	PINMUX_GFUNC_GPSR(GRP7_20_FUNC, MSIOF5_TXD),
+	PINMUX_GFUNC_GPSR(GRP7_20_FUNC, HSCK2_B),
+	PINMUX_GFUNC_GPSR(GRP7_20_FUNC, SCK4_B),
+
+	PINMUX_GFUNC_GPSR(GRP7_19_FUNC, MSIOF6_SS2_A),
+
+	PINMUX_GFUNC_GPSR(GRP7_18_FUNC, MSIOF6_SS1_A),
+
+	PINMUX_GFUNC_GPSR(GRP7_17_FUNC, MSIOF5_SCK),
+
+	PINMUX_GFUNC_GPSR(GRP7_16_FUNC, AUDIO_CLKC_A),
+
+	PINMUX_GFUNC_GPSR(GRP7_15_FUNC, SSI6_SD),
+	PINMUX_GFUNC_GPSR(GRP7_15_FUNC, MSIOF6_RXD_A),
+	PINMUX_GFUNC_GPSR(GRP7_15_FUNC, RIF4_D1),
+
+	PINMUX_GFUNC_GPSR(GRP7_14_FUNC, SSI6_WS),
+	PINMUX_GFUNC_GPSR(GRP7_14_FUNC, MSIOF6_TXD_A),
+	PINMUX_GFUNC_GPSR(GRP7_14_FUNC, RIF4_D0),
+
+	PINMUX_GFUNC_GPSR(GRP7_13_FUNC, SSI6_SCK),
+	PINMUX_GFUNC_GPSR(GRP7_13_FUNC, MSIOF6_SCK_A),
+	PINMUX_GFUNC_GPSR(GRP7_13_FUNC, RIF4_SYNC),
+
+	PINMUX_GFUNC_GPSR(GRP7_12_FUNC, AUDIO_CLKB_A),
+
+	PINMUX_GFUNC_GPSR(GRP7_11_FUNC, SSI5_SD),
+	PINMUX_GFUNC_GPSR(GRP7_11_FUNC, MSIOF6_SYNC_A),
+	PINMUX_GFUNC_GPSR(GRP7_11_FUNC, RIF4_CLK),
+
+	PINMUX_GFUNC_GPSR(GRP7_10_FUNC, SSI5_WS),
+	PINMUX_GFUNC_GPSR(GRP7_10_FUNC, RIF3_SYNC),
+
+	PINMUX_GFUNC_GPSR(GRP7_9_FUNC, SSI5_SCK),
+	PINMUX_GFUNC_GPSR(GRP7_9_FUNC, RIF3_CLK),
+
+	PINMUX_GFUNC_GPSR(GRP7_8_FUNC, AUDIO_CLKA_A),
+
+	PINMUX_GFUNC_GPSR(GRP7_7_FUNC, SSI4_SD),
+	PINMUX_GFUNC_GPSR(GRP7_7_FUNC, RIF3_D1),
+
+	PINMUX_GFUNC_GPSR(GRP7_6_FUNC, SSI4_WS),
+	PINMUX_GFUNC_GPSR(GRP7_6_FUNC, RIF3_D0),
+
+	PINMUX_GFUNC_GPSR(GRP7_5_FUNC, SSI4_SCK),
+	PINMUX_GFUNC_GPSR(GRP7_5_FUNC, RIF2_CLK),
+
+	PINMUX_GFUNC_GPSR(GRP7_4_FUNC, AUDIO1_CLKOUT3),
+	PINMUX_GFUNC_GPSR(GRP7_4_FUNC, RIF0_D0_A),
+
+	PINMUX_GFUNC_GPSR(GRP7_3_FUNC, AUDIO1_CLKOUT2),
+	PINMUX_GFUNC_GPSR(GRP7_3_FUNC, RIF0_CLK_A),
+
+	PINMUX_GFUNC_GPSR(GRP7_2_FUNC, SSI3_SD),
+	PINMUX_GFUNC_GPSR(GRP7_2_FUNC, MSIOF7_SS2_B),
+
+	PINMUX_GFUNC_GPSR(GRP7_1_FUNC, SSI3_WS),
+	PINMUX_GFUNC_GPSR(GRP7_1_FUNC, MSIOF7_SS1_B),
+	PINMUX_GFUNC_GPSR(GRP7_1_FUNC, RIF5_D1),
+
+	PINMUX_GFUNC_GPSR(GRP7_0_FUNC, SSI3_SCK),
+	PINMUX_GFUNC_GPSR(GRP7_0_FUNC, MSIOF7_SYNC_B),
+	PINMUX_GFUNC_GPSR(GRP7_0_FUNC, RIF5_D0),
+
+	/* Group8 Functions */
+	PINMUX_GFUNC_GPSR(GRP8_31_FUNC, S3DA2),
+
+	PINMUX_GFUNC_GPSR(GRP8_30_FUNC, S3CL2),
+
+	PINMUX_GFUNC_GPSR(GRP8_29_FUNC, S3DA1),
+
+	PINMUX_GFUNC_GPSR(GRP8_28_FUNC, S3CL1),
+
+	PINMUX_GFUNC_GPSR(GRP8_27_FUNC, S3DA0),
+
+	PINMUX_GFUNC_GPSR(GRP8_26_FUNC, S3CL0),
+
+	PINMUX_GFUNC_MSEL_GPSR(GRP8_15_FUNC, SDA8, SEL_SDA8_1),
+
+	PINMUX_GFUNC_MSEL_GPSR(GRP8_14_FUNC, SCL8, SEL_SCL8_1),
+
+	PINMUX_GFUNC_MSEL_GPSR(GRP8_13_FUNC, SDA7, SEL_SDA7_1),
+
+	PINMUX_GFUNC_MSEL_GPSR(GRP8_12_FUNC, SCL7, SEL_SCL7_1),
+
+	PINMUX_GFUNC_MSEL_GPSR(GRP8_11_FUNC, SDA6, SEL_SDA6_1),
+
+	PINMUX_GFUNC_MSEL_GPSR(GRP8_10_FUNC, SCL6, SEL_SCL6_1),
+
+	PINMUX_GFUNC_MSEL_GPSR(GRP8_9_FUNC,  SDA5, SEL_SDA5_1),
+
+	PINMUX_GFUNC_MSEL_GPSR(GRP8_8_FUNC,  SCL5, SEL_SCL5_1),
+
+	PINMUX_GFUNC_MSEL_GPSR(GRP8_7_FUNC,  SDA4, SEL_SDA4_1),
+	PINMUX_GFUNC_GPSR(GRP8_7_FUNC, HCTS2_N_A),
+	PINMUX_GFUNC_GPSR(GRP8_7_FUNC, CTS4_N_A),
+	PINMUX_GFUNC_GPSR(GRP8_7_FUNC, PWM7_B),
+
+	PINMUX_GFUNC_MSEL_GPSR(GRP8_6_FUNC,  SCL4, SEL_SCL4_1),
+	PINMUX_GFUNC_GPSR(GRP8_6_FUNC, HRTS2_N_A),
+	PINMUX_GFUNC_GPSR(GRP8_6_FUNC, RTS4_N_A),
+	PINMUX_GFUNC_GPSR(GRP8_6_FUNC, PWM9_B),
+
+	PINMUX_GFUNC_MSEL_GPSR(GRP8_5_FUNC,  SDA3, SEL_SDA3_1),
+	PINMUX_GFUNC_GPSR(GRP8_5_FUNC, HRX2_A),
+	PINMUX_GFUNC_GPSR(GRP8_5_FUNC, RX4_A),
+	PINMUX_GFUNC_GPSR(GRP8_5_FUNC, PWM8_B),
+
+	PINMUX_GFUNC_MSEL_GPSR(GRP8_4_FUNC,  SCL3, SEL_SCL3_1),
+	PINMUX_GFUNC_GPSR(GRP8_4_FUNC, HTX2_A),
+	PINMUX_GFUNC_GPSR(GRP8_4_FUNC, TX4_A),
+	PINMUX_GFUNC_GPSR(GRP8_4_FUNC, PWM6_B),
+
+	PINMUX_GFUNC_MSEL_GPSR(GRP8_3_FUNC,  SDA2, SEL_SDA2_1),
+	PINMUX_GFUNC_GPSR(GRP8_3_FUNC, HSCK2_A),
+	PINMUX_GFUNC_GPSR(GRP8_3_FUNC, SCK4_A),
+
+	PINMUX_GFUNC_MSEL_GPSR(GRP8_2_FUNC,  SCL2, SEL_SCL2_1),
+	PINMUX_GFUNC_GPSR(GRP8_2_FUNC, PWM0_B),
+
+	PINMUX_GFUNC_MSEL_GPSR(GRP8_1_FUNC,  SDA1, SEL_SDA1_1),
+
+	PINMUX_GFUNC_MSEL_GPSR(GRP8_0_FUNC,  SCL1, SEL_SCL1_1),
+
+	/* Group9 Functions */
+	PINMUX_GFUNC_GPSR(GRP9_16_FUNC, RSW3_MATCH),
+	PINMUX_GFUNC_GPSR(GRP9_16_FUNC, PWM9_A),
+
+	PINMUX_GFUNC_GPSR(GRP9_15_FUNC, RSW3_CAPTURE),
+	PINMUX_GFUNC_GPSR(GRP9_15_FUNC, PWM8_A),
+
+	PINMUX_GFUNC_GPSR(GRP9_14_FUNC, RSW3_PPS),
+
+	PINMUX_GFUNC_GPSR(GRP9_13_FUNC, ETH10G0_PHYINT),
+	PINMUX_GFUNC_GPSR(GRP9_13_FUNC, ETH10G1_PHYINT),
+
+	PINMUX_GFUNC_GPSR(GRP9_12_FUNC, ETH10G0_LINK),
+	PINMUX_GFUNC_GPSR(GRP9_12_FUNC, ETH10G1_LINK),
+	PINMUX_GFUNC_GPSR(GRP9_12_FUNC, PWM7_A),
+
+	PINMUX_GFUNC_GPSR(GRP9_11_FUNC, ETH10G0_MDC),
+	PINMUX_GFUNC_GPSR(GRP9_11_FUNC, ETH10G1_MDC),
+	PINMUX_GFUNC_GPSR(GRP9_11_FUNC, IRQ3_B),
+
+	PINMUX_GFUNC_GPSR(GRP9_10_FUNC, ETH10G0_MDIO),
+	PINMUX_GFUNC_GPSR(GRP9_10_FUNC, ETH10G1_MDIO),
+	PINMUX_GFUNC_GPSR(GRP9_10_FUNC, IRQ2_B),
+
+	PINMUX_GFUNC_GPSR(GRP9_9_FUNC, ETH25G0_PHYINT),
+	PINMUX_GFUNC_GPSR(GRP9_9_FUNC, ETH25G1_PHYINT),
+	PINMUX_GFUNC_GPSR(GRP9_9_FUNC, ETH25G2_PHYINT),
+
+	PINMUX_GFUNC_GPSR(GRP9_8_FUNC, ETH25G0_LINK),
+	PINMUX_GFUNC_GPSR(GRP9_8_FUNC, ETH25G1_LINK),
+	PINMUX_GFUNC_GPSR(GRP9_8_FUNC, ETH25G2_LINK),
+	PINMUX_GFUNC_GPSR(GRP9_8_FUNC, PWM6_A),
+
+	PINMUX_GFUNC_GPSR(GRP9_7_FUNC, ETH25G0_MDC),
+	PINMUX_GFUNC_GPSR(GRP9_7_FUNC, ETH25G1_MDC),
+	PINMUX_GFUNC_GPSR(GRP9_7_FUNC, ETH25G2_MDC),
+
+	PINMUX_GFUNC_GPSR(GRP9_6_FUNC, ETH25G0_MDIO),
+	PINMUX_GFUNC_GPSR(GRP9_6_FUNC, ETH25G1_MDIO),
+	PINMUX_GFUNC_GPSR(GRP9_6_FUNC, ETH25G2_MDIO),
+
+	PINMUX_GFUNC_GPSR(GRP9_5_FUNC, ETHES4_MATCH),
+	PINMUX_GFUNC_GPSR(GRP9_5_FUNC, ETHES5_MATCH),
+	PINMUX_GFUNC_GPSR(GRP9_5_FUNC, ETHES6_MATCH),
+	PINMUX_GFUNC_GPSR(GRP9_5_FUNC, ETHES7_MATCH),
+
+	PINMUX_GFUNC_GPSR(GRP9_4_FUNC, ETHES4_CAPTURE),
+	PINMUX_GFUNC_GPSR(GRP9_4_FUNC, ETHES5_CAPTURE),
+	PINMUX_GFUNC_GPSR(GRP9_4_FUNC, ETHES6_CAPTURE),
+	PINMUX_GFUNC_GPSR(GRP9_4_FUNC, ETHES7_CAPTURE),
+
+	PINMUX_GFUNC_GPSR(GRP9_3_FUNC, ETHES4_PPS),
+	PINMUX_GFUNC_GPSR(GRP9_3_FUNC, ETHES5_PPS),
+	PINMUX_GFUNC_GPSR(GRP9_3_FUNC, ETHES6_PPS),
+	PINMUX_GFUNC_GPSR(GRP9_3_FUNC, ETHES7_PPS),
+
+	PINMUX_GFUNC_GPSR(GRP9_2_FUNC, ETHES0_MATCH),
+	PINMUX_GFUNC_GPSR(GRP9_2_FUNC, ETHES1_MATCH),
+	PINMUX_GFUNC_GPSR(GRP9_2_FUNC, ETHES2_MATCH),
+	PINMUX_GFUNC_GPSR(GRP9_2_FUNC, ETHES3_MATCH),
+
+	PINMUX_GFUNC_GPSR(GRP9_1_FUNC, ETHES0_CAPTURE),
+	PINMUX_GFUNC_GPSR(GRP9_1_FUNC, ETHES1_CAPTURE),
+	PINMUX_GFUNC_GPSR(GRP9_1_FUNC, ETHES2_CAPTURE),
+	PINMUX_GFUNC_GPSR(GRP9_1_FUNC, ETHES3_CAPTURE),
+
+	PINMUX_GFUNC_GPSR(GRP9_0_FUNC, ETHES0_PPS),
+	PINMUX_GFUNC_GPSR(GRP9_0_FUNC, ETHES1_PPS),
+	PINMUX_GFUNC_GPSR(GRP9_0_FUNC, ETHES2_PPS),
+	PINMUX_GFUNC_GPSR(GRP9_0_FUNC, ETHES3_PPS),
+
+	/* Group10 Functions */
+	PINMUX_GFUNC_GPSR(GRP10_13_FUNC, PCIE41_CLKREQ_N),
+
+	PINMUX_GFUNC_GPSR(GRP10_12_FUNC, PCIE40_CLKREQ_N),
+
+	PINMUX_GFUNC_GPSR(GRP10_11_FUNC, USB3_VBUS_VALID),
+
+	PINMUX_GFUNC_GPSR(GRP10_10_FUNC, USB3_OVC),
+
+	PINMUX_GFUNC_GPSR(GRP10_9_FUNC, USB3_PWEN),
+
+	PINMUX_GFUNC_GPSR(GRP10_8_FUNC, USB2_VBUS_VALID),
+
+	PINMUX_GFUNC_GPSR(GRP10_7_FUNC, USB2_OVC),
+
+	PINMUX_GFUNC_GPSR(GRP10_6_FUNC, USB2_PWEN),
+
+	PINMUX_GFUNC_GPSR(GRP10_5_FUNC, USB1_VBUS_VALID),
+
+	PINMUX_GFUNC_GPSR(GRP10_4_FUNC, USB1_OVC),
+
+	PINMUX_GFUNC_GPSR(GRP10_3_FUNC, USB1_PWEN),
+
+	PINMUX_GFUNC_GPSR(GRP10_2_FUNC, USB0_VBUS_VALID),
+
+	PINMUX_GFUNC_GPSR(GRP10_1_FUNC, USB0_OVC),
+
+	PINMUX_GFUNC_GPSR(GRP10_0_FUNC, USB0_PWEN),
+
+};
+
+/*
+ * Pins not associated with a GPIO port.
+ * TODO: Define for None GPIO pins.
+ */
+enum {
+	GP_ASSIGN_LAST(),
+	//NOGP_ALL(),
+};
+
+static const struct sh_pfc_pin pinmux_pins[] = {
+	PINMUX_GPIO_GP_ALL(),
+	// TODO: Define for None GPIO pins.
+	//PINMUX_NOGP_ALL(),
+};
+
+/* - HSCIF0 ----------------------------------------------------------------- */
+static const unsigned int hscif0_data_pins[] = {
+	/* HRX0, HTX0 */
+	RCAR_GP_PIN(5, 1), RCAR_GP_PIN(5, 0),
+};
+static const unsigned int hscif0_data_mux[] = {
+	HRX0_MARK, HTX0_MARK,
+};
+static const unsigned int hscif0_clk_pins[] = {
+	/* HSCK0 */
+	RCAR_GP_PIN(5, 4),
+};
+static const unsigned int hscif0_clk_mux[] = {
+	HSCK0_MARK,
+};
+static const unsigned int hscif0_ctrl_pins[] = {
+	/* HRTS0_N, HCTS0_N */
+	RCAR_GP_PIN(5, 2), RCAR_GP_PIN(5, 3),
+};
+static const unsigned int hscif0_ctrl_mux[] = {
+	HRTS0_N_MARK, HCTS0_N_MARK,
+};
+
+/* - HSCIF1 ----------------------------------------------------------------- */
+static const unsigned int hscif1_data_pins[] = {
+	/* HRX1, HTX1 */
+	RCAR_GP_PIN(5, 7), RCAR_GP_PIN(5, 6),
+};
+static const unsigned int hscif1_data_mux[] = {
+	HRX1_MARK, HTX1_MARK,
+};
+static const unsigned int hscif1_clk_pins[] = {
+	/* HSCK1 */
+	RCAR_GP_PIN(5, 10),
+};
+static const unsigned int hscif1_clk_mux[] = {
+	HSCK1_MARK,
+};
+static const unsigned int hscif1_ctrl_pins[] = {
+	/* HRTS1_N, HCTS1_N */
+	RCAR_GP_PIN(5, 8), RCAR_GP_PIN(5, 9),
+};
+static const unsigned int hscif1_ctrl_mux[] = {
+	HRTS1_N_MARK, HCTS1_N_MARK,
+};
+
+/* - HSCIF2 ----------------------------------------------------------------- */
+static const unsigned int hscif2_data_a_pins[] = {
+	/* HRX2_A, HTX2_A */
+	RCAR_GP_PIN(8, 5), RCAR_GP_PIN(8, 4),
+};
+static const unsigned int hscif2_data_a_mux[] = {
+	HRX2_A_MARK, HTX2_A_MARK,
+};
+static const unsigned int hscif2_clk_a_pins[] = {
+	/* HSCK2_A */
+	RCAR_GP_PIN(8, 3),
+};
+static const unsigned int hscif2_clk_a_mux[] = {
+	HSCK2_A_MARK,
+};
+static const unsigned int hscif2_ctrl_a_pins[] = {
+	/* HRTS2_A_N, HCTS2_A_N */
+	RCAR_GP_PIN(8, 6), RCAR_GP_PIN(8, 7),
+};
+static const unsigned int hscif2_ctrl_a_mux[] = {
+	HRTS2_N_A_MARK, HCTS2_N_A_MARK,
+};
+
+static const unsigned int hscif2_data_b_pins[] = {
+	/* HRX2_B, HTX2_B */
+	RCAR_GP_PIN(7, 30), RCAR_GP_PIN(7, 26),
+};
+static const unsigned int hscif2_data_b_mux[] = {
+	HRX2_B_MARK, HTX2_B_MARK,
+};
+static const unsigned int hscif2_clk_b_pins[] = {
+	/* HSCK2_B */
+	RCAR_GP_PIN(7, 20),
+};
+static const unsigned int hscif2_clk_b_mux[] = {
+	HSCK2_B_MARK,
+};
+static const unsigned int hscif2_ctrl_b_pins[] = {
+	/* HRTS2_B_N, HCTS2_B_N */
+	RCAR_GP_PIN(7, 22), RCAR_GP_PIN(7, 24),
+};
+static const unsigned int hscif2_ctrl_b_mux[] = {
+	HRTS2_N_B_MARK, HCTS2_N_B_MARK,
+};
+
+/* - HSCIF3 ----------------------------------------------------------------- */
+static const unsigned int hscif3_data_pins[] = {
+	/* HRX3, HTX3 */
+	RCAR_GP_PIN(6, 18), RCAR_GP_PIN(8, 17),
+};
+static const unsigned int hscif3_data_mux[] = {
+	HRX3_MARK, HTX3_MARK,
+};
+static const unsigned int hscif3_clk_pins[] = {
+	/* HSCK3 */
+	RCAR_GP_PIN(6, 21),
+};
+static const unsigned int hscif3_clk_mux[] = {
+	HSCK3_MARK,
+};
+static const unsigned int hscif3_ctrl_pins[] = {
+	/* HRTS3_N, HCTS3_N */
+	RCAR_GP_PIN(6, 22), RCAR_GP_PIN(6, 23),
+};
+static const unsigned int hscif3_ctrl_mux[] = {
+	HRTS3_N_MARK, HCTS3_N_MARK,
+};
+
+/* - SCIF0 ----------------------------------------------------------------- */
+static const unsigned int scif0_data_pins[] = {
+	/* RX0, TX0 */
+	RCAR_GP_PIN(5, 1), RCAR_GP_PIN(5, 0),
+};
+static const unsigned int scif0_data_mux[] = {
+	RX0_MARK, TX0_MARK,
+};
+static const unsigned int scif0_clk_pins[] = {
+	/* SCK0 */
+	RCAR_GP_PIN(5, 4),
+};
+static const unsigned int scif0_clk_mux[] = {
+	SCK0_MARK,
+};
+static const unsigned int scif0_ctrl_pins[] = {
+	/* RTS0_N, CTS0_N */
+	RCAR_GP_PIN(5, 2), RCAR_GP_PIN(5, 3),
+};
+static const unsigned int scif0_ctrl_mux[] = {
+	RTS0_N_MARK, CTS0_N_MARK,
+};
+
+/* - SCIF1 ----------------------------------------------------------------- */
+static const unsigned int scif1_data_pins[] = {
+	/* RX1, TX1 */
+	RCAR_GP_PIN(5, 7), RCAR_GP_PIN(5, 6),
+};
+static const unsigned int scif1_data_mux[] = {
+	RX1_MARK, TX1_MARK,
+};
+static const unsigned int scif1_clk_pins[] = {
+	/* SCK1 */
+	RCAR_GP_PIN(5, 10),
+};
+static const unsigned int scif1_clk_mux[] = {
+	SCK1_MARK,
+};
+static const unsigned int scif1_ctrl_pins[] = {
+	/* RTS1_N, CTS1_N */
+	RCAR_GP_PIN(5, 8), RCAR_GP_PIN(5, 9),
+};
+static const unsigned int scif1_ctrl_mux[] = {
+	RTS1_N_MARK, CTS1_N_MARK,
+};
+
+/* - SCIF3 ----------------------------------------------------------------- */
+static const unsigned int scif3_data_pins[] = {
+	/* RX3, TX3 */
+	RCAR_GP_PIN(6, 18), RCAR_GP_PIN(8, 17),
+};
+static const unsigned int scif3_data_mux[] = {
+	RX3_MARK, TX3_MARK,
+};
+static const unsigned int scif3_clk_pins[] = {
+	/* SCK3 */
+	RCAR_GP_PIN(6, 21),
+};
+static const unsigned int scif3_clk_mux[] = {
+	SCK3_MARK,
+};
+static const unsigned int scif3_ctrl_pins[] = {
+	/* RTS3_N, CTS3_N */
+	RCAR_GP_PIN(6, 22), RCAR_GP_PIN(6, 23),
+};
+static const unsigned int scif3_ctrl_mux[] = {
+	RTS3_N_MARK, CTS3_N_MARK,
+};
+
+/* - SCIF4 ----------------------------------------------------------------- */
+static const unsigned int scif4_data_a_pins[] = {
+	/* RX4_A, TX4_A */
+	RCAR_GP_PIN(8, 5), RCAR_GP_PIN(8, 4),
+};
+static const unsigned int scif4_data_a_mux[] = {
+	RX4_A_MARK, TX4_A_MARK,
+};
+static const unsigned int scif4_clk_a_pins[] = {
+	/* SCK4_A */
+	RCAR_GP_PIN(8, 3),
+};
+static const unsigned int scif4_clk_a_mux[] = {
+	SCK4_A_MARK,
+};
+static const unsigned int scif4_ctrl_a_pins[] = {
+	/* RTS4_A_N, CTS4_A_N */
+	RCAR_GP_PIN(8, 6), RCAR_GP_PIN(8, 7),
+};
+static const unsigned int scif4_ctrl_a_mux[] = {
+	RTS4_N_A_MARK, CTS4_N_A_MARK,
+};
+
+static const unsigned int scif4_data_b_pins[] = {
+	/* RX4_B, TX4_B */
+	RCAR_GP_PIN(7, 30), RCAR_GP_PIN(7, 26),
+};
+static const unsigned int scif4_data_b_mux[] = {
+	RX4_B_MARK, TX4_B_MARK,
+};
+static const unsigned int scif4_clk_b_pins[] = {
+	/* SCK4_B */
+	RCAR_GP_PIN(7, 20),
+};
+static const unsigned int scif4_clk_b_mux[] = {
+	SCK4_B_MARK,
+};
+static const unsigned int scif4_ctrl_b_pins[] = {
+	/* RTS4_B_N, CTS4_B_N */
+	RCAR_GP_PIN(7, 22), RCAR_GP_PIN(7, 24),
+};
+static const unsigned int scif4_ctrl_b_mux[] = {
+	RTS4_N_B_MARK, CTS4_N_B_MARK,
+};
+
+/* - SCIF Clock ------------------------------------------------------------- */
+static const unsigned int scif_clk_pins[] = {
+	/* SCIF_CLK */
+	RCAR_GP_PIN(5, 5),
+};
+static const unsigned int scif_clk_mux[] = {
+	SCIF_CLK_MARK,
+};
+
+/* - I2C0 ------------------------------------------------------------------- */
+static const unsigned int i2c0_pins[] = {
+	/* SDA0, SCL0 */
+	RCAR_GP_PIN(2, 20), RCAR_GP_PIN(2, 19),
+};
+static const unsigned int i2c0_mux[] = {
+	SDA0_MARK, SCL0_MARK,
+};
+
+/* - I2C1 ------------------------------------------------------------------- */
+static const unsigned int i2c1_pins[] = {
+	/* SDA1, SCL1 */
+	RCAR_GP_PIN(8, 1), RCAR_GP_PIN(8, 0),
+};
+static const unsigned int i2c1_mux[] = {
+	SDA1_MARK, SCL1_MARK,
+};
+
+/* - I2C2 ------------------------------------------------------------------- */
+static const unsigned int i2c2_pins[] = {
+	/* SDA2, SCL2 */
+	RCAR_GP_PIN(8, 3), RCAR_GP_PIN(8, 2),
+};
+static const unsigned int i2c2_mux[] = {
+	SDA2_MARK, SCL2_MARK,
+};
+
+/* - I2C3 ------------------------------------------------------------------- */
+static const unsigned int i2c3_pins[] = {
+	/* SDA3, SCL3 */
+	RCAR_GP_PIN(8, 5), RCAR_GP_PIN(8, 4),
+};
+static const unsigned int i2c3_mux[] = {
+	SDA3_MARK, SCL3_MARK,
+};
+
+/* - I2C4 ------------------------------------------------------------------- */
+static const unsigned int i2c4_pins[] = {
+	/* SDA4, SCL4 */
+	RCAR_GP_PIN(8, 7), RCAR_GP_PIN(8, 6),
+};
+static const unsigned int i2c4_mux[] = {
+	SDA4_MARK, SCL4_MARK,
+};
+
+/* - I2C5 ------------------------------------------------------------------- */
+static const unsigned int i2c5_pins[] = {
+	/* SDA5, SCL5 */
+	RCAR_GP_PIN(8, 9), RCAR_GP_PIN(8, 8),
+};
+static const unsigned int i2c5_mux[] = {
+	SDA5_MARK, SCL5_MARK,
+};
+
+/* - I2C6 ------------------------------------------------------------------- */
+static const unsigned int i2c6_pins[] = {
+	/* SDA6, SCL6 */
+	RCAR_GP_PIN(8, 11), RCAR_GP_PIN(8, 10),
+};
+static const unsigned int i2c6_mux[] = {
+	SDA6_MARK, SCL6_MARK,
+};
+
+/* - I2C7 ------------------------------------------------------------------- */
+static const unsigned int i2c7_pins[] = {
+	/* SDA7, SCL7 */
+	RCAR_GP_PIN(8, 13), RCAR_GP_PIN(8, 12),
+};
+static const unsigned int i2c7_mux[] = {
+	SDA7_MARK, SCL7_MARK,
+};
+
+/* - I2C8 ------------------------------------------------------------------- */
+static const unsigned int i2c8_pins[] = {
+	/* SDA8, SCL8 */
+	RCAR_GP_PIN(8, 15), RCAR_GP_PIN(8, 14),
+};
+static const unsigned int i2c8_mux[] = {
+	SDA8_MARK, SCL8_MARK,
+};
+
+/* - INTC-EX ---------------------------------------------------------------- */
+static const unsigned int intc_ex_irq0_pins[] = {
+	/* IRQ0_A, IRQ0_B */
+	RCAR_GP_PIN(5, 11), RCAR_GP_PIN(5, 2),
+};
+static const unsigned int intc_ex_irq0_mux[] = {
+	IRQ0_A_MARK, IRQ0_B_MARK,
+};
+static const unsigned int intc_ex_irq1_pins[] = {
+	/* IRQ1_A, IRQ1_B */
+	RCAR_GP_PIN(5, 12), RCAR_GP_PIN(5, 3),
+};
+static const unsigned int intc_ex_irq1_mux[] = {
+	IRQ1_A_MARK, IRQ1_B_MARK,
+};
+static const unsigned int intc_ex_irq2_pins[] = {
+	/* IRQ2_A, IRQ2_B */
+	RCAR_GP_PIN(5, 13), RCAR_GP_PIN(9, 10),
+};
+static const unsigned int intc_ex_irq2_mux[] = {
+	IRQ2_A_MARK, IRQ2_B_MARK,
+};
+static const unsigned int intc_ex_irq3_pins[] = {
+	/* IRQ3_A, IRQ3_B */
+	RCAR_GP_PIN(5, 14), RCAR_GP_PIN(9, 11),
+};
+static const unsigned int intc_ex_irq3_mux[] = {
+	IRQ3_A_MARK, IRQ3_B_MARK,
+};
+
+/* - PCIE4 ------------------------------------------------------------------- */
+static const unsigned int pcie40_clkreq_n_pins[] = {
+	/* PCIE40_CLKREQ_N */
+	RCAR_GP_PIN(10, 12),
+};
+
+static const unsigned int pcie40_clkreq_n_mux[] = {
+	PCIE40_CLKREQ_N_MARK,
+};
+
+static const unsigned int pcie41_clkreq_n_pins[] = {
+	/* PCIE41_CLKREQ_N */
+	RCAR_GP_PIN(10, 13),
+};
+
+static const unsigned int pcie41_clkreq_n_mux[] = {
+	PCIE41_CLKREQ_N_MARK,
+};
+
+/* - PCIE6 ------------------------------------------------------------------- */
+static const unsigned int pcie60_clkreq_n_pins[] = {
+	/* PCIE60_CLKREQ_N */
+	RCAR_GP_PIN(4, 14),
+};
+
+static const unsigned int pcie60_clkreq_n_mux[] = {
+	PCIE60_CLKREQ_N_MARK,
+};
+
+static const unsigned int pcie61_clkreq_n_pins[] = {
+	/* PCIE61_CLKREQ_N */
+	RCAR_GP_PIN(4, 15),
+};
+
+static const unsigned int pcie61_clkreq_n_mux[] = {
+	PCIE61_CLKREQ_N_MARK,
+};
+
+/* - QSPI0 ------------------------------------------------------------------ */
+static const unsigned int qspi0_ctrl_pins[] = {
+	/* SPCLK, SSL */
+	RCAR_GP_PIN(3, 0), RCAR_GP_PIN(3, 5),
+};
+static const unsigned int qspi0_ctrl_mux[] = {
+	QSPI0_SPCLK_MARK, QSPI0_SSL_MARK,
+};
+static const unsigned int qspi0_data_pins[] = {
+	/* MOSI_IO0, MISO_IO1, IO2, IO3 */
+	RCAR_GP_PIN(3, 1), RCAR_GP_PIN(3, 2),
+	RCAR_GP_PIN(3, 3), RCAR_GP_PIN(3, 4),
+};
+static const unsigned int qspi0_data_mux[] = {
+	QSPI0_MOSI_IO0_MARK, QSPI0_MISO_IO1_MARK,
+	QSPI0_IO2_MARK, QSPI0_IO3_MARK,
+};
+
+/* - QSPI1 ------------------------------------------------------------------ */
+static const unsigned int qspi1_ctrl_pins[] = {
+	/* SPCLK, SSL */
+	RCAR_GP_PIN(3, 9), RCAR_GP_PIN(3, 14),
+};
+static const unsigned int qspi1_ctrl_mux[] = {
+	QSPI1_SPCLK_MARK, QSPI1_SSL_MARK,
+};
+static const unsigned int qspi1_data_pins[] = {
+	/* MOSI_IO0, MISO_IO1, IO2, IO3 */
+	RCAR_GP_PIN(3, 10), RCAR_GP_PIN(3, 11),
+	RCAR_GP_PIN(3, 12), RCAR_GP_PIN(3, 13),
+};
+static const unsigned int qspi1_data_mux[] = {
+	QSPI1_MOSI_IO0_MARK, QSPI1_MISO_IO1_MARK,
+	QSPI1_IO2_MARK, QSPI1_IO3_MARK,
+};
+
+/* - SDHI/MMC0 --------------------------------------------------------------- */
+static const unsigned int mmc0_data_pins[] = {
+	/* MMC0_SD_D[0:3], MMC0_D[4:7] */
+	RCAR_GP_PIN(4, 2), RCAR_GP_PIN(4, 3),
+	RCAR_GP_PIN(4, 4), RCAR_GP_PIN(4, 5),
+	RCAR_GP_PIN(4, 6), RCAR_GP_PIN(4, 7),
+	RCAR_GP_PIN(4, 8), RCAR_GP_PIN(4, 9),
+};
+static const unsigned int mmc0_data_mux[] = {
+	MMC0_SD_D0_MARK, MMC0_SD_D1_MARK,
+	MMC0_SD_D2_MARK, MMC0_SD_D3_MARK,
+	MMC0_D4_MARK, MMC0_D5_MARK,
+	MMC0_D6_MARK, MMC0_D7_MARK,
+};
+static const unsigned int mmc0_ctrl_pins[] = {
+	/* MMC0_SD_CLK, MMC0_SD_CMD */
+	RCAR_GP_PIN(4, 0), RCAR_GP_PIN(4, 1),
+};
+static const unsigned int mmc0_ctrl_mux[] = {
+	MMC0_SD_CLK_MARK, MMC0_SD_CMD_MARK,
+};
+static const unsigned int mmc0_cd_pins[] = {
+	/* SD0_CD */
+	RCAR_GP_PIN(4, 12),
+};
+static const unsigned int mmc0_cd_mux[] = {
+	SD0_CD_MARK,
+};
+static const unsigned int mmc0_wp_pins[] = {
+	/* SD0_WP */
+	RCAR_GP_PIN(4, 11),
+};
+static const unsigned int mmc0_wp_mux[] = {
+	SD0_WP_MARK,
+};
+static const unsigned int mmc0_ds_pins[] = {
+	/* MMC0_DS */
+	RCAR_GP_PIN(4, 10),
+};
+static const unsigned int mmc0_ds_mux[] = {
+	MMC0_DS_MARK,
+};
+
+/* - RSW3 ------------------------------------------------------------------ */
+static const unsigned int rsw3_match_pins[] = {
+	/* RSW3_MATCH */
+	RCAR_GP_PIN(9, 16),
+};
+static const unsigned int rsw3_match_mux[] = {
+	RSW3_MATCH_MARK,
+};
+static const unsigned int rsw3_capture_pins[] = {
+	/* RSW3_CAPTURE */
+	RCAR_GP_PIN(9, 15),
+};
+static const unsigned int rsw3_capture_mux[] = {
+	RSW3_CAPTURE_MARK,
+};
+static const unsigned int rsw3_pps_pins[] = {
+	/* RSW3_PPS */
+	RCAR_GP_PIN(9, 14),
+};
+static const unsigned int rsw3_pps_mux[] = {
+	RSW3_PPS_MARK,
+};
+
+/* - TSN0 ------------------------------------------------ */
+static const unsigned int eth10g0_link_pins[] = {
+	/* ETH10G0_LINK */
+	RCAR_GP_PIN(9, 12),
+};
+static const unsigned int eth10g0_link_mux[] = {
+	ETH10G0_LINK_MARK,
+};
+static const unsigned int eth10g0_phyint_pins[] = {
+	/* ETH10G0_PHYINT */
+	RCAR_GP_PIN(9, 13),
+};
+static const unsigned int eth10g0_phyint_mux[] = {
+	ETH10G0_PHYINT_MARK,
+};
+static const unsigned int eth10g0_mdio_pins[] = {
+	/* ETH10G0_MDC, ETH10G0_MDIO */
+	RCAR_GP_PIN(9, 11), RCAR_GP_PIN(9, 10),
+};
+static const unsigned int eth10g0_mdio_mux[] = {
+	ETH10G0_MDC_MARK, ETH10G0_MDIO_MARK,
+};
+
+static const unsigned int eth25g0_link_pins[] = {
+	/* ETH25G0_LINK */
+	RCAR_GP_PIN(9, 8),
+};
+static const unsigned int eth25g0_link_mux[] = {
+	ETH25G0_LINK_MARK,
+};
+static const unsigned int eth25g0_phyint_pins[] = {
+	/* ETH25G0_PHYINT */
+	RCAR_GP_PIN(9, 9),
+};
+static const unsigned int eth25g0_phyint_mux[] = {
+	ETH25G0_PHYINT_MARK,
+};
+static const unsigned int eth25g0_mdio_pins[] = {
+	/* ETH25G0_MDC, ETH25G0_MDIO */
+	RCAR_GP_PIN(9, 7), RCAR_GP_PIN(9, 6),
+};
+static const unsigned int eth25g0_mdio_mux[] = {
+	ETH25G0_MDC_MARK, ETH25G0_MDIO_MARK,
+};
+
+/* - TSN1 ------------------------------------------------ */
+static const unsigned int eth10g1_link_pins[] = {
+	/* ETH10G1_LINK */
+	RCAR_GP_PIN(9, 12),
+};
+static const unsigned int eth10g1_link_mux[] = {
+	ETH10G1_LINK_MARK,
+};
+static const unsigned int eth10g1_phyint_pins[] = {
+	/* ETH10G1_PHYINT */
+	RCAR_GP_PIN(9, 13),
+};
+static const unsigned int eth10g1_phyint_mux[] = {
+	ETH10G1_PHYINT_MARK,
+};
+static const unsigned int eth10g1_mdio_pins[] = {
+	/* ETH10G1_MDC, ETH10G1_MDIO */
+	RCAR_GP_PIN(9, 11), RCAR_GP_PIN(9, 10),
+};
+static const unsigned int eth10g1_mdio_mux[] = {
+	ETH10G1_MDC_MARK, ETH10G1_MDIO_MARK,
+};
+
+static const unsigned int eth25g1_link_pins[] = {
+	/* ETH25G1_LINK */
+	RCAR_GP_PIN(9, 8),
+};
+static const unsigned int eth25g1_link_mux[] = {
+	ETH25G1_LINK_MARK,
+};
+static const unsigned int eth25g1_phyint_pins[] = {
+	/* ETH25G1_PHYINT */
+	RCAR_GP_PIN(9, 9),
+};
+static const unsigned int eth25g1_phyint_mux[] = {
+	ETH25G1_PHYINT_MARK,
+};
+static const unsigned int eth25g1_mdio_pins[] = {
+	/* ETH25G1_MDC, ETH25G1_MDIO */
+	RCAR_GP_PIN(9, 7), RCAR_GP_PIN(9, 6),
+};
+static const unsigned int eth25g1_mdio_mux[] = {
+	ETH25G1_MDC_MARK, ETH25G1_MDIO_MARK,
+};
+
+/* - TSN2 ------------------------------------------------ */
+static const unsigned int eth25g2_link_pins[] = {
+	/* ETH25G2_LINK */
+	RCAR_GP_PIN(9, 8),
+};
+static const unsigned int eth25g2_link_mux[] = {
+	ETH25G2_LINK_MARK,
+};
+static const unsigned int eth25g2_phyint_pins[] = {
+	/* ETH25G2_PHYINT */
+	RCAR_GP_PIN(9, 9),
+};
+static const unsigned int eth25g2_phyint_mux[] = {
+	ETH25G2_PHYINT_MARK,
+};
+static const unsigned int eth25g2_mdio_pins[] = {
+	/* ETH25G2_MDC, ETH25G2_MDIO */
+	RCAR_GP_PIN(9, 7), RCAR_GP_PIN(9, 6),
+};
+static const unsigned int eth25g2_mdio_mux[] = {
+	ETH25G2_MDC_MARK, ETH25G2_MDIO_MARK,
+};
+
+/* - gPTPa (TSN0) ---------------------------------------- */
+static const unsigned int ethes0_pps_pins[] = {
+	/* ETHES0_PPS */
+	RCAR_GP_PIN(9, 0),
+};
+static const unsigned int ethes0_pps_mux[] = {
+	ETHES0_PPS_MARK,
+};
+static const unsigned int ethes0_capture_pins[] = {
+	/* ETHES0_CAPTURE */
+	RCAR_GP_PIN(9, 1),
+};
+static const unsigned int ethes0_capture_mux[] = {
+	ETHES0_CAPTURE_MARK,
+};
+static const unsigned int ethes0_match_pins[] = {
+	/* ETHES0_MATCH */
+	RCAR_GP_PIN(9, 2),
+};
+static const unsigned int ethes0_match_mux[] = {
+	ETHES0_MATCH_MARK,
+};
+
+/* - gPTPb (TSN1-7) -------------------------------------- */
+static const unsigned int ethes1_pps_pins[] = {
+	/* ETHES1_PPS */
+	RCAR_GP_PIN(9, 0),
+};
+static const unsigned int ethes1_pps_mux[] = {
+	ETHES1_PPS_MARK,
+};
+static const unsigned int ethes1_capture_pins[] = {
+	/* ETHES1_CAPTURE */
+	RCAR_GP_PIN(9, 1),
+};
+static const unsigned int ethes1_capture_mux[] = {
+	ETHES1_CAPTURE_MARK,
+};
+static const unsigned int ethes1_match_pins[] = {
+	/* ETHES1_MATCH */
+	RCAR_GP_PIN(9, 2),
+};
+static const unsigned int ethes1_match_mux[] = {
+	ETHES1_MATCH_MARK,
+};
+
+static const unsigned int ethes2_pps_pins[] = {
+	/* ETHES2_PPS */
+	RCAR_GP_PIN(9, 0),
+};
+static const unsigned int ethes2_pps_mux[] = {
+	ETHES2_PPS_MARK,
+};
+static const unsigned int ethes2_capture_pins[] = {
+	/* ETHES2_CAPTURE */
+	RCAR_GP_PIN(9, 1),
+};
+static const unsigned int ethes2_capture_mux[] = {
+	ETHES2_CAPTURE_MARK,
+};
+static const unsigned int ethes2_match_pins[] = {
+	/* ETHES1_MATCH */
+	RCAR_GP_PIN(9, 2),
+};
+static const unsigned int ethes2_match_mux[] = {
+	ETHES2_MATCH_MARK,
+};
+
+static const unsigned int ethes3_pps_pins[] = {
+	/* ETHES3_PPS */
+	RCAR_GP_PIN(9, 0),
+};
+static const unsigned int ethes3_pps_mux[] = {
+	ETHES3_PPS_MARK,
+};
+static const unsigned int ethes3_capture_pins[] = {
+	/* ETHES3_CAPTURE */
+	RCAR_GP_PIN(9, 1),
+};
+static const unsigned int ethes3_capture_mux[] = {
+	ETHES3_CAPTURE_MARK,
+};
+static const unsigned int ethes3_match_pins[] = {
+	/* ETHES3_MATCH */
+	RCAR_GP_PIN(9, 2),
+};
+static const unsigned int ethes3_match_mux[] = {
+	ETHES3_MATCH_MARK,
+};
+
+static const unsigned int ethes4_pps_pins[] = {
+	/* ETHES4_PPS */
+	RCAR_GP_PIN(9, 3),
+};
+static const unsigned int ethes4_pps_mux[] = {
+	ETHES4_PPS_MARK,
+};
+static const unsigned int ethes4_capture_pins[] = {
+	/* ETHES4_CAPTURE */
+	RCAR_GP_PIN(9, 4),
+};
+static const unsigned int ethes4_capture_mux[] = {
+	ETHES4_CAPTURE_MARK,
+};
+static const unsigned int ethes4_match_pins[] = {
+	/* ETHES4_MATCH */
+	RCAR_GP_PIN(9, 5),
+};
+static const unsigned int ethes4_match_mux[] = {
+	ETHES4_MATCH_MARK,
+};
+
+static const unsigned int ethes5_pps_pins[] = {
+	/* ETHES5_PPS */
+	RCAR_GP_PIN(9, 3),
+};
+static const unsigned int ethes5_pps_mux[] = {
+	ETHES5_PPS_MARK,
+};
+static const unsigned int ethes5_capture_pins[] = {
+	/* ETHES5_CAPTURE */
+	RCAR_GP_PIN(9, 4),
+};
+static const unsigned int ethes5_capture_mux[] = {
+	ETHES5_CAPTURE_MARK,
+};
+static const unsigned int ethes5_match_pins[] = {
+	/* ETHES5_MATCH */
+	RCAR_GP_PIN(9, 5),
+};
+static const unsigned int ethes5_match_mux[] = {
+	ETHES5_MATCH_MARK,
+};
+
+static const unsigned int ethes6_pps_pins[] = {
+	/* ETHES6_PPS */
+	RCAR_GP_PIN(9, 3),
+};
+static const unsigned int ethes6_pps_mux[] = {
+	ETHES6_PPS_MARK,
+};
+static const unsigned int ethes6_capture_pins[] = {
+	/* ETHES6_CAPTURE */
+	RCAR_GP_PIN(9, 4),
+};
+static const unsigned int ethes6_capture_mux[] = {
+	ETHES6_CAPTURE_MARK,
+};
+static const unsigned int ethes6_match_pins[] = {
+	/* ETHES6_MATCH */
+	RCAR_GP_PIN(9, 5),
+};
+static const unsigned int ethes6_match_mux[] = {
+	ETHES6_MATCH_MARK,
+};
+
+static const unsigned int ethes7_pps_pins[] = {
+	/* ETHES7_PPS */
+	RCAR_GP_PIN(9, 3),
+};
+static const unsigned int ethes7_pps_mux[] = {
+	ETHES7_PPS_MARK,
+};
+static const unsigned int ethes7_capture_pins[] = {
+	/* ETHES7_CAPTURE */
+	RCAR_GP_PIN(9, 4),
+};
+static const unsigned int ethes7_capture_mux[] = {
+	ETHES7_CAPTURE_MARK,
+};
+static const unsigned int ethes7_match_pins[] = {
+	/* ETHES7_MATCH */
+	RCAR_GP_PIN(9, 5),
+};
+static const unsigned int ethes7_match_mux[] = {
+	ETHES7_MATCH_MARK,
+};
+
+static const struct sh_pfc_pin_group pinmux_groups[] = {
+	SH_PFC_PIN_GROUP(hscif0_data),
+	SH_PFC_PIN_GROUP(hscif0_clk),
+	SH_PFC_PIN_GROUP(hscif0_ctrl),
+	SH_PFC_PIN_GROUP(hscif1_data),
+	SH_PFC_PIN_GROUP(hscif1_clk),
+	SH_PFC_PIN_GROUP(hscif1_ctrl),
+	SH_PFC_PIN_GROUP(hscif2_data_a),
+	SH_PFC_PIN_GROUP(hscif2_clk_a),
+	SH_PFC_PIN_GROUP(hscif2_ctrl_a),
+	SH_PFC_PIN_GROUP(hscif2_data_b),
+	SH_PFC_PIN_GROUP(hscif2_clk_b),
+	SH_PFC_PIN_GROUP(hscif2_ctrl_b),
+	SH_PFC_PIN_GROUP(hscif3_data),
+	SH_PFC_PIN_GROUP(hscif3_clk),
+	SH_PFC_PIN_GROUP(hscif3_ctrl),
+
+	SH_PFC_PIN_GROUP(scif0_data),
+	SH_PFC_PIN_GROUP(scif0_clk),
+	SH_PFC_PIN_GROUP(scif0_ctrl),
+	SH_PFC_PIN_GROUP(scif1_data),
+	SH_PFC_PIN_GROUP(scif1_clk),
+	SH_PFC_PIN_GROUP(scif1_ctrl),
+	SH_PFC_PIN_GROUP(scif3_data),
+	SH_PFC_PIN_GROUP(scif3_clk),
+	SH_PFC_PIN_GROUP(scif3_ctrl),
+	SH_PFC_PIN_GROUP(scif4_data_a),
+	SH_PFC_PIN_GROUP(scif4_clk_a),
+	SH_PFC_PIN_GROUP(scif4_ctrl_a),
+	SH_PFC_PIN_GROUP(scif4_data_b),
+	SH_PFC_PIN_GROUP(scif4_clk_b),
+	SH_PFC_PIN_GROUP(scif4_ctrl_b),
+	SH_PFC_PIN_GROUP(scif_clk),
+
+	SH_PFC_PIN_GROUP(i2c0),
+	SH_PFC_PIN_GROUP(i2c1),
+	SH_PFC_PIN_GROUP(i2c2),
+	SH_PFC_PIN_GROUP(i2c3),
+	SH_PFC_PIN_GROUP(i2c4),
+	SH_PFC_PIN_GROUP(i2c5),
+	SH_PFC_PIN_GROUP(i2c6),
+	SH_PFC_PIN_GROUP(i2c7),
+	SH_PFC_PIN_GROUP(i2c8),
+
+	SH_PFC_PIN_GROUP(intc_ex_irq0),
+	SH_PFC_PIN_GROUP(intc_ex_irq1),
+	SH_PFC_PIN_GROUP(intc_ex_irq2),
+	SH_PFC_PIN_GROUP(intc_ex_irq3),
+
+	SH_PFC_PIN_GROUP(pcie40_clkreq_n),
+	SH_PFC_PIN_GROUP(pcie41_clkreq_n),
+	SH_PFC_PIN_GROUP(pcie60_clkreq_n),
+	SH_PFC_PIN_GROUP(pcie61_clkreq_n),
+
+	SH_PFC_PIN_GROUP(qspi0_ctrl),
+	BUS_DATA_PIN_GROUP(qspi0_data, 2),
+	BUS_DATA_PIN_GROUP(qspi0_data, 4),
+	SH_PFC_PIN_GROUP(qspi1_ctrl),
+	BUS_DATA_PIN_GROUP(qspi1_data, 2),
+	BUS_DATA_PIN_GROUP(qspi1_data, 4),
+
+	BUS_DATA_PIN_GROUP(mmc0_data, 1),
+	BUS_DATA_PIN_GROUP(mmc0_data, 4),
+	BUS_DATA_PIN_GROUP(mmc0_data, 8),
+	SH_PFC_PIN_GROUP(mmc0_ctrl),
+	SH_PFC_PIN_GROUP(mmc0_cd),
+	SH_PFC_PIN_GROUP(mmc0_wp),
+	SH_PFC_PIN_GROUP(mmc0_ds),
+
+	SH_PFC_PIN_GROUP(rsw3_match),
+	SH_PFC_PIN_GROUP(rsw3_capture),
+	SH_PFC_PIN_GROUP(rsw3_pps),
+
+	SH_PFC_PIN_GROUP(eth10g0_link),
+	SH_PFC_PIN_GROUP(eth10g0_phyint),
+	SH_PFC_PIN_GROUP(eth10g0_mdio),
+	SH_PFC_PIN_GROUP(eth25g0_link),
+	SH_PFC_PIN_GROUP(eth25g0_phyint),
+	SH_PFC_PIN_GROUP(eth25g0_mdio),
+
+	SH_PFC_PIN_GROUP(eth10g1_link),
+	SH_PFC_PIN_GROUP(eth10g1_phyint),
+	SH_PFC_PIN_GROUP(eth10g1_mdio),
+	SH_PFC_PIN_GROUP(eth25g1_link),
+	SH_PFC_PIN_GROUP(eth25g1_phyint),
+	SH_PFC_PIN_GROUP(eth25g1_mdio),
+
+	SH_PFC_PIN_GROUP(eth25g2_link),
+	SH_PFC_PIN_GROUP(eth25g2_phyint),
+	SH_PFC_PIN_GROUP(eth25g2_mdio),
+
+	SH_PFC_PIN_GROUP(ethes0_pps),
+	SH_PFC_PIN_GROUP(ethes0_capture),
+	SH_PFC_PIN_GROUP(ethes0_match),
+	SH_PFC_PIN_GROUP(ethes1_pps),
+	SH_PFC_PIN_GROUP(ethes1_capture),
+	SH_PFC_PIN_GROUP(ethes1_match),
+	SH_PFC_PIN_GROUP(ethes2_pps),
+	SH_PFC_PIN_GROUP(ethes2_capture),
+	SH_PFC_PIN_GROUP(ethes2_match),
+	SH_PFC_PIN_GROUP(ethes3_pps),
+	SH_PFC_PIN_GROUP(ethes3_capture),
+	SH_PFC_PIN_GROUP(ethes3_match),
+	SH_PFC_PIN_GROUP(ethes4_pps),
+	SH_PFC_PIN_GROUP(ethes4_capture),
+	SH_PFC_PIN_GROUP(ethes4_match),
+	SH_PFC_PIN_GROUP(ethes5_pps),
+	SH_PFC_PIN_GROUP(ethes5_capture),
+	SH_PFC_PIN_GROUP(ethes5_match),
+	SH_PFC_PIN_GROUP(ethes6_pps),
+	SH_PFC_PIN_GROUP(ethes6_capture),
+	SH_PFC_PIN_GROUP(ethes6_match),
+	SH_PFC_PIN_GROUP(ethes7_pps),
+	SH_PFC_PIN_GROUP(ethes7_capture),
+	SH_PFC_PIN_GROUP(ethes7_match),
+};
+
+static const char * const hscif0_groups[] = {
+	"hscif0_data",
+	"hscif0_clk",
+	"hscif0_ctrl",
+};
+
+static const char * const hscif1_groups[] = {
+	"hscif1_data",
+	"hscif1_clk",
+	"hscif1_ctrl",
+};
+
+static const char * const hscif2_groups[] = {
+	"hscif2_data_a",
+	"hscif2_clk_a",
+	"hscif2_ctrl_a",
+	"hscif2_data_b",
+	"hscif2_clk_b",
+	"hscif2_ctrl_b",
+};
+
+static const char * const hscif3_groups[] = {
+	"hscif3_data",
+	"hscif3_clk",
+	"hscif3_ctrl",
+};
+
+static const char * const scif0_groups[] = {
+	"scif0_data",
+	"scif0_clk",
+	"scif0_ctrl",
+};
+
+static const char * const scif1_groups[] = {
+	"scif1_data",
+	"scif1_clk",
+	"scif1_ctrl",
+};
+
+static const char * const scif3_groups[] = {
+	"scif3_data",
+	"scif3_clk",
+	"scif3_ctrl",
+};
+
+static const char * const scif4_groups[] = {
+	"scif4_data_a",
+	"scif4_clk_a",
+	"scif4_ctrl_a",
+	"scif4_data_b",
+	"scif4_clk_b",
+	"scif4_ctrl_b",
+};
+
+static const char * const scif_clk_groups[] = {
+	"scif_clk",
+};
+
+static const char * const i2c0_groups[] = {
+	"i2c0",
+};
+
+static const char * const i2c1_groups[] = {
+	"i2c1",
+};
+
+static const char * const i2c2_groups[] = {
+	"i2c2",
+};
+
+static const char * const i2c3_groups[] = {
+	"i2c3",
+};
+
+static const char * const i2c4_groups[] = {
+	"i2c4",
+};
+
+static const char * const i2c5_groups[] = {
+	"i2c5",
+};
+
+static const char * const i2c6_groups[] = {
+	"i2c6",
+};
+
+static const char * const i2c7_groups[] = {
+	"i2c7",
+};
+
+static const char * const i2c8_groups[] = {
+	"i2c8",
+};
+
+static const char * const intc_ex_groups[] = {
+	"intc_ex_irq0",
+	"intc_ex_irq1",
+	"intc_ex_irq2",
+	"intc_ex_irq3",
+};
+
+static const char * const pcie4_groups[] = {
+	"pcie40_clkreq_n",
+	"pcie41_clkreq_n",
+};
+
+static const char * const pcie6_groups[] = {
+	"pcie60_clkreq_n",
+	"pcie61_clkreq_n",
+};
+
+static const char * const qspi0_groups[] = {
+	"qspi0_ctrl",
+	"qspi0_data2",
+	"qspi0_data4",
+};
+
+static const char * const qspi1_groups[] = {
+	"qspi1_ctrl",
+	"qspi1_data2",
+	"qspi1_data4",
+};
+
+static const char * const mmc0_groups[] = {
+	"mmc0_data1",
+	"mmc0_data4",
+	"mmc0_data8",
+	"mmc0_ctrl",
+	"mmc0_cd",
+	"mmc0_wp",
+	"mmc0_ds",
+};
+
+static const char * const rsw3_groups[] = {
+	"rsw3_match",
+	"rsw3_capture",
+	"rsw3_pps",
+};
+
+static const char * const eth10g0_groups[] = {
+	"eth10g0_link",
+	"eth10g0_phyint",
+	"eth10g0_mdio",
+};
+
+static const char * const eth25g0_groups[] = {
+	"eth25g0_link",
+	"eth25g0_phyint",
+	"eth25g0_mdio",
+};
+
+static const char * const eth10g1_groups[] = {
+	"eth10g1_link",
+	"eth10g1_phyint",
+	"eth10g1_mdio",
+};
+
+static const char * const eth25g1_groups[] = {
+	"eth25g1_link",
+	"eth25g1_phyint",
+	"eth25g1_mdio",
+};
+
+static const char * const eth25g2_groups[] = {
+	"eth25g2_link",
+	"eth25g2_phyint",
+	"eth25g2_mdio",
+};
+
+static const char * const ethes0_groups[] = {
+	"ethes0_pps",
+	"ethes0_capture",
+	"ethes0_match",
+};
+
+static const char * const ethes1_groups[] = {
+	"ethes1_pps",
+	"ethes1_capture",
+	"ethes1_match",
+};
+
+static const char * const ethes2_groups[] = {
+	"ethes2_pps",
+	"ethes2_capture",
+	"ethes2_match",
+};
+
+static const char * const ethes3_groups[] = {
+	"ethes3_pps",
+	"ethes3_capture",
+	"ethes3_match",
+};
+
+static const char * const ethes4_groups[] = {
+	"ethes4_pps",
+	"ethes4_capture",
+	"ethes4_match",
+};
+
+static const char * const ethes5_groups[] = {
+	"ethes5_pps",
+	"ethes5_capture",
+	"ethes5_match",
+};
+
+static const char * const ethes6_groups[] = {
+	"ethes6_pps",
+	"ethes6_capture",
+	"ethes6_match",
+};
+
+static const char * const ethes7_groups[] = {
+	"ethes7_pps",
+	"ethes7_capture",
+	"ethes7_match",
+};
+
+static const struct sh_pfc_function pinmux_functions[] = {
+	SH_PFC_FUNCTION(hscif0),
+	SH_PFC_FUNCTION(hscif1),
+	SH_PFC_FUNCTION(hscif2),
+	SH_PFC_FUNCTION(hscif3),
+
+	SH_PFC_FUNCTION(scif0),
+	SH_PFC_FUNCTION(scif1),
+	SH_PFC_FUNCTION(scif3),
+	SH_PFC_FUNCTION(scif4),
+	SH_PFC_FUNCTION(scif_clk),
+
+	SH_PFC_FUNCTION(i2c0),
+	SH_PFC_FUNCTION(i2c1),
+	SH_PFC_FUNCTION(i2c2),
+	SH_PFC_FUNCTION(i2c3),
+	SH_PFC_FUNCTION(i2c4),
+	SH_PFC_FUNCTION(i2c5),
+	SH_PFC_FUNCTION(i2c6),
+	SH_PFC_FUNCTION(i2c7),
+	SH_PFC_FUNCTION(i2c8),
+
+	SH_PFC_FUNCTION(intc_ex),
+
+	SH_PFC_FUNCTION(pcie4),
+	SH_PFC_FUNCTION(pcie6),
+
+	SH_PFC_FUNCTION(qspi0),
+	SH_PFC_FUNCTION(qspi1),
+
+	SH_PFC_FUNCTION(mmc0),
+
+	SH_PFC_FUNCTION(rsw3),
+
+	SH_PFC_FUNCTION(eth10g0),
+	SH_PFC_FUNCTION(eth25g0),
+	SH_PFC_FUNCTION(eth10g1),
+	SH_PFC_FUNCTION(eth25g1),
+	SH_PFC_FUNCTION(eth25g2),
+
+	SH_PFC_FUNCTION(ethes0),
+	SH_PFC_FUNCTION(ethes1),
+	SH_PFC_FUNCTION(ethes2),
+	SH_PFC_FUNCTION(ethes3),
+	SH_PFC_FUNCTION(ethes4),
+	SH_PFC_FUNCTION(ethes5),
+	SH_PFC_FUNCTION(ethes6),
+	SH_PFC_FUNCTION(ethes7),
+};
+
+static const struct pinmux_cfg_reg pinmux_config_regs[] = {
+#define F_(x, y)	FN_##y
+#define FM(x)		FN_##x
+	{ PINMUX_CFG_REG_VAR("GPSR0", 0xC1080040, 32,
+			     GROUP(-4,
+				  1, 1, 1, 1, 1, 1, 1,
+				  1, 1, 1, 1, 1, 1, 1,
+				  1, 1, 1, 1, 1, 1, 1,
+				  1, 1, 1, 1, 1, 1, 1),
+			     GROUP(
+		/* GP0_31_28 RESERVED */
+		GP_0_27_FN, 	GPSR0_27,
+		GP_0_26_FN, 	GPSR0_26,
+		GP_0_25_FN, 	GPSR0_25,
+		GP_0_24_FN, 	GPSR0_24,
+		GP_0_23_FN, 	GPSR0_23,
+		GP_0_22_FN, 	GPSR0_22,
+		GP_0_21_FN, 	GPSR0_21,
+		GP_0_20_FN, 	GPSR0_20,
+		GP_0_19_FN, 	GPSR0_19,
+		GP_0_18_FN, 	GPSR0_18,
+		GP_0_17_FN, 	GPSR0_17,
+		GP_0_16_FN, 	GPSR0_16,
+		GP_0_15_FN, 	GPSR0_15,
+		GP_0_14_FN, 	GPSR0_14,
+		GP_0_13_FN, 	GPSR0_13,
+		GP_0_12_FN, 	GPSR0_12,
+		GP_0_11_FN, 	GPSR0_11,
+		GP_0_10_FN, 	GPSR0_10,
+		GP_0_9_FN, 	GPSR0_9,
+		GP_0_8_FN, 	GPSR0_8,
+		GP_0_7_FN, 	GPSR0_7,
+		GP_0_6_FN, 	GPSR0_6,
+		GP_0_5_FN, 	GPSR0_5,
+		GP_0_4_FN,	GPSR0_4,
+		GP_0_3_FN,	GPSR0_3,
+		GP_0_2_FN,	GPSR0_2,
+		GP_0_1_FN,	GPSR0_1,
+		GP_0_0_FN,	GPSR0_0, ))
+	},
+	{ PINMUX_CFG_REG_VAR("GPSR1", 0xC1080840, 32,
+			     GROUP(-10,
+				   1, 1, 1, 1, 1, 1, 1,
+				   1, 1, 1, 1, 1, 1, 1,
+				   1, 1, 1, 1, 1, 1, 1, 1),
+			     GROUP(
+		/* GP1_31_22 RESERVED */
+		GP_1_21_FN,	GPSR1_21,
+		GP_1_20_FN,	GPSR1_20,
+		GP_1_19_FN,	GPSR1_19,
+		GP_1_18_FN,	GPSR1_18,
+		GP_1_17_FN,	GPSR1_17,
+		GP_1_16_FN,	GPSR1_16,
+		GP_1_15_FN,	GPSR1_15,
+		GP_1_14_FN,	GPSR1_14,
+		GP_1_13_FN,	GPSR1_13,
+		GP_1_12_FN,	GPSR1_12,
+		GP_1_11_FN,	GPSR1_11,
+		GP_1_10_FN,	GPSR1_10,
+		GP_1_9_FN,	GPSR1_9,
+		GP_1_8_FN,	GPSR1_8,
+		GP_1_7_FN,	GPSR1_7,
+		GP_1_6_FN,	GPSR1_6,
+		GP_1_5_FN,	GPSR1_5,
+		GP_1_4_FN,	GPSR1_4,
+		GP_1_3_FN,	GPSR1_3,
+		GP_1_2_FN,	GPSR1_2,
+		GP_1_1_FN,	GPSR1_1,
+		GP_1_0_FN,	GPSR1_0, ))
+	},
+	{ PINMUX_CFG_REG_VAR("GPSR2", 0xC1081040, 32,
+			     GROUP(-3,
+				  1, 1, 1, 1, 1, 1, 1,
+				  1, 1, 1, 1, 1, 1, 1,
+				  1, 1, 1, 1, 1, 1, 1,
+				  1, 1, 1, 1, 1, 1, 1, 1),
+			     GROUP(
+		/* GP2_31_29 RESERVED */
+		GP_2_28_FN,	GPSR2_28,
+		GP_2_27_FN,	GPSR2_27,
+		GP_2_26_FN,	GPSR2_26,
+		GP_2_25_FN,	GPSR2_25,
+		GP_2_24_FN,	GPSR2_24,
+		GP_2_23_FN,	GPSR2_23,
+		GP_2_22_FN,	GPSR2_22,
+		GP_2_21_FN,	GPSR2_21,
+		GP_2_20_FN,	GPSR2_20,
+		GP_2_19_FN,	GPSR2_19,
+		GP_2_18_FN,	GPSR2_18,
+		GP_2_17_FN,	GPSR2_17,
+		GP_2_16_FN,	GPSR2_16,
+		GP_2_15_FN,	GPSR2_15,
+		GP_2_14_FN,	GPSR2_14,
+		GP_2_13_FN,	GPSR2_13,
+		GP_2_12_FN,	GPSR2_12,
+		GP_2_11_FN,	GPSR2_11,
+		GP_2_10_FN,	GPSR2_10,
+		GP_2_9_FN,	GPSR2_9,
+		GP_2_8_FN,	GPSR2_8,
+		GP_2_7_FN,	GPSR2_7,
+		GP_2_6_FN,	GPSR2_6,
+		GP_2_5_FN,	GPSR2_5,
+		GP_2_4_FN,	GPSR2_4,
+		GP_2_3_FN,	GPSR2_3,
+		GP_2_2_FN,	GPSR2_2,
+		GP_2_1_FN,	GPSR2_1,
+		GP_2_0_FN,	GPSR2_0, ))
+	},
+	{ PINMUX_CFG_REG_VAR("GPSR3", 0xC0800040, 32,
+			     GROUP(-15,
+				   1, 1, 1, 1, 1, 1, 1, 1,
+				   1, 1, 1, 1, 1, 1, 1, 1, 1),
+			     GROUP(
+		/* GP3_31_17 RESERVED */
+		GP_3_16_FN,	GPSR3_16,
+		GP_3_15_FN,	GPSR3_15,
+		GP_3_14_FN,	GPSR3_14,
+		GP_3_13_FN,	GPSR3_13,
+		GP_3_12_FN,	GPSR3_12,
+		GP_3_11_FN,	GPSR3_11,
+		GP_3_10_FN,	GPSR3_10,
+		GP_3_9_FN,	GPSR3_9,
+		GP_3_8_FN,	GPSR3_8,
+		GP_3_7_FN,	GPSR3_7,
+		GP_3_6_FN,	GPSR3_6,
+		GP_3_5_FN,	GPSR3_5,
+		GP_3_4_FN,	GPSR3_4,
+		GP_3_3_FN,	GPSR3_3,
+		GP_3_2_FN,	GPSR3_2,
+		GP_3_1_FN,	GPSR3_1,
+		GP_3_0_FN,	GPSR3_0, ))
+	},
+	{ PINMUX_CFG_REG_VAR("GPSR4", 0xC0800840, 32,
+			     GROUP(-16,
+				   1, 1, 1, 1, 1, 1, 1, 1,
+				   1, 1, 1, 1, 1, 1, 1, 1),
+			     GROUP(
+		/* GP4_31_16 RESERVED */
+		GP_4_15_FN,	GPSR4_15,
+		GP_4_14_FN,	GPSR4_14,
+		GP_4_13_FN,	GPSR4_13,
+		GP_4_12_FN,	GPSR4_12,
+		GP_4_11_FN,	GPSR4_11,
+		GP_4_10_FN,	GPSR4_10,
+		GP_4_9_FN,	GPSR4_9,
+		GP_4_8_FN,	GPSR4_8,
+		GP_4_7_FN,	GPSR4_7,
+		GP_4_6_FN,	GPSR4_6,
+		GP_4_5_FN,	GPSR4_5,
+		GP_4_4_FN,	GPSR4_4,
+		GP_4_3_FN,	GPSR4_3,
+		GP_4_2_FN,	GPSR4_2,
+		GP_4_1_FN,	GPSR4_1,
+		GP_4_0_FN,	GPSR4_0, ))
+	},
+	{ PINMUX_CFG_REG_VAR("GPSR5", 0xC0400040, 32,
+			     GROUP(-9,
+				   1, 1, 1, 1, 1, 1, 1,
+				   1, 1, 1, 1, 1, 1, 1, 1,
+				   1, 1, 1, 1, 1, 1, 1, 1),
+			     GROUP(
+		/* GP5_31_23 RESERVED */
+		GP_5_22_FN,	GPSR5_22,
+		GP_5_21_FN,	GPSR5_21,
+		GP_5_20_FN,	GPSR5_20,
+		GP_5_19_FN,	GPSR5_19,
+		GP_5_18_FN,	GPSR5_18,
+		GP_5_17_FN,	GPSR5_17,
+		GP_5_16_FN,	GPSR5_16,
+		GP_5_15_FN,	GPSR5_15,
+		GP_5_14_FN,	GPSR5_14,
+		GP_5_13_FN,	GPSR5_13,
+		GP_5_12_FN,	GPSR5_12,
+		GP_5_11_FN,	GPSR5_11,
+		GP_5_10_FN,	GPSR5_10,
+		GP_5_9_FN,	GPSR5_9,
+		GP_5_8_FN,	GPSR5_8,
+		GP_5_7_FN,	GPSR5_7,
+		GP_5_6_FN,	GPSR5_6,
+		GP_5_5_FN,	GPSR5_5,
+		GP_5_4_FN,	GPSR5_4,
+		GP_5_3_FN,	GPSR5_3,
+		GP_5_2_FN,	GPSR5_2,
+		GP_5_1_FN,	GPSR5_1,
+		GP_5_0_FN,	GPSR5_0, ))
+	},
+	{ PINMUX_CFG_REG("GPSR6", 0xC0400840, 32, 1, GROUP(
+		0, 		0,
+		GP_6_30_FN, 	GPSR6_30,
+		GP_6_29_FN,	GPSR6_29,
+		GP_6_28_FN,	GPSR6_28,
+		GP_6_27_FN,	GPSR6_27,
+		GP_6_26_FN,	GPSR6_26,
+		GP_6_25_FN,	GPSR6_25,
+		GP_6_24_FN,	GPSR6_24,
+		GP_6_23_FN,	GPSR6_23,
+		GP_6_22_FN,	GPSR6_22,
+		GP_6_21_FN,	GPSR6_21,
+		GP_6_20_FN,	GPSR6_20,
+		GP_6_19_FN,	GPSR6_19,
+		GP_6_18_FN,	GPSR6_18,
+		GP_6_17_FN,	GPSR6_17,
+		GP_6_16_FN,	GPSR6_16,
+		GP_6_15_FN,	GPSR6_15,
+		GP_6_14_FN,	GPSR6_14,
+		GP_6_13_FN,	GPSR6_13,
+		GP_6_12_FN,	GPSR6_12,
+		GP_6_11_FN,	GPSR6_11,
+		GP_6_10_FN,	GPSR6_10,
+		GP_6_9_FN,	GPSR6_9,
+		GP_6_8_FN,	GPSR6_8,
+		GP_6_7_FN,	GPSR6_7,
+		GP_6_6_FN,	GPSR6_6,
+		GP_6_5_FN,	GPSR6_5,
+		GP_6_4_FN,	GPSR6_4,
+		GP_6_3_FN,	GPSR6_3,
+		GP_6_2_FN,	GPSR6_2,
+		GP_6_1_FN,	GPSR6_1,
+		GP_6_0_FN,	GPSR6_0, ))
+	},
+	{ PINMUX_CFG_REG("GPSR7", 0xC0401040, 32, 1, GROUP(
+		0, 		0,
+		GP_7_30_FN, 	GPSR7_30,
+		GP_7_29_FN,	GPSR7_29,
+		GP_7_28_FN,	GPSR7_28,
+		GP_7_27_FN,	GPSR7_27,
+		GP_7_26_FN,	GPSR7_26,
+		GP_7_25_FN,	GPSR7_25,
+		GP_7_24_FN,	GPSR7_24,
+		GP_7_23_FN,	GPSR7_23,
+		GP_7_22_FN,	GPSR7_22,
+		GP_7_21_FN,	GPSR7_21,
+		GP_7_20_FN,	GPSR7_20,
+		GP_7_19_FN,	GPSR7_19,
+		GP_7_18_FN,	GPSR7_18,
+		GP_7_17_FN,	GPSR7_17,
+		GP_7_16_FN,	GPSR7_16,
+		GP_7_15_FN,	GPSR7_15,
+		GP_7_14_FN,	GPSR7_14,
+		GP_7_13_FN,	GPSR7_13,
+		GP_7_12_FN,	GPSR7_12,
+		GP_7_11_FN,	GPSR7_11,
+		GP_7_10_FN,	GPSR7_10,
+		GP_7_9_FN,	GPSR7_9,
+		GP_7_8_FN,	GPSR7_8,
+		GP_7_7_FN,	GPSR7_7,
+		GP_7_6_FN,	GPSR7_6,
+		GP_7_5_FN,	GPSR7_5,
+		GP_7_4_FN,	GPSR7_4,
+		GP_7_3_FN,	GPSR7_3,
+		GP_7_2_FN,	GPSR7_2,
+		GP_7_1_FN,	GPSR7_1,
+		GP_7_0_FN,	GPSR7_0, ))
+	},
+	{ PINMUX_CFG_REG_VAR("GPSR8", 0xC0401840, 32,
+			     GROUP(1, 1, 1, 1, 1, 1,
+				   -10,
+				   1, 1, 1, 1, 1, 1, 1, 1,
+				   1, 1, 1, 1, 1, 1, 1, 1),
+			     GROUP(
+		GP_8_31_FN,	GPSR8_31,
+		GP_8_30_FN,	GPSR8_30,
+		GP_8_29_FN,	GPSR8_29,
+		GP_8_28_FN,	GPSR8_28,
+		GP_8_27_FN,	GPSR8_27,
+		GP_8_26_FN,	GPSR8_26,
+		/* GP8_25_16 RESERVED */
+		GP_8_15_FN,	GPSR8_15,
+		GP_8_14_FN,	GPSR8_14,
+		GP_8_13_FN,	GPSR8_13,
+		GP_8_12_FN,	GPSR8_12,
+		GP_8_11_FN,	GPSR8_11,
+		GP_8_10_FN,	GPSR8_10,
+		GP_8_9_FN,	GPSR8_9,
+		GP_8_8_FN,	GPSR8_8,
+		GP_8_7_FN,	GPSR8_7,
+		GP_8_6_FN,	GPSR8_6,
+		GP_8_5_FN,	GPSR8_5,
+		GP_8_4_FN,	GPSR8_4,
+		GP_8_3_FN,	GPSR8_3,
+		GP_8_2_FN,	GPSR8_2,
+		GP_8_1_FN,	GPSR8_1,
+		GP_8_0_FN,	GPSR8_0, ))
+	},
+	{ PINMUX_CFG_REG_VAR("GPSR9", 0xC9B00040, 32,
+			     GROUP(-15,
+				   1, 1, 1, 1, 1, 1, 1, 1,
+				   1, 1, 1, 1, 1, 1, 1, 1, 1),
+			     GROUP(
+		/* GP9_31_17 RESERVED */
+		GP_9_16_FN,	GPSR9_16,
+		GP_9_15_FN,	GPSR9_15,
+		GP_9_14_FN,	GPSR9_14,
+		GP_9_13_FN,	GPSR9_13,
+		GP_9_12_FN,	GPSR9_12,
+		GP_9_11_FN,	GPSR9_11,
+		GP_9_10_FN,	GPSR9_10,
+		GP_9_9_FN,	GPSR9_9,
+		GP_9_8_FN,	GPSR9_8,
+		GP_9_7_FN,	GPSR9_7,
+		GP_9_6_FN,	GPSR9_6,
+		GP_9_5_FN,	GPSR9_5,
+		GP_9_4_FN,	GPSR9_4,
+		GP_9_3_FN,	GPSR9_3,
+		GP_9_2_FN,	GPSR9_2,
+		GP_9_1_FN,	GPSR9_1,
+		GP_9_0_FN,	GPSR9_0, ))
+	},
+	{ PINMUX_CFG_REG_VAR("GPSR10", 0xC9B00840, 32,
+			     GROUP(-18,
+				   1, 1, 1, 1, 1, 1, 1,
+				   1, 1, 1, 1, 1, 1, 1),
+			     GROUP(
+		/* GP10_31_14 RESERVED */
+		GP_10_13_FN,	GPSR10_13,
+		GP_10_12_FN,	GPSR10_12,
+		GP_10_11_FN,	GPSR10_11,
+		GP_10_10_FN,	GPSR10_10,
+		GP_10_9_FN,	GPSR10_9,
+		GP_10_8_FN,	GPSR10_8,
+		GP_10_7_FN,	GPSR10_7,
+		GP_10_6_FN,	GPSR10_6,
+		GP_10_5_FN,	GPSR10_5,
+		GP_10_4_FN,	GPSR10_4,
+		GP_10_3_FN,	GPSR10_3,
+		GP_10_2_FN,	GPSR10_2,
+		GP_10_1_FN,	GPSR10_1,
+		GP_10_0_FN,	GPSR10_0, ))
+	},
+#undef F_
+#undef FM
+
+#define F_(x, y)	x,
+#define FM(x)		FN_##x,
+	{ PINMUX_CFG_REG("GP0_ALTSEL0", 0xC1080060, 32, 1, GROUP(
+		GP_ALTSEL0(0)
+		))
+	},
+	{ PINMUX_CFG_REG("GP0_ALTSEL1", 0xC1080064, 32, 1, GROUP(
+		GP_ALTSEL1(0)
+		))
+	},
+	{ PINMUX_CFG_REG("GP0_ALTSEL2", 0xC1080068, 32, 1, GROUP(
+		GP_ALTSEL2(0)
+		))
+	},
+	{ PINMUX_CFG_REG("GP0_ALTSEL3", 0xC108006C, 32, 1, GROUP(
+		GP_ALTSEL3(0)
+		))
+	},
+	{ PINMUX_CFG_REG("GP1_ALTSEL0", 0xC1080860, 32, 1, GROUP(
+		GP_ALTSEL0(1)
+		))
+	},
+	{ PINMUX_CFG_REG("GP1_ALTSEL1", 0xC1080864, 32, 1, GROUP(
+		GP_ALTSEL1(1)
+		))
+	},
+	{ PINMUX_CFG_REG("GP1_ALTSEL2", 0xC1080868, 32, 1, GROUP(
+		GP_ALTSEL2(1)
+		))
+	},
+	{ PINMUX_CFG_REG("GP1_ALTSEL3", 0xC108086C, 32, 1, GROUP(
+		GP_ALTSEL3(1)
+		))
+	},
+	{ PINMUX_CFG_REG("GP2_ALTSEL0", 0xC1081060, 32, 1, GROUP(
+		GP_ALTSEL0(2)
+		))
+	},
+	{ PINMUX_CFG_REG("GP2_ALTSEL1", 0xC1081064, 32, 1, GROUP(
+		GP_ALTSEL1(2)
+		))
+	},
+	{ PINMUX_CFG_REG("GP2_ALTSEL2", 0xC1081068, 32, 1, GROUP(
+		GP_ALTSEL2(2)
+		))
+	},
+	{ PINMUX_CFG_REG("GP2_ALTSEL3", 0xC108106C, 32, 1, GROUP(
+		GP_ALTSEL3(2)
+		))
+	},
+	{ PINMUX_CFG_REG("GP3_ALTSEL0", 0xC0800060, 32, 1, GROUP(
+		GP_ALTSEL0(3)
+		))
+	},
+	{ PINMUX_CFG_REG("GP3_ALTSEL1", 0xC0800064, 32, 1, GROUP(
+		GP_ALTSEL1(3)
+		))
+	},
+	{ PINMUX_CFG_REG("GP3_ALTSEL2", 0xC0800068, 32, 1, GROUP(
+		GP_ALTSEL2(3)
+		))
+	},
+	{ PINMUX_CFG_REG("GP3_ALTSEL3", 0xC080006C, 32, 1, GROUP(
+		GP_ALTSEL3(3)
+		))
+	},
+	{ PINMUX_CFG_REG("GP4_ALTSEL0", 0xC0800860, 32, 1, GROUP(
+		GP_ALTSEL0(4)
+		))
+	},
+	{ PINMUX_CFG_REG("GP4_ALTSEL1", 0xC0800864, 32, 1, GROUP(
+		GP_ALTSEL1(4)
+		))
+	},
+	{ PINMUX_CFG_REG("GP4_ALTSEL2", 0xC0800868, 32, 1, GROUP(
+		GP_ALTSEL2(4)
+		))
+	},
+	{ PINMUX_CFG_REG("GP4_ALTSEL3", 0xC080086C, 32, 1, GROUP(
+		GP_ALTSEL3(4)
+		))
+	},
+	{ PINMUX_CFG_REG("GP5_ALTSEL0", 0xC0400060, 32, 1, GROUP(
+		GP_ALTSEL0(5)
+		))
+	},
+	{ PINMUX_CFG_REG("GP5_ALTSEL1", 0xC0400064, 32, 1, GROUP(
+		GP_ALTSEL1(5)
+		))
+	},
+	{ PINMUX_CFG_REG("GP5_ALTSEL2", 0xC0400068, 32, 1, GROUP(
+		GP_ALTSEL2(5)
+		))
+	},
+	{ PINMUX_CFG_REG("GP5_ALTSEL3", 0xC040006C, 32, 1, GROUP(
+		GP_ALTSEL3(5)
+		))
+	},
+	{ PINMUX_CFG_REG("GP6_ALTSEL0", 0xC0400860, 32, 1, GROUP(
+		GP_ALTSEL0(6)
+		))
+	},
+	{ PINMUX_CFG_REG("GP6_ALTSEL1", 0xC0400864, 32, 1, GROUP(
+		GP_ALTSEL1(6)
+		))
+	},
+	{ PINMUX_CFG_REG("GP6_ALTSEL2", 0xC0400868, 32, 1, GROUP(
+		GP_ALTSEL2(6)
+		))
+	},
+	{ PINMUX_CFG_REG("GP6_ALTSEL3", 0xC040086C, 32, 1, GROUP(
+		GP_ALTSEL3(6)
+		))
+	},
+	{ PINMUX_CFG_REG("GP7_ALTSEL0", 0xC0401060, 32, 1, GROUP(
+		GP_ALTSEL0(7)
+		))
+	},
+	{ PINMUX_CFG_REG("GP7_ALTSEL1", 0xC0401064, 32, 1, GROUP(
+		GP_ALTSEL1(7)
+		))
+	},
+	{ PINMUX_CFG_REG("GP7_ALTSEL2", 0xC0401068, 32, 1, GROUP(
+		GP_ALTSEL2(7)
+		))
+	},
+	{ PINMUX_CFG_REG("GP7_ALTSEL3", 0xC040106C, 32, 1, GROUP(
+		GP_ALTSEL3(7)
+		))
+	},
+	{ PINMUX_CFG_REG("GP8_ALTSEL0", 0xC0401860, 32, 1, GROUP(
+		GP_ALTSEL0(8)
+		))
+	},
+	{ PINMUX_CFG_REG("GP8_ALTSEL1", 0xC0401864, 32, 1, GROUP(
+		GP_ALTSEL1(8)
+		))
+	},
+	{ PINMUX_CFG_REG("GP8_ALTSEL2", 0xC0401868, 32, 1, GROUP(
+		GP_ALTSEL2(8)
+		))
+	},
+	{ PINMUX_CFG_REG("GP8_ALTSEL3", 0xC040186C, 32, 1, GROUP(
+		GP_ALTSEL3(8)
+		))
+	},
+	{ PINMUX_CFG_REG("GP9_ALTSEL0", 0xC9B00060, 32, 1, GROUP(
+		GP_ALTSEL0(9)
+		))
+	},
+	{ PINMUX_CFG_REG("GP5_ALTSEL1", 0xC9B00064, 32, 1, GROUP(
+		GP_ALTSEL1(9)
+		))
+	},
+	{ PINMUX_CFG_REG("GP9_ALTSEL2", 0xC9B00068, 32, 1, GROUP(
+		GP_ALTSEL2(9)
+		))
+	},
+	{ PINMUX_CFG_REG("GP9_ALTSEL3", 0xC9B0006C, 32, 1, GROUP(
+		GP_ALTSEL3(9)
+		))
+	},
+	{ PINMUX_CFG_REG("GP10_ALTSEL0", 0xC9B00860, 32, 1, GROUP(
+		GP_ALTSEL0(10)
+		))
+	},
+	{ PINMUX_CFG_REG("GP10_ALTSEL1", 0xC9B00864, 32, 1, GROUP(
+		GP_ALTSEL1(10)
+		))
+	},
+	{ PINMUX_CFG_REG("GP10_ALTSEL2", 0xC9B00868, 32, 1, GROUP(
+		GP_ALTSEL2(10)
+		))
+	},
+	{ PINMUX_CFG_REG("GP10_ALTSEL3", 0xC9B0086C, 32, 1, GROUP(
+		GP_ALTSEL3(10)
+		))
+	},
+#undef F_
+#undef FM
+
+#define F_(x, y)	x,
+#define FM(x)		FN_##x,
+	{ PINMUX_CFG_REG_VAR("GP1_MODSEL", 0xC1080900, 32,
+			     GROUP(-10,
+				   1, 1, 1, 1, 1, 1, 1, 1,
+				   -14),
+			     GROUP(
+		/* GP1_MODSEL_31_22 RESERVED */
+		GP1_MODSEL_21
+		GP1_MODSEL_20
+		GP1_MODSEL_19
+		GP1_MODSEL_18
+		GP1_MODSEL_17
+		GP1_MODSEL_16
+		GP1_MODSEL_15
+		GP1_MODSEL_14
+		/* GP1_MODSEL_13_0 RESERVED */
+		))
+	},
+	{ PINMUX_CFG_REG_VAR("GP2_MODSEL", 0xC1081100, 32,
+			     GROUP(-11,
+				   1, 1,
+				   -19),
+			     GROUP(
+		/* GP2_MODSEL_31_21 RESERVED */
+		GP2_MODSEL_20
+		GP2_MODSEL_19
+		/* GP2_MODSEL_18_0 RESERVED */
+		))
+	},
+	{ PINMUX_CFG_REG_VAR("GP8_MODSEL", 0xC0401900, 32,
+			     GROUP(-16,
+				   1, 1, 1, 1, 1, 1, 1, 1,
+				   1, 1, 1, 1, 1, 1, 1, 1),
+			     GROUP(
+		/* GP8_MODSEL_31_16 RESERVED */
+		GP8_MODSEL_15
+		GP8_MODSEL_14
+		GP8_MODSEL_13
+		GP8_MODSEL_12
+		GP8_MODSEL_11
+		GP8_MODSEL_10
+		GP8_MODSEL_9
+		GP8_MODSEL_8
+		GP8_MODSEL_7
+		GP8_MODSEL_6
+		GP8_MODSEL_5
+		GP8_MODSEL_4
+		GP8_MODSEL_3
+		GP8_MODSEL_2
+		GP8_MODSEL_1
+		GP8_MODSEL_0
+		))
+	},
+	{ },
+};
+
+#define RCAR5_PINMUX_DRIVE_REG(name1, r1, name2, r2, name3, r3) \
+	.drvctrl0 = r1,	\
+	.drvctrl1 = r2,	\
+	.drvctrl2 = r3,	\
+	.pins =
+
+struct rcar5_pinmux_drive_reg {
+	u32 drvctrl0;
+	u32 drvctrl1;
+	u32 drvctrl2;
+	const u16 pins[32];
+};
+
+static const struct rcar5_pinmux_drive_reg pinmux_drive_regs[] = {
+	{ RCAR5_PINMUX_DRIVE_REG("GP0_DRVCTRL0", 0xC1080080, "GP0_DRVCTRL1", 0xC1080084, "GP0_DRVCTRL2", 0xC1080088) {
+		[ 0] = RCAR_GP_PIN(0,  0),	/* GP0_00 */
+		[ 1] = RCAR_GP_PIN(0,  1),	/* GP0_01 */
+		[ 2] = RCAR_GP_PIN(0,  2),	/* GP0_02 */
+		[ 3] = RCAR_GP_PIN(0,  3),	/* STPWT_EXTFXR_A */
+		[ 4] = RCAR_GP_PIN(0,  4),	/* FXR_CLKOUT1_A */
+		[ 5] = RCAR_GP_PIN(0,  5),	/* FXR_CLKOUT2_A */
+		[ 6] = RCAR_GP_PIN(0,  6),	/* CLK_EXTFXR_A */
+		[ 7] = RCAR_GP_PIN(0,  7),	/* FXR_TXDA_A */
+		[ 8] = RCAR_GP_PIN(0,  8),	/* FXR_TXENA_N_A */
+		[ 9] = RCAR_GP_PIN(0,  9),	/* RXDA_EXTFXR_A */
+		[10] = RCAR_GP_PIN(0, 10),	/* FXR_TXDB_A */
+		[11] = RCAR_GP_PIN(0, 11),	/* FXR_TXENB_N_A */
+		[12] = RCAR_GP_PIN(0, 12),	/* RXDB_EXTFXR_A */
+		[13] = RCAR_GP_PIN(0, 13),	/* MSIOF0_SCK */
+		[14] = RCAR_GP_PIN(0, 14),	/* MSIOF0_TXD */
+		[15] = RCAR_GP_PIN(0, 15),	/* MSIOF0_RXD */
+		[16] = RCAR_GP_PIN(0, 16),	/* MSIOF0_SYNC */
+		[17] = RCAR_GP_PIN(0, 17),	/* MSIOF0_SS1 */
+		[18] = RCAR_GP_PIN(0, 18),	/* MSIOF0_SS2 */
+		[19] = RCAR_GP_PIN(0, 19),	/* MSIOF1_SCK_A */
+		[20] = RCAR_GP_PIN(0, 20),	/* MSIOF1_TXD_A */
+		[21] = RCAR_GP_PIN(0, 21),	/* MSIOF1_RXD_A */
+		[22] = RCAR_GP_PIN(0, 22),	/* MSIOF1_SYNC_A */
+		[23] = RCAR_GP_PIN(0, 23),	/* MSIOF1_SS1_A */
+		[24] = RCAR_GP_PIN(0, 24),	/* MSIOF1_SS2_A */
+		[25] = RCAR_GP_PIN(0, 25),	/* DP0_HOTPLUG */
+		[26] = RCAR_GP_PIN(0, 26),	/* DP1_HOTPLUG */
+		[27] = RCAR_GP_PIN(0, 27),	/* DP2_HOTPLUG */
+		[28] = SH_PFC_PIN_NONE,
+		[29] = SH_PFC_PIN_NONE,
+		[30] = SH_PFC_PIN_NONE,
+		[31] = SH_PFC_PIN_NONE,
+	} },
+	{ RCAR5_PINMUX_DRIVE_REG("GP1_DRVCTRL0", 0xC1080880, "GP1_DRVCTRL1", 0xC1080884, "GP1_DRVCTRL2", 0xC1080888) {
+		[ 0] = RCAR_GP_PIN(1,  0),	/* CAN0RX_INTP0 */
+		[ 1] = RCAR_GP_PIN(1,  1),	/* CAN0TX */
+		[ 2] = RCAR_GP_PIN(1,  2),	/* CAN1RX_INTP1 */
+		[ 3] = RCAR_GP_PIN(1,  3),	/* CAN1TX */
+		[ 4] = RCAR_GP_PIN(1,  4),	/* CAN2RX_INTP2 */
+		[ 5] = RCAR_GP_PIN(1,  5),	/* CAN2TX */
+		[ 6] = RCAR_GP_PIN(1,  6),	/* CAN3RX_INTP3 */
+		[ 7] = RCAR_GP_PIN(1,  7),	/* CAN3TX */
+		[ 8] = RCAR_GP_PIN(1,  8),	/* CAN4RX_INTP4 */
+		[ 9] = RCAR_GP_PIN(1,  9),	/* CAN4TX */
+		[10] = RCAR_GP_PIN(1, 10),	/* CAN5RX_INTP5 */
+		[11] = RCAR_GP_PIN(1, 11),	/* CAN5TX */
+		[12] = RCAR_GP_PIN(1, 12),	/* CAN6RX_INTP6 */
+		[13] = RCAR_GP_PIN(1, 13),	/* CAN6TX */
+		[14] = RCAR_GP_PIN(1, 14),	/* RLIN30RX_INTP16 */
+		[15] = RCAR_GP_PIN(1, 15),	/* RLIN30TX */
+		[16] = RCAR_GP_PIN(1, 16),	/* RLIN31RX_INTP17 */
+		[17] = RCAR_GP_PIN(1, 17),	/* RLIN31TX */
+		[18] = RCAR_GP_PIN(1, 18),	/* RLIN32RX_INTP18 */
+		[19] = RCAR_GP_PIN(1, 19),	/* RLIN32TX */
+		[20] = RCAR_GP_PIN(1, 20),	/* RLIN33RX_INTP19 */
+		[21] = RCAR_GP_PIN(1, 21),	/* RLIN33TX */
+		[22] = SH_PFC_PIN_NONE,
+		[23] = SH_PFC_PIN_NONE,
+		[24] = SH_PFC_PIN_NONE,
+		[25] = SH_PFC_PIN_NONE,
+		[26] = SH_PFC_PIN_NONE,
+		[27] = SH_PFC_PIN_NONE,
+		[28] = SH_PFC_PIN_NONE,
+		[29] = SH_PFC_PIN_NONE,
+		[30] = SH_PFC_PIN_NONE,
+		[31] = SH_PFC_PIN_NONE,
+	} },
+	{ RCAR5_PINMUX_DRIVE_REG("GP2_DRVCTRL0", 0xC1081080, "GP2_DRVCTRL1", 0xC1081084, "GP2_DRVCTRL2", 0xC1081088) {
+		[ 0] = RCAR_GP_PIN(2,  0),	/* RLIN34RX_INTP20_B */
+		[ 1] = RCAR_GP_PIN(2,  1),	/* RLIN34TX_B */
+		[ 2] = RCAR_GP_PIN(2,  2),	/* RLIN35RX_INTP21_B */
+		[ 3] = RCAR_GP_PIN(2,  3),	/* RLIN35TX_B */
+		[ 4] = RCAR_GP_PIN(2,  4),	/* RLIN36RX_INTP22_B */
+		[ 5] = RCAR_GP_PIN(2,  5),	/* RLIN36TX_B */
+		[ 6] = RCAR_GP_PIN(2,  6),	/* RLIN37RX_INTP23_B */
+		[ 7] = RCAR_GP_PIN(2,  7),	/* RLIN37TX_B */
+		[ 8] = RCAR_GP_PIN(2,  8),	/* CAN12RX_INTP12_B */
+		[ 9] = RCAR_GP_PIN(2,  9),	/* CAN12TX_B */
+		[10] = RCAR_GP_PIN(2, 10),	/* CAN13RX_INTP13_B */
+		[11] = RCAR_GP_PIN(2, 11),	/* CAN13TX_B */
+		[12] = RCAR_GP_PIN(2, 12),	/* CAN14RX_INTP14_B */
+		[13] = RCAR_GP_PIN(2, 13),	/* CAN14TX_B */
+		[14] = RCAR_GP_PIN(2, 14),	/* CAN15RX_INTP15_B */
+		[15] = RCAR_GP_PIN(2, 15),	/* CAN15TX_B */
+		[16] = RCAR_GP_PIN(2, 16),	/* CAN_CLK */
+		[17] = RCAR_GP_PIN(2, 17),	/* INTP32_B */
+		[18] = RCAR_GP_PIN(2, 18),	/* INTP33_B */
+		[19] = RCAR_GP_PIN(2, 19),	/* SCL0 */
+		[20] = RCAR_GP_PIN(2, 20),	/* SDA0 */
+		[21] = RCAR_GP_PIN(2, 21),	/* AVS0 */
+		[22] = RCAR_GP_PIN(2, 22),	/* AVS1 */
+		[23] = RCAR_GP_PIN(2, 23),	/* EXTCLK0O_B */
+		[24] = RCAR_GP_PIN(2, 24),	/* TAUD1O0 */
+		[25] = RCAR_GP_PIN(2, 25),	/* TAUD1O1 */
+		[26] = RCAR_GP_PIN(2, 26),	/* TAUD1O2 */
+		[27] = RCAR_GP_PIN(2, 27),	/* TAUD1O3 */
+		[28] = RCAR_GP_PIN(2, 28),	/* INTP34_B */
+		[29] = SH_PFC_PIN_NONE,
+		[30] = SH_PFC_PIN_NONE,
+		[31] = SH_PFC_PIN_NONE,
+	} },
+	{ RCAR5_PINMUX_DRIVE_REG("GP3_DRVCTRL0", 0xC0800080, "GP3_DRVCTRL1", 0xC0800084, "GP3_DRVCTRL2", 0xC0800088) {
+		[ 0] = RCAR_GP_PIN(3,  0),	/* QSPI0_SPCLK */
+		[ 1] = RCAR_GP_PIN(3,  1),	/* QSPI0_MOSI_IO0 */
+		[ 2] = RCAR_GP_PIN(3,  2),	/* QSPI0_MISO_IO1 */
+		[ 3] = RCAR_GP_PIN(3,  3),	/* QSPI0_IO2 */
+		[ 4] = RCAR_GP_PIN(3,  4),	/* QSPI0_IO3 */
+		[ 5] = RCAR_GP_PIN(3,  5),	/* QSPI0_SSL */
+		[ 6] = RCAR_GP_PIN(3,  6),	/* RPC_RESET_N */
+		[ 7] = RCAR_GP_PIN(3,  7),	/* RPC_WP_N */
+		[ 8] = RCAR_GP_PIN(3,  8),	/* RPC_INT_N */
+		[ 9] = RCAR_GP_PIN(3,  9),	/* QSPI1_SPCLK */
+		[10] = RCAR_GP_PIN(3, 10),	/* QSPI1_MOSI_IO0 */
+		[11] = RCAR_GP_PIN(3, 11),	/* QSPI1_MISO_IO1 */
+		[12] = RCAR_GP_PIN(3, 12),	/* QSPI1_IO2 */
+		[13] = RCAR_GP_PIN(3, 13),	/* QSPI1_IO3 */
+		[14] = RCAR_GP_PIN(3, 14),	/* QSPI1_SSL */
+		[15] = RCAR_GP_PIN(3, 15),	/* ERROROUT_N */
+		[16] = RCAR_GP_PIN(3, 16),	/* ERRORIN_N */
+		[17] = SH_PFC_PIN_NONE,
+		[18] = SH_PFC_PIN_NONE,
+		[19] = SH_PFC_PIN_NONE,
+		[20] = SH_PFC_PIN_NONE,
+		[21] = SH_PFC_PIN_NONE,
+		[22] = SH_PFC_PIN_NONE,
+		[23] = SH_PFC_PIN_NONE,
+		[24] = SH_PFC_PIN_NONE,
+		[25] = SH_PFC_PIN_NONE,
+		[26] = SH_PFC_PIN_NONE,
+		[27] = SH_PFC_PIN_NONE,
+		[28] = SH_PFC_PIN_NONE,
+		[29] = SH_PFC_PIN_NONE,
+		[30] = SH_PFC_PIN_NONE,
+		[31] = SH_PFC_PIN_NONE,
+	} },
+	{ RCAR5_PINMUX_DRIVE_REG("GP4_DRVCTRL0", 0xC0800880, "GP4_DRVCTRL1", 0xC0800884, "GP4_DRVCTRL2", 0xC0800888) {
+		[ 0] = RCAR_GP_PIN(4,  0),	/* MMC0_SD_CLK */
+		[ 1] = RCAR_GP_PIN(4,  1),	/* MMC0_SD_CMD */
+		[ 2] = RCAR_GP_PIN(4,  2),	/* MMC0_SD_D0 */
+		[ 3] = RCAR_GP_PIN(4,  3),	/* MMC0_SD_D1 */
+		[ 4] = RCAR_GP_PIN(4,  4),	/* MMC0_SD_D2 */
+		[ 5] = RCAR_GP_PIN(4,  5),	/* MMC0_SD_D3 */
+		[ 6] = RCAR_GP_PIN(4,  6),	/* MMC0_D4 */
+		[ 7] = RCAR_GP_PIN(4,  7),	/* MMC0_D5 */
+		[ 8] = RCAR_GP_PIN(4,  8),	/* MMC0_D6 */
+		[ 9] = RCAR_GP_PIN(4,  9),	/* MMC0_D7 */
+		[10] = RCAR_GP_PIN(4, 10),	/* MMC0_DS */
+		[11] = RCAR_GP_PIN(4, 11),	/* SD0_WP */
+		[12] = RCAR_GP_PIN(4, 12),	/* SD0_CD */
+		[13] = RCAR_GP_PIN(4, 13),	/* ERRORIN_N */
+		[14] = RCAR_GP_PIN(4, 14),	/* PCIE60_CLKREQ_N */
+		[15] = RCAR_GP_PIN(4, 15),	/* PCIE61_CLKREQ_N */
+		[16] = SH_PFC_PIN_NONE,
+		[17] = SH_PFC_PIN_NONE,
+		[18] = SH_PFC_PIN_NONE,
+		[19] = SH_PFC_PIN_NONE,
+		[20] = SH_PFC_PIN_NONE,
+		[21] = SH_PFC_PIN_NONE,
+		[22] = SH_PFC_PIN_NONE,
+		[23] = SH_PFC_PIN_NONE,
+		[24] = SH_PFC_PIN_NONE,
+		[25] = SH_PFC_PIN_NONE,
+		[26] = SH_PFC_PIN_NONE,
+		[27] = SH_PFC_PIN_NONE,
+		[28] = SH_PFC_PIN_NONE,
+		[29] = SH_PFC_PIN_NONE,
+		[30] = SH_PFC_PIN_NONE,
+		[31] = SH_PFC_PIN_NONE,
+	} },
+	{ RCAR5_PINMUX_DRIVE_REG("GP5_DRVCTRL0", 0xC0400080, "GP5_DRVCTRL1", 0xC0400084, "GP5_DRVCTRL2", 0xC0400088) {
+		[ 0] = RCAR_GP_PIN(5,  0),	/* HTX0 */
+		[ 1] = RCAR_GP_PIN(5,  1),	/* HRX0 */
+		[ 2] = RCAR_GP_PIN(5,  2),	/* HRTS0_N */
+		[ 3] = RCAR_GP_PIN(5,  3),	/* HCTS0_N */
+		[ 4] = RCAR_GP_PIN(5,  4),	/* HSCK0 */
+		[ 5] = RCAR_GP_PIN(5,  5),	/* SCIF_CLK */
+		[ 6] = RCAR_GP_PIN(5,  6),	/* HTX1 */
+		[ 7] = RCAR_GP_PIN(5,  7),	/* HRX1 */
+		[ 8] = RCAR_GP_PIN(5,  8),	/* HRTS1_N */
+		[ 9] = RCAR_GP_PIN(5,  9),	/* HCTS1_N */
+		[10] = RCAR_GP_PIN(5, 10),	/* HSCK1 */
+		[11] = RCAR_GP_PIN(5, 11),	/* IRQ0_A */
+		[12] = RCAR_GP_PIN(5, 12),	/* IRQ1_A */
+		[13] = RCAR_GP_PIN(5, 13),	/* IRQ2_A */
+		[14] = RCAR_GP_PIN(5, 14),	/* IRQ3_A */
+		[15] = RCAR_GP_PIN(5, 15),	/* TCLK1 */
+		[16] = RCAR_GP_PIN(5, 16),	/* TCLK2 */
+		[17] = RCAR_GP_PIN(5, 17),	/* TCLK3 */
+		[18] = RCAR_GP_PIN(5, 18),	/* TCLK4 */
+		[19] = RCAR_GP_PIN(5, 19),	/* TPU0TO0 */
+		[20] = RCAR_GP_PIN(5, 20),	/* TPU0TO1 */
+		[21] = RCAR_GP_PIN(5, 21),	/* TPU0TO2 */
+		[22] = RCAR_GP_PIN(5, 22),	/* TPU0TO3 */
+		[23] = SH_PFC_PIN_NONE,
+		[24] = SH_PFC_PIN_NONE,
+		[25] = SH_PFC_PIN_NONE,
+		[26] = SH_PFC_PIN_NONE,
+		[27] = SH_PFC_PIN_NONE,
+		[28] = SH_PFC_PIN_NONE,
+		[29] = SH_PFC_PIN_NONE,
+		[30] = SH_PFC_PIN_NONE,
+		[31] = SH_PFC_PIN_NONE,
+	} },
+	{ RCAR5_PINMUX_DRIVE_REG("GP6_DRVCTRL0", 0xC0400880, "GP6_DRVCTRL1", 0xC0400884, "GP6_DRVCTRL2", 0xC0400888) {
+		[ 0] = RCAR_GP_PIN(6,  0),	/* RIF6_D0 */
+		[ 1] = RCAR_GP_PIN(6,  1),	/* RIF6_D1 */
+		[ 2] = RCAR_GP_PIN(6,  2),	/* RIF6_SYNC */
+		[ 3] = RCAR_GP_PIN(6,  3),	/* RIF6_CLK */
+		[ 4] = RCAR_GP_PIN(6,  4),	/* MSIOF7_SCK_A */
+		[ 5] = RCAR_GP_PIN(6,  5),	/* MSIOF7_TXD_A */
+		[ 6] = RCAR_GP_PIN(6,  6),	/* MSIOF7_RXD_A */
+		[ 7] = RCAR_GP_PIN(6,  7),	/* MSIOF7_SYNC_A */
+		[ 8] = RCAR_GP_PIN(6,  8),	/* MSIOF7_SS1_A */
+		[ 9] = RCAR_GP_PIN(6,  9),	/* MSIOF7_SS2_A */
+		[10] = RCAR_GP_PIN(6, 10),	/* MSIOF4_SCK_B */
+		[11] = RCAR_GP_PIN(6, 11),	/* MSIOF4_TXD_B */
+		[12] = RCAR_GP_PIN(6, 12),	/* MSIOF4_RXD_B */
+		[13] = RCAR_GP_PIN(6, 13),	/* MSIOF4_SYNC_B */
+		[14] = RCAR_GP_PIN(6, 14),	/* MSIOF4_SS1_B */
+		[15] = RCAR_GP_PIN(6, 15),	/* MSIOF4_SS2_B */
+		[16] = RCAR_GP_PIN(6, 16),	/* SSI0_SCK */
+		[17] = RCAR_GP_PIN(6, 17),	/* SSI0_WS */
+		[18] = RCAR_GP_PIN(6, 18),	/* SSI0_SD */
+		[19] = RCAR_GP_PIN(6, 19),	/* AUDIO0_CLKOUT0 */
+		[20] = RCAR_GP_PIN(6, 20),	/* AUDIO0_CLKOUT1 */
+		[21] = RCAR_GP_PIN(6, 21),	/* SSI1_SCK */
+		[22] = RCAR_GP_PIN(6, 22),	/* SSI1_WS */
+		[23] = RCAR_GP_PIN(6, 23),	/* SSI1_SD */
+		[24] = RCAR_GP_PIN(6, 24),	/* AUDIO0_CLKOUT2 */
+		[25] = RCAR_GP_PIN(6, 25),	/* AUDIO0_CLKOUT3 */
+		[26] = RCAR_GP_PIN(6, 26),	/* SSI2_SCK */
+		[27] = RCAR_GP_PIN(6, 27),	/* SSI2_WS */
+		[28] = RCAR_GP_PIN(6, 28),	/* SSI2_SD */
+		[29] = RCAR_GP_PIN(6, 29),	/* AUDIO1_CLKOUT0 */
+		[30] = RCAR_GP_PIN(6, 30),	/* AUDIO1_CLKOUT1 */
+		[31] = SH_PFC_PIN_NONE,
+	} },
+	{ RCAR5_PINMUX_DRIVE_REG("GP7_DRVCTRL0", 0xC0401080, "GP7_DRVCTRL1", 0xC0401084, "GP7_DRVCTRL2", 0xC0401088) {
+		[ 0] = RCAR_GP_PIN(7,  0),	/* SSI3_SCK */
+		[ 1] = RCAR_GP_PIN(7,  1),	/* SSI3_WS */
+		[ 2] = RCAR_GP_PIN(7,  2),	/* SSI3_SD */
+		[ 3] = RCAR_GP_PIN(7,  3),	/* AUDIO1_CLKOUT2 */
+		[ 4] = RCAR_GP_PIN(7,  4),	/* AUDIO1_CLKOUT3 */
+		[ 5] = RCAR_GP_PIN(7,  5),	/* SSI4_SCK */
+		[ 6] = RCAR_GP_PIN(7,  6),	/* SSI4_WS */
+		[ 7] = RCAR_GP_PIN(7,  7),	/* SSI4_SD */
+		[ 8] = RCAR_GP_PIN(7,  8),	/* AUDIO_CLKA_A */
+		[ 9] = RCAR_GP_PIN(7,  9),	/* SSI5_SCK */
+		[10] = RCAR_GP_PIN(7, 10),	/* SSI5_WS */
+		[11] = RCAR_GP_PIN(7, 11),	/* SSI5_SD */
+		[12] = RCAR_GP_PIN(7, 12),	/* AUDIO_CLKB_A */
+		[13] = RCAR_GP_PIN(7, 13),	/* SSI6_SCK */
+		[14] = RCAR_GP_PIN(7, 14),	/* SSI6_WS */
+		[15] = RCAR_GP_PIN(7, 15),	/* SSI6_SD */
+		[16] = RCAR_GP_PIN(7, 16),	/* AUDIO_CLKC_A */
+		[17] = RCAR_GP_PIN(7, 17),	/* MSIOF5_SCK */
+		[18] = RCAR_GP_PIN(7, 18),	/* GP07_18 */
+		[19] = RCAR_GP_PIN(7, 19),	/* GP07_19 */
+		[20] = RCAR_GP_PIN(7, 20),	/* MSIOF5_TXD */
+		[21] = RCAR_GP_PIN(7, 21),	/* MSIOF5_RXD */
+		[22] = RCAR_GP_PIN(7, 22),	/* MSIOF5_SYNC */
+		[23] = RCAR_GP_PIN(7, 23),	/* MSIOF5_SS1 */
+		[24] = RCAR_GP_PIN(7, 24),	/* MSIOF5_SS2 */
+		[25] = RCAR_GP_PIN(7, 25),	/* MSIOF6_SCK_B */
+		[26] = RCAR_GP_PIN(7, 26),	/* MSIOF6_TXD_B */
+		[27] = RCAR_GP_PIN(7, 27),	/* MSIOF6_RXD_B */
+		[28] = RCAR_GP_PIN(7, 28),	/* MSIOF6_SYNC_B */
+		[29] = RCAR_GP_PIN(7, 29),	/* MSIOF6_SS1_B */
+		[30] = RCAR_GP_PIN(7, 30),	/* MSIOF6_SS2_B */
+		[31] = SH_PFC_PIN_NONE,
+	} },
+	{ RCAR5_PINMUX_DRIVE_REG("GP8_DRVCTRL0", 0xC0401880, "GP8_DRVCTRL1", 0xC0401884, "GP8_DRVCTRL2", 0xC0401888) {
+		[ 0] = RCAR_GP_PIN(8,  0),	/* SCL1 */
+		[ 1] = RCAR_GP_PIN(8,  1),	/* SDA1 */
+		[ 2] = RCAR_GP_PIN(8,  2),	/* SCL2 */
+		[ 3] = RCAR_GP_PIN(8,  3),	/* SDA2 */
+		[ 4] = RCAR_GP_PIN(8,  4),	/* SCL3 */
+		[ 5] = RCAR_GP_PIN(8,  5),	/* SDA3 */
+		[ 6] = RCAR_GP_PIN(8,  6),	/* SCL4 */
+		[ 7] = RCAR_GP_PIN(8,  7),	/* SDA4 */
+		[ 8] = RCAR_GP_PIN(8,  8),	/* SCL5 */
+		[ 9] = RCAR_GP_PIN(8,  9),	/* SDA5 */
+		[10] = RCAR_GP_PIN(8, 10),	/* SCL6 */
+		[11] = RCAR_GP_PIN(8, 11),	/* SDA6 */
+		[12] = RCAR_GP_PIN(8, 12),	/* SCL7 */
+		[13] = RCAR_GP_PIN(8, 13),	/* SDA7 */
+		[14] = RCAR_GP_PIN(8, 14),	/* SCL8 */
+		[15] = RCAR_GP_PIN(8, 15),	/* SDA8 */
+		[16] = SH_PFC_PIN_NONE,
+		[17] = SH_PFC_PIN_NONE,
+		[18] = SH_PFC_PIN_NONE,
+		[19] = SH_PFC_PIN_NONE,
+		[20] = SH_PFC_PIN_NONE,
+		[21] = SH_PFC_PIN_NONE,
+		[22] = SH_PFC_PIN_NONE,
+		[23] = SH_PFC_PIN_NONE,
+		[24] = SH_PFC_PIN_NONE,
+		[25] = SH_PFC_PIN_NONE,
+		[26] = RCAR_GP_PIN(8, 26),	/* S3CL0 */
+		[27] = RCAR_GP_PIN(8, 27),	/* S3DA0 */
+		[28] = RCAR_GP_PIN(8, 28),	/* S3CL1 */
+		[29] = RCAR_GP_PIN(8, 29),	/* S3DA1 */
+		[30] = RCAR_GP_PIN(8, 30),	/* S3CL2 */
+		[31] = RCAR_GP_PIN(8, 31),	/* S3DA2 */
+	} },
+	{ RCAR5_PINMUX_DRIVE_REG("GP9_DRVCTRL0", 0xC9B00080, "GP9_DRVCTRL1", 0xC9B00084, "GP9_DRVCTRL2", 0xC9B00088) {
+		[ 0] = RCAR_GP_PIN(9,  0),	/* ETHES0_PPS */
+		[ 1] = RCAR_GP_PIN(9,  1),	/* ETHES0_CAPTURE */
+		[ 2] = RCAR_GP_PIN(9,  2),	/* ETHES0_MATCH */
+		[ 3] = RCAR_GP_PIN(9,  3),	/* ETHES4_PPS */
+		[ 4] = RCAR_GP_PIN(9,  4),	/* ETHES4_CAPTURE */
+		[ 5] = RCAR_GP_PIN(9,  5),	/* ETHES4_MATCH */
+		[ 6] = RCAR_GP_PIN(9,  6),	/* ETH25G0_MDIO */
+		[ 7] = RCAR_GP_PIN(9,  7),	/* ETH25G0_MDC */
+		[ 8] = RCAR_GP_PIN(9,  8),	/* ETH25G0_LINK */
+		[ 9] = RCAR_GP_PIN(9,  9),	/* ETH25G0_PHYINT */
+		[10] = RCAR_GP_PIN(9, 10),	/* ETH10G0_MDIO */
+		[11] = RCAR_GP_PIN(9, 11),	/* ETH10G0_MDC */
+		[12] = RCAR_GP_PIN(9, 12),	/* ETH10G0_LINK */
+		[13] = RCAR_GP_PIN(9, 13),	/* ETH10G0_PHYINT */
+		[14] = RCAR_GP_PIN(9, 14),	/* RSW3_PPS */
+		[15] = RCAR_GP_PIN(9, 15),	/* RSW3_CAPTURE */
+		[16] = RCAR_GP_PIN(9, 16),	/* RSW3_MATCH */
+		[17] = SH_PFC_PIN_NONE,
+		[18] = SH_PFC_PIN_NONE,
+		[19] = SH_PFC_PIN_NONE,
+		[20] = SH_PFC_PIN_NONE,
+		[21] = SH_PFC_PIN_NONE,
+		[22] = SH_PFC_PIN_NONE,
+		[23] = SH_PFC_PIN_NONE,
+		[24] = SH_PFC_PIN_NONE,
+		[25] = SH_PFC_PIN_NONE,
+		[26] = SH_PFC_PIN_NONE,
+		[27] = SH_PFC_PIN_NONE,
+		[28] = SH_PFC_PIN_NONE,
+		[29] = SH_PFC_PIN_NONE,
+		[30] = SH_PFC_PIN_NONE,
+		[31] = SH_PFC_PIN_NONE,
+	} },
+	{ RCAR5_PINMUX_DRIVE_REG("GP10_DRVCTRL0", 0xC9B00880, "GP10_DRVCTRL1", 0xC9B00884, "GP10_DRVCTRL2", 0xC9B00888) {
+		[ 0] = RCAR_GP_PIN(10,  0),	/* USB0_PWEN */
+		[ 1] = RCAR_GP_PIN(10,  1),	/* USB0_OVC */
+		[ 2] = RCAR_GP_PIN(10,  2),	/* USB0_VBUS_VALID */
+		[ 3] = RCAR_GP_PIN(10,  3),	/* USB1_PWEN */
+		[ 4] = RCAR_GP_PIN(10,  4),	/* USB1_OVC */
+		[ 5] = RCAR_GP_PIN(10,  5),	/* USB1_VBUS_VALID */
+		[ 6] = RCAR_GP_PIN(10,  6),	/* USB2_PWEN */
+		[ 7] = RCAR_GP_PIN(10,  7),	/* USB2_OVC */
+		[ 8] = RCAR_GP_PIN(10,  8),	/* USB2_VBUS_VALID */
+		[ 9] = RCAR_GP_PIN(10,  9),	/* USB3_PWEN */
+		[10] = RCAR_GP_PIN(10, 10),	/* USB3_OVC */
+		[11] = RCAR_GP_PIN(10, 11),	/* USB3_VBUS_VALID */
+		[12] = RCAR_GP_PIN(10, 12),	/* PCIE40_CLKREQ_N */
+		[13] = RCAR_GP_PIN(10, 13),	/* PCIE41_CLKREQ_N */
+		[14] = SH_PFC_PIN_NONE,
+		[15] = SH_PFC_PIN_NONE,
+		[16] = SH_PFC_PIN_NONE,
+		[17] = SH_PFC_PIN_NONE,
+		[18] = SH_PFC_PIN_NONE,
+		[19] = SH_PFC_PIN_NONE,
+		[20] = SH_PFC_PIN_NONE,
+		[21] = SH_PFC_PIN_NONE,
+		[22] = SH_PFC_PIN_NONE,
+		[23] = SH_PFC_PIN_NONE,
+		[24] = SH_PFC_PIN_NONE,
+		[25] = SH_PFC_PIN_NONE,
+		[26] = SH_PFC_PIN_NONE,
+		[27] = SH_PFC_PIN_NONE,
+		[28] = SH_PFC_PIN_NONE,
+		[29] = SH_PFC_PIN_NONE,
+		[30] = SH_PFC_PIN_NONE,
+		[31] = SH_PFC_PIN_NONE,
+	} },
+	{ /* sentinel */ },
+};
+
+enum ioctrl_regs {
+	GP0_TDSEL0,
+	GP0_TDSEL1,
+	GP1_TDSEL0,
+	GP1_TDSEL1,
+	GP2_TDSEL0,
+	GP2_TDSEL1,
+	GP3_TDSEL0,
+	GP3_TDSEL1,
+	GP4_TDSEL0,
+	GP4_TDSEL1,
+	GP5_TDSEL0,
+	GP5_TDSEL1,
+	GP6_TDSEL0,
+	GP6_TDSEL1,
+	GP7_TDSEL0,
+	GP7_TDSEL1,
+	GP8_TDSEL0,
+	GP8_TDSEL1,
+	GP9_TDSEL0,
+	GP9_TDSEL1,
+	GP10_TDSEL0,
+	GP10_TDSEL1,
+};
+
+static const struct pinmux_ioctrl_reg pinmux_ioctrl_regs[] = {
+	[GP0_TDSEL0] = { 0xC1080094, },
+	[GP0_TDSEL1] = { 0xC1080098, },
+	[GP1_TDSEL0] = { 0xC1080894, },
+	[GP1_TDSEL1] = { 0xC1080898, },
+	[GP2_TDSEL0] = { 0xC1081094, },
+	[GP2_TDSEL1] = { 0xC1081098, },
+	[GP3_TDSEL0] = { 0xC0800094, },
+	[GP3_TDSEL1] = { 0xC0800098, },
+	[GP4_TDSEL0] = { 0xC0800894, },
+	[GP4_TDSEL1] = { 0xC0800898, },
+	[GP5_TDSEL0] = { 0xC0400094, },
+	[GP5_TDSEL1] = { 0xC0400098, },
+	[GP6_TDSEL0] = { 0xC0400894, },
+	[GP6_TDSEL1] = { 0xC0400898, },
+	[GP7_TDSEL0] = { 0xC0401094, },
+	[GP7_TDSEL1] = { 0xC0401098, },
+	[GP8_TDSEL0] = { 0xC0401894, },
+	[GP8_TDSEL1] = { 0xC0401898, },
+	[GP9_TDSEL0] = { 0xC9B00094, },
+	[GP9_TDSEL1] = { 0xC9B00098, },
+	[GP10_TDSEL0] = { 0xC9B00894, },
+	[GP10_TDSEL1] = { 0xC9B00898, },
+	{ /* sentinel */ }
+};
+
+static const struct pinmux_bias_reg pinmux_bias_regs[] = {
+	{ PINMUX_BIAS_REG("GP0_PULLEN", 0xC10800C0, "GP0_PUDSEL", 0xC10800C4) {
+		[ 0] = RCAR_GP_PIN(0,  0),	/* GP0_00 */
+		[ 1] = RCAR_GP_PIN(0,  1),	/* GP0_01 */
+		[ 2] = RCAR_GP_PIN(0,  2),	/* GP0_02 */
+		[ 3] = RCAR_GP_PIN(0,  3),	/* STPWT_EXTFXR_A */
+		[ 4] = RCAR_GP_PIN(0,  4),	/* FXR_CLKOUT1_A */
+		[ 5] = RCAR_GP_PIN(0,  5),	/* FXR_CLKOUT2_A */
+		[ 6] = RCAR_GP_PIN(0,  6),	/* CLK_EXTFXR_A */
+		[ 7] = RCAR_GP_PIN(0,  7),	/* FXR_TXDA_A */
+		[ 8] = RCAR_GP_PIN(0,  8),	/* FXR_TXENA_N_A */
+		[ 9] = RCAR_GP_PIN(0,  9),	/* RXDA_EXTFXR_A */
+		[10] = RCAR_GP_PIN(0, 10),	/* FXR_TXDB_A */
+		[11] = RCAR_GP_PIN(0, 11),	/* FXR_TXENB_N_A */
+		[12] = RCAR_GP_PIN(0, 12),	/* RXDB_EXTFXR_A */
+		[13] = RCAR_GP_PIN(0, 13),	/* MSIOF0_SCK */
+		[14] = RCAR_GP_PIN(0, 14),	/* MSIOF0_TXD */
+		[15] = RCAR_GP_PIN(0, 15),	/* MSIOF0_RXD */
+		[16] = RCAR_GP_PIN(0, 16),	/* MSIOF0_SYNC */
+		[17] = RCAR_GP_PIN(0, 17),	/* MSIOF0_SS1 */
+		[18] = RCAR_GP_PIN(0, 18),	/* MSIOF0_SS2 */
+		[19] = RCAR_GP_PIN(0, 19),	/* MSIOF1_SCK_A */
+		[20] = RCAR_GP_PIN(0, 20),	/* MSIOF1_TXD_A */
+		[21] = RCAR_GP_PIN(0, 21),	/* MSIOF1_RXD_A */
+		[22] = RCAR_GP_PIN(0, 22),	/* MSIOF1_SYNC_A */
+		[23] = RCAR_GP_PIN(0, 23),	/* MSIOF1_SS1_A */
+		[24] = RCAR_GP_PIN(0, 24),	/* MSIOF1_SS2_A */
+		[25] = RCAR_GP_PIN(0, 25),	/* DP0_HOTPLUG */
+		[26] = RCAR_GP_PIN(0, 26),	/* DP1_HOTPLUG */
+		[27] = RCAR_GP_PIN(0, 27),	/* DP2_HOTPLUG */
+		[28] = SH_PFC_PIN_NONE,
+		[29] = SH_PFC_PIN_NONE,
+		[30] = SH_PFC_PIN_NONE,
+		[31] = SH_PFC_PIN_NONE,
+	} },
+	{ PINMUX_BIAS_REG("GP1_PULLEN", 0xC10808C0, "GP1_PUDSEL", 0xC10808C4) {
+		[ 0] = RCAR_GP_PIN(1,  0),	/* CAN0RX_INTP0 */
+		[ 1] = RCAR_GP_PIN(1,  1),	/* CAN0TX */
+		[ 2] = RCAR_GP_PIN(1,  2),	/* CAN1RX_INTP1 */
+		[ 3] = RCAR_GP_PIN(1,  3),	/* CAN1TX */
+		[ 4] = RCAR_GP_PIN(1,  4),	/* CAN2RX_INTP2 */
+		[ 5] = RCAR_GP_PIN(1,  5),	/* CAN2TX */
+		[ 6] = RCAR_GP_PIN(1,  6),	/* CAN3RX_INTP3 */
+		[ 7] = RCAR_GP_PIN(1,  7),	/* CAN3TX */
+		[ 8] = RCAR_GP_PIN(1,  8),	/* CAN4RX_INTP4 */
+		[ 9] = RCAR_GP_PIN(1,  9),	/* CAN4TX */
+		[10] = RCAR_GP_PIN(1, 10),	/* CAN5RX_INTP5 */
+		[11] = RCAR_GP_PIN(1, 11),	/* CAN5TX */
+		[12] = RCAR_GP_PIN(1, 12),	/* CAN6RX_INTP6 */
+		[13] = RCAR_GP_PIN(1, 13),	/* CAN6TX */
+		[14] = RCAR_GP_PIN(1, 14),	/* RLIN30RX_INTP16 */
+		[15] = RCAR_GP_PIN(1, 15),	/* RLIN30TX */
+		[16] = RCAR_GP_PIN(1, 16),	/* RLIN31RX_INTP17 */
+		[17] = RCAR_GP_PIN(1, 17),	/* RLIN31TX */
+		[18] = RCAR_GP_PIN(1, 18),	/* RLIN32RX_INTP18 */
+		[19] = RCAR_GP_PIN(1, 19),	/* RLIN32TX */
+		[20] = RCAR_GP_PIN(1, 20),	/* RLIN33RX_INTP19 */
+		[21] = RCAR_GP_PIN(1, 21),	/* RLIN33TX */
+		[22] = SH_PFC_PIN_NONE,
+		[23] = SH_PFC_PIN_NONE,
+		[24] = SH_PFC_PIN_NONE,
+		[25] = SH_PFC_PIN_NONE,
+		[26] = SH_PFC_PIN_NONE,
+		[27] = SH_PFC_PIN_NONE,
+		[28] = SH_PFC_PIN_NONE,
+		[29] = SH_PFC_PIN_NONE,
+		[30] = SH_PFC_PIN_NONE,
+		[31] = SH_PFC_PIN_NONE,
+	} },
+	{ PINMUX_BIAS_REG("GP2_PULLEN", 0xC10810C0, "GP2_PUDSEL", 0xC10810C4) {
+		[ 0] = RCAR_GP_PIN(2,  0),	/* RLIN34RX_INTP20_B */
+		[ 1] = RCAR_GP_PIN(2,  1),	/* RLIN34TX_B */
+		[ 2] = RCAR_GP_PIN(2,  2),	/* RLIN35RX_INTP21_B */
+		[ 3] = RCAR_GP_PIN(2,  3),	/* RLIN35TX_B */
+		[ 4] = RCAR_GP_PIN(2,  4),	/* RLIN36RX_INTP22_B */
+		[ 5] = RCAR_GP_PIN(2,  5),	/* RLIN36TX_B */
+		[ 6] = RCAR_GP_PIN(2,  6),	/* RLIN37RX_INTP23_B */
+		[ 7] = RCAR_GP_PIN(2,  7),	/* RLIN37TX_B */
+		[ 8] = RCAR_GP_PIN(2,  8),	/* CAN12RX_INTP12_B */
+		[ 9] = RCAR_GP_PIN(2,  9),	/* CAN12TX_B */
+		[10] = RCAR_GP_PIN(2, 10),	/* CAN13RX_INTP13_B */
+		[11] = RCAR_GP_PIN(2, 11),	/* CAN13TX_B */
+		[12] = RCAR_GP_PIN(2, 12),	/* CAN14RX_INTP14_B */
+		[13] = RCAR_GP_PIN(2, 13),	/* CAN14TX_B */
+		[14] = RCAR_GP_PIN(2, 14),	/* CAN15RX_INTP15_B */
+		[15] = RCAR_GP_PIN(2, 15),	/* CAN15TX_B */
+		[16] = RCAR_GP_PIN(2, 16),	/* CAN_CLK */
+		[17] = RCAR_GP_PIN(2, 17),	/* INTP32_B */
+		[18] = RCAR_GP_PIN(2, 18),	/* INTP33_B */
+		[19] = RCAR_GP_PIN(2, 19),	/* SCL0 */
+		[20] = RCAR_GP_PIN(2, 20),	/* SDA0 */
+		[21] = RCAR_GP_PIN(2, 21),	/* AVS0 */
+		[22] = RCAR_GP_PIN(2, 22),	/* AVS1 */
+		[23] = RCAR_GP_PIN(2, 23),	/* EXTCLK0O_B */
+		[24] = RCAR_GP_PIN(2, 24),	/* TAUD1O0 */
+		[25] = RCAR_GP_PIN(2, 25),	/* TAUD1O1 */
+		[26] = RCAR_GP_PIN(2, 26),	/* TAUD1O2 */
+		[27] = RCAR_GP_PIN(2, 27),	/* TAUD1O3 */
+		[28] = RCAR_GP_PIN(2, 28),	/* INTP34_B */
+		[29] = SH_PFC_PIN_NONE,
+		[30] = SH_PFC_PIN_NONE,
+		[31] = SH_PFC_PIN_NONE,
+	} },
+	{ PINMUX_BIAS_REG("GP3_PULLEN", 0xC08000C0, "GP3_PUDSEL", 0xC08000C4) {
+		[ 0] = RCAR_GP_PIN(3,  0),	/* QSPI0_SPCLK */
+		[ 1] = RCAR_GP_PIN(3,  1),	/* QSPI0_MOSI_IO0 */
+		[ 2] = RCAR_GP_PIN(3,  2),	/* QSPI0_MISO_IO1 */
+		[ 3] = RCAR_GP_PIN(3,  3),	/* QSPI0_IO2 */
+		[ 4] = RCAR_GP_PIN(3,  4),	/* QSPI0_IO3 */
+		[ 5] = RCAR_GP_PIN(3,  5),	/* QSPI0_SSL */
+		[ 6] = RCAR_GP_PIN(3,  6),	/* RPC_RESET_N */
+		[ 7] = RCAR_GP_PIN(3,  7),	/* RPC_WP_N */
+		[ 8] = RCAR_GP_PIN(3,  8),	/* RPC_INT_N */
+		[ 9] = RCAR_GP_PIN(3,  9),	/* QSPI1_SPCLK */
+		[10] = RCAR_GP_PIN(3, 10),	/* QSPI1_MOSI_IO0 */
+		[11] = RCAR_GP_PIN(3, 11),	/* QSPI1_MISO_IO1 */
+		[12] = RCAR_GP_PIN(3, 12),	/* QSPI1_IO2 */
+		[13] = RCAR_GP_PIN(3, 13),	/* QSPI1_IO3 */
+		[14] = RCAR_GP_PIN(3, 14),	/* QSPI1_SSL */
+		[15] = RCAR_GP_PIN(3, 15),	/* ERROROUT_N */
+		[16] = RCAR_GP_PIN(3, 16),	/* ERRORIN_N */
+		[17] = SH_PFC_PIN_NONE,
+		[18] = SH_PFC_PIN_NONE,
+		[19] = SH_PFC_PIN_NONE,
+		[20] = SH_PFC_PIN_NONE,
+		[21] = SH_PFC_PIN_NONE,
+		[22] = SH_PFC_PIN_NONE,
+		[23] = SH_PFC_PIN_NONE,
+		[24] = SH_PFC_PIN_NONE,
+		[25] = SH_PFC_PIN_NONE,
+		[26] = SH_PFC_PIN_NONE,
+		[27] = SH_PFC_PIN_NONE,
+		[28] = SH_PFC_PIN_NONE,
+		[29] = SH_PFC_PIN_NONE,
+		[30] = SH_PFC_PIN_NONE,
+		[31] = SH_PFC_PIN_NONE,
+	} },
+	{ PINMUX_BIAS_REG("GP4_PULLEN", 0xC08008C0, "GP4_PUDSEL", 0xC08008C4) {
+		[ 0] = RCAR_GP_PIN(4,  0),	/* MMC0_SD_CLK */
+		[ 1] = RCAR_GP_PIN(4,  1),	/* MMC0_SD_CMD */
+		[ 2] = RCAR_GP_PIN(4,  2),	/* MMC0_SD_D0 */
+		[ 3] = RCAR_GP_PIN(4,  3),	/* MMC0_SD_D1 */
+		[ 4] = RCAR_GP_PIN(4,  4),	/* MMC0_SD_D2 */
+		[ 5] = RCAR_GP_PIN(4,  5),	/* MMC0_SD_D3 */
+		[ 6] = RCAR_GP_PIN(4,  6),	/* MMC0_D4 */
+		[ 7] = RCAR_GP_PIN(4,  7),	/* MMC0_D5 */
+		[ 8] = RCAR_GP_PIN(4,  8),	/* MMC0_D6 */
+		[ 9] = RCAR_GP_PIN(4,  9),	/* MMC0_D7 */
+		[10] = RCAR_GP_PIN(4, 10),	/* MMC0_DS */
+		[11] = RCAR_GP_PIN(4, 11),	/* SD0_WP */
+		[12] = RCAR_GP_PIN(4, 12),	/* SD0_CD */
+		[13] = RCAR_GP_PIN(4, 13),	/* ERRORIN_N */
+		[14] = RCAR_GP_PIN(4, 14),	/* PCIE60_CLKREQ_N */
+		[15] = RCAR_GP_PIN(4, 15),	/* PCIE61_CLKREQ_N */
+		[16] = SH_PFC_PIN_NONE,
+		[17] = SH_PFC_PIN_NONE,
+		[18] = SH_PFC_PIN_NONE,
+		[19] = SH_PFC_PIN_NONE,
+		[20] = SH_PFC_PIN_NONE,
+		[21] = SH_PFC_PIN_NONE,
+		[22] = SH_PFC_PIN_NONE,
+		[23] = SH_PFC_PIN_NONE,
+		[24] = SH_PFC_PIN_NONE,
+		[25] = SH_PFC_PIN_NONE,
+		[26] = SH_PFC_PIN_NONE,
+		[27] = SH_PFC_PIN_NONE,
+		[28] = SH_PFC_PIN_NONE,
+		[29] = SH_PFC_PIN_NONE,
+		[30] = SH_PFC_PIN_NONE,
+		[31] = SH_PFC_PIN_NONE,
+	} },
+	{ PINMUX_BIAS_REG("GP5_PULLEN", 0xC04000C0, "GP5_PUDSEL", 0xC04000C4) {
+		[ 0] = RCAR_GP_PIN(5,  0),	/* HTX0 */
+		[ 1] = RCAR_GP_PIN(5,  1),	/* HRX0 */
+		[ 2] = RCAR_GP_PIN(5,  2),	/* HRTS0_N */
+		[ 3] = RCAR_GP_PIN(5,  3),	/* HCTS0_N */
+		[ 4] = RCAR_GP_PIN(5,  4),	/* HSCK0 */
+		[ 5] = RCAR_GP_PIN(5,  5),	/* SCIF_CLK */
+		[ 6] = RCAR_GP_PIN(5,  6),	/* HTX1 */
+		[ 7] = RCAR_GP_PIN(5,  7),	/* HRX1 */
+		[ 8] = RCAR_GP_PIN(5,  8),	/* HRTS1_N */
+		[ 9] = RCAR_GP_PIN(5,  9),	/* HCTS1_N */
+		[10] = RCAR_GP_PIN(5, 10),	/* HSCK1 */
+		[11] = RCAR_GP_PIN(5, 11),	/* IRQ0_A */
+		[12] = RCAR_GP_PIN(5, 12),	/* IRQ1_A */
+		[13] = RCAR_GP_PIN(5, 13),	/* IRQ2_A */
+		[14] = RCAR_GP_PIN(5, 14),	/* IRQ3_A */
+		[15] = RCAR_GP_PIN(5, 15),	/* TCLK1 */
+		[16] = RCAR_GP_PIN(5, 16),	/* TCLK2 */
+		[17] = RCAR_GP_PIN(5, 17),	/* TCLK3 */
+		[18] = RCAR_GP_PIN(5, 18),	/* TCLK4 */
+		[19] = RCAR_GP_PIN(5, 19),	/* TPU0TO0 */
+		[20] = RCAR_GP_PIN(5, 20),	/* TPU0TO1 */
+		[21] = RCAR_GP_PIN(5, 21),	/* TPU0TO2 */
+		[22] = RCAR_GP_PIN(5, 22),	/* TPU0TO3 */
+		[23] = SH_PFC_PIN_NONE,
+		[24] = SH_PFC_PIN_NONE,
+		[25] = SH_PFC_PIN_NONE,
+		[26] = SH_PFC_PIN_NONE,
+		[27] = SH_PFC_PIN_NONE,
+		[28] = SH_PFC_PIN_NONE,
+		[29] = SH_PFC_PIN_NONE,
+		[30] = SH_PFC_PIN_NONE,
+		[31] = SH_PFC_PIN_NONE,
+	} },
+	{ PINMUX_BIAS_REG("GP6_PULLEN", 0xC04008C0, "GP6_PUDSEL", 0xC04008C4) {
+		[ 0] = RCAR_GP_PIN(6,  0),	/* RIF6_D0 */
+		[ 1] = RCAR_GP_PIN(6,  1),	/* RIF6_D1 */
+		[ 2] = RCAR_GP_PIN(6,  2),	/* RIF6_SYNC */
+		[ 3] = RCAR_GP_PIN(6,  3),	/* RIF6_CLK */
+		[ 4] = RCAR_GP_PIN(6,  4),	/* MSIOF7_SCK_A */
+		[ 5] = RCAR_GP_PIN(6,  5),	/* MSIOF7_TXD_A */
+		[ 6] = RCAR_GP_PIN(6,  6),	/* MSIOF7_RXD_A */
+		[ 7] = RCAR_GP_PIN(6,  7),	/* MSIOF7_SYNC_A */
+		[ 8] = RCAR_GP_PIN(6,  8),	/* MSIOF7_SS1_A */
+		[ 9] = RCAR_GP_PIN(6,  9),	/* MSIOF7_SS2_A */
+		[10] = RCAR_GP_PIN(6, 10),	/* MSIOF4_SCK_B */
+		[11] = RCAR_GP_PIN(6, 11),	/* MSIOF4_TXD_B */
+		[12] = RCAR_GP_PIN(6, 12),	/* MSIOF4_RXD_B */
+		[13] = RCAR_GP_PIN(6, 13),	/* MSIOF4_SYNC_B */
+		[14] = RCAR_GP_PIN(6, 14),	/* MSIOF4_SS1_B */
+		[15] = RCAR_GP_PIN(6, 15),	/* MSIOF4_SS2_B */
+		[16] = RCAR_GP_PIN(6, 16),	/* SSI0_SCK */
+		[17] = RCAR_GP_PIN(6, 17),	/* SSI0_WS */
+		[18] = RCAR_GP_PIN(6, 18),	/* SSI0_SD */
+		[19] = RCAR_GP_PIN(6, 19),	/* AUDIO0_CLKOUT0 */
+		[20] = RCAR_GP_PIN(6, 20),	/* AUDIO0_CLKOUT1 */
+		[21] = RCAR_GP_PIN(6, 21),	/* SSI1_SCK */
+		[22] = RCAR_GP_PIN(6, 22),	/* SSI1_WS */
+		[23] = RCAR_GP_PIN(6, 23),	/* SSI1_SD */
+		[24] = RCAR_GP_PIN(6, 24),	/* AUDIO0_CLKOUT2 */
+		[25] = RCAR_GP_PIN(6, 25),	/* AUDIO0_CLKOUT3 */
+		[26] = RCAR_GP_PIN(6, 26),	/* SSI2_SCK */
+		[27] = RCAR_GP_PIN(6, 27),	/* SSI2_WS */
+		[28] = RCAR_GP_PIN(6, 28),	/* SSI2_SD */
+		[29] = RCAR_GP_PIN(6, 29),	/* AUDIO1_CLKOUT0 */
+		[30] = RCAR_GP_PIN(6, 30),	/* AUDIO1_CLKOUT1 */
+		[31] = SH_PFC_PIN_NONE,
+	} },
+	{ PINMUX_BIAS_REG("GP7_PULLEN", 0xC04010C0, "GP7_PUDSEL", 0xC04010C4) {
+		[ 0] = RCAR_GP_PIN(7,  0),	/* SSI3_SCK */
+		[ 1] = RCAR_GP_PIN(7,  1),	/* SSI3_WS */
+		[ 2] = RCAR_GP_PIN(7,  2),	/* SSI3_SD */
+		[ 3] = RCAR_GP_PIN(7,  3),	/* AUDIO1_CLKOUT2 */
+		[ 4] = RCAR_GP_PIN(7,  4),	/* AUDIO1_CLKOUT3 */
+		[ 5] = RCAR_GP_PIN(7,  5),	/* SSI4_SCK */
+		[ 6] = RCAR_GP_PIN(7,  6),	/* SSI4_WS */
+		[ 7] = RCAR_GP_PIN(7,  7),	/* SSI4_SD */
+		[ 8] = RCAR_GP_PIN(7,  8),	/* AUDIO_CLKA_A */
+		[ 9] = RCAR_GP_PIN(7,  9),	/* SSI5_SCK */
+		[10] = RCAR_GP_PIN(7, 10),	/* SSI5_WS */
+		[11] = RCAR_GP_PIN(7, 11),	/* SSI5_SD */
+		[12] = RCAR_GP_PIN(7, 12),	/* AUDIO_CLKB_A */
+		[13] = RCAR_GP_PIN(7, 13),	/* SSI6_SCK */
+		[14] = RCAR_GP_PIN(7, 14),	/* SSI6_WS */
+		[15] = RCAR_GP_PIN(7, 15),	/* SSI6_SD */
+		[16] = RCAR_GP_PIN(7, 16),	/* AUDIO_CLKC_A */
+		[17] = RCAR_GP_PIN(7, 17),	/* MSIOF5_SCK */
+		[18] = RCAR_GP_PIN(7, 18),	/* GP07_18 */
+		[19] = RCAR_GP_PIN(7, 19),	/* GP07_19 */
+		[20] = RCAR_GP_PIN(7, 20),	/* MSIOF5_TXD */
+		[21] = RCAR_GP_PIN(7, 21),	/* MSIOF5_RXD */
+		[22] = RCAR_GP_PIN(7, 22),	/* MSIOF5_SYNC */
+		[23] = RCAR_GP_PIN(7, 23),	/* MSIOF5_SS1 */
+		[24] = RCAR_GP_PIN(7, 24),	/* MSIOF5_SS2 */
+		[25] = RCAR_GP_PIN(7, 25),	/* MSIOF6_SCK_B */
+		[26] = RCAR_GP_PIN(7, 26),	/* MSIOF6_TXD_B */
+		[27] = RCAR_GP_PIN(7, 27),	/* MSIOF6_RXD_B */
+		[28] = RCAR_GP_PIN(7, 28),	/* MSIOF6_SYNC_B */
+		[29] = RCAR_GP_PIN(7, 29),	/* MSIOF6_SS1_B */
+		[30] = RCAR_GP_PIN(7, 30),	/* MSIOF6_SS2_B */
+		[31] = SH_PFC_PIN_NONE,
+	} },
+	{ PINMUX_BIAS_REG("GP8_PULLEN", 0xC04018C0, "GP8_PUDSEL", 0xC04018C4) {
+		[ 0] = RCAR_GP_PIN(8,  0),	/* SCL1 */
+		[ 1] = RCAR_GP_PIN(8,  1),	/* SDA1 */
+		[ 2] = RCAR_GP_PIN(8,  2),	/* SCL2 */
+		[ 3] = RCAR_GP_PIN(8,  3),	/* SDA2 */
+		[ 4] = RCAR_GP_PIN(8,  4),	/* SCL3 */
+		[ 5] = RCAR_GP_PIN(8,  5),	/* SDA3 */
+		[ 6] = RCAR_GP_PIN(8,  6),	/* SCL4 */
+		[ 7] = RCAR_GP_PIN(8,  7),	/* SDA4 */
+		[ 8] = RCAR_GP_PIN(8,  8),	/* SCL5 */
+		[ 9] = RCAR_GP_PIN(8,  9),	/* SDA5 */
+		[10] = RCAR_GP_PIN(8, 10),	/* SCL6 */
+		[11] = RCAR_GP_PIN(8, 11),	/* SDA6 */
+		[12] = RCAR_GP_PIN(8, 12),	/* SCL7 */
+		[13] = RCAR_GP_PIN(8, 13),	/* SDA7 */
+		[14] = RCAR_GP_PIN(8, 14),	/* SCL8 */
+		[15] = RCAR_GP_PIN(8, 15),	/* SDA8 */
+		[16] = SH_PFC_PIN_NONE,
+		[17] = SH_PFC_PIN_NONE,
+		[18] = SH_PFC_PIN_NONE,
+		[19] = SH_PFC_PIN_NONE,
+		[20] = SH_PFC_PIN_NONE,
+		[21] = SH_PFC_PIN_NONE,
+		[22] = SH_PFC_PIN_NONE,
+		[23] = SH_PFC_PIN_NONE,
+		[24] = SH_PFC_PIN_NONE,
+		[25] = SH_PFC_PIN_NONE,
+		[26] = RCAR_GP_PIN(8, 26),	/* S3CL0 */
+		[27] = RCAR_GP_PIN(8, 27),	/* S3DA0 */
+		[28] = RCAR_GP_PIN(8, 28),	/* S3CL1 */
+		[29] = RCAR_GP_PIN(8, 29),	/* S3DA1 */
+		[30] = RCAR_GP_PIN(8, 30),	/* S3CL2 */
+		[31] = RCAR_GP_PIN(8, 31),	/* S3DA2 */
+	} },
+	{ PINMUX_BIAS_REG("GP9_PULLEN", 0xC9B000C0, "GP9_PUDSEL", 0xC9B000C4) {
+		[ 0] = RCAR_GP_PIN(9,  0),	/* ETHES0_PPS */
+		[ 1] = RCAR_GP_PIN(9,  1),	/* ETHES0_CAPTURE */
+		[ 2] = RCAR_GP_PIN(9,  2),	/* ETHES0_MATCH */
+		[ 3] = RCAR_GP_PIN(9,  3),	/* ETHES4_PPS */
+		[ 4] = RCAR_GP_PIN(9,  4),	/* ETHES4_CAPTURE */
+		[ 5] = RCAR_GP_PIN(9,  5),	/* ETHES4_MATCH */
+		[ 6] = RCAR_GP_PIN(9,  6),	/* ETH25G0_MDIO */
+		[ 7] = RCAR_GP_PIN(9,  7),	/* ETH25G0_MDC */
+		[ 8] = RCAR_GP_PIN(9,  8),	/* ETH25G0_LINK */
+		[ 9] = RCAR_GP_PIN(9,  9),	/* ETH25G0_PHYINT */
+		[10] = RCAR_GP_PIN(9, 10),	/* ETH10G0_MDIO */
+		[11] = RCAR_GP_PIN(9, 11),	/* ETH10G0_MDC */
+		[12] = RCAR_GP_PIN(9, 12),	/* ETH10G0_LINK */
+		[13] = RCAR_GP_PIN(9, 13),	/* ETH10G0_PHYINT */
+		[14] = RCAR_GP_PIN(9, 14),	/* RSW3_PPS */
+		[15] = RCAR_GP_PIN(9, 15),	/* RSW3_CAPTURE */
+		[16] = RCAR_GP_PIN(9, 16),	/* RSW3_MATCH */
+		[17] = SH_PFC_PIN_NONE,
+		[18] = SH_PFC_PIN_NONE,
+		[19] = SH_PFC_PIN_NONE,
+		[20] = SH_PFC_PIN_NONE,
+		[21] = SH_PFC_PIN_NONE,
+		[22] = SH_PFC_PIN_NONE,
+		[23] = SH_PFC_PIN_NONE,
+		[24] = SH_PFC_PIN_NONE,
+		[25] = SH_PFC_PIN_NONE,
+		[26] = SH_PFC_PIN_NONE,
+		[27] = SH_PFC_PIN_NONE,
+		[28] = SH_PFC_PIN_NONE,
+		[29] = SH_PFC_PIN_NONE,
+		[30] = SH_PFC_PIN_NONE,
+		[31] = SH_PFC_PIN_NONE,
+	} },
+	{ PINMUX_BIAS_REG("GP10_PULLEN", 0xC9B008C0, "GP10_PUDSEL", 0xC9B008C4) {
+		[ 0] = RCAR_GP_PIN(10,  0),	/* USB0_PWEN */
+		[ 1] = RCAR_GP_PIN(10,  1),	/* USB0_OVC */
+		[ 2] = RCAR_GP_PIN(10,  2),	/* USB0_VBUS_VALID */
+		[ 3] = RCAR_GP_PIN(10,  3),	/* USB1_PWEN */
+		[ 4] = RCAR_GP_PIN(10,  4),	/* USB1_OVC */
+		[ 5] = RCAR_GP_PIN(10,  5),	/* USB1_VBUS_VALID */
+		[ 6] = RCAR_GP_PIN(10,  6),	/* USB2_PWEN */
+		[ 7] = RCAR_GP_PIN(10,  7),	/* USB2_OVC */
+		[ 8] = RCAR_GP_PIN(10,  8),	/* USB2_VBUS_VALID */
+		[ 9] = RCAR_GP_PIN(10,  9),	/* USB3_PWEN */
+		[10] = RCAR_GP_PIN(10, 10),	/* USB3_OVC */
+		[11] = RCAR_GP_PIN(10, 11),	/* USB3_VBUS_VALID */
+		[12] = RCAR_GP_PIN(10, 12),	/* PCIE40_CLKREQ_N */
+		[13] = RCAR_GP_PIN(10, 13),	/* PCIE41_CLKREQ_N */
+		[14] = SH_PFC_PIN_NONE,
+		[15] = SH_PFC_PIN_NONE,
+		[16] = SH_PFC_PIN_NONE,
+		[17] = SH_PFC_PIN_NONE,
+		[18] = SH_PFC_PIN_NONE,
+		[19] = SH_PFC_PIN_NONE,
+		[20] = SH_PFC_PIN_NONE,
+		[21] = SH_PFC_PIN_NONE,
+		[22] = SH_PFC_PIN_NONE,
+		[23] = SH_PFC_PIN_NONE,
+		[24] = SH_PFC_PIN_NONE,
+		[25] = SH_PFC_PIN_NONE,
+		[26] = SH_PFC_PIN_NONE,
+		[27] = SH_PFC_PIN_NONE,
+		[28] = SH_PFC_PIN_NONE,
+		[29] = SH_PFC_PIN_NONE,
+		[30] = SH_PFC_PIN_NONE,
+		[31] = SH_PFC_PIN_NONE,
+	} },
+	{ /* sentinel */ },
+};
+
+static int rcar5_pinconf_write_bit(struct sh_pfc *pfc, unsigned int bit,
+				   u16 value, u32 reg)
+{
+	u32 val = sh_pfc_read(pfc, reg);
+
+	val &= ~BIT(bit);
+	val |= value << bit;
+
+	sh_pfc_write(pfc, reg, val);
+
+	return 0;
+}
+
+static int rcar5_pinconf_set_drive_strength(struct sh_pfc *pfc,
+					    unsigned int pin, u16 strength)
+{
+	unsigned int bank = pin / 32;
+	unsigned int bit = pin % 32;
+	const struct rcar5_pinmux_drive_reg *reg = &pinmux_drive_regs[bank];
+
+	if (reg->pins[bit] != pin)
+		return -EINVAL;
+
+	if (strength < 3 || strength > 24)
+		return -EINVAL;
+
+	/* Convert the value from mA based on a full drive strength value of
+	 * 24mA. We can make the full value configurable later if needed.
+	 */
+	strength = strength / 3 - 1;
+
+	rcar5_pinconf_write_bit(pfc, bit, bitfield_extract(strength, 0, 1), reg->drvctrl0);
+	rcar5_pinconf_write_bit(pfc, bit, bitfield_extract(strength, 1, 1), reg->drvctrl1);
+	rcar5_pinconf_write_bit(pfc, bit, bitfield_extract(strength, 2, 1), reg->drvctrl2);
+
+	return 0;
+}
+
+static const struct sh_pfc_soc_operations r8a78000_pin_ops = {
+	.get_bias = rcar_pinmux_get_bias,
+	.set_bias = rcar_pinmux_set_bias,
+	.set_drive_strength = rcar5_pinconf_set_drive_strength,
+};
+
+const struct sh_pfc_soc_info r8a78000_pinmux_info = {
+	.name = "r8a78000_pfc",
+	.ops = &r8a78000_pin_ops,
+	.unlock_reg = 0x1ff,	/* PMMRn mask */
+
+	.function = { PINMUX_FUNCTION_BEGIN, PINMUX_FUNCTION_END },
+
+	.pins = pinmux_pins,
+	.nr_pins = ARRAY_SIZE(pinmux_pins),
+	.groups = pinmux_groups,
+	.nr_groups = ARRAY_SIZE(pinmux_groups),
+	.functions = pinmux_functions,
+	.nr_functions = ARRAY_SIZE(pinmux_functions),
+
+	.cfg_regs = pinmux_config_regs,
+	.bias_regs = pinmux_bias_regs,
+	.ioctrl_regs = pinmux_ioctrl_regs,
+
+	.pinmux_data = pinmux_data,
+	.pinmux_data_size = ARRAY_SIZE(pinmux_data),
+};
diff --git a/drivers/pinctrl/renesas/pfc.c b/drivers/pinctrl/renesas/pfc.c
index a7fd37a2177..1e0fc3f563d 100644
--- a/drivers/pinctrl/renesas/pfc.c
+++ b/drivers/pinctrl/renesas/pfc.c
@@ -45,6 +45,7 @@ enum sh_pfc_model {
 	SH_PFC_R8A779F0,
 	SH_PFC_R8A779G0,
 	SH_PFC_R8A779H0,
+	SH_PFC_R8A78000,
 };
 
 struct sh_pfc_pin_config {
@@ -1006,6 +1007,8 @@ static int sh_pfc_pinctrl_probe(struct udevice *dev)
 		priv->pfc.info = &r8a779g0_pinmux_info;
 	else if (IS_ENABLED(CONFIG_PINCTRL_PFC_R8A779H0) && model == SH_PFC_R8A779H0)
 		priv->pfc.info = &r8a779h0_pinmux_info;
+	else if (IS_ENABLED(CONFIG_PINCTRL_PFC_R8A78000) && model == SH_PFC_R8A78000)
+		priv->pfc.info = &r8a78000_pinmux_info;
 	else
 		return -ENODEV;
 
@@ -1143,6 +1146,12 @@ static const struct udevice_id sh_pfc_pinctrl_ids[] = {
 		.data = SH_PFC_R8A779H0,
 	},
 #endif
+#if IS_ENABLED(CONFIG_PINCTRL_PFC_R8A78000)
+	{
+		.compatible = "renesas,pfc-r8a78000",
+		.data = SH_PFC_R8A78000,
+	},
+#endif
 
 	{ },
 };
diff --git a/drivers/pinctrl/renesas/sh_pfc.h b/drivers/pinctrl/renesas/sh_pfc.h
index 505bc90983f..30d2e6a8e81 100644
--- a/drivers/pinctrl/renesas/sh_pfc.h
+++ b/drivers/pinctrl/renesas/sh_pfc.h
@@ -310,6 +310,7 @@ extern const struct sh_pfc_soc_info r8a779a0_pinmux_info;
 extern const struct sh_pfc_soc_info r8a779f0_pinmux_info;
 extern const struct sh_pfc_soc_info r8a779g0_pinmux_info;
 extern const struct sh_pfc_soc_info r8a779h0_pinmux_info;
+extern const struct sh_pfc_soc_info r8a78000_pinmux_info;
 
 /* -----------------------------------------------------------------------------
  * Helper macros to create pin and port lists
-- 
2.51.0



More information about the U-Boot mailing list