Based on Venice2, may change as P2571 board is fully
brought up. Incorporates Stephen Warren's P2571 pinmux table.

Signed-off-by: Tom Warren <twar...@nvidia.com>
---
 arch/arm/mach-tegra/tegra210/Kconfig               |   7 +
 board/nvidia/{beaver => p2571}/Kconfig             |   6 +-
 board/nvidia/p2571/MAINTAINERS                     |   6 +
 board/nvidia/{venice2 => p2571}/Makefile           |   6 +-
 board/nvidia/p2571/max77620_init.c                 |  47 +++++
 board/nvidia/p2571/max77620_init.h                 |  14 ++
 board/nvidia/p2571/p2571.c                         |  29 +++
 board/nvidia/p2571/pinmux-config-p2571.h           | 235 +++++++++++++++++++++
 configs/p2571_defconfig                            |   5 +
 include/configs/{venice2.h => p2571.h}             |  17 +-
 .../{tegra124-common.h => tegra210-common.h}       |   8 +-
 11 files changed, 363 insertions(+), 17 deletions(-)
 copy board/nvidia/{beaver => p2571}/Kconfig (61%)
 create mode 100644 board/nvidia/p2571/MAINTAINERS
 copy board/nvidia/{venice2 => p2571}/Makefile (55%)
 create mode 100644 board/nvidia/p2571/max77620_init.c
 create mode 100644 board/nvidia/p2571/max77620_init.h
 create mode 100644 board/nvidia/p2571/p2571.c
 create mode 100644 board/nvidia/p2571/pinmux-config-p2571.h
 create mode 100644 configs/p2571_defconfig
 copy include/configs/{venice2.h => p2571.h} (81%)
 copy include/configs/{tegra124-common.h => tegra210-common.h} (95%)

diff --git a/arch/arm/mach-tegra/tegra210/Kconfig 
b/arch/arm/mach-tegra/tegra210/Kconfig
index f2a0059..147e6a8 100644
--- a/arch/arm/mach-tegra/tegra210/Kconfig
+++ b/arch/arm/mach-tegra/tegra210/Kconfig
@@ -3,9 +3,16 @@ if TEGRA210
 choice
        prompt "Tegra210 board select"
 
+config TARGET_P2571
+       bool "NVIDIA Tegra210 P2571 base board"
+       help
+         P2571 is a P2530 married to a P1963 I/O board
+
 endchoice
 
 config SYS_SOC
        default "tegra210"
 
+source "board/nvidia/p2571/Kconfig"
+
 endif
diff --git a/board/nvidia/beaver/Kconfig b/board/nvidia/p2571/Kconfig
similarity index 61%
copy from board/nvidia/beaver/Kconfig
copy to board/nvidia/p2571/Kconfig
index 23f7c94..7bc4874 100644
--- a/board/nvidia/beaver/Kconfig
+++ b/board/nvidia/p2571/Kconfig
@@ -1,12 +1,12 @@
-if TARGET_BEAVER
+if TARGET_P2571
 
 config SYS_BOARD
-       default "beaver"
+       default "p2571"
 
 config SYS_VENDOR
        default "nvidia"
 
 config SYS_CONFIG_NAME
-       default "beaver"
+       default "p2571"
 
 endif
diff --git a/board/nvidia/p2571/MAINTAINERS b/board/nvidia/p2571/MAINTAINERS
new file mode 100644
index 0000000..c165135
--- /dev/null
+++ b/board/nvidia/p2571/MAINTAINERS
@@ -0,0 +1,6 @@
+P2571 BOARD
+M:     Tom Warren <twar...@nvidia.com>
+S:     Maintained
+F:     board/nvidia/p2571/
+F:     include/configs/p2571.h
+F:     configs/p2571_defconfig
diff --git a/board/nvidia/venice2/Makefile b/board/nvidia/p2571/Makefile
similarity index 55%
copy from board/nvidia/venice2/Makefile
copy to board/nvidia/p2571/Makefile
index 5fac5ab..223062e 100644
--- a/board/nvidia/venice2/Makefile
+++ b/board/nvidia/p2571/Makefile
@@ -1,9 +1,9 @@
 #
-# (C) Copyright 2013-2014
+# (C) Copyright 2013-2015
 # NVIDIA Corporation <www.nvidia.com>
 #
 # SPDX-License-Identifier:     GPL-2.0+
 #
 
-obj-y  += as3722_init.o
-obj-y  += venice2.o
+obj-y  += max77620_init.o
+obj-y  += p2571.o
diff --git a/board/nvidia/p2571/max77620_init.c 
b/board/nvidia/p2571/max77620_init.c
new file mode 100644
index 0000000..98c94af
--- /dev/null
+++ b/board/nvidia/p2571/max77620_init.c
@@ -0,0 +1,47 @@
+/*
+ * (C) Copyright 2013-2015
+ * NVIDIA Corporation <www.nvidia.com>
+ *
+ * SPDX-License-Identifier:     GPL-2.0+
+ */
+
+#include <common.h>
+#include <asm/io.h>
+#include <asm/arch-tegra/tegra_i2c.h>
+#include "max77620_init.h"
+
+/* MAX77620-PMIC-specific early init code - get CPU rails up, etc */
+
+void tegra_i2c_ll_write_addr(uint addr, uint config)
+{
+       struct i2c_ctlr *reg = (struct i2c_ctlr *)TEGRA_DVC_BASE;
+
+       writel(addr, &reg->cmd_addr0);
+       writel(config, &reg->cnfg);
+}
+
+void tegra_i2c_ll_write_data(uint data, uint config)
+{
+       struct i2c_ctlr *reg = (struct i2c_ctlr *)TEGRA_DVC_BASE;
+
+       writel(data, &reg->cmd_data1);
+       writel(config, &reg->cnfg);
+}
+
+void pmic_enable_cpu_vdd(void)
+{
+       debug("%s entry\n", __func__);
+
+        //from TegraShell init script: Set GPIO5 to drive CPU_REG_EN
+        //                              then 1.0V on ???
+        debug("%s: Setting GPIO5 to push-pull out, logic high to enable CPU 
regulator\n", __func__);
+        tegra_i2c_ll_write_addr(MAX77620_I2C_ADDR, 2);
+        tegra_i2c_ll_write_data(0x2040, I2C_SEND_2_BYTES);      //data/reg
+        udelay(10*1000);
+
+        tegra_i2c_ll_write_addr(MAX77620_I2C_ADDR, 2);
+        tegra_i2c_ll_write_data(0x093B, I2C_SEND_2_BYTES);      //B3=1=logic 
high,B2=dontcare,B1=0=output,B0=1=push-pull
+        udelay(10 * 1000);
+
+        debug("%s: Set VDD_SDMMC to 3.3V via MAX77620 reg ???\n", __func__);
+}
diff --git a/board/nvidia/p2571/max77620_init.h 
b/board/nvidia/p2571/max77620_init.h
new file mode 100644
index 0000000..2278386
--- /dev/null
+++ b/board/nvidia/p2571/max77620_init.h
@@ -0,0 +1,14 @@
+/*
+ * (C) Copyright 2013-2015
+ * NVIDIA Corporation <www.nvidia.com>
+ *
+ * SPDX-License-Identifier:     GPL-2.0+
+ */
+
+/* MAX77620-PMIC-specific early init regs */
+
+#define MAX77620_I2C_ADDR      0x78            /* or 0x3C 7-bit */
+
+#define I2C_SEND_2_BYTES       0x0A02
+
+void pmic_enable_cpu_vdd(void);
diff --git a/board/nvidia/p2571/p2571.c b/board/nvidia/p2571/p2571.c
new file mode 100644
index 0000000..fc710c1
--- /dev/null
+++ b/board/nvidia/p2571/p2571.c
@@ -0,0 +1,29 @@
+/*
+ * (C) Copyright 2013-2015
+ * NVIDIA Corporation <www.nvidia.com>
+ *
+ * SPDX-License-Identifier:     GPL-2.0+
+ */
+
+#include <common.h>
+#include <asm/arch/gpio.h>
+#include <asm/arch/pinmux.h>
+#include "pinmux-config-p2571.h"
+
+/*
+ * Routine: pinmux_init
+ * Description: Do individual peripheral pinmux configs
+ */
+void pinmux_init(void)
+{
+       pinmux_clear_tristate_input_clamping();
+
+       gpio_config_table(p2571_gpio_inits,
+                         ARRAY_SIZE(p2571_gpio_inits));
+
+       pinmux_config_pingrp_table(p2571_pingrps,
+                                  ARRAY_SIZE(p2571_pingrps));
+
+       pinmux_config_drvgrp_table(p2571_drvgrps,
+                                  ARRAY_SIZE(p2571_drvgrps));
+}
diff --git a/board/nvidia/p2571/pinmux-config-p2571.h 
b/board/nvidia/p2571/pinmux-config-p2571.h
new file mode 100644
index 0000000..d476d5c
--- /dev/null
+++ b/board/nvidia/p2571/pinmux-config-p2571.h
@@ -0,0 +1,235 @@
+/*
+ * Copyright (c) 2015, NVIDIA CORPORATION. All rights reserved.
+ *
+ * SPDX-License-Identifier: GPL-2.0+
+ */
+
+#ifndef _PINMUX_CONFIG_P2571_H_
+#define _PINMUX_CONFIG_P2571_H_
+
+#define GPIO_INIT(_gpio, _init)                                \
+       {                                               \
+               .gpio   = GPIO_P##_gpio,                \
+               .init   = TEGRA_GPIO_INIT_##_init,      \
+       }
+
+static const struct tegra_gpio_config p2571_gpio_inits[] = {
+       /*        gpio, init_val */
+       GPIO_INIT(A0,   IN),
+       GPIO_INIT(A5,   IN),
+       GPIO_INIT(D4,   IN),
+       GPIO_INIT(E4,   OUT0),
+       GPIO_INIT(G0,   IN),
+       GPIO_INIT(H0,   OUT0),
+       GPIO_INIT(H2,   IN),
+       GPIO_INIT(H3,   OUT0),
+       GPIO_INIT(H4,   OUT0),
+       GPIO_INIT(H5,   IN),
+       GPIO_INIT(I0,   OUT0),
+       GPIO_INIT(I1,   IN),
+       GPIO_INIT(V1,   OUT0),
+       GPIO_INIT(V6,   OUT1),
+       GPIO_INIT(X4,   IN),
+       GPIO_INIT(X6,   IN),
+       GPIO_INIT(X7,   IN),
+       GPIO_INIT(Y1,   IN),
+       GPIO_INIT(Z0,   IN),
+       GPIO_INIT(Z4,   OUT0),
+       GPIO_INIT(BB2,  OUT0),
+       GPIO_INIT(CC1,  IN),
+       GPIO_INIT(CC3,  IN),
+};
+
+#define PINCFG(_pingrp, _mux, _pull, _tri, _io, _od, _e_io_hv)         \
+       {                                                               \
+               .pingrp         = PMUX_PINGRP_##_pingrp,                \
+               .func           = PMUX_FUNC_##_mux,             \
+               .pull           = PMUX_PULL_##_pull,            \
+               .tristate       = PMUX_TRI_##_tri,                      \
+               .io             = PMUX_PIN_##_io,                       \
+               .od             = PMUX_PIN_OD_##_od,                    \
+               .e_io_hv        = PMUX_PIN_E_IO_HV_##_e_io_hv,          \
+               .lock           = PMUX_PIN_LOCK_DEFAULT,                \
+       }
+
+static const struct pmux_pingrp_config p2571_pingrps[] = {
+       /*     pingrp,               mux,      pull,   tri,      e_input, od,   
   e_io_hv */
+       PINCFG(PEX_L0_RST_N_PA0,     DEFAULT,  UP,     NORMAL,   INPUT,   
DISABLE, NORMAL),
+       PINCFG(PEX_L0_CLKREQ_N_PA1,  RSVD1,    DOWN,   TRISTATE, OUTPUT,  
DISABLE, NORMAL),
+       PINCFG(PEX_WAKE_N_PA2,       RSVD1,    DOWN,   TRISTATE, OUTPUT,  
DISABLE, NORMAL),
+       PINCFG(PEX_L1_RST_N_PA3,     RSVD1,    DOWN,   TRISTATE, OUTPUT,  
DISABLE, NORMAL),
+       PINCFG(PEX_L1_CLKREQ_N_PA4,  RSVD1,    DOWN,   TRISTATE, OUTPUT,  
DISABLE, NORMAL),
+       PINCFG(SATA_LED_ACTIVE_PA5,  DEFAULT,  UP,     NORMAL,   INPUT,   
DISABLE, DEFAULT),
+       PINCFG(PA6,                  RSVD1,    DOWN,   TRISTATE, OUTPUT,  
DISABLE, DEFAULT),
+       PINCFG(DAP1_FS_PB0,          RSVD1,    DOWN,   TRISTATE, OUTPUT,  
DISABLE, DEFAULT),
+       PINCFG(DAP1_DIN_PB1,         RSVD1,    DOWN,   TRISTATE, OUTPUT,  
DISABLE, DEFAULT),
+       PINCFG(DAP1_DOUT_PB2,        RSVD1,    DOWN,   TRISTATE, OUTPUT,  
DISABLE, DEFAULT),
+       PINCFG(DAP1_SCLK_PB3,        RSVD1,    DOWN,   TRISTATE, OUTPUT,  
DISABLE, DEFAULT),
+       PINCFG(SPI2_MOSI_PB4,        RSVD2,    DOWN,   TRISTATE, OUTPUT,  
DISABLE, DEFAULT),
+       PINCFG(SPI2_MISO_PB5,        RSVD2,    DOWN,   TRISTATE, OUTPUT,  
DISABLE, DEFAULT),
+       PINCFG(SPI2_SCK_PB6,         RSVD2,    DOWN,   TRISTATE, OUTPUT,  
DISABLE, DEFAULT),
+       PINCFG(SPI2_CS0_PB7,         RSVD2,    DOWN,   TRISTATE, OUTPUT,  
DISABLE, DEFAULT),
+       PINCFG(SPI1_MOSI_PC0,        RSVD1,    DOWN,   TRISTATE, OUTPUT,  
DISABLE, DEFAULT),
+       PINCFG(SPI1_MISO_PC1,        RSVD1,    DOWN,   TRISTATE, OUTPUT,  
DISABLE, DEFAULT),
+       PINCFG(SPI1_SCK_PC2,         RSVD1,    DOWN,   TRISTATE, OUTPUT,  
DISABLE, DEFAULT),
+       PINCFG(SPI1_CS0_PC3,         RSVD1,    DOWN,   TRISTATE, OUTPUT,  
DISABLE, DEFAULT),
+       PINCFG(SPI1_CS1_PC4,         RSVD1,    DOWN,   TRISTATE, OUTPUT,  
DISABLE, DEFAULT),
+       PINCFG(SPI4_SCK_PC5,         RSVD1,    DOWN,   TRISTATE, OUTPUT,  
DISABLE, DEFAULT),
+       PINCFG(SPI4_CS0_PC6,         RSVD1,    DOWN,   TRISTATE, OUTPUT,  
DISABLE, DEFAULT),
+       PINCFG(SPI4_MOSI_PC7,        RSVD1,    DOWN,   TRISTATE, OUTPUT,  
DISABLE, DEFAULT),
+       PINCFG(SPI4_MISO_PD0,        RSVD1,    DOWN,   TRISTATE, OUTPUT,  
DISABLE, DEFAULT),
+       PINCFG(UART3_TX_PD1,         RSVD2,    DOWN,   TRISTATE, OUTPUT,  
DISABLE, DEFAULT),
+       PINCFG(UART3_RX_PD2,         RSVD2,    DOWN,   TRISTATE, OUTPUT,  
DISABLE, DEFAULT),
+       PINCFG(UART3_RTS_PD3,        RSVD2,    DOWN,   TRISTATE, OUTPUT,  
DISABLE, DEFAULT),
+       PINCFG(UART3_CTS_PD4,        DEFAULT,  NORMAL, NORMAL,   INPUT,   
DISABLE, DEFAULT),
+       PINCFG(DMIC1_CLK_PE0,        I2S3,     NORMAL, NORMAL,   INPUT,   
DISABLE, DEFAULT),
+       PINCFG(DMIC1_DAT_PE1,        I2S3,     NORMAL, NORMAL,   INPUT,   
DISABLE, DEFAULT),
+       PINCFG(DMIC2_CLK_PE2,        I2S3,     NORMAL, NORMAL,   INPUT,   
DISABLE, DEFAULT),
+       PINCFG(DMIC2_DAT_PE3,        I2S3,     NORMAL, NORMAL,   INPUT,   
DISABLE, DEFAULT),
+       PINCFG(DMIC3_CLK_PE4,        DEFAULT,  NORMAL, NORMAL,   OUTPUT,  
DISABLE, DEFAULT),
+       PINCFG(DMIC3_DAT_PE5,        RSVD2,    DOWN,   TRISTATE, OUTPUT,  
DISABLE, DEFAULT),
+       PINCFG(PE6,                  RSVD0,    DOWN,   TRISTATE, OUTPUT,  
DISABLE, DEFAULT),
+       PINCFG(PE7,                  PWM3,     NORMAL, NORMAL,   OUTPUT,  
DISABLE, DEFAULT),
+       PINCFG(GEN3_I2C_SCL_PF0,     I2C3,     NORMAL, NORMAL,   INPUT,   
DISABLE, NORMAL),
+       PINCFG(GEN3_I2C_SDA_PF1,     I2C3,     NORMAL, NORMAL,   INPUT,   
DISABLE, NORMAL),
+       PINCFG(UART2_TX_PG0,         DEFAULT,  NORMAL, NORMAL,   INPUT,   
DISABLE, DEFAULT),
+       PINCFG(UART2_RX_PG1,         UARTB,    DOWN,   TRISTATE, OUTPUT,  
DISABLE, DEFAULT),
+       PINCFG(UART2_RTS_PG2,        RSVD2,    DOWN,   TRISTATE, OUTPUT,  
DISABLE, DEFAULT),
+       PINCFG(UART2_CTS_PG3,        RSVD2,    DOWN,   TRISTATE, OUTPUT,  
DISABLE, DEFAULT),
+       PINCFG(WIFI_EN_PH0,          DEFAULT,  NORMAL, NORMAL,   OUTPUT,  
DISABLE, DEFAULT),
+       PINCFG(WIFI_RST_PH1,         RSVD0,    DOWN,   TRISTATE, OUTPUT,  
DISABLE, DEFAULT),
+       PINCFG(WIFI_WAKE_AP_PH2,     DEFAULT,  UP,     NORMAL,   INPUT,   
DISABLE, DEFAULT),
+       PINCFG(AP_WAKE_BT_PH3,       DEFAULT,  NORMAL, NORMAL,   OUTPUT,  
DISABLE, DEFAULT),
+       PINCFG(BT_RST_PH4,           DEFAULT,  NORMAL, NORMAL,   OUTPUT,  
DISABLE, DEFAULT),
+       PINCFG(BT_WAKE_AP_PH5,       DEFAULT,  UP,     NORMAL,   INPUT,   
DISABLE, DEFAULT),
+       PINCFG(PH6,                  RSVD0,    DOWN,   TRISTATE, OUTPUT,  
DISABLE, DEFAULT),
+       PINCFG(AP_WAKE_NFC_PH7,      RSVD0,    DOWN,   TRISTATE, OUTPUT,  
DISABLE, DEFAULT),
+       PINCFG(NFC_EN_PI0,           DEFAULT,  NORMAL, NORMAL,   OUTPUT,  
DISABLE, DEFAULT),
+       PINCFG(NFC_INT_PI1,          DEFAULT,  NORMAL, NORMAL,   INPUT,   
DISABLE, DEFAULT),
+       PINCFG(GPS_EN_PI2,           RSVD0,    DOWN,   TRISTATE, OUTPUT,  
DISABLE, DEFAULT),
+       PINCFG(GPS_RST_PI3,          RSVD0,    DOWN,   TRISTATE, OUTPUT,  
DISABLE, DEFAULT),
+       PINCFG(UART4_TX_PI4,         UARTD,    NORMAL, NORMAL,   OUTPUT,  
DISABLE, DEFAULT),
+       PINCFG(UART4_RX_PI5,         UARTD,    NORMAL, NORMAL,   INPUT,   
DISABLE, DEFAULT),
+       PINCFG(UART4_RTS_PI6,        UARTD,    NORMAL, NORMAL,   OUTPUT,  
DISABLE, DEFAULT),
+       PINCFG(UART4_CTS_PI7,        UARTD,    NORMAL, NORMAL,   INPUT,   
DISABLE, DEFAULT),
+       PINCFG(GEN1_I2C_SDA_PJ0,     I2C1,     NORMAL, NORMAL,   INPUT,   
DISABLE, NORMAL),
+       PINCFG(GEN1_I2C_SCL_PJ1,     I2C1,     NORMAL, NORMAL,   INPUT,   
DISABLE, NORMAL),
+       PINCFG(GEN2_I2C_SCL_PJ2,     I2C2,     NORMAL, NORMAL,   INPUT,   
DISABLE, HIGH),
+       PINCFG(GEN2_I2C_SDA_PJ3,     I2C2,     NORMAL, NORMAL,   INPUT,   
DISABLE, HIGH),
+       PINCFG(DAP4_FS_PJ4,          RSVD1,    DOWN,   TRISTATE, OUTPUT,  
DISABLE, DEFAULT),
+       PINCFG(DAP4_DIN_PJ5,         RSVD1,    DOWN,   TRISTATE, OUTPUT,  
DISABLE, DEFAULT),
+       PINCFG(DAP4_DOUT_PJ6,        RSVD1,    DOWN,   TRISTATE, OUTPUT,  
DISABLE, DEFAULT),
+       PINCFG(DAP4_SCLK_PJ7,        RSVD1,    DOWN,   TRISTATE, OUTPUT,  
DISABLE, DEFAULT),
+       PINCFG(PK0,                  RSVD2,    DOWN,   TRISTATE, OUTPUT,  
DISABLE, DEFAULT),
+       PINCFG(PK1,                  RSVD2,    DOWN,   TRISTATE, OUTPUT,  
DISABLE, DEFAULT),
+       PINCFG(PK2,                  RSVD2,    DOWN,   TRISTATE, OUTPUT,  
DISABLE, DEFAULT),
+       PINCFG(PK3,                  RSVD2,    DOWN,   TRISTATE, OUTPUT,  
DISABLE, DEFAULT),
+       PINCFG(PK4,                  RSVD1,    DOWN,   TRISTATE, OUTPUT,  
DISABLE, DEFAULT),
+       PINCFG(PK5,                  RSVD1,    DOWN,   TRISTATE, OUTPUT,  
DISABLE, DEFAULT),
+       PINCFG(PK6,                  RSVD1,    DOWN,   TRISTATE, OUTPUT,  
DISABLE, DEFAULT),
+       PINCFG(PK7,                  RSVD1,    DOWN,   TRISTATE, OUTPUT,  
DISABLE, DEFAULT),
+       PINCFG(PL0,                  RSVD0,    DOWN,   TRISTATE, OUTPUT,  
DISABLE, DEFAULT),
+       PINCFG(PL1,                  RSVD1,    DOWN,   TRISTATE, OUTPUT,  
DISABLE, DEFAULT),
+       PINCFG(SDMMC1_CLK_PM0,       SDMMC1,   NORMAL, NORMAL,   INPUT,   
DISABLE, DEFAULT),
+       PINCFG(SDMMC1_CMD_PM1,       SDMMC1,   UP,     NORMAL,   INPUT,   
DISABLE, DEFAULT),
+       PINCFG(SDMMC1_DAT3_PM2,      SDMMC1,   UP,     NORMAL,   INPUT,   
DISABLE, DEFAULT),
+       PINCFG(SDMMC1_DAT2_PM3,      SDMMC1,   UP,     NORMAL,   INPUT,   
DISABLE, DEFAULT),
+       PINCFG(SDMMC1_DAT1_PM4,      SDMMC1,   UP,     NORMAL,   INPUT,   
DISABLE, DEFAULT),
+       PINCFG(SDMMC1_DAT0_PM5,      SDMMC1,   UP,     NORMAL,   INPUT,   
DISABLE, DEFAULT),
+       PINCFG(SDMMC3_CLK_PP0,       SDMMC3,   NORMAL, NORMAL,   INPUT,   
DISABLE, DEFAULT),
+       PINCFG(SDMMC3_CMD_PP1,       SDMMC3,   UP,     NORMAL,   INPUT,   
DISABLE, DEFAULT),
+       PINCFG(SDMMC3_DAT3_PP2,      SDMMC3,   UP,     NORMAL,   INPUT,   
DISABLE, DEFAULT),
+       PINCFG(SDMMC3_DAT2_PP3,      SDMMC3,   UP,     NORMAL,   INPUT,   
DISABLE, DEFAULT),
+       PINCFG(SDMMC3_DAT1_PP4,      SDMMC3,   UP,     NORMAL,   INPUT,   
DISABLE, DEFAULT),
+       PINCFG(SDMMC3_DAT0_PP5,      SDMMC3,   UP,     NORMAL,   INPUT,   
DISABLE, DEFAULT),
+       PINCFG(CAM1_MCLK_PS0,        RSVD1,    DOWN,   TRISTATE, OUTPUT,  
DISABLE, DEFAULT),
+       PINCFG(CAM2_MCLK_PS1,        RSVD1,    DOWN,   TRISTATE, OUTPUT,  
DISABLE, DEFAULT),
+       PINCFG(CAM_I2C_SCL_PS2,      I2CVI,    NORMAL, NORMAL,   INPUT,   
DISABLE, NORMAL),
+       PINCFG(CAM_I2C_SDA_PS3,      I2CVI,    NORMAL, NORMAL,   INPUT,   
DISABLE, NORMAL),
+       PINCFG(CAM_RST_PS4,          RSVD1,    DOWN,   TRISTATE, OUTPUT,  
DISABLE, DEFAULT),
+       PINCFG(CAM_AF_EN_PS5,        RSVD2,    DOWN,   TRISTATE, OUTPUT,  
DISABLE, DEFAULT),
+       PINCFG(CAM_FLASH_EN_PS6,     RSVD2,    DOWN,   TRISTATE, OUTPUT,  
DISABLE, DEFAULT),
+       PINCFG(CAM1_PWDN_PS7,        RSVD1,    DOWN,   TRISTATE, OUTPUT,  
DISABLE, DEFAULT),
+       PINCFG(CAM2_PWDN_PT0,        RSVD1,    DOWN,   TRISTATE, OUTPUT,  
DISABLE, DEFAULT),
+       PINCFG(CAM1_STROBE_PT1,      RSVD1,    DOWN,   TRISTATE, OUTPUT,  
DISABLE, DEFAULT),
+       PINCFG(UART1_TX_PU0,         UARTA,    NORMAL, NORMAL,   OUTPUT,  
DISABLE, DEFAULT),
+       PINCFG(UART1_RX_PU1,         UARTA,    UP,     NORMAL,   INPUT,   
DISABLE, DEFAULT),
+       PINCFG(UART1_RTS_PU2,        UARTA,    NORMAL, NORMAL,   OUTPUT,  
DISABLE, DEFAULT),
+       PINCFG(UART1_CTS_PU3,        UARTA,    UP,     NORMAL,   INPUT,   
DISABLE, DEFAULT),
+       PINCFG(LCD_BL_PWM_PV0,       PWM0,     NORMAL, NORMAL,   OUTPUT,  
DISABLE, DEFAULT),
+       PINCFG(LCD_BL_EN_PV1,        DEFAULT,  NORMAL, NORMAL,   OUTPUT,  
DISABLE, DEFAULT),
+       PINCFG(LCD_RST_PV2,          RSVD0,    DOWN,   TRISTATE, OUTPUT,  
DISABLE, DEFAULT),
+       PINCFG(LCD_GPIO1_PV3,        RSVD1,    DOWN,   TRISTATE, OUTPUT,  
DISABLE, DEFAULT),
+       PINCFG(LCD_GPIO2_PV4,        PWM1,     NORMAL, NORMAL,   OUTPUT,  
DISABLE, DEFAULT),
+       PINCFG(AP_READY_PV5,         RSVD0,    DOWN,   TRISTATE, OUTPUT,  
DISABLE, DEFAULT),
+       PINCFG(TOUCH_RST_PV6,        DEFAULT,  NORMAL, NORMAL,   OUTPUT,  
DISABLE, DEFAULT),
+       PINCFG(TOUCH_CLK_PV7,        RSVD1,    DOWN,   TRISTATE, OUTPUT,  
DISABLE, DEFAULT),
+       PINCFG(MODEM_WAKE_AP_PX0,    RSVD0,    DOWN,   TRISTATE, OUTPUT,  
DISABLE, DEFAULT),
+       PINCFG(TOUCH_INT_PX1,        RSVD0,    DOWN,   TRISTATE, OUTPUT,  
DISABLE, DEFAULT),
+       PINCFG(MOTION_INT_PX2,       RSVD0,    DOWN,   TRISTATE, OUTPUT,  
DISABLE, DEFAULT),
+       PINCFG(ALS_PROX_INT_PX3,     RSVD0,    DOWN,   TRISTATE, OUTPUT,  
DISABLE, DEFAULT),
+       PINCFG(TEMP_ALERT_PX4,       DEFAULT,  UP,     NORMAL,   INPUT,   
DISABLE, DEFAULT),
+       PINCFG(BUTTON_POWER_ON_PX5,  RSVD0,    DOWN,   TRISTATE, OUTPUT,  
DISABLE, DEFAULT),
+       PINCFG(BUTTON_VOL_UP_PX6,    DEFAULT,  UP,     NORMAL,   INPUT,   
DISABLE, DEFAULT),
+       PINCFG(BUTTON_VOL_DOWN_PX7,  DEFAULT,  UP,     NORMAL,   INPUT,   
DISABLE, DEFAULT),
+       PINCFG(BUTTON_SLIDE_SW_PY0,  RSVD0,    DOWN,   TRISTATE, OUTPUT,  
DISABLE, DEFAULT),
+       PINCFG(BUTTON_HOME_PY1,      DEFAULT,  UP,     NORMAL,   INPUT,   
DISABLE, DEFAULT),
+       PINCFG(LCD_TE_PY2,           RSVD1,    DOWN,   TRISTATE, OUTPUT,  
DISABLE, DEFAULT),
+       PINCFG(PWR_I2C_SCL_PY3,      I2CPMU,   NORMAL, NORMAL,   INPUT,   
DISABLE, NORMAL),
+       PINCFG(PWR_I2C_SDA_PY4,      I2CPMU,   NORMAL, NORMAL,   INPUT,   
DISABLE, NORMAL),
+       PINCFG(CLK_32K_OUT_PY5,      SOC,      UP,     NORMAL,   INPUT,   
DISABLE, DEFAULT),
+       PINCFG(PZ0,                  DEFAULT,  UP,     NORMAL,   INPUT,   
DISABLE, DEFAULT),
+       PINCFG(PZ1,                  SDMMC1,   UP,     NORMAL,   INPUT,   
DISABLE, DEFAULT),
+       PINCFG(PZ2,                  RSVD2,    DOWN,   TRISTATE, OUTPUT,  
DISABLE, DEFAULT),
+       PINCFG(PZ3,                  RSVD1,    DOWN,   TRISTATE, OUTPUT,  
DISABLE, DEFAULT),
+       PINCFG(PZ4,                  DEFAULT,  NORMAL, NORMAL,   OUTPUT,  
DISABLE, DEFAULT),
+       PINCFG(PZ5,                  SOC,      UP,     NORMAL,   INPUT,   
DISABLE, DEFAULT),
+       PINCFG(DAP2_FS_PAA0,         I2S2,     NORMAL, NORMAL,   INPUT,   
DISABLE, DEFAULT),
+       PINCFG(DAP2_SCLK_PAA1,       I2S2,     NORMAL, NORMAL,   INPUT,   
DISABLE, DEFAULT),
+       PINCFG(DAP2_DIN_PAA2,        I2S2,     NORMAL, NORMAL,   INPUT,   
DISABLE, DEFAULT),
+       PINCFG(DAP2_DOUT_PAA3,       I2S2,     NORMAL, NORMAL,   INPUT,   
DISABLE, DEFAULT),
+       PINCFG(AUD_MCLK_PBB0,        AUD,      NORMAL, NORMAL,   OUTPUT,  
DISABLE, DEFAULT),
+       PINCFG(DVFS_PWM_PBB1,        CLDVFS,   NORMAL, TRISTATE, OUTPUT,  
DISABLE, DEFAULT),
+       PINCFG(DVFS_CLK_PBB2,        DEFAULT,  NORMAL, NORMAL,   OUTPUT,  
DISABLE, DEFAULT),
+       PINCFG(GPIO_X1_AUD_PBB3,     RSVD0,    DOWN,   TRISTATE, OUTPUT,  
DISABLE, DEFAULT),
+       PINCFG(GPIO_X3_AUD_PBB4,     RSVD0,    DOWN,   TRISTATE, OUTPUT,  
DISABLE, DEFAULT),
+       PINCFG(HDMI_CEC_PCC0,        CEC,      NORMAL, NORMAL,   INPUT,   
DISABLE, HIGH),
+       PINCFG(HDMI_INT_DP_HPD_PCC1, DEFAULT,  DOWN,   NORMAL,   INPUT,   
DISABLE, NORMAL),
+       PINCFG(SPDIF_OUT_PCC2,       RSVD1,    DOWN,   TRISTATE, OUTPUT,  
DISABLE, DEFAULT),
+       PINCFG(SPDIF_IN_PCC3,        DEFAULT,  NORMAL, NORMAL,   INPUT,   
DISABLE, DEFAULT),
+       PINCFG(USB_VBUS_EN0_PCC4,    USB,      NORMAL, NORMAL,   INPUT,   
DISABLE, HIGH),
+       PINCFG(USB_VBUS_EN1_PCC5,    USB,      NORMAL, NORMAL,   INPUT,   
DISABLE, HIGH),
+       PINCFG(DP_HPD0_PCC6,         RSVD1,    DOWN,   TRISTATE, OUTPUT,  
DISABLE, DEFAULT),
+       PINCFG(PCC7,                 RSVD0,    DOWN,   TRISTATE, OUTPUT,  
DISABLE, NORMAL),
+       PINCFG(SPI2_CS1_PDD0,        RSVD1,    DOWN,   TRISTATE, OUTPUT,  
DISABLE, DEFAULT),
+       PINCFG(QSPI_SCK_PEE0,        RSVD1,    DOWN,   TRISTATE, OUTPUT,  
DISABLE, DEFAULT),
+       PINCFG(QSPI_CS_N_PEE1,       RSVD1,    DOWN,   TRISTATE, OUTPUT,  
DISABLE, DEFAULT),
+       PINCFG(QSPI_IO0_PEE2,        RSVD1,    DOWN,   TRISTATE, OUTPUT,  
DISABLE, DEFAULT),
+       PINCFG(QSPI_IO1_PEE3,        RSVD1,    DOWN,   TRISTATE, OUTPUT,  
DISABLE, DEFAULT),
+       PINCFG(QSPI_IO2_PEE4,        RSVD1,    DOWN,   TRISTATE, OUTPUT,  
DISABLE, DEFAULT),
+       PINCFG(QSPI_IO3_PEE5,        RSVD1,    DOWN,   TRISTATE, OUTPUT,  
DISABLE, DEFAULT),
+       PINCFG(CORE_PWR_REQ,         CORE,     NORMAL, NORMAL,   OUTPUT,  
DISABLE, DEFAULT),
+       PINCFG(CPU_PWR_REQ,          CPU,      NORMAL, NORMAL,   OUTPUT,  
DISABLE, DEFAULT),
+       PINCFG(PWR_INT_N,            PMI,      UP,     NORMAL,   INPUT,   
DISABLE, DEFAULT),
+       PINCFG(CLK_32K_IN,           CLK,      NORMAL, NORMAL,   INPUT,   
DISABLE, DEFAULT),
+       PINCFG(JTAG_RTCK,            JTAG,     NORMAL, NORMAL,   OUTPUT,  
DISABLE, DEFAULT),
+       PINCFG(CLK_REQ,              SYS,      NORMAL, NORMAL,   OUTPUT,  
DISABLE, DEFAULT),
+       PINCFG(SHUTDOWN,             SHUTDOWN, NORMAL, NORMAL,   OUTPUT,  
DISABLE, DEFAULT),
+};
+
+#define DRVCFG(_drvgrp, _slwf, _slwr, _drvup, _drvdn, _lpmd, _schmt, _hsm) \
+       {                                               \
+               .drvgrp = PMUX_DRVGRP_##_drvgrp,        \
+               .slwf   = _slwf,                        \
+               .slwr   = _slwr,                        \
+               .drvup  = _drvup,                       \
+               .drvdn  = _drvdn,                       \
+               .lpmd   = PMUX_LPMD_##_lpmd,            \
+               .schmt  = PMUX_SCHMT_##_schmt,          \
+               .hsm    = PMUX_HSM_##_hsm,              \
+       }
+
+static const struct pmux_drvgrp_config p2571_drvgrps[] = {
+};
+
+#endif /* PINMUX_CONFIG_P2571_H */
diff --git a/configs/p2571_defconfig b/configs/p2571_defconfig
new file mode 100644
index 0000000..a91ff22
--- /dev/null
+++ b/configs/p2571_defconfig
@@ -0,0 +1,5 @@
+CONFIG_ARM=y
+CONFIG_TEGRA=y
+CONFIG_TEGRA210=y
+CONFIG_TARGET_P2571=y
+CONFIG_DEFAULT_DEVICE_TREE="tegra210-p2571"
diff --git a/include/configs/venice2.h b/include/configs/p2571.h
similarity index 81%
copy from include/configs/venice2.h
copy to include/configs/p2571.h
index 4594002..b015452 100644
--- a/include/configs/venice2.h
+++ b/include/configs/p2571.h
@@ -1,5 +1,5 @@
 /*
- * (C) Copyright 2013-2014
+ * (C) Copyright 2013-2015
  * NVIDIA Corporation <www.nvidia.com>
  *
  * SPDX-License-Identifier:     GPL-2.0+
@@ -10,11 +10,14 @@
 
 #include <linux/sizes.h>
 
-#include "tegra124-common.h"
+/* enable PMIC */
+#define CONFIG_MAX77620_POWER
+
+#include "tegra210-common.h"
 
 /* High-level configuration options */
-#define V_PROMPT                       "Tegra124 (Venice2) # "
-#define CONFIG_TEGRA_BOARD_STRING      "NVIDIA Venice2"
+#define V_PROMPT                       "Tegra210 (P2571) # "
+#define CONFIG_TEGRA_BOARD_STRING      "NVIDIA P2571"
 
 /* Board-specific serial config */
 #define CONFIG_SERIAL_MULTI
@@ -42,11 +45,11 @@
 #define CONFIG_TEGRA114_SPI_CTRLS      6
 #define CONFIG_SPI_FLASH
 #define CONFIG_SPI_FLASH_WINBOND
-#define CONFIG_SF_DEFAULT_MODE         SPI_MODE_0
-#define CONFIG_SF_DEFAULT_SPEED        24000000
+#define CONFIG_SF_DEFAULT_MODE         SPI_MODE_0
+#define CONFIG_SF_DEFAULT_SPEED                24000000
 #define CONFIG_CMD_SPI
 #define CONFIG_CMD_SF
-#define CONFIG_SPI_FLASH_SIZE          (4 << 20)
+#define CONFIG_SPI_FLASH_SIZE          (4 << 20)
 
 /* USB Host support */
 #define CONFIG_USB_EHCI
diff --git a/include/configs/tegra124-common.h 
b/include/configs/tegra210-common.h
similarity index 95%
copy from include/configs/tegra124-common.h
copy to include/configs/tegra210-common.h
index 1aee5c8..cebe598 100644
--- a/include/configs/tegra124-common.h
+++ b/include/configs/tegra210-common.h
@@ -1,12 +1,12 @@
 /*
- * (C) Copyright 2013
+ * (C) Copyright 2013-2015
  * NVIDIA Corporation <www.nvidia.com>
  *
  * SPDX-License-Identifier:     GPL-2.0+
  */
 
-#ifndef _TEGRA124_COMMON_H_
-#define _TEGRA124_COMMON_H_
+#ifndef _TEGRA210_COMMON_H_
+#define _TEGRA210_COMMON_H_
 
 #include "tegra-common.h"
 
@@ -70,4 +70,4 @@
 #define CONFIG_USB_EHCI_TXFIFO_THRESH  0x10
 #define CONFIG_SYS_USB_EHCI_MAX_ROOT_PORTS 1
 
-#endif /* _TEGRA124_COMMON_H_ */
+#endif /* _TEGRA210_COMMON_H_ */
-- 
1.8.2.1.610.g562af5b

_______________________________________________
U-Boot mailing list
U-Boot@lists.denx.de
http://lists.denx.de/mailman/listinfo/u-boot

Reply via email to