diff options
| author | Nobuhiro Iwamatsu <nobuhiro.iwamatsu.yj@renesas.com> | 2013-11-21 17:07:45 +0900 | 
|---|---|---|
| committer | Nobuhiro Iwamatsu <iwamatsu@nigauri.org> | 2013-12-03 09:46:45 +0900 | 
| commit | bd0550fc5fcc0d7de38c56adba9e8b3e383213d0 (patch) | |
| tree | 68ddf44c76e4f192932e63454cef1d79c9721413 | |
| parent | f4ec45229709323b1f58a096fa4ce6a67f3b9c10 (diff) | |
| download | olio-uboot-2014.01-bd0550fc5fcc0d7de38c56adba9e8b3e383213d0.tar.xz olio-uboot-2014.01-bd0550fc5fcc0d7de38c56adba9e8b3e383213d0.zip | |
arm: rmobile: Add support R8A7791
Renesas R8A7791 is CPU with Cortex-A15.
This supports the basic register definition and GPIO and
framework of PFC.
Signed-off-by: Hisashi Nakamura <hisashi.nakamura.ak@renesas.com>
Signed-off-by: Nobuhiro Iwamatsu <nobuhiro.iwamatsu.yj@renesas.com>
CC: Nobuhiro Iwamatsu <iwamatsu@nigauri.org>
CC: Albert Aribaud <albert.u.boot@aribaud.net>
| -rw-r--r-- | arch/arm/cpu/armv7/rmobile/Makefile | 1 | ||||
| -rw-r--r-- | arch/arm/cpu/armv7/rmobile/cpu_info-r8a7791.c | 29 | ||||
| -rw-r--r-- | arch/arm/cpu/armv7/rmobile/cpu_info.c | 5 | ||||
| -rw-r--r-- | arch/arm/cpu/armv7/rmobile/pfc-r8a7791.c | 1117 | ||||
| -rw-r--r-- | arch/arm/include/asm/arch-rmobile/gpio.h | 3 | ||||
| -rw-r--r-- | arch/arm/include/asm/arch-rmobile/r8a7791-gpio.h | 438 | ||||
| -rw-r--r-- | arch/arm/include/asm/arch-rmobile/r8a7791.h | 598 | ||||
| -rw-r--r-- | arch/arm/include/asm/arch-rmobile/rmobile.h | 2 | 
8 files changed, 2193 insertions, 0 deletions
| diff --git a/arch/arm/cpu/armv7/rmobile/Makefile b/arch/arm/cpu/armv7/rmobile/Makefile index 6cdacaa44..7b9d47eb8 100644 --- a/arch/arm/cpu/armv7/rmobile/Makefile +++ b/arch/arm/cpu/armv7/rmobile/Makefile @@ -12,6 +12,7 @@ obj-$(CONFIG_DISPLAY_BOARDINFO) += board.o  obj-$(CONFIG_GLOBAL_TIMER) += timer.o  obj-$(CONFIG_R8A7740) += lowlevel_init.o cpu_info-r8a7740.o pfc-r8a7740.o  obj-$(CONFIG_R8A7790) += lowlevel_init_ca15.o cpu_info-r8a7790.o pfc-r8a7790.o +obj-$(CONFIG_R8A7791) += lowlevel_init_ca15.o cpu_info-r8a7791.o pfc-r8a7791.o  obj-$(CONFIG_SH73A0) += lowlevel_init.o cpu_info-sh73a0.o pfc-sh73a0.o  obj-$(CONFIG_TMU_TIMER) += sh_timer.o diff --git a/arch/arm/cpu/armv7/rmobile/cpu_info-r8a7791.c b/arch/arm/cpu/armv7/rmobile/cpu_info-r8a7791.c new file mode 100644 index 000000000..2de58ed27 --- /dev/null +++ b/arch/arm/cpu/armv7/rmobile/cpu_info-r8a7791.c @@ -0,0 +1,29 @@ +/* + * arch/arm/cpu/armv7/rmobile/cpu_info-r8a7791.c + * + * Copyright (C) 2013 Renesas Electronics Corporation + * + * SPDX-License-Identifier: GPL-2.0 + */ +#include <common.h> +#include <asm/io.h> + +#define PRR 0xFF000044 + +u32 rmobile_get_cpu_type(void) +{ +	u32 product; + +	product = readl(PRR); + +	return (u32)((product & 0x00007F00) >> 8); +} + +u32 rmobile_get_cpu_rev_integer(void) +{ +	u32 product; + +	product = readl(PRR); + +	return (u32)((product & 0x000000F0) >> 4); +} diff --git a/arch/arm/cpu/armv7/rmobile/cpu_info.c b/arch/arm/cpu/armv7/rmobile/cpu_info.c index 6bd3c2e73..83d5282e3 100644 --- a/arch/arm/cpu/armv7/rmobile/cpu_info.c +++ b/arch/arm/cpu/armv7/rmobile/cpu_info.c @@ -63,6 +63,11 @@ int print_cpuinfo(void)  		       rmobile_get_cpu_rev_integer());  		break; +	case 0x47: +		printf("CPU: Renesas Electronics R8A7791 rev %d\n", +			rmobile_get_cpu_rev_integer()); +		break; +  	default:  		printf("CPU: Renesas Electronics CPU rev %d.%d\n",  		       rmobile_get_cpu_rev_integer(), diff --git a/arch/arm/cpu/armv7/rmobile/pfc-r8a7791.c b/arch/arm/cpu/armv7/rmobile/pfc-r8a7791.c new file mode 100644 index 000000000..f49f990a0 --- /dev/null +++ b/arch/arm/cpu/armv7/rmobile/pfc-r8a7791.c @@ -0,0 +1,1117 @@ +/* + * arch/arm/cpu/armv7/rmobile/pfc-r8a7791.c + * + * Copyright (C) 2013 Renesas Electronics Corporation + * + * SPDX-License-Identifier: GPL-2.0 + */ + +#include <common.h> +#include <sh_pfc.h> +#include <asm/gpio.h> +#include "pfc-r8a7790.h" + +enum { +	PINMUX_RESERVED = 0, + +	PINMUX_DATA_BEGIN, +	GP_ALL(DATA), +	PINMUX_DATA_END, + +	PINMUX_INPUT_BEGIN, +	GP_ALL(IN), +	PINMUX_INPUT_END, + +	PINMUX_OUTPUT_BEGIN, +	GP_ALL(OUT), +	PINMUX_OUTPUT_END, + +	PINMUX_FUNCTION_BEGIN, +	GP_ALL(FN), + +	/* GPSR0 */ +	FN_IP0_0, FN_IP0_1, FN_IP0_2, FN_IP0_3, FN_IP0_4, FN_IP0_5, +	FN_IP0_6, FN_IP0_7, FN_IP0_8, FN_IP0_9, FN_IP0_10, FN_IP0_11, +	FN_IP0_12, FN_IP0_13, FN_IP0_14, FN_IP0_15, FN_IP0_18_16, FN_IP0_20_19, +	FN_IP0_22_21, FN_IP0_24_23, FN_IP0_26_25, FN_IP0_28_27, FN_IP0_30_29, +	FN_IP1_1_0, FN_IP1_3_2, FN_IP1_5_4, FN_IP1_7_6, FN_IP1_10_8, +	FN_IP1_13_11, FN_IP1_16_14, FN_IP1_19_17, FN_IP1_22_20, + +	/* GPSR1 */ +	FN_IP1_25_23, FN_IP1_28_26, FN_IP1_31_29, FN_IP2_2_0, FN_IP2_4_3, +	FN_IP2_6_5, FN_IP2_9_7, FN_IP2_12_10, FN_IP2_15_13, FN_IP2_18_16, +	FN_IP2_20_19, FN_IP2_22_21, FN_EX_CS0_N, FN_IP2_24_23, FN_IP2_26_25, +	FN_IP2_29_27, FN_IP3_2_0, FN_IP3_5_3, FN_IP3_8_6, FN_RD_N, +	FN_IP3_11_9, FN_IP3_13_12, FN_IP3_15_14 , FN_IP3_17_16 , FN_IP3_19_18, +	FN_IP3_21_20, + +	/* GPSR2 */ +	FN_IP3_27_25, FN_IP3_30_28, FN_IP4_1_0, FN_IP4_4_2, FN_IP4_7_5, +	FN_IP4_9_8, FN_IP4_12_10, FN_IP4_15_13, FN_IP4_18_16, FN_IP4_19, +	FN_IP4_20, FN_IP4_21, FN_IP4_23_22, FN_IP4_25_24, FN_IP4_27_26, +	FN_IP4_30_28, FN_IP5_2_0, FN_IP5_5_3, FN_IP5_8_6, FN_IP5_11_9, +	FN_IP5_14_12, FN_IP5_16_15, FN_IP5_19_17, FN_IP5_21_20, FN_IP5_23_22, +	FN_IP5_25_24, FN_IP5_28_26, FN_IP5_31_29, FN_AUDIO_CLKA, FN_IP6_2_0, +	FN_IP6_5_3, FN_IP6_7_6, + +	/* GPSR3 */ +	FN_IP7_5_3, FN_IP7_8_6, FN_IP7_10_9, FN_IP7_12_11, FN_IP7_14_13, +	FN_IP7_16_15, FN_IP7_18_17, FN_IP7_20_19, FN_IP7_23_21, FN_IP7_26_24, +	FN_IP7_29_27, FN_IP8_2_0, FN_IP8_5_3, FN_IP8_8_6, FN_IP8_11_9, +	FN_IP8_14_12, FN_IP8_17_15, FN_IP8_20_18, FN_IP8_23_21, FN_IP8_25_24, +	FN_IP8_27_26, FN_IP8_30_28, FN_IP9_2_0, FN_IP9_5_3, FN_IP9_6, FN_IP9_7, +	FN_IP9_10_8, FN_IP9_11, FN_IP9_12, FN_IP9_15_13, FN_IP9_16, +	FN_IP9_18_17, + +	/* GPSR4 */ +	FN_VI0_CLK, FN_IP9_20_19, FN_IP9_22_21, FN_IP9_24_23, FN_IP9_26_25, +	FN_VI0_DATA0_VI0_B0, FN_VI0_DATA0_VI0_B1, FN_VI0_DATA0_VI0_B2, +	FN_IP9_28_27, FN_VI0_DATA0_VI0_B4, FN_VI0_DATA0_VI0_B5, +	FN_VI0_DATA0_VI0_B6, FN_VI0_DATA0_VI0_B7, FN_IP9_31_29, FN_IP10_2_0, +	FN_IP10_5_3, FN_IP10_8_6, FN_IP10_11_9, FN_IP10_14_12, FN_IP10_16_15, +	FN_IP10_18_17, FN_IP10_21_19, FN_IP10_24_22, FN_IP10_26_25, +	FN_IP10_28_27, FN_IP10_31_29, FN_IP11_2_0, FN_IP11_5_3, FN_IP11_8_6, +	FN_IP15_1_0, FN_IP15_3_2, FN_IP15_5_4, + +	/* GPSR5 */ +	FN_IP11_11_9, FN_IP11_14_12, FN_IP11_16_15, FN_IP11_18_17, FN_IP11_19, +	FN_IP11_20, FN_IP11_21, FN_IP11_22, FN_IP11_23, FN_IP11_24, +	FN_IP11_25, FN_IP11_26, FN_IP11_27, FN_IP11_29_28, FN_IP11_31_30, +	FN_IP12_1_0, FN_IP12_3_2, FN_IP12_6_4, FN_IP12_9_7, FN_IP12_12_10, +	FN_IP12_15_13, FN_IP12_17_16, FN_IP12_19_18, FN_IP12_21_20, +	FN_IP12_23_22, FN_IP12_26_24, FN_IP12_29_27, FN_IP13_2_0, FN_IP13_4_3, +	FN_IP13_6_5, FN_IP13_9_7, FN_IP3_24_22, + +	/* GPSR6 */ +	FN_IP13_10, FN_IP13_11, FN_IP13_12, FN_IP13_13, FN_IP13_14, +	FN_IP13_15, FN_IP13_18_16, FN_IP13_21_19, FN_IP13_22, FN_IP13_24_23, +	FN_IP13_25, FN_IP13_26, FN_IP13_27, FN_IP13_30_28, FN_IP14_1_0, +	FN_IP14_2, FN_IP14_3, FN_IP14_4, FN_IP14_5, FN_IP14_6, FN_IP14_7, +	FN_IP14_10_8, FN_IP14_13_11, FN_IP14_16_14, FN_IP14_19_17, +	FN_IP14_22_20, FN_IP14_25_23, FN_IP14_28_26, FN_IP14_31_29, + +	/* GPSR7 */ +	FN_IP15_17_15, FN_IP15_20_18, FN_IP15_23_21, FN_IP15_26_24, +	FN_IP15_29_27, FN_IP16_2_0, FN_IP16_5_3, FN_IP16_7_6, FN_IP16_9_8, +	FN_IP16_11_10, FN_IP6_9_8, FN_IP6_11_10, FN_IP6_13_12, FN_IP6_15_14, +	FN_IP6_18_16, FN_IP6_20_19, FN_IP6_23_21, FN_IP6_26_24, FN_IP6_29_27, +	FN_IP7_2_0, FN_IP15_8_6, FN_IP15_11_9, FN_IP15_14_12, +	FN_USB0_PWEN, FN_USB0_OVC, FN_USB1_PWEN, + +	/* IPSR0 -  IPSR10 */ + +	/* IPSR11 */ +	FN_VI0_R5, FN_VI2_DATA6, FN_GLO_SDATA_B, FN_RX0_C, FN_SDA1_D, +	FN_VI0_R6, FN_VI2_DATA7, FN_GLO_SS_B, FN_TX1_C, FN_SCL4_B, +	FN_VI0_R7, FN_GLO_RFON_B, FN_RX1_C, FN_CAN0_RX_E, +	FN_SDA4_B, FN_HRX1_D, FN_SCIFB0_RXD_D, +	FN_VI1_HSYNC_N, FN_AVB_RXD0, FN_TS_SDATA0_B, FN_TX4_B, FN_SCIFA4_TXD_B, +	FN_VI1_VSYNC_N, FN_AVB_RXD1, FN_TS_SCK0_B, FN_RX4_B, FN_SCIFA4_RXD_B, +	FN_VI1_CLKENB, FN_AVB_RXD2, FN_TS_SDEN0_B, +	FN_VI1_FIELD, FN_AVB_RXD3, FN_TS_SPSYNC0_B, +	FN_VI1_CLK, FN_AVB_RXD4, FN_VI1_DATA0, FN_AVB_RXD5, +	FN_VI1_DATA1, FN_AVB_RXD6, FN_VI1_DATA2, FN_AVB_RXD7, +	FN_VI1_DATA3, FN_AVB_RX_ER, FN_VI1_DATA4, FN_AVB_MDIO, +	FN_VI1_DATA5, FN_AVB_RX_DV, FN_VI1_DATA6, FN_AVB_MAGIC, +	FN_VI1_DATA7, FN_AVB_MDC, +	FN_ETH_MDIO, FN_AVB_RX_CLK, FN_SCL2_C, +	FN_ETH_CRS_DV, FN_AVB_LINK, FN_SDA2_C, + +	/* IPSR12 */ +	FN_ETH_RX_ER, FN_AVB_CRS, FN_SCL3, FN_SCL7, +	FN_ETH_RXD0, FN_AVB_PHY_INT, FN_SDA3, FN_SDA7, +	FN_ETH_RXD1, FN_AVB_GTXREFCLK, FN_CAN0_TX_C, +	FN_SCL2_D, FN_MSIOF1_RXD_E, +	FN_ETH_LINK, FN_AVB_TXD0, FN_CAN0_RX_C, FN_SDA2_D, FN_MSIOF1_SCK_E, +	FN_ETH_REFCLK, FN_AVB_TXD1, FN_SCIFA3_RXD_B, +	FN_CAN1_RX_C, FN_MSIOF1_SYNC_E, +	FN_ETH_TXD1, FN_AVB_TXD2, FN_SCIFA3_TXD_B, +	FN_CAN1_TX_C, FN_MSIOF1_TXD_E, +	FN_ETH_TX_EN, FN_AVB_TXD3, FN_TCLK1_B, FN_CAN_CLK_B, +	FN_ETH_MAGIC, FN_AVB_TXD4, FN_IETX_C, +	FN_ETH_TXD0, FN_AVB_TXD5, FN_IECLK_C, +	FN_ETH_MDC, FN_AVB_TXD6, FN_IERX_C, +	FN_STP_IVCXO27_0, FN_AVB_TXD7, FN_SCIFB2_TXD_D, +	FN_ADIDATA_B, FN_MSIOF0_SYNC_C, +	FN_STP_ISCLK_0, FN_AVB_TX_EN, FN_SCIFB2_RXD_D, +	FN_ADICS_SAMP_B, FN_MSIOF0_SCK_C, + +	/* IPSR13 */ +	/* MOD_SEL */ +	FN_SEL_SCIF1_0, FN_SEL_SCIF1_1, FN_SEL_SCIF1_2, FN_SEL_SCIF1_3, +	FN_SEL_SCIFB_0, FN_SEL_SCIFB_1, FN_SEL_SCIFB_2, FN_SEL_SCIFB_3, +	FN_SEL_SCIFB2_0, FN_SEL_SCIFB2_1, FN_SEL_SCIFB2_2, FN_SEL_SCIFB2_3, +	FN_SEL_SCIFB1_0, FN_SEL_SCIFB1_1, FN_SEL_SCIFB1_2, FN_SEL_SCIFB1_3, +	FN_SEL_SCIFA1_0, FN_SEL_SCIFA1_1, FN_SEL_SCIFA1_2, +	FN_SEL_SSI9_0, FN_SEL_SSI9_1, +	FN_SEL_SCFA_0, FN_SEL_SCFA_1, +	FN_SEL_QSP_0, FN_SEL_QSP_1, +	FN_SEL_SSI7_0, FN_SEL_SSI7_1, +	FN_SEL_HSCIF1_0, FN_SEL_HSCIF1_1, FN_SEL_HSCIF1_2, FN_SEL_HSCIF1_3, +	FN_SEL_HSCIF1_4, +	FN_SEL_VI1_0, FN_SEL_VI1_1, FN_SEL_VI1_2, +	FN_SEL_TMU1_0, FN_SEL_TMU1_1, +	FN_SEL_LBS_0, FN_SEL_LBS_1, FN_SEL_LBS_2, FN_SEL_LBS_3, +	FN_SEL_TSIF0_0, FN_SEL_TSIF0_1, FN_SEL_TSIF0_2, FN_SEL_TSIF0_3, +	FN_SEL_SOF0_0, FN_SEL_SOF0_1, FN_SEL_SOF0_2, + +	/* MOD_SEL2 */ +	FN_SEL_SCIF0_0, FN_SEL_SCIF0_1, FN_SEL_SCIF0_2, FN_SEL_SCIF0_3, +	FN_SEL_SCIF0_4, +	FN_SEL_SCIF_0, FN_SEL_SCIF_1, +	FN_SEL_CAN0_0, FN_SEL_CAN0_1, FN_SEL_CAN0_2, FN_SEL_CAN0_3, +	FN_SEL_CAN0_4, FN_SEL_CAN0_5, +	FN_SEL_CAN1_0, FN_SEL_CAN1_1, FN_SEL_CAN1_2, FN_SEL_CAN1_3, +	FN_SEL_SCIFA2_0, FN_SEL_SCIFA2_1, +	FN_SEL_SCIF4_0, FN_SEL_SCIF4_1, FN_SEL_SCIF4_2, +	FN_SEL_ADG_0, FN_SEL_ADG_1, +	FN_SEL_FM_0, FN_SEL_FM_1, FN_SEL_FM_2, FN_SEL_FM_3, FN_SEL_FM_4, +	FN_SEL_SCIFA5_0, FN_SEL_SCIFA5_1, FN_SEL_SCIFA5_2, +	FN_SEL_GPS_0, FN_SEL_GPS_1, FN_SEL_GPS_2, FN_SEL_GPS_3, +	FN_SEL_SCIFA4_0, FN_SEL_SCIFA4_1, FN_SEL_SCIFA4_2, +	FN_SEL_SCIFA3_0, FN_SEL_SCIFA3_1, FN_SEL_SCIFA3_2, +	FN_SEL_SIM_0, FN_SEL_SIM_1, +	FN_SEL_SSI8_0, FN_SEL_SSI8_1, + +	/* MOD_SEL3 */ +	FN_SEL_HSCIF2_0, FN_SEL_HSCIF2_1, FN_SEL_HSCIF2_2, FN_SEL_HSCIF2_3, +	FN_SEL_CANCLK_0, FN_SEL_CANCLK_1, FN_SEL_CANCLK_2, FN_SEL_CANCLK_3, +	FN_SEL_IIC8_0, FN_SEL_IIC8_1, FN_SEL_IIC8_2, +	FN_SEL_IIC7_0, FN_SEL_IIC7_1, FN_SEL_IIC7_2, +	FN_SEL_IIC4_0, FN_SEL_IIC4_1, FN_SEL_IIC4_2, +	FN_SEL_IIC3_0, FN_SEL_IIC3_1, FN_SEL_IIC3_2, FN_SEL_IIC3_3, +	FN_SEL_SCIF3_0, FN_SEL_SCIF3_1, FN_SEL_SCIF3_2, FN_SEL_SCIF3_3, +	FN_SEL_IEB_0, FN_SEL_IEB_1, FN_SEL_IEB_2, +	FN_SEL_MMC_0, FN_SEL_MMC_1, +	FN_SEL_SCIF5_0, FN_SEL_SCIF5_1, +	FN_SEL_IIC2_0, FN_SEL_IIC2_1, FN_SEL_IIC2_2, FN_SEL_IIC2_3, +	FN_SEL_IIC1_0, FN_SEL_IIC1_1, FN_SEL_IIC1_2, FN_SEL_IIC1_3, +	FN_SEL_IIC1_4, +	FN_SEL_IIC0_0, FN_SEL_IIC0_1, FN_SEL_IIC0_2, + +	/* MOD_SEL4 */ +	FN_SEL_SOF1_0, FN_SEL_SOF1_1, FN_SEL_SOF1_2, FN_SEL_SOF1_3, +	FN_SEL_SOF1_4, +	FN_SEL_HSCIF0_0, FN_SEL_HSCIF0_1, FN_SEL_HSCIF0_2, +	FN_SEL_DIS_0, FN_SEL_DIS_1, FN_SEL_DIS_2, +	FN_SEL_RAD_0, FN_SEL_RAD_1, +	FN_SEL_RCN_0, FN_SEL_RCN_1, +	FN_SEL_RSP_0, FN_SEL_RSP_1, +	FN_SEL_SCIF2_0, FN_SEL_SCIF2_1, FN_SEL_SCIF2_2, FN_SEL_SCIF2_3, +	FN_SEL_SCIF2_4, +	FN_SEL_SOF2_0, FN_SEL_SOF2_1, FN_SEL_SOF2_2, FN_SEL_SOF2_3, +	FN_SEL_SOF2_4, +	FN_SEL_SSI1_0, FN_SEL_SSI1_1, +	FN_SEL_SSI0_0, FN_SEL_SSI0_1, +	FN_SEL_SSP_0, FN_SEL_SSP_1, FN_SEL_SSP_2, +	PINMUX_FUNCTION_END, + +	PINMUX_MARK_BEGIN, + +	EX_CS0_N_MARK, RD_N_MARK, + +	AUDIO_CLKA_MARK, + +	VI0_CLK_MARK, VI0_DATA0_VI0_B0_MARK, VI0_DATA0_VI0_B1_MARK, +	VI0_DATA0_VI0_B2_MARK, VI0_DATA0_VI0_B4_MARK, VI0_DATA0_VI0_B5_MARK, +	VI0_DATA0_VI0_B6_MARK, VI0_DATA0_VI0_B7_MARK, + +	USB0_PWEN_MARK, USB0_OVC_MARK, USB1_PWEN_MARK, + +	/* IPSR0  IPSR10 */ +	/* IPSR11 */ +	VI0_R5_MARK, VI2_DATA6_MARK, GLO_SDATA_B_MARK, RX0_C_MARK, SDA1_D_MARK, +	VI0_R6_MARK, VI2_DATA7_MARK, GLO_SS_B_MARK, TX1_C_MARK, SCL4_B_MARK, +	VI0_R7_MARK, GLO_RFON_B_MARK, RX1_C_MARK, CAN0_RX_E_MARK, +	SDA4_B_MARK, _MARK, HRX1_D_MARK, SCIFB0_RXD_D_MARK, +	VI1_HSYNC_N_MARK, AVB_RXD0_MARK, TS_SDATA0_B_MARK, +	TX4_B_MARK, SCIFA4_TXD_B_MARK, +	VI1_VSYNC_N_MARK, AVB_RXD1_MARK, TS_SCK0_B_MARK, +	RX4_B_MARK, SCIFA4_RXD_B_MARK, +	VI1_CLKENB_MARK, AVB_RXD2_MARK, TS_SDEN0_B_MARK, +	VI1_FIELD_MARK, AVB_RXD3_MARK, TS_SPSYNC0_B_MARK, +	VI1_CLK_MARK, AVB_RXD4_MARK, VI1_DATA0_MARK, AVB_RXD5_MARK, +	VI1_DATA1_MARK, AVB_RXD6_MARK, VI1_DATA2_MARK, AVB_RXD7_MARK, +	VI1_DATA3_MARK, AVB_RX_ER_MARK, VI1_DATA4_MARK, AVB_MDIO_MARK, +	VI1_DATA5_MARK, AVB_RX_DV_MARK, VI1_DATA6_MARK, AVB_MAGIC_MARK, +	VI1_DATA7_MARK, AVB_MDC_MARK, +	ETH_MDIO_MARK, AVB_RX_CLK_MARK, SCL2_C_MARK, +	ETH_CRS_DV_MARK, AVB_LINK_MARK, SDA2_C_MARK, + +	/* IPSR12 */ +	ETH_RX_ER_MARK, AVB_CRS_MARK, SCL3_MARK, SCL7_MARK, +	ETH_RXD0_MARK, AVB_PHY_INT_MARK, SDA3_MARK, SDA7_MARK, +	ETH_RXD1_MARK, AVB_GTXREFCLK_MARK, CAN0_TX_C_MARK, +	SCL2_D_MARK, MSIOF1_RXD_E_MARK, +	ETH_LINK_MARK, AVB_TXD0_MARK, CAN0_RX_C_MARK, +	SDA2_D_MARK, MSIOF1_SCK_E_MARK, +	ETH_REFCLK_MARK, AVB_TXD1_MARK, SCIFA3_RXD_B_MARK, +	CAN1_RX_C_MARK, MSIOF1_SYNC_E_MARK, +	ETH_TXD1_MARK, AVB_TXD2_MARK, SCIFA3_TXD_B_MARK, +	CAN1_TX_C_MARK, MSIOF1_TXD_E_MARK, +	ETH_TX_EN_MARK, AVB_TXD3_MARK, TCLK1_B_MARK, CAN_CLK_B_MARK, +	ETH_MAGIC_MARK, AVB_TXD4_MARK, IETX_C_MARK, +	ETH_TXD0_MARK, AVB_TXD5_MARK, IECLK_C_MARK, +	ETH_MDC_MARK, AVB_TXD6_MARK, IERX_C_MARK, +	STP_IVCXO27_0_MARK, AVB_TXD7_MARK, SCIFB2_TXD_D_MARK, +	ADIDATA_B_MARK, MSIOF0_SYNC_C_MARK, +	STP_ISCLK_0_MARK, AVB_TX_EN_MARK, SCIFB2_RXD_D_MARK, +	ADICS_SAMP_B_MARK, MSIOF0_SCK_C_MARK, + +	/* IPSR13 */ +	PINMUX_MARK_END, +}; + +static pinmux_enum_t pinmux_data[] = { +	PINMUX_DATA_GP_ALL(), /* PINMUX_DATA(GP_M_N_DATA, GP_M_N_FN...), */ + +	/* OTHER IPSR0  - IPSR10 */ +	/* IPSR11 */ +	PINMUX_IPSR_DATA(IP11_2_0, VI0_R5), +	PINMUX_IPSR_DATA(IP11_2_0, VI2_DATA6), +	PINMUX_IPSR_MODSEL_DATA(IP11_2_0, GLO_SDATA_B, SEL_GPS_1), +	PINMUX_IPSR_MODSEL_DATA(IP11_2_0, RX0_C, SEL_SCIF0_2), +	PINMUX_IPSR_MODSEL_DATA(IP11_2_0, SDA1_D, SEL_IIC1_3), +	PINMUX_IPSR_DATA(IP11_5_3, VI0_R6), +	PINMUX_IPSR_DATA(IP11_5_3, VI2_DATA7), +	PINMUX_IPSR_MODSEL_DATA(IP11_5_3, GLO_SS_B, SEL_GPS_1), +	PINMUX_IPSR_MODSEL_DATA(IP11_5_3, TX1_C, SEL_SCIF1_2), +	PINMUX_IPSR_MODSEL_DATA(IP11_5_3, SCL4_B, SEL_IIC4_1), +	PINMUX_IPSR_DATA(IP11_8_6, VI0_R7), +	PINMUX_IPSR_MODSEL_DATA(IP11_8_6, GLO_RFON_B, SEL_GPS_1), +	PINMUX_IPSR_MODSEL_DATA(IP11_8_6, RX1_C, SEL_SCIF1_2), +	PINMUX_IPSR_MODSEL_DATA(IP11_8_6, CAN0_RX_E, SEL_CAN0_4), +	PINMUX_IPSR_MODSEL_DATA(IP11_8_6, SDA4_B, SEL_IIC4_1), +	PINMUX_IPSR_MODSEL_DATA(IP11_8_6, HRX1_D, SEL_HSCIF1_3), +	PINMUX_IPSR_MODSEL_DATA(IP11_8_6, SCIFB0_RXD_D, SEL_SCIFB_3), +	PINMUX_IPSR_MODSEL_DATA(IP11_11_9, VI1_HSYNC_N, SEL_VI1_0), +	PINMUX_IPSR_DATA(IP11_11_9, AVB_RXD0), +	PINMUX_IPSR_MODSEL_DATA(IP11_11_9, TS_SDATA0_B, SEL_TSIF0_1), +	PINMUX_IPSR_MODSEL_DATA(IP11_11_9, TX4_B, SEL_SCIF4_1), +	PINMUX_IPSR_MODSEL_DATA(IP11_11_9, SCIFA4_TXD_B, SEL_SCIFA4_1), +	PINMUX_IPSR_MODSEL_DATA(IP11_14_12, VI1_VSYNC_N, SEL_VI1_0), +	PINMUX_IPSR_DATA(IP11_14_12, AVB_RXD1), +	PINMUX_IPSR_MODSEL_DATA(IP11_14_12, TS_SCK0_B, SEL_TSIF0_1), +	PINMUX_IPSR_MODSEL_DATA(IP11_14_12, RX4_B, SEL_SCIF4_1), +	PINMUX_IPSR_MODSEL_DATA(IP11_14_12, SCIFA4_RXD_B, SEL_SCIFA4_1), +	PINMUX_IPSR_MODSEL_DATA(IP11_16_15, VI1_CLKENB, SEL_VI1_0), +	PINMUX_IPSR_DATA(IP11_16_15, AVB_RXD2), +	PINMUX_IPSR_MODSEL_DATA(IP11_16_15, TS_SDEN0_B, SEL_TSIF0_1), +	PINMUX_IPSR_MODSEL_DATA(IP11_18_17, VI1_FIELD, SEL_VI1_0), +	PINMUX_IPSR_DATA(IP11_18_17, AVB_RXD3), +	PINMUX_IPSR_MODSEL_DATA(IP11_18_17, TS_SPSYNC0_B, SEL_TSIF0_1), +	PINMUX_IPSR_MODSEL_DATA(IP11_19, VI1_CLK, SEL_VI1_0), +	PINMUX_IPSR_DATA(IP11_19, AVB_RXD4), +	PINMUX_IPSR_MODSEL_DATA(IP11_20, VI1_DATA0, SEL_VI1_0), +	PINMUX_IPSR_DATA(IP11_20, AVB_RXD5), +	PINMUX_IPSR_MODSEL_DATA(IP11_21, VI1_DATA1, SEL_VI1_0), +	PINMUX_IPSR_DATA(IP11_21, AVB_RXD6), +	PINMUX_IPSR_MODSEL_DATA(IP11_22, VI1_DATA2, SEL_VI1_0), +	PINMUX_IPSR_DATA(IP11_22, AVB_RXD7), +	PINMUX_IPSR_MODSEL_DATA(IP11_23, VI1_DATA3, SEL_VI1_0), +	PINMUX_IPSR_DATA(IP11_23, AVB_RX_ER), +	PINMUX_IPSR_MODSEL_DATA(IP11_24, VI1_DATA4, SEL_VI1_0), +	PINMUX_IPSR_DATA(IP11_24, AVB_MDIO), +	PINMUX_IPSR_MODSEL_DATA(IP11_25, VI1_DATA5, SEL_VI1_0), +	PINMUX_IPSR_DATA(IP11_25, AVB_RX_DV), +	PINMUX_IPSR_MODSEL_DATA(IP11_26, VI1_DATA6, SEL_VI1_0), +	PINMUX_IPSR_DATA(IP11_26, AVB_MAGIC), +	PINMUX_IPSR_MODSEL_DATA(IP11_27, VI1_DATA7, SEL_VI1_0), +	PINMUX_IPSR_DATA(IP11_27, AVB_MDC), +	PINMUX_IPSR_DATA(IP11_29_28, ETH_MDIO), +	PINMUX_IPSR_DATA(IP11_29_28, AVB_RX_CLK), +	PINMUX_IPSR_MODSEL_DATA(IP11_29_28, SCL2_C, SEL_IIC2_2), +	PINMUX_IPSR_DATA(IP11_31_30, ETH_CRS_DV), +	PINMUX_IPSR_DATA(IP11_31_30, AVB_LINK), +	PINMUX_IPSR_MODSEL_DATA(IP11_31_30, SDA2_C, SEL_IIC2_2), + +	/* IPSR12 */ +	PINMUX_IPSR_DATA(IP12_1_0, ETH_RX_ER), +	PINMUX_IPSR_DATA(IP12_1_0, AVB_CRS), +	PINMUX_IPSR_MODSEL_DATA(IP12_1_0, SCL3, SEL_IIC3_0), +	PINMUX_IPSR_MODSEL_DATA(IP12_1_0, SCL7, SEL_IIC7_0), +	PINMUX_IPSR_DATA(IP12_3_2, ETH_RXD0), +	PINMUX_IPSR_DATA(IP12_3_2, AVB_PHY_INT), +	PINMUX_IPSR_MODSEL_DATA(IP12_3_2, SDA3, SEL_IIC3_0), +	PINMUX_IPSR_MODSEL_DATA(IP12_3_2, SDA7, SEL_IIC7_0), +	PINMUX_IPSR_DATA(IP12_6_4, ETH_RXD1), +	PINMUX_IPSR_DATA(IP12_6_4, AVB_GTXREFCLK), +	PINMUX_IPSR_MODSEL_DATA(IP12_6_4, CAN0_TX_C, SEL_CAN0_2), +	PINMUX_IPSR_MODSEL_DATA(IP12_6_4, SCL2_D, SEL_IIC2_3), +	PINMUX_IPSR_MODSEL_DATA(IP12_6_4, MSIOF1_RXD_E, SEL_SOF1_4), +	PINMUX_IPSR_DATA(IP12_9_7, ETH_LINK), +	PINMUX_IPSR_DATA(IP12_9_7, AVB_TXD0), +	PINMUX_IPSR_MODSEL_DATA(IP12_9_7, CAN0_RX_C, SEL_CAN0_2), +	PINMUX_IPSR_MODSEL_DATA(IP12_9_7, SDA2_D, SEL_IIC2_3), +	PINMUX_IPSR_MODSEL_DATA(IP12_9_7, MSIOF1_SCK_E, SEL_SOF1_4), +	PINMUX_IPSR_DATA(IP12_12_10, ETH_REFCLK), +	PINMUX_IPSR_DATA(IP12_12_10, AVB_TXD1), +	PINMUX_IPSR_MODSEL_DATA(IP12_12_10, SCIFA3_RXD_B, SEL_SCIFA3_1), +	PINMUX_IPSR_MODSEL_DATA(IP12_12_10, CAN1_RX_C, SEL_CAN1_2), +	PINMUX_IPSR_MODSEL_DATA(IP12_12_10, MSIOF1_SYNC_E, SEL_SOF1_4), +	PINMUX_IPSR_DATA(IP12_15_13, ETH_TXD1), +	PINMUX_IPSR_DATA(IP12_15_13, AVB_TXD2), +	PINMUX_IPSR_MODSEL_DATA(IP12_15_13, SCIFA3_TXD_B, SEL_SCIFA3_1), +	PINMUX_IPSR_MODSEL_DATA(IP12_15_13, CAN1_TX_C, SEL_CAN1_2), +	PINMUX_IPSR_MODSEL_DATA(IP12_15_13, MSIOF1_TXD_E, SEL_SOF1_4), +	PINMUX_IPSR_DATA(IP12_17_16, ETH_TX_EN), +	PINMUX_IPSR_DATA(IP12_17_16, AVB_TXD3), +	PINMUX_IPSR_MODSEL_DATA(IP12_17_16, TCLK1_B, SEL_TMU1_0), +	PINMUX_IPSR_MODSEL_DATA(IP12_17_16, CAN_CLK_B, SEL_CANCLK_1), +	PINMUX_IPSR_DATA(IP12_19_18, ETH_MAGIC), +	PINMUX_IPSR_DATA(IP12_19_18, AVB_TXD4), +	PINMUX_IPSR_MODSEL_DATA(IP12_19_18, IETX_C, SEL_IEB_2), +	PINMUX_IPSR_DATA(IP12_21_20, ETH_TXD0), +	PINMUX_IPSR_DATA(IP12_21_20, AVB_TXD5), +	PINMUX_IPSR_MODSEL_DATA(IP12_21_20, IECLK_C, SEL_IEB_2), +	PINMUX_IPSR_DATA(IP12_23_22, ETH_MDC), +	PINMUX_IPSR_DATA(IP12_23_22, AVB_TXD6), +	PINMUX_IPSR_MODSEL_DATA(IP12_23_22, IERX_C, SEL_IEB_2), +	PINMUX_IPSR_MODSEL_DATA(IP12_26_24, STP_IVCXO27_0, SEL_SSP_0), +	PINMUX_IPSR_DATA(IP12_26_24, AVB_TXD7), +	PINMUX_IPSR_MODSEL_DATA(IP12_26_24, SCIFB2_TXD_D, SEL_SCIFB2_3), +	PINMUX_IPSR_MODSEL_DATA(IP12_26_24, ADIDATA_B, SEL_RAD_1), +	PINMUX_IPSR_MODSEL_DATA(IP12_26_24, MSIOF0_SYNC_C, SEL_SOF0_2), +	PINMUX_IPSR_MODSEL_DATA(IP12_29_27, STP_ISCLK_0, SEL_SSP_0), +	PINMUX_IPSR_DATA(IP12_29_27, AVB_TX_EN), +	PINMUX_IPSR_MODSEL_DATA(IP12_29_27, SCIFB2_RXD_D, SEL_SCIFB2_3), +	PINMUX_IPSR_MODSEL_DATA(IP12_29_27, ADICS_SAMP_B, SEL_RAD_1), +	PINMUX_IPSR_MODSEL_DATA(IP12_29_27, MSIOF0_SCK_C, SEL_SOF0_2), + +	/* IPSR13 - IPSR16 */ +}; + +static struct pinmux_gpio pinmux_gpios[] = { +	PINMUX_GPIO_GP_ALL(), + +	/* OTHER, IPSR0 - IPSR10 */ +	/* IPSR11 */ +	GPIO_FN(VI0_R5), GPIO_FN(VI2_DATA6), GPIO_FN(GLO_SDATA_B), +	GPIO_FN(RX0_C), GPIO_FN(SDA1_D), +	GPIO_FN(VI0_R6), GPIO_FN(VI2_DATA7), +	GPIO_FN(GLO_SS_B), GPIO_FN(TX1_C), GPIO_FN(SCL4_B), +	GPIO_FN(VI0_R7), GPIO_FN(GLO_RFON_B), +	GPIO_FN(RX1_C), GPIO_FN(CAN0_RX_E), +	GPIO_FN(SDA4_B), GPIO_FN(HRX1_D), GPIO_FN(SCIFB0_RXD_D), +	GPIO_FN(VI1_HSYNC_N), GPIO_FN(AVB_RXD0), GPIO_FN(TS_SDATA0_B), +	GPIO_FN(TX4_B), GPIO_FN(SCIFA4_TXD_B), +	GPIO_FN(VI1_VSYNC_N), GPIO_FN(AVB_RXD1), GPIO_FN(TS_SCK0_B), +	GPIO_FN(RX4_B), GPIO_FN(SCIFA4_RXD_B), +	GPIO_FN(VI1_CLKENB), GPIO_FN(AVB_RXD2), GPIO_FN(TS_SDEN0_B), +	GPIO_FN(VI1_FIELD), GPIO_FN(AVB_RXD3), GPIO_FN(TS_SPSYNC0_B), +	GPIO_FN(VI1_CLK), GPIO_FN(AVB_RXD4), +	GPIO_FN(VI1_DATA0), GPIO_FN(AVB_RXD5), +	GPIO_FN(VI1_DATA1), GPIO_FN(AVB_RXD6), +	GPIO_FN(VI1_DATA2), GPIO_FN(AVB_RXD7), +	GPIO_FN(VI1_DATA3), GPIO_FN(AVB_RX_ER), +	GPIO_FN(VI1_DATA4), GPIO_FN(AVB_MDIO), +	GPIO_FN(VI1_DATA5), GPIO_FN(AVB_RX_DV), +	GPIO_FN(VI1_DATA6), GPIO_FN(AVB_MAGIC), +	GPIO_FN(VI1_DATA7), GPIO_FN(AVB_MDC), +	GPIO_FN(ETH_MDIO), GPIO_FN(AVB_RX_CLK), GPIO_FN(SCL2_C), +	GPIO_FN(ETH_CRS_DV), GPIO_FN(AVB_LINK), GPIO_FN(SDA2_C), + +	/* IPSR12 */ +	GPIO_FN(ETH_RX_ER), GPIO_FN(AVB_CRS), GPIO_FN(SCL3), GPIO_FN(SCL7), +	GPIO_FN(ETH_RXD0), GPIO_FN(AVB_PHY_INT), GPIO_FN(SDA3), GPIO_FN(SDA7), +	GPIO_FN(ETH_RXD1), GPIO_FN(AVB_GTXREFCLK), GPIO_FN(CAN0_TX_C), +	GPIO_FN(SCL2_D), GPIO_FN(MSIOF1_RXD_E), +	GPIO_FN(ETH_LINK), GPIO_FN(AVB_TXD0), GPIO_FN(CAN0_RX_C), +	GPIO_FN(SDA2_D), GPIO_FN(MSIOF1_SCK_E), +	GPIO_FN(ETH_REFCLK), GPIO_FN(AVB_TXD1), GPIO_FN(SCIFA3_RXD_B), +	GPIO_FN(CAN1_RX_C), GPIO_FN(MSIOF1_SYNC_E), +	GPIO_FN(ETH_TXD1), GPIO_FN(AVB_TXD2), GPIO_FN(SCIFA3_TXD_B), +	GPIO_FN(CAN1_TX_C), GPIO_FN(MSIOF1_TXD_E), +	GPIO_FN(ETH_TX_EN), GPIO_FN(AVB_TXD3), +	GPIO_FN(TCLK1_B), GPIO_FN(CAN_CLK_B), +	GPIO_FN(ETH_MAGIC), GPIO_FN(AVB_TXD4), GPIO_FN(IETX_C), +	GPIO_FN(ETH_TXD0), GPIO_FN(AVB_TXD5), GPIO_FN(IECLK_C), +	GPIO_FN(ETH_MDC), GPIO_FN(AVB_TXD6), GPIO_FN(IERX_C), +	GPIO_FN(STP_IVCXO27_0), GPIO_FN(AVB_TXD7), GPIO_FN(SCIFB2_TXD_D), +	GPIO_FN(ADIDATA_B), GPIO_FN(MSIOF0_SYNC_C), +	GPIO_FN(STP_ISCLK_0), GPIO_FN(AVB_TX_EN), GPIO_FN(SCIFB2_RXD_D), +	GPIO_FN(ADICS_SAMP_B), GPIO_FN(MSIOF0_SCK_C), + +	/* IPSR13 - IPSR16 */ +}; + +static struct pinmux_cfg_reg pinmux_config_regs[] = { +	{ PINMUX_CFG_REG("GPSR0", 0xE6060004, 32, 1) { +		GP_0_31_FN, FN_IP1_22_20, +		GP_0_30_FN, FN_IP1_19_17, +		GP_0_29_FN, FN_IP1_16_14, +		GP_0_28_FN, FN_IP1_13_11, +		GP_0_27_FN, FN_IP1_10_8, +		GP_0_26_FN, FN_IP1_7_6, +		GP_0_25_FN, FN_IP1_5_4, +		GP_0_24_FN, FN_IP1_3_2, +		GP_0_23_FN, FN_IP1_1_0, +		GP_0_22_FN, FN_IP0_30_29, +		GP_0_21_FN, FN_IP0_28_27, +		GP_0_20_FN, FN_IP0_26_25, +		GP_0_19_FN, FN_IP0_24_23, +		GP_0_18_FN, FN_IP0_22_21, +		GP_0_17_FN, FN_IP0_20_19, +		GP_0_16_FN, FN_IP0_18_16, +		GP_0_15_FN, FN_IP0_15, +		GP_0_14_FN, FN_IP0_14, +		GP_0_13_FN, FN_IP0_13, +		GP_0_12_FN, FN_IP0_12, +		GP_0_11_FN, FN_IP0_11, +		GP_0_10_FN, FN_IP0_10, +		GP_0_9_FN, FN_IP0_9, +		GP_0_8_FN, FN_IP0_8, +		GP_0_7_FN, FN_IP0_7, +		GP_0_6_FN, FN_IP0_6, +		GP_0_5_FN, FN_IP0_5, +		GP_0_4_FN, FN_IP0_4, +		GP_0_3_FN, FN_IP0_3, +		GP_0_2_FN, FN_IP0_2, +		GP_0_1_FN, FN_IP0_1, +		GP_0_0_FN, FN_IP0_0, } +	}, +	{ PINMUX_CFG_REG("GPSR1", 0xE6060008, 32, 1) { +		0, 0, +		0, 0, +		0, 0, +		0, 0, +		0, 0, +		0, 0, +		GP_1_25_FN, FN_IP3_21_20, +		GP_1_24_FN, FN_IP3_19_18, +		GP_1_23_FN, FN_IP3_17_16, +		GP_1_22_FN, FN_IP3_15_14, +		GP_1_21_FN, FN_IP3_13_12, +		GP_1_20_FN, FN_IP3_11_9, +		GP_1_19_FN, FN_RD_N, +		GP_1_18_FN, FN_IP3_8_6, +		GP_1_17_FN, FN_IP3_5_3, +		GP_1_16_FN, FN_IP3_2_0, +		GP_1_15_FN, FN_IP2_29_27, +		GP_1_14_FN, FN_IP2_26_25, +		GP_1_13_FN, FN_IP2_24_23, +		GP_1_12_FN, FN_EX_CS0_N, +		GP_1_11_FN, FN_IP2_22_21, +		GP_1_10_FN, FN_IP2_20_19, +		GP_1_9_FN, FN_IP2_18_16, +		GP_1_8_FN, FN_IP2_15_13, +		GP_1_7_FN, FN_IP2_12_10, +		GP_1_6_FN, FN_IP2_9_7, +		GP_1_5_FN, FN_IP2_6_5, +		GP_1_4_FN, FN_IP2_4_3, +		GP_1_3_FN, FN_IP2_2_0, +		GP_1_2_FN, FN_IP1_31_29, +		GP_1_1_FN, FN_IP1_28_26, +		GP_1_0_FN, FN_IP1_25_23, } +	}, +	{ PINMUX_CFG_REG("GPSR2", 0xE606000C, 32, 1) { +		GP_2_31_FN, FN_IP6_7_6, +		GP_2_30_FN, FN_IP6_5_3, +		GP_2_29_FN, FN_IP6_2_0, +		GP_2_28_FN, FN_AUDIO_CLKA, +		GP_2_27_FN, FN_IP5_31_29, +		GP_2_26_FN, FN_IP5_28_26, +		GP_2_25_FN, FN_IP5_25_24, +		GP_2_24_FN, FN_IP5_23_22, +		GP_2_23_FN, FN_IP5_21_20, +		GP_2_22_FN, FN_IP5_19_17, +		GP_2_21_FN, FN_IP5_16_15, +		GP_2_20_FN, FN_IP5_14_12, +		GP_2_19_FN, FN_IP5_11_9, +		GP_2_18_FN, FN_IP5_8_6, +		GP_2_17_FN, FN_IP5_5_3, +		GP_2_16_FN, FN_IP5_2_0, +		GP_2_15_FN, FN_IP4_30_28, +		GP_2_14_FN, FN_IP4_27_26, +		GP_2_13_FN, FN_IP4_25_24, +		GP_2_12_FN, FN_IP4_23_22, +		GP_2_11_FN, FN_IP4_21, +		GP_2_10_FN, FN_IP4_20, +		GP_2_9_FN, FN_IP4_19, +		GP_2_8_FN, FN_IP4_18_16, +		GP_2_7_FN, FN_IP4_15_13, +		GP_2_6_FN, FN_IP4_12_10, +		GP_2_5_FN, FN_IP4_9_8, +		GP_2_4_FN, FN_IP4_7_5, +		GP_2_3_FN, FN_IP4_4_2, +		GP_2_2_FN, FN_IP4_1_0, +		GP_2_1_FN, FN_IP3_30_28, +		GP_2_0_FN, FN_IP3_27_25 } +	}, +	{ PINMUX_CFG_REG("GPSR3", 0xE6060010, 32, 1) { +		GP_3_31_FN, FN_IP9_18_17, +		GP_3_30_FN, FN_IP9_16, +		GP_3_29_FN, FN_IP9_15_13, +		GP_3_28_FN, FN_IP9_12, +		GP_3_27_FN, FN_IP9_11, +		GP_3_26_FN, FN_IP9_10_8, +		GP_3_25_FN, FN_IP9_7, +		GP_3_24_FN, FN_IP9_6, +		GP_3_23_FN, FN_IP9_5_3, +		GP_3_22_FN, FN_IP9_2_0, +		GP_3_21_FN, FN_IP8_30_28, +		GP_3_20_FN, FN_IP8_27_26, +		GP_3_19_FN, FN_IP8_25_24, +		GP_3_18_FN, FN_IP8_23_21, +		GP_3_17_FN, FN_IP8_20_18, +		GP_3_16_FN, FN_IP8_17_15, +		GP_3_15_FN, FN_IP8_14_12, +		GP_3_14_FN, FN_IP8_11_9, +		GP_3_13_FN, FN_IP8_8_6, +		GP_3_12_FN, FN_IP8_5_3, +		GP_3_11_FN, FN_IP8_2_0, +		GP_3_10_FN, FN_IP7_29_27, +		GP_3_9_FN, FN_IP7_26_24, +		GP_3_8_FN, FN_IP7_23_21, +		GP_3_7_FN, FN_IP7_20_19, +		GP_3_6_FN, FN_IP7_18_17, +		GP_3_5_FN, FN_IP7_16_15, +		GP_3_4_FN, FN_IP7_14_13, +		GP_3_3_FN, FN_IP7_12_11, +		GP_3_2_FN, FN_IP7_10_9, +		GP_3_1_FN, FN_IP7_8_6, +		GP_3_0_FN, FN_IP7_5_3 } +	}, +	{ PINMUX_CFG_REG("GPSR4", 0xE6060014, 32, 1) { +		GP_4_31_FN, FN_IP15_5_4, +		GP_4_30_FN, FN_IP15_3_2, +		GP_4_29_FN, FN_IP15_1_0, +		GP_4_28_FN, FN_IP11_8_6, +		GP_4_27_FN, FN_IP11_5_3, +		GP_4_26_FN, FN_IP11_2_0, +		GP_4_25_FN, FN_IP10_31_29, +		GP_4_24_FN, FN_IP10_28_27, +		GP_4_23_FN, FN_IP10_26_25, +		GP_4_22_FN, FN_IP10_24_22, +		GP_4_21_FN, FN_IP10_21_19, +		GP_4_20_FN, FN_IP10_18_17, +		GP_4_19_FN, FN_IP10_16_15, +		GP_4_18_FN, FN_IP10_14_12, +		GP_4_17_FN, FN_IP10_11_9, +		GP_4_16_FN, FN_IP10_8_6, +		GP_4_15_FN, FN_IP10_5_3, +		GP_4_14_FN, FN_IP10_2_0, +		GP_4_13_FN, FN_IP9_31_29, +		GP_4_12_FN, FN_VI0_DATA0_VI0_B7, +		GP_4_11_FN, FN_VI0_DATA0_VI0_B6, +		GP_4_10_FN, FN_VI0_DATA0_VI0_B5, +		GP_4_9_FN, FN_VI0_DATA0_VI0_B4, +		GP_4_8_FN, FN_IP9_28_27, +		GP_4_7_FN, FN_VI0_DATA0_VI0_B2, +		GP_4_6_FN, FN_VI0_DATA0_VI0_B1, +		GP_4_5_FN, FN_VI0_DATA0_VI0_B0, +		GP_4_4_FN, FN_IP9_26_25, +		GP_4_3_FN, FN_IP9_24_23, +		GP_4_2_FN, FN_IP9_22_21, +		GP_4_1_FN, FN_IP9_20_19, +		GP_4_0_FN, FN_VI0_CLK } +	}, +	{ PINMUX_CFG_REG("GPSR5", 0xE6060018, 32, 1) { +		GP_5_31_FN, FN_IP3_24_22, +		GP_5_30_FN, FN_IP13_9_7, +		GP_5_29_FN, FN_IP13_6_5, +		GP_5_28_FN, FN_IP13_4_3, +		GP_5_27_FN, FN_IP13_2_0, +		GP_5_26_FN, FN_IP12_29_27, +		GP_5_25_FN, FN_IP12_26_24, +		GP_5_24_FN, FN_IP12_23_22, +		GP_5_23_FN, FN_IP12_21_20, +		GP_5_22_FN, FN_IP12_19_18, +		GP_5_21_FN, FN_IP12_17_16, +		GP_5_20_FN, FN_IP12_15_13, +		GP_5_19_FN, FN_IP12_12_10, +		GP_5_18_FN, FN_IP12_9_7, +		GP_5_17_FN, FN_IP12_6_4, +		GP_5_16_FN, FN_IP12_3_2, +		GP_5_15_FN, FN_IP12_1_0, +		GP_5_14_FN, FN_IP11_31_30, +		GP_5_13_FN, FN_IP11_29_28, +		GP_5_12_FN, FN_IP11_27, +		GP_5_11_FN, FN_IP11_26, +		GP_5_10_FN, FN_IP11_25, +		GP_5_9_FN, FN_IP11_24, +		GP_5_8_FN, FN_IP11_23, +		GP_5_7_FN, FN_IP11_22, +		GP_5_6_FN, FN_IP11_21, +		GP_5_5_FN, FN_IP11_20, +		GP_5_4_FN, FN_IP11_19, +		GP_5_3_FN, FN_IP11_18_17, +		GP_5_2_FN, FN_IP11_16_15, +		GP_5_1_FN, FN_IP11_14_12, +		GP_5_0_FN, FN_IP11_11_9 } +	}, +	{ PINMUX_CFG_REG("GPSR6", 0xE606001C, 32, 1) { +		0, 0, +		0, 0, +		GP_6_29_FN, FN_IP14_31_29, +		GP_6_28_FN, FN_IP14_28_26, +		GP_6_27_FN, FN_IP14_25_23, +		GP_6_26_FN, FN_IP14_22_20, +		GP_6_25_FN, FN_IP14_19_17, +		GP_6_24_FN, FN_IP14_16_14, +		GP_6_23_FN, FN_IP14_13_11, +		GP_6_22_FN, FN_IP14_10_8, +		GP_6_21_FN, FN_IP14_7, +		GP_6_20_FN, FN_IP14_6, +		GP_6_19_FN, FN_IP14_5, +		GP_6_18_FN, FN_IP14_4, +		GP_6_17_FN, FN_IP14_3, +		GP_6_16_FN, FN_IP14_2, +		GP_6_15_FN, FN_IP14_1_0, +		GP_6_14_FN, FN_IP13_30_28, +		GP_6_13_FN, FN_IP13_27, +		GP_6_12_FN, FN_IP13_26, +		GP_6_11_FN, FN_IP13_25, +		GP_6_10_FN, FN_IP13_24_23, +		GP_6_9_FN, FN_IP13_22, +		0, 0, +		GP_6_7_FN, FN_IP13_21_19, +		GP_6_6_FN, FN_IP13_18_16, +		GP_6_5_FN, FN_IP13_15, +		GP_6_4_FN, FN_IP13_14, +		GP_6_3_FN, FN_IP13_13, +		GP_6_2_FN, FN_IP13_12, +		GP_6_1_FN, FN_IP13_11, +		GP_6_0_FN, FN_IP13_10 } +	}, +	{ PINMUX_CFG_REG("GPSR7", 0xE6060074, 32, 1) { +		0, 0, +		0, 0, +		0, 0, +		0, 0, +		0, 0, +		0, 0, +		GP_7_25_FN, FN_USB1_PWEN, +		GP_7_24_FN, FN_USB0_OVC, +		GP_7_23_FN, FN_USB0_PWEN, +		GP_7_22_FN, FN_IP15_14_12, +		GP_7_21_FN, FN_IP15_11_9, +		GP_7_20_FN, FN_IP15_8_6, +		GP_7_19_FN, FN_IP7_2_0, +		GP_7_18_FN, FN_IP6_29_27, +		GP_7_17_FN, FN_IP6_26_24, +		GP_7_16_FN, FN_IP6_23_21, +		GP_7_15_FN, FN_IP6_20_19, +		GP_7_14_FN, FN_IP6_18_16, +		GP_7_13_FN, FN_IP6_15_14, +		GP_7_12_FN, FN_IP6_13_12, +		GP_7_11_FN, FN_IP6_11_10, +		GP_7_10_FN, FN_IP6_9_8, +		GP_7_9_FN, FN_IP16_11_10, +		GP_7_8_FN, FN_IP16_9_8, +		GP_7_7_FN, FN_IP16_7_6, +		GP_7_6_FN, FN_IP16_5_3, +		GP_7_5_FN, FN_IP16_2_0, +		GP_7_4_FN, FN_IP15_29_27, +		GP_7_3_FN, FN_IP15_26_24, +		GP_7_2_FN, FN_IP15_23_21, +		GP_7_1_FN, FN_IP15_20_18, +		GP_7_0_FN, FN_IP15_17_15 } +	}, +	/* IPSR0 - IPSR10 */ +	{ PINMUX_CFG_REG_VAR("IPSR11", 0xE606004C, 32, +			     2, 2, 1, 1, 1, 1, 1, 1, 1, 1, 1, 2, 2, +			     3, 3, 3, 3, 3) { +		/* IP11_31_30 [2] */ +		FN_ETH_CRS_DV, FN_AVB_LINK, FN_SDA2_C, 0, +		/* IP11_29_28 [2] */ +		FN_ETH_MDIO, FN_AVB_RX_CLK, FN_SCL2_C, 0, +		/* IP11_27 [1] */ +		FN_VI1_DATA7, FN_AVB_MDC, +		/* IP11_26 [1] */ +		FN_VI1_DATA6, FN_AVB_MAGIC, +		/* IP11_25 [1] */ +		FN_VI1_DATA5, FN_AVB_RX_DV, +		/* IP11_24 [1] */ +		FN_VI1_DATA4, FN_AVB_MDIO, +		/* IP11_23 [1] */ +		FN_VI1_DATA3, FN_AVB_RX_ER, +		/* IP11_22 [1] */ +		FN_VI1_DATA2, FN_AVB_RXD7, +		/* IP11_21 [1] */ +		FN_VI1_DATA1, FN_AVB_RXD6, +		/* IP11_20 [1] */ +		FN_VI1_DATA0, FN_AVB_RXD5, +		/* IP11_19 [1] */ +		FN_VI1_CLK, FN_AVB_RXD4, +		/* IP11_18_17 [2] */ +		FN_VI1_FIELD, FN_AVB_RXD3, FN_TS_SPSYNC0_B, 0, +		/* IP11_16_15 [2] */ +		FN_VI1_CLKENB, FN_AVB_RXD2, FN_TS_SDEN0_B, 0, +		/* IP11_14_12 [3] */ +		FN_VI1_VSYNC_N, FN_AVB_RXD1, FN_TS_SCK0_B, +		FN_RX4_B, FN_SCIFA4_RXD_B, +		0, 0, 0, +		/* IP11_11_9 [3] */ +		FN_VI1_HSYNC_N, FN_AVB_RXD0, FN_TS_SDATA0_B, +		FN_TX4_B, FN_SCIFA4_TXD_B, +		0, 0, 0, +		/* IP11_8_6 [3] */ +		FN_VI0_R7, FN_GLO_RFON_B, FN_RX1_C, FN_CAN0_RX_E, +		FN_SDA4_B, FN_HRX1_D, FN_SCIFB0_RXD_D, 0, +		/* IP11_5_3 [3] */ +		FN_VI0_R6, FN_VI2_DATA7, FN_GLO_SS_B, FN_TX1_C, FN_SCL4_B, +		0, 0, 0, +		/* IP11_2_0 [3] */ +		FN_VI0_R5, FN_VI2_DATA6, FN_GLO_SDATA_B, FN_RX0_C, FN_SDA1_D, +		0, 0, 0, } +	}, +	{ PINMUX_CFG_REG_VAR("IPSR12", 0xE6060050, 32, +			     2, 3, 3, 2, 2, 2, 2, 3, 3, 3, 3, 2, 2) { +		/* IP12_31_30 [2] */ +		0, 0, 0, 0, +		/* IP12_29_27 [3] */ +		FN_STP_ISCLK_0, FN_AVB_TX_EN, FN_SCIFB2_RXD_D, +		FN_ADICS_SAMP_B, FN_MSIOF0_SCK_C, +		0, 0, 0, +		/* IP12_26_24 [3] */ +		FN_STP_IVCXO27_0, FN_AVB_TXD7, FN_SCIFB2_TXD_D, +		FN_ADIDATA_B, FN_MSIOF0_SYNC_C, +		0, 0, 0, +		/* IP12_23_22 [2] */ +		FN_ETH_MDC, FN_AVB_TXD6, FN_IERX_C, 0, +		/* IP12_21_20 [2] */ +		FN_ETH_TXD0, FN_AVB_TXD5, FN_IECLK_C, 0, +		/* IP12_19_18 [2] */ +		FN_ETH_MAGIC, FN_AVB_TXD4, FN_IETX_C, 0, +		/* IP12_17_16 [2] */ +		FN_ETH_TX_EN, FN_AVB_TXD3, FN_TCLK1_B, FN_CAN_CLK_B, +		/* IP12_15_13 [3] */ +		FN_ETH_TXD1, FN_AVB_TXD2, FN_SCIFA3_TXD_B, +		FN_CAN1_TX_C, FN_MSIOF1_TXD_E, +		0, 0, 0, +		/* IP12_12_10 [3] */ +		FN_ETH_REFCLK, FN_AVB_TXD1, FN_SCIFA3_RXD_B, +		FN_CAN1_RX_C, FN_MSIOF1_SYNC_E, +		0, 0, 0, +		/* IP12_9_7 [3] */ +		FN_ETH_LINK, FN_AVB_TXD0, FN_CAN0_RX_C, +		FN_SDA2_D, FN_MSIOF1_SCK_E, +		0, 0, 0, +		/* IP12_6_4 [3] */ +		FN_ETH_RXD1, FN_AVB_GTXREFCLK, FN_CAN0_TX_C, +		FN_SCL2_D, FN_MSIOF1_RXD_E, +		0, 0, 0, +		/* IP12_3_2 [2] */ +		FN_ETH_RXD0, FN_AVB_PHY_INT, FN_SDA3, FN_SDA7, +		/* IP12_1_0 [2] */ +		FN_ETH_RX_ER, FN_AVB_CRS, FN_SCL3, FN_SCL7, } +	}, + +	/* IPSR13 - IPSR16 */ + +	{ PINMUX_CFG_REG_VAR("MOD_SEL", 0xE6060090, 32, +			     1, 2, 2, 2, 3, 2, 1, 1, 1, 1, +			     3, 2, 2, 2, 1, 2, 2, 2) { +		/* RESEVED [1] */ +		0, 0, +		/* SEL_SCIF1 [2] */ +		FN_SEL_SCIF1_0, FN_SEL_SCIF1_1, FN_SEL_SCIF1_2, FN_SEL_SCIF1_3, +		/* SEL_SCIFB [2] */ +		FN_SEL_SCIFB_0, FN_SEL_SCIFB_1, FN_SEL_SCIFB_2, FN_SEL_SCIFB_3, +		/* SEL_SCIFB2 [2] */ +		FN_SEL_SCIFB2_0, FN_SEL_SCIFB2_1, +		FN_SEL_SCIFB2_2, FN_SEL_SCIFB2_3, +		/* SEL_SCIFB1 [3] */ +		FN_SEL_SCIFB1_0, FN_SEL_SCIFB1_1, +		FN_SEL_SCIFB1_2, FN_SEL_SCIFB1_3, +		0, 0, 0, 0, +		/* SEL_SCIFA1 [2] */ +		FN_SEL_SCIFA1_0, FN_SEL_SCIFA1_1, FN_SEL_SCIFA1_2, 0, +		/* SEL_SSI9 [1] */ +		FN_SEL_SSI9_0, FN_SEL_SSI9_1, +		/* SEL_SCFA [1] */ +		FN_SEL_SCFA_0, FN_SEL_SCFA_1, +		/* SEL_QSP [1] */ +		FN_SEL_QSP_0, FN_SEL_QSP_1, +		/* SEL_SSI7 [1] */ +		FN_SEL_SSI7_0, FN_SEL_SSI7_1, +		/* SEL_HSCIF1 [3] */ +		FN_SEL_HSCIF1_0, FN_SEL_HSCIF1_1, FN_SEL_HSCIF1_2, +		FN_SEL_HSCIF1_3, FN_SEL_HSCIF1_4, +		0, 0, 0, +		/* RESEVED [2] */ +		0, 0, 0, 0, +		/* SEL_VI1 [2] */ +		FN_SEL_VI1_0, FN_SEL_VI1_1, FN_SEL_VI1_2, 0, +		/* RESEVED [2] */ +		0, 0, 0, 0, +		/* SEL_TMU [1] */ +		FN_SEL_TMU1_0, FN_SEL_TMU1_1, +		/* SEL_LBS [2] */ +		FN_SEL_LBS_0, FN_SEL_LBS_1, FN_SEL_LBS_2, FN_SEL_LBS_3, +		/* SEL_TSIF0 [2] */ +		FN_SEL_TSIF0_0, FN_SEL_TSIF0_1, FN_SEL_TSIF0_2, FN_SEL_TSIF0_3, +		/* SEL_SOF0 [2] */ +		FN_SEL_SOF0_0, FN_SEL_SOF0_1, FN_SEL_SOF0_2, 0, } +	}, +	{ PINMUX_CFG_REG_VAR("MOD_SEL2", 0xE6060094, 32, +			     3, 1, 1, 3, 2, 1, 1, 2, 2, +			     1, 3, 2, 1, 2, 2, 2, 1, 1, 1) { +		/* SEL_SCIF0 [3] */ +		FN_SEL_SCIF0_0, FN_SEL_SCIF0_1, FN_SEL_SCIF0_2, +		FN_SEL_SCIF0_3, FN_SEL_SCIF0_4, +		0, 0, 0, +		/* RESEVED [1] */ +		0, 0, +		/* SEL_SCIF [1] */ +		FN_SEL_SCIF_0, FN_SEL_SCIF_1, +		/* SEL_CAN0 [3] */ +		FN_SEL_CAN0_0, FN_SEL_CAN0_1, FN_SEL_CAN0_2, FN_SEL_CAN0_3, +		FN_SEL_CAN0_4, FN_SEL_CAN0_5, +		0, 0, +		/* SEL_CAN1 [2] */ +		FN_SEL_CAN1_0, FN_SEL_CAN1_1, FN_SEL_CAN1_2, FN_SEL_CAN1_3, +		/* RESEVED [1] */ +		0, 0, +		/* SEL_SCIFA2 [1] */ +		FN_SEL_SCIFA2_0, FN_SEL_SCIFA2_1, +		/* SEL_SCIF4 [2] */ +		FN_SEL_SCIF4_0, FN_SEL_SCIF4_1, FN_SEL_SCIF4_2, 0, +		/* RESEVED [2] */ +		0, 0, 0, 0, +		/* SEL_ADG [1] */ +		FN_SEL_ADG_0, FN_SEL_ADG_1, +		/* SEL_FM [3] */ +		FN_SEL_FM_0, FN_SEL_FM_1, FN_SEL_FM_2, +		FN_SEL_FM_3, FN_SEL_FM_4, +		0, 0, 0, +		/* SEL_SCIFA5 [2] */ +		FN_SEL_SCIFA5_0, FN_SEL_SCIFA5_1, FN_SEL_SCIFA5_2, 0, +		/* RESEVED [1] */ +		0, 0, +		/* SEL_GPS [2] */ +		FN_SEL_GPS_0, FN_SEL_GPS_1, FN_SEL_GPS_2, FN_SEL_GPS_3, +		/* SEL_SCIFA4 [2] */ +		FN_SEL_SCIFA4_0, FN_SEL_SCIFA4_1, FN_SEL_SCIFA4_2, 0, +		/* SEL_SCIFA3 [2] */ +		FN_SEL_SCIFA3_0, FN_SEL_SCIFA3_1, FN_SEL_SCIFA3_2, 0, +		/* SEL_SIM [1] */ +		FN_SEL_SIM_0, FN_SEL_SIM_1, +		/* RESEVED [1] */ +		0, 0, +		/* SEL_SSI8 [1] */ +		FN_SEL_SSI8_0, FN_SEL_SSI8_1, } +	}, +	{ PINMUX_CFG_REG_VAR("MOD_SEL3", 0xE6060098, 32, +			     2, 2, 2, 2, 2, 2, 2, 2, +			     1, 1, 2, 2, 3, 2, 2, 2, 1) { +		/* SEL_HSCIF2 [2] */ +		FN_SEL_HSCIF2_0, FN_SEL_HSCIF2_1, +		FN_SEL_HSCIF2_2, FN_SEL_HSCIF2_3, +		/* SEL_CANCLK [2] */ +		FN_SEL_CANCLK_0, FN_SEL_CANCLK_1, +		FN_SEL_CANCLK_2, FN_SEL_CANCLK_3, +		/* SEL_IIC8 [2] */ +		FN_SEL_IIC8_0, FN_SEL_IIC8_1, FN_SEL_IIC8_2, 0, +		/* SEL_IIC7 [2] */ +		FN_SEL_IIC7_0, FN_SEL_IIC7_1, FN_SEL_IIC7_2, 0, +		/* SEL_IIC4 [2] */ +		FN_SEL_IIC4_0, FN_SEL_IIC4_1, FN_SEL_IIC4_2, 0, +		/* SEL_IIC3 [2] */ +		FN_SEL_IIC3_0, FN_SEL_IIC3_1, FN_SEL_IIC3_2, FN_SEL_IIC3_3, +		/* SEL_SCIF3 [2] */ +		FN_SEL_SCIF3_0, FN_SEL_SCIF3_1, FN_SEL_SCIF3_2, FN_SEL_SCIF3_3, +		/* SEL_IEB [2] */ +		FN_SEL_IEB_0, FN_SEL_IEB_1, FN_SEL_IEB_2, +		/* SEL_MMC [1] */ +		FN_SEL_MMC_0, FN_SEL_MMC_1, +		/* SEL_SCIF5 [1] */ +		FN_SEL_SCIF5_0, FN_SEL_SCIF5_1, +		/* RESEVED [2] */ +		0, 0, 0, 0, +		/* SEL_IIC2 [2] */ +		FN_SEL_IIC2_0, FN_SEL_IIC2_1, FN_SEL_IIC2_2, FN_SEL_IIC2_3, +		/* SEL_IIC1 [3] */ +		FN_SEL_IIC1_0, FN_SEL_IIC1_1, FN_SEL_IIC1_2, FN_SEL_IIC1_3, +		FN_SEL_IIC1_4, +		0, 0, 0, +		/* SEL_IIC0 [2] */ +		FN_SEL_IIC0_0, FN_SEL_IIC0_1, FN_SEL_IIC0_2, 0, +		/* RESEVED [2] */ +		0, 0, 0, 0, +		/* RESEVED [2] */ +		0, 0, 0, 0, +		/* RESEVED [1] */ +		0, 0, } +	}, +	{ PINMUX_CFG_REG_VAR("MOD_SEL4", 0xE606009C, 32, +			     3, 2, 2, 1, 1, 1, 1, 3, 2, +			     2, 3, 1, 1, 1, 2, 2, 2, 2) { +		/* SEL_SOF1 [3] */ +		FN_SEL_SOF1_0, FN_SEL_SOF1_1, FN_SEL_SOF1_2, FN_SEL_SOF1_3, +		FN_SEL_SOF1_4, +		0, 0, 0, +		/* SEL_HSCIF0 [2] */ +		FN_SEL_HSCIF0_0, FN_SEL_HSCIF0_1, FN_SEL_HSCIF0_2, 0, +		/* SEL_DIS [2] */ +		FN_SEL_DIS_0, FN_SEL_DIS_1, FN_SEL_DIS_2, 0, +		/* RESEVED [1] */ +		0, 0, +		/* SEL_RAD [1] */ +		FN_SEL_RAD_0, FN_SEL_RAD_1, +		/* SEL_RCN [1] */ +		FN_SEL_RCN_0, FN_SEL_RCN_1, +		/* SEL_RSP [1] */ +		FN_SEL_RSP_0, FN_SEL_RSP_1, +		/* SEL_SCIF2 [3] */ +		FN_SEL_SCIF2_0, FN_SEL_SCIF2_1, FN_SEL_SCIF2_2, +		FN_SEL_SCIF2_3, FN_SEL_SCIF2_4, +		0, 0, 0, +		/* RESEVED [2] */ +		0, 0, 0, 0, +		/* RESEVED [2] */ +		0, 0, 0, 0, +		/* SEL_SOF2 [3] */ +		FN_SEL_SOF2_0, FN_SEL_SOF2_1, FN_SEL_SOF2_2, +		FN_SEL_SOF2_3, FN_SEL_SOF2_4, +		0, 0, 0, +		/* RESEVED [1] */ +		0, 0, +		/* SEL_SSI1 [1] */ +		FN_SEL_SSI1_0, FN_SEL_SSI1_1, +		/* SEL_SSI0 [1] */ +		FN_SEL_SSI0_0, FN_SEL_SSI0_1, +		/* SEL_SSP [2] */ +		FN_SEL_SSP_0, FN_SEL_SSP_1, FN_SEL_SSP_2, 0, +		/* RESEVED [2] */ +		0, 0, 0, 0, +		/* RESEVED [2] */ +		0, 0, 0, 0, +		/* RESEVED [2] */ +		0, 0, 0, 0, } +	}, +	{ PINMUX_CFG_REG("INOUTSEL0", 0xE6050004, 32, 1) { GP_INOUTSEL(0) } }, +	{ PINMUX_CFG_REG("INOUTSEL1", 0xE6051004, 32, 1) { +		0, 0, +		0, 0, +		0, 0, +		0, 0, +		0, 0, +		0, 0, +		GP_1_25_IN, GP_1_25_OUT, +		GP_1_24_IN, GP_1_24_OUT, +		GP_1_23_IN, GP_1_23_OUT, +		GP_1_22_IN, GP_1_22_OUT, +		GP_1_21_IN, GP_1_21_OUT, +		GP_1_20_IN, GP_1_20_OUT, +		GP_1_19_IN, GP_1_19_OUT, +		GP_1_18_IN, GP_1_18_OUT, +		GP_1_17_IN, GP_1_17_OUT, +		GP_1_16_IN, GP_1_16_OUT, +		GP_1_15_IN, GP_1_15_OUT, +		GP_1_14_IN, GP_1_14_OUT, +		GP_1_13_IN, GP_1_13_OUT, +		GP_1_12_IN, GP_1_12_OUT, +		GP_1_11_IN, GP_1_11_OUT, +		GP_1_10_IN, GP_1_10_OUT, +		GP_1_9_IN, GP_1_9_OUT, +		GP_1_8_IN, GP_1_8_OUT, +		GP_1_7_IN, GP_1_7_OUT, +		GP_1_6_IN, GP_1_6_OUT, +		GP_1_5_IN, GP_1_5_OUT, +		GP_1_4_IN, GP_1_4_OUT, +		GP_1_3_IN, GP_1_3_OUT, +		GP_1_2_IN, GP_1_2_OUT, +		GP_1_1_IN, GP_1_1_OUT, +		GP_1_0_IN, GP_1_0_OUT, } +	}, +	{ PINMUX_CFG_REG("INOUTSEL2", 0xE6052004, 32, 1) { GP_INOUTSEL(2) } }, +	{ PINMUX_CFG_REG("INOUTSEL3", 0xE6053004, 32, 1) { GP_INOUTSEL(3) } }, +	{ PINMUX_CFG_REG("INOUTSEL4", 0xE6054004, 32, 1) { GP_INOUTSEL(4) } }, +	{ PINMUX_CFG_REG("INOUTSEL5", 0xE6055004, 32, 1) { GP_INOUTSEL(5) } }, +	{ PINMUX_CFG_REG("INOUTSEL6", 0xE6055404, 32, 1) { GP_INOUTSEL(6) } }, +	{ PINMUX_CFG_REG("INOUTSEL7", 0xE6055804, 32, 1) { +		0, 0, +		0, 0, +		0, 0, +		0, 0, +		0, 0, +		0, 0, +		GP_7_25_IN, GP_7_25_OUT, +		GP_7_24_IN, GP_7_24_OUT, +		GP_7_23_IN, GP_7_23_OUT, +		GP_7_22_IN, GP_7_22_OUT, +		GP_7_21_IN, GP_7_21_OUT, +		GP_7_20_IN, GP_7_20_OUT, +		GP_7_19_IN, GP_7_19_OUT, +		GP_7_18_IN, GP_7_18_OUT, +		GP_7_17_IN, GP_7_17_OUT, +		GP_7_16_IN, GP_7_16_OUT, +		GP_7_15_IN, GP_7_15_OUT, +		GP_7_14_IN, GP_7_14_OUT, +		GP_7_13_IN, GP_7_13_OUT, +		GP_7_12_IN, GP_7_12_OUT, +		GP_7_11_IN, GP_7_11_OUT, +		GP_7_10_IN, GP_7_10_OUT, +		GP_7_9_IN, GP_7_9_OUT, +		GP_7_8_IN, GP_7_8_OUT, +		GP_7_7_IN, GP_7_7_OUT, +		GP_7_6_IN, GP_7_6_OUT, +		GP_7_5_IN, GP_7_5_OUT, +		GP_7_4_IN, GP_7_4_OUT, +		GP_7_3_IN, GP_7_3_OUT, +		GP_7_2_IN, GP_7_2_OUT, +		GP_7_1_IN, GP_7_1_OUT, +		GP_7_0_IN, GP_7_0_OUT, } +	}, +	{ }, +}; + +static struct pinmux_data_reg pinmux_data_regs[] = { +	{ PINMUX_DATA_REG("INDT0", 0xE6050008, 32) { GP_INDT(0) } }, +	{ PINMUX_DATA_REG("INDT1", 0xE6051008, 32) { +		0, 0, 0, 0, +		0, 0, GP_1_25_DATA, GP_1_24_DATA, +		GP_1_23_DATA, GP_1_22_DATA, GP_1_21_DATA, GP_1_20_DATA, +		GP_1_19_DATA, GP_1_18_DATA, GP_1_17_DATA, GP_1_16_DATA, +		GP_1_15_DATA, GP_1_14_DATA, GP_1_13_DATA, GP_1_12_DATA, +		GP_1_11_DATA, GP_1_10_DATA, GP_1_9_DATA, GP_1_8_DATA, +		GP_1_7_DATA, GP_1_6_DATA, GP_1_5_DATA, GP_1_4_DATA, +		GP_1_3_DATA, GP_1_2_DATA, GP_1_1_DATA, GP_1_0_DATA } +	}, +	{ PINMUX_DATA_REG("INDT2", 0xE6052008, 32) { GP_INDT(2) } }, +	{ PINMUX_DATA_REG("INDT3", 0xE6053008, 32) { GP_INDT(3) } }, +	{ PINMUX_DATA_REG("INDT4", 0xE6054008, 32) { GP_INDT(4) } }, +	{ PINMUX_DATA_REG("INDT5", 0xE6055008, 32) { GP_INDT(5) } }, +	{ PINMUX_DATA_REG("INDT6", 0xE6055408, 32) { GP_INDT(6) } }, +	{ PINMUX_DATA_REG("INDT7", 0xE6055808, 32) { +		0, 0, 0, 0, +		0, 0, GP_7_25_DATA, GP_7_24_DATA, +		GP_7_23_DATA, GP_7_22_DATA, GP_7_21_DATA, GP_7_20_DATA, +		GP_7_19_DATA, GP_7_18_DATA, GP_7_17_DATA, GP_7_16_DATA, +		GP_7_15_DATA, GP_7_14_DATA, GP_7_13_DATA, GP_7_12_DATA, +		GP_7_11_DATA, GP_7_10_DATA, GP_7_9_DATA, GP_7_8_DATA, +		GP_7_7_DATA, GP_7_6_DATA, GP_7_5_DATA, GP_7_4_DATA, +		GP_7_3_DATA, GP_7_2_DATA, GP_7_1_DATA, GP_7_0_DATA } +	}, +	{ }, +}; + +static struct pinmux_info r8a7791_pinmux_info = { +	.name = "r8a7791_pfc", + +	.unlock_reg = 0xe6060000, /* PMMR */ + +	.reserved_id = PINMUX_RESERVED, +	.data = { PINMUX_DATA_BEGIN, PINMUX_DATA_END }, +	.input = { PINMUX_INPUT_BEGIN, PINMUX_INPUT_END }, +	.output = { PINMUX_OUTPUT_BEGIN, PINMUX_OUTPUT_END }, +	.mark = { PINMUX_MARK_BEGIN, PINMUX_MARK_END }, +	.function = { PINMUX_FUNCTION_BEGIN, PINMUX_FUNCTION_END }, + +	.first_gpio = GPIO_GP_0_0, +	.last_gpio = GPIO_FN_MSIOF0_SCK_C /* GPIO_FN_CAN1_RX_B */, + +	.gpios = pinmux_gpios, +	.cfg_regs = pinmux_config_regs, +	.data_regs = pinmux_data_regs, + +	.gpio_data = pinmux_data, +	.gpio_data_size = ARRAY_SIZE(pinmux_data), +}; + +void r8a7791_pinmux_init(void) +{ +	register_pinmux(&r8a7791_pinmux_info); +} diff --git a/arch/arm/include/asm/arch-rmobile/gpio.h b/arch/arm/include/asm/arch-rmobile/gpio.h index 877b394b0..560e9f42d 100644 --- a/arch/arm/include/asm/arch-rmobile/gpio.h +++ b/arch/arm/include/asm/arch-rmobile/gpio.h @@ -10,6 +10,9 @@ void r8a7740_pinmux_init(void);  #elif defined(CONFIG_R8A7790)  #include "r8a7790-gpio.h"  void r8a7790_pinmux_init(void); +#elif defined(CONFIG_R8A7791) +#include "r8a7791-gpio.h" +void r8a7791_pinmux_init(void);  #endif  #endif /* __ASM_ARCH_GPIO_H */ diff --git a/arch/arm/include/asm/arch-rmobile/r8a7791-gpio.h b/arch/arm/include/asm/arch-rmobile/r8a7791-gpio.h new file mode 100644 index 000000000..d3cf0c10a --- /dev/null +++ b/arch/arm/include/asm/arch-rmobile/r8a7791-gpio.h @@ -0,0 +1,438 @@ +#ifndef __ASM_R8A7791_H__ +#define __ASM_R8A7791_H__ + +/* Pin Function Controller: + * GPIO_FN_xx - GPIO used to select pin function + * GPIO_GP_x_x - GPIO mapped to real I/O pin on CPU + */ +enum { +	GPIO_GP_0_0, GPIO_GP_0_1, GPIO_GP_0_2, GPIO_GP_0_3, +	GPIO_GP_0_4, GPIO_GP_0_5, GPIO_GP_0_6, GPIO_GP_0_7, +	GPIO_GP_0_8, GPIO_GP_0_9, GPIO_GP_0_10, GPIO_GP_0_11, +	GPIO_GP_0_12, GPIO_GP_0_13, GPIO_GP_0_14, GPIO_GP_0_15, +	GPIO_GP_0_16, GPIO_GP_0_17, GPIO_GP_0_18, GPIO_GP_0_19, +	GPIO_GP_0_20, GPIO_GP_0_21, GPIO_GP_0_22, GPIO_GP_0_23, +	GPIO_GP_0_24, GPIO_GP_0_25, GPIO_GP_0_26, GPIO_GP_0_27, +	GPIO_GP_0_28, GPIO_GP_0_29, GPIO_GP_0_30, GPIO_GP_0_31, + +	GPIO_GP_1_0, GPIO_GP_1_1, GPIO_GP_1_2, GPIO_GP_1_3, +	GPIO_GP_1_4, GPIO_GP_1_5, GPIO_GP_1_6, GPIO_GP_1_7, +	GPIO_GP_1_8, GPIO_GP_1_9, GPIO_GP_1_10, GPIO_GP_1_11, +	GPIO_GP_1_12, GPIO_GP_1_13, GPIO_GP_1_14, GPIO_GP_1_15, +	GPIO_GP_1_16, GPIO_GP_1_17, GPIO_GP_1_18, GPIO_GP_1_19, +	GPIO_GP_1_20, GPIO_GP_1_21, GPIO_GP_1_22, GPIO_GP_1_23, +	GPIO_GP_1_24, GPIO_GP_1_25, + +	GPIO_GP_2_0, GPIO_GP_2_1, GPIO_GP_2_2, GPIO_GP_2_3, +	GPIO_GP_2_4, GPIO_GP_2_5, GPIO_GP_2_6, GPIO_GP_2_7, +	GPIO_GP_2_8, GPIO_GP_2_9, GPIO_GP_2_10, GPIO_GP_2_11, +	GPIO_GP_2_12, GPIO_GP_2_13, GPIO_GP_2_14, GPIO_GP_2_15, +	GPIO_GP_2_16, GPIO_GP_2_17, GPIO_GP_2_18, GPIO_GP_2_19, +	GPIO_GP_2_20, GPIO_GP_2_21, GPIO_GP_2_22, GPIO_GP_2_23, +	GPIO_GP_2_24, GPIO_GP_2_25, GPIO_GP_2_26, GPIO_GP_2_27, +	GPIO_GP_2_28, GPIO_GP_2_29, GPIO_GP_2_30, GPIO_GP_2_31, + +	GPIO_GP_3_0, GPIO_GP_3_1, GPIO_GP_3_2, GPIO_GP_3_3, +	GPIO_GP_3_4, GPIO_GP_3_5, GPIO_GP_3_6, GPIO_GP_3_7, +	GPIO_GP_3_8, GPIO_GP_3_9, GPIO_GP_3_10, GPIO_GP_3_11, +	GPIO_GP_3_12, GPIO_GP_3_13, GPIO_GP_3_14, GPIO_GP_3_15, +	GPIO_GP_3_16, GPIO_GP_3_17, GPIO_GP_3_18, GPIO_GP_3_19, +	GPIO_GP_3_20, GPIO_GP_3_21, GPIO_GP_3_22, GPIO_GP_3_23, +	GPIO_GP_3_24, GPIO_GP_3_25, GPIO_GP_3_26, GPIO_GP_3_27, +	GPIO_GP_3_28, GPIO_GP_3_29, GPIO_GP_3_30, GPIO_GP_3_31, + +	GPIO_GP_4_0, GPIO_GP_4_1, GPIO_GP_4_2, GPIO_GP_4_3, +	GPIO_GP_4_4, GPIO_GP_4_5, GPIO_GP_4_6, GPIO_GP_4_7, +	GPIO_GP_4_8, GPIO_GP_4_9, GPIO_GP_4_10, GPIO_GP_4_11, +	GPIO_GP_4_12, GPIO_GP_4_13, GPIO_GP_4_14, GPIO_GP_4_15, +	GPIO_GP_4_16, GPIO_GP_4_17, GPIO_GP_4_18, GPIO_GP_4_19, +	GPIO_GP_4_20, GPIO_GP_4_21, GPIO_GP_4_22, GPIO_GP_4_23, +	GPIO_GP_4_24, GPIO_GP_4_25, GPIO_GP_4_26, GPIO_GP_4_27, +	GPIO_GP_4_28, GPIO_GP_4_29, GPIO_GP_4_30, GPIO_GP_4_31, + +	GPIO_GP_5_0, GPIO_GP_5_1, GPIO_GP_5_2, GPIO_GP_5_3, +	GPIO_GP_5_4, GPIO_GP_5_5, GPIO_GP_5_6, GPIO_GP_5_7, +	GPIO_GP_5_8, GPIO_GP_5_9, GPIO_GP_5_10, GPIO_GP_5_11, +	GPIO_GP_5_12, GPIO_GP_5_13, GPIO_GP_5_14, GPIO_GP_5_15, +	GPIO_GP_5_16, GPIO_GP_5_17, GPIO_GP_5_18, GPIO_GP_5_19, +	GPIO_GP_5_20, GPIO_GP_5_21, GPIO_GP_5_22, GPIO_GP_5_23, +	GPIO_GP_5_24, GPIO_GP_5_25, GPIO_GP_5_26, GPIO_GP_5_27, +	GPIO_GP_5_28, GPIO_GP_5_29, GPIO_GP_5_30, GPIO_GP_5_31, + +	GPIO_GP_6_0, GPIO_GP_6_1, GPIO_GP_6_2, GPIO_GP_6_3, +	GPIO_GP_6_4, GPIO_GP_6_5, GPIO_GP_6_6, GPIO_GP_6_7, +	GPIO_GP_6_8, GPIO_GP_6_9, GPIO_GP_6_10, GPIO_GP_6_11, +	GPIO_GP_6_12, GPIO_GP_6_13, GPIO_GP_6_14, GPIO_GP_6_15, +	GPIO_GP_6_16, GPIO_GP_6_17, GPIO_GP_6_18, GPIO_GP_6_19, +	GPIO_GP_6_20, GPIO_GP_6_21, GPIO_GP_6_22, GPIO_GP_6_23, +	GPIO_GP_6_24, GPIO_GP_6_25, GPIO_GP_6_26, GPIO_GP_6_27, +	GPIO_GP_6_28, GPIO_GP_6_29, GPIO_GP_6_30, GPIO_GP_6_31, + +	GPIO_GP_7_0, GPIO_GP_7_1, GPIO_GP_7_2, GPIO_GP_7_3, +	GPIO_GP_7_4, GPIO_GP_7_5, GPIO_GP_7_6, GPIO_GP_7_7, +	GPIO_GP_7_8, GPIO_GP_7_9, GPIO_GP_7_10, GPIO_GP_7_11, +	GPIO_GP_7_12, GPIO_GP_7_13, GPIO_GP_7_14, GPIO_GP_7_15, +	GPIO_GP_7_16, GPIO_GP_7_17, GPIO_GP_7_18, GPIO_GP_7_19, +	GPIO_GP_7_20, GPIO_GP_7_21, GPIO_GP_7_22, GPIO_GP_7_23, +	GPIO_GP_7_24, GPIO_GP_7_25, + +	GPIO_FN_EX_CS0_N, GPIO_FN_RD_N, GPIO_FN_AUDIO_CLKA, +	GPIO_FN_VI0_CLK, GPIO_FN_VI0_DATA0_VI0_B0, +	GPIO_FN_VI0_DATA0_VI0_B1, GPIO_FN_VI0_DATA0_VI0_B2, +	GPIO_FN_VI0_DATA0_VI0_B4, GPIO_FN_VI0_DATA0_VI0_B5, +	GPIO_FN_VI0_DATA0_VI0_B6, GPIO_FN_VI0_DATA0_VI0_B7, +	GPIO_FN_USB0_PWEN, GPIO_FN_USB0_OVC, GPIO_FN_USB1_PWEN, + +	/* IPSR0 */ +	GPIO_FN_D0, GPIO_FN_D1, GPIO_FN_D2, GPIO_FN_D3, GPIO_FN_D4, GPIO_FN_D5, +	GPIO_FN_D6, GPIO_FN_D7, GPIO_FN_D8, GPIO_FN_D9, GPIO_FN_D10, +	GPIO_FN_D11, GPIO_FN_D12, GPIO_FN_D13, GPIO_FN_D14, GPIO_FN_D15, +	GPIO_FN_A0, GPIO_FN_ATAWR0_N_C, GPIO_FN_MSIOF0_SCK_B, +	GPIO_FN_SCL0_C, GPIO_FN_PWM2_B, +	GPIO_FN_A1, GPIO_FN_MSIOF0_SYNC_B, GPIO_FN_A2, GPIO_FN_MSIOF0_SS1_B, +	GPIO_FN_A3, GPIO_FN_MSIOF0_SS2_B, GPIO_FN_A4, GPIO_FN_MSIOF0_TXD_B, +	GPIO_FN_A5, GPIO_FN_MSIOF0_RXD_B, GPIO_FN_A6, GPIO_FN_MSIOF1_SCK, + +	/* IPSR1 */ +	GPIO_FN_A7, GPIO_FN_MSIOF1_SYNC, GPIO_FN_A8, +	GPIO_FN_MSIOF1_SS1, GPIO_FN_SCL0, +	GPIO_FN_A9, GPIO_FN_MSIOF1_SS2, GPIO_FN_SDA0, +	GPIO_FN_A10, GPIO_FN_MSIOF1_TXD, GPIO_FN_MSIOF1_TXD_D, +	GPIO_FN_A11, GPIO_FN_MSIOF1_RXD, GPIO_FN_SCL3_D, GPIO_FN_MSIOF1_RXD_D, +	GPIO_FN_A12, GPIO_FN_FMCLK, GPIO_FN_SDA3_D, GPIO_FN_MSIOF1_SCK_D, +	GPIO_FN_A13, GPIO_FN_ATAG0_N_C, GPIO_FN_BPFCLK, GPIO_FN_MSIOF1_SS1_D, +	GPIO_FN_A14, GPIO_FN_ATADIR0_N_C, GPIO_FN_FMIN, +	GPIO_FN_FMIN_C, GPIO_FN_MSIOF1_SYNC_D, +	GPIO_FN_A15, GPIO_FN_BPFCLK_C, +	GPIO_FN_A16, GPIO_FN_DREQ2_B, GPIO_FN_FMCLK_C, GPIO_FN_SCIFA1_SCK_B, +	GPIO_FN_A17, GPIO_FN_DACK2_B, GPIO_FN_SDA0_C, +	GPIO_FN_A18, GPIO_FN_DREQ1, GPIO_FN_SCIFA1_RXD_C, GPIO_FN_SCIFB1_RXD_C, + +	/* IPSR2 */ +	GPIO_FN_A19, GPIO_FN_DACK1, GPIO_FN_SCIFA1_TXD_C, +	GPIO_FN_SCIFB1_TXD_C, GPIO_FN_SCIFB1_SCK_B, +	GPIO_FN_A20, GPIO_FN_SPCLK, +	GPIO_FN_A21, GPIO_FN_ATAWR0_N_B, GPIO_FN_MOSI_IO0, +	GPIO_FN_A22, GPIO_FN_MISO_IO1, GPIO_FN_FMCLK_B, +	GPIO_FN_TX0, GPIO_FN_SCIFA0_TXD, +	GPIO_FN_A23, GPIO_FN_IO2, GPIO_FN_BPFCLK_B, +	GPIO_FN_RX0, GPIO_FN_SCIFA0_RXD, +	GPIO_FN_A24, GPIO_FN_DREQ2, GPIO_FN_IO3, +	GPIO_FN_TX1, GPIO_FN_SCIFA1_TXD, +	GPIO_FN_A25, GPIO_FN_DACK2, GPIO_FN_SSL, GPIO_FN_DREQ1_C, +	GPIO_FN_RX1, GPIO_FN_SCIFA1_RXD, +	GPIO_FN_CS0_N, GPIO_FN_ATAG0_N_B, GPIO_FN_SCL1, +	GPIO_FN_CS1_N_A26, GPIO_FN_ATADIR0_N_B, GPIO_FN_SDA1, +	GPIO_FN_EX_CS1_N, GPIO_FN_MSIOF2_SCK, +	GPIO_FN_EX_CS2_N, GPIO_FN_ATAWR0_N, GPIO_FN_MSIOF2_SYNC, +	GPIO_FN_EX_CS3_N, GPIO_FN_ATADIR0_N, GPIO_FN_MSIOF2_TXD, +	GPIO_FN_ATAG0_N, GPIO_FN_EX_WAIT1, + +	/* IPSR3 */ +	GPIO_FN_EX_CS4_N, GPIO_FN_ATARD0_N, +	GPIO_FN_MSIOF2_RXD, GPIO_FN_EX_WAIT2, +	GPIO_FN_EX_CS5_N, GPIO_FN_ATACS00_N, GPIO_FN_MSIOF2_SS1, +	GPIO_FN_HRX1_B, GPIO_FN_SCIFB1_RXD_B, +	GPIO_FN_PWM1, GPIO_FN_TPU_TO1, +	GPIO_FN_BS_N, GPIO_FN_ATACS10_N, GPIO_FN_MSIOF2_SS2, +	GPIO_FN_HTX1_B, GPIO_FN_SCIFB1_TXD_B, +	GPIO_FN_PWM2, GPIO_FN_TPU_TO2, +	GPIO_FN_RD_WR_N, GPIO_FN_HRX2_B, GPIO_FN_FMIN_B, +	GPIO_FN_SCIFB0_RXD_B, GPIO_FN_DREQ1_D, +	GPIO_FN_WE0_N, GPIO_FN_HCTS2_N_B, GPIO_FN_SCIFB0_TXD_B, +	GPIO_FN_WE1_N, GPIO_FN_ATARD0_N_B, +	GPIO_FN_HTX2_B, GPIO_FN_SCIFB0_RTS_N_B, +	GPIO_FN_EX_WAIT0, GPIO_FN_HRTS2_N_B, GPIO_FN_SCIFB0_CTS_N_B, +	GPIO_FN_DREQ0, GPIO_FN_PWM3, GPIO_FN_TPU_TO3, +	GPIO_FN_DACK0, GPIO_FN_DRACK0, GPIO_FN_REMOCON, +	GPIO_FN_SPEEDIN, GPIO_FN_HSCK0_C, GPIO_FN_HSCK2_C, +	GPIO_FN_SCIFB0_SCK_B, GPIO_FN_SCIFB2_SCK_B, +	GPIO_FN_DREQ2_C, GPIO_FN_HTX2_D, +	GPIO_FN_SSI_SCK0129, GPIO_FN_HRX0_C, GPIO_FN_HRX2_C, +	GPIO_FN_SCIFB0_RXD_C, GPIO_FN_SCIFB2_RXD_C, +	GPIO_FN_SSI_WS0129, GPIO_FN_HTX0_C, GPIO_FN_HTX2_C, +	GPIO_FN_SCIFB0_TXD_C, GPIO_FN_SCIFB2_TXD_C, + +	/* IPSR4 */ +	GPIO_FN_SSI_SDATA0, GPIO_FN_SCL0_B, +	GPIO_FN_SCL7_B, GPIO_FN_MSIOF2_SCK_C, +	GPIO_FN_SSI_SCK1, GPIO_FN_SDA0_B, GPIO_FN_SDA7_B, +	GPIO_FN_MSIOF2_SYNC_C, GPIO_FN_GLO_I0_D, +	GPIO_FN_SSI_WS1, GPIO_FN_SCL1_B, GPIO_FN_SCL8_B, +	GPIO_FN_MSIOF2_TXD_C, GPIO_FN_GLO_I1_D, +	GPIO_FN_SSI_SDATA1, GPIO_FN_SDA1_B, +	GPIO_FN_SDA8_B, GPIO_FN_MSIOF2_RXD_C, +	GPIO_FN_SSI_SCK2, GPIO_FN_SCL2, GPIO_FN_GPS_CLK_B, +	GPIO_FN_GLO_Q0_D, GPIO_FN_HSCK1_E, +	GPIO_FN_SSI_WS2, GPIO_FN_SDA2, GPIO_FN_GPS_SIGN_B, +	GPIO_FN_RX2_E, GPIO_FN_GLO_Q1_D, GPIO_FN_HCTS1_N_E, +	GPIO_FN_SSI_SDATA2, GPIO_FN_GPS_MAG_B, +	GPIO_FN_TX2_E, GPIO_FN_HRTS1_N_E, +	GPIO_FN_SSI_SCK34, GPIO_FN_SSI_WS34, GPIO_FN_SSI_SDATA3, +	GPIO_FN_SSI_SCK4, GPIO_FN_GLO_SS_D, +	GPIO_FN_SSI_WS4, GPIO_FN_GLO_RFON_D, +	GPIO_FN_SSI_SDATA4, GPIO_FN_MSIOF2_SCK_D, +	GPIO_FN_SSI_SCK5, GPIO_FN_MSIOF1_SCK_C, +	GPIO_FN_TS_SDATA0, GPIO_FN_GLO_I0, +	GPIO_FN_MSIOF2_SYNC_D, GPIO_FN_VI1_R2_B, + +	/* IPSR5 */ +	GPIO_FN_SSI_WS5, GPIO_FN_MSIOF1_SYNC_C, GPIO_FN_TS_SCK0, +	GPIO_FN_GLO_I1, GPIO_FN_MSIOF2_TXD_D, GPIO_FN_VI1_R3_B, +	GPIO_FN_SSI_SDATA5, GPIO_FN_MSIOF1_TXD_C, GPIO_FN_TS_SDEN0, +	GPIO_FN_GLO_Q0, GPIO_FN_MSIOF2_SS1_D, GPIO_FN_VI1_R4_B, +	GPIO_FN_SSI_SCK6, GPIO_FN_MSIOF1_RXD_C, GPIO_FN_TS_SPSYNC0, +	GPIO_FN_GLO_Q1, GPIO_FN_MSIOF2_RXD_D, GPIO_FN_VI1_R5_B, +	GPIO_FN_SSI_WS6, GPIO_FN_GLO_SCLK, +	GPIO_FN_MSIOF2_SS2_D, GPIO_FN_VI1_R6_B, +	GPIO_FN_SSI_SDATA6, GPIO_FN_STP_IVCXO27_0_B, +	GPIO_FN_GLO_SDATA, GPIO_FN_VI1_R7_B, +	GPIO_FN_SSI_SCK78, GPIO_FN_STP_ISCLK_0_B, GPIO_FN_GLO_SS, +	GPIO_FN_SSI_WS78, GPIO_FN_TX0_D, GPIO_FN_STP_ISD_0_B, GPIO_FN_GLO_RFON, +	GPIO_FN_SSI_SDATA7, GPIO_FN_RX0_D, GPIO_FN_STP_ISEN_0_B, +	GPIO_FN_SSI_SDATA8, GPIO_FN_TX1_D, GPIO_FN_STP_ISSYNC_0_B, +	GPIO_FN_SSI_SCK9, GPIO_FN_RX1_D, GPIO_FN_GLO_SCLK_D, +	GPIO_FN_SSI_WS9, GPIO_FN_TX3_D, GPIO_FN_CAN0_TX_D, GPIO_FN_GLO_SDATA_D, +	GPIO_FN_SSI_SDATA9, GPIO_FN_RX3_D, GPIO_FN_CAN0_RX_D, + +	/* IPSR6 */ +	GPIO_FN_AUDIO_CLKB, GPIO_FN_STP_OPWM_0_B, GPIO_FN_MSIOF1_SCK_B, +	GPIO_FN_SCIF_CLK, GPIO_FN_BPFCLK_E, +	GPIO_FN_AUDIO_CLKC, GPIO_FN_SCIFB0_SCK_C, GPIO_FN_MSIOF1_SYNC_B, +	GPIO_FN_RX2, GPIO_FN_SCIFA2_RXD, GPIO_FN_FMIN_E, +	GPIO_FN_AUDIO_CLKOUT, GPIO_FN_MSIOF1_SS1_B, +	GPIO_FN_TX2, GPIO_FN_SCIFA2_TXD, +	GPIO_FN_IRQ0, GPIO_FN_SCIFB1_RXD_D, GPIO_FN_INTC_IRQ0_N, +	GPIO_FN_IRQ1, GPIO_FN_SCIFB1_SCK_C, GPIO_FN_INTC_IRQ1_N, +	GPIO_FN_IRQ2, GPIO_FN_SCIFB1_TXD_D, GPIO_FN_INTC_IRQ2_N, +	GPIO_FN_IRQ3, GPIO_FN_SCL4_C, +	GPIO_FN_MSIOF2_TXD_E, GPIO_FN_INTC_IRQ3_N, +	GPIO_FN_IRQ4, GPIO_FN_HRX1_C, GPIO_FN_SDA4_C, +	GPIO_FN_MSIOF2_RXD_E, GPIO_FN_INTC_IRQ4_N, +	GPIO_FN_IRQ5, GPIO_FN_HTX1_C, GPIO_FN_SCL1_E, GPIO_FN_MSIOF2_SCK_E, +	GPIO_FN_IRQ6, GPIO_FN_HSCK1_C, GPIO_FN_MSIOF1_SS2_B, +	GPIO_FN_SDA1_E, GPIO_FN_MSIOF2_SYNC_E, +	GPIO_FN_IRQ7, GPIO_FN_HCTS1_N_C, GPIO_FN_MSIOF1_TXD_B, +	GPIO_FN_GPS_CLK_C, GPIO_FN_GPS_CLK_D, +	GPIO_FN_IRQ8, GPIO_FN_HRTS1_N_C, GPIO_FN_MSIOF1_RXD_B, +	GPIO_FN_GPS_SIGN_C, GPIO_FN_GPS_SIGN_D, + +	/* IPSR7 */ +	GPIO_FN_IRQ9, GPIO_FN_DU1_DOTCLKIN_B, GPIO_FN_CAN_CLK_D, +	GPIO_FN_GPS_MAG_C, GPIO_FN_SCIF_CLK_B, GPIO_FN_GPS_MAG_D, +	GPIO_FN_DU1_DR0, GPIO_FN_LCDOUT0, GPIO_FN_VI1_DATA0_B, GPIO_FN_TX0_B, +	GPIO_FN_SCIFA0_TXD_B, GPIO_FN_MSIOF2_SCK_B, +	GPIO_FN_DU1_DR1, GPIO_FN_LCDOUT1, GPIO_FN_VI1_DATA1_B, GPIO_FN_RX0_B, +	GPIO_FN_SCIFA0_RXD_B, GPIO_FN_MSIOF2_SYNC_B, +	GPIO_FN_DU1_DR2, GPIO_FN_LCDOUT2, GPIO_FN_SSI_SCK0129_B, +	GPIO_FN_DU1_DR3, GPIO_FN_LCDOUT3, GPIO_FN_SSI_WS0129_B, +	GPIO_FN_DU1_DR4, GPIO_FN_LCDOUT4, GPIO_FN_SSI_SDATA0_B, +	GPIO_FN_DU1_DR5, GPIO_FN_LCDOUT5, GPIO_FN_SSI_SCK1_B, +	GPIO_FN_DU1_DR6, GPIO_FN_LCDOUT6, GPIO_FN_SSI_WS1_B, +	GPIO_FN_DU1_DR7, GPIO_FN_LCDOUT7, GPIO_FN_SSI_SDATA1_B, +	GPIO_FN_DU1_DG0, GPIO_FN_LCDOUT8, GPIO_FN_VI1_DATA2_B, GPIO_FN_TX1_B, +	GPIO_FN_SCIFA1_TXD_B, GPIO_FN_MSIOF2_SS1_B, +	GPIO_FN_DU1_DG1, GPIO_FN_LCDOUT9, GPIO_FN_VI1_DATA3_B, GPIO_FN_RX1_B, +	GPIO_FN_SCIFA1_RXD_B, GPIO_FN_MSIOF2_SS2_B, +	GPIO_FN_DU1_DG2, GPIO_FN_LCDOUT10, GPIO_FN_VI1_DATA4_B, +	GPIO_FN_SCIF1_SCK_B, GPIO_FN_SCIFA1_SCK, GPIO_FN_SSI_SCK78_B, + +	/* IPSR8 */ +	GPIO_FN_DU1_DG3, GPIO_FN_LCDOUT11, +	GPIO_FN_VI1_DATA5_B, GPIO_FN_SSI_WS78_B, +	GPIO_FN_DU1_DG4, GPIO_FN_LCDOUT12, GPIO_FN_VI1_DATA6_B, +	GPIO_FN_HRX0_B, GPIO_FN_SCIFB2_RXD_B, GPIO_FN_SSI_SDATA7_B, +	GPIO_FN_DU1_DG5, GPIO_FN_LCDOUT13, GPIO_FN_VI1_DATA7_B, +	GPIO_FN_HCTS0_N_B, GPIO_FN_SCIFB2_TXD_B, GPIO_FN_SSI_SDATA8_B, +	GPIO_FN_DU1_DG6, GPIO_FN_LCDOUT14, GPIO_FN_HRTS0_N_B, +	GPIO_FN_SCIFB2_CTS_N_B, GPIO_FN_SSI_SCK9_B, +	GPIO_FN_DU1_DG7, GPIO_FN_LCDOUT15, GPIO_FN_HTX0_B, +	GPIO_FN_SCIFB2_RTS_N_B, GPIO_FN_SSI_WS9_B, +	GPIO_FN_DU1_DB0, GPIO_FN_LCDOUT16, GPIO_FN_VI1_CLK_B, GPIO_FN_TX2_B, +	GPIO_FN_SCIFA2_TXD_B, GPIO_FN_MSIOF2_TXD_B, +	GPIO_FN_DU1_DB1, GPIO_FN_LCDOUT17, GPIO_FN_VI1_HSYNC_N_B, +	GPIO_FN_RX2_B, GPIO_FN_SCIFA2_RXD_B, GPIO_FN_MSIOF2_RXD_B, +	GPIO_FN_DU1_DB2, GPIO_FN_LCDOUT18, GPIO_FN_VI1_VSYNC_N_B, +	GPIO_FN_SCIF2_SCK_B, GPIO_FN_SCIFA2_SCK, GPIO_FN_SSI_SDATA9_B, +	GPIO_FN_DU1_DB3, GPIO_FN_LCDOUT19, GPIO_FN_VI1_CLKENB_B, +	GPIO_FN_DU1_DB4, GPIO_FN_LCDOUT20, +	GPIO_FN_VI1_FIELD_B, GPIO_FN_CAN1_RX, +	GPIO_FN_DU1_DB5, GPIO_FN_LCDOUT21, GPIO_FN_TX3, +	GPIO_FN_SCIFA3_TXD, GPIO_FN_CAN1_TX, + +	/* IPSR9 */ +	GPIO_FN_DU1_DB6, GPIO_FN_LCDOUT22, GPIO_FN_SCL3_C, +	GPIO_FN_RX3, GPIO_FN_SCIFA3_RXD, +	GPIO_FN_DU1_DB7, GPIO_FN_LCDOUT23, GPIO_FN_SDA3_C, +	GPIO_FN_SCIF3_SCK, GPIO_FN_SCIFA3_SCK, +	GPIO_FN_DU1_DOTCLKIN, GPIO_FN_QSTVA_QVS, +	GPIO_FN_DU1_DOTCLKOUT0, GPIO_FN_QCLK, +	GPIO_FN_DU1_DOTCLKOUT1, GPIO_FN_QSTVB_QVE, GPIO_FN_CAN0_TX, +	GPIO_FN_TX3_B, GPIO_FN_SCL2_B, GPIO_FN_PWM4, +	GPIO_FN_DU1_EXHSYNC_DU1_HSYNC, GPIO_FN_QSTH_QHS, +	GPIO_FN_DU1_EXVSYNC_DU1_VSYNC, GPIO_FN_QSTB_QHE, +	GPIO_FN_DU1_EXODDF_DU1_ODDF_DISP_CDE, GPIO_FN_QCPV_QDE, +	GPIO_FN_CAN0_RX, GPIO_FN_RX3_B, GPIO_FN_SDA2_B, +	GPIO_FN_DU1_DISP, GPIO_FN_QPOLA, +	GPIO_FN_DU1_CDE, GPIO_FN_QPOLB, GPIO_FN_PWM4_B, +	GPIO_FN_VI0_CLKENB, GPIO_FN_TX4, +	GPIO_FN_SCIFA4_TXD, GPIO_FN_TS_SDATA0_D, +	GPIO_FN_VI0_FIELD, GPIO_FN_RX4, GPIO_FN_SCIFA4_RXD, GPIO_FN_TS_SCK0_D, +	GPIO_FN_VI0_HSYNC_N, GPIO_FN_TX5, +	GPIO_FN_SCIFA5_TXD, GPIO_FN_TS_SDEN0_D, +	GPIO_FN_VI0_VSYNC_N, GPIO_FN_RX5, +	GPIO_FN_SCIFA5_RXD, GPIO_FN_TS_SPSYNC0_D, +	GPIO_FN_VI0_DATA3_VI0_B3, GPIO_FN_SCIF3_SCK_B, GPIO_FN_SCIFA3_SCK_B, +	GPIO_FN_VI0_G0, GPIO_FN_SCL8, GPIO_FN_STP_IVCXO27_0_C, GPIO_FN_SCL4, +	GPIO_FN_HCTS2_N, GPIO_FN_SCIFB2_CTS_N, GPIO_FN_ATAWR1_N, + +	/* IPSR10 */ +	GPIO_FN_VI0_G1, GPIO_FN_SDA8, GPIO_FN_STP_ISCLK_0_C, GPIO_FN_SDA4, +	GPIO_FN_HRTS2_N, GPIO_FN_SCIFB2_RTS_N, GPIO_FN_ATADIR1_N, +	GPIO_FN_VI0_G2, GPIO_FN_VI2_HSYNC_N, GPIO_FN_STP_ISD_0_C, +	GPIO_FN_SCL3_B, GPIO_FN_HSCK2, GPIO_FN_SCIFB2_SCK, GPIO_FN_ATARD1_N, +	GPIO_FN_VI0_G3, GPIO_FN_VI2_VSYNC_N, GPIO_FN_STP_ISEN_0_C, +	GPIO_FN_SDA3_B, GPIO_FN_HRX2, GPIO_FN_SCIFB2_RXD, GPIO_FN_ATACS01_N, +	GPIO_FN_VI0_G4, GPIO_FN_VI2_CLKENB, GPIO_FN_STP_ISSYNC_0_C, +	GPIO_FN_HTX2, GPIO_FN_SCIFB2_TXD, GPIO_FN_SCIFB0_SCK_D, +	GPIO_FN_VI0_G5, GPIO_FN_VI2_FIELD, GPIO_FN_STP_OPWM_0_C, +	GPIO_FN_FMCLK_D, GPIO_FN_CAN0_TX_E, +	GPIO_FN_HTX1_D, GPIO_FN_SCIFB0_TXD_D, +	GPIO_FN_VI0_G6, GPIO_FN_VI2_CLK, GPIO_FN_BPFCLK_D, +	GPIO_FN_VI0_G7, GPIO_FN_VI2_DATA0, GPIO_FN_FMIN_D, +	GPIO_FN_VI0_R0, GPIO_FN_VI2_DATA1, GPIO_FN_GLO_I0_B, +	GPIO_FN_TS_SDATA0_C, GPIO_FN_ATACS11_N, +	GPIO_FN_VI0_R1, GPIO_FN_VI2_DATA2, GPIO_FN_GLO_I1_B, +	GPIO_FN_TS_SCK0_C, GPIO_FN_ATAG1_N, +	GPIO_FN_VI0_R2, GPIO_FN_VI2_DATA3, +	GPIO_FN_GLO_Q0_B, GPIO_FN_TS_SDEN0_C, +	GPIO_FN_VI0_R3, GPIO_FN_VI2_DATA4, +	GPIO_FN_GLO_Q1_B, GPIO_FN_TS_SPSYNC0_C, +	GPIO_FN_VI0_R4, GPIO_FN_VI2_DATA5, GPIO_FN_GLO_SCLK_B, +	GPIO_FN_TX0_C, GPIO_FN_SCL1_D, + +	/* IPSR11 */ +	GPIO_FN_VI0_R5, GPIO_FN_VI2_DATA6, GPIO_FN_GLO_SDATA_B, +	GPIO_FN_RX0_C, GPIO_FN_SDA1_D, +	GPIO_FN_VI0_R6, GPIO_FN_VI2_DATA7, GPIO_FN_GLO_SS_B, +	GPIO_FN_TX1_C, GPIO_FN_SCL4_B, +	GPIO_FN_VI0_R7, GPIO_FN_GLO_RFON_B, GPIO_FN_RX1_C, GPIO_FN_CAN0_RX_E, +	GPIO_FN_SDA4_B, GPIO_FN_HRX1_D, GPIO_FN_SCIFB0_RXD_D, +	GPIO_FN_VI1_HSYNC_N, GPIO_FN_AVB_RXD0, GPIO_FN_TS_SDATA0_B, +	GPIO_FN_TX4_B, GPIO_FN_SCIFA4_TXD_B, +	GPIO_FN_VI1_VSYNC_N, GPIO_FN_AVB_RXD1, GPIO_FN_TS_SCK0_B, +	GPIO_FN_RX4_B, GPIO_FN_SCIFA4_RXD_B, +	GPIO_FN_VI1_CLKENB, GPIO_FN_AVB_RXD2, GPIO_FN_TS_SDEN0_B, +	GPIO_FN_VI1_FIELD, GPIO_FN_AVB_RXD3, GPIO_FN_TS_SPSYNC0_B, +	GPIO_FN_VI1_CLK, GPIO_FN_AVB_RXD4, GPIO_FN_VI1_DATA0, GPIO_FN_AVB_RXD5, +	GPIO_FN_VI1_DATA1, GPIO_FN_AVB_RXD6, +	GPIO_FN_VI1_DATA2, GPIO_FN_AVB_RXD7, +	GPIO_FN_VI1_DATA3, GPIO_FN_AVB_RX_ER, +	GPIO_FN_VI1_DATA4, GPIO_FN_AVB_MDIO, +	GPIO_FN_VI1_DATA5, GPIO_FN_AVB_RX_DV, +	GPIO_FN_VI1_DATA6, GPIO_FN_AVB_MAGIC, +	GPIO_FN_VI1_DATA7, GPIO_FN_AVB_MDC, +	GPIO_FN_ETH_MDIO, GPIO_FN_AVB_RX_CLK, GPIO_FN_SCL2_C, +	GPIO_FN_ETH_CRS_DV, GPIO_FN_AVB_LINK, GPIO_FN_SDA2_C, + +	/* IPSR12 */ +	GPIO_FN_ETH_RX_ER, GPIO_FN_AVB_CRS, GPIO_FN_SCL3, GPIO_FN_SCL7, +	GPIO_FN_ETH_RXD0, GPIO_FN_AVB_PHY_INT, GPIO_FN_SDA3, GPIO_FN_SDA7, +	GPIO_FN_ETH_RXD1, GPIO_FN_AVB_GTXREFCLK, GPIO_FN_CAN0_TX_C, +	GPIO_FN_SCL2_D, GPIO_FN_MSIOF1_RXD_E, +	GPIO_FN_ETH_LINK, GPIO_FN_AVB_TXD0, GPIO_FN_CAN0_RX_C, +	GPIO_FN_SDA2_D, GPIO_FN_MSIOF1_SCK_E, +	GPIO_FN_ETH_REFCLK, GPIO_FN_AVB_TXD1, GPIO_FN_SCIFA3_RXD_B, +	GPIO_FN_CAN1_RX_C, GPIO_FN_MSIOF1_SYNC_E, +	GPIO_FN_ETH_TXD1, GPIO_FN_AVB_TXD2, GPIO_FN_SCIFA3_TXD_B, +	GPIO_FN_CAN1_TX_C, GPIO_FN_MSIOF1_TXD_E, +	GPIO_FN_ETH_TX_EN, GPIO_FN_AVB_TXD3, +	GPIO_FN_TCLK1_B, GPIO_FN_CAN_CLK_B, +	GPIO_FN_ETH_MAGIC, GPIO_FN_AVB_TXD4, GPIO_FN_IETX_C, +	GPIO_FN_ETH_TXD0, GPIO_FN_AVB_TXD5, GPIO_FN_IECLK_C, +	GPIO_FN_ETH_MDC, GPIO_FN_AVB_TXD6, GPIO_FN_IERX_C, +	GPIO_FN_STP_IVCXO27_0, GPIO_FN_AVB_TXD7, GPIO_FN_SCIFB2_TXD_D, +	GPIO_FN_ADIDATA_B, GPIO_FN_MSIOF0_SYNC_C, +	GPIO_FN_STP_ISCLK_0, GPIO_FN_AVB_TX_EN, GPIO_FN_SCIFB2_RXD_D, +	GPIO_FN_ADICS_SAMP_B, GPIO_FN_MSIOF0_SCK_C, + +	/* IPSR13 */ +	GPIO_FN_STP_ISD_0, GPIO_FN_AVB_TX_ER, GPIO_FN_SCIFB2_SCK_C, +	GPIO_FN_ADICLK_B, GPIO_FN_MSIOF0_SS1_C, +	GPIO_FN_STP_ISEN_0, GPIO_FN_AVB_TX_CLK, +	GPIO_FN_ADICHS0_B, GPIO_FN_MSIOF0_SS2_C, +	GPIO_FN_STP_ISSYNC_0, GPIO_FN_AVB_COL, +	GPIO_FN_ADICHS1_B, GPIO_FN_MSIOF0_RXD_C, +	GPIO_FN_STP_OPWM_0, GPIO_FN_AVB_GTX_CLK, GPIO_FN_PWM0_B, +	GPIO_FN_ADICHS2_B, GPIO_FN_MSIOF0_TXD_C, +	GPIO_FN_SD0_CLK, GPIO_FN_SPCLK_B, GPIO_FN_SD0_CMD, GPIO_FN_MOSI_IO0_B, +	GPIO_FN_SD0_DATA0, GPIO_FN_MISO_IO1_B, +	GPIO_FN_SD0_DATA1, GPIO_FN_IO2_B, +	GPIO_FN_SD0_DATA2, GPIO_FN_IO3_B, GPIO_FN_SD0_DATA3, GPIO_FN_SSL_B, +	GPIO_FN_SD0_CD, GPIO_FN_MMC_D6_B, +	GPIO_FN_SIM0_RST_B, GPIO_FN_CAN0_RX_F, +	GPIO_FN_SCIFA5_TXD_B, GPIO_FN_TX3_C, +	GPIO_FN_SD0_WP, GPIO_FN_MMC_D7_B, GPIO_FN_SIM0_D_B, GPIO_FN_CAN0_TX_F, +	GPIO_FN_SCIFA5_RXD_B, GPIO_FN_RX3_C, +	GPIO_FN_SD1_CMD, GPIO_FN_REMOCON_B, +	GPIO_FN_SD1_DATA0, GPIO_FN_SPEEDIN_B, +	GPIO_FN_SD1_DATA1, GPIO_FN_IETX_B, GPIO_FN_SD1_DATA2, GPIO_FN_IECLK_B, +	GPIO_FN_SD1_DATA3, GPIO_FN_IERX_B, +	GPIO_FN_SD1_CD, GPIO_FN_PWM0, GPIO_FN_TPU_TO0, GPIO_FN_SCL1_C, + +	/* IPSR14 */ +	GPIO_FN_SD1_WP, GPIO_FN_PWM1_B, GPIO_FN_SDA1_C, +	GPIO_FN_SD2_CLK, GPIO_FN_MMC_CLK, GPIO_FN_SD2_CMD, GPIO_FN_MMC_CMD, +	GPIO_FN_SD2_DATA0, GPIO_FN_MMC_D0, GPIO_FN_SD2_DATA1, GPIO_FN_MMC_D1, +	GPIO_FN_SD2_DATA2, GPIO_FN_MMC_D2, GPIO_FN_SD2_DATA3, GPIO_FN_MMC_D3, +	GPIO_FN_SD2_CD, GPIO_FN_MMC_D4, GPIO_FN_SCL8_C, +	GPIO_FN_TX5_B, GPIO_FN_SCIFA5_TXD_C, +	GPIO_FN_SD2_WP, GPIO_FN_MMC_D5, GPIO_FN_SDA8_C, +	GPIO_FN_RX5_B, GPIO_FN_SCIFA5_RXD_C, +	GPIO_FN_MSIOF0_SCK, GPIO_FN_RX2_C, GPIO_FN_ADIDATA, +	GPIO_FN_VI1_CLK_C, GPIO_FN_VI1_G0_B, +	GPIO_FN_MSIOF0_SYNC, GPIO_FN_TX2_C, GPIO_FN_ADICS_SAMP, +	GPIO_FN_VI1_CLKENB_C, GPIO_FN_VI1_G1_B, +	GPIO_FN_MSIOF0_TXD, GPIO_FN_ADICLK, +	GPIO_FN_VI1_FIELD_C, GPIO_FN_VI1_G2_B, +	GPIO_FN_MSIOF0_RXD, GPIO_FN_ADICHS0, +	GPIO_FN_VI1_DATA0_C, GPIO_FN_VI1_G3_B, +	GPIO_FN_MSIOF0_SS1, GPIO_FN_MMC_D6, GPIO_FN_ADICHS1, GPIO_FN_TX0_E, +	GPIO_FN_VI1_HSYNC_N_C, GPIO_FN_SCL7_C, GPIO_FN_VI1_G4_B, +	GPIO_FN_MSIOF0_SS2, GPIO_FN_MMC_D7, GPIO_FN_ADICHS2, GPIO_FN_RX0_E, +	GPIO_FN_VI1_VSYNC_N_C, GPIO_FN_SDA7_C, GPIO_FN_VI1_G5_B, + +	/* IPSR15 */ +	GPIO_FN_SIM0_RST, GPIO_FN_IETX, GPIO_FN_CAN1_TX_D, +	GPIO_FN_SIM0_CLK, GPIO_FN_IECLK, GPIO_FN_CAN_CLK_C, +	GPIO_FN_SIM0_D, GPIO_FN_IERX, GPIO_FN_CAN1_RX_D, +	GPIO_FN_GPS_CLK, GPIO_FN_DU1_DOTCLKIN_C, GPIO_FN_AUDIO_CLKB_B, +	GPIO_FN_PWM5_B, GPIO_FN_SCIFA3_TXD_C, +	GPIO_FN_GPS_SIGN, GPIO_FN_TX4_C, GPIO_FN_SCIFA4_TXD_C, GPIO_FN_PWM5, +	GPIO_FN_VI1_G6_B, GPIO_FN_SCIFA3_RXD_C, +	GPIO_FN_GPS_MAG, GPIO_FN_RX4_C, GPIO_FN_SCIFA4_RXD_C, GPIO_FN_PWM6, +	GPIO_FN_VI1_G7_B, GPIO_FN_SCIFA3_SCK_C, +	GPIO_FN_HCTS0_N, GPIO_FN_SCIFB0_CTS_N, GPIO_FN_GLO_I0_C, +	GPIO_FN_TCLK1, GPIO_FN_VI1_DATA1_C, +	GPIO_FN_HRTS0_N, GPIO_FN_SCIFB0_RTS_N, +	GPIO_FN_GLO_I1_C, GPIO_FN_VI1_DATA2_C, +	GPIO_FN_HSCK0, GPIO_FN_SCIFB0_SCK, GPIO_FN_GLO_Q0_C, GPIO_FN_CAN_CLK, +	GPIO_FN_TCLK2, GPIO_FN_VI1_DATA3_C, +	GPIO_FN_HRX0, GPIO_FN_SCIFB0_RXD, GPIO_FN_GLO_Q1_C, +	GPIO_FN_CAN0_RX_B, GPIO_FN_VI1_DATA4_C, +	GPIO_FN_HTX0, GPIO_FN_SCIFB0_TXD, GPIO_FN_GLO_SCLK_C, +	GPIO_FN_CAN0_TX_B, GPIO_FN_VI1_DATA5_C, + +	/* IPSR16 */ +	GPIO_FN_HRX1, GPIO_FN_SCIFB1_RXD, GPIO_FN_VI1_R0_B, +	GPIO_FN_GLO_SDATA_C, GPIO_FN_VI1_DATA6_C, +	GPIO_FN_HTX1, GPIO_FN_SCIFB1_TXD, GPIO_FN_VI1_R1_B, +	GPIO_FN_GLO_SS_C, GPIO_FN_VI1_DATA7_C, +	GPIO_FN_HSCK1, GPIO_FN_SCIFB1_SCK, GPIO_FN_MLB_CK, GPIO_FN_GLO_RFON_C, +	GPIO_FN_HCTS1_N, GPIO_FN_SCIFB1_CTS_N, +	GPIO_FN_MLB_SIG, GPIO_FN_CAN1_TX_B, +	GPIO_FN_HRTS1_N, GPIO_FN_SCIFB1_RTS_N, +	GPIO_FN_MLB_DAT, GPIO_FN_CAN1_RX_B, +}; + +#endif /* __ASM_R8A7791_H__ */ diff --git a/arch/arm/include/asm/arch-rmobile/r8a7791.h b/arch/arm/include/asm/arch-rmobile/r8a7791.h new file mode 100644 index 000000000..8f26e6ee6 --- /dev/null +++ b/arch/arm/include/asm/arch-rmobile/r8a7791.h @@ -0,0 +1,598 @@ +/* + * arch/arm/include/asm/arch-rmobile/r8a7791.h + *     This file is r8a7791 processor definition. + * + * Copyright (C) 2013 Renesas Electronics Corporation + * + * SPDX-License-Identifier: GPL-2.0 + */ + +#ifndef __ASM_ARCH_R8A7791_H +#define __ASM_ARCH_R8A7791_H + +/* + * R8A7791 I/O Addresses + */ +#define	RWDT_BASE	0xE6020000 +#define	SWDT_BASE	0xE6030000 +#define	LBSC_BASE	0xFEC00200 +#define DBSC3_0_BASE	0xE6790000 +#define DBSC3_1_BASE	0xE67A0000 +#define TMU_BASE	0xE61E0000 +#define	GPIO5_BASE	0xE6055000 + +#define S3C_BASE	0xE6784000 +#define S3C_INT_BASE	0xE6784A00 +#define S3C_MEDIA_BASE	0xE6784B00 + +#define S3C_QOS_DCACHE_BASE	0xE6784BDC +#define S3C_QOS_CCI0_BASE	0xE6784C00 +#define S3C_QOS_CCI1_BASE	0xE6784C24 +#define S3C_QOS_MXI_BASE	0xE6784C48 +#define S3C_QOS_AXI_BASE	0xE6784C6C + +#define DBSC3_0_QOS_R0_BASE	0xE6791000 +#define DBSC3_0_QOS_R1_BASE	0xE6791100 +#define DBSC3_0_QOS_R2_BASE	0xE6791200 +#define DBSC3_0_QOS_R3_BASE	0xE6791300 +#define DBSC3_0_QOS_R4_BASE	0xE6791400 +#define DBSC3_0_QOS_R5_BASE	0xE6791500 +#define DBSC3_0_QOS_R6_BASE	0xE6791600 +#define DBSC3_0_QOS_R7_BASE	0xE6791700 +#define DBSC3_0_QOS_R8_BASE	0xE6791800 +#define DBSC3_0_QOS_R9_BASE	0xE6791900 +#define DBSC3_0_QOS_R10_BASE	0xE6791A00 +#define DBSC3_0_QOS_R11_BASE	0xE6791B00 +#define DBSC3_0_QOS_R12_BASE	0xE6791C00 +#define DBSC3_0_QOS_R13_BASE	0xE6791D00 +#define DBSC3_0_QOS_R14_BASE	0xE6791E00 +#define DBSC3_0_QOS_R15_BASE	0xE6791F00 +#define DBSC3_0_QOS_W0_BASE	0xE6792000 +#define DBSC3_0_QOS_W1_BASE	0xE6792100 +#define DBSC3_0_QOS_W2_BASE	0xE6792200 +#define DBSC3_0_QOS_W3_BASE	0xE6792300 +#define DBSC3_0_QOS_W4_BASE	0xE6792400 +#define DBSC3_0_QOS_W5_BASE	0xE6792500 +#define DBSC3_0_QOS_W6_BASE	0xE6792600 +#define DBSC3_0_QOS_W7_BASE	0xE6792700 +#define DBSC3_0_QOS_W8_BASE	0xE6792800 +#define DBSC3_0_QOS_W9_BASE	0xE6792900 +#define DBSC3_0_QOS_W10_BASE	0xE6792A00 +#define DBSC3_0_QOS_W11_BASE	0xE6792B00 +#define DBSC3_0_QOS_W12_BASE	0xE6792C00 +#define DBSC3_0_QOS_W13_BASE	0xE6792D00 +#define DBSC3_0_QOS_W14_BASE	0xE6792E00 +#define DBSC3_0_QOS_W15_BASE	0xE6792F00 + +#define CCI_400_MAXOT_1		0xF0091110 +#define CCI_400_MAXOT_2		0xF0092110 +#define CCI_400_QOSCNTL_1	0xF009110C +#define CCI_400_QOSCNTL_2	0xF009210C + +#define	MXI_BASE		0xFE960000 + +#define SYS_AXI_SYX64TO128_BASE	0xFF800300 +#define SYS_AXI_AVB_BASE	0xFF800340 +#define SYS_AXI_G2D_BASE	0xFF800540 +#define SYS_AXI_IMP0_BASE	0xFF800580 +#define SYS_AXI_IMP1_BASE	0xFF8005C0 +#define SYS_AXI_IMUX0_BASE	0xFF800600 +#define SYS_AXI_IMUX1_BASE	0xFF800640 +#define SYS_AXI_IMUX2_BASE	0xFF800680 +#define SYS_AXI_LBS_BASE	0xFF8006C0 +#define SYS_AXI_MMUDS_BASE	0xFF800700 +#define SYS_AXI_MMUM_BASE	0xFF800740 +#define SYS_AXI_MMUR_BASE	0xFF800780 +#define SYS_AXI_MMUS0_BASE	0xFF8007C0 +#define SYS_AXI_MMUS1_BASE	0xFF800800 +#define SYS_AXI_MTSB0_BASE	0xFF800880 +#define SYS_AXI_MTSB1_BASE	0xFF8008C0 +#define SYS_AXI_PCI_BASE	0xFF800900 +#define SYS_AXI_RTX_BASE	0xFF800940 +#define SYS_AXI_SDS0_BASE	0xFF800A80 +#define SYS_AXI_SDS1_BASE	0xFF800AC0 +#define SYS_AXI_USB20_BASE	0xFF800C00 +#define SYS_AXI_USB21_BASE	0xFF800C40 +#define SYS_AXI_USB22_BASE	0xFF800C80 +#define SYS_AXI_USB30_BASE	0xFF800CC0 + +#define RT_AXI_SHX_BASE		0xFF810100 +#define RT_AXI_RDS_BASE		0xFF8101C0 +#define RT_AXI_RTX64TO128_BASE	0xFF810200 +#define RT_AXI_STPRO_BASE	0xFF810240 + +#define MP_AXI_ADSP_BASE	0xFF820100 +#define MP_AXI_ASDS0_BASE	0xFF8201C0 +#define MP_AXI_ASDS1_BASE	0xFF820200 +#define MP_AXI_MLP_BASE		0xFF820240 +#define MP_AXI_MMUMP_BASE	0xFF820280 +#define MP_AXI_SPU_BASE		0xFF8202C0 +#define MP_AXI_SPUC_BASE	0xFF820300 + +#define SYS_AXI256_AXI128TO256_BASE	0xFF860100 +#define SYS_AXI256_SYX_BASE	0xFF860140 +#define SYS_AXI256_MPX_BASE	0xFF860180 +#define SYS_AXI256_MXI_BASE	0xFF8601C0 + +#define CCI_AXI_MMUS0_BASE	0xFF880100 +#define CCI_AXI_SYX2_BASE	0xFF880140 +#define CCI_AXI_MMUR_BASE	0xFF880180 +#define CCI_AXI_MMUDS_BASE	0xFF8801C0 +#define CCI_AXI_MMUM_BASE	0xFF880200 +#define CCI_AXI_MXI_BASE	0xFF880240 +#define CCI_AXI_MMUS1_BASE	0xFF880280 +#define CCI_AXI_MMUMP_BASE	0xFF8802C0 + +#define MEDIA_AXI_JPR_BASE	0xFE964100 +#define MEDIA_AXI_JPW_BASE	0xFE966100 +#define MEDIA_AXI_GCU0R_BASE	0xFE964140 +#define MEDIA_AXI_GCU0W_BASE	0xFE966140 +#define MEDIA_AXI_GCU1R_BASE	0xFE964180 +#define MEDIA_AXI_GCU1W_BASE	0xFE966180 +#define MEDIA_AXI_TDMR_BASE	0xFE964500 +#define MEDIA_AXI_TDMW_BASE	0xFE966500 +#define MEDIA_AXI_VSP0CR_BASE	0xFE964540 +#define MEDIA_AXI_VSP0CW_BASE	0xFE966540 +#define MEDIA_AXI_VSP1CR_BASE	0xFE964580 +#define MEDIA_AXI_VSP1CW_BASE	0xFE966580 +#define MEDIA_AXI_VSPDU0CR_BASE	0xFE9645C0 +#define MEDIA_AXI_VSPDU0CW_BASE	0xFE9665C0 +#define MEDIA_AXI_VSPDU1CR_BASE	0xFE964600 +#define MEDIA_AXI_VSPDU1CW_BASE	0xFE966600 +#define MEDIA_AXI_VIN0W_BASE	0xFE966900 +#define MEDIA_AXI_VSP0R_BASE	0xFE964D00 +#define MEDIA_AXI_VSP0W_BASE	0xFE966D00 +#define MEDIA_AXI_FDP0R_BASE	0xFE964D40 +#define MEDIA_AXI_FDP0W_BASE	0xFE966D40 +#define MEDIA_AXI_IMSR_BASE	0xFE964D80 +#define MEDIA_AXI_IMSW_BASE	0xFE966D80 +#define MEDIA_AXI_VSP1R_BASE	0xFE965100 +#define MEDIA_AXI_VSP1W_BASE	0xFE967100 +#define MEDIA_AXI_FDP1R_BASE	0xFE965140 +#define MEDIA_AXI_FDP1W_BASE	0xFE967140 +#define MEDIA_AXI_IMRR_BASE	0xFE965180 +#define MEDIA_AXI_IMRW_BASE	0xFE967180 +#define MEDIA_AXI_FDP2R_BASE	0xFE9651C0 +#define MEDIA_AXI_FDP2W_BASE	0xFE966DC0 +#define MEDIA_AXI_VSPD0R_BASE	0xFE965500 +#define MEDIA_AXI_VSPD0W_BASE	0xFE967500 +#define MEDIA_AXI_VSPD1R_BASE	0xFE965540 +#define MEDIA_AXI_VSPD1W_BASE	0xFE967540 +#define MEDIA_AXI_DU0R_BASE	0xFE965580 +#define MEDIA_AXI_DU0W_BASE	0xFE967580 +#define MEDIA_AXI_DU1R_BASE	0xFE9655C0 +#define MEDIA_AXI_DU1W_BASE	0xFE9675C0 +#define MEDIA_AXI_VCP0CR_BASE	0xFE965900 +#define MEDIA_AXI_VCP0CW_BASE	0xFE967900 +#define MEDIA_AXI_VCP0VR_BASE	0xFE965940 +#define MEDIA_AXI_VCP0VW_BASE	0xFE967940 +#define MEDIA_AXI_VPC0R_BASE	0xFE965980 +#define MEDIA_AXI_VCP1CR_BASE	0xFE965D00 +#define MEDIA_AXI_VCP1CW_BASE	0xFE967D00 +#define MEDIA_AXI_VCP1VR_BASE	0xFE965D40 +#define MEDIA_AXI_VCP1VW_BASE	0xFE967D40 +#define MEDIA_AXI_VPC1R_BASE	0xFE965D80 + +#define SYS_AXI_AVBDMSCR	0xFF802000 +#define SYS_AXI_SYX2DMSCR	0xFF802004 +#define SYS_AXI_CC50DMSCR	0xFF802008 +#define SYS_AXI_CC51DMSCR	0xFF80200C +#define SYS_AXI_CCIDMSCR	0xFF802010 +#define SYS_AXI_CSDMSCR		0xFF802014 +#define SYS_AXI_DDMDMSCR	0xFF802018 +#define SYS_AXI_ETHDMSCR	0xFF80201C +#define SYS_AXI_G2DDMSCR	0xFF802020 +#define SYS_AXI_IMP0DMSCR	0xFF802024 +#define SYS_AXI_IMP1DMSCR	0xFF802028 +#define SYS_AXI_LBSDMSCR	0xFF80202C +#define SYS_AXI_MMUDSDMSCR	0xFF802030 +#define SYS_AXI_MMUMXDMSCR	0xFF802034 +#define SYS_AXI_MMURDDMSCR	0xFF802038 +#define SYS_AXI_MMUS0DMSCR	0xFF80203C +#define SYS_AXI_MMUS1DMSCR	0xFF802040 +#define SYS_AXI_MPXDMSCR	0xFF802044 +#define SYS_AXI_MTSB0DMSCR	0xFF802048 +#define SYS_AXI_MTSB1DMSCR	0xFF80204C +#define SYS_AXI_PCIDMSCR	0xFF802050 +#define SYS_AXI_RTXDMSCR	0xFF802054 +#define SYS_AXI_SAT0DMSCR	0xFF802058 +#define SYS_AXI_SAT1DMSCR	0xFF80205C +#define SYS_AXI_SDM0DMSCR	0xFF802060 +#define SYS_AXI_SDM1DMSCR	0xFF802064 +#define SYS_AXI_SDS0DMSCR	0xFF802068 +#define SYS_AXI_SDS1DMSCR	0xFF80206C +#define SYS_AXI_ETRABDMSCR	0xFF802070 +#define SYS_AXI_ETRKFDMSCR	0xFF802074 +#define SYS_AXI_UDM0DMSCR	0xFF802078 +#define SYS_AXI_UDM1DMSCR	0xFF80207C +#define SYS_AXI_USB20DMSCR	0xFF802080 +#define SYS_AXI_USB21DMSCR	0xFF802084 +#define SYS_AXI_USB22DMSCR	0xFF802088 +#define SYS_AXI_USB30DMSCR	0xFF80208C +#define SYS_AXI_X128TO64SLVDMSCR	0xFF802100 +#define SYS_AXI_X64TO128SLVDMSCR	0xFF802104 +#define SYS_AXI_AVBSLVDMSCR	0xFF802108 +#define SYS_AXI_SYX2SLVDMSCR	0xFF80210C +#define SYS_AXI_ETHSLVDMSCR	0xFF802110 +#define SYS_AXI_GICSLVDMSCR	0xFF802114 +#define SYS_AXI_IMPSLVDMSCR	0xFF802118 +#define SYS_AXI_IMX0SLVDMSCR	0xFF80211C +#define SYS_AXI_IMX1SLVDMSCR	0xFF802120 +#define SYS_AXI_IMX2SLVDMSCR	0xFF802124 +#define SYS_AXI_LBSSLVDMSCR	0xFF802128 +#define SYS_AXI_MMC0SLVDMSCR	0xFF80212C +#define SYS_AXI_MMC1SLVDMSCR	0xFF802130 +#define SYS_AXI_MPXSLVDMSCR	0xFF802134 +#define SYS_AXI_MTSB0SLVDMSCR	0xFF802138 +#define SYS_AXI_MTSB1SLVDMSCR	0xFF80213C +#define SYS_AXI_MXTSLVDMSCR	0xFF802140 +#define SYS_AXI_PCISLVDMSCR	0xFF802144 +#define SYS_AXI_SYAPBSLVDMSCR	0xFF802148 +#define SYS_AXI_QSAPBSLVDMSCR	0xFF80214C +#define SYS_AXI_RTXSLVDMSCR	0xFF802150 +#define SYS_AXI_SAT0SLVDMSCR	0xFF802168 +#define SYS_AXI_SAT1SLVDMSCR	0xFF80216C +#define SYS_AXI_SDAP0SLVDMSCR	0xFF802170 +#define SYS_AXI_SDAP1SLVDMSCR	0xFF802174 +#define SYS_AXI_SDAP2SLVDMSCR	0xFF802178 +#define SYS_AXI_SDAP3SLVDMSCR	0xFF80217C +#define SYS_AXI_SGXSLVDMSCR	0xFF802180 +#define SYS_AXI_STBSLVDMSCR	0xFF802188 +#define SYS_AXI_STMSLVDMSCR	0xFF80218C +#define SYS_AXI_TSPL0SLVDMSCR	0xFF802194 +#define SYS_AXI_TSPL1SLVDMSCR	0xFF802198 +#define SYS_AXI_TSPL2SLVDMSCR	0xFF80219C +#define SYS_AXI_USB20SLVDMSCR	0xFF8021A0 +#define SYS_AXI_USB21SLVDMSCR	0xFF8021A4 +#define SYS_AXI_USB22SLVDMSCR	0xFF8021A8 +#define SYS_AXI_USB30SLVDMSCR	0xFF8021AC + +#define RT_AXI_CBMDMSCR		0xFF812000 +#define RT_AXI_DBDMSCR		0xFF812004 +#define RT_AXI_RDMDMSCR		0xFF812008 +#define RT_AXI_RDSDMSCR		0xFF81200C +#define RT_AXI_STRDMSCR		0xFF812010 +#define RT_AXI_SY2RTDMSCR	0xFF812014 +#define RT_AXI_CBSSLVDMSCR	0xFF812100 +#define RT_AXI_DBSSLVDMSCR	0xFF812104 +#define RT_AXI_RTAP1SLVDMSCR	0xFF812108 +#define RT_AXI_RTAP2SLVDMSCR	0xFF81210C +#define RT_AXI_RTAP3SLVDMSCR	0xFF812110 +#define RT_AXI_RT2SYSLVDMSCR	0xFF812114 +#define RT_AXI_A128TO64SLVDMSCR	0xFF812118 +#define RT_AXI_A64TO128SLVDMSCR	0xFF81211C +#define RT_AXI_A64TO128CSLVDMSCR	0xFF812120 +#define RT_AXI_UTLBRSLVDMSCR	0xFF812128 + +#define MP_AXI_ADSPDMSCR	0xFF822000 +#define MP_AXI_ASDM0DMSCR	0xFF822004 +#define MP_AXI_ASDM1DMSCR	0xFF822008 +#define MP_AXI_ASDS0DMSCR	0xFF82200C +#define MP_AXI_ASDS1DMSCR	0xFF822010 +#define MP_AXI_MLPDMSCR		0xFF822014 +#define MP_AXI_MMUMPDMSCR	0xFF822018 +#define MP_AXI_SPUDMSCR		0xFF82201C +#define MP_AXI_SPUCDMSCR	0xFF822020 +#define MP_AXI_SY2MPDMSCR	0xFF822024 +#define MP_AXI_ADSPSLVDMSCR	0xFF822100 +#define MP_AXI_MLMSLVDMSCR	0xFF822104 +#define MP_AXI_MPAP4SLVDMSCR	0xFF822108 +#define MP_AXI_MPAP5SLVDMSCR	0xFF82210C +#define MP_AXI_MPAP6SLVDMSCR	0xFF822110 +#define MP_AXI_MPAP7SLVDMSCR	0xFF822114 +#define MP_AXI_MP2SYSLVDMSCR	0xFF822118 +#define MP_AXI_MP2SY2SLVDMSCR	0xFF82211C +#define MP_AXI_MPXAPSLVDMSCR	0xFF822124 +#define MP_AXI_SPUSLVDMSCR	0xFF822128 +#define MP_AXI_UTLBMPSLVDMSCR	0xFF82212C + +#define ADM_AXI_ASDM0DMSCR	0xFF842000 +#define ADM_AXI_ASDM1DMSCR	0xFF842004 +#define ADM_AXI_MPAP1SLVDMSCR	0xFF842104 +#define ADM_AXI_MPAP2SLVDMSCR	0xFF842108 +#define ADM_AXI_MPAP3SLVDMSCR	0xFF84210C + +#define DM_AXI_RDMDMSCR		0xFF852000 +#define DM_AXI_SDM0DMSCR	0xFF852004 +#define DM_AXI_SDM1DMSCR	0xFF852008 +#define DM_AXI_MMAP0SLVDMSCR	0xFF852100 +#define DM_AXI_MMAP1SLVDMSCR	0xFF852104 +#define DM_AXI_QSPAPSLVDMSCR	0xFF852108 +#define DM_AXI_RAP4SLVDMSCR	0xFF85210C +#define DM_AXI_RAP5SLVDMSCR	0xFF852110 +#define DM_AXI_SAP4SLVDMSCR	0xFF852114 +#define DM_AXI_SAP5SLVDMSCR	0xFF852118 +#define DM_AXI_SAP6SLVDMSCR	0xFF85211C +#define DM_AXI_SAP65SLVDMSCR	0xFF852120 +#define DM_AXI_SDAP0SLVDMSCR	0xFF852124 +#define DM_AXI_SDAP1SLVDMSCR	0xFF852128 +#define DM_AXI_SDAP2SLVDMSCR	0xFF85212C +#define DM_AXI_SDAP3SLVDMSCR	0xFF852130 + +#define SYS_AXI256_SYXDMSCR	0xFF862000 +#define SYS_AXI256_MPXDMSCR	0xFF862004 +#define SYS_AXI256_MXIDMSCR	0xFF862008 +#define SYS_AXI256_X128TO256SLVDMSCR	0xFF862100 +#define SYS_AXI256_X256TO128SLVDMSCR	0xFF862104 +#define SYS_AXI256_SYXSLVDMSCR	0xFF862108 +#define SYS_AXI256_CCXSLVDMSCR	0xFF86210C +#define SYS_AXI256_S3CSLVDMSCR	0xFF862110 + +#define MXT_SYXDMSCR		0xFF872000 +#define MXT_CMM0SLVDMSCR	0xFF872100 +#define MXT_CMM1SLVDMSCR	0xFF872104 +#define MXT_CMM2SLVDMSCR	0xFF872108 +#define MXT_FDPSLVDMSCR		0xFF87210C +#define MXT_IMRSLVDMSCR		0xFF872110 +#define MXT_VINSLVDMSCR		0xFF872114 +#define MXT_VPC0SLVDMSCR	0xFF872118 +#define MXT_VPC1SLVDMSCR	0xFF87211C +#define MXT_VSP0SLVDMSCR	0xFF872120 +#define MXT_VSP1SLVDMSCR	0xFF872124 +#define MXT_VSPD0SLVDMSCR	0xFF872128 +#define MXT_VSPD1SLVDMSCR	0xFF87212C +#define MXT_MAP1SLVDMSCR	0xFF872130 +#define MXT_MAP2SLVDMSCR	0xFF872134 + +#define CCI_AXI_MMUS0DMSCR	0xFF882000 +#define CCI_AXI_SYX2DMSCR	0xFF882004 +#define CCI_AXI_MMURDMSCR	0xFF882008 +#define CCI_AXI_MMUDSDMSCR	0xFF88200C +#define CCI_AXI_MMUMDMSCR	0xFF882010 +#define CCI_AXI_MXIDMSCR	0xFF882014 +#define CCI_AXI_MMUS1DMSCR	0xFF882018 +#define CCI_AXI_MMUMPDMSCR	0xFF88201C +#define CCI_AXI_DVMDMSCR	0xFF882020 +#define CCI_AXI_CCISLVDMSCR	0xFF882100 + +#define CCI_AXI_IPMMUIDVMCR	0xFF880400 +#define CCI_AXI_IPMMURDVMCR	0xFF880404 +#define CCI_AXI_IPMMUS0DVMCR	0xFF880408 +#define CCI_AXI_IPMMUS1DVMCR	0xFF88040C +#define CCI_AXI_IPMMUMPDVMCR	0xFF880410 +#define CCI_AXI_IPMMUDSDVMCR	0xFF880414 +#define CCI_AXI_AX2ADDRMASK	0xFF88041C + +#ifndef __ASSEMBLY__ +#include <asm/types.h> + +/* RWDT */ +struct r8a7791_rwdt { +	u32 rwtcnt;	/* 0x00 */ +	u32 rwtcsra;	/* 0x04 */ +	u16 rwtcsrb;	/* 0x08 */ +}; + +/* SWDT */ +struct r8a7791_swdt { +	u32 swtcnt;	/* 0x00 */ +	u32 swtcsra;	/* 0x04 */ +	u16 swtcsrb;	/* 0x08 */ +}; + +/* LBSC */ +struct r8a7791_lbsc { +	u32 cs0ctrl; +	u32 cs1ctrl; +	u32 ecs0ctrl; +	u32 ecs1ctrl; +	u32 ecs2ctrl; +	u32 ecs3ctrl; +	u32 ecs4ctrl; +	u32 ecs5ctrl; +	u32 dummy0[4];	/* 0x20 .. 0x2C */ +	u32 cswcr0; +	u32 cswcr1; +	u32 ecswcr0; +	u32 ecswcr1; +	u32 ecswcr2; +	u32 ecswcr3; +	u32 ecswcr4; +	u32 ecswcr5; +	u32 exdmawcr0; +	u32 exdmawcr1; +	u32 exdmawcr2; +	u32 dummy1[9];	/* 0x5C .. 0x7C */ +	u32 cspwcr0; +	u32 cspwcr1; +	u32 ecspwcr0; +	u32 ecspwcr1; +	u32 ecspwcr2; +	u32 ecspwcr3; +	u32 ecspwcr4; +	u32 ecspwcr5; +	u32 exwtsync; +	u32 dummy2[3];	/* 0xA4 .. 0xAC */ +	u32 cs0bstctl; +	u32 cs0btph; +	u32 dummy3[2];	/* 0xB8 .. 0xBC */ +	u32 cs1gdst; +	u32 ecs0gdst; +	u32 ecs1gdst; +	u32 ecs2gdst; +	u32 ecs3gdst; +	u32 ecs4gdst; +	u32 ecs5gdst; +	u32 dummy4[5];	/* 0xDC .. 0xEC */ +	u32 exdmaset0; +	u32 exdmaset1; +	u32 exdmaset2; +	u32 dummy5[5];	/* 0xFC .. 0x10C */ +	u32 exdmcr0; +	u32 exdmcr1; +	u32 exdmcr2; +	u32 dummy6[5];	/* 0x11C .. 0x12C */ +	u32 bcintsr; +	u32 bcintcr; +	u32 bcintmr; +	u32 dummy7;	/* 0x13C */ +	u32 exbatlv; +	u32 exwtsts; +	u32 dummy8[14];	/* 0x148 .. 0x17C */ +	u32 atacsctrl; +	u32 dummy9[15]; /* 0x184 .. 0x1BC */ +	u32 exbct; +	u32 extct; +}; + +/* DBSC3 */ +struct r8a7791_dbsc3 { +	u32 dummy0[3];	/* 0x00 .. 0x08 */ +	u32 dbstate1; +	u32 dbacen; +	u32 dbrfen; +	u32 dbcmd; +	u32 dbwait; +	u32 dbkind; +	u32 dbconf0; +	u32 dummy1[2];	/* 0x28 .. 0x2C */ +	u32 dbphytype; +	u32 dummy2[3];	/* 0x34 .. 0x3C */ +	u32 dbtr0; +	u32 dbtr1; +	u32 dbtr2; +	u32 dummy3;	/* 0x4C */ +	u32 dbtr3; +	u32 dbtr4; +	u32 dbtr5; +	u32 dbtr6; +	u32 dbtr7; +	u32 dbtr8; +	u32 dbtr9; +	u32 dbtr10; +	u32 dbtr11; +	u32 dbtr12; +	u32 dbtr13; +	u32 dbtr14; +	u32 dbtr15; +	u32 dbtr16; +	u32 dbtr17; +	u32 dbtr18; +	u32 dbtr19; +	u32 dummy4[7];	/* 0x94 .. 0xAC */ +	u32 dbbl; +	u32 dummy5[3];	/* 0xB4 .. 0xBC */ +	u32 dbadj0; +	u32 dummy6;	/* 0xC4 */ +	u32 dbadj2; +	u32 dummy7[5];	/* 0xCC .. 0xDC */ +	u32 dbrfcnf0; +	u32 dbrfcnf1; +	u32 dbrfcnf2; +	u32 dummy8[2];	/* 0xEC .. 0xF0 */ +	u32 dbcalcnf; +	u32 dbcaltr; +	u32 dummy9;	/* 0xFC */ +	u32 dbrnk0; +	u32 dummy10[31];	/* 0x104 .. 0x17C */ +	u32 dbpdncnf; +	u32 dummy11[47];	/* 0x184 ..0x23C */ +	u32 dbdfistat; +	u32 dbdficnt; +	u32 dummy12[14];	/* 0x248 .. 0x27C */ +	u32 dbpdlck; +	u32 dummy13[3];	/* 0x284 .. 0x28C */ +	u32 dbpdrga; +	u32 dummy14[3];	/* 0x294 .. 0x29C */ +	u32 dbpdrgd; +	u32 dummy15[24];	/* 0x2A4 .. 0x300 */ +	u32 dbbs0cnt1; +	u32 dummy16[30];	/* 0x308 .. 0x37C */ +	u32 dbwt0cnf0; +	u32 dbwt0cnf1; +	u32 dbwt0cnf2; +	u32 dbwt0cnf3; +	u32 dbwt0cnf4; +}; + +/* GPIO */ +struct r8a7791_gpio { +	u32 iointsel; +	u32 inoutsel; +	u32 outdt; +	u32 indt; +	u32 intdt; +	u32 intclr; +	u32 intmsk; +	u32 posneg; +	u32 edglevel; +	u32 filonoff; +	u32 intmsks; +	u32 mskclrs; +	u32 outdtsel; +	u32 outdth; +	u32 outdtl; +	u32 bothedge; +}; + +/* S3C(QoS) */ +struct r8a7791_s3c { +	u32 s3cexcladdmsk; +	u32 s3cexclidmsk; +	u32 s3cadsplcr; +	u32 s3cmaar; +	u32 dummy0;	/* 0x10 */ +	u32 s3crorr; +	u32 s3cworr; +	u32 s3carcr22; +	u32 dummy1[2];	/* 0x20 .. 0x24 */ +	u32 s3cmctr; +	u32 dummy2;	/* 0x2C */ +	u32 cconf0; +	u32 cconf1; +	u32 cconf2; +	u32 cconf3; +}; + +struct r8a7791_s3c_qos { +	u32 s3cqos0; +	u32 s3cqos1; +	u32 s3cqos2; +	u32 s3cqos3; +	u32 s3cqos4; +	u32 s3cqos5; +	u32 s3cqos6; +	u32 s3cqos7; +	u32 s3cqos8; +}; + +/* DBSC(QoS) */ +struct r8a7791_dbsc3_qos { +	u32 dblgcnt; +	u32 dbtmval0; +	u32 dbtmval1; +	u32 dbtmval2; +	u32 dbtmval3; +	u32 dbrqctr; +	u32 dbthres0; +	u32 dbthres1; +	u32 dbthres2; +	u32 dblgqon; +}; + +/* MXI(QoS) */ +struct r8a7791_mxi { +	u32 dummy0[10];	/* 0x00 .. 0x24 */ +	u32 mxs3cracr; +	u32 dummy1[5];	/* 0x2C .. 0x3C */ +	u32 mxrtcr; +	u32 mxwtcr; +}; + +/* AXI(QoS) */ +struct r8a7791_axi_qos { +	u32 qosconf; +	u32 qosctset0; +	u32 qosctset1; +	u32 qosctset2; +	u32 qosctset3; +	u32 qosreqctr; +	u32 qosthres0; +	u32 qosthres1; +	u32 qosthres2; +	u32 qosqon; +}; + +#endif + +#endif /* __ASM_ARCH_R8A7791_H */ diff --git a/arch/arm/include/asm/arch-rmobile/rmobile.h b/arch/arm/include/asm/arch-rmobile/rmobile.h index ab39f6716..238256502 100644 --- a/arch/arm/include/asm/arch-rmobile/rmobile.h +++ b/arch/arm/include/asm/arch-rmobile/rmobile.h @@ -8,6 +8,8 @@  #include <asm/arch/r8a7740.h>  #elif defined(CONFIG_R8A7790)  #include <asm/arch/r8a7790.h> +#elif defined(CONFIG_R8A7791) +#include <asm/arch/r8a7791.h>  #else  #error "SOC Name not defined"  #endif |