summaryrefslogtreecommitdiff
path: root/arch/arm/mach-tegra
diff options
context:
space:
mode:
authorMarcel Ziswiler <marcel.ziswiler@toradex.com>2012-12-17 09:00:24 +0100
committerMarcel Ziswiler <marcel.ziswiler@toradex.com>2012-12-17 09:00:24 +0100
commit94315e07e7b250c7546664e3845cd1d907d844c9 (patch)
treeda5fb4264c2cf3bb289621006a0640fd6f3d14bd /arch/arm/mach-tegra
parentde68848ba2ffd3ab88f9407be94a0374f87d7086 (diff)
colibri_t20: pin-mux: re-work function tri-stating
Use GPIO inputs for function tri-stating rather than pin group tri-stating to avoid influencing neighbouring pins. While at it get rid of most pull-up/downs and a lot of commented out stuff.
Diffstat (limited to 'arch/arm/mach-tegra')
-rw-r--r--arch/arm/mach-tegra/board-colibri_t20-pinmux.c192
-rw-r--r--arch/arm/mach-tegra/board-colibri_t20.c21
2 files changed, 144 insertions, 69 deletions
diff --git a/arch/arm/mach-tegra/board-colibri_t20-pinmux.c b/arch/arm/mach-tegra/board-colibri_t20-pinmux.c
index 6e2306b9328c..9a3b490bc63b 100644
--- a/arch/arm/mach-tegra/board-colibri_t20-pinmux.c
+++ b/arch/arm/mach-tegra/board-colibri_t20-pinmux.c
@@ -58,10 +58,68 @@ static __initdata struct tegra_drive_pingroup_config colibri_t20_drive_pinmux[]
SET_DRIVE(VI2, DISABLE, ENABLE, DIV_1, 31, 31, FASTEST, FASTEST),
};
+static __initdata int colibri_t20_gpio_input_pinmux[] = {
+ /* SODIMM pin 152 tri-stating GMI_CLK as OWR can not be tri-stated */
+//currently reserved during board platform GPIO handling
+// TEGRA_GPIO_PK1, /* GMI_CLK multiplexed OWR */
+
+ /* Camera interface aka video input */
+#ifdef COLIBRI_T20_VI
+ TEGRA_GPIO_PA7, /* SDIO3_CMD multiplexed VI_D6 */
+ TEGRA_GPIO_PB4, /* SDIO3_DAT3 multiplexed VI_D7 */
+#else /* COLIBRI_T20_VI */
+ TEGRA_GPIO_PL4, /* VI_D6 multiplexed SDIO3_CMD */
+ TEGRA_GPIO_PL5, /* VI_D7 multiplexed SDIO3_DAT3 */
+#endif /* COLIBRI_T20_VI */
+
+ /* SODIMM pin 93 RDnWR */
+#if 1
+ TEGRA_GPIO_PW0, /* gated GMI_WR_N multiplexed LCD_CS1_N */
+#endif
+
+ /* SODIMM pin 44 L_BIAS configured as LCD data enable */
+#if 0
+ TEGRA_GPIO_PJ1, /* LCD_M1 multiplexed LCD_DE */
+#else
+ TEGRA_GPIO_PW1, /* LCD_DE multiplexed LCD_M1 */
+#endif
+
+ /* SODIMM pin 95 RDY */
+#if 1
+ TEGRA_GPIO_PI7, /* GMI_IORDY multiplexed GMI_WAIT */
+#else
+ TEGRA_GPIO_PI5, /* GMI_WAIT multiplexed GMI_IORDY */
+#endif
+
+ /* SODIMM pin 99 nPWE */
+#if 0
+ TEGRA_GPIO_PZ3, /* gated GMI_WR_N multiplexed LCD_WR_N */
+#endif
+
+ /* 24-bit LCD lines */
+#if 0
+ TEGRA_GPIO_PM2, /* SPI2_CS0_N multiplexed LCD_D18 */
+ TEGRA_GPIO_PM3, /* SPI2_SCK multiplexed LCD_D19 */
+ TEGRA_GPIO_PM4, /* SPI2_MISO multiplexed LCD_D20 */
+ TEGRA_GPIO_PM5, /* SPI2_MOSI multiplexed LCD_D21 */
+ TEGRA_GPIO_PM6, /* DAP2_DOUT multiplexed LCD_D22 */
+ TEGRA_GPIO_PM7, /* DAP2_DIN multiplexed LCD_D23 */
+#else
+ TEGRA_GPIO_PX3, /* LCD_D18 multiplexed SPI2_CS0_N */
+ TEGRA_GPIO_PX2, /* LCD_D19 multiplexed SPI2_SCK */
+ TEGRA_GPIO_PX1, /* LCD_D20 multiplexed SPI2_MISO */
+ TEGRA_GPIO_PX0, /* LCD_D21 multiplexed SPI2_MOSI */
+ TEGRA_GPIO_PA5, /* LCD_D22 multiplexed DAP2_DOUT */
+ TEGRA_GPIO_PA4, /* LCD_D23 multiplexed DAP2_DIN */
+#endif
+};
+
static __initdata struct tegra_pingroup_config colibri_t20_pinmux[] = {
-/* tegra_pingroup tegra_mux_func tegra_pullupdown tegra_tristate */
- /* nRESET_OUT, GPIO I3, I4 and I6 */
- {TEGRA_PINGROUP_ATA, TEGRA_MUX_GMI, TEGRA_PUPD_PULL_UP, TEGRA_TRI_NORMAL},
+/* tegra_pingroup tegra_mux_func tegra_pullupdown tegra_tristate
+ TRISTATE here means output driver is tri-stated, even configuring GPIO function won't override this.
+ Tristating would significantly reduce I/O power consumption. */
+ /* nRESET_OUT de-asserted further down below, GPIO I3, I4 and I6 */
+ {TEGRA_PINGROUP_ATA, TEGRA_MUX_GMI, TEGRA_PUPD_NORMAL, TEGRA_TRI_NORMAL},
{TEGRA_PINGROUP_ATB, TEGRA_MUX_SDIO4, TEGRA_PUPD_NORMAL, TEGRA_TRI_NORMAL},
/* nCSx, AD0, AD1, AD2, AD3, AD4, AD5, AD6 and AD7, nWR, nOE, GPIO K0, K1, K2, K3 and K4 */
{TEGRA_PINGROUP_ATC, TEGRA_MUX_GMI, TEGRA_PUPD_NORMAL, TEGRA_TRI_NORMAL},
@@ -76,9 +134,10 @@ static __initdata struct tegra_pingroup_config colibri_t20_pinmux[] = {
{TEGRA_PINGROUP_CDEV1, TEGRA_MUX_PLLA_OUT, TEGRA_PUPD_NORMAL, TEGRA_TRI_NORMAL},
/* USB3340 REFCLK */
{TEGRA_PINGROUP_CDEV2, TEGRA_MUX_PLLP_OUT4, TEGRA_PUPD_NORMAL, TEGRA_TRI_NORMAL},
+ /* CLK_32K_IN pin pull-up/down control only */
{TEGRA_PINGROUP_CK32, TEGRA_MUX_NONE, TEGRA_PUPD_NORMAL, TEGRA_TRI_NORMAL},
{TEGRA_PINGROUP_CRTP, TEGRA_MUX_CRT, TEGRA_PUPD_NORMAL, TEGRA_TRI_NORMAL},
- {TEGRA_PINGROUP_CSUS, TEGRA_MUX_VI_SENSOR_CLK,TEGRA_PUPD_PULL_DOWN, TEGRA_TRI_NORMAL},
+ {TEGRA_PINGROUP_CSUS, TEGRA_MUX_VI_SENSOR_CLK,TEGRA_PUPD_NORMAL, TEGRA_TRI_NORMAL},
/* GPIO N0, N1, N2, N3 and USBC_DET */
{TEGRA_PINGROUP_DAP1, TEGRA_MUX_RSVD, TEGRA_PUPD_NORMAL, TEGRA_TRI_NORMAL},
/* GPIO A2 and A3 */
@@ -86,19 +145,20 @@ static __initdata struct tegra_pingroup_config colibri_t20_pinmux[] = {
{TEGRA_PINGROUP_DAP3, TEGRA_MUX_DAP3, TEGRA_PUPD_NORMAL, TEGRA_TRI_NORMAL},
/* A13, A14, A15 and A16, GPIO P4, P5, P6 and P7 */
{TEGRA_PINGROUP_DAP4, TEGRA_MUX_GMI, TEGRA_PUPD_NORMAL, TEGRA_TRI_NORMAL},
+ /* DDC pins pulled up to avoid issues if no FFC cable is connected to X3 */
{TEGRA_PINGROUP_DDC, TEGRA_MUX_I2C2, TEGRA_PUPD_PULL_UP, TEGRA_TRI_NORMAL},
+ /* Pull-up/down control only */
{TEGRA_PINGROUP_DDRC, TEGRA_MUX_NONE, TEGRA_PUPD_NORMAL, TEGRA_TRI_NORMAL},
/* GPIO D5 */
- {TEGRA_PINGROUP_DTA, TEGRA_MUX_VI, TEGRA_PUPD_PULL_DOWN, TEGRA_TRI_NORMAL},
+ {TEGRA_PINGROUP_DTA, TEGRA_MUX_VI, TEGRA_PUPD_NORMAL, TEGRA_TRI_NORMAL},
/* GPIO T2 and T3 */
- {TEGRA_PINGROUP_DTB, TEGRA_MUX_VI, TEGRA_PUPD_PULL_DOWN, TEGRA_TRI_NORMAL},
- {TEGRA_PINGROUP_DTC, TEGRA_MUX_VI, TEGRA_PUPD_PULL_DOWN, TEGRA_TRI_NORMAL},
+ {TEGRA_PINGROUP_DTB, TEGRA_MUX_VI, TEGRA_PUPD_NORMAL, TEGRA_TRI_NORMAL},
+ {TEGRA_PINGROUP_DTC, TEGRA_MUX_VI, TEGRA_PUPD_NORMAL, TEGRA_TRI_NORMAL},
/* GPIO L0, L1, L2, L3, L6 and L7
GPIO L4 and L5 multiplexed with PWM<A> and PWM<D> */
- {TEGRA_PINGROUP_DTD, TEGRA_MUX_VI, TEGRA_PUPD_PULL_DOWN, TEGRA_TRI_NORMAL},
- /* AX88772B V_BUS, WM9715L PENDOWN, GPIO A0 and BB4 */
-// {TEGRA_PINGROUP_DTE, TEGRA_MUX_RSVD, TEGRA_PUPD_NORMAL, TEGRA_TRI_NORMAL},
- {TEGRA_PINGROUP_DTE, TEGRA_MUX_VI, TEGRA_PUPD_NORMAL, TEGRA_TRI_NORMAL},
+ {TEGRA_PINGROUP_DTD, TEGRA_MUX_VI, TEGRA_PUPD_NORMAL, TEGRA_TRI_NORMAL},
+ /* AX88772B V_BUS, WM9715L PENDOWN, GPIO A0, BB4 and BB5 */
+ {TEGRA_PINGROUP_DTE, TEGRA_MUX_RSVD, TEGRA_PUPD_NORMAL, TEGRA_TRI_NORMAL},
/* GPIO BB2 and BB3 */
{TEGRA_PINGROUP_DTF, TEGRA_MUX_I2C3, TEGRA_PUPD_NORMAL, TEGRA_TRI_NORMAL},
{TEGRA_PINGROUP_GMA, TEGRA_MUX_SDIO4, TEGRA_PUPD_NORMAL, TEGRA_TRI_NORMAL},
@@ -106,7 +166,7 @@ static __initdata struct tegra_pingroup_config colibri_t20_pinmux[] = {
{TEGRA_PINGROUP_GMB, TEGRA_MUX_GMI_INT, TEGRA_PUPD_NORMAL, TEGRA_TRI_NORMAL},
/* BT_TXD, BT_RXD, BT_CTS and BT_RTS, GPIO K7 */
{TEGRA_PINGROUP_GMC, TEGRA_MUX_UARTD, TEGRA_PUPD_NORMAL, TEGRA_TRI_NORMAL},
- {TEGRA_PINGROUP_GMD, TEGRA_MUX_RSVD, TEGRA_PUPD_PULL_UP, TEGRA_TRI_NORMAL},
+ {TEGRA_PINGROUP_GMD, TEGRA_MUX_RSVD, TEGRA_PUPD_NORMAL, TEGRA_TRI_NORMAL},
/* GPIO AA4, AA5, AA6 and AA7 */
#ifndef SDHCI_8BIT
{TEGRA_PINGROUP_GME, TEGRA_MUX_RSVD, TEGRA_PUPD_NORMAL, TEGRA_TRI_NORMAL},
@@ -115,7 +175,7 @@ static __initdata struct tegra_pingroup_config colibri_t20_pinmux[] = {
#endif
/* A6, A7, A8, A9, A10, A11 and A12, GPIO U6 */
{TEGRA_PINGROUP_GPU, TEGRA_MUX_GMI, TEGRA_PUPD_NORMAL, TEGRA_TRI_NORMAL},
- {TEGRA_PINGROUP_GPU7, TEGRA_MUX_RSVD, TEGRA_PUPD_NORMAL, TEGRA_TRI_TRISTATE},
+ {TEGRA_PINGROUP_GPU7, TEGRA_MUX_RTCK, TEGRA_PUPD_NORMAL, TEGRA_TRI_NORMAL},
/* AX88772B RESET_N and EXTWAKEUP_N */
{TEGRA_PINGROUP_GPV, TEGRA_MUX_RSVD, TEGRA_PUPD_NORMAL, TEGRA_TRI_NORMAL},
/* HDMI HOTPLUG_DETECT */
@@ -153,68 +213,61 @@ static __initdata struct tegra_pingroup_config colibri_t20_pinmux[] = {
{TEGRA_PINGROUP_LD9, TEGRA_MUX_DISPLAYA, TEGRA_PUPD_NORMAL, TEGRA_TRI_NORMAL},
/* GPIO N6 */
{TEGRA_PINGROUP_LDC, TEGRA_MUX_RSVD, TEGRA_PUPD_NORMAL, TEGRA_TRI_NORMAL},
- {TEGRA_PINGROUP_LDI, TEGRA_MUX_RSVD, TEGRA_PUPD_NORMAL, TEGRA_TRI_NORMAL},
- {TEGRA_PINGROUP_LHP0, TEGRA_MUX_RSVD, TEGRA_PUPD_NORMAL, TEGRA_TRI_NORMAL},
- {TEGRA_PINGROUP_LHP1, TEGRA_MUX_RSVD, TEGRA_PUPD_NORMAL, TEGRA_TRI_NORMAL},
- {TEGRA_PINGROUP_LHP2, TEGRA_MUX_RSVD, TEGRA_PUPD_NORMAL, TEGRA_TRI_NORMAL},
+ {TEGRA_PINGROUP_LDI, TEGRA_MUX_DISPLAYA, TEGRA_PUPD_NORMAL, TEGRA_TRI_NORMAL},
+ {TEGRA_PINGROUP_LHP0, TEGRA_MUX_DISPLAYA, TEGRA_PUPD_NORMAL, TEGRA_TRI_NORMAL},
+ {TEGRA_PINGROUP_LHP1, TEGRA_MUX_DISPLAYA, TEGRA_PUPD_NORMAL, TEGRA_TRI_NORMAL},
+ {TEGRA_PINGROUP_LHP2, TEGRA_MUX_DISPLAYA, TEGRA_PUPD_NORMAL, TEGRA_TRI_NORMAL},
{TEGRA_PINGROUP_LHS, TEGRA_MUX_DISPLAYA, TEGRA_PUPD_NORMAL, TEGRA_TRI_NORMAL},
/* Multiplexed RDnWR */
- {TEGRA_PINGROUP_LM0, TEGRA_MUX_RSVD, TEGRA_PUPD_NORMAL, TEGRA_TRI_TRISTATE},
- {TEGRA_PINGROUP_LM1, TEGRA_MUX_RSVD, TEGRA_PUPD_NORMAL, TEGRA_TRI_TRISTATE},
- {TEGRA_PINGROUP_LPP, TEGRA_MUX_RSVD, TEGRA_PUPD_NORMAL, TEGRA_TRI_NORMAL},
+ {TEGRA_PINGROUP_LM0, TEGRA_MUX_RSVD, TEGRA_PUPD_NORMAL, TEGRA_TRI_NORMAL},
+ {TEGRA_PINGROUP_LM1, TEGRA_MUX_RSVD, TEGRA_PUPD_NORMAL, TEGRA_TRI_NORMAL},
+ {TEGRA_PINGROUP_LPP, TEGRA_MUX_DISPLAYA, TEGRA_PUPD_NORMAL, TEGRA_TRI_NORMAL},
/* GPIO B2 */
-// {TEGRA_PINGROUP_LPW0, TEGRA_MUX_RSVD, TEGRA_PUPD_NORMAL, TEGRA_TRI_NORMAL},
- {TEGRA_PINGROUP_LPW0, TEGRA_MUX_DISPLAYA, TEGRA_PUPD_NORMAL, TEGRA_TRI_NORMAL},
- {TEGRA_PINGROUP_LPW1, TEGRA_MUX_RSVD, TEGRA_PUPD_NORMAL, TEGRA_TRI_TRISTATE},
-// {TEGRA_PINGROUP_LPW2, TEGRA_MUX_RSVD, TEGRA_PUPD_NORMAL, TEGRA_TRI_TRISTATE},
- {TEGRA_PINGROUP_LPW2, TEGRA_MUX_DISPLAYA, TEGRA_PUPD_NORMAL, TEGRA_TRI_TRISTATE},
+ {TEGRA_PINGROUP_LPW0, TEGRA_MUX_DISPLAYB, TEGRA_PUPD_NORMAL, TEGRA_TRI_NORMAL},
+ {TEGRA_PINGROUP_LPW1, TEGRA_MUX_RSVD, TEGRA_PUPD_NORMAL, TEGRA_TRI_NORMAL},
+ {TEGRA_PINGROUP_LPW2, TEGRA_MUX_DISPLAYB, TEGRA_PUPD_NORMAL, TEGRA_TRI_NORMAL},
{TEGRA_PINGROUP_LSC0, TEGRA_MUX_DISPLAYA, TEGRA_PUPD_NORMAL, TEGRA_TRI_NORMAL},
- /* Multiplexed nPWE */
-// {TEGRA_PINGROUP_LSC1, TEGRA_MUX_RSVD, TEGRA_PUPD_NORMAL, TEGRA_TRI_TRISTATE},
- {TEGRA_PINGROUP_LSC1, TEGRA_MUX_DISPLAYA, TEGRA_PUPD_NORMAL, TEGRA_TRI_TRISTATE},
+ /* Multiplexed gated nPWE */
+ {TEGRA_PINGROUP_LSC1, TEGRA_MUX_DISPLAYB, TEGRA_PUPD_NORMAL, TEGRA_TRI_NORMAL},
/* GPIO Z4 */
-// {TEGRA_PINGROUP_LSCK, TEGRA_MUX_RSVD, TEGRA_PUPD_NORMAL, TEGRA_TRI_NORMAL},
- {TEGRA_PINGROUP_LSCK, TEGRA_MUX_DISPLAYA, TEGRA_PUPD_NORMAL, TEGRA_TRI_NORMAL},
+ {TEGRA_PINGROUP_LSCK, TEGRA_MUX_DISPLAYB, TEGRA_PUPD_NORMAL, TEGRA_TRI_NORMAL},
/* GPIO N5 */
-// {TEGRA_PINGROUP_LSDA, TEGRA_MUX_RSVD, TEGRA_PUPD_NORMAL, TEGRA_TRI_NORMAL},
- {TEGRA_PINGROUP_LSDA, TEGRA_MUX_DISPLAYA, TEGRA_PUPD_NORMAL, TEGRA_TRI_NORMAL},
+ {TEGRA_PINGROUP_LSDA, TEGRA_MUX_DISPLAYB, TEGRA_PUPD_NORMAL, TEGRA_TRI_NORMAL},
/* GPIO Z2 */
{TEGRA_PINGROUP_LSDI, TEGRA_MUX_RSVD, TEGRA_PUPD_NORMAL, TEGRA_TRI_NORMAL},
{TEGRA_PINGROUP_LSPI, TEGRA_MUX_DISPLAYA, TEGRA_PUPD_NORMAL, TEGRA_TRI_NORMAL},
- {TEGRA_PINGROUP_LVP0, TEGRA_MUX_RSVD, TEGRA_PUPD_NORMAL, TEGRA_TRI_TRISTATE},
- {TEGRA_PINGROUP_LVP1, TEGRA_MUX_RSVD, TEGRA_PUPD_NORMAL, TEGRA_TRI_NORMAL},
+ /* THERMD_ALERT */
+ {TEGRA_PINGROUP_LVP0, TEGRA_MUX_RSVD, TEGRA_PUPD_NORMAL, TEGRA_TRI_NORMAL},
+ {TEGRA_PINGROUP_LVP1, TEGRA_MUX_DISPLAYA, TEGRA_PUPD_NORMAL, TEGRA_TRI_NORMAL},
{TEGRA_PINGROUP_LVS, TEGRA_MUX_DISPLAYA, TEGRA_PUPD_NORMAL, TEGRA_TRI_NORMAL},
- {TEGRA_PINGROUP_OWC, TEGRA_MUX_OWR, TEGRA_PUPD_PULL_UP, TEGRA_TRI_NORMAL},
-//Todo: Tri-state for now due to 5K/s spurious interrupts.
-// {TEGRA_PINGROUP_PMC, TEGRA_MUX_PWR_ON, TEGRA_PUPD_NORMAL, TEGRA_TRI_NORMAL},
- {TEGRA_PINGROUP_PMC, TEGRA_MUX_PWR_ON, TEGRA_PUPD_NORMAL, TEGRA_TRI_TRISTATE},
+ /* OWR multiplexed with GMI_CLK */
+ {TEGRA_PINGROUP_OWC, TEGRA_MUX_OWR, TEGRA_PUPD_NORMAL, TEGRA_TRI_NORMAL},
+ {TEGRA_PINGROUP_PMC, TEGRA_MUX_PWR_ON, TEGRA_PUPD_NORMAL, TEGRA_TRI_NORMAL},
+
+ /* Following five are for specific PMC pin pull-up/down control only */
+ /* CLK_32K_OUT */
{TEGRA_PINGROUP_PMCA, TEGRA_MUX_NONE, TEGRA_PUPD_NORMAL, TEGRA_TRI_NORMAL},
+ /* SYS_CLK_REQ */
{TEGRA_PINGROUP_PMCB, TEGRA_MUX_NONE, TEGRA_PUPD_NORMAL, TEGRA_TRI_NORMAL},
+ /* CORE_PWR_REQ */
{TEGRA_PINGROUP_PMCC, TEGRA_MUX_NONE, TEGRA_PUPD_NORMAL, TEGRA_TRI_NORMAL},
+ /* CPU_PWR_REQ */
{TEGRA_PINGROUP_PMCD, TEGRA_MUX_NONE, TEGRA_PUPD_NORMAL, TEGRA_TRI_NORMAL},
-//Todo: What exactly is PMCE? Why would it need pull-up?
-// {TEGRA_PINGROUP_PMCE, TEGRA_MUX_NONE, TEGRA_PUPD_NORMAL, TEGRA_TRI_NORMAL},
+ /* PWR_INT_N pulled up */
{TEGRA_PINGROUP_PMCE, TEGRA_MUX_NONE, TEGRA_PUPD_PULL_UP, TEGRA_TRI_NORMAL},
- /* Not tri-stating RDnWR, nPWE */
- {TEGRA_PINGROUP_PTA, TEGRA_MUX_RSVD, TEGRA_PUPD_PULL_DOWN, TEGRA_TRI_NORMAL},
+
+ /* Gating RDnWR, nPWE through GPIOs further down below */
+ {TEGRA_PINGROUP_PTA, TEGRA_MUX_RSVD, TEGRA_PUPD_NORMAL, TEGRA_TRI_NORMAL},
{TEGRA_PINGROUP_RM, TEGRA_MUX_I2C, TEGRA_PUPD_NORMAL, TEGRA_TRI_NORMAL},
/* PWM3 */
-#ifdef COLIBRI_T20_VI
/* PWM<D> multiplexed with CIF_DD<6> */
- {TEGRA_PINGROUP_SDB, TEGRA_MUX_PWM, TEGRA_PUPD_NORMAL, TEGRA_TRI_TRISTATE},
-#else
{TEGRA_PINGROUP_SDB, TEGRA_MUX_PWM, TEGRA_PUPD_NORMAL, TEGRA_TRI_NORMAL},
-#endif
/* GPIO B6 and B7, PWM0 and PWM1 */
-#ifdef COLIBRI_T20_VI
/* PWM<A> multiplexed with CIF_DD<7> */
- {TEGRA_PINGROUP_SDC, TEGRA_MUX_PWM, TEGRA_PUPD_NORMAL, TEGRA_TRI_TRISTATE},
-#else
{TEGRA_PINGROUP_SDC, TEGRA_MUX_PWM, TEGRA_PUPD_NORMAL, TEGRA_TRI_NORMAL},
-#endif
/* PWM2 */
{TEGRA_PINGROUP_SDD, TEGRA_MUX_PWM, TEGRA_PUPD_NORMAL, TEGRA_TRI_NORMAL},
- {TEGRA_PINGROUP_SDIO1, TEGRA_MUX_UARTA, TEGRA_PUPD_PULL_UP, TEGRA_TRI_NORMAL},
+ {TEGRA_PINGROUP_SDIO1, TEGRA_MUX_UARTA, TEGRA_PUPD_NORMAL, TEGRA_TRI_NORMAL},
/* SPI4 */
{TEGRA_PINGROUP_SLXA, TEGRA_MUX_SPI4, TEGRA_PUPD_NORMAL, TEGRA_TRI_NORMAL},
@@ -225,29 +278,25 @@ static __initdata struct tegra_pingroup_config colibri_t20_pinmux[] = {
/* GPIO K6 multiplexed ACC1_DETECT */
{TEGRA_PINGROUP_SPDI, TEGRA_MUX_RSVD, TEGRA_PUPD_NORMAL, TEGRA_TRI_NORMAL},
/* GPIO K5 multiplexed USB1_VBUS */
- {TEGRA_PINGROUP_SPDO, TEGRA_MUX_RSVD, TEGRA_PUPD_NORMAL, TEGRA_TRI_TRISTATE},
+ {TEGRA_PINGROUP_SPDO, TEGRA_MUX_RSVD, TEGRA_PUPD_NORMAL, TEGRA_TRI_NORMAL},
/* X0, X1, X2, X3, X4, X5, X6 and X7 */
-// {TEGRA_PINGROUP_SPIA, TEGRA_MUX_RSVD, TEGRA_PUPD_NORMAL, TEGRA_TRI_NORMAL},
{TEGRA_PINGROUP_SPIA, TEGRA_MUX_GMI, TEGRA_PUPD_NORMAL, TEGRA_TRI_NORMAL},
-// {TEGRA_PINGROUP_SPIB, TEGRA_MUX_RSVD, TEGRA_PUPD_NORMAL, TEGRA_TRI_NORMAL},
{TEGRA_PINGROUP_SPIB, TEGRA_MUX_GMI, TEGRA_PUPD_NORMAL, TEGRA_TRI_NORMAL},
-// {TEGRA_PINGROUP_SPIC, TEGRA_MUX_RSVD, TEGRA_PUPD_NORMAL, TEGRA_TRI_NORMAL},
{TEGRA_PINGROUP_SPIC, TEGRA_MUX_GMI, TEGRA_PUPD_NORMAL, TEGRA_TRI_NORMAL},
-// {TEGRA_PINGROUP_SPID, TEGRA_MUX_RSVD, TEGRA_PUPD_NORMAL, TEGRA_TRI_NORMAL},
{TEGRA_PINGROUP_SPID, TEGRA_MUX_SPI1, TEGRA_PUPD_NORMAL, TEGRA_TRI_NORMAL},
-// {TEGRA_PINGROUP_SPIE, TEGRA_MUX_RSVD, TEGRA_PUPD_NORMAL, TEGRA_TRI_NORMAL},
{TEGRA_PINGROUP_SPIE, TEGRA_MUX_SPI1, TEGRA_PUPD_NORMAL, TEGRA_TRI_NORMAL},
{TEGRA_PINGROUP_SPIF, TEGRA_MUX_RSVD, TEGRA_PUPD_NORMAL, TEGRA_TRI_NORMAL},
/* USBH_PEN */
-// {TEGRA_PINGROUP_SPIG, TEGRA_MUX_RSVD, TEGRA_PUPD_PULL_UP, TEGRA_TRI_NORMAL},
{TEGRA_PINGROUP_SPIG, TEGRA_MUX_SPI2_ALT, TEGRA_PUPD_NORMAL, TEGRA_TRI_NORMAL},
/* USBH_OC */
-// {TEGRA_PINGROUP_SPIH, TEGRA_MUX_RSVD, TEGRA_PUPD_PULL_UP, TEGRA_TRI_NORMAL},
- {TEGRA_PINGROUP_SPIH, TEGRA_MUX_SPI2_ALT, TEGRA_PUPD_PULL_UP, TEGRA_TRI_NORMAL},
+ {TEGRA_PINGROUP_SPIH, TEGRA_MUX_SPI2_ALT, TEGRA_PUPD_NORMAL, TEGRA_TRI_NORMAL},
+
+ /* ULPI data pins pulled up like on NVIDIA's Ventana reference platform */
{TEGRA_PINGROUP_UAA, TEGRA_MUX_ULPI, TEGRA_PUPD_PULL_UP, TEGRA_TRI_NORMAL},
{TEGRA_PINGROUP_UAB, TEGRA_MUX_ULPI, TEGRA_PUPD_PULL_UP, TEGRA_TRI_NORMAL},
+
/* WM9715L RESET#, USB3340 RESETB, WM9715L GENIRQ and GPIO V3 */
{TEGRA_PINGROUP_UAC, TEGRA_MUX_RSVD, TEGRA_PUPD_NORMAL, TEGRA_TRI_NORMAL},
/* STD_TXD and STD_RXD */
@@ -257,6 +306,8 @@ static __initdata struct tegra_pingroup_config colibri_t20_pinmux[] = {
/* A4 and A5 */
{TEGRA_PINGROUP_UCB, TEGRA_MUX_GMI, TEGRA_PUPD_NORMAL, TEGRA_TRI_NORMAL},
{TEGRA_PINGROUP_UDA, TEGRA_MUX_ULPI, TEGRA_PUPD_NORMAL, TEGRA_TRI_NORMAL},
+
+ /* Following two are for specific DDR pin pull-up/down control only */
{TEGRA_PINGROUP_XM2C, TEGRA_MUX_NONE, TEGRA_PUPD_NORMAL, TEGRA_TRI_NORMAL},
{TEGRA_PINGROUP_XM2D, TEGRA_MUX_NONE, TEGRA_PUPD_NORMAL, TEGRA_TRI_NORMAL},
};
@@ -281,9 +332,30 @@ static __initdata struct tegra_pingroup_config colibri_t20_widebus_pinmux[] = {
int __init colibri_t20_pinmux_init(void)
{
+ int i;
+
tegra_pinmux_config_table(colibri_t20_pinmux, ARRAY_SIZE(colibri_t20_pinmux));
tegra_drive_pinmux_config_table(colibri_t20_drive_pinmux,
ARRAY_SIZE(colibri_t20_drive_pinmux));
+ /* configure GPIO inputs on multiplexed balls to tri-state specific functions
+ instead of tri-stating whole groups */
+ for(i = 0; i < ARRAY_SIZE(colibri_t20_gpio_input_pinmux); i++) {
+ gpio_request(colibri_t20_gpio_input_pinmux[i], "function tri-stated");
+ gpio_direction_input(colibri_t20_gpio_input_pinmux[i]);
+ }
+
+ /* un-resetting external devices via SODIMM pin 87 nRESET_OUT */
+ gpio_request(TEGRA_GPIO_PI4, "SODIMM 87 nRESET_OUT");
+ gpio_direction_output(TEGRA_GPIO_PI4, 1);
+
+ /* tri-stating GMI_WR_N on SODIMM pin 99 nPWE */
+ gpio_request(TEGRA_GPIO_PT6, "no GMI_WR_N on 99");
+ gpio_direction_output(TEGRA_GPIO_PT6, 1);
+
+ /* not tri-stating GMI_WR_N on SODIMM pin 93 RDnWR */
+ gpio_request(TEGRA_GPIO_PT5, "GMI_WR_N on 93 RDnWR");
+ gpio_direction_output(TEGRA_GPIO_PT5, 0);
+
return 0;
}
diff --git a/arch/arm/mach-tegra/board-colibri_t20.c b/arch/arm/mach-tegra/board-colibri_t20.c
index 2077a46dec12..261d11b439af 100644
--- a/arch/arm/mach-tegra/board-colibri_t20.c
+++ b/arch/arm/mach-tegra/board-colibri_t20.c
@@ -171,7 +171,11 @@ static struct gpio colibri_t20_gpios[] = {
#endif
{TEGRA_GPIO_PA2, GPIOF_IN, "SODIMM pin 186"},
{TEGRA_GPIO_PA3, GPIOF_IN, "SODIMM pin 184"},
+//multiplexed VI_D6
+ {TEGRA_GPIO_PA7, GPIOF_IN, "SODIMM pin 67"},
{TEGRA_GPIO_PB2, GPIOF_IN, "SODIMM pin 154"},
+//multiplexed VI_D7
+ {TEGRA_GPIO_PB4, GPIOF_IN, "SODIMM pin 59"},
//conflicts with MECS Tellurium xPOD2 SSPCLK2
{TEGRA_GPIO_PB6, GPIOF_IN, "SODIMM pin 55"},
//conflicts with MECS Tellurium xPOD2 SSPFRM2
@@ -182,7 +186,6 @@ static struct gpio colibri_t20_gpios[] = {
{TEGRA_GPIO_PD7, GPIOF_IN, "SODIMM pin 94"},
#endif
{TEGRA_GPIO_PI3, GPIOF_IN, "SODIMM pin 130"},
- {TEGRA_GPIO_PI4, GPIOF_IN, "SODIMM pin 87"},
{TEGRA_GPIO_PI6, GPIOF_IN, "SODIMM pin 132"},
{TEGRA_GPIO_PK0, GPIOF_IN, "SODIMM pin 150"},
//multiplexed OWR
@@ -199,13 +202,16 @@ static struct gpio colibri_t20_gpios[] = {
//conflicts with Ethernet interrupt on Protea
{TEGRA_GPIO_PL2, GPIOF_IN, "SODI-79, Iris X16-19"},
{TEGRA_GPIO_PL3, GPIOF_IN, "SODI-97, Iris X16-17"},
-//multiplexed PWM<D>
- {TEGRA_GPIO_PL4, GPIOF_IN, "SODIMM pin 67"},
-//multiplexed PWM<A>
- {TEGRA_GPIO_PL5, GPIOF_IN, "SODIMM pin 59"},
{TEGRA_GPIO_PL6, GPIOF_IN, "SODI-85, Iris X16-18"},
{TEGRA_GPIO_PL7, GPIOF_IN, "SODIMM pin 65"},
#endif
+
+//multiplexed SPI2_CS0_N, SPI2_MISO, SPI2_MOSI and SPI2_SCK
+ {TEGRA_GPIO_PM2, GPIOF_IN, "SODIMM pin 136"},
+ {TEGRA_GPIO_PM3, GPIOF_IN, "SODIMM pin 138"},
+ {TEGRA_GPIO_PM4, GPIOF_IN, "SODIMM pin 140"},
+ {TEGRA_GPIO_PM5, GPIOF_IN, "SODIMM pin 142"},
+
{TEGRA_GPIO_PN0, GPIOF_IN, "SODIMM pin 174"},
{TEGRA_GPIO_PN1, GPIOF_IN, "SODIMM pin 176"},
{TEGRA_GPIO_PN2, GPIOF_IN, "SODIMM pin 178"},
@@ -237,10 +243,7 @@ static struct gpio colibri_t20_gpios[] = {
//conflicts with power key (WAKE1)
{TEGRA_GPIO_PV3, GPIOF_IN, "SODI-45, Iris X16-20"},
#endif
- {TEGRA_GPIO_PX0, GPIOF_IN, "SODIMM pin 142"},
- {TEGRA_GPIO_PX1, GPIOF_IN, "SODIMM pin 140"},
- {TEGRA_GPIO_PX2, GPIOF_IN, "SODIMM pin 138"},
- {TEGRA_GPIO_PX3, GPIOF_IN, "SODIMM pin 136"},
+
{TEGRA_GPIO_PX4, GPIOF_IN, "SODIMM pin 134"},
{TEGRA_GPIO_PX6, GPIOF_IN, "102, I X13 ForceOFF#"},
{TEGRA_GPIO_PX7, GPIOF_IN, "104, I X14 ForceOFF#"},