1*4882a593Smuzhiyun /* 2*4882a593Smuzhiyun * Copyright (c) 2015, NVIDIA CORPORATION. All rights reserved. 3*4882a593Smuzhiyun * 4*4882a593Smuzhiyun * SPDX-License-Identifier: GPL-2.0+ 5*4882a593Smuzhiyun */ 6*4882a593Smuzhiyun 7*4882a593Smuzhiyun #include <common.h> 8*4882a593Smuzhiyun #include <asm/io.h> 9*4882a593Smuzhiyun #include <asm/arch/pinmux.h> 10*4882a593Smuzhiyun 11*4882a593Smuzhiyun #define PIN(pin, f0, f1, f2, f3) \ 12*4882a593Smuzhiyun { \ 13*4882a593Smuzhiyun .funcs = { \ 14*4882a593Smuzhiyun PMUX_FUNC_##f0, \ 15*4882a593Smuzhiyun PMUX_FUNC_##f1, \ 16*4882a593Smuzhiyun PMUX_FUNC_##f2, \ 17*4882a593Smuzhiyun PMUX_FUNC_##f3, \ 18*4882a593Smuzhiyun }, \ 19*4882a593Smuzhiyun } 20*4882a593Smuzhiyun 21*4882a593Smuzhiyun #define PIN_RESERVED {} 22*4882a593Smuzhiyun 23*4882a593Smuzhiyun static const struct pmux_pingrp_desc tegra210_pingroups[] = { 24*4882a593Smuzhiyun /* pin, f0, f1, f2, f3 */ 25*4882a593Smuzhiyun /* Offset 0x3000 */ 26*4882a593Smuzhiyun PIN(SDMMC1_CLK_PM0, SDMMC1, RSVD1, RSVD2, RSVD3), 27*4882a593Smuzhiyun PIN(SDMMC1_CMD_PM1, SDMMC1, SPI3, RSVD2, RSVD3), 28*4882a593Smuzhiyun PIN(SDMMC1_DAT3_PM2, SDMMC1, SPI3, RSVD2, RSVD3), 29*4882a593Smuzhiyun PIN(SDMMC1_DAT2_PM3, SDMMC1, SPI3, RSVD2, RSVD3), 30*4882a593Smuzhiyun PIN(SDMMC1_DAT1_PM4, SDMMC1, SPI3, RSVD2, RSVD3), 31*4882a593Smuzhiyun PIN(SDMMC1_DAT0_PM5, SDMMC1, RSVD1, RSVD2, RSVD3), 32*4882a593Smuzhiyun PIN_RESERVED, 33*4882a593Smuzhiyun /* Offset 0x301c */ 34*4882a593Smuzhiyun PIN(SDMMC3_CLK_PP0, SDMMC3, RSVD1, RSVD2, RSVD3), 35*4882a593Smuzhiyun PIN(SDMMC3_CMD_PP1, SDMMC3, RSVD1, RSVD2, RSVD3), 36*4882a593Smuzhiyun PIN(SDMMC3_DAT0_PP5, SDMMC3, RSVD1, RSVD2, RSVD3), 37*4882a593Smuzhiyun PIN(SDMMC3_DAT1_PP4, SDMMC3, RSVD1, RSVD2, RSVD3), 38*4882a593Smuzhiyun PIN(SDMMC3_DAT2_PP3, SDMMC3, RSVD1, RSVD2, RSVD3), 39*4882a593Smuzhiyun PIN(SDMMC3_DAT3_PP2, SDMMC3, RSVD1, RSVD2, RSVD3), 40*4882a593Smuzhiyun PIN_RESERVED, 41*4882a593Smuzhiyun /* Offset 0x3038 */ 42*4882a593Smuzhiyun PIN(PEX_L0_RST_N_PA0, PE0, RSVD1, RSVD2, RSVD3), 43*4882a593Smuzhiyun PIN(PEX_L0_CLKREQ_N_PA1, PE0, RSVD1, RSVD2, RSVD3), 44*4882a593Smuzhiyun PIN(PEX_WAKE_N_PA2, PE, RSVD1, RSVD2, RSVD3), 45*4882a593Smuzhiyun PIN(PEX_L1_RST_N_PA3, PE1, RSVD1, RSVD2, RSVD3), 46*4882a593Smuzhiyun PIN(PEX_L1_CLKREQ_N_PA4, PE1, RSVD1, RSVD2, RSVD3), 47*4882a593Smuzhiyun PIN(SATA_LED_ACTIVE_PA5, SATA, RSVD1, RSVD2, RSVD3), 48*4882a593Smuzhiyun PIN(SPI1_MOSI_PC0, SPI1, RSVD1, RSVD2, RSVD3), 49*4882a593Smuzhiyun PIN(SPI1_MISO_PC1, SPI1, RSVD1, RSVD2, RSVD3), 50*4882a593Smuzhiyun PIN(SPI1_SCK_PC2, SPI1, RSVD1, RSVD2, RSVD3), 51*4882a593Smuzhiyun PIN(SPI1_CS0_PC3, SPI1, RSVD1, RSVD2, RSVD3), 52*4882a593Smuzhiyun PIN(SPI1_CS1_PC4, SPI1, RSVD1, RSVD2, RSVD3), 53*4882a593Smuzhiyun PIN(SPI2_MOSI_PB4, SPI2, DTV, RSVD2, RSVD3), 54*4882a593Smuzhiyun PIN(SPI2_MISO_PB5, SPI2, DTV, RSVD2, RSVD3), 55*4882a593Smuzhiyun PIN(SPI2_SCK_PB6, SPI2, DTV, RSVD2, RSVD3), 56*4882a593Smuzhiyun PIN(SPI2_CS0_PB7, SPI2, DTV, RSVD2, RSVD3), 57*4882a593Smuzhiyun PIN(SPI2_CS1_PDD0, SPI2, RSVD1, RSVD2, RSVD3), 58*4882a593Smuzhiyun PIN(SPI4_MOSI_PC7, SPI4, RSVD1, RSVD2, RSVD3), 59*4882a593Smuzhiyun PIN(SPI4_MISO_PD0, SPI4, RSVD1, RSVD2, RSVD3), 60*4882a593Smuzhiyun PIN(SPI4_SCK_PC5, SPI4, RSVD1, RSVD2, RSVD3), 61*4882a593Smuzhiyun PIN(SPI4_CS0_PC6, SPI4, RSVD1, RSVD2, RSVD3), 62*4882a593Smuzhiyun PIN(QSPI_SCK_PEE0, QSPI, RSVD1, RSVD2, RSVD3), 63*4882a593Smuzhiyun PIN(QSPI_CS_N_PEE1, QSPI, RSVD1, RSVD2, RSVD3), 64*4882a593Smuzhiyun PIN(QSPI_IO0_PEE2, QSPI, RSVD1, RSVD2, RSVD3), 65*4882a593Smuzhiyun PIN(QSPI_IO1_PEE3, QSPI, RSVD1, RSVD2, RSVD3), 66*4882a593Smuzhiyun PIN(QSPI_IO2_PEE4, QSPI, RSVD1, RSVD2, RSVD3), 67*4882a593Smuzhiyun PIN(QSPI_IO3_PEE5, QSPI, RSVD1, RSVD2, RSVD3), 68*4882a593Smuzhiyun PIN_RESERVED, 69*4882a593Smuzhiyun /* Offset 0x30a4 */ 70*4882a593Smuzhiyun PIN(DMIC1_CLK_PE0, DMIC1, I2S3, RSVD2, RSVD3), 71*4882a593Smuzhiyun PIN(DMIC1_DAT_PE1, DMIC1, I2S3, RSVD2, RSVD3), 72*4882a593Smuzhiyun PIN(DMIC2_CLK_PE2, DMIC2, I2S3, RSVD2, RSVD3), 73*4882a593Smuzhiyun PIN(DMIC2_DAT_PE3, DMIC2, I2S3, RSVD2, RSVD3), 74*4882a593Smuzhiyun PIN(DMIC3_CLK_PE4, DMIC3, I2S5A, RSVD2, RSVD3), 75*4882a593Smuzhiyun PIN(DMIC3_DAT_PE5, DMIC3, I2S5A, RSVD2, RSVD3), 76*4882a593Smuzhiyun PIN(GEN1_I2C_SCL_PJ1, I2C1, RSVD1, RSVD2, RSVD3), 77*4882a593Smuzhiyun PIN(GEN1_I2C_SDA_PJ0, I2C1, RSVD1, RSVD2, RSVD3), 78*4882a593Smuzhiyun PIN(GEN2_I2C_SCL_PJ2, I2C2, RSVD1, RSVD2, RSVD3), 79*4882a593Smuzhiyun PIN(GEN2_I2C_SDA_PJ3, I2C2, RSVD1, RSVD2, RSVD3), 80*4882a593Smuzhiyun PIN(GEN3_I2C_SCL_PF0, I2C3, RSVD1, RSVD2, RSVD3), 81*4882a593Smuzhiyun PIN(GEN3_I2C_SDA_PF1, I2C3, RSVD1, RSVD2, RSVD3), 82*4882a593Smuzhiyun PIN(CAM_I2C_SCL_PS2, I2C3, I2CVI, RSVD2, RSVD3), 83*4882a593Smuzhiyun PIN(CAM_I2C_SDA_PS3, I2C3, I2CVI, RSVD2, RSVD3), 84*4882a593Smuzhiyun PIN(PWR_I2C_SCL_PY3, I2CPMU, RSVD1, RSVD2, RSVD3), 85*4882a593Smuzhiyun PIN(PWR_I2C_SDA_PY4, I2CPMU, RSVD1, RSVD2, RSVD3), 86*4882a593Smuzhiyun PIN(UART1_TX_PU0, UARTA, RSVD1, RSVD2, RSVD3), 87*4882a593Smuzhiyun PIN(UART1_RX_PU1, UARTA, RSVD1, RSVD2, RSVD3), 88*4882a593Smuzhiyun PIN(UART1_RTS_PU2, UARTA, RSVD1, RSVD2, RSVD3), 89*4882a593Smuzhiyun PIN(UART1_CTS_PU3, UARTA, RSVD1, RSVD2, RSVD3), 90*4882a593Smuzhiyun PIN(UART2_TX_PG0, UARTB, I2S4A, SPDIF, UART), 91*4882a593Smuzhiyun PIN(UART2_RX_PG1, UARTB, I2S4A, SPDIF, UART), 92*4882a593Smuzhiyun PIN(UART2_RTS_PG2, UARTB, I2S4A, RSVD2, UART), 93*4882a593Smuzhiyun PIN(UART2_CTS_PG3, UARTB, I2S4A, RSVD2, UART), 94*4882a593Smuzhiyun PIN(UART3_TX_PD1, UARTC, SPI4, RSVD2, RSVD3), 95*4882a593Smuzhiyun PIN(UART3_RX_PD2, UARTC, SPI4, RSVD2, RSVD3), 96*4882a593Smuzhiyun PIN(UART3_RTS_PD3, UARTC, SPI4, RSVD2, RSVD3), 97*4882a593Smuzhiyun PIN(UART3_CTS_PD4, UARTC, SPI4, RSVD2, RSVD3), 98*4882a593Smuzhiyun PIN(UART4_TX_PI4, UARTD, UART, RSVD2, RSVD3), 99*4882a593Smuzhiyun PIN(UART4_RX_PI5, UARTD, UART, RSVD2, RSVD3), 100*4882a593Smuzhiyun PIN(UART4_RTS_PI6, UARTD, UART, RSVD2, RSVD3), 101*4882a593Smuzhiyun PIN(UART4_CTS_PI7, UARTD, UART, RSVD2, RSVD3), 102*4882a593Smuzhiyun PIN(DAP1_FS_PB0, I2S1, RSVD1, RSVD2, RSVD3), 103*4882a593Smuzhiyun PIN(DAP1_DIN_PB1, I2S1, RSVD1, RSVD2, RSVD3), 104*4882a593Smuzhiyun PIN(DAP1_DOUT_PB2, I2S1, RSVD1, RSVD2, RSVD3), 105*4882a593Smuzhiyun PIN(DAP1_SCLK_PB3, I2S1, RSVD1, RSVD2, RSVD3), 106*4882a593Smuzhiyun PIN(DAP2_FS_PAA0, I2S2, RSVD1, RSVD2, RSVD3), 107*4882a593Smuzhiyun PIN(DAP2_DIN_PAA2, I2S2, RSVD1, RSVD2, RSVD3), 108*4882a593Smuzhiyun PIN(DAP2_DOUT_PAA3, I2S2, RSVD1, RSVD2, RSVD3), 109*4882a593Smuzhiyun PIN(DAP2_SCLK_PAA1, I2S2, RSVD1, RSVD2, RSVD3), 110*4882a593Smuzhiyun PIN(DAP4_FS_PJ4, I2S4B, RSVD1, RSVD2, RSVD3), 111*4882a593Smuzhiyun PIN(DAP4_DIN_PJ5, I2S4B, RSVD1, RSVD2, RSVD3), 112*4882a593Smuzhiyun PIN(DAP4_DOUT_PJ6, I2S4B, RSVD1, RSVD2, RSVD3), 113*4882a593Smuzhiyun PIN(DAP4_SCLK_PJ7, I2S4B, RSVD1, RSVD2, RSVD3), 114*4882a593Smuzhiyun PIN(CAM1_MCLK_PS0, EXTPERIPH3, RSVD1, RSVD2, RSVD3), 115*4882a593Smuzhiyun PIN(CAM2_MCLK_PS1, EXTPERIPH3, RSVD1, RSVD2, RSVD3), 116*4882a593Smuzhiyun PIN(JTAG_RTCK, JTAG, RSVD1, RSVD2, RSVD3), 117*4882a593Smuzhiyun PIN(CLK_32K_IN, CLK, RSVD1, RSVD2, RSVD3), 118*4882a593Smuzhiyun PIN(CLK_32K_OUT_PY5, SOC, BLINK, RSVD2, RSVD3), 119*4882a593Smuzhiyun PIN(BATT_BCL, BCL, RSVD1, RSVD2, RSVD3), 120*4882a593Smuzhiyun PIN(CLK_REQ, SYS, RSVD1, RSVD2, RSVD3), 121*4882a593Smuzhiyun PIN(CPU_PWR_REQ, CPU, RSVD1, RSVD2, RSVD3), 122*4882a593Smuzhiyun PIN(PWR_INT_N, PMI, RSVD1, RSVD2, RSVD3), 123*4882a593Smuzhiyun PIN(SHUTDOWN, SHUTDOWN, RSVD1, RSVD2, RSVD3), 124*4882a593Smuzhiyun PIN(CORE_PWR_REQ, CORE, RSVD1, RSVD2, RSVD3), 125*4882a593Smuzhiyun PIN(AUD_MCLK_PBB0, AUD, RSVD1, RSVD2, RSVD3), 126*4882a593Smuzhiyun PIN(DVFS_PWM_PBB1, RSVD0, CLDVFS, SPI3, RSVD3), 127*4882a593Smuzhiyun PIN(DVFS_CLK_PBB2, RSVD0, CLDVFS, SPI3, RSVD3), 128*4882a593Smuzhiyun PIN(GPIO_X1_AUD_PBB3, RSVD0, RSVD1, SPI3, RSVD3), 129*4882a593Smuzhiyun PIN(GPIO_X3_AUD_PBB4, RSVD0, RSVD1, SPI3, RSVD3), 130*4882a593Smuzhiyun PIN(PCC7, RSVD0, RSVD1, RSVD2, RSVD3), 131*4882a593Smuzhiyun PIN(HDMI_CEC_PCC0, CEC, RSVD1, RSVD2, RSVD3), 132*4882a593Smuzhiyun PIN(HDMI_INT_DP_HPD_PCC1, DP, RSVD1, RSVD2, RSVD3), 133*4882a593Smuzhiyun PIN(SPDIF_OUT_PCC2, SPDIF, RSVD1, RSVD2, RSVD3), 134*4882a593Smuzhiyun PIN(SPDIF_IN_PCC3, SPDIF, RSVD1, RSVD2, RSVD3), 135*4882a593Smuzhiyun PIN(USB_VBUS_EN0_PCC4, USB, RSVD1, RSVD2, RSVD3), 136*4882a593Smuzhiyun PIN(USB_VBUS_EN1_PCC5, USB, RSVD1, RSVD2, RSVD3), 137*4882a593Smuzhiyun PIN(DP_HPD0_PCC6, DP, RSVD1, RSVD2, RSVD3), 138*4882a593Smuzhiyun PIN(WIFI_EN_PH0, RSVD0, RSVD1, RSVD2, RSVD3), 139*4882a593Smuzhiyun PIN(WIFI_RST_PH1, RSVD0, RSVD1, RSVD2, RSVD3), 140*4882a593Smuzhiyun PIN(WIFI_WAKE_AP_PH2, RSVD0, RSVD1, RSVD2, RSVD3), 141*4882a593Smuzhiyun PIN(AP_WAKE_BT_PH3, RSVD0, UARTB, SPDIF, RSVD3), 142*4882a593Smuzhiyun PIN(BT_RST_PH4, RSVD0, UARTB, SPDIF, RSVD3), 143*4882a593Smuzhiyun PIN(BT_WAKE_AP_PH5, RSVD0, RSVD1, RSVD2, RSVD3), 144*4882a593Smuzhiyun PIN(AP_WAKE_NFC_PH7, RSVD0, RSVD1, RSVD2, RSVD3), 145*4882a593Smuzhiyun PIN(NFC_EN_PI0, RSVD0, RSVD1, RSVD2, RSVD3), 146*4882a593Smuzhiyun PIN(NFC_INT_PI1, RSVD0, RSVD1, RSVD2, RSVD3), 147*4882a593Smuzhiyun PIN(GPS_EN_PI2, RSVD0, RSVD1, RSVD2, RSVD3), 148*4882a593Smuzhiyun PIN(GPS_RST_PI3, RSVD0, RSVD1, RSVD2, RSVD3), 149*4882a593Smuzhiyun PIN(CAM_RST_PS4, VGP1, RSVD1, RSVD2, RSVD3), 150*4882a593Smuzhiyun PIN(CAM_AF_EN_PS5, VIMCLK, VGP2, RSVD2, RSVD3), 151*4882a593Smuzhiyun PIN(CAM_FLASH_EN_PS6, VIMCLK, VGP3, RSVD2, RSVD3), 152*4882a593Smuzhiyun PIN(CAM1_PWDN_PS7, VGP4, RSVD1, RSVD2, RSVD3), 153*4882a593Smuzhiyun PIN(CAM2_PWDN_PT0, VGP5, RSVD1, RSVD2, RSVD3), 154*4882a593Smuzhiyun PIN(CAM1_STROBE_PT1, VGP6, RSVD1, RSVD2, RSVD3), 155*4882a593Smuzhiyun PIN(LCD_TE_PY2, DISPLAYA, RSVD1, RSVD2, RSVD3), 156*4882a593Smuzhiyun PIN(LCD_BL_PWM_PV0, DISPLAYA, PWM0, SOR0, RSVD3), 157*4882a593Smuzhiyun PIN(LCD_BL_EN_PV1, RSVD0, RSVD1, RSVD2, RSVD3), 158*4882a593Smuzhiyun PIN(LCD_RST_PV2, RSVD0, RSVD1, RSVD2, RSVD3), 159*4882a593Smuzhiyun PIN(LCD_GPIO1_PV3, DISPLAYB, RSVD1, RSVD2, RSVD3), 160*4882a593Smuzhiyun PIN(LCD_GPIO2_PV4, DISPLAYB, PWM1, RSVD2, SOR1), 161*4882a593Smuzhiyun PIN(AP_READY_PV5, RSVD0, RSVD1, RSVD2, RSVD3), 162*4882a593Smuzhiyun PIN(TOUCH_RST_PV6, RSVD0, RSVD1, RSVD2, RSVD3), 163*4882a593Smuzhiyun PIN(TOUCH_CLK_PV7, TOUCH, RSVD1, RSVD2, RSVD3), 164*4882a593Smuzhiyun PIN(MODEM_WAKE_AP_PX0, RSVD0, RSVD1, RSVD2, RSVD3), 165*4882a593Smuzhiyun PIN(TOUCH_INT_PX1, RSVD0, RSVD1, RSVD2, RSVD3), 166*4882a593Smuzhiyun PIN(MOTION_INT_PX2, RSVD0, RSVD1, RSVD2, RSVD3), 167*4882a593Smuzhiyun PIN(ALS_PROX_INT_PX3, RSVD0, RSVD1, RSVD2, RSVD3), 168*4882a593Smuzhiyun PIN(TEMP_ALERT_PX4, RSVD0, RSVD1, RSVD2, RSVD3), 169*4882a593Smuzhiyun PIN(BUTTON_POWER_ON_PX5, RSVD0, RSVD1, RSVD2, RSVD3), 170*4882a593Smuzhiyun PIN(BUTTON_VOL_UP_PX6, RSVD0, RSVD1, RSVD2, RSVD3), 171*4882a593Smuzhiyun PIN(BUTTON_VOL_DOWN_PX7, RSVD0, RSVD1, RSVD2, RSVD3), 172*4882a593Smuzhiyun PIN(BUTTON_SLIDE_SW_PY0, RSVD0, RSVD1, RSVD2, RSVD3), 173*4882a593Smuzhiyun PIN(BUTTON_HOME_PY1, RSVD0, RSVD1, RSVD2, RSVD3), 174*4882a593Smuzhiyun PIN(PA6, SATA, RSVD1, RSVD2, RSVD3), 175*4882a593Smuzhiyun PIN(PE6, RSVD0, I2S5A, PWM2, RSVD3), 176*4882a593Smuzhiyun PIN(PE7, RSVD0, I2S5A, PWM3, RSVD3), 177*4882a593Smuzhiyun PIN(PH6, RSVD0, RSVD1, RSVD2, RSVD3), 178*4882a593Smuzhiyun PIN(PK0, IQC0, I2S5B, RSVD2, RSVD3), 179*4882a593Smuzhiyun PIN(PK1, IQC0, I2S5B, RSVD2, RSVD3), 180*4882a593Smuzhiyun PIN(PK2, IQC0, I2S5B, RSVD2, RSVD3), 181*4882a593Smuzhiyun PIN(PK3, IQC0, I2S5B, RSVD2, RSVD3), 182*4882a593Smuzhiyun PIN(PK4, IQC1, RSVD1, RSVD2, RSVD3), 183*4882a593Smuzhiyun PIN(PK5, IQC1, RSVD1, RSVD2, RSVD3), 184*4882a593Smuzhiyun PIN(PK6, IQC1, RSVD1, RSVD2, RSVD3), 185*4882a593Smuzhiyun PIN(PK7, IQC1, RSVD1, RSVD2, RSVD3), 186*4882a593Smuzhiyun PIN(PL0, RSVD0, RSVD1, RSVD2, RSVD3), 187*4882a593Smuzhiyun PIN(PL1, SOC, RSVD1, RSVD2, RSVD3), 188*4882a593Smuzhiyun PIN(PZ0, VIMCLK2, RSVD1, RSVD2, RSVD3), 189*4882a593Smuzhiyun PIN(PZ1, VIMCLK2, SDMMC1, RSVD2, RSVD3), 190*4882a593Smuzhiyun PIN(PZ2, SDMMC3, CCLA, RSVD2, RSVD3), 191*4882a593Smuzhiyun PIN(PZ3, SDMMC3, RSVD1, RSVD2, RSVD3), 192*4882a593Smuzhiyun PIN(PZ4, SDMMC1, RSVD1, RSVD2, RSVD3), 193*4882a593Smuzhiyun PIN(PZ5, SOC, RSVD1, RSVD2, RSVD3), 194*4882a593Smuzhiyun }; 195*4882a593Smuzhiyun const struct pmux_pingrp_desc *tegra_soc_pingroups = tegra210_pingroups; 196