1*542baf77SAaron Kling // SPDX-License-Identifier: GPL-2.0+ 2*542baf77SAaron Kling /* 3*542baf77SAaron Kling * Pinctrl data for the NVIDIA Tegra186 pinmux 4*542baf77SAaron Kling * 5*542baf77SAaron Kling * Copyright (c) 2021, NVIDIA CORPORATION. All rights reserved. 6*542baf77SAaron Kling * 7*542baf77SAaron Kling * This program is free software; you can redistribute it and/or modify it 8*542baf77SAaron Kling * under the terms and conditions of the GNU General Public License, 9*542baf77SAaron Kling * version 2, as published by the Free Software Foundation. 10*542baf77SAaron Kling * 11*542baf77SAaron Kling * This program is distributed in the hope it will be useful, but WITHOUT 12*542baf77SAaron Kling * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or 13*542baf77SAaron Kling * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for 14*542baf77SAaron Kling * more details. 15*542baf77SAaron Kling */ 16*542baf77SAaron Kling 17*542baf77SAaron Kling #include <linux/init.h> 18*542baf77SAaron Kling #include <linux/of.h> 19*542baf77SAaron Kling #include <linux/platform_device.h> 20*542baf77SAaron Kling #include <linux/pinctrl/pinctrl.h> 21*542baf77SAaron Kling #include <linux/pinctrl/pinmux.h> 22*542baf77SAaron Kling 23*542baf77SAaron Kling #include "pinctrl-tegra.h" 24*542baf77SAaron Kling 25*542baf77SAaron Kling /* Define unique ID for each pins */ 26*542baf77SAaron Kling enum { 27*542baf77SAaron Kling TEGRA_PIN_PEX_L0_RST_N_PA0, 28*542baf77SAaron Kling TEGRA_PIN_PEX_L0_CLKREQ_N_PA1, 29*542baf77SAaron Kling TEGRA_PIN_PEX_WAKE_N_PA2, 30*542baf77SAaron Kling TEGRA_PIN_PEX_L1_RST_N_PA3, 31*542baf77SAaron Kling TEGRA_PIN_PEX_L1_CLKREQ_N_PA4, 32*542baf77SAaron Kling TEGRA_PIN_PEX_L2_RST_N_PA5, 33*542baf77SAaron Kling TEGRA_PIN_PEX_L2_CLKREQ_N_PA6, 34*542baf77SAaron Kling TEGRA_PIN_UART4_TX_PB0, 35*542baf77SAaron Kling TEGRA_PIN_UART4_RX_PB1, 36*542baf77SAaron Kling TEGRA_PIN_UART4_RTS_PB2, 37*542baf77SAaron Kling TEGRA_PIN_UART4_CTS_PB3, 38*542baf77SAaron Kling TEGRA_PIN_GPIO_WAN1_PB4, 39*542baf77SAaron Kling TEGRA_PIN_GPIO_WAN2_PB5, 40*542baf77SAaron Kling TEGRA_PIN_GPIO_WAN3_PB6, 41*542baf77SAaron Kling TEGRA_PIN_GPIO_WAN4_PC0, 42*542baf77SAaron Kling TEGRA_PIN_DAP2_SCLK_PC1, 43*542baf77SAaron Kling TEGRA_PIN_DAP2_DOUT_PC2, 44*542baf77SAaron Kling TEGRA_PIN_DAP2_DIN_PC3, 45*542baf77SAaron Kling TEGRA_PIN_DAP2_FS_PC4, 46*542baf77SAaron Kling TEGRA_PIN_GEN1_I2C_SCL_PC5, 47*542baf77SAaron Kling TEGRA_PIN_GEN1_I2C_SDA_PC6, 48*542baf77SAaron Kling TEGRA_PIN_SDMMC1_CLK_PD0, 49*542baf77SAaron Kling TEGRA_PIN_SDMMC1_CMD_PD1, 50*542baf77SAaron Kling TEGRA_PIN_SDMMC1_DAT0_PD2, 51*542baf77SAaron Kling TEGRA_PIN_SDMMC1_DAT1_PD3, 52*542baf77SAaron Kling TEGRA_PIN_SDMMC1_DAT2_PD4, 53*542baf77SAaron Kling TEGRA_PIN_SDMMC1_DAT3_PD5, 54*542baf77SAaron Kling TEGRA_PIN_EQOS_TXC_PE0, 55*542baf77SAaron Kling TEGRA_PIN_EQOS_TD0_PE1, 56*542baf77SAaron Kling TEGRA_PIN_EQOS_TD1_PE2, 57*542baf77SAaron Kling TEGRA_PIN_EQOS_TD2_PE3, 58*542baf77SAaron Kling TEGRA_PIN_EQOS_TD3_PE4, 59*542baf77SAaron Kling TEGRA_PIN_EQOS_TX_CTL_PE5, 60*542baf77SAaron Kling TEGRA_PIN_EQOS_RD0_PE6, 61*542baf77SAaron Kling TEGRA_PIN_EQOS_RD1_PE7, 62*542baf77SAaron Kling TEGRA_PIN_EQOS_RD2_PF0, 63*542baf77SAaron Kling TEGRA_PIN_EQOS_RD3_PF1, 64*542baf77SAaron Kling TEGRA_PIN_EQOS_RX_CTL_PF2, 65*542baf77SAaron Kling TEGRA_PIN_EQOS_RXC_PF3, 66*542baf77SAaron Kling TEGRA_PIN_EQOS_MDIO_PF4, 67*542baf77SAaron Kling TEGRA_PIN_EQOS_MDC_PF5, 68*542baf77SAaron Kling TEGRA_PIN_SDMMC3_CLK_PG0, 69*542baf77SAaron Kling TEGRA_PIN_SDMMC3_CMD_PG1, 70*542baf77SAaron Kling TEGRA_PIN_SDMMC3_DAT0_PG2, 71*542baf77SAaron Kling TEGRA_PIN_SDMMC3_DAT1_PG3, 72*542baf77SAaron Kling TEGRA_PIN_SDMMC3_DAT2_PG4, 73*542baf77SAaron Kling TEGRA_PIN_SDMMC3_DAT3_PG5, 74*542baf77SAaron Kling TEGRA_PIN_GPIO_WAN5_PH0, 75*542baf77SAaron Kling TEGRA_PIN_GPIO_WAN6_PH1, 76*542baf77SAaron Kling TEGRA_PIN_GPIO_WAN7_PH2, 77*542baf77SAaron Kling TEGRA_PIN_GPIO_WAN8_PH3, 78*542baf77SAaron Kling TEGRA_PIN_BCPU_PWR_REQ_PH4, 79*542baf77SAaron Kling TEGRA_PIN_MCPU_PWR_REQ_PH5, 80*542baf77SAaron Kling TEGRA_PIN_GPU_PWR_REQ_PH6, 81*542baf77SAaron Kling TEGRA_PIN_GPIO_PQ0_PI0, 82*542baf77SAaron Kling TEGRA_PIN_GPIO_PQ1_PI1, 83*542baf77SAaron Kling TEGRA_PIN_GPIO_PQ2_PI2, 84*542baf77SAaron Kling TEGRA_PIN_GPIO_PQ3_PI3, 85*542baf77SAaron Kling TEGRA_PIN_GPIO_PQ4_PI4, 86*542baf77SAaron Kling TEGRA_PIN_GPIO_PQ5_PI5, 87*542baf77SAaron Kling TEGRA_PIN_GPIO_PQ6_PI6, 88*542baf77SAaron Kling TEGRA_PIN_GPIO_PQ7_PI7, 89*542baf77SAaron Kling TEGRA_PIN_DAP1_SCLK_PJ0, 90*542baf77SAaron Kling TEGRA_PIN_DAP1_DOUT_PJ1, 91*542baf77SAaron Kling TEGRA_PIN_DAP1_DIN_PJ2, 92*542baf77SAaron Kling TEGRA_PIN_DAP1_FS_PJ3, 93*542baf77SAaron Kling TEGRA_PIN_AUD_MCLK_PJ4, 94*542baf77SAaron Kling TEGRA_PIN_GPIO_AUD0_PJ5, 95*542baf77SAaron Kling TEGRA_PIN_GPIO_AUD1_PJ6, 96*542baf77SAaron Kling TEGRA_PIN_GPIO_AUD2_PJ7, 97*542baf77SAaron Kling TEGRA_PIN_GPIO_AUD3_PK0, 98*542baf77SAaron Kling TEGRA_PIN_GEN7_I2C_SCL_PL0, 99*542baf77SAaron Kling TEGRA_PIN_GEN7_I2C_SDA_PL1, 100*542baf77SAaron Kling TEGRA_PIN_GEN9_I2C_SCL_PL2, 101*542baf77SAaron Kling TEGRA_PIN_GEN9_I2C_SDA_PL3, 102*542baf77SAaron Kling TEGRA_PIN_USB_VBUS_EN0_PL4, 103*542baf77SAaron Kling TEGRA_PIN_USB_VBUS_EN1_PL5, 104*542baf77SAaron Kling TEGRA_PIN_GP_PWM6_PL6, 105*542baf77SAaron Kling TEGRA_PIN_GP_PWM7_PL7, 106*542baf77SAaron Kling TEGRA_PIN_DMIC1_DAT_PM0, 107*542baf77SAaron Kling TEGRA_PIN_DMIC1_CLK_PM1, 108*542baf77SAaron Kling TEGRA_PIN_DMIC2_DAT_PM2, 109*542baf77SAaron Kling TEGRA_PIN_DMIC2_CLK_PM3, 110*542baf77SAaron Kling TEGRA_PIN_DMIC4_DAT_PM4, 111*542baf77SAaron Kling TEGRA_PIN_DMIC4_CLK_PM5, 112*542baf77SAaron Kling TEGRA_PIN_GPIO_CAM1_PN0, 113*542baf77SAaron Kling TEGRA_PIN_GPIO_CAM2_PN1, 114*542baf77SAaron Kling TEGRA_PIN_GPIO_CAM3_PN2, 115*542baf77SAaron Kling TEGRA_PIN_GPIO_CAM4_PN3, 116*542baf77SAaron Kling TEGRA_PIN_GPIO_CAM5_PN4, 117*542baf77SAaron Kling TEGRA_PIN_GPIO_CAM6_PN5, 118*542baf77SAaron Kling TEGRA_PIN_GPIO_CAM7_PN6, 119*542baf77SAaron Kling TEGRA_PIN_EXTPERIPH1_CLK_PO0, 120*542baf77SAaron Kling TEGRA_PIN_EXTPERIPH2_CLK_PO1, 121*542baf77SAaron Kling TEGRA_PIN_CAM_I2C_SCL_PO2, 122*542baf77SAaron Kling TEGRA_PIN_CAM_I2C_SDA_PO3, 123*542baf77SAaron Kling TEGRA_PIN_DP_AUX_CH0_HPD_PP0, 124*542baf77SAaron Kling TEGRA_PIN_DP_AUX_CH1_HPD_PP1, 125*542baf77SAaron Kling TEGRA_PIN_HDMI_CEC_PP2, 126*542baf77SAaron Kling TEGRA_PIN_GPIO_EDP0_PP3, 127*542baf77SAaron Kling TEGRA_PIN_GPIO_EDP1_PP4, 128*542baf77SAaron Kling TEGRA_PIN_GPIO_EDP2_PP5, 129*542baf77SAaron Kling TEGRA_PIN_GPIO_EDP3_PP6, 130*542baf77SAaron Kling TEGRA_PIN_DIRECTDC1_CLK_PQ0, 131*542baf77SAaron Kling TEGRA_PIN_DIRECTDC1_IN_PQ1, 132*542baf77SAaron Kling TEGRA_PIN_DIRECTDC1_OUT0_PQ2, 133*542baf77SAaron Kling TEGRA_PIN_DIRECTDC1_OUT1_PQ3, 134*542baf77SAaron Kling TEGRA_PIN_DIRECTDC1_OUT2_PQ4, 135*542baf77SAaron Kling TEGRA_PIN_DIRECTDC1_OUT3_PQ5, 136*542baf77SAaron Kling TEGRA_PIN_QSPI_SCK_PR0, 137*542baf77SAaron Kling TEGRA_PIN_QSPI_IO0_PR1, 138*542baf77SAaron Kling TEGRA_PIN_QSPI_IO1_PR2, 139*542baf77SAaron Kling TEGRA_PIN_QSPI_IO2_PR3, 140*542baf77SAaron Kling TEGRA_PIN_QSPI_IO3_PR4, 141*542baf77SAaron Kling TEGRA_PIN_QSPI_CS_N_PR5, 142*542baf77SAaron Kling TEGRA_PIN_UART1_TX_PT0, 143*542baf77SAaron Kling TEGRA_PIN_UART1_RX_PT1, 144*542baf77SAaron Kling TEGRA_PIN_UART1_RTS_PT2, 145*542baf77SAaron Kling TEGRA_PIN_UART1_CTS_PT3, 146*542baf77SAaron Kling TEGRA_PIN_UART2_TX_PX0, 147*542baf77SAaron Kling TEGRA_PIN_UART2_RX_PX1, 148*542baf77SAaron Kling TEGRA_PIN_UART2_RTS_PX2, 149*542baf77SAaron Kling TEGRA_PIN_UART2_CTS_PX3, 150*542baf77SAaron Kling TEGRA_PIN_UART5_TX_PX4, 151*542baf77SAaron Kling TEGRA_PIN_UART5_RX_PX5, 152*542baf77SAaron Kling TEGRA_PIN_UART5_RTS_PX6, 153*542baf77SAaron Kling TEGRA_PIN_UART5_CTS_PX7, 154*542baf77SAaron Kling TEGRA_PIN_GPIO_MDM1_PY0, 155*542baf77SAaron Kling TEGRA_PIN_GPIO_MDM2_PY1, 156*542baf77SAaron Kling TEGRA_PIN_GPIO_MDM3_PY2, 157*542baf77SAaron Kling TEGRA_PIN_GPIO_MDM4_PY3, 158*542baf77SAaron Kling TEGRA_PIN_GPIO_MDM5_PY4, 159*542baf77SAaron Kling TEGRA_PIN_GPIO_MDM6_PY5, 160*542baf77SAaron Kling TEGRA_PIN_GPIO_MDM7_PY6, 161*542baf77SAaron Kling TEGRA_PIN_UFS0_REF_CLK_PBB0, 162*542baf77SAaron Kling TEGRA_PIN_UFS0_RST_PBB1, 163*542baf77SAaron Kling TEGRA_PIN_DAP4_SCLK_PCC0, 164*542baf77SAaron Kling TEGRA_PIN_DAP4_DOUT_PCC1, 165*542baf77SAaron Kling TEGRA_PIN_DAP4_DIN_PCC2, 166*542baf77SAaron Kling TEGRA_PIN_DAP4_FS_PCC3, 167*542baf77SAaron Kling TEGRA_PIN_DIRECTDC_COMP, 168*542baf77SAaron Kling TEGRA_PIN_SDMMC1_COMP, 169*542baf77SAaron Kling TEGRA_PIN_EQOS_COMP, 170*542baf77SAaron Kling TEGRA_PIN_SDMMC3_COMP, 171*542baf77SAaron Kling TEGRA_PIN_QSPI_COMP, 172*542baf77SAaron Kling }; 173*542baf77SAaron Kling 174*542baf77SAaron Kling enum { 175*542baf77SAaron Kling TEGRA_PIN_PWR_I2C_SCL_PS0, 176*542baf77SAaron Kling TEGRA_PIN_PWR_I2C_SDA_PS1, 177*542baf77SAaron Kling TEGRA_PIN_BATT_OC_PS2, 178*542baf77SAaron Kling TEGRA_PIN_SAFE_STATE_PS3, 179*542baf77SAaron Kling TEGRA_PIN_VCOMP_ALERT_PS4, 180*542baf77SAaron Kling TEGRA_PIN_GPIO_DIS0_PU0, 181*542baf77SAaron Kling TEGRA_PIN_GPIO_DIS1_PU1, 182*542baf77SAaron Kling TEGRA_PIN_GPIO_DIS2_PU2, 183*542baf77SAaron Kling TEGRA_PIN_GPIO_DIS3_PU3, 184*542baf77SAaron Kling TEGRA_PIN_GPIO_DIS4_PU4, 185*542baf77SAaron Kling TEGRA_PIN_GPIO_DIS5_PU5, 186*542baf77SAaron Kling TEGRA_PIN_GPIO_SEN0_PV0, 187*542baf77SAaron Kling TEGRA_PIN_GPIO_SEN1_PV1, 188*542baf77SAaron Kling TEGRA_PIN_GPIO_SEN2_PV2, 189*542baf77SAaron Kling TEGRA_PIN_GPIO_SEN3_PV3, 190*542baf77SAaron Kling TEGRA_PIN_GPIO_SEN4_PV4, 191*542baf77SAaron Kling TEGRA_PIN_GPIO_SEN5_PV5, 192*542baf77SAaron Kling TEGRA_PIN_GPIO_SEN6_PV6, 193*542baf77SAaron Kling TEGRA_PIN_GPIO_SEN7_PV7, 194*542baf77SAaron Kling TEGRA_PIN_GEN8_I2C_SCL_PW0, 195*542baf77SAaron Kling TEGRA_PIN_GEN8_I2C_SDA_PW1, 196*542baf77SAaron Kling TEGRA_PIN_UART3_TX_PW2, 197*542baf77SAaron Kling TEGRA_PIN_UART3_RX_PW3, 198*542baf77SAaron Kling TEGRA_PIN_UART3_RTS_PW4, 199*542baf77SAaron Kling TEGRA_PIN_UART3_CTS_PW5, 200*542baf77SAaron Kling TEGRA_PIN_UART7_TX_PW6, 201*542baf77SAaron Kling TEGRA_PIN_UART7_RX_PW7, 202*542baf77SAaron Kling TEGRA_PIN_CAN1_DOUT_PZ0, 203*542baf77SAaron Kling TEGRA_PIN_CAN1_DIN_PZ1, 204*542baf77SAaron Kling TEGRA_PIN_CAN0_DOUT_PZ2, 205*542baf77SAaron Kling TEGRA_PIN_CAN0_DIN_PZ3, 206*542baf77SAaron Kling TEGRA_PIN_CAN_GPIO0_PAA0, 207*542baf77SAaron Kling TEGRA_PIN_CAN_GPIO1_PAA1, 208*542baf77SAaron Kling TEGRA_PIN_CAN_GPIO2_PAA2, 209*542baf77SAaron Kling TEGRA_PIN_CAN_GPIO3_PAA3, 210*542baf77SAaron Kling TEGRA_PIN_CAN_GPIO4_PAA4, 211*542baf77SAaron Kling TEGRA_PIN_CAN_GPIO5_PAA5, 212*542baf77SAaron Kling TEGRA_PIN_CAN_GPIO6_PAA6, 213*542baf77SAaron Kling TEGRA_PIN_CAN_GPIO7_PAA7, 214*542baf77SAaron Kling TEGRA_PIN_GPIO_SEN8_PEE0, 215*542baf77SAaron Kling TEGRA_PIN_GPIO_SEN9_PEE1, 216*542baf77SAaron Kling TEGRA_PIN_TOUCH_CLK_PEE2, 217*542baf77SAaron Kling TEGRA_PIN_POWER_ON_PFF0, 218*542baf77SAaron Kling TEGRA_PIN_GPIO_SW1_PFF1, 219*542baf77SAaron Kling TEGRA_PIN_GPIO_SW2_PFF2, 220*542baf77SAaron Kling TEGRA_PIN_GPIO_SW3_PFF3, 221*542baf77SAaron Kling TEGRA_PIN_GPIO_SW4_PFF4, 222*542baf77SAaron Kling TEGRA_PIN_SHUTDOWN, 223*542baf77SAaron Kling TEGRA_PIN_PMU_INT, 224*542baf77SAaron Kling TEGRA_PIN_SOC_PWR_REQ, 225*542baf77SAaron Kling TEGRA_PIN_CLK_32K_IN, 226*542baf77SAaron Kling }; 227*542baf77SAaron Kling 228*542baf77SAaron Kling /* Table for pin descriptor */ 229*542baf77SAaron Kling static const struct pinctrl_pin_desc tegra186_pins[] = { 230*542baf77SAaron Kling PINCTRL_PIN(TEGRA_PIN_PEX_L0_RST_N_PA0, "PEX_L0_RST_N_PA0"), 231*542baf77SAaron Kling PINCTRL_PIN(TEGRA_PIN_PEX_L0_CLKREQ_N_PA1, "PEX_L0_CLKREQ_N_PA1"), 232*542baf77SAaron Kling PINCTRL_PIN(TEGRA_PIN_PEX_WAKE_N_PA2, "PEX_WAKE_N_PA2"), 233*542baf77SAaron Kling PINCTRL_PIN(TEGRA_PIN_PEX_L1_RST_N_PA3, "PEX_L1_RST_N_PA3"), 234*542baf77SAaron Kling PINCTRL_PIN(TEGRA_PIN_PEX_L1_CLKREQ_N_PA4, "PEX_L1_CLKREQ_N_PA4"), 235*542baf77SAaron Kling PINCTRL_PIN(TEGRA_PIN_PEX_L2_RST_N_PA5, "PEX_L2_RST_N_PA5"), 236*542baf77SAaron Kling PINCTRL_PIN(TEGRA_PIN_PEX_L2_CLKREQ_N_PA6, "PEX_L2_CLKREQ_N_PA6"), 237*542baf77SAaron Kling PINCTRL_PIN(TEGRA_PIN_UART4_TX_PB0, "UART4_TX_PB0"), 238*542baf77SAaron Kling PINCTRL_PIN(TEGRA_PIN_UART4_RX_PB1, "UART4_RX_PB1"), 239*542baf77SAaron Kling PINCTRL_PIN(TEGRA_PIN_UART4_RTS_PB2, "UART4_RTS_PB2"), 240*542baf77SAaron Kling PINCTRL_PIN(TEGRA_PIN_UART4_CTS_PB3, "UART4_CTS_PB3"), 241*542baf77SAaron Kling PINCTRL_PIN(TEGRA_PIN_GPIO_WAN1_PB4, "GPIO_WAN1_PB4"), 242*542baf77SAaron Kling PINCTRL_PIN(TEGRA_PIN_GPIO_WAN2_PB5, "GPIO_WAN2_PB5"), 243*542baf77SAaron Kling PINCTRL_PIN(TEGRA_PIN_GPIO_WAN3_PB6, "GPIO_WAN3_PB6"), 244*542baf77SAaron Kling PINCTRL_PIN(TEGRA_PIN_GPIO_WAN4_PC0, "GPIO_WAN4_PC0"), 245*542baf77SAaron Kling PINCTRL_PIN(TEGRA_PIN_DAP2_SCLK_PC1, "DAP2_SCLK_PC1"), 246*542baf77SAaron Kling PINCTRL_PIN(TEGRA_PIN_DAP2_DOUT_PC2, "DAP2_DOUT_PC2"), 247*542baf77SAaron Kling PINCTRL_PIN(TEGRA_PIN_DAP2_DIN_PC3, "DAP2_DIN_PC3"), 248*542baf77SAaron Kling PINCTRL_PIN(TEGRA_PIN_DAP2_FS_PC4, "DAP2_FS_PC4"), 249*542baf77SAaron Kling PINCTRL_PIN(TEGRA_PIN_GEN1_I2C_SCL_PC5, "GEN1_I2C_SCL_PC5"), 250*542baf77SAaron Kling PINCTRL_PIN(TEGRA_PIN_GEN1_I2C_SDA_PC6, "GEN1_I2C_SDA_PC6"), 251*542baf77SAaron Kling PINCTRL_PIN(TEGRA_PIN_SDMMC1_CLK_PD0, "SDMMC1_CLK_PD0"), 252*542baf77SAaron Kling PINCTRL_PIN(TEGRA_PIN_SDMMC1_CMD_PD1, "SDMMC1_CMD_PD1"), 253*542baf77SAaron Kling PINCTRL_PIN(TEGRA_PIN_SDMMC1_DAT0_PD2, "SDMMC1_DAT0_PD2"), 254*542baf77SAaron Kling PINCTRL_PIN(TEGRA_PIN_SDMMC1_DAT1_PD3, "SDMMC1_DAT1_PD3"), 255*542baf77SAaron Kling PINCTRL_PIN(TEGRA_PIN_SDMMC1_DAT2_PD4, "SDMMC1_DAT2_PD4"), 256*542baf77SAaron Kling PINCTRL_PIN(TEGRA_PIN_SDMMC1_DAT3_PD5, "SDMMC1_DAT3_PD5"), 257*542baf77SAaron Kling PINCTRL_PIN(TEGRA_PIN_EQOS_TXC_PE0, "EQOS_TXC_PE0"), 258*542baf77SAaron Kling PINCTRL_PIN(TEGRA_PIN_EQOS_TD0_PE1, "EQOS_TD0_PE1"), 259*542baf77SAaron Kling PINCTRL_PIN(TEGRA_PIN_EQOS_TD1_PE2, "EQOS_TD1_PE2"), 260*542baf77SAaron Kling PINCTRL_PIN(TEGRA_PIN_EQOS_TD2_PE3, "EQOS_TD2_PE3"), 261*542baf77SAaron Kling PINCTRL_PIN(TEGRA_PIN_EQOS_TD3_PE4, "EQOS_TD3_PE4"), 262*542baf77SAaron Kling PINCTRL_PIN(TEGRA_PIN_EQOS_TX_CTL_PE5, "EQOS_TX_CTL_PE5"), 263*542baf77SAaron Kling PINCTRL_PIN(TEGRA_PIN_EQOS_RD0_PE6, "EQOS_RD0_PE6"), 264*542baf77SAaron Kling PINCTRL_PIN(TEGRA_PIN_EQOS_RD1_PE7, "EQOS_RD1_PE7"), 265*542baf77SAaron Kling PINCTRL_PIN(TEGRA_PIN_EQOS_RD2_PF0, "EQOS_RD2_PF0"), 266*542baf77SAaron Kling PINCTRL_PIN(TEGRA_PIN_EQOS_RD3_PF1, "EQOS_RD3_PF1"), 267*542baf77SAaron Kling PINCTRL_PIN(TEGRA_PIN_EQOS_RX_CTL_PF2, "EQOS_RX_CTL_PF2"), 268*542baf77SAaron Kling PINCTRL_PIN(TEGRA_PIN_EQOS_RXC_PF3, "EQOS_RXC_PF3"), 269*542baf77SAaron Kling PINCTRL_PIN(TEGRA_PIN_EQOS_MDIO_PF4, "EQOS_MDIO_PF4"), 270*542baf77SAaron Kling PINCTRL_PIN(TEGRA_PIN_EQOS_MDC_PF5, "EQOS_MDC_PF5"), 271*542baf77SAaron Kling PINCTRL_PIN(TEGRA_PIN_SDMMC3_CLK_PG0, "SDMMC3_CLK_PG0"), 272*542baf77SAaron Kling PINCTRL_PIN(TEGRA_PIN_SDMMC3_CMD_PG1, "SDMMC3_CMD_PG1"), 273*542baf77SAaron Kling PINCTRL_PIN(TEGRA_PIN_SDMMC3_DAT0_PG2, "SDMMC3_DAT0_PG2"), 274*542baf77SAaron Kling PINCTRL_PIN(TEGRA_PIN_SDMMC3_DAT1_PG3, "SDMMC3_DAT1_PG3"), 275*542baf77SAaron Kling PINCTRL_PIN(TEGRA_PIN_SDMMC3_DAT2_PG4, "SDMMC3_DAT2_PG4"), 276*542baf77SAaron Kling PINCTRL_PIN(TEGRA_PIN_SDMMC3_DAT3_PG5, "SDMMC3_DAT3_PG5"), 277*542baf77SAaron Kling PINCTRL_PIN(TEGRA_PIN_GPIO_WAN5_PH0, "GPIO_WAN5_PH0"), 278*542baf77SAaron Kling PINCTRL_PIN(TEGRA_PIN_GPIO_WAN6_PH1, "GPIO_WAN6_PH1"), 279*542baf77SAaron Kling PINCTRL_PIN(TEGRA_PIN_GPIO_WAN7_PH2, "GPIO_WAN7_PH2"), 280*542baf77SAaron Kling PINCTRL_PIN(TEGRA_PIN_GPIO_WAN8_PH3, "GPIO_WAN8_PH3"), 281*542baf77SAaron Kling PINCTRL_PIN(TEGRA_PIN_BCPU_PWR_REQ_PH4, "BCPU_PWR_REQ_PH4"), 282*542baf77SAaron Kling PINCTRL_PIN(TEGRA_PIN_MCPU_PWR_REQ_PH5, "MCPU_PWR_REQ_PH5"), 283*542baf77SAaron Kling PINCTRL_PIN(TEGRA_PIN_GPU_PWR_REQ_PH6, "GPU_PWR_REQ_PH6"), 284*542baf77SAaron Kling PINCTRL_PIN(TEGRA_PIN_GPIO_PQ0_PI0, "GPIO_PQ0_PI0"), 285*542baf77SAaron Kling PINCTRL_PIN(TEGRA_PIN_GPIO_PQ1_PI1, "GPIO_PQ1_PI1"), 286*542baf77SAaron Kling PINCTRL_PIN(TEGRA_PIN_GPIO_PQ2_PI2, "GPIO_PQ2_PI2"), 287*542baf77SAaron Kling PINCTRL_PIN(TEGRA_PIN_GPIO_PQ3_PI3, "GPIO_PQ3_PI3"), 288*542baf77SAaron Kling PINCTRL_PIN(TEGRA_PIN_GPIO_PQ4_PI4, "GPIO_PQ4_PI4"), 289*542baf77SAaron Kling PINCTRL_PIN(TEGRA_PIN_GPIO_PQ5_PI5, "GPIO_PQ5_PI5"), 290*542baf77SAaron Kling PINCTRL_PIN(TEGRA_PIN_GPIO_PQ6_PI6, "GPIO_PQ6_PI6"), 291*542baf77SAaron Kling PINCTRL_PIN(TEGRA_PIN_GPIO_PQ7_PI7, "GPIO_PQ7_PI7"), 292*542baf77SAaron Kling PINCTRL_PIN(TEGRA_PIN_DAP1_SCLK_PJ0, "DAP1_SCLK_PJ0"), 293*542baf77SAaron Kling PINCTRL_PIN(TEGRA_PIN_DAP1_DOUT_PJ1, "DAP1_DOUT_PJ1"), 294*542baf77SAaron Kling PINCTRL_PIN(TEGRA_PIN_DAP1_DIN_PJ2, "DAP1_DIN_PJ2"), 295*542baf77SAaron Kling PINCTRL_PIN(TEGRA_PIN_DAP1_FS_PJ3, "DAP1_FS_PJ3"), 296*542baf77SAaron Kling PINCTRL_PIN(TEGRA_PIN_AUD_MCLK_PJ4, "AUD_MCLK_PJ4"), 297*542baf77SAaron Kling PINCTRL_PIN(TEGRA_PIN_GPIO_AUD0_PJ5, "GPIO_AUD0_PJ5"), 298*542baf77SAaron Kling PINCTRL_PIN(TEGRA_PIN_GPIO_AUD1_PJ6, "GPIO_AUD1_PJ6"), 299*542baf77SAaron Kling PINCTRL_PIN(TEGRA_PIN_GPIO_AUD2_PJ7, "GPIO_AUD2_PJ7"), 300*542baf77SAaron Kling PINCTRL_PIN(TEGRA_PIN_GPIO_AUD3_PK0, "GPIO_AUD3_PK0"), 301*542baf77SAaron Kling PINCTRL_PIN(TEGRA_PIN_GEN7_I2C_SCL_PL0, "GEN7_I2C_SCL_PL0"), 302*542baf77SAaron Kling PINCTRL_PIN(TEGRA_PIN_GEN7_I2C_SDA_PL1, "GEN7_I2C_SDA_PL1"), 303*542baf77SAaron Kling PINCTRL_PIN(TEGRA_PIN_GEN9_I2C_SCL_PL2, "GEN9_I2C_SCL_PL2"), 304*542baf77SAaron Kling PINCTRL_PIN(TEGRA_PIN_GEN9_I2C_SDA_PL3, "GEN9_I2C_SDA_PL3"), 305*542baf77SAaron Kling PINCTRL_PIN(TEGRA_PIN_USB_VBUS_EN0_PL4, "USB_VBUS_EN0_PL4"), 306*542baf77SAaron Kling PINCTRL_PIN(TEGRA_PIN_USB_VBUS_EN1_PL5, "USB_VBUS_EN1_PL5"), 307*542baf77SAaron Kling PINCTRL_PIN(TEGRA_PIN_GP_PWM6_PL6, "GP_PWM6_PL6"), 308*542baf77SAaron Kling PINCTRL_PIN(TEGRA_PIN_GP_PWM7_PL7, "GP_PWM7_PL7"), 309*542baf77SAaron Kling PINCTRL_PIN(TEGRA_PIN_DMIC1_DAT_PM0, "DMIC1_DAT_PM0"), 310*542baf77SAaron Kling PINCTRL_PIN(TEGRA_PIN_DMIC1_CLK_PM1, "DMIC1_CLK_PM1"), 311*542baf77SAaron Kling PINCTRL_PIN(TEGRA_PIN_DMIC2_DAT_PM2, "DMIC2_DAT_PM2"), 312*542baf77SAaron Kling PINCTRL_PIN(TEGRA_PIN_DMIC2_CLK_PM3, "DMIC2_CLK_PM3"), 313*542baf77SAaron Kling PINCTRL_PIN(TEGRA_PIN_DMIC4_DAT_PM4, "DMIC4_DAT_PM4"), 314*542baf77SAaron Kling PINCTRL_PIN(TEGRA_PIN_DMIC4_CLK_PM5, "DMIC4_CLK_PM5"), 315*542baf77SAaron Kling PINCTRL_PIN(TEGRA_PIN_GPIO_CAM1_PN0, "GPIO_CAM1_PN0"), 316*542baf77SAaron Kling PINCTRL_PIN(TEGRA_PIN_GPIO_CAM2_PN1, "GPIO_CAM2_PN1"), 317*542baf77SAaron Kling PINCTRL_PIN(TEGRA_PIN_GPIO_CAM3_PN2, "GPIO_CAM3_PN2"), 318*542baf77SAaron Kling PINCTRL_PIN(TEGRA_PIN_GPIO_CAM4_PN3, "GPIO_CAM4_PN3"), 319*542baf77SAaron Kling PINCTRL_PIN(TEGRA_PIN_GPIO_CAM5_PN4, "GPIO_CAM6_PN5"), 320*542baf77SAaron Kling PINCTRL_PIN(TEGRA_PIN_GPIO_CAM6_PN5, "GPIO_CAM6_PN5"), 321*542baf77SAaron Kling PINCTRL_PIN(TEGRA_PIN_GPIO_CAM7_PN6, "GPIO_CAM7_PN6"), 322*542baf77SAaron Kling PINCTRL_PIN(TEGRA_PIN_EXTPERIPH1_CLK_PO0, "EXTPERIPH1_CLK_PO0"), 323*542baf77SAaron Kling PINCTRL_PIN(TEGRA_PIN_EXTPERIPH2_CLK_PO1, "EXTPERIPH2_CLK_PO1"), 324*542baf77SAaron Kling PINCTRL_PIN(TEGRA_PIN_CAM_I2C_SCL_PO2, "CAM_I2C_SCL_PO2"), 325*542baf77SAaron Kling PINCTRL_PIN(TEGRA_PIN_CAM_I2C_SDA_PO3, "CAM_I2C_SDA_PO3"), 326*542baf77SAaron Kling PINCTRL_PIN(TEGRA_PIN_DP_AUX_CH0_HPD_PP0, "DP_AUX_CH0_HPD_PP0"), 327*542baf77SAaron Kling PINCTRL_PIN(TEGRA_PIN_DP_AUX_CH1_HPD_PP1, "DP_AUX_CH1_HPD_PP1"), 328*542baf77SAaron Kling PINCTRL_PIN(TEGRA_PIN_HDMI_CEC_PP2, "HDMI_CEC_PP2"), 329*542baf77SAaron Kling PINCTRL_PIN(TEGRA_PIN_GPIO_EDP0_PP3, "GPIO_EDP0_PP3"), 330*542baf77SAaron Kling PINCTRL_PIN(TEGRA_PIN_GPIO_EDP1_PP4, "GPIO_EDP1_PP4"), 331*542baf77SAaron Kling PINCTRL_PIN(TEGRA_PIN_GPIO_EDP2_PP5, "GPIO_EDP2_PP5"), 332*542baf77SAaron Kling PINCTRL_PIN(TEGRA_PIN_GPIO_EDP3_PP6, "GPIO_EDP3_PP6"), 333*542baf77SAaron Kling PINCTRL_PIN(TEGRA_PIN_DIRECTDC1_CLK_PQ0, "DIRECTDC1_CLK_PQ0"), 334*542baf77SAaron Kling PINCTRL_PIN(TEGRA_PIN_DIRECTDC1_IN_PQ1, "DIRECTDC1_IN_PQ1"), 335*542baf77SAaron Kling PINCTRL_PIN(TEGRA_PIN_DIRECTDC1_OUT0_PQ2, "DIRECTDC1_OUT0_PQ2"), 336*542baf77SAaron Kling PINCTRL_PIN(TEGRA_PIN_DIRECTDC1_OUT1_PQ3, "DIRECTDC1_OUT1_PQ3"), 337*542baf77SAaron Kling PINCTRL_PIN(TEGRA_PIN_DIRECTDC1_OUT2_PQ4, "DIRECTDC1_OUT2_PQ4"), 338*542baf77SAaron Kling PINCTRL_PIN(TEGRA_PIN_DIRECTDC1_OUT3_PQ5, "DIRECTDC1_OUT3_PQ5"), 339*542baf77SAaron Kling PINCTRL_PIN(TEGRA_PIN_QSPI_SCK_PR0, "QSPI_SCK_PR0"), 340*542baf77SAaron Kling PINCTRL_PIN(TEGRA_PIN_QSPI_IO0_PR1, "QSPI_IO0_PR1"), 341*542baf77SAaron Kling PINCTRL_PIN(TEGRA_PIN_QSPI_IO1_PR2, "QSPI_IO1_PR2"), 342*542baf77SAaron Kling PINCTRL_PIN(TEGRA_PIN_QSPI_IO2_PR3, "QSPI_IO2_PR3"), 343*542baf77SAaron Kling PINCTRL_PIN(TEGRA_PIN_QSPI_IO3_PR4, "QSPI_IO3_PR4"), 344*542baf77SAaron Kling PINCTRL_PIN(TEGRA_PIN_QSPI_CS_N_PR5, "QSPI_CS_N_PR5"), 345*542baf77SAaron Kling PINCTRL_PIN(TEGRA_PIN_UART1_TX_PT0, "UART1_TX_PT0"), 346*542baf77SAaron Kling PINCTRL_PIN(TEGRA_PIN_UART1_RX_PT1, "UART1_RX_PT1"), 347*542baf77SAaron Kling PINCTRL_PIN(TEGRA_PIN_UART1_RTS_PT2, "UART1_RTS_PT2"), 348*542baf77SAaron Kling PINCTRL_PIN(TEGRA_PIN_UART1_CTS_PT3, "UART1_CTS_PT3"), 349*542baf77SAaron Kling PINCTRL_PIN(TEGRA_PIN_UART2_TX_PX0, "UART2_TX_PX0"), 350*542baf77SAaron Kling PINCTRL_PIN(TEGRA_PIN_UART2_RX_PX1, "UART2_RX_PX1"), 351*542baf77SAaron Kling PINCTRL_PIN(TEGRA_PIN_UART2_RTS_PX2, "UART2_RTS_PX2"), 352*542baf77SAaron Kling PINCTRL_PIN(TEGRA_PIN_UART2_CTS_PX3, "UART2_CTS_PX3"), 353*542baf77SAaron Kling PINCTRL_PIN(TEGRA_PIN_UART5_TX_PX4, "UART5_TX_PX4"), 354*542baf77SAaron Kling PINCTRL_PIN(TEGRA_PIN_UART5_RX_PX5, "UART5_RX_PX5"), 355*542baf77SAaron Kling PINCTRL_PIN(TEGRA_PIN_UART5_RTS_PX6, "UART5_RTS_PX6"), 356*542baf77SAaron Kling PINCTRL_PIN(TEGRA_PIN_UART5_CTS_PX7, "UART5_CTS_PX7"), 357*542baf77SAaron Kling PINCTRL_PIN(TEGRA_PIN_GPIO_MDM1_PY0, "GPIO_MDM1_PY0"), 358*542baf77SAaron Kling PINCTRL_PIN(TEGRA_PIN_GPIO_MDM2_PY1, "GPIO_MDM2_PY1"), 359*542baf77SAaron Kling PINCTRL_PIN(TEGRA_PIN_GPIO_MDM3_PY2, "GPIO_MDM3_PY2"), 360*542baf77SAaron Kling PINCTRL_PIN(TEGRA_PIN_GPIO_MDM4_PY3, "GPIO_MDM4_PY3"), 361*542baf77SAaron Kling PINCTRL_PIN(TEGRA_PIN_GPIO_MDM5_PY4, "GPIO_MDM5_PY4"), 362*542baf77SAaron Kling PINCTRL_PIN(TEGRA_PIN_GPIO_MDM6_PY5, "GPIO_MDM6_PY5"), 363*542baf77SAaron Kling PINCTRL_PIN(TEGRA_PIN_GPIO_MDM7_PY6, "GPIO_MDM7_PY6"), 364*542baf77SAaron Kling PINCTRL_PIN(TEGRA_PIN_UFS0_REF_CLK_PBB0, "UFS0_REF_CLK_PBB0"), 365*542baf77SAaron Kling PINCTRL_PIN(TEGRA_PIN_UFS0_RST_PBB1, "UFS0_RST_PBB1"), 366*542baf77SAaron Kling PINCTRL_PIN(TEGRA_PIN_DAP4_SCLK_PCC0, "DAP4_SCLK_PCC0"), 367*542baf77SAaron Kling PINCTRL_PIN(TEGRA_PIN_DAP4_DOUT_PCC1, "DAP4_DOUT_PCC1"), 368*542baf77SAaron Kling PINCTRL_PIN(TEGRA_PIN_DAP4_DIN_PCC2, "DAP4_DIN_PCC2"), 369*542baf77SAaron Kling PINCTRL_PIN(TEGRA_PIN_DAP4_FS_PCC3, "DAP4_FS_PCC3"), 370*542baf77SAaron Kling PINCTRL_PIN(TEGRA_PIN_DIRECTDC_COMP, "DIRECTDC_COMP"), 371*542baf77SAaron Kling PINCTRL_PIN(TEGRA_PIN_SDMMC1_COMP, "SDMMC1_COMP"), 372*542baf77SAaron Kling PINCTRL_PIN(TEGRA_PIN_EQOS_COMP, "EQOS_COMP"), 373*542baf77SAaron Kling PINCTRL_PIN(TEGRA_PIN_SDMMC3_COMP, "SDMMC3_COMP"), 374*542baf77SAaron Kling PINCTRL_PIN(TEGRA_PIN_QSPI_COMP, "QSPI_COMP"), 375*542baf77SAaron Kling }; 376*542baf77SAaron Kling 377*542baf77SAaron Kling static const unsigned int pex_l0_rst_n_pa0_pins[] = { 378*542baf77SAaron Kling TEGRA_PIN_PEX_L0_RST_N_PA0, 379*542baf77SAaron Kling }; 380*542baf77SAaron Kling 381*542baf77SAaron Kling static const unsigned int pex_l0_clkreq_n_pa1_pins[] = { 382*542baf77SAaron Kling TEGRA_PIN_PEX_L0_CLKREQ_N_PA1, 383*542baf77SAaron Kling }; 384*542baf77SAaron Kling 385*542baf77SAaron Kling static const unsigned int pex_wake_n_pa2_pins[] = { 386*542baf77SAaron Kling TEGRA_PIN_PEX_WAKE_N_PA2, 387*542baf77SAaron Kling }; 388*542baf77SAaron Kling 389*542baf77SAaron Kling static const unsigned int pex_l1_rst_n_pa3_pins[] = { 390*542baf77SAaron Kling TEGRA_PIN_PEX_L1_RST_N_PA3, 391*542baf77SAaron Kling }; 392*542baf77SAaron Kling 393*542baf77SAaron Kling static const unsigned int pex_l1_clkreq_n_pa4_pins[] = { 394*542baf77SAaron Kling TEGRA_PIN_PEX_L1_CLKREQ_N_PA4, 395*542baf77SAaron Kling }; 396*542baf77SAaron Kling 397*542baf77SAaron Kling static const unsigned int pex_l2_rst_n_pa5_pins[] = { 398*542baf77SAaron Kling TEGRA_PIN_PEX_L2_RST_N_PA5, 399*542baf77SAaron Kling }; 400*542baf77SAaron Kling 401*542baf77SAaron Kling static const unsigned int pex_l2_clkreq_n_pa6_pins[] = { 402*542baf77SAaron Kling TEGRA_PIN_PEX_L2_CLKREQ_N_PA6, 403*542baf77SAaron Kling }; 404*542baf77SAaron Kling 405*542baf77SAaron Kling static const unsigned int uart4_tx_pb0_pins[] = { 406*542baf77SAaron Kling TEGRA_PIN_UART4_TX_PB0, 407*542baf77SAaron Kling }; 408*542baf77SAaron Kling 409*542baf77SAaron Kling static const unsigned int uart4_rx_pb1_pins[] = { 410*542baf77SAaron Kling TEGRA_PIN_UART4_RX_PB1, 411*542baf77SAaron Kling }; 412*542baf77SAaron Kling 413*542baf77SAaron Kling static const unsigned int uart4_rts_pb2_pins[] = { 414*542baf77SAaron Kling TEGRA_PIN_UART4_RTS_PB2, 415*542baf77SAaron Kling }; 416*542baf77SAaron Kling 417*542baf77SAaron Kling static const unsigned int uart4_cts_pb3_pins[] = { 418*542baf77SAaron Kling TEGRA_PIN_UART4_CTS_PB3, 419*542baf77SAaron Kling }; 420*542baf77SAaron Kling 421*542baf77SAaron Kling static const unsigned int gpio_wan1_pb4_pins[] = { 422*542baf77SAaron Kling TEGRA_PIN_GPIO_WAN1_PB4, 423*542baf77SAaron Kling }; 424*542baf77SAaron Kling 425*542baf77SAaron Kling static const unsigned int gpio_wan2_pb5_pins[] = { 426*542baf77SAaron Kling TEGRA_PIN_GPIO_WAN2_PB5, 427*542baf77SAaron Kling }; 428*542baf77SAaron Kling 429*542baf77SAaron Kling static const unsigned int gpio_wan3_pb6_pins[] = { 430*542baf77SAaron Kling TEGRA_PIN_GPIO_WAN3_PB6, 431*542baf77SAaron Kling }; 432*542baf77SAaron Kling 433*542baf77SAaron Kling static const unsigned int gpio_wan4_pc0_pins[] = { 434*542baf77SAaron Kling TEGRA_PIN_GPIO_WAN4_PC0, 435*542baf77SAaron Kling }; 436*542baf77SAaron Kling 437*542baf77SAaron Kling static const unsigned int dap2_sclk_pc1_pins[] = { 438*542baf77SAaron Kling TEGRA_PIN_DAP2_SCLK_PC1, 439*542baf77SAaron Kling }; 440*542baf77SAaron Kling 441*542baf77SAaron Kling static const unsigned int dap2_dout_pc2_pins[] = { 442*542baf77SAaron Kling TEGRA_PIN_DAP2_DOUT_PC2, 443*542baf77SAaron Kling }; 444*542baf77SAaron Kling 445*542baf77SAaron Kling static const unsigned int dap2_din_pc3_pins[] = { 446*542baf77SAaron Kling TEGRA_PIN_DAP2_DIN_PC3, 447*542baf77SAaron Kling }; 448*542baf77SAaron Kling 449*542baf77SAaron Kling static const unsigned int dap2_fs_pc4_pins[] = { 450*542baf77SAaron Kling TEGRA_PIN_DAP2_FS_PC4, 451*542baf77SAaron Kling }; 452*542baf77SAaron Kling 453*542baf77SAaron Kling static const unsigned int gen1_i2c_scl_pc5_pins[] = { 454*542baf77SAaron Kling TEGRA_PIN_GEN1_I2C_SCL_PC5, 455*542baf77SAaron Kling }; 456*542baf77SAaron Kling 457*542baf77SAaron Kling static const unsigned int gen1_i2c_sda_pc6_pins[] = { 458*542baf77SAaron Kling TEGRA_PIN_GEN1_I2C_SDA_PC6, 459*542baf77SAaron Kling }; 460*542baf77SAaron Kling 461*542baf77SAaron Kling static const unsigned int sdmmc1_clk_pd0_pins[] = { 462*542baf77SAaron Kling TEGRA_PIN_SDMMC1_CLK_PD0, 463*542baf77SAaron Kling }; 464*542baf77SAaron Kling 465*542baf77SAaron Kling static const unsigned int sdmmc1_cmd_pd1_pins[] = { 466*542baf77SAaron Kling TEGRA_PIN_SDMMC1_CMD_PD1, 467*542baf77SAaron Kling }; 468*542baf77SAaron Kling 469*542baf77SAaron Kling static const unsigned int sdmmc1_dat0_pd2_pins[] = { 470*542baf77SAaron Kling TEGRA_PIN_SDMMC1_DAT0_PD2, 471*542baf77SAaron Kling }; 472*542baf77SAaron Kling 473*542baf77SAaron Kling static const unsigned int sdmmc1_dat1_pd3_pins[] = { 474*542baf77SAaron Kling TEGRA_PIN_SDMMC1_DAT1_PD3, 475*542baf77SAaron Kling }; 476*542baf77SAaron Kling 477*542baf77SAaron Kling static const unsigned int sdmmc1_dat2_pd4_pins[] = { 478*542baf77SAaron Kling TEGRA_PIN_SDMMC1_DAT2_PD4, 479*542baf77SAaron Kling }; 480*542baf77SAaron Kling 481*542baf77SAaron Kling static const unsigned int sdmmc1_dat3_pd5_pins[] = { 482*542baf77SAaron Kling TEGRA_PIN_SDMMC1_DAT3_PD5, 483*542baf77SAaron Kling }; 484*542baf77SAaron Kling 485*542baf77SAaron Kling static const unsigned int eqos_txc_pe0_pins[] = { 486*542baf77SAaron Kling TEGRA_PIN_EQOS_TXC_PE0, 487*542baf77SAaron Kling }; 488*542baf77SAaron Kling 489*542baf77SAaron Kling static const unsigned int eqos_td0_pe1_pins[] = { 490*542baf77SAaron Kling TEGRA_PIN_EQOS_TD0_PE1, 491*542baf77SAaron Kling }; 492*542baf77SAaron Kling 493*542baf77SAaron Kling static const unsigned int eqos_td1_pe2_pins[] = { 494*542baf77SAaron Kling TEGRA_PIN_EQOS_TD1_PE2, 495*542baf77SAaron Kling }; 496*542baf77SAaron Kling 497*542baf77SAaron Kling static const unsigned int eqos_td2_pe3_pins[] = { 498*542baf77SAaron Kling TEGRA_PIN_EQOS_TD2_PE3, 499*542baf77SAaron Kling }; 500*542baf77SAaron Kling 501*542baf77SAaron Kling static const unsigned int eqos_td3_pe4_pins[] = { 502*542baf77SAaron Kling TEGRA_PIN_EQOS_TD3_PE4, 503*542baf77SAaron Kling }; 504*542baf77SAaron Kling 505*542baf77SAaron Kling static const unsigned int eqos_tx_ctl_pe5_pins[] = { 506*542baf77SAaron Kling TEGRA_PIN_EQOS_TX_CTL_PE5, 507*542baf77SAaron Kling }; 508*542baf77SAaron Kling 509*542baf77SAaron Kling static const unsigned int eqos_rd0_pe6_pins[] = { 510*542baf77SAaron Kling TEGRA_PIN_EQOS_RD0_PE6, 511*542baf77SAaron Kling }; 512*542baf77SAaron Kling 513*542baf77SAaron Kling static const unsigned int eqos_rd1_pe7_pins[] = { 514*542baf77SAaron Kling TEGRA_PIN_EQOS_RD1_PE7, 515*542baf77SAaron Kling }; 516*542baf77SAaron Kling 517*542baf77SAaron Kling static const unsigned int eqos_rd2_pf0_pins[] = { 518*542baf77SAaron Kling TEGRA_PIN_EQOS_RD2_PF0, 519*542baf77SAaron Kling }; 520*542baf77SAaron Kling 521*542baf77SAaron Kling static const unsigned int eqos_rd3_pf1_pins[] = { 522*542baf77SAaron Kling TEGRA_PIN_EQOS_RD3_PF1, 523*542baf77SAaron Kling }; 524*542baf77SAaron Kling 525*542baf77SAaron Kling static const unsigned int eqos_rx_ctl_pf2_pins[] = { 526*542baf77SAaron Kling TEGRA_PIN_EQOS_RX_CTL_PF2, 527*542baf77SAaron Kling }; 528*542baf77SAaron Kling 529*542baf77SAaron Kling static const unsigned int eqos_rxc_pf3_pins[] = { 530*542baf77SAaron Kling TEGRA_PIN_EQOS_RXC_PF3, 531*542baf77SAaron Kling }; 532*542baf77SAaron Kling 533*542baf77SAaron Kling static const unsigned int eqos_mdio_pf4_pins[] = { 534*542baf77SAaron Kling TEGRA_PIN_EQOS_MDIO_PF4, 535*542baf77SAaron Kling }; 536*542baf77SAaron Kling 537*542baf77SAaron Kling static const unsigned int eqos_mdc_pf5_pins[] = { 538*542baf77SAaron Kling TEGRA_PIN_EQOS_MDC_PF5, 539*542baf77SAaron Kling }; 540*542baf77SAaron Kling 541*542baf77SAaron Kling static const unsigned int sdmmc3_clk_pg0_pins[] = { 542*542baf77SAaron Kling TEGRA_PIN_SDMMC3_CLK_PG0, 543*542baf77SAaron Kling }; 544*542baf77SAaron Kling 545*542baf77SAaron Kling static const unsigned int sdmmc3_cmd_pg1_pins[] = { 546*542baf77SAaron Kling TEGRA_PIN_SDMMC3_CMD_PG1, 547*542baf77SAaron Kling }; 548*542baf77SAaron Kling 549*542baf77SAaron Kling static const unsigned int sdmmc3_dat0_pg2_pins[] = { 550*542baf77SAaron Kling TEGRA_PIN_SDMMC3_DAT0_PG2, 551*542baf77SAaron Kling }; 552*542baf77SAaron Kling 553*542baf77SAaron Kling static const unsigned int sdmmc3_dat1_pg3_pins[] = { 554*542baf77SAaron Kling TEGRA_PIN_SDMMC3_DAT1_PG3, 555*542baf77SAaron Kling }; 556*542baf77SAaron Kling 557*542baf77SAaron Kling static const unsigned int sdmmc3_dat2_pg4_pins[] = { 558*542baf77SAaron Kling TEGRA_PIN_SDMMC3_DAT2_PG4, 559*542baf77SAaron Kling }; 560*542baf77SAaron Kling 561*542baf77SAaron Kling static const unsigned int sdmmc3_dat3_pg5_pins[] = { 562*542baf77SAaron Kling TEGRA_PIN_SDMMC3_DAT3_PG5, 563*542baf77SAaron Kling }; 564*542baf77SAaron Kling 565*542baf77SAaron Kling static const unsigned int gpio_wan5_ph0_pins[] = { 566*542baf77SAaron Kling TEGRA_PIN_GPIO_WAN5_PH0, 567*542baf77SAaron Kling }; 568*542baf77SAaron Kling 569*542baf77SAaron Kling static const unsigned int gpio_wan6_ph1_pins[] = { 570*542baf77SAaron Kling TEGRA_PIN_GPIO_WAN6_PH1, 571*542baf77SAaron Kling }; 572*542baf77SAaron Kling 573*542baf77SAaron Kling static const unsigned int gpio_wan7_ph2_pins[] = { 574*542baf77SAaron Kling TEGRA_PIN_GPIO_WAN7_PH2, 575*542baf77SAaron Kling }; 576*542baf77SAaron Kling 577*542baf77SAaron Kling static const unsigned int gpio_wan8_ph3_pins[] = { 578*542baf77SAaron Kling TEGRA_PIN_GPIO_WAN8_PH3, 579*542baf77SAaron Kling }; 580*542baf77SAaron Kling 581*542baf77SAaron Kling static const unsigned int bcpu_pwr_req_ph4_pins[] = { 582*542baf77SAaron Kling TEGRA_PIN_BCPU_PWR_REQ_PH4, 583*542baf77SAaron Kling }; 584*542baf77SAaron Kling 585*542baf77SAaron Kling static const unsigned int mcpu_pwr_req_ph5_pins[] = { 586*542baf77SAaron Kling TEGRA_PIN_MCPU_PWR_REQ_PH5, 587*542baf77SAaron Kling }; 588*542baf77SAaron Kling 589*542baf77SAaron Kling static const unsigned int gpu_pwr_req_ph6_pins[] = { 590*542baf77SAaron Kling TEGRA_PIN_GPU_PWR_REQ_PH6, 591*542baf77SAaron Kling }; 592*542baf77SAaron Kling 593*542baf77SAaron Kling static const unsigned int gpio_pq0_pi0_pins[] = { 594*542baf77SAaron Kling TEGRA_PIN_GPIO_PQ0_PI0, 595*542baf77SAaron Kling }; 596*542baf77SAaron Kling 597*542baf77SAaron Kling static const unsigned int gpio_pq1_pi1_pins[] = { 598*542baf77SAaron Kling TEGRA_PIN_GPIO_PQ1_PI1, 599*542baf77SAaron Kling }; 600*542baf77SAaron Kling 601*542baf77SAaron Kling static const unsigned int gpio_pq2_pi2_pins[] = { 602*542baf77SAaron Kling TEGRA_PIN_GPIO_PQ2_PI2, 603*542baf77SAaron Kling }; 604*542baf77SAaron Kling 605*542baf77SAaron Kling static const unsigned int gpio_pq3_pi3_pins[] = { 606*542baf77SAaron Kling TEGRA_PIN_GPIO_PQ3_PI3, 607*542baf77SAaron Kling }; 608*542baf77SAaron Kling 609*542baf77SAaron Kling static const unsigned int gpio_pq4_pi4_pins[] = { 610*542baf77SAaron Kling TEGRA_PIN_GPIO_PQ4_PI4, 611*542baf77SAaron Kling }; 612*542baf77SAaron Kling 613*542baf77SAaron Kling static const unsigned int gpio_pq5_pi5_pins[] = { 614*542baf77SAaron Kling TEGRA_PIN_GPIO_PQ5_PI5, 615*542baf77SAaron Kling }; 616*542baf77SAaron Kling 617*542baf77SAaron Kling static const unsigned int gpio_pq6_pi6_pins[] = { 618*542baf77SAaron Kling TEGRA_PIN_GPIO_PQ6_PI6, 619*542baf77SAaron Kling }; 620*542baf77SAaron Kling 621*542baf77SAaron Kling static const unsigned int gpio_pq7_pi7_pins[] = { 622*542baf77SAaron Kling TEGRA_PIN_GPIO_PQ7_PI7, 623*542baf77SAaron Kling }; 624*542baf77SAaron Kling 625*542baf77SAaron Kling static const unsigned int dap1_sclk_pj0_pins[] = { 626*542baf77SAaron Kling TEGRA_PIN_DAP1_SCLK_PJ0, 627*542baf77SAaron Kling }; 628*542baf77SAaron Kling 629*542baf77SAaron Kling static const unsigned int dap1_dout_pj1_pins[] = { 630*542baf77SAaron Kling TEGRA_PIN_DAP1_DOUT_PJ1, 631*542baf77SAaron Kling }; 632*542baf77SAaron Kling 633*542baf77SAaron Kling static const unsigned int dap1_din_pj2_pins[] = { 634*542baf77SAaron Kling TEGRA_PIN_DAP1_DIN_PJ2, 635*542baf77SAaron Kling }; 636*542baf77SAaron Kling 637*542baf77SAaron Kling static const unsigned int dap1_fs_pj3_pins[] = { 638*542baf77SAaron Kling TEGRA_PIN_DAP1_FS_PJ3, 639*542baf77SAaron Kling }; 640*542baf77SAaron Kling 641*542baf77SAaron Kling static const unsigned int aud_mclk_pj4_pins[] = { 642*542baf77SAaron Kling TEGRA_PIN_AUD_MCLK_PJ4, 643*542baf77SAaron Kling }; 644*542baf77SAaron Kling 645*542baf77SAaron Kling static const unsigned int gpio_aud0_pj5_pins[] = { 646*542baf77SAaron Kling TEGRA_PIN_GPIO_AUD0_PJ5, 647*542baf77SAaron Kling }; 648*542baf77SAaron Kling 649*542baf77SAaron Kling static const unsigned int gpio_aud1_pj6_pins[] = { 650*542baf77SAaron Kling TEGRA_PIN_GPIO_AUD1_PJ6, 651*542baf77SAaron Kling }; 652*542baf77SAaron Kling 653*542baf77SAaron Kling static const unsigned int gpio_aud2_pj7_pins[] = { 654*542baf77SAaron Kling TEGRA_PIN_GPIO_AUD2_PJ7, 655*542baf77SAaron Kling }; 656*542baf77SAaron Kling 657*542baf77SAaron Kling static const unsigned int gpio_aud3_pk0_pins[] = { 658*542baf77SAaron Kling TEGRA_PIN_GPIO_AUD3_PK0, 659*542baf77SAaron Kling }; 660*542baf77SAaron Kling 661*542baf77SAaron Kling static const unsigned int gen7_i2c_scl_pl0_pins[] = { 662*542baf77SAaron Kling TEGRA_PIN_GEN7_I2C_SCL_PL0, 663*542baf77SAaron Kling }; 664*542baf77SAaron Kling 665*542baf77SAaron Kling static const unsigned int gen7_i2c_sda_pl1_pins[] = { 666*542baf77SAaron Kling TEGRA_PIN_GEN7_I2C_SDA_PL1, 667*542baf77SAaron Kling }; 668*542baf77SAaron Kling 669*542baf77SAaron Kling static const unsigned int gen9_i2c_scl_pl2_pins[] = { 670*542baf77SAaron Kling TEGRA_PIN_GEN9_I2C_SCL_PL2, 671*542baf77SAaron Kling }; 672*542baf77SAaron Kling 673*542baf77SAaron Kling static const unsigned int gen9_i2c_sda_pl3_pins[] = { 674*542baf77SAaron Kling TEGRA_PIN_GEN9_I2C_SDA_PL3, 675*542baf77SAaron Kling }; 676*542baf77SAaron Kling 677*542baf77SAaron Kling static const unsigned int usb_vbus_en0_pl4_pins[] = { 678*542baf77SAaron Kling TEGRA_PIN_USB_VBUS_EN0_PL4, 679*542baf77SAaron Kling }; 680*542baf77SAaron Kling 681*542baf77SAaron Kling static const unsigned int usb_vbus_en1_pl5_pins[] = { 682*542baf77SAaron Kling TEGRA_PIN_USB_VBUS_EN1_PL5, 683*542baf77SAaron Kling }; 684*542baf77SAaron Kling 685*542baf77SAaron Kling static const unsigned int gp_pwm6_pl6_pins[] = { 686*542baf77SAaron Kling TEGRA_PIN_GP_PWM6_PL6, 687*542baf77SAaron Kling }; 688*542baf77SAaron Kling 689*542baf77SAaron Kling static const unsigned int gp_pwm7_pl7_pins[] = { 690*542baf77SAaron Kling TEGRA_PIN_GP_PWM7_PL7, 691*542baf77SAaron Kling }; 692*542baf77SAaron Kling 693*542baf77SAaron Kling static const unsigned int dmic1_dat_pm0_pins[] = { 694*542baf77SAaron Kling TEGRA_PIN_DMIC1_DAT_PM0, 695*542baf77SAaron Kling }; 696*542baf77SAaron Kling 697*542baf77SAaron Kling static const unsigned int dmic1_clk_pm1_pins[] = { 698*542baf77SAaron Kling TEGRA_PIN_DMIC1_CLK_PM1, 699*542baf77SAaron Kling }; 700*542baf77SAaron Kling 701*542baf77SAaron Kling static const unsigned int dmic2_dat_pm2_pins[] = { 702*542baf77SAaron Kling TEGRA_PIN_DMIC2_DAT_PM2, 703*542baf77SAaron Kling }; 704*542baf77SAaron Kling 705*542baf77SAaron Kling static const unsigned int dmic2_clk_pm3_pins[] = { 706*542baf77SAaron Kling TEGRA_PIN_DMIC2_CLK_PM3, 707*542baf77SAaron Kling }; 708*542baf77SAaron Kling 709*542baf77SAaron Kling static const unsigned int dmic4_dat_pm4_pins[] = { 710*542baf77SAaron Kling TEGRA_PIN_DMIC4_DAT_PM4, 711*542baf77SAaron Kling }; 712*542baf77SAaron Kling 713*542baf77SAaron Kling static const unsigned int dmic4_clk_pm5_pins[] = { 714*542baf77SAaron Kling TEGRA_PIN_DMIC4_CLK_PM5, 715*542baf77SAaron Kling }; 716*542baf77SAaron Kling 717*542baf77SAaron Kling static const unsigned int gpio_cam1_pn0_pins[] = { 718*542baf77SAaron Kling TEGRA_PIN_GPIO_CAM1_PN0, 719*542baf77SAaron Kling }; 720*542baf77SAaron Kling 721*542baf77SAaron Kling static const unsigned int gpio_cam2_pn1_pins[] = { 722*542baf77SAaron Kling TEGRA_PIN_GPIO_CAM2_PN1, 723*542baf77SAaron Kling }; 724*542baf77SAaron Kling 725*542baf77SAaron Kling static const unsigned int gpio_cam3_pn2_pins[] = { 726*542baf77SAaron Kling TEGRA_PIN_GPIO_CAM3_PN2, 727*542baf77SAaron Kling }; 728*542baf77SAaron Kling 729*542baf77SAaron Kling static const unsigned int gpio_cam4_pn3_pins[] = { 730*542baf77SAaron Kling TEGRA_PIN_GPIO_CAM4_PN3, 731*542baf77SAaron Kling }; 732*542baf77SAaron Kling 733*542baf77SAaron Kling static const unsigned int gpio_cam5_pn4_pins[] = { 734*542baf77SAaron Kling TEGRA_PIN_GPIO_CAM5_PN4, 735*542baf77SAaron Kling }; 736*542baf77SAaron Kling 737*542baf77SAaron Kling static const unsigned int gpio_cam6_pn5_pins[] = { 738*542baf77SAaron Kling TEGRA_PIN_GPIO_CAM6_PN5, 739*542baf77SAaron Kling }; 740*542baf77SAaron Kling 741*542baf77SAaron Kling static const unsigned int gpio_cam7_pn6_pins[] = { 742*542baf77SAaron Kling TEGRA_PIN_GPIO_CAM7_PN6, 743*542baf77SAaron Kling }; 744*542baf77SAaron Kling 745*542baf77SAaron Kling static const unsigned int extperiph1_clk_po0_pins[] = { 746*542baf77SAaron Kling TEGRA_PIN_EXTPERIPH1_CLK_PO0, 747*542baf77SAaron Kling }; 748*542baf77SAaron Kling 749*542baf77SAaron Kling static const unsigned int extperiph2_clk_po1_pins[] = { 750*542baf77SAaron Kling TEGRA_PIN_EXTPERIPH2_CLK_PO1, 751*542baf77SAaron Kling }; 752*542baf77SAaron Kling 753*542baf77SAaron Kling static const unsigned int cam_i2c_scl_po2_pins[] = { 754*542baf77SAaron Kling TEGRA_PIN_CAM_I2C_SCL_PO2, 755*542baf77SAaron Kling }; 756*542baf77SAaron Kling 757*542baf77SAaron Kling static const unsigned int cam_i2c_sda_po3_pins[] = { 758*542baf77SAaron Kling TEGRA_PIN_CAM_I2C_SDA_PO3, 759*542baf77SAaron Kling }; 760*542baf77SAaron Kling 761*542baf77SAaron Kling static const unsigned int dp_aux_ch0_hpd_pp0_pins[] = { 762*542baf77SAaron Kling TEGRA_PIN_DP_AUX_CH0_HPD_PP0, 763*542baf77SAaron Kling }; 764*542baf77SAaron Kling 765*542baf77SAaron Kling static const unsigned int dp_aux_ch1_hpd_pp1_pins[] = { 766*542baf77SAaron Kling TEGRA_PIN_DP_AUX_CH1_HPD_PP1, 767*542baf77SAaron Kling }; 768*542baf77SAaron Kling 769*542baf77SAaron Kling static const unsigned int hdmi_cec_pp2_pins[] = { 770*542baf77SAaron Kling TEGRA_PIN_HDMI_CEC_PP2, 771*542baf77SAaron Kling }; 772*542baf77SAaron Kling 773*542baf77SAaron Kling static const unsigned int gpio_edp0_pp3_pins[] = { 774*542baf77SAaron Kling TEGRA_PIN_GPIO_EDP0_PP3, 775*542baf77SAaron Kling }; 776*542baf77SAaron Kling 777*542baf77SAaron Kling static const unsigned int gpio_edp1_pp4_pins[] = { 778*542baf77SAaron Kling TEGRA_PIN_GPIO_EDP1_PP4, 779*542baf77SAaron Kling }; 780*542baf77SAaron Kling 781*542baf77SAaron Kling static const unsigned int gpio_edp2_pp5_pins[] = { 782*542baf77SAaron Kling TEGRA_PIN_GPIO_EDP2_PP5, 783*542baf77SAaron Kling }; 784*542baf77SAaron Kling 785*542baf77SAaron Kling static const unsigned int gpio_edp3_pp6_pins[] = { 786*542baf77SAaron Kling TEGRA_PIN_GPIO_EDP3_PP6, 787*542baf77SAaron Kling }; 788*542baf77SAaron Kling 789*542baf77SAaron Kling static const unsigned int directdc1_clk_pq0_pins[] = { 790*542baf77SAaron Kling TEGRA_PIN_DIRECTDC1_CLK_PQ0, 791*542baf77SAaron Kling }; 792*542baf77SAaron Kling 793*542baf77SAaron Kling static const unsigned int directdc1_in_pq1_pins[] = { 794*542baf77SAaron Kling TEGRA_PIN_DIRECTDC1_IN_PQ1, 795*542baf77SAaron Kling }; 796*542baf77SAaron Kling 797*542baf77SAaron Kling static const unsigned int directdc1_out0_pq2_pins[] = { 798*542baf77SAaron Kling TEGRA_PIN_DIRECTDC1_OUT0_PQ2, 799*542baf77SAaron Kling }; 800*542baf77SAaron Kling 801*542baf77SAaron Kling static const unsigned int directdc1_out1_pq3_pins[] = { 802*542baf77SAaron Kling TEGRA_PIN_DIRECTDC1_OUT1_PQ3, 803*542baf77SAaron Kling }; 804*542baf77SAaron Kling 805*542baf77SAaron Kling static const unsigned int directdc1_out2_pq4_pins[] = { 806*542baf77SAaron Kling TEGRA_PIN_DIRECTDC1_OUT2_PQ4, 807*542baf77SAaron Kling }; 808*542baf77SAaron Kling 809*542baf77SAaron Kling static const unsigned int directdc1_out3_pq5_pins[] = { 810*542baf77SAaron Kling TEGRA_PIN_DIRECTDC1_OUT3_PQ5, 811*542baf77SAaron Kling }; 812*542baf77SAaron Kling 813*542baf77SAaron Kling static const unsigned int qspi_sck_pr0_pins[] = { 814*542baf77SAaron Kling TEGRA_PIN_QSPI_SCK_PR0, 815*542baf77SAaron Kling }; 816*542baf77SAaron Kling 817*542baf77SAaron Kling static const unsigned int qspi_io0_pr1_pins[] = { 818*542baf77SAaron Kling TEGRA_PIN_QSPI_IO0_PR1, 819*542baf77SAaron Kling }; 820*542baf77SAaron Kling 821*542baf77SAaron Kling static const unsigned int qspi_io1_pr2_pins[] = { 822*542baf77SAaron Kling TEGRA_PIN_QSPI_IO1_PR2, 823*542baf77SAaron Kling }; 824*542baf77SAaron Kling 825*542baf77SAaron Kling static const unsigned int qspi_io2_pr3_pins[] = { 826*542baf77SAaron Kling TEGRA_PIN_QSPI_IO2_PR3, 827*542baf77SAaron Kling }; 828*542baf77SAaron Kling 829*542baf77SAaron Kling static const unsigned int qspi_io3_pr4_pins[] = { 830*542baf77SAaron Kling TEGRA_PIN_QSPI_IO3_PR4, 831*542baf77SAaron Kling }; 832*542baf77SAaron Kling 833*542baf77SAaron Kling static const unsigned int qspi_cs_n_pr5_pins[] = { 834*542baf77SAaron Kling TEGRA_PIN_QSPI_CS_N_PR5, 835*542baf77SAaron Kling }; 836*542baf77SAaron Kling 837*542baf77SAaron Kling static const unsigned int pwr_i2c_scl_ps0_pins[] = { 838*542baf77SAaron Kling TEGRA_PIN_PWR_I2C_SCL_PS0, 839*542baf77SAaron Kling }; 840*542baf77SAaron Kling 841*542baf77SAaron Kling static const unsigned int pwr_i2c_sda_ps1_pins[] = { 842*542baf77SAaron Kling TEGRA_PIN_PWR_I2C_SDA_PS1, 843*542baf77SAaron Kling }; 844*542baf77SAaron Kling 845*542baf77SAaron Kling static const unsigned int batt_oc_ps2_pins[] = { 846*542baf77SAaron Kling TEGRA_PIN_BATT_OC_PS2, 847*542baf77SAaron Kling }; 848*542baf77SAaron Kling 849*542baf77SAaron Kling static const unsigned int safe_state_ps3_pins[] = { 850*542baf77SAaron Kling TEGRA_PIN_SAFE_STATE_PS3, 851*542baf77SAaron Kling }; 852*542baf77SAaron Kling 853*542baf77SAaron Kling static const unsigned int vcomp_alert_ps4_pins[] = { 854*542baf77SAaron Kling TEGRA_PIN_VCOMP_ALERT_PS4, 855*542baf77SAaron Kling }; 856*542baf77SAaron Kling 857*542baf77SAaron Kling static const unsigned int uart1_tx_pt0_pins[] = { 858*542baf77SAaron Kling TEGRA_PIN_UART1_TX_PT0, 859*542baf77SAaron Kling }; 860*542baf77SAaron Kling 861*542baf77SAaron Kling static const unsigned int uart1_rx_pt1_pins[] = { 862*542baf77SAaron Kling TEGRA_PIN_UART1_RX_PT1, 863*542baf77SAaron Kling }; 864*542baf77SAaron Kling 865*542baf77SAaron Kling static const unsigned int uart1_rts_pt2_pins[] = { 866*542baf77SAaron Kling TEGRA_PIN_UART1_RTS_PT2, 867*542baf77SAaron Kling }; 868*542baf77SAaron Kling 869*542baf77SAaron Kling static const unsigned int uart1_cts_pt3_pins[] = { 870*542baf77SAaron Kling TEGRA_PIN_UART1_CTS_PT3, 871*542baf77SAaron Kling }; 872*542baf77SAaron Kling 873*542baf77SAaron Kling static const unsigned int gpio_dis0_pu0_pins[] = { 874*542baf77SAaron Kling TEGRA_PIN_GPIO_DIS0_PU0, 875*542baf77SAaron Kling }; 876*542baf77SAaron Kling 877*542baf77SAaron Kling static const unsigned int gpio_dis1_pu1_pins[] = { 878*542baf77SAaron Kling TEGRA_PIN_GPIO_DIS1_PU1, 879*542baf77SAaron Kling }; 880*542baf77SAaron Kling 881*542baf77SAaron Kling static const unsigned int gpio_dis2_pu2_pins[] = { 882*542baf77SAaron Kling TEGRA_PIN_GPIO_DIS2_PU2, 883*542baf77SAaron Kling }; 884*542baf77SAaron Kling 885*542baf77SAaron Kling static const unsigned int gpio_dis3_pu3_pins[] = { 886*542baf77SAaron Kling TEGRA_PIN_GPIO_DIS3_PU3, 887*542baf77SAaron Kling }; 888*542baf77SAaron Kling 889*542baf77SAaron Kling static const unsigned int gpio_dis4_pu4_pins[] = { 890*542baf77SAaron Kling TEGRA_PIN_GPIO_DIS4_PU4, 891*542baf77SAaron Kling }; 892*542baf77SAaron Kling 893*542baf77SAaron Kling static const unsigned int gpio_dis5_pu5_pins[] = { 894*542baf77SAaron Kling TEGRA_PIN_GPIO_DIS5_PU5, 895*542baf77SAaron Kling }; 896*542baf77SAaron Kling 897*542baf77SAaron Kling static const unsigned int gpio_sen0_pv0_pins[] = { 898*542baf77SAaron Kling TEGRA_PIN_GPIO_SEN0_PV0, 899*542baf77SAaron Kling }; 900*542baf77SAaron Kling 901*542baf77SAaron Kling static const unsigned int gpio_sen1_pv1_pins[] = { 902*542baf77SAaron Kling TEGRA_PIN_GPIO_SEN1_PV1, 903*542baf77SAaron Kling }; 904*542baf77SAaron Kling 905*542baf77SAaron Kling static const unsigned int gpio_sen2_pv2_pins[] = { 906*542baf77SAaron Kling TEGRA_PIN_GPIO_SEN2_PV2, 907*542baf77SAaron Kling }; 908*542baf77SAaron Kling 909*542baf77SAaron Kling static const unsigned int gpio_sen3_pv3_pins[] = { 910*542baf77SAaron Kling TEGRA_PIN_GPIO_SEN3_PV3, 911*542baf77SAaron Kling }; 912*542baf77SAaron Kling 913*542baf77SAaron Kling static const unsigned int gpio_sen4_pv4_pins[] = { 914*542baf77SAaron Kling TEGRA_PIN_GPIO_SEN4_PV4, 915*542baf77SAaron Kling }; 916*542baf77SAaron Kling 917*542baf77SAaron Kling static const unsigned int gpio_sen5_pv5_pins[] = { 918*542baf77SAaron Kling TEGRA_PIN_GPIO_SEN5_PV5, 919*542baf77SAaron Kling }; 920*542baf77SAaron Kling 921*542baf77SAaron Kling static const unsigned int gpio_sen6_pv6_pins[] = { 922*542baf77SAaron Kling TEGRA_PIN_GPIO_SEN6_PV6, 923*542baf77SAaron Kling }; 924*542baf77SAaron Kling 925*542baf77SAaron Kling static const unsigned int gpio_sen7_pv7_pins[] = { 926*542baf77SAaron Kling TEGRA_PIN_GPIO_SEN7_PV7, 927*542baf77SAaron Kling }; 928*542baf77SAaron Kling 929*542baf77SAaron Kling static const unsigned int gen8_i2c_scl_pw0_pins[] = { 930*542baf77SAaron Kling TEGRA_PIN_GEN8_I2C_SCL_PW0, 931*542baf77SAaron Kling }; 932*542baf77SAaron Kling 933*542baf77SAaron Kling static const unsigned int gen8_i2c_sda_pw1_pins[] = { 934*542baf77SAaron Kling TEGRA_PIN_GEN8_I2C_SDA_PW1, 935*542baf77SAaron Kling }; 936*542baf77SAaron Kling 937*542baf77SAaron Kling static const unsigned int uart3_tx_pw2_pins[] = { 938*542baf77SAaron Kling TEGRA_PIN_UART3_TX_PW2, 939*542baf77SAaron Kling }; 940*542baf77SAaron Kling 941*542baf77SAaron Kling static const unsigned int uart3_rx_pw3_pins[] = { 942*542baf77SAaron Kling TEGRA_PIN_UART3_RX_PW3, 943*542baf77SAaron Kling }; 944*542baf77SAaron Kling 945*542baf77SAaron Kling static const unsigned int uart3_rts_pw4_pins[] = { 946*542baf77SAaron Kling TEGRA_PIN_UART3_RTS_PW4, 947*542baf77SAaron Kling }; 948*542baf77SAaron Kling 949*542baf77SAaron Kling static const unsigned int uart3_cts_pw5_pins[] = { 950*542baf77SAaron Kling TEGRA_PIN_UART3_CTS_PW5, 951*542baf77SAaron Kling }; 952*542baf77SAaron Kling 953*542baf77SAaron Kling static const unsigned int uart7_tx_pw6_pins[] = { 954*542baf77SAaron Kling TEGRA_PIN_UART7_TX_PW6, 955*542baf77SAaron Kling }; 956*542baf77SAaron Kling 957*542baf77SAaron Kling static const unsigned int uart7_rx_pw7_pins[] = { 958*542baf77SAaron Kling TEGRA_PIN_UART7_RX_PW7, 959*542baf77SAaron Kling }; 960*542baf77SAaron Kling 961*542baf77SAaron Kling static const unsigned int uart2_tx_px0_pins[] = { 962*542baf77SAaron Kling TEGRA_PIN_UART2_TX_PX0, 963*542baf77SAaron Kling }; 964*542baf77SAaron Kling 965*542baf77SAaron Kling static const unsigned int uart2_rx_px1_pins[] = { 966*542baf77SAaron Kling TEGRA_PIN_UART2_RX_PX1, 967*542baf77SAaron Kling }; 968*542baf77SAaron Kling 969*542baf77SAaron Kling static const unsigned int uart2_rts_px2_pins[] = { 970*542baf77SAaron Kling TEGRA_PIN_UART2_RTS_PX2, 971*542baf77SAaron Kling }; 972*542baf77SAaron Kling 973*542baf77SAaron Kling static const unsigned int uart2_cts_px3_pins[] = { 974*542baf77SAaron Kling TEGRA_PIN_UART2_CTS_PX3, 975*542baf77SAaron Kling }; 976*542baf77SAaron Kling 977*542baf77SAaron Kling static const unsigned int uart5_tx_px4_pins[] = { 978*542baf77SAaron Kling TEGRA_PIN_UART5_TX_PX4, 979*542baf77SAaron Kling }; 980*542baf77SAaron Kling 981*542baf77SAaron Kling static const unsigned int uart5_rx_px5_pins[] = { 982*542baf77SAaron Kling TEGRA_PIN_UART5_RX_PX5, 983*542baf77SAaron Kling }; 984*542baf77SAaron Kling 985*542baf77SAaron Kling static const unsigned int uart5_rts_px6_pins[] = { 986*542baf77SAaron Kling TEGRA_PIN_UART5_RTS_PX6, 987*542baf77SAaron Kling }; 988*542baf77SAaron Kling 989*542baf77SAaron Kling static const unsigned int uart5_cts_px7_pins[] = { 990*542baf77SAaron Kling TEGRA_PIN_UART5_CTS_PX7, 991*542baf77SAaron Kling }; 992*542baf77SAaron Kling 993*542baf77SAaron Kling static const unsigned int gpio_mdm1_py0_pins[] = { 994*542baf77SAaron Kling TEGRA_PIN_GPIO_MDM1_PY0, 995*542baf77SAaron Kling }; 996*542baf77SAaron Kling 997*542baf77SAaron Kling static const unsigned int gpio_mdm2_py1_pins[] = { 998*542baf77SAaron Kling TEGRA_PIN_GPIO_MDM2_PY1, 999*542baf77SAaron Kling }; 1000*542baf77SAaron Kling 1001*542baf77SAaron Kling static const unsigned int gpio_mdm3_py2_pins[] = { 1002*542baf77SAaron Kling TEGRA_PIN_GPIO_MDM3_PY2, 1003*542baf77SAaron Kling }; 1004*542baf77SAaron Kling 1005*542baf77SAaron Kling static const unsigned int gpio_mdm4_py3_pins[] = { 1006*542baf77SAaron Kling TEGRA_PIN_GPIO_MDM4_PY3, 1007*542baf77SAaron Kling }; 1008*542baf77SAaron Kling 1009*542baf77SAaron Kling static const unsigned int gpio_mdm5_py4_pins[] = { 1010*542baf77SAaron Kling TEGRA_PIN_GPIO_MDM5_PY4, 1011*542baf77SAaron Kling }; 1012*542baf77SAaron Kling 1013*542baf77SAaron Kling static const unsigned int gpio_mdm6_py5_pins[] = { 1014*542baf77SAaron Kling TEGRA_PIN_GPIO_MDM6_PY5, 1015*542baf77SAaron Kling }; 1016*542baf77SAaron Kling 1017*542baf77SAaron Kling static const unsigned int gpio_mdm7_py6_pins[] = { 1018*542baf77SAaron Kling TEGRA_PIN_GPIO_MDM7_PY6, 1019*542baf77SAaron Kling }; 1020*542baf77SAaron Kling 1021*542baf77SAaron Kling static const unsigned int can1_dout_pz0_pins[] = { 1022*542baf77SAaron Kling TEGRA_PIN_CAN1_DOUT_PZ0, 1023*542baf77SAaron Kling }; 1024*542baf77SAaron Kling 1025*542baf77SAaron Kling static const unsigned int can1_din_pz1_pins[] = { 1026*542baf77SAaron Kling TEGRA_PIN_CAN1_DIN_PZ1, 1027*542baf77SAaron Kling }; 1028*542baf77SAaron Kling 1029*542baf77SAaron Kling static const unsigned int can0_dout_pz2_pins[] = { 1030*542baf77SAaron Kling TEGRA_PIN_CAN0_DOUT_PZ2, 1031*542baf77SAaron Kling }; 1032*542baf77SAaron Kling 1033*542baf77SAaron Kling static const unsigned int can0_din_pz3_pins[] = { 1034*542baf77SAaron Kling TEGRA_PIN_CAN0_DIN_PZ3, 1035*542baf77SAaron Kling }; 1036*542baf77SAaron Kling 1037*542baf77SAaron Kling static const unsigned int can_gpio0_paa0_pins[] = { 1038*542baf77SAaron Kling TEGRA_PIN_CAN_GPIO0_PAA0, 1039*542baf77SAaron Kling }; 1040*542baf77SAaron Kling 1041*542baf77SAaron Kling static const unsigned int can_gpio1_paa1_pins[] = { 1042*542baf77SAaron Kling TEGRA_PIN_CAN_GPIO1_PAA1, 1043*542baf77SAaron Kling }; 1044*542baf77SAaron Kling 1045*542baf77SAaron Kling static const unsigned int can_gpio2_paa2_pins[] = { 1046*542baf77SAaron Kling TEGRA_PIN_CAN_GPIO2_PAA2, 1047*542baf77SAaron Kling }; 1048*542baf77SAaron Kling 1049*542baf77SAaron Kling static const unsigned int can_gpio3_paa3_pins[] = { 1050*542baf77SAaron Kling TEGRA_PIN_CAN_GPIO3_PAA3, 1051*542baf77SAaron Kling }; 1052*542baf77SAaron Kling 1053*542baf77SAaron Kling static const unsigned int can_gpio4_paa4_pins[] = { 1054*542baf77SAaron Kling TEGRA_PIN_CAN_GPIO4_PAA4, 1055*542baf77SAaron Kling }; 1056*542baf77SAaron Kling 1057*542baf77SAaron Kling static const unsigned int can_gpio5_paa5_pins[] = { 1058*542baf77SAaron Kling TEGRA_PIN_CAN_GPIO5_PAA5, 1059*542baf77SAaron Kling }; 1060*542baf77SAaron Kling 1061*542baf77SAaron Kling static const unsigned int can_gpio6_paa6_pins[] = { 1062*542baf77SAaron Kling TEGRA_PIN_CAN_GPIO6_PAA6, 1063*542baf77SAaron Kling }; 1064*542baf77SAaron Kling 1065*542baf77SAaron Kling static const unsigned int can_gpio7_paa7_pins[] = { 1066*542baf77SAaron Kling TEGRA_PIN_CAN_GPIO7_PAA7, 1067*542baf77SAaron Kling }; 1068*542baf77SAaron Kling 1069*542baf77SAaron Kling static const unsigned int ufs0_ref_clk_pbb0_pins[] = { 1070*542baf77SAaron Kling TEGRA_PIN_UFS0_REF_CLK_PBB0, 1071*542baf77SAaron Kling }; 1072*542baf77SAaron Kling 1073*542baf77SAaron Kling static const unsigned int ufs0_rst_pbb1_pins[] = { 1074*542baf77SAaron Kling TEGRA_PIN_UFS0_RST_PBB1, 1075*542baf77SAaron Kling }; 1076*542baf77SAaron Kling 1077*542baf77SAaron Kling static const unsigned int dap4_sclk_pcc0_pins[] = { 1078*542baf77SAaron Kling TEGRA_PIN_DAP4_SCLK_PCC0, 1079*542baf77SAaron Kling }; 1080*542baf77SAaron Kling 1081*542baf77SAaron Kling static const unsigned int dap4_dout_pcc1_pins[] = { 1082*542baf77SAaron Kling TEGRA_PIN_DAP4_DOUT_PCC1, 1083*542baf77SAaron Kling }; 1084*542baf77SAaron Kling 1085*542baf77SAaron Kling static const unsigned int dap4_din_pcc2_pins[] = { 1086*542baf77SAaron Kling TEGRA_PIN_DAP4_DIN_PCC2, 1087*542baf77SAaron Kling }; 1088*542baf77SAaron Kling 1089*542baf77SAaron Kling static const unsigned int dap4_fs_pcc3_pins[] = { 1090*542baf77SAaron Kling TEGRA_PIN_DAP4_FS_PCC3, 1091*542baf77SAaron Kling }; 1092*542baf77SAaron Kling 1093*542baf77SAaron Kling static const unsigned int gpio_sen8_pee0_pins[] = { 1094*542baf77SAaron Kling TEGRA_PIN_GPIO_SEN8_PEE0, 1095*542baf77SAaron Kling }; 1096*542baf77SAaron Kling 1097*542baf77SAaron Kling static const unsigned int gpio_sen9_pee1_pins[] = { 1098*542baf77SAaron Kling TEGRA_PIN_GPIO_SEN9_PEE1, 1099*542baf77SAaron Kling }; 1100*542baf77SAaron Kling 1101*542baf77SAaron Kling static const unsigned int touch_clk_pee2_pins[] = { 1102*542baf77SAaron Kling TEGRA_PIN_TOUCH_CLK_PEE2, 1103*542baf77SAaron Kling }; 1104*542baf77SAaron Kling 1105*542baf77SAaron Kling static const unsigned int power_on_pff0_pins[] = { 1106*542baf77SAaron Kling TEGRA_PIN_POWER_ON_PFF0, 1107*542baf77SAaron Kling }; 1108*542baf77SAaron Kling 1109*542baf77SAaron Kling static const unsigned int gpio_sw1_pff1_pins[] = { 1110*542baf77SAaron Kling TEGRA_PIN_GPIO_SW1_PFF1, 1111*542baf77SAaron Kling }; 1112*542baf77SAaron Kling 1113*542baf77SAaron Kling static const unsigned int gpio_sw2_pff2_pins[] = { 1114*542baf77SAaron Kling TEGRA_PIN_GPIO_SW2_PFF2, 1115*542baf77SAaron Kling }; 1116*542baf77SAaron Kling 1117*542baf77SAaron Kling static const unsigned int gpio_sw3_pff3_pins[] = { 1118*542baf77SAaron Kling TEGRA_PIN_GPIO_SW3_PFF3, 1119*542baf77SAaron Kling }; 1120*542baf77SAaron Kling 1121*542baf77SAaron Kling static const unsigned int gpio_sw4_pff4_pins[] = { 1122*542baf77SAaron Kling TEGRA_PIN_GPIO_SW4_PFF4, 1123*542baf77SAaron Kling }; 1124*542baf77SAaron Kling 1125*542baf77SAaron Kling static const unsigned int directdc_comp_pins[] = { 1126*542baf77SAaron Kling TEGRA_PIN_DIRECTDC_COMP, 1127*542baf77SAaron Kling }; 1128*542baf77SAaron Kling 1129*542baf77SAaron Kling static const unsigned int sdmmc1_comp_pins[] = { 1130*542baf77SAaron Kling TEGRA_PIN_SDMMC1_COMP, 1131*542baf77SAaron Kling }; 1132*542baf77SAaron Kling 1133*542baf77SAaron Kling static const unsigned int eqos_comp_pins[] = { 1134*542baf77SAaron Kling TEGRA_PIN_EQOS_COMP, 1135*542baf77SAaron Kling }; 1136*542baf77SAaron Kling 1137*542baf77SAaron Kling static const unsigned int sdmmc3_comp_pins[] = { 1138*542baf77SAaron Kling TEGRA_PIN_SDMMC3_COMP, 1139*542baf77SAaron Kling }; 1140*542baf77SAaron Kling 1141*542baf77SAaron Kling static const unsigned int qspi_comp_pins[] = { 1142*542baf77SAaron Kling TEGRA_PIN_QSPI_COMP, 1143*542baf77SAaron Kling }; 1144*542baf77SAaron Kling 1145*542baf77SAaron Kling static const unsigned int shutdown_pins[] = { 1146*542baf77SAaron Kling TEGRA_PIN_SHUTDOWN, 1147*542baf77SAaron Kling }; 1148*542baf77SAaron Kling 1149*542baf77SAaron Kling static const unsigned int pmu_int_pins[] = { 1150*542baf77SAaron Kling TEGRA_PIN_PMU_INT, 1151*542baf77SAaron Kling }; 1152*542baf77SAaron Kling 1153*542baf77SAaron Kling static const unsigned int soc_pwr_req_pins[] = { 1154*542baf77SAaron Kling TEGRA_PIN_SOC_PWR_REQ, 1155*542baf77SAaron Kling }; 1156*542baf77SAaron Kling 1157*542baf77SAaron Kling static const unsigned int clk_32k_in_pins[] = { 1158*542baf77SAaron Kling TEGRA_PIN_CLK_32K_IN, 1159*542baf77SAaron Kling }; 1160*542baf77SAaron Kling 1161*542baf77SAaron Kling static const unsigned int sdmmc4_clk_pins[] = {}; 1162*542baf77SAaron Kling 1163*542baf77SAaron Kling static const unsigned int sdmmc4_cmd_pins[] = {}; 1164*542baf77SAaron Kling 1165*542baf77SAaron Kling static const unsigned int sdmmc4_dqs_pins[] = {}; 1166*542baf77SAaron Kling 1167*542baf77SAaron Kling static const unsigned int sdmmc4_dat7_pins[] = {}; 1168*542baf77SAaron Kling 1169*542baf77SAaron Kling static const unsigned int sdmmc4_dat6_pins[] = {}; 1170*542baf77SAaron Kling 1171*542baf77SAaron Kling static const unsigned int sdmmc4_dat5_pins[] = {}; 1172*542baf77SAaron Kling 1173*542baf77SAaron Kling static const unsigned int sdmmc4_dat4_pins[] = {}; 1174*542baf77SAaron Kling 1175*542baf77SAaron Kling static const unsigned int sdmmc4_dat3_pins[] = {}; 1176*542baf77SAaron Kling 1177*542baf77SAaron Kling static const unsigned int sdmmc4_dat2_pins[] = {}; 1178*542baf77SAaron Kling 1179*542baf77SAaron Kling static const unsigned int sdmmc4_dat1_pins[] = {}; 1180*542baf77SAaron Kling 1181*542baf77SAaron Kling static const unsigned int sdmmc4_dat0_pins[] = {}; 1182*542baf77SAaron Kling 1183*542baf77SAaron Kling /* Define unique ID for each function */ 1184*542baf77SAaron Kling enum tegra_mux_dt { 1185*542baf77SAaron Kling TEGRA_MUX_RSVD0, 1186*542baf77SAaron Kling TEGRA_MUX_RSVD1, 1187*542baf77SAaron Kling TEGRA_MUX_RSVD2, 1188*542baf77SAaron Kling TEGRA_MUX_RSVD3, 1189*542baf77SAaron Kling TEGRA_MUX_TOUCH, 1190*542baf77SAaron Kling TEGRA_MUX_UARTC, 1191*542baf77SAaron Kling TEGRA_MUX_I2C8, 1192*542baf77SAaron Kling TEGRA_MUX_UARTG, 1193*542baf77SAaron Kling TEGRA_MUX_SPI2, 1194*542baf77SAaron Kling TEGRA_MUX_GP, 1195*542baf77SAaron Kling TEGRA_MUX_DCA, 1196*542baf77SAaron Kling TEGRA_MUX_WDT, 1197*542baf77SAaron Kling TEGRA_MUX_I2C2, 1198*542baf77SAaron Kling TEGRA_MUX_CAN1, 1199*542baf77SAaron Kling TEGRA_MUX_CAN0, 1200*542baf77SAaron Kling TEGRA_MUX_DMIC3, 1201*542baf77SAaron Kling TEGRA_MUX_DMIC5, 1202*542baf77SAaron Kling TEGRA_MUX_GPIO, 1203*542baf77SAaron Kling TEGRA_MUX_DSPK1, 1204*542baf77SAaron Kling TEGRA_MUX_DSPK0, 1205*542baf77SAaron Kling TEGRA_MUX_SPDIF, 1206*542baf77SAaron Kling TEGRA_MUX_AUD, 1207*542baf77SAaron Kling TEGRA_MUX_I2S1, 1208*542baf77SAaron Kling TEGRA_MUX_DMIC1, 1209*542baf77SAaron Kling TEGRA_MUX_DMIC2, 1210*542baf77SAaron Kling TEGRA_MUX_I2S3, 1211*542baf77SAaron Kling TEGRA_MUX_DMIC4, 1212*542baf77SAaron Kling TEGRA_MUX_I2S4, 1213*542baf77SAaron Kling TEGRA_MUX_EXTPERIPH2, 1214*542baf77SAaron Kling TEGRA_MUX_EXTPERIPH1, 1215*542baf77SAaron Kling TEGRA_MUX_I2C3, 1216*542baf77SAaron Kling TEGRA_MUX_VGP1, 1217*542baf77SAaron Kling TEGRA_MUX_VGP2, 1218*542baf77SAaron Kling TEGRA_MUX_VGP3, 1219*542baf77SAaron Kling TEGRA_MUX_VGP4, 1220*542baf77SAaron Kling TEGRA_MUX_VGP5, 1221*542baf77SAaron Kling TEGRA_MUX_VGP6, 1222*542baf77SAaron Kling TEGRA_MUX_EXTPERIPH3, 1223*542baf77SAaron Kling TEGRA_MUX_EXTPERIPH4, 1224*542baf77SAaron Kling TEGRA_MUX_SPI4, 1225*542baf77SAaron Kling TEGRA_MUX_I2S2, 1226*542baf77SAaron Kling TEGRA_MUX_UARTD, 1227*542baf77SAaron Kling TEGRA_MUX_I2C1, 1228*542baf77SAaron Kling TEGRA_MUX_UARTA, 1229*542baf77SAaron Kling TEGRA_MUX_DIRECTDC1, 1230*542baf77SAaron Kling TEGRA_MUX_DIRECTDC, 1231*542baf77SAaron Kling TEGRA_MUX_IQC0, 1232*542baf77SAaron Kling TEGRA_MUX_IQC1, 1233*542baf77SAaron Kling TEGRA_MUX_I2S6, 1234*542baf77SAaron Kling TEGRA_MUX_DTV, 1235*542baf77SAaron Kling TEGRA_MUX_UARTF, 1236*542baf77SAaron Kling TEGRA_MUX_SDMMC3, 1237*542baf77SAaron Kling TEGRA_MUX_SDMMC4, 1238*542baf77SAaron Kling TEGRA_MUX_SDMMC1, 1239*542baf77SAaron Kling TEGRA_MUX_DP, 1240*542baf77SAaron Kling TEGRA_MUX_HDMI, 1241*542baf77SAaron Kling TEGRA_MUX_PE2, 1242*542baf77SAaron Kling TEGRA_MUX_SATA, 1243*542baf77SAaron Kling TEGRA_MUX_PE, 1244*542baf77SAaron Kling TEGRA_MUX_PE1, 1245*542baf77SAaron Kling TEGRA_MUX_PE0, 1246*542baf77SAaron Kling TEGRA_MUX_SOC, 1247*542baf77SAaron Kling TEGRA_MUX_EQOS, 1248*542baf77SAaron Kling TEGRA_MUX_SDMMC2, 1249*542baf77SAaron Kling TEGRA_MUX_QSPI, 1250*542baf77SAaron Kling TEGRA_MUX_SCE, 1251*542baf77SAaron Kling TEGRA_MUX_I2C5, 1252*542baf77SAaron Kling TEGRA_MUX_DISPLAYA, 1253*542baf77SAaron Kling TEGRA_MUX_DISPLAYB, 1254*542baf77SAaron Kling TEGRA_MUX_DCC, 1255*542baf77SAaron Kling TEGRA_MUX_DCB, 1256*542baf77SAaron Kling TEGRA_MUX_SPI1, 1257*542baf77SAaron Kling TEGRA_MUX_UARTB, 1258*542baf77SAaron Kling TEGRA_MUX_UARTE, 1259*542baf77SAaron Kling TEGRA_MUX_SPI3, 1260*542baf77SAaron Kling TEGRA_MUX_NV, 1261*542baf77SAaron Kling TEGRA_MUX_CCLA, 1262*542baf77SAaron Kling TEGRA_MUX_I2C7, 1263*542baf77SAaron Kling TEGRA_MUX_I2C9, 1264*542baf77SAaron Kling TEGRA_MUX_I2S5, 1265*542baf77SAaron Kling TEGRA_MUX_USB, 1266*542baf77SAaron Kling TEGRA_MUX_UFS0, 1267*542baf77SAaron Kling }; 1268*542baf77SAaron Kling 1269*542baf77SAaron Kling /* Make list of each function name */ 1270*542baf77SAaron Kling #define TEGRA_PIN_FUNCTION(lid) #lid 1271*542baf77SAaron Kling 1272*542baf77SAaron Kling static const char * const tegra186_functions[] = { 1273*542baf77SAaron Kling TEGRA_PIN_FUNCTION(rsvd0), 1274*542baf77SAaron Kling TEGRA_PIN_FUNCTION(rsvd1), 1275*542baf77SAaron Kling TEGRA_PIN_FUNCTION(rsvd2), 1276*542baf77SAaron Kling TEGRA_PIN_FUNCTION(rsvd3), 1277*542baf77SAaron Kling TEGRA_PIN_FUNCTION(touch), 1278*542baf77SAaron Kling TEGRA_PIN_FUNCTION(uartc), 1279*542baf77SAaron Kling TEGRA_PIN_FUNCTION(i2c8), 1280*542baf77SAaron Kling TEGRA_PIN_FUNCTION(uartg), 1281*542baf77SAaron Kling TEGRA_PIN_FUNCTION(spi2), 1282*542baf77SAaron Kling TEGRA_PIN_FUNCTION(gp), 1283*542baf77SAaron Kling TEGRA_PIN_FUNCTION(dca), 1284*542baf77SAaron Kling TEGRA_PIN_FUNCTION(wdt), 1285*542baf77SAaron Kling TEGRA_PIN_FUNCTION(i2c2), 1286*542baf77SAaron Kling TEGRA_PIN_FUNCTION(can1), 1287*542baf77SAaron Kling TEGRA_PIN_FUNCTION(can0), 1288*542baf77SAaron Kling TEGRA_PIN_FUNCTION(dmic3), 1289*542baf77SAaron Kling TEGRA_PIN_FUNCTION(dmic5), 1290*542baf77SAaron Kling TEGRA_PIN_FUNCTION(gpio), 1291*542baf77SAaron Kling TEGRA_PIN_FUNCTION(dspk1), 1292*542baf77SAaron Kling TEGRA_PIN_FUNCTION(dspk0), 1293*542baf77SAaron Kling TEGRA_PIN_FUNCTION(spdif), 1294*542baf77SAaron Kling TEGRA_PIN_FUNCTION(aud), 1295*542baf77SAaron Kling TEGRA_PIN_FUNCTION(i2s1), 1296*542baf77SAaron Kling TEGRA_PIN_FUNCTION(dmic1), 1297*542baf77SAaron Kling TEGRA_PIN_FUNCTION(dmic2), 1298*542baf77SAaron Kling TEGRA_PIN_FUNCTION(i2s3), 1299*542baf77SAaron Kling TEGRA_PIN_FUNCTION(dmic4), 1300*542baf77SAaron Kling TEGRA_PIN_FUNCTION(i2s4), 1301*542baf77SAaron Kling TEGRA_PIN_FUNCTION(extperiph2), 1302*542baf77SAaron Kling TEGRA_PIN_FUNCTION(extperiph1), 1303*542baf77SAaron Kling TEGRA_PIN_FUNCTION(i2c3), 1304*542baf77SAaron Kling TEGRA_PIN_FUNCTION(vgp1), 1305*542baf77SAaron Kling TEGRA_PIN_FUNCTION(vgp2), 1306*542baf77SAaron Kling TEGRA_PIN_FUNCTION(vgp3), 1307*542baf77SAaron Kling TEGRA_PIN_FUNCTION(vgp4), 1308*542baf77SAaron Kling TEGRA_PIN_FUNCTION(vgp5), 1309*542baf77SAaron Kling TEGRA_PIN_FUNCTION(vgp6), 1310*542baf77SAaron Kling TEGRA_PIN_FUNCTION(extperiph3), 1311*542baf77SAaron Kling TEGRA_PIN_FUNCTION(extperiph4), 1312*542baf77SAaron Kling TEGRA_PIN_FUNCTION(spi4), 1313*542baf77SAaron Kling TEGRA_PIN_FUNCTION(i2s2), 1314*542baf77SAaron Kling TEGRA_PIN_FUNCTION(uartd), 1315*542baf77SAaron Kling TEGRA_PIN_FUNCTION(i2c1), 1316*542baf77SAaron Kling TEGRA_PIN_FUNCTION(uarta), 1317*542baf77SAaron Kling TEGRA_PIN_FUNCTION(directdc1), 1318*542baf77SAaron Kling TEGRA_PIN_FUNCTION(directdc), 1319*542baf77SAaron Kling TEGRA_PIN_FUNCTION(iqc0), 1320*542baf77SAaron Kling TEGRA_PIN_FUNCTION(iqc1), 1321*542baf77SAaron Kling TEGRA_PIN_FUNCTION(i2s6), 1322*542baf77SAaron Kling TEGRA_PIN_FUNCTION(dtv), 1323*542baf77SAaron Kling TEGRA_PIN_FUNCTION(uartf), 1324*542baf77SAaron Kling TEGRA_PIN_FUNCTION(sdmmc3), 1325*542baf77SAaron Kling TEGRA_PIN_FUNCTION(sdmmc4), 1326*542baf77SAaron Kling TEGRA_PIN_FUNCTION(sdmmc1), 1327*542baf77SAaron Kling TEGRA_PIN_FUNCTION(dp), 1328*542baf77SAaron Kling TEGRA_PIN_FUNCTION(hdmi), 1329*542baf77SAaron Kling TEGRA_PIN_FUNCTION(pe2), 1330*542baf77SAaron Kling TEGRA_PIN_FUNCTION(sata), 1331*542baf77SAaron Kling TEGRA_PIN_FUNCTION(pe), 1332*542baf77SAaron Kling TEGRA_PIN_FUNCTION(pe1), 1333*542baf77SAaron Kling TEGRA_PIN_FUNCTION(pe0), 1334*542baf77SAaron Kling TEGRA_PIN_FUNCTION(soc), 1335*542baf77SAaron Kling TEGRA_PIN_FUNCTION(eqos), 1336*542baf77SAaron Kling TEGRA_PIN_FUNCTION(sdmmc2), 1337*542baf77SAaron Kling TEGRA_PIN_FUNCTION(qspi), 1338*542baf77SAaron Kling TEGRA_PIN_FUNCTION(sce), 1339*542baf77SAaron Kling TEGRA_PIN_FUNCTION(i2c5), 1340*542baf77SAaron Kling TEGRA_PIN_FUNCTION(displaya), 1341*542baf77SAaron Kling TEGRA_PIN_FUNCTION(displayb), 1342*542baf77SAaron Kling TEGRA_PIN_FUNCTION(dcc), 1343*542baf77SAaron Kling TEGRA_PIN_FUNCTION(dcb), 1344*542baf77SAaron Kling TEGRA_PIN_FUNCTION(spi1), 1345*542baf77SAaron Kling TEGRA_PIN_FUNCTION(uartb), 1346*542baf77SAaron Kling TEGRA_PIN_FUNCTION(uarte), 1347*542baf77SAaron Kling TEGRA_PIN_FUNCTION(spi3), 1348*542baf77SAaron Kling TEGRA_PIN_FUNCTION(nv), 1349*542baf77SAaron Kling TEGRA_PIN_FUNCTION(ccla), 1350*542baf77SAaron Kling TEGRA_PIN_FUNCTION(i2c7), 1351*542baf77SAaron Kling TEGRA_PIN_FUNCTION(i2c9), 1352*542baf77SAaron Kling TEGRA_PIN_FUNCTION(i2s5), 1353*542baf77SAaron Kling TEGRA_PIN_FUNCTION(usb), 1354*542baf77SAaron Kling TEGRA_PIN_FUNCTION(ufs0), 1355*542baf77SAaron Kling }; 1356*542baf77SAaron Kling 1357*542baf77SAaron Kling #define PINGROUP_REG_Y(r) ((r)) 1358*542baf77SAaron Kling #define PINGROUP_REG_N(r) -1 1359*542baf77SAaron Kling 1360*542baf77SAaron Kling #define DRV_PINGROUP_Y(r) ((r)) 1361*542baf77SAaron Kling #define DRV_PINGROUP_N(r) -1 1362*542baf77SAaron Kling 1363*542baf77SAaron Kling #define DRV_PINGROUP_ENTRY_N(pg_name) \ 1364*542baf77SAaron Kling .drv_reg = -1, \ 1365*542baf77SAaron Kling .drv_bank = -1, \ 1366*542baf77SAaron Kling .drvdn_bit = -1, \ 1367*542baf77SAaron Kling .drvdn_width = -1, \ 1368*542baf77SAaron Kling .drvup_bit = -1, \ 1369*542baf77SAaron Kling .drvup_width = -1, \ 1370*542baf77SAaron Kling .slwr_bit = -1, \ 1371*542baf77SAaron Kling .slwr_width = -1, \ 1372*542baf77SAaron Kling .slwf_bit = -1, \ 1373*542baf77SAaron Kling .slwf_width = -1 1374*542baf77SAaron Kling 1375*542baf77SAaron Kling #define DRV_PINGROUP_ENTRY_Y(r, drvdn_b, drvdn_w, drvup_b, \ 1376*542baf77SAaron Kling drvup_w, slwr_b, slwr_w, slwf_b, \ 1377*542baf77SAaron Kling slwf_w, bank) \ 1378*542baf77SAaron Kling .drv_reg = ((r)), \ 1379*542baf77SAaron Kling .drv_bank = bank, \ 1380*542baf77SAaron Kling .drvdn_bit = drvdn_b, \ 1381*542baf77SAaron Kling .drvdn_width = drvdn_w, \ 1382*542baf77SAaron Kling .drvup_bit = drvup_b, \ 1383*542baf77SAaron Kling .drvup_width = drvup_w, \ 1384*542baf77SAaron Kling .slwr_bit = slwr_b, \ 1385*542baf77SAaron Kling .slwr_width = slwr_w, \ 1386*542baf77SAaron Kling .slwf_bit = slwf_b, \ 1387*542baf77SAaron Kling .slwf_width = slwf_w 1388*542baf77SAaron Kling 1389*542baf77SAaron Kling #define PIN_PINGROUP_ENTRY_N(pg_name) \ 1390*542baf77SAaron Kling .mux_reg = -1, \ 1391*542baf77SAaron Kling .pupd_reg = -1, \ 1392*542baf77SAaron Kling .tri_reg = -1, \ 1393*542baf77SAaron Kling .einput_bit = -1, \ 1394*542baf77SAaron Kling .e_io_hv_bit = -1, \ 1395*542baf77SAaron Kling .odrain_bit = -1, \ 1396*542baf77SAaron Kling .lock_bit = -1, \ 1397*542baf77SAaron Kling .parked_bit = -1, \ 1398*542baf77SAaron Kling .lpmd_bit = -1, \ 1399*542baf77SAaron Kling .drvtype_bit = -1, \ 1400*542baf77SAaron Kling .lpdr_bit = -1, \ 1401*542baf77SAaron Kling .pbias_buf_bit = -1, \ 1402*542baf77SAaron Kling .preemp_bit = -1, \ 1403*542baf77SAaron Kling .rfu_in_bit = -1 1404*542baf77SAaron Kling 1405*542baf77SAaron Kling #define PIN_PINGROUP_ENTRY_Y(r, bank, pupd, e_io_hv, e_lpbk, e_input, \ 1406*542baf77SAaron Kling e_lpdr, e_pbias_buf, gpio_sfio_sel, \ 1407*542baf77SAaron Kling e_od, schmitt_b, drvtype, epreemp, \ 1408*542baf77SAaron Kling io_reset, rfu_in) \ 1409*542baf77SAaron Kling .mux_reg = PINGROUP_REG_Y(r), \ 1410*542baf77SAaron Kling .lpmd_bit = -1, \ 1411*542baf77SAaron Kling .lock_bit = -1, \ 1412*542baf77SAaron Kling .hsm_bit = -1, \ 1413*542baf77SAaron Kling .mux_bank = bank, \ 1414*542baf77SAaron Kling .mux_bit = 0, \ 1415*542baf77SAaron Kling .pupd_reg = PINGROUP_REG_##pupd(r), \ 1416*542baf77SAaron Kling .pupd_bank = bank, \ 1417*542baf77SAaron Kling .pupd_bit = 2, \ 1418*542baf77SAaron Kling .tri_reg = PINGROUP_REG_Y(r), \ 1419*542baf77SAaron Kling .tri_bank = bank, \ 1420*542baf77SAaron Kling .tri_bit = 4, \ 1421*542baf77SAaron Kling .einput_bit = e_input, \ 1422*542baf77SAaron Kling .sfsel_bit = gpio_sfio_sel, \ 1423*542baf77SAaron Kling .odrain_bit = e_od, \ 1424*542baf77SAaron Kling .schmitt_bit = schmitt_b, \ 1425*542baf77SAaron Kling .drvtype_bit = 13, \ 1426*542baf77SAaron Kling .lpdr_bit = e_lpdr, \ 1427*542baf77SAaron Kling 1428*542baf77SAaron Kling /* main drive pin groups */ 1429*542baf77SAaron Kling #define drive_gpio_aud3_pk0 DRV_PINGROUP_ENTRY_Y(0x1004, 12, 5, 20, 5, -1, -1, -1, -1, 0) 1430*542baf77SAaron Kling #define drive_gpio_aud2_pj7 DRV_PINGROUP_ENTRY_Y(0x100c, 12, 5, 20, 5, -1, -1, -1, -1, 0) 1431*542baf77SAaron Kling #define drive_gpio_aud1_pj6 DRV_PINGROUP_ENTRY_Y(0x1014, 12, 5, 20, 5, -1, -1, -1, -1, 0) 1432*542baf77SAaron Kling #define drive_gpio_aud0_pj5 DRV_PINGROUP_ENTRY_Y(0x101c, 12, 5, 20, 5, -1, -1, -1, -1, 0) 1433*542baf77SAaron Kling #define drive_aud_mclk_pj4 DRV_PINGROUP_ENTRY_Y(0x1024, 12, 5, 20, 5, -1, -1, -1, -1, 0) 1434*542baf77SAaron Kling #define drive_dap1_fs_pj3 DRV_PINGROUP_ENTRY_Y(0x102c, 12, 5, 20, 5, -1, -1, -1, -1, 0) 1435*542baf77SAaron Kling #define drive_dap1_din_pj2 DRV_PINGROUP_ENTRY_Y(0x1034, 12, 5, 20, 5, -1, -1, -1, -1, 0) 1436*542baf77SAaron Kling #define drive_dap1_dout_pj1 DRV_PINGROUP_ENTRY_Y(0x103c, 12, 5, 20, 5, -1, -1, -1, -1, 0) 1437*542baf77SAaron Kling #define drive_dap1_sclk_pj0 DRV_PINGROUP_ENTRY_Y(0x1044, 12, 5, 20, 5, -1, -1, -1, -1, 0) 1438*542baf77SAaron Kling #define drive_dmic1_clk_pm1 DRV_PINGROUP_ENTRY_Y(0x2004, -1, -1, -1, -1, 28, 2, 30, 2, 0) 1439*542baf77SAaron Kling #define drive_dmic1_dat_pm0 DRV_PINGROUP_ENTRY_Y(0x200c, -1, -1, -1, -1, 28, 2, 30, 2, 0) 1440*542baf77SAaron Kling #define drive_dmic2_dat_pm2 DRV_PINGROUP_ENTRY_Y(0x2014, -1, -1, -1, -1, 28, 2, 30, 2, 0) 1441*542baf77SAaron Kling #define drive_dmic2_clk_pm3 DRV_PINGROUP_ENTRY_Y(0x201c, -1, -1, -1, -1, 28, 2, 30, 2, 0) 1442*542baf77SAaron Kling #define drive_dmic4_dat_pm4 DRV_PINGROUP_ENTRY_Y(0x2024, -1, -1, -1, -1, 28, 2, 30, 2, 0) 1443*542baf77SAaron Kling #define drive_dmic4_clk_pm5 DRV_PINGROUP_ENTRY_Y(0x202c, -1, -1, -1, -1, 28, 2, 30, 2, 0) 1444*542baf77SAaron Kling #define drive_dap4_fs_pcc3 DRV_PINGROUP_ENTRY_Y(0x2034, -1, -1, -1, -1, 28, 2, 30, 2, 0) 1445*542baf77SAaron Kling #define drive_dap4_din_pcc2 DRV_PINGROUP_ENTRY_Y(0x203c, -1, -1, -1, -1, 28, 2, 30, 2, 0) 1446*542baf77SAaron Kling #define drive_dap4_dout_pcc1 DRV_PINGROUP_ENTRY_Y(0x2044, -1, -1, -1, -1, 28, 2, 30, 2, 0) 1447*542baf77SAaron Kling #define drive_dap4_sclk_pcc0 DRV_PINGROUP_ENTRY_Y(0x204c, -1, -1, -1, -1, 28, 2, 30, 2, 0) 1448*542baf77SAaron Kling #define drive_extperiph2_clk_po1 DRV_PINGROUP_ENTRY_Y(0x0004, 12, 5, 20, 5, -1, -1, -1, -1, 0) 1449*542baf77SAaron Kling #define drive_extperiph1_clk_po0 DRV_PINGROUP_ENTRY_Y(0x000c, 12, 5, 20, 5, -1, -1, -1, -1, 0) 1450*542baf77SAaron Kling #define drive_cam_i2c_sda_po3 DRV_PINGROUP_ENTRY_Y(0x0014, 12, 5, 20, 5, -1, -1, -1, -1, 0) 1451*542baf77SAaron Kling #define drive_cam_i2c_scl_po2 DRV_PINGROUP_ENTRY_Y(0x001c, 12, 5, 20, 5, -1, -1, -1, -1, 0) 1452*542baf77SAaron Kling #define drive_gpio_cam1_pn0 DRV_PINGROUP_ENTRY_Y(0x0024, 12, 5, 20, 5, -1, -1, -1, -1, 0) 1453*542baf77SAaron Kling #define drive_gpio_cam2_pn1 DRV_PINGROUP_ENTRY_Y(0x002c, 12, 5, 20, 5, -1, -1, -1, -1, 0) 1454*542baf77SAaron Kling #define drive_gpio_cam3_pn2 DRV_PINGROUP_ENTRY_Y(0x0034, 12, 5, 20, 5, -1, -1, -1, -1, 0) 1455*542baf77SAaron Kling #define drive_gpio_cam4_pn3 DRV_PINGROUP_ENTRY_Y(0x003c, 12, 5, 20, 5, -1, -1, -1, -1, 0) 1456*542baf77SAaron Kling #define drive_gpio_cam5_pn4 DRV_PINGROUP_ENTRY_Y(0x0044, 12, 5, 20, 5, -1, -1, -1, -1, 0) 1457*542baf77SAaron Kling #define drive_gpio_cam6_pn5 DRV_PINGROUP_ENTRY_Y(0x004c, 12, 5, 20, 5, -1, -1, -1, -1, 0) 1458*542baf77SAaron Kling #define drive_gpio_cam7_pn6 DRV_PINGROUP_ENTRY_Y(0x0054, 12, 5, 20, 5, -1, -1, -1, -1, 0) 1459*542baf77SAaron Kling #define drive_dap2_din_pc3 DRV_PINGROUP_ENTRY_Y(0x4004, 12, 5, 20, 5, -1, -1, -1, -1, 0) 1460*542baf77SAaron Kling #define drive_dap2_dout_pc2 DRV_PINGROUP_ENTRY_Y(0x400c, 12, 5, 20, 5, -1, -1, -1, -1, 0) 1461*542baf77SAaron Kling #define drive_dap2_fs_pc4 DRV_PINGROUP_ENTRY_Y(0x4014, 12, 5, 20, 5, -1, -1, -1, -1, 0) 1462*542baf77SAaron Kling #define drive_dap2_sclk_pc1 DRV_PINGROUP_ENTRY_Y(0x401c, 12, 5, 20, 5, -1, -1, -1, -1, 0) 1463*542baf77SAaron Kling #define drive_uart4_cts_pb3 DRV_PINGROUP_ENTRY_Y(0x4024, 12, 5, 20, 5, -1, -1, -1, -1, 0) 1464*542baf77SAaron Kling #define drive_uart4_rts_pb2 DRV_PINGROUP_ENTRY_Y(0x402c, 12, 5, 20, 5, -1, -1, -1, -1, 0) 1465*542baf77SAaron Kling #define drive_uart4_rx_pb1 DRV_PINGROUP_ENTRY_Y(0x4034, 12, 5, 20, 5, -1, -1, -1, -1, 0) 1466*542baf77SAaron Kling #define drive_uart4_tx_pb0 DRV_PINGROUP_ENTRY_Y(0x403c, 12, 5, 20, 5, -1, -1, -1, -1, 0) 1467*542baf77SAaron Kling #define drive_gpio_wan4_pc0 DRV_PINGROUP_ENTRY_Y(0x4044, 12, 5, 20, 5, -1, -1, -1, -1, 0) 1468*542baf77SAaron Kling #define drive_gpio_wan3_pb6 DRV_PINGROUP_ENTRY_Y(0x404c, 12, 5, 20, 5, -1, -1, -1, -1, 0) 1469*542baf77SAaron Kling #define drive_gpio_wan2_pb5 DRV_PINGROUP_ENTRY_Y(0x4054, 12, 5, 20, 5, -1, -1, -1, -1, 0) 1470*542baf77SAaron Kling #define drive_gpio_wan1_pb4 DRV_PINGROUP_ENTRY_Y(0x405c, 12, 5, 20, 5, -1, -1, -1, -1, 0) 1471*542baf77SAaron Kling #define drive_gen1_i2c_scl_pc5 DRV_PINGROUP_ENTRY_Y(0x4064, 12, 5, 20, 5, -1, -1, -1, -1, 0) 1472*542baf77SAaron Kling #define drive_gen1_i2c_sda_pc6 DRV_PINGROUP_ENTRY_Y(0x406c, 12, 5, 20, 5, -1, -1, -1, -1, 0) 1473*542baf77SAaron Kling #define drive_uart1_cts_pt3 DRV_PINGROUP_ENTRY_Y(0x5004, 12, 5, 20, 5, -1, -1, -1, -1, 0) 1474*542baf77SAaron Kling #define drive_uart1_rts_pt2 DRV_PINGROUP_ENTRY_Y(0x500c, 12, 5, 20, 5, -1, -1, -1, -1, 0) 1475*542baf77SAaron Kling #define drive_uart1_rx_pt1 DRV_PINGROUP_ENTRY_Y(0x5014, 12, 5, 20, 5, -1, -1, -1, -1, 0) 1476*542baf77SAaron Kling #define drive_uart1_tx_pt0 DRV_PINGROUP_ENTRY_Y(0x501c, 12, 5, 20, 5, -1, -1, -1, -1, 0) 1477*542baf77SAaron Kling #define drive_directdc1_out3_pq5 DRV_PINGROUP_ENTRY_Y(0x502c, 12, 9, 24, 8, -1, -1, -1, -1, 0) 1478*542baf77SAaron Kling #define drive_directdc1_out2_pq4 DRV_PINGROUP_ENTRY_Y(0x5034, 12, 9, 24, 8, -1, -1, -1, -1, 0) 1479*542baf77SAaron Kling #define drive_directdc1_out1_pq3 DRV_PINGROUP_ENTRY_Y(0x503c, 12, 9, 24, 8, -1, -1, -1, -1, 0) 1480*542baf77SAaron Kling #define drive_directdc1_out0_pq2 DRV_PINGROUP_ENTRY_Y(0x5044, 12, 9, 24, 8, -1, -1, -1, -1, 0) 1481*542baf77SAaron Kling #define drive_directdc1_in_pq1 DRV_PINGROUP_ENTRY_Y(0x504c, 12, 9, 24, 8, -1, -1, -1, -1, 0) 1482*542baf77SAaron Kling #define drive_directdc1_clk_pq0 DRV_PINGROUP_ENTRY_Y(0x5054, 12, 9, 24, 8, -1, -1, -1, -1, 0) 1483*542baf77SAaron Kling #define drive_gpio_pq0_pi0 DRV_PINGROUP_ENTRY_Y(0x3004, -1, -1, -1, -1, 28, 2, 30, 2, 0) 1484*542baf77SAaron Kling #define drive_gpio_pq1_pi1 DRV_PINGROUP_ENTRY_Y(0x300c, -1, -1, -1, -1, 28, 2, 30, 2, 0) 1485*542baf77SAaron Kling #define drive_gpio_pq2_pi2 DRV_PINGROUP_ENTRY_Y(0x3014, -1, -1, -1, -1, 28, 2, 30, 2, 0) 1486*542baf77SAaron Kling #define drive_gpio_pq3_pi3 DRV_PINGROUP_ENTRY_Y(0x301c, -1, -1, -1, -1, 28, 2, 30, 2, 0) 1487*542baf77SAaron Kling #define drive_gpio_pq4_pi4 DRV_PINGROUP_ENTRY_Y(0x3024, -1, -1, -1, -1, 28, 2, 30, 2, 0) 1488*542baf77SAaron Kling #define drive_gpio_pq5_pi5 DRV_PINGROUP_ENTRY_Y(0x302c, -1, -1, -1, -1, 28, 2, 30, 2, 0) 1489*542baf77SAaron Kling #define drive_gpio_pq6_pi6 DRV_PINGROUP_ENTRY_Y(0x3034, -1, -1, -1, -1, 28, 2, 30, 2, 0) 1490*542baf77SAaron Kling #define drive_gpio_pq7_pi7 DRV_PINGROUP_ENTRY_Y(0x303c, -1, -1, -1, -1, 28, 2, 30, 2, 0) 1491*542baf77SAaron Kling #define drive_gpio_edp2_pp5 DRV_PINGROUP_ENTRY_Y(0x10004, 12, 5, 20, 5, -1, -1, -1, -1, 0) 1492*542baf77SAaron Kling #define drive_gpio_edp3_pp6 DRV_PINGROUP_ENTRY_Y(0x1000c, 12, 5, 20, 5, -1, -1, -1, -1, 0) 1493*542baf77SAaron Kling #define drive_gpio_edp0_pp3 DRV_PINGROUP_ENTRY_Y(0x10014, 12, 5, 20, 5, -1, -1, -1, -1, 0) 1494*542baf77SAaron Kling #define drive_gpio_edp1_pp4 DRV_PINGROUP_ENTRY_Y(0x1001c, 12, 5, 20, 5, -1, -1, -1, -1, 0) 1495*542baf77SAaron Kling #define drive_dp_aux_ch0_hpd_pp0 DRV_PINGROUP_ENTRY_Y(0x10024, 12, 5, 20, 5, -1, -1, -1, -1, 0) 1496*542baf77SAaron Kling #define drive_dp_aux_ch1_hpd_pp1 DRV_PINGROUP_ENTRY_Y(0x1002c, 12, 5, 20, 5, -1, -1, -1, -1, 0) 1497*542baf77SAaron Kling #define drive_hdmi_cec_pp2 DRV_PINGROUP_ENTRY_Y(0x10034, 12, 5, 20, 5, -1, -1, -1, -1, 0) 1498*542baf77SAaron Kling #define drive_pex_l2_clkreq_n_pa6 DRV_PINGROUP_ENTRY_Y(0x7004, 12, 5, 20, 5, -1, -1, -1, -1, 0) 1499*542baf77SAaron Kling #define drive_pex_wake_n_pa2 DRV_PINGROUP_ENTRY_Y(0x700c, 12, 5, 20, 5, -1, -1, -1, -1, 0) 1500*542baf77SAaron Kling #define drive_pex_l1_clkreq_n_pa4 DRV_PINGROUP_ENTRY_Y(0x7014, 12, 5, 20, 5, -1, -1, -1, -1, 0) 1501*542baf77SAaron Kling #define drive_pex_l1_rst_n_pa3 DRV_PINGROUP_ENTRY_Y(0x701c, 12, 5, 20, 5, -1, -1, -1, -1, 0) 1502*542baf77SAaron Kling #define drive_pex_l0_clkreq_n_pa1 DRV_PINGROUP_ENTRY_Y(0x7024, 12, 5, 20, 5, -1, -1, -1, -1, 0) 1503*542baf77SAaron Kling #define drive_pex_l0_rst_n_pa0 DRV_PINGROUP_ENTRY_Y(0x702c, 12, 5, 20, 5, -1, -1, -1, -1, 0) 1504*542baf77SAaron Kling #define drive_pex_l2_rst_n_pa5 DRV_PINGROUP_ENTRY_Y(0x7034, 12, 5, 20, 5, -1, -1, -1, -1, 0) 1505*542baf77SAaron Kling #define drive_sdmmc1_clk_pd0 DRV_PINGROUP_ENTRY_Y(0x8004, -1, -1, -1, -1, 28, 2, 30, 2, 0) 1506*542baf77SAaron Kling #define drive_sdmmc1_cmd_pd1 DRV_PINGROUP_ENTRY_Y(0x800c, -1, -1, -1, -1, 28, 2, 30, 2, 0) 1507*542baf77SAaron Kling #define drive_sdmmc1_dat3_pd5 DRV_PINGROUP_ENTRY_Y(0x8018, -1, -1, -1, -1, 28, 2, 30, 2, 0) 1508*542baf77SAaron Kling #define drive_sdmmc1_dat2_pd4 DRV_PINGROUP_ENTRY_Y(0x8020, -1, -1, -1, -1, 28, 2, 30, 2, 0) 1509*542baf77SAaron Kling #define drive_sdmmc1_dat1_pd3 DRV_PINGROUP_ENTRY_Y(0x8028, -1, -1, -1, -1, 28, 2, 30, 2, 0) 1510*542baf77SAaron Kling #define drive_sdmmc1_dat0_pd2 DRV_PINGROUP_ENTRY_Y(0x8030, -1, -1, -1, -1, 28, 2, 30, 2, 0) 1511*542baf77SAaron Kling #define drive_eqos_td3_pe4 DRV_PINGROUP_ENTRY_Y(0x9004, -1, -1, -1, -1, 28, 2, 30, 2, 0) 1512*542baf77SAaron Kling #define drive_eqos_td2_pe3 DRV_PINGROUP_ENTRY_Y(0x900c, -1, -1, -1, -1, 28, 2, 30, 2, 0) 1513*542baf77SAaron Kling #define drive_eqos_td1_pe2 DRV_PINGROUP_ENTRY_Y(0x9014, -1, -1, -1, -1, 28, 2, 30, 2, 0) 1514*542baf77SAaron Kling #define drive_eqos_td0_pe1 DRV_PINGROUP_ENTRY_Y(0x901c, -1, -1, -1, -1, 28, 2, 30, 2, 0) 1515*542baf77SAaron Kling #define drive_eqos_rd3_pf1 DRV_PINGROUP_ENTRY_Y(0x9024, -1, -1, -1, -1, 28, 2, 30, 2, 0) 1516*542baf77SAaron Kling #define drive_eqos_rd2_pf0 DRV_PINGROUP_ENTRY_Y(0x902c, -1, -1, -1, -1, 28, 2, 30, 2, 0) 1517*542baf77SAaron Kling #define drive_eqos_rd1_pe7 DRV_PINGROUP_ENTRY_Y(0x9034, -1, -1, -1, -1, 28, 2, 30, 2, 0) 1518*542baf77SAaron Kling #define drive_eqos_mdio_pf4 DRV_PINGROUP_ENTRY_Y(0x903c, -1, -1, -1, -1, 28, 2, 30, 2, 0) 1519*542baf77SAaron Kling #define drive_eqos_rd0_pe6 DRV_PINGROUP_ENTRY_Y(0x9044, -1, -1, -1, -1, 28, 2, 30, 2, 0) 1520*542baf77SAaron Kling #define drive_eqos_mdc_pf5 DRV_PINGROUP_ENTRY_Y(0x904c, -1, -1, -1, -1, 28, 2, 30, 2, 0) 1521*542baf77SAaron Kling #define drive_eqos_txc_pe0 DRV_PINGROUP_ENTRY_Y(0x9058, -1, -1, -1, -1, 28, 2, 30, 2, 0) 1522*542baf77SAaron Kling #define drive_eqos_rxc_pf3 DRV_PINGROUP_ENTRY_Y(0x9060, -1, -1, -1, -1, 28, 2, 30, 2, 0) 1523*542baf77SAaron Kling #define drive_eqos_tx_ctl_pe5 DRV_PINGROUP_ENTRY_Y(0x9068, -1, -1, -1, -1, 28, 2, 30, 2, 0) 1524*542baf77SAaron Kling #define drive_eqos_rx_ctl_pf2 DRV_PINGROUP_ENTRY_Y(0x9070, -1, -1, -1, -1, 28, 2, 30, 2, 0) 1525*542baf77SAaron Kling #define drive_sdmmc3_dat3_pg5 DRV_PINGROUP_ENTRY_Y(0xa004, -1, -1, -1, -1, 28, 2, 30, 2, 0) 1526*542baf77SAaron Kling #define drive_sdmmc3_dat2_pg4 DRV_PINGROUP_ENTRY_Y(0xa00c, -1, -1, -1, -1, 28, 2, 30, 2, 0) 1527*542baf77SAaron Kling #define drive_sdmmc3_dat1_pg3 DRV_PINGROUP_ENTRY_Y(0xa014, -1, -1, -1, -1, 28, 2, 30, 2, 0) 1528*542baf77SAaron Kling #define drive_sdmmc3_dat0_pg2 DRV_PINGROUP_ENTRY_Y(0xa01c, -1, -1, -1, -1, 28, 2, 30, 2, 0) 1529*542baf77SAaron Kling #define drive_sdmmc3_cmd_pg1 DRV_PINGROUP_ENTRY_Y(0xa028, -1, -1, -1, -1, 28, 2, 30, 2, 0) 1530*542baf77SAaron Kling #define drive_sdmmc3_clk_pg0 DRV_PINGROUP_ENTRY_Y(0xa030, -1, -1, -1, -1, 28, 2, 30, 2, 0) 1531*542baf77SAaron Kling #define drive_qspi_io3_pr4 DRV_PINGROUP_ENTRY_Y(0xB004, -1, -1, -1, -1, 28, 2, 30, 2, 0) 1532*542baf77SAaron Kling #define drive_qspi_io2_pr3 DRV_PINGROUP_ENTRY_Y(0xB00C, -1, -1, -1, -1, 28, 2, 30, 2, 0) 1533*542baf77SAaron Kling #define drive_qspi_io1_pr2 DRV_PINGROUP_ENTRY_Y(0xB014, -1, -1, -1, -1, 28, 2, 30, 2, 0) 1534*542baf77SAaron Kling #define drive_qspi_io0_pr1 DRV_PINGROUP_ENTRY_Y(0xB01C, -1, -1, -1, -1, 28, 2, 30, 2, 0) 1535*542baf77SAaron Kling #define drive_qspi_sck_pr0 DRV_PINGROUP_ENTRY_Y(0xB024, -1, -1, -1, -1, 28, 2, 30, 2, 0) 1536*542baf77SAaron Kling #define drive_qspi_cs_n_pr5 DRV_PINGROUP_ENTRY_Y(0xB02C, -1, -1, -1, -1, 28, 2, 30, 2, 0) 1537*542baf77SAaron Kling #define drive_gpio_wan8_ph3 DRV_PINGROUP_ENTRY_Y(0xd004, 12, 5, 20, 5, -1, -1, -1, -1, 0) 1538*542baf77SAaron Kling #define drive_gpio_wan7_ph2 DRV_PINGROUP_ENTRY_Y(0xd00c, 12, 5, 20, 5, -1, -1, -1, -1, 0) 1539*542baf77SAaron Kling #define drive_gpio_wan6_ph1 DRV_PINGROUP_ENTRY_Y(0xd014, 12, 5, 20, 5, -1, -1, -1, -1, 0) 1540*542baf77SAaron Kling #define drive_gpio_wan5_ph0 DRV_PINGROUP_ENTRY_Y(0xd01c, 12, 5, 20, 5, -1, -1, -1, -1, 0) 1541*542baf77SAaron Kling #define drive_uart2_tx_px0 DRV_PINGROUP_ENTRY_Y(0xd024, 12, 5, 20, 5, -1, -1, -1, -1, 0) 1542*542baf77SAaron Kling #define drive_uart2_rx_px1 DRV_PINGROUP_ENTRY_Y(0xd02c, 12, 5, 20, 5, -1, -1, -1, -1, 0) 1543*542baf77SAaron Kling #define drive_uart2_rts_px2 DRV_PINGROUP_ENTRY_Y(0xd034, 12, 5, 20, 5, -1, -1, -1, -1, 0) 1544*542baf77SAaron Kling #define drive_uart2_cts_px3 DRV_PINGROUP_ENTRY_Y(0xd03c, 12, 5, 20, 5, -1, -1, -1, -1, 0) 1545*542baf77SAaron Kling #define drive_uart5_rx_px5 DRV_PINGROUP_ENTRY_Y(0xd044, 12, 5, 20, 5, -1, -1, -1, -1, 0) 1546*542baf77SAaron Kling #define drive_uart5_tx_px4 DRV_PINGROUP_ENTRY_Y(0xd04c, 12, 5, 20, 5, -1, -1, -1, -1, 0) 1547*542baf77SAaron Kling #define drive_uart5_rts_px6 DRV_PINGROUP_ENTRY_Y(0xd054, 12, 5, 20, 5, -1, -1, -1, -1, 0) 1548*542baf77SAaron Kling #define drive_uart5_cts_px7 DRV_PINGROUP_ENTRY_Y(0xd05c, 12, 5, 20, 5, -1, -1, -1, -1, 0) 1549*542baf77SAaron Kling #define drive_gpio_mdm1_py0 DRV_PINGROUP_ENTRY_Y(0xd064, 12, 5, 20, 5, -1, -1, -1, -1, 0) 1550*542baf77SAaron Kling #define drive_gpio_mdm2_py1 DRV_PINGROUP_ENTRY_Y(0xd06c, 12, 5, 20, 5, -1, -1, -1, -1, 0) 1551*542baf77SAaron Kling #define drive_gpio_mdm3_py2 DRV_PINGROUP_ENTRY_Y(0xd074, 12, 5, 20, 5, -1, -1, -1, -1, 0) 1552*542baf77SAaron Kling #define drive_gpio_mdm4_py3 DRV_PINGROUP_ENTRY_Y(0xd07c, 12, 5, 20, 5, -1, -1, -1, -1, 0) 1553*542baf77SAaron Kling #define drive_gpio_mdm5_py4 DRV_PINGROUP_ENTRY_Y(0xd084, 12, 5, 20, 5, -1, -1, -1, -1, 0) 1554*542baf77SAaron Kling #define drive_gpio_mdm6_py5 DRV_PINGROUP_ENTRY_Y(0xd08c, 12, 5, 20, 5, -1, -1, -1, -1, 0) 1555*542baf77SAaron Kling #define drive_gpio_mdm7_py6 DRV_PINGROUP_ENTRY_Y(0xd094, 12, 5, 20, 5, -1, -1, -1, -1, 0) 1556*542baf77SAaron Kling #define drive_bcpu_pwr_req_ph4 DRV_PINGROUP_ENTRY_Y(0xd09c, 12, 5, 20, 5, -1, -1, -1, -1, 0) 1557*542baf77SAaron Kling #define drive_mcpu_pwr_req_ph5 DRV_PINGROUP_ENTRY_Y(0xd0a4, 12, 5, 20, 5, -1, -1, -1, -1, 0) 1558*542baf77SAaron Kling #define drive_gpu_pwr_req_ph6 DRV_PINGROUP_ENTRY_Y(0xd0ac, 12, 5, 20, 5, -1, -1, -1, -1, 0) 1559*542baf77SAaron Kling #define drive_gen7_i2c_scl_pl0 DRV_PINGROUP_ENTRY_Y(0xd0b4, 12, 5, 20, 5, -1, -1, -1, -1, 0) 1560*542baf77SAaron Kling #define drive_gen7_i2c_sda_pl1 DRV_PINGROUP_ENTRY_Y(0xd0bc, 12, 5, 20, 5, -1, -1, -1, -1, 0) 1561*542baf77SAaron Kling #define drive_gen9_i2c_sda_pl3 DRV_PINGROUP_ENTRY_Y(0xd0c4, 12, 5, 20, 5, -1, -1, -1, -1, 0) 1562*542baf77SAaron Kling #define drive_gen9_i2c_scl_pl2 DRV_PINGROUP_ENTRY_Y(0xd0cc, 12, 5, 20, 5, -1, -1, -1, -1, 0) 1563*542baf77SAaron Kling #define drive_usb_vbus_en0_pl4 DRV_PINGROUP_ENTRY_Y(0xd0d4, 12, 5, 20, 5, -1, -1, -1, -1, 0) 1564*542baf77SAaron Kling #define drive_usb_vbus_en1_pl5 DRV_PINGROUP_ENTRY_Y(0xd0dc, 12, 5, 20, 5, -1, -1, -1, -1, 0) 1565*542baf77SAaron Kling #define drive_gp_pwm7_pl7 DRV_PINGROUP_ENTRY_Y(0xd0e4, 12, 5, 20, 5, -1, -1, -1, -1, 0) 1566*542baf77SAaron Kling #define drive_gp_pwm6_pl6 DRV_PINGROUP_ENTRY_Y(0xd0ec, 12, 5, 20, 5, -1, -1, -1, -1, 0) 1567*542baf77SAaron Kling #define drive_ufs0_rst_pbb1 DRV_PINGROUP_ENTRY_Y(0x11004, 12, 9, 24, 8, -1, -1, -1, -1, 0) 1568*542baf77SAaron Kling #define drive_ufs0_ref_clk_pbb0 DRV_PINGROUP_ENTRY_Y(0x1100c, 12, 9, 24, 8, -1, -1, -1, -1, 0) 1569*542baf77SAaron Kling 1570*542baf77SAaron Kling #define drive_directdc_comp DRV_PINGROUP_ENTRY_N(no_entry) 1571*542baf77SAaron Kling #define drive_sdmmc1_comp DRV_PINGROUP_ENTRY_N(no_entry) 1572*542baf77SAaron Kling #define drive_eqos_comp DRV_PINGROUP_ENTRY_N(no_entry) 1573*542baf77SAaron Kling #define drive_sdmmc3_comp DRV_PINGROUP_ENTRY_N(no_entry) 1574*542baf77SAaron Kling #define drive_sdmmc4_clk DRV_PINGROUP_ENTRY_N(no_entry) 1575*542baf77SAaron Kling #define drive_sdmmc4_cmd DRV_PINGROUP_ENTRY_N(no_entry) 1576*542baf77SAaron Kling #define drive_sdmmc4_dqs DRV_PINGROUP_ENTRY_N(no_entry) 1577*542baf77SAaron Kling #define drive_sdmmc4_dat7 DRV_PINGROUP_ENTRY_N(no_entry) 1578*542baf77SAaron Kling #define drive_sdmmc4_dat6 DRV_PINGROUP_ENTRY_N(no_entry) 1579*542baf77SAaron Kling #define drive_sdmmc4_dat5 DRV_PINGROUP_ENTRY_N(no_entry) 1580*542baf77SAaron Kling #define drive_sdmmc4_dat4 DRV_PINGROUP_ENTRY_N(no_entry) 1581*542baf77SAaron Kling #define drive_sdmmc4_dat3 DRV_PINGROUP_ENTRY_N(no_entry) 1582*542baf77SAaron Kling #define drive_sdmmc4_dat2 DRV_PINGROUP_ENTRY_N(no_entry) 1583*542baf77SAaron Kling #define drive_sdmmc4_dat1 DRV_PINGROUP_ENTRY_N(no_entry) 1584*542baf77SAaron Kling #define drive_sdmmc4_dat0 DRV_PINGROUP_ENTRY_N(no_entry) 1585*542baf77SAaron Kling #define drive_qspi_comp DRV_PINGROUP_ENTRY_N(no_entry) 1586*542baf77SAaron Kling 1587*542baf77SAaron Kling /* AON drive pin groups */ 1588*542baf77SAaron Kling #define drive_touch_clk_pee2 DRV_PINGROUP_ENTRY_Y(0x2004, 12, 5, 20, 5, -1, -1, -1, -1, 1) 1589*542baf77SAaron Kling #define drive_uart3_cts_pw5 DRV_PINGROUP_ENTRY_Y(0x200c, 12, 5, 20, 5, -1, -1, -1, -1, 1) 1590*542baf77SAaron Kling #define drive_uart3_rts_pw4 DRV_PINGROUP_ENTRY_Y(0x2014, 12, 5, 20, 5, -1, -1, -1, -1, 1) 1591*542baf77SAaron Kling #define drive_uart3_rx_pw3 DRV_PINGROUP_ENTRY_Y(0x201c, 12, 5, 20, 5, -1, -1, -1, -1, 1) 1592*542baf77SAaron Kling #define drive_uart3_tx_pw2 DRV_PINGROUP_ENTRY_Y(0x2024, 12, 5, 20, 5, -1, -1, -1, -1, 1) 1593*542baf77SAaron Kling #define drive_gen8_i2c_sda_pw1 DRV_PINGROUP_ENTRY_Y(0x202c, 12, 5, 20, 5, -1, -1, -1, -1, 1) 1594*542baf77SAaron Kling #define drive_gen8_i2c_scl_pw0 DRV_PINGROUP_ENTRY_Y(0x2034, 12, 5, 20, 5, -1, -1, -1, -1, 1) 1595*542baf77SAaron Kling #define drive_uart7_rx_pw7 DRV_PINGROUP_ENTRY_Y(0x203c, 12, 5, 20, 5, -1, -1, -1, -1, 1) 1596*542baf77SAaron Kling #define drive_uart7_tx_pw6 DRV_PINGROUP_ENTRY_Y(0x2044, 12, 5, 20, 5, -1, -1, -1, -1, 1) 1597*542baf77SAaron Kling #define drive_gpio_sen0_pv0 DRV_PINGROUP_ENTRY_Y(0x204c, 12, 5, 20, 5, -1, -1, -1, -1, 1) 1598*542baf77SAaron Kling #define drive_gpio_sen1_pv1 DRV_PINGROUP_ENTRY_Y(0x2054, 12, 5, 20, 5, -1, -1, -1, -1, 1) 1599*542baf77SAaron Kling #define drive_gpio_sen2_pv2 DRV_PINGROUP_ENTRY_Y(0x205c, 12, 5, 20, 5, -1, -1, -1, -1, 1) 1600*542baf77SAaron Kling #define drive_gpio_sen3_pv3 DRV_PINGROUP_ENTRY_Y(0x2064, 12, 5, 20, 5, -1, -1, -1, -1, 1) 1601*542baf77SAaron Kling #define drive_gpio_sen4_pv4 DRV_PINGROUP_ENTRY_Y(0x206c, 12, 5, 20, 5, -1, -1, -1, -1, 1) 1602*542baf77SAaron Kling #define drive_gpio_sen5_pv5 DRV_PINGROUP_ENTRY_Y(0x2074, 12, 5, 20, 5, -1, -1, -1, -1, 1) 1603*542baf77SAaron Kling #define drive_gpio_sen6_pv6 DRV_PINGROUP_ENTRY_Y(0x207c, 12, 5, 20, 5, -1, -1, -1, -1, 1) 1604*542baf77SAaron Kling #define drive_gpio_sen7_pv7 DRV_PINGROUP_ENTRY_Y(0x2084, 12, 5, 20, 5, -1, -1, -1, -1, 1) 1605*542baf77SAaron Kling #define drive_gpio_sen8_pee0 DRV_PINGROUP_ENTRY_Y(0x208c, 12, 5, 20, 5, -1, -1, -1, -1, 1) 1606*542baf77SAaron Kling #define drive_gpio_sen9_pee1 DRV_PINGROUP_ENTRY_Y(0x2094, 12, 5, 20, 5, -1, -1, -1, -1, 1) 1607*542baf77SAaron Kling #define drive_can_gpio7_paa7 DRV_PINGROUP_ENTRY_Y(0x3004, -1, -1, -1, -1, 28, 2, 30, 2, 1) 1608*542baf77SAaron Kling #define drive_can1_dout_pz0 DRV_PINGROUP_ENTRY_Y(0x300C, -1, -1, -1, -1, 28, 2, 30, 2, 1) 1609*542baf77SAaron Kling #define drive_can1_din_pz1 DRV_PINGROUP_ENTRY_Y(0x3014, -1, -1, -1, -1, 28, 2, 30, 2, 1) 1610*542baf77SAaron Kling #define drive_can0_dout_pz2 DRV_PINGROUP_ENTRY_Y(0x301c, -1, -1, -1, -1, 28, 2, 30, 2, 1) 1611*542baf77SAaron Kling #define drive_can0_din_pz3 DRV_PINGROUP_ENTRY_Y(0x3024, -1, -1, -1, -1, 28, 2, 30, 2, 1) 1612*542baf77SAaron Kling #define drive_can_gpio0_paa0 DRV_PINGROUP_ENTRY_Y(0x302c, -1, -1, -1, -1, 28, 2, 30, 2, 1) 1613*542baf77SAaron Kling #define drive_can_gpio1_paa1 DRV_PINGROUP_ENTRY_Y(0x3034, -1, -1, -1, -1, 28, 2, 30, 2, 1) 1614*542baf77SAaron Kling #define drive_can_gpio2_paa2 DRV_PINGROUP_ENTRY_Y(0x303c, -1, -1, -1, -1, 28, 2, 30, 2, 1) 1615*542baf77SAaron Kling #define drive_can_gpio3_paa3 DRV_PINGROUP_ENTRY_Y(0x3044, -1, -1, -1, -1, 28, 2, 30, 2, 1) 1616*542baf77SAaron Kling #define drive_can_gpio4_paa4 DRV_PINGROUP_ENTRY_Y(0x304c, -1, -1, -1, -1, 28, 2, 30, 2, 1) 1617*542baf77SAaron Kling #define drive_can_gpio5_paa5 DRV_PINGROUP_ENTRY_Y(0x3054, -1, -1, -1, -1, 28, 2, 30, 2, 1) 1618*542baf77SAaron Kling #define drive_can_gpio6_paa6 DRV_PINGROUP_ENTRY_Y(0x305c, -1, -1, -1, -1, 28, 2, 30, 2, 1) 1619*542baf77SAaron Kling #define drive_gpio_sw1_pff1 DRV_PINGROUP_ENTRY_Y(0x1004, 12, 5, 20, 5, -1, -1, -1, -1, 1) 1620*542baf77SAaron Kling #define drive_gpio_sw2_pff2 DRV_PINGROUP_ENTRY_Y(0x100c, 12, 5, 20, 5, -1, -1, -1, -1, 1) 1621*542baf77SAaron Kling #define drive_gpio_sw3_pff3 DRV_PINGROUP_ENTRY_Y(0x1014, 12, 5, 20, 5, -1, -1, -1, -1, 1) 1622*542baf77SAaron Kling #define drive_gpio_sw4_pff4 DRV_PINGROUP_ENTRY_Y(0x101c, 12, 5, 20, 5, -1, -1, -1, -1, 1) 1623*542baf77SAaron Kling #define drive_shutdown DRV_PINGROUP_ENTRY_Y(0x1024, 12, 5, 20, 5, -1, -1, -1, -1, 1) 1624*542baf77SAaron Kling #define drive_pmu_int DRV_PINGROUP_ENTRY_Y(0x102C, 12, 5, 20, 5, -1, -1, -1, -1, 1) 1625*542baf77SAaron Kling #define drive_safe_state_ps3 DRV_PINGROUP_ENTRY_Y(0x1034, 12, 5, 20, 5, -1, -1, -1, -1, 1) 1626*542baf77SAaron Kling #define drive_vcomp_alert_ps4 DRV_PINGROUP_ENTRY_Y(0x103c, 12, 5, 20, 5, -1, -1, -1, -1, 1) 1627*542baf77SAaron Kling #define drive_soc_pwr_req DRV_PINGROUP_ENTRY_Y(0x1044, 12, 5, 20, 5, -1, -1, -1, -1, 1) 1628*542baf77SAaron Kling #define drive_batt_oc_ps2 DRV_PINGROUP_ENTRY_Y(0x104c, 12, 5, 20, 5, -1, -1, -1, -1, 1) 1629*542baf77SAaron Kling #define drive_clk_32k_in DRV_PINGROUP_ENTRY_Y(0x1054, 12, 5, 20, 5, -1, -1, -1, -1, 1) 1630*542baf77SAaron Kling #define drive_power_on_pff0 DRV_PINGROUP_ENTRY_Y(0x105c, 12, 5, 20, 5, -1, -1, -1, -1, 1) 1631*542baf77SAaron Kling #define drive_pwr_i2c_scl_ps0 DRV_PINGROUP_ENTRY_Y(0x1064, 12, 5, 20, 5, -1, -1, -1, -1, 1) 1632*542baf77SAaron Kling #define drive_pwr_i2c_sda_ps1 DRV_PINGROUP_ENTRY_Y(0x106c, 12, 5, 20, 5, -1, -1, -1, -1, 1) 1633*542baf77SAaron Kling #define drive_gpio_dis0_pu0 DRV_PINGROUP_ENTRY_Y(0x1084, 12, 5, 20, 5, -1, -1, -1, -1, 1) 1634*542baf77SAaron Kling #define drive_gpio_dis1_pu1 DRV_PINGROUP_ENTRY_Y(0x108c, 12, 5, 20, 5, -1, -1, -1, -1, 1) 1635*542baf77SAaron Kling #define drive_gpio_dis2_pu2 DRV_PINGROUP_ENTRY_Y(0x1094, 12, 5, 20, 5, -1, -1, -1, -1, 1) 1636*542baf77SAaron Kling #define drive_gpio_dis3_pu3 DRV_PINGROUP_ENTRY_Y(0x109c, 12, 5, 20, 5, -1, -1, -1, -1, 1) 1637*542baf77SAaron Kling #define drive_gpio_dis4_pu4 DRV_PINGROUP_ENTRY_Y(0x10a4, 12, 5, 20, 5, -1, -1, -1, -1, 1) 1638*542baf77SAaron Kling #define drive_gpio_dis5_pu5 DRV_PINGROUP_ENTRY_Y(0x10ac, 12, 5, 20, 5, -1, -1, -1, -1, 1) 1639*542baf77SAaron Kling 1640*542baf77SAaron Kling #define PINGROUP(pg_name, f0, f1, f2, f3, r, bank, pupd, e_io_hv, e_lpbk, e_input, e_lpdr, e_pbias_buf, \ 1641*542baf77SAaron Kling gpio_sfio_sel, e_od, schmitt_b, drvtype, epreemp, io_reset, rfu_in) \ 1642*542baf77SAaron Kling { \ 1643*542baf77SAaron Kling .name = #pg_name, \ 1644*542baf77SAaron Kling .pins = pg_name##_pins, \ 1645*542baf77SAaron Kling .npins = ARRAY_SIZE(pg_name##_pins), \ 1646*542baf77SAaron Kling .funcs = { \ 1647*542baf77SAaron Kling TEGRA_MUX_##f0, \ 1648*542baf77SAaron Kling TEGRA_MUX_##f1, \ 1649*542baf77SAaron Kling TEGRA_MUX_##f2, \ 1650*542baf77SAaron Kling TEGRA_MUX_##f3, \ 1651*542baf77SAaron Kling }, \ 1652*542baf77SAaron Kling PIN_PINGROUP_ENTRY_Y(r, bank, pupd, e_io_hv, e_lpbk, \ 1653*542baf77SAaron Kling e_input, e_lpdr, e_pbias_buf, \ 1654*542baf77SAaron Kling gpio_sfio_sel, e_od, \ 1655*542baf77SAaron Kling schmitt_b, drvtype, \ 1656*542baf77SAaron Kling epreemp, io_reset, \ 1657*542baf77SAaron Kling rfu_in) \ 1658*542baf77SAaron Kling drive_##pg_name, \ 1659*542baf77SAaron Kling } 1660*542baf77SAaron Kling 1661*542baf77SAaron Kling static const struct tegra_pingroup tegra186_groups[] = { 1662*542baf77SAaron Kling PINGROUP(gpio_aud3_pk0, RSVD0, DSPK1, SPDIF, RSVD3, 0x1000, 0, Y, -1, -1, 6, 8, -1, 10, 11, 12, N, -1, -1, N), 1663*542baf77SAaron Kling PINGROUP(gpio_aud2_pj7, RSVD0, DSPK1, SPDIF, RSVD3, 0x1008, 0, Y, -1, -1, 6, 8, -1, 10, 11, 12, N, -1, -1, N), 1664*542baf77SAaron Kling PINGROUP(gpio_aud1_pj6, RSVD0, RSVD1, RSVD2, RSVD3, 0x1010, 0, Y, -1, -1, 6, 8, -1, 10, 11, 12, N, -1, -1, N), 1665*542baf77SAaron Kling PINGROUP(gpio_aud0_pj5, RSVD0, RSVD1, RSVD2, RSVD3, 0x1018, 0, Y, -1, -1, 6, 8, -1, 10, 11, 12, N, -1, -1, N), 1666*542baf77SAaron Kling PINGROUP(aud_mclk_pj4, AUD, RSVD1, RSVD2, RSVD3, 0x1020, 0, Y, -1, -1, 6, 8, -1, 10, 11, 12, N, -1, -1, N), 1667*542baf77SAaron Kling PINGROUP(dap1_fs_pj3, I2S1, RSVD1, RSVD2, RSVD3, 0x1028, 0, Y, -1, -1, 6, 8, -1, 10, 11, 12, N, -1, -1, N), 1668*542baf77SAaron Kling PINGROUP(dap1_din_pj2, I2S1, RSVD1, RSVD2, RSVD3, 0x1030, 0, Y, -1, -1, 6, 8, -1, 10, 11, 12, N, -1, -1, N), 1669*542baf77SAaron Kling PINGROUP(dap1_dout_pj1, I2S1, RSVD1, RSVD2, RSVD3, 0x1038, 0, Y, -1, -1, 6, 8, -1, 10, 11, 12, N, -1, -1, N), 1670*542baf77SAaron Kling PINGROUP(dap1_sclk_pj0, I2S1, RSVD1, RSVD2, RSVD3, 0x1040, 0, Y, -1, -1, 6, 8, -1, 10, 11, 12, N, -1, -1, N), 1671*542baf77SAaron Kling PINGROUP(dmic1_clk_pm1, DMIC1, I2S3, RSVD2, RSVD3, 0x2000, 0, Y, -1, -1, 6, -1, 9, 10, -1, 12, Y, -1, -1, Y), 1672*542baf77SAaron Kling PINGROUP(dmic1_dat_pm0, DMIC1, I2S3, RSVD2, RSVD3, 0x2008, 0, Y, -1, -1, 6, -1, 9, 10, -1, 12, Y, -1, -1, Y), 1673*542baf77SAaron Kling PINGROUP(dmic2_dat_pm2, DMIC2, I2S3, RSVD2, RSVD3, 0x2010, 0, Y, -1, -1, 6, -1, 9, 10, -1, 12, Y, -1, -1, Y), 1674*542baf77SAaron Kling PINGROUP(dmic2_clk_pm3, DMIC2, I2S3, RSVD2, RSVD3, 0x2018, 0, Y, -1, -1, 6, -1, 9, 10, -1, 12, Y, -1, -1, Y), 1675*542baf77SAaron Kling PINGROUP(dmic4_dat_pm4, DMIC4, DSPK0, RSVD2, RSVD3, 0x2020, 0, Y, -1, -1, 6, -1, 9, 10, -1, 12, Y, -1, -1, Y), 1676*542baf77SAaron Kling PINGROUP(dmic4_clk_pm5, DMIC4, DSPK0, RSVD2, RSVD3, 0x2028, 0, Y, -1, -1, 6, -1, 9, 10, -1, 12, Y, -1, -1, Y), 1677*542baf77SAaron Kling PINGROUP(dap4_fs_pcc3, I2S4, RSVD1, RSVD2, RSVD3, 0x2030, 0, Y, -1, -1, 6, -1, 9, 10, -1, 12, Y, -1, -1, Y), 1678*542baf77SAaron Kling PINGROUP(dap4_din_pcc2, I2S4, RSVD1, RSVD2, RSVD3, 0x2038, 0, Y, -1, -1, 6, -1, 9, 10, -1, 12, Y, -1, -1, Y), 1679*542baf77SAaron Kling PINGROUP(dap4_dout_pcc1, I2S4, RSVD1, RSVD2, RSVD3, 0x2040, 0, Y, -1, -1, 6, -1, 9, 10, -1, 12, Y, -1, -1, Y), 1680*542baf77SAaron Kling PINGROUP(dap4_sclk_pcc0, I2S4, RSVD1, RSVD2, RSVD3, 0x2048, 0, Y, -1, -1, 6, -1, 9, 10, -1, 12, Y, -1, -1, Y), 1681*542baf77SAaron Kling PINGROUP(extperiph2_clk_po1, EXTPERIPH2, RSVD1, RSVD2, RSVD3, 0x0000, 0, Y, -1, -1, 6, 8, -1, 10, 11, 12, N, -1, -1, N), 1682*542baf77SAaron Kling PINGROUP(extperiph1_clk_po0, EXTPERIPH1, RSVD1, RSVD2, RSVD3, 0x0008, 0, Y, -1, -1, 6, 8, -1, 10, 11, 12, N, -1, -1, N), 1683*542baf77SAaron Kling PINGROUP(cam_i2c_sda_po3, I2C3, RSVD1, RSVD2, RSVD3, 0x0010, 0, Y, 5, -1, 6, 8, -1, 10, 11, 12, N, -1, -1, N), 1684*542baf77SAaron Kling PINGROUP(cam_i2c_scl_po2, I2C3, RSVD1, RSVD2, RSVD3, 0x0018, 0, Y, 5, -1, 6, 8, -1, 10, 11, 12, N, -1, -1, N), 1685*542baf77SAaron Kling PINGROUP(gpio_cam1_pn0, VGP1, RSVD1, RSVD2, RSVD3, 0x0020, 0, Y, -1, -1, 6, 8, -1, 10, 11, 12, N, -1, -1, N), 1686*542baf77SAaron Kling PINGROUP(gpio_cam2_pn1, VGP2, EXTPERIPH3, RSVD2, RSVD3, 0x0028, 0, Y, -1, -1, 6, 8, -1, 10, 11, 12, N, -1, -1, N), 1687*542baf77SAaron Kling PINGROUP(gpio_cam3_pn2, VGP3, EXTPERIPH4, RSVD2, RSVD3, 0x0030, 0, Y, -1, -1, 6, 8, -1, 10, 11, 12, N, -1, -1, N), 1688*542baf77SAaron Kling PINGROUP(gpio_cam4_pn3, VGP4, SPI4, RSVD2, RSVD3, 0x0038, 0, Y, -1, -1, 6, 8, -1, 10, 11, 12, N, -1, -1, N), 1689*542baf77SAaron Kling PINGROUP(gpio_cam5_pn4, VGP5, SPI4, RSVD2, RSVD3, 0x0040, 0, Y, -1, -1, 6, 8, -1, 10, 11, 12, N, -1, -1, N), 1690*542baf77SAaron Kling PINGROUP(gpio_cam6_pn5, VGP6, SPI4, RSVD2, RSVD3, 0x0048, 0, Y, -1, -1, 6, 8, -1, 10, 11, 12, N, -1, -1, N), 1691*542baf77SAaron Kling PINGROUP(gpio_cam7_pn6, RSVD0, SPI4, RSVD2, RSVD3, 0x0050, 0, Y, -1, -1, 6, 8, -1, 10, 11, 12, N, -1, -1, N), 1692*542baf77SAaron Kling PINGROUP(dap2_din_pc3, I2S2, RSVD1, RSVD2, RSVD3, 0x4000, 0, Y, -1, -1, 6, 8, -1, 10, 11, 12, N, -1, -1, N), 1693*542baf77SAaron Kling PINGROUP(dap2_dout_pc2, I2S2, RSVD1, RSVD2, RSVD3, 0x4008, 0, Y, -1, -1, 6, 8, -1, 10, 11, 12, N, -1, -1, N), 1694*542baf77SAaron Kling PINGROUP(dap2_fs_pc4, I2S2, RSVD1, RSVD2, RSVD3, 0x4010, 0, Y, -1, -1, 6, 8, -1, 10, 11, 12, N, -1, -1, N), 1695*542baf77SAaron Kling PINGROUP(dap2_sclk_pc1, I2S2, RSVD1, RSVD2, RSVD3, 0x4018, 0, Y, -1, -1, 6, 8, -1, 10, 11, 12, N, -1, -1, N), 1696*542baf77SAaron Kling PINGROUP(uart4_cts_pb3, UARTD, RSVD1, RSVD2, RSVD3, 0x4020, 0, Y, -1, -1, 6, 8, -1, 10, 11, 12, N, -1, -1, N), 1697*542baf77SAaron Kling PINGROUP(uart4_rts_pb2, UARTD, RSVD1, RSVD2, RSVD3, 0x4028, 0, Y, -1, -1, 6, 8, -1, 10, 11, 12, N, -1, -1, N), 1698*542baf77SAaron Kling PINGROUP(uart4_rx_pb1, UARTD, RSVD1, RSVD2, RSVD3, 0x4030, 0, Y, -1, -1, 6, 8, -1, 10, 11, 12, N, -1, -1, N), 1699*542baf77SAaron Kling PINGROUP(uart4_tx_pb0, UARTD, RSVD1, RSVD2, RSVD3, 0x4038, 0, Y, -1, -1, 6, 8, -1, 10, 11, 12, N, -1, -1, N), 1700*542baf77SAaron Kling PINGROUP(gpio_wan4_pc0, RSVD0, RSVD1, RSVD2, RSVD3, 0x4040, 0, Y, -1, -1, 6, 8, -1, 10, 11, 12, N, -1, -1, N), 1701*542baf77SAaron Kling PINGROUP(gpio_wan3_pb6, RSVD0, RSVD1, RSVD2, RSVD3, 0x4048, 0, Y, -1, -1, 6, 8, -1, 10, 11, 12, N, -1, -1, N), 1702*542baf77SAaron Kling PINGROUP(gpio_wan2_pb5, RSVD0, RSVD1, RSVD2, RSVD3, 0x4050, 0, Y, -1, -1, 6, 8, -1, 10, 11, 12, N, -1, -1, N), 1703*542baf77SAaron Kling PINGROUP(gpio_wan1_pb4, RSVD0, RSVD1, RSVD2, RSVD3, 0x4058, 0, Y, -1, -1, 6, 8, -1, 10, 11, 12, N, -1, -1, N), 1704*542baf77SAaron Kling PINGROUP(gen1_i2c_scl_pc5, I2C1, RSVD1, RSVD2, RSVD3, 0x4060, 0, Y, 5, -1, 6, 8, -1, 10, 11, 12, N, -1, -1, N), 1705*542baf77SAaron Kling PINGROUP(gen1_i2c_sda_pc6, I2C1, RSVD1, RSVD2, RSVD3, 0x4068, 0, Y, 5, -1, 6, 8, -1, 10, 11, 12, N, -1, -1, N), 1706*542baf77SAaron Kling PINGROUP(uart1_cts_pt3, UARTA, RSVD1, RSVD2, RSVD3, 0x5000, 0, Y, -1, -1, 6, 8, -1, 10, 11, 12, N, -1, -1, N), 1707*542baf77SAaron Kling PINGROUP(uart1_rts_pt2, UARTA, RSVD1, RSVD2, RSVD3, 0x5008, 0, Y, -1, -1, 6, 8, -1, 10, 11, 12, N, -1, -1, N), 1708*542baf77SAaron Kling PINGROUP(uart1_rx_pt1, UARTA, RSVD1, RSVD2, RSVD3, 0x5010, 0, Y, -1, -1, 6, 8, -1, 10, 11, 12, N, -1, -1, N), 1709*542baf77SAaron Kling PINGROUP(uart1_tx_pt0, UARTA, RSVD1, RSVD2, RSVD3, 0x5018, 0, Y, -1, -1, 6, 8, -1, 10, 11, 12, N, -1, -1, N), 1710*542baf77SAaron Kling PINGROUP(directdc1_out3_pq5, DIRECTDC1, RSVD1, RSVD2, RSVD3, 0x5028, 0, Y, -1, -1, 6, -1, 9, 10, -1, 12, Y, 15, 17, Y), 1711*542baf77SAaron Kling PINGROUP(directdc1_out2_pq4, DIRECTDC1, RSVD1, RSVD2, RSVD3, 0x5030, 0, Y, -1, -1, 6, -1, 9, 10, -1, 12, Y, 15, 17, Y), 1712*542baf77SAaron Kling PINGROUP(directdc1_out1_pq3, DIRECTDC1, RSVD1, RSVD2, RSVD3, 0x5038, 0, Y, -1, -1, 6, -1, 9, 10, -1, 12, Y, 15, 17, Y), 1713*542baf77SAaron Kling PINGROUP(directdc1_out0_pq2, DIRECTDC1, RSVD1, RSVD2, RSVD3, 0x5040, 0, Y, -1, -1, 6, -1, 9, 10, -1, 12, Y, 15, 17, Y), 1714*542baf77SAaron Kling PINGROUP(directdc1_in_pq1, DIRECTDC1, RSVD1, RSVD2, RSVD3, 0x5048, 0, Y, -1, -1, 6, -1, 9, 10, -1, 12, Y, 15, 17, Y), 1715*542baf77SAaron Kling PINGROUP(directdc1_clk_pq0, DIRECTDC1, RSVD1, RSVD2, RSVD3, 0x5050, 0, Y, -1, -1, 6, -1, 9, 10, -1, 12, Y, 15, 17, Y), 1716*542baf77SAaron Kling PINGROUP(directdc_comp, DIRECTDC, RSVD1, RSVD2, RSVD3, 0x5058, 0, Y, -1, -1, -1, -1, 9, 10, -1, 12, Y, -1, -1, Y), 1717*542baf77SAaron Kling PINGROUP(gpio_pq0_pi0, RSVD0, IQC0, I2S6, RSVD3, 0x3000, 0, Y, -1, -1, 6, -1, 9, 10, -1, 12, Y, -1, -1, Y), 1718*542baf77SAaron Kling PINGROUP(gpio_pq1_pi1, RSVD0, IQC0, I2S6, RSVD3, 0x3008, 0, Y, -1, -1, 6, -1, 9, 10, -1, 12, Y, -1, -1, Y), 1719*542baf77SAaron Kling PINGROUP(gpio_pq2_pi2, RSVD0, IQC0, I2S6, RSVD3, 0x3010, 0, Y, -1, -1, 6, -1, 9, 10, -1, 12, Y, -1, -1, Y), 1720*542baf77SAaron Kling PINGROUP(gpio_pq3_pi3, RSVD0, IQC0, I2S6, RSVD3, 0x3018, 0, Y, -1, -1, 6, -1, 9, 10, -1, 12, Y, -1, -1, Y), 1721*542baf77SAaron Kling PINGROUP(gpio_pq4_pi4, RSVD0, IQC1, DTV, RSVD3, 0x3020, 0, Y, -1, -1, 6, -1, 9, 10, -1, 12, Y, -1, -1, Y), 1722*542baf77SAaron Kling PINGROUP(gpio_pq5_pi5, RSVD0, IQC1, DTV, RSVD3, 0x3028, 0, Y, -1, -1, 6, -1, 9, 10, -1, 12, Y, -1, -1, Y), 1723*542baf77SAaron Kling PINGROUP(gpio_pq6_pi6, RSVD0, IQC1, DTV, RSVD3, 0x3030, 0, Y, -1, -1, 6, -1, 9, 10, -1, 12, Y, -1, -1, Y), 1724*542baf77SAaron Kling PINGROUP(gpio_pq7_pi7, RSVD0, IQC1, DTV, RSVD3, 0x3038, 0, Y, -1, -1, 6, -1, 9, 10, -1, 12, Y, -1, -1, Y), 1725*542baf77SAaron Kling PINGROUP(gpio_edp2_pp5, RSVD0, UARTF, SDMMC3, RSVD3, 0x10000, 0, Y, 5, -1, 6, 8, -1, 10, 11, 12, N, -1, -1, N), 1726*542baf77SAaron Kling PINGROUP(gpio_edp3_pp6, RSVD0, UARTF, SDMMC1, RSVD3, 0x10008, 0, Y, -1, -1, 6, 8, -1, 10, 11, 12, N, -1, -1, N), 1727*542baf77SAaron Kling PINGROUP(gpio_edp0_pp3, RSVD0, UARTF, SDMMC3, RSVD3, 0x10010, 0, Y, -1, -1, 6, 8, -1, 10, 11, 12, N, -1, -1, N), 1728*542baf77SAaron Kling PINGROUP(gpio_edp1_pp4, RSVD0, UARTF, SDMMC1, RSVD3, 0x10018, 0, Y, -1, -1, 6, 8, -1, 10, 11, 12, N, -1, -1, N), 1729*542baf77SAaron Kling PINGROUP(dp_aux_ch0_hpd_pp0, DP, RSVD1, RSVD2, RSVD3, 0x10020, 0, Y, 5, -1, 6, 8, -1, 10, 11, 12, N, -1, -1, N), 1730*542baf77SAaron Kling PINGROUP(dp_aux_ch1_hpd_pp1, DP, RSVD1, RSVD2, RSVD3, 0x10028, 0, Y, 5, -1, 6, 8, -1, 10, 11, 12, N, -1, -1, N), 1731*542baf77SAaron Kling PINGROUP(hdmi_cec_pp2, HDMI, RSVD1, RSVD2, RSVD3, 0x10030, 0, Y, 5, -1, 6, 8, -1, 10, 11, 12, N, -1, -1, N), 1732*542baf77SAaron Kling PINGROUP(pex_l2_clkreq_n_pa6, PE2, GP, SATA, RSVD3, 0x7000, 0, Y, 5, -1, 6, 8, -1, 10, 11, 12, N, -1, -1, N), 1733*542baf77SAaron Kling PINGROUP(pex_wake_n_pa2, PE, RSVD1, RSVD2, RSVD3, 0x7008, 0, Y, 5, -1, 6, 8, -1, 10, 11, 12, N, -1, -1, N), 1734*542baf77SAaron Kling PINGROUP(pex_l1_clkreq_n_pa4, PE1, RSVD1, RSVD2, RSVD3, 0x7010, 0, Y, 5, -1, 6, 8, -1, 10, 11, 12, N, -1, -1, N), 1735*542baf77SAaron Kling PINGROUP(pex_l1_rst_n_pa3, PE1, RSVD1, RSVD2, RSVD3, 0x7018, 0, Y, 5, -1, 6, 8, -1, 10, 11, 12, N, -1, -1, N), 1736*542baf77SAaron Kling PINGROUP(pex_l0_clkreq_n_pa1, PE0, RSVD1, RSVD2, RSVD3, 0x7020, 0, Y, 5, -1, 6, 8, -1, 10, 11, 12, N, -1, -1, N), 1737*542baf77SAaron Kling PINGROUP(pex_l0_rst_n_pa0, PE0, RSVD1, RSVD2, RSVD3, 0x7028, 0, Y, 5, -1, 6, 8, -1, 10, 11, 12, N, -1, -1, N), 1738*542baf77SAaron Kling PINGROUP(pex_l2_rst_n_pa5, PE2, SOC, SATA, RSVD3, 0x7030, 0, Y, 5, -1, 6, 8, -1, 10, 11, 12, N, -1, -1, N), 1739*542baf77SAaron Kling PINGROUP(sdmmc1_clk_pd0, SDMMC1, RSVD1, RSVD2, RSVD3, 0x8000, 0, Y, 5, -1, 6, -1, 9, 10, -1, 12, Y, -1, -1, Y), 1740*542baf77SAaron Kling PINGROUP(sdmmc1_cmd_pd1, SDMMC1, RSVD1, RSVD2, RSVD3, 0x8008, 0, Y, -1, -1, 6, -1, 9, 10, -1, 12, Y, -1, -1, Y), 1741*542baf77SAaron Kling PINGROUP(sdmmc1_comp, SDMMC1, RSVD1, RSVD2, RSVD3, 0x8010, 0, Y, -1, -1, 6, -1, -1, -1, -1, -1, N, -1, -1, N), 1742*542baf77SAaron Kling PINGROUP(sdmmc1_dat3_pd5, SDMMC1, RSVD1, RSVD2, RSVD3, 0x8014, 0, Y, -1, -1, 6, -1, 9, 10, -1, 12, Y, -1, -1, Y), 1743*542baf77SAaron Kling PINGROUP(sdmmc1_dat2_pd4, SDMMC1, RSVD1, RSVD2, RSVD3, 0x801c, 0, Y, -1, -1, 6, -1, 9, 10, -1, 12, Y, -1, -1, Y), 1744*542baf77SAaron Kling PINGROUP(sdmmc1_dat1_pd3, SDMMC1, RSVD1, RSVD2, RSVD3, 0x8024, 0, Y, -1, -1, 6, -1, 9, 10, -1, 12, Y, -1, -1, Y), 1745*542baf77SAaron Kling PINGROUP(sdmmc1_dat0_pd2, SDMMC1, RSVD1, RSVD2, RSVD3, 0x802c, 0, Y, -1, -1, 6, -1, 9, 10, -1, 12, Y, -1, -1, Y), 1746*542baf77SAaron Kling PINGROUP(eqos_td3_pe4, EQOS, SDMMC2, RSVD2, RSVD3, 0x9000, 0, Y, -1, -1, 6, -1, 9, 10, -1, 12, Y, -1, -1, Y), 1747*542baf77SAaron Kling PINGROUP(eqos_td2_pe3, EQOS, SDMMC2, RSVD2, RSVD3, 0x9008, 0, Y, -1, -1, 6, -1, 9, 10, -1, 12, Y, -1, -1, Y), 1748*542baf77SAaron Kling PINGROUP(eqos_td1_pe2, EQOS, SDMMC2, RSVD2, RSVD3, 0x9010, 0, Y, -1, -1, 6, -1, 9, 10, -1, 12, Y, -1, -1, Y), 1749*542baf77SAaron Kling PINGROUP(eqos_td0_pe1, EQOS, SDMMC2, RSVD2, RSVD3, 0x9018, 0, Y, -1, -1, 6, -1, 9, 10, -1, 12, Y, -1, -1, Y), 1750*542baf77SAaron Kling PINGROUP(eqos_rd3_pf1, EQOS, SDMMC2, RSVD2, RSVD3, 0x9020, 0, Y, -1, 5, 6, -1, 9, 10, -1, 12, Y, -1, -1, Y), 1751*542baf77SAaron Kling PINGROUP(eqos_rd2_pf0, EQOS, SDMMC2, RSVD2, RSVD3, 0x9028, 0, Y, -1, -1, 6, -1, 9, 10, -1, 12, Y, -1, -1, Y), 1752*542baf77SAaron Kling PINGROUP(eqos_rd1_pe7, EQOS, SDMMC2, RSVD2, RSVD3, 0x9030, 0, Y, -1, -1, 6, -1, 9, 10, -1, 12, Y, -1, -1, Y), 1753*542baf77SAaron Kling PINGROUP(eqos_mdio_pf4, EQOS, SOC, RSVD2, RSVD3, 0x9038, 0, Y, -1, -1, 6, -1, 9, 10, -1, 12, Y, -1, -1, Y), 1754*542baf77SAaron Kling PINGROUP(eqos_rd0_pe6, EQOS, SDMMC2, RSVD2, RSVD3, 0x9040, 0, Y, -1, -1, 6, -1, 9, 10, -1, 12, Y, -1, -1, Y), 1755*542baf77SAaron Kling PINGROUP(eqos_mdc_pf5, EQOS, RSVD1, RSVD2, RSVD3, 0x9048, 0, Y, -1, -1, 6, -1, 9, 10, -1, 12, Y, -1, -1, Y), 1756*542baf77SAaron Kling PINGROUP(eqos_comp, EQOS, SDMMC2, RSVD2, RSVD3, 0x9050, 0, Y, -1, -1, -1, -1, -1, -1, -1, -1, N, -1, -1, N), 1757*542baf77SAaron Kling PINGROUP(eqos_txc_pe0, EQOS, SDMMC2, RSVD2, RSVD3, 0x9054, 0, Y, -1, -1, 6, -1, 9, 10, -1, 12, Y, -1, -1, Y), 1758*542baf77SAaron Kling PINGROUP(eqos_rxc_pf3, EQOS, SDMMC2, RSVD2, RSVD3, 0x905c, 0, Y, -1, -1, 6, -1, 9, 10, -1, 12, Y, -1, -1, Y), 1759*542baf77SAaron Kling PINGROUP(eqos_tx_ctl_pe5, EQOS, SDMMC2, RSVD2, RSVD3, 0x9064, 0, Y, -1, -1, 6, -1, 9, 10, -1, 12, Y, -1, -1, Y), 1760*542baf77SAaron Kling PINGROUP(eqos_rx_ctl_pf2, EQOS, SDMMC2, RSVD2, RSVD3, 0x906c, 0, Y, -1, -1, 6, -1, 9, 10, -1, 12, Y, -1, -1, Y), 1761*542baf77SAaron Kling PINGROUP(sdmmc3_dat3_pg5, SDMMC3, RSVD1, RSVD2, RSVD3, 0xa000, 0, Y, -1, -1, 6, -1, 9, 10, -1, 12, Y, -1, -1, Y), 1762*542baf77SAaron Kling PINGROUP(sdmmc3_dat2_pg4, SDMMC3, RSVD1, RSVD2, RSVD3, 0xa008, 0, Y, -1, -1, 6, -1, 9, 10, -1, 12, Y, -1, -1, Y), 1763*542baf77SAaron Kling PINGROUP(sdmmc3_dat1_pg3, SDMMC3, RSVD1, RSVD2, RSVD3, 0xa010, 0, Y, -1, -1, 6, -1, 9, 10, -1, 12, Y, -1, -1, Y), 1764*542baf77SAaron Kling PINGROUP(sdmmc3_dat0_pg2, SDMMC3, RSVD1, RSVD2, RSVD3, 0xa018, 0, Y, -1, -1, 6, -1, 9, 10, -1, 12, Y, -1, -1, Y), 1765*542baf77SAaron Kling PINGROUP(sdmmc3_comp, SDMMC3, RSVD1, RSVD2, RSVD3, 0xa020, 0, Y, -1, -1, -1, -1, -1, -1, -1, -1, N, -1, -1, N), 1766*542baf77SAaron Kling PINGROUP(sdmmc3_cmd_pg1, SDMMC3, RSVD1, RSVD2, RSVD3, 0xa024, 0, Y, -1, -1, 6, -1, 9, 10, -1, 12, Y, -1, -1, Y), 1767*542baf77SAaron Kling PINGROUP(sdmmc3_clk_pg0, SDMMC3, RSVD1, RSVD1, RSVD3, 0xa02c, 0, Y, -1, 5, 6, -1, 9, 10, -1, 12, Y, -1, -1, Y), 1768*542baf77SAaron Kling PINGROUP(sdmmc4_clk, SDMMC4, RSVD1, RSVD2, RSVD3, 0x6004, 0, Y, -1, 5, 6, -1, 9, -1, -1, 12, Y, -1, -1, Y), 1769*542baf77SAaron Kling PINGROUP(sdmmc4_cmd, SDMMC4, RSVD1, RSVD2, RSVD3, 0x6008, 0, Y, -1, -1, 6, -1, 9, -1, -1, 12, Y, -1, -1, Y), 1770*542baf77SAaron Kling PINGROUP(sdmmc4_dqs, SDMMC4, RSVD1, RSVD2, RSVD3, 0x600c, 0, Y, -1, -1, 6, -1, 9, -1, -1, 12, Y, -1, -1, Y), 1771*542baf77SAaron Kling PINGROUP(sdmmc4_dat7, SDMMC4, RSVD1, RSVD2, RSVD3, 0x6010, 0, Y, -1, -1, 6, -1, 9, -1, -1, 12, Y, -1, -1, Y), 1772*542baf77SAaron Kling PINGROUP(sdmmc4_dat6, SDMMC4, RSVD1, RSVD2, RSVD3, 0x6014, 0, Y, -1, -1, 6, -1, 9, -1, -1, 12, Y, -1, -1, Y), 1773*542baf77SAaron Kling PINGROUP(sdmmc4_dat5, SDMMC4, RSVD1, RSVD2, RSVD3, 0x6018, 0, Y, -1, -1, 6, -1, 9, -1, -1, 12, Y, -1, -1, Y), 1774*542baf77SAaron Kling PINGROUP(sdmmc4_dat4, SDMMC4, RSVD1, RSVD2, RSVD3, 0x601c, 0, Y, -1, -1, 6, -1, 9, -1, -1, 12, Y, -1, -1, Y), 1775*542baf77SAaron Kling PINGROUP(sdmmc4_dat3, SDMMC4, RSVD1, RSVD2, RSVD3, 0x6020, 0, Y, -1, -1, 6, -1, 9, -1, -1, 12, Y, -1, -1, Y), 1776*542baf77SAaron Kling PINGROUP(sdmmc4_dat2, SDMMC4, RSVD1, RSVD2, RSVD3, 0x6024, 0, Y, -1, -1, 6, -1, 9, -1, -1, 12, Y, -1, -1, Y), 1777*542baf77SAaron Kling PINGROUP(sdmmc4_dat1, SDMMC4, RSVD1, RSVD2, RSVD3, 0x6028, 0, Y, -1, -1, 6, -1, 9, -1, -1, 12, Y, -1, -1, Y), 1778*542baf77SAaron Kling PINGROUP(sdmmc4_dat0, SDMMC4, RSVD1, RSVD2, RSVD3, 0x602c, 0, Y, -1, -1, 6, -1, 9, -1, -1, 12, Y, -1, -1, Y), 1779*542baf77SAaron Kling PINGROUP(qspi_io3_pr4, QSPI, RSVD1, RSVD2, RSVD3, 0xB000, 0, Y, -1, -1, 6, -1, 9, 10, -1, 12, Y, 15, 17, Y), 1780*542baf77SAaron Kling PINGROUP(qspi_io2_pr3, QSPI, RSVD1, RSVD2, RSVD3, 0xB008, 0, Y, -1, -1, 6, -1, 9, 10, -1, 12, Y, 15, 17, Y), 1781*542baf77SAaron Kling PINGROUP(qspi_io1_pr2, QSPI, RSVD1, RSVD2, RSVD3, 0xB010, 0, Y, -1, -1, 6, -1, 9, 10, -1, 12, Y, 15, 17, Y), 1782*542baf77SAaron Kling PINGROUP(qspi_io0_pr1, QSPI, RSVD1, RSVD2, RSVD3, 0xB018, 0, Y, -1, -1, 6, -1, 9, 10, -1, 12, Y, 15, 17, Y), 1783*542baf77SAaron Kling PINGROUP(qspi_sck_pr0, QSPI, RSVD1, RSVD2, RSVD3, 0xB020, 0, Y, -1, 5, 6, -1, 9, 10, -1, 12, Y, 15, 17, Y), 1784*542baf77SAaron Kling PINGROUP(qspi_cs_n_pr5, QSPI, RSVD1, RSVD2, RSVD3, 0xB028, 0, Y, -1, -1, 6, -1, 9, 10, -1, 12, Y, 15, 17, Y), 1785*542baf77SAaron Kling PINGROUP(qspi_comp, QSPI, RSVD1, RSVD2, RSVD3, 0xB030, 0, Y, -1, -1, -1, -1, -1, -1, -1, -1, Y, -1, -1, Y), 1786*542baf77SAaron Kling PINGROUP(gpio_wan8_ph3, RSVD0, RSVD1, SPI1, RSVD3, 0xd000, 0, Y, -1, -1, 6, 8, -1, 10, 11, 12, N, -1, -1, N), 1787*542baf77SAaron Kling PINGROUP(gpio_wan7_ph2, RSVD0, RSVD1, SPI1, RSVD3, 0xd008, 0, Y, -1, -1, 6, 8, -1, 10, 11, 12, N, -1, -1, N), 1788*542baf77SAaron Kling PINGROUP(gpio_wan6_ph1, RSVD0, RSVD1, SPI1, RSVD3, 0xd010, 0, Y, -1, -1, 6, 8, -1, 10, 11, 12, N, -1, -1, N), 1789*542baf77SAaron Kling PINGROUP(gpio_wan5_ph0, RSVD0, RSVD1, SPI1, RSVD3, 0xd018, 0, Y, -1, -1, 6, 8, -1, 10, 11, 12, N, -1, -1, N), 1790*542baf77SAaron Kling PINGROUP(uart2_tx_px0, UARTB, RSVD1, RSVD2, RSVD3, 0xd020, 0, Y, -1, -1, 6, 8, -1, 10, 11, 12, N, -1, -1, N), 1791*542baf77SAaron Kling PINGROUP(uart2_rx_px1, UARTB, RSVD1, RSVD2, RSVD3, 0xd028, 0, Y, -1, -1, 6, 8, -1, 10, 11, 12, N, -1, -1, N), 1792*542baf77SAaron Kling PINGROUP(uart2_rts_px2, UARTB, RSVD1, RSVD2, RSVD3, 0xd030, 0, Y, -1, -1, 6, 8, -1, 10, 11, 12, N, -1, -1, N), 1793*542baf77SAaron Kling PINGROUP(uart2_cts_px3, UARTB, RSVD1, RSVD2, RSVD3, 0xd038, 0, Y, -1, -1, 6, 8, -1, 10, 11, 12, N, -1, -1, N), 1794*542baf77SAaron Kling PINGROUP(uart5_rx_px5, UARTE, SPI3, GP, RSVD3, 0xd040, 0, Y, -1, -1, 6, 8, -1, 10, 11, 12, N, -1, -1, N), 1795*542baf77SAaron Kling PINGROUP(uart5_tx_px4, UARTE, SPI3, NV, RSVD3, 0xd048, 0, Y, -1, -1, 6, 8, -1, 10, 11, 12, N, -1, -1, N), 1796*542baf77SAaron Kling PINGROUP(uart5_rts_px6, UARTE, SPI3, RSVD2, RSVD3, 0xd050, 0, Y, -1, -1, 6, 8, -1, 10, 11, 12, N, -1, -1, N), 1797*542baf77SAaron Kling PINGROUP(uart5_cts_px7, UARTE, SPI3, RSVD2, RSVD3, 0xd058, 0, Y, -1, -1, 6, 8, -1, 10, 11, 12, N, -1, -1, N), 1798*542baf77SAaron Kling PINGROUP(gpio_mdm1_py0, RSVD0, RSVD1, RSVD2, RSVD3, 0xd060, 0, Y, -1, -1, 6, 8, -1, 10, 11, 12, N, -1, -1, N), 1799*542baf77SAaron Kling PINGROUP(gpio_mdm2_py1, RSVD0, RSVD1, RSVD2, RSVD3, 0xd068, 0, Y, -1, -1, 6, 8, -1, 10, 11, 12, N, -1, -1, N), 1800*542baf77SAaron Kling PINGROUP(gpio_mdm3_py2, RSVD0, RSVD1, RSVD2, RSVD3, 0xd070, 0, Y, -1, -1, 6, 8, -1, 10, 11, 12, N, -1, -1, N), 1801*542baf77SAaron Kling PINGROUP(gpio_mdm4_py3, RSVD0, SPI1, CCLA, RSVD3, 0xd078, 0, Y, -1, -1, 6, 8, -1, 10, 11, 12, N, -1, -1, N), 1802*542baf77SAaron Kling PINGROUP(gpio_mdm5_py4, RSVD0, SPI1, RSVD2, RSVD3, 0xd080, 0, Y, -1, -1, 6, 8, -1, 10, 11, 12, N, -1, -1, N), 1803*542baf77SAaron Kling PINGROUP(gpio_mdm6_py5, SOC, RSVD1, RSVD2, RSVD3, 0xd088, 0, Y, -1, -1, 6, 8, -1, 10, 11, 12, N, -1, -1, N), 1804*542baf77SAaron Kling PINGROUP(gpio_mdm7_py6, RSVD0, RSVD1, RSVD2, RSVD3, 0xd090, 0, Y, -1, -1, 6, 8, -1, 10, 11, 12, N, -1, -1, N), 1805*542baf77SAaron Kling PINGROUP(bcpu_pwr_req_ph4, RSVD0, RSVD1, RSVD2, RSVD3, 0xd098, 0, Y, -1, -1, 6, 8, -1, 10, 11, 12, N, -1, -1, N), 1806*542baf77SAaron Kling PINGROUP(mcpu_pwr_req_ph5, RSVD0, RSVD1, RSVD2, RSVD3, 0xd0a0, 0, Y, -1, -1, 6, 8, -1, 10, 11, 12, N, -1, -1, N), 1807*542baf77SAaron Kling PINGROUP(gpu_pwr_req_ph6, RSVD0, RSVD1, RSVD2, RSVD3, 0xd0a8, 0, Y, -1, -1, 6, 8, -1, 10, 11, 12, N, -1, -1, N), 1808*542baf77SAaron Kling PINGROUP(gen7_i2c_scl_pl0, I2C7, I2S5, RSVD2, RSVD3, 0xd0b0, 0, Y, 5, -1, 6, 8, -1, 10, 11, 12, N, -1, -1, N), 1809*542baf77SAaron Kling PINGROUP(gen7_i2c_sda_pl1, I2C7, I2S5, RSVD2, RSVD3, 0xd0b8, 0, Y, 5, -1, 6, 8, -1, 10, 11, 12, N, -1, -1, N), 1810*542baf77SAaron Kling PINGROUP(gen9_i2c_sda_pl3, I2C9, I2S5, RSVD2, RSVD3, 0xd0c0, 0, Y, 5, -1, 6, 8, -1, 10, 11, 12, N, -1, -1, N), 1811*542baf77SAaron Kling PINGROUP(gen9_i2c_scl_pl2, I2C9, I2S5, RSVD2, RSVD3, 0xd0c8, 0, Y, 5, -1, 6, 8, -1, 10, 11, 12, N, -1, -1, N), 1812*542baf77SAaron Kling PINGROUP(usb_vbus_en0_pl4, USB, RSVD1, RSVD2, RSVD3, 0xd0d0, 0, Y, 5, -1, 6, 8, -1, 10, 11, 12, N, -1, -1, N), 1813*542baf77SAaron Kling PINGROUP(usb_vbus_en1_pl5, USB, RSVD1, RSVD2, RSVD3, 0xd0d8, 0, Y, 5, -1, 6, 8, -1, 10, 11, 12, N, -1, -1, N), 1814*542baf77SAaron Kling PINGROUP(gp_pwm7_pl7, GP, RSVD1, RSVD2, RSVD3, 0xd0e0, 0, Y, -1, -1, 6, 8, -1, 10, 11, 12, N, -1, -1, N), 1815*542baf77SAaron Kling PINGROUP(gp_pwm6_pl6, GP, RSVD1, RSVD2, RSVD3, 0xd0e8, 0, Y, -1, -1, 6, 8, -1, 10, 11, 12, N, -1, -1, N), 1816*542baf77SAaron Kling PINGROUP(ufs0_rst_pbb1, UFS0, RSVD1, RSVD2, RSVD3, 0x11000, 0, Y, -1, -1, 6, -1, 9, 10, -1, 12, Y, 15, 17, Y), 1817*542baf77SAaron Kling PINGROUP(ufs0_ref_clk_pbb0, UFS0, RSVD1, RSVD2, RSVD3, 0x11008, 0, Y, -1, -1, 6, -1, 9, 10, -1, 12, Y, 15, 17, Y), 1818*542baf77SAaron Kling }; 1819*542baf77SAaron Kling 1820*542baf77SAaron Kling static const struct tegra_pinctrl_soc_data tegra186_pinctrl = { 1821*542baf77SAaron Kling .pins = tegra186_pins, 1822*542baf77SAaron Kling .npins = ARRAY_SIZE(tegra186_pins), 1823*542baf77SAaron Kling .functions = tegra186_functions, 1824*542baf77SAaron Kling .nfunctions = ARRAY_SIZE(tegra186_functions), 1825*542baf77SAaron Kling .groups = tegra186_groups, 1826*542baf77SAaron Kling .ngroups = ARRAY_SIZE(tegra186_groups), 1827*542baf77SAaron Kling .hsm_in_mux = false, 1828*542baf77SAaron Kling .schmitt_in_mux = true, 1829*542baf77SAaron Kling .drvtype_in_mux = true, 1830*542baf77SAaron Kling .sfsel_in_mux = true, 1831*542baf77SAaron Kling }; 1832*542baf77SAaron Kling 1833*542baf77SAaron Kling static const struct pinctrl_pin_desc tegra186_aon_pins[] = { 1834*542baf77SAaron Kling PINCTRL_PIN(TEGRA_PIN_PWR_I2C_SCL_PS0, "PWR_I2C_SCL_PS0"), 1835*542baf77SAaron Kling PINCTRL_PIN(TEGRA_PIN_PWR_I2C_SDA_PS1, "PWR_I2C_SDA_PS1"), 1836*542baf77SAaron Kling PINCTRL_PIN(TEGRA_PIN_BATT_OC_PS2, "BATT_OC_PS2"), 1837*542baf77SAaron Kling PINCTRL_PIN(TEGRA_PIN_SAFE_STATE_PS3, "SAFE_STATE_PS3"), 1838*542baf77SAaron Kling PINCTRL_PIN(TEGRA_PIN_VCOMP_ALERT_PS4, "VCOMP_ALERT_PS4"), 1839*542baf77SAaron Kling PINCTRL_PIN(TEGRA_PIN_GPIO_DIS0_PU0, "GPIO_DIS0_PU0"), 1840*542baf77SAaron Kling PINCTRL_PIN(TEGRA_PIN_GPIO_DIS1_PU1, "GPIO_DIS1_PU1"), 1841*542baf77SAaron Kling PINCTRL_PIN(TEGRA_PIN_GPIO_DIS2_PU2, "GPIO_DIS2_PU2"), 1842*542baf77SAaron Kling PINCTRL_PIN(TEGRA_PIN_GPIO_DIS3_PU3, "GPIO_DIS3_PU3"), 1843*542baf77SAaron Kling PINCTRL_PIN(TEGRA_PIN_GPIO_DIS4_PU4, "GPIO_DIS4_PU4"), 1844*542baf77SAaron Kling PINCTRL_PIN(TEGRA_PIN_GPIO_DIS5_PU5, "GPIO_DIS5_PU5"), 1845*542baf77SAaron Kling PINCTRL_PIN(TEGRA_PIN_GPIO_SEN0_PV0, "GPIO_SEN0_PV0"), 1846*542baf77SAaron Kling PINCTRL_PIN(TEGRA_PIN_GPIO_SEN1_PV1, "GPIO_SEN1_PV1"), 1847*542baf77SAaron Kling PINCTRL_PIN(TEGRA_PIN_GPIO_SEN2_PV2, "GPIO_SEN2_PV2"), 1848*542baf77SAaron Kling PINCTRL_PIN(TEGRA_PIN_GPIO_SEN3_PV3, "GPIO_SEN3_PV3"), 1849*542baf77SAaron Kling PINCTRL_PIN(TEGRA_PIN_GPIO_SEN4_PV4, "GPIO_SEN4_PV4"), 1850*542baf77SAaron Kling PINCTRL_PIN(TEGRA_PIN_GPIO_SEN5_PV5, "GPIO_SEN5_PV5"), 1851*542baf77SAaron Kling PINCTRL_PIN(TEGRA_PIN_GPIO_SEN6_PV6, "GPIO_SEN6_PV6"), 1852*542baf77SAaron Kling PINCTRL_PIN(TEGRA_PIN_GPIO_SEN7_PV7, "GPIO_SEN7_PV7"), 1853*542baf77SAaron Kling PINCTRL_PIN(TEGRA_PIN_GEN8_I2C_SCL_PW0, "GEN8_I2C_SCL_PW0"), 1854*542baf77SAaron Kling PINCTRL_PIN(TEGRA_PIN_GEN8_I2C_SDA_PW1, "GEN8_I2C_SDA_PW1"), 1855*542baf77SAaron Kling PINCTRL_PIN(TEGRA_PIN_UART3_TX_PW2, "UART3_TX_PW2"), 1856*542baf77SAaron Kling PINCTRL_PIN(TEGRA_PIN_UART3_RX_PW3, "UART3_RX_PW3"), 1857*542baf77SAaron Kling PINCTRL_PIN(TEGRA_PIN_UART3_RTS_PW4, "UART3_RTS_PW4"), 1858*542baf77SAaron Kling PINCTRL_PIN(TEGRA_PIN_UART3_CTS_PW5, "UART3_CTS_PW5"), 1859*542baf77SAaron Kling PINCTRL_PIN(TEGRA_PIN_UART7_TX_PW6, "UART7_TX_PW6"), 1860*542baf77SAaron Kling PINCTRL_PIN(TEGRA_PIN_UART7_RX_PW7, "UART7_RX_PW7"), 1861*542baf77SAaron Kling PINCTRL_PIN(TEGRA_PIN_CAN1_DOUT_PZ0, "CAN1_DOUT_PZ0"), 1862*542baf77SAaron Kling PINCTRL_PIN(TEGRA_PIN_CAN1_DIN_PZ1, "CAN1_DIN_PZ1"), 1863*542baf77SAaron Kling PINCTRL_PIN(TEGRA_PIN_CAN0_DOUT_PZ2, "CAN0_DOUT_PZ2"), 1864*542baf77SAaron Kling PINCTRL_PIN(TEGRA_PIN_CAN0_DIN_PZ3, "CAN0_DIN_PZ3"), 1865*542baf77SAaron Kling PINCTRL_PIN(TEGRA_PIN_CAN_GPIO0_PAA0, "CAN_GPIO0_PAA0"), 1866*542baf77SAaron Kling PINCTRL_PIN(TEGRA_PIN_CAN_GPIO1_PAA1, "CAN_GPIO1_PAA1"), 1867*542baf77SAaron Kling PINCTRL_PIN(TEGRA_PIN_CAN_GPIO2_PAA2, "CAN_GPIO2_PAA2"), 1868*542baf77SAaron Kling PINCTRL_PIN(TEGRA_PIN_CAN_GPIO3_PAA3, "CAN_GPIO3_PAA3"), 1869*542baf77SAaron Kling PINCTRL_PIN(TEGRA_PIN_CAN_GPIO4_PAA4, "CAN_GPIO4_PAA4"), 1870*542baf77SAaron Kling PINCTRL_PIN(TEGRA_PIN_CAN_GPIO5_PAA5, "CAN_GPIO5_PAA5"), 1871*542baf77SAaron Kling PINCTRL_PIN(TEGRA_PIN_CAN_GPIO6_PAA6, "CAN_GPIO6_PAA6"), 1872*542baf77SAaron Kling PINCTRL_PIN(TEGRA_PIN_CAN_GPIO7_PAA7, "CAN_GPIO7_PAA7"), 1873*542baf77SAaron Kling PINCTRL_PIN(TEGRA_PIN_GPIO_SEN8_PEE0, "GPIO_SEN8_PEE0"), 1874*542baf77SAaron Kling PINCTRL_PIN(TEGRA_PIN_GPIO_SEN9_PEE1, "GPIO_SEN9_PEE1"), 1875*542baf77SAaron Kling PINCTRL_PIN(TEGRA_PIN_TOUCH_CLK_PEE2, "TOUCH_CLK_PEE2"), 1876*542baf77SAaron Kling PINCTRL_PIN(TEGRA_PIN_POWER_ON_PFF0, "POWER_ON_PFF0"), 1877*542baf77SAaron Kling PINCTRL_PIN(TEGRA_PIN_GPIO_SW1_PFF1, "GPIO_SW1_PFF1"), 1878*542baf77SAaron Kling PINCTRL_PIN(TEGRA_PIN_GPIO_SW2_PFF2, "GPIO_SW2_PFF2"), 1879*542baf77SAaron Kling PINCTRL_PIN(TEGRA_PIN_GPIO_SW3_PFF3, "GPIO_SW3_PFF3"), 1880*542baf77SAaron Kling PINCTRL_PIN(TEGRA_PIN_GPIO_SW4_PFF4, "GPIO_SW4_PFF4"), 1881*542baf77SAaron Kling PINCTRL_PIN(TEGRA_PIN_SHUTDOWN, "SHUTDOWN"), 1882*542baf77SAaron Kling PINCTRL_PIN(TEGRA_PIN_PMU_INT, "PMU_INT"), 1883*542baf77SAaron Kling PINCTRL_PIN(TEGRA_PIN_SOC_PWR_REQ, "SOC_PWR_REQ"), 1884*542baf77SAaron Kling PINCTRL_PIN(TEGRA_PIN_CLK_32K_IN, "CLK_32K_IN"), 1885*542baf77SAaron Kling }; 1886*542baf77SAaron Kling 1887*542baf77SAaron Kling static const struct tegra_pingroup tegra186_aon_groups[] = { 1888*542baf77SAaron Kling PINGROUP(touch_clk_pee2, TOUCH, RSVD1, RSVD2, RSVD3, 0x2000, 0, Y, -1, -1, 6, 8, -1, 10, 11, 12, N, -1, -1, N), 1889*542baf77SAaron Kling PINGROUP(uart3_cts_pw5, UARTC, RSVD1, RSVD2, RSVD3, 0x2008, 0, Y, -1, -1, 6, 8, -1, 10, 11, 12, N, -1, -1, N), 1890*542baf77SAaron Kling PINGROUP(uart3_rts_pw4, UARTC, RSVD1, RSVD2, RSVD3, 0x2010, 0, Y, -1, -1, 6, 8, -1, 10, 11, 12, N, -1, -1, N), 1891*542baf77SAaron Kling PINGROUP(uart3_rx_pw3, UARTC, RSVD1, RSVD2, RSVD3, 0x2018, 0, Y, -1, -1, 6, 8, -1, 10, 11, 12, N, -1, -1, N), 1892*542baf77SAaron Kling PINGROUP(uart3_tx_pw2, UARTC, RSVD1, RSVD2, RSVD3, 0x2020, 0, Y, -1, -1, 6, 8, -1, 10, 11, 12, N, -1, -1, N), 1893*542baf77SAaron Kling PINGROUP(gen8_i2c_sda_pw1, I2C8, RSVD1, RSVD2, RSVD3, 0x2028, 0, Y, 5, -1, 6, 8, -1, 10, 11, 12, N, -1, -1, N), 1894*542baf77SAaron Kling PINGROUP(gen8_i2c_scl_pw0, I2C8, RSVD1, RSVD2, RSVD3, 0x2030, 0, Y, 5, -1, 6, 8, -1, 10, 11, 12, N, -1, -1, N), 1895*542baf77SAaron Kling PINGROUP(uart7_rx_pw7, UARTG, RSVD1, RSVD2, RSVD3, 0x2038, 0, Y, -1, -1, 6, 8, -1, 10, 11, 12, N, -1, -1, N), 1896*542baf77SAaron Kling PINGROUP(uart7_tx_pw6, UARTG, RSVD1, RSVD2, RSVD3, 0x2040, 0, Y, -1, -1, 6, 8, -1, 10, 11, 12, N, -1, -1, N), 1897*542baf77SAaron Kling PINGROUP(gpio_sen0_pv0, RSVD0, RSVD1, RSVD2, RSVD3, 0x2048, 0, Y, -1, -1, 6, 8, -1, 10, 11, 12, N, -1, -1, N), 1898*542baf77SAaron Kling PINGROUP(gpio_sen1_pv1, SPI2, RSVD1, RSVD2, RSVD3, 0x2050, 0, Y, -1, -1, 6, 8, -1, 10, 11, 12, N, -1, -1, N), 1899*542baf77SAaron Kling PINGROUP(gpio_sen2_pv2, SPI2, RSVD1, RSVD2, RSVD3, 0x2058, 0, Y, -1, -1, 6, 8, -1, 10, 11, 12, N, -1, -1, N), 1900*542baf77SAaron Kling PINGROUP(gpio_sen3_pv3, SPI2, RSVD1, RSVD2, RSVD3, 0x2060, 0, Y, -1, -1, 6, 8, -1, 10, 11, 12, N, -1, -1, N), 1901*542baf77SAaron Kling PINGROUP(gpio_sen4_pv4, SPI2, RSVD1, RSVD2, RSVD3, 0x2068, 0, Y, -1, -1, 6, 8, -1, 10, 11, 12, N, -1, -1, N), 1902*542baf77SAaron Kling PINGROUP(gpio_sen5_pv5, RSVD0, RSVD1, RSVD2, RSVD3, 0x2070, 0, Y, -1, -1, 6, 8, -1, 10, 11, 12, N, -1, -1, N), 1903*542baf77SAaron Kling PINGROUP(gpio_sen6_pv6, RSVD0, GP, RSVD2, RSVD3, 0x2078, 0, Y, -1, -1, 6, 8, -1, 10, 11, 12, N, -1, -1, N), 1904*542baf77SAaron Kling PINGROUP(gpio_sen7_pv7, RSVD0, WDT, RSVD2, RSVD3, 0x2080, 0, Y, -1, -1, 6, 8, -1, 10, 11, 12, N, -1, -1, N), 1905*542baf77SAaron Kling PINGROUP(gpio_sen8_pee0, RSVD0, I2C2, RSVD2, RSVD3, 0x2088, 0, Y, 5, -1, 6, 8, -1, 10, 11, 12, N, -1, -1, N), 1906*542baf77SAaron Kling PINGROUP(gpio_sen9_pee1, RSVD0, I2C2, RSVD2, RSVD3, 0x2090, 0, Y, 5, -1, 6, 8, -1, 10, 11, 12, N, -1, -1, N), 1907*542baf77SAaron Kling PINGROUP(can_gpio7_paa7, RSVD0, WDT, RSVD2, RSVD3, 0x3000, 0, Y, -1, -1, 6, -1, 9, 10, -1, 12, Y, -1, -1, Y), 1908*542baf77SAaron Kling PINGROUP(can1_dout_pz0, CAN1, RSVD1, RSVD2, RSVD3, 0x3008, 0, Y, -1, -1, 6, -1, 9, 10, -1, 12, Y, -1, -1, Y), 1909*542baf77SAaron Kling PINGROUP(can1_din_pz1, CAN1, RSVD1, RSVD2, RSVD3, 0x3010, 0, Y, -1, -1, 6, -1, 9, 10, -1, 12, Y, -1, -1, Y), 1910*542baf77SAaron Kling PINGROUP(can0_dout_pz2, CAN0, RSVD1, RSVD2, RSVD3, 0x3018, 0, Y, -1, -1, 6, -1, 9, 10, -1, 12, Y, -1, -1, Y), 1911*542baf77SAaron Kling PINGROUP(can0_din_pz3, CAN0, RSVD1, RSVD2, RSVD3, 0x3020, 0, Y, -1, -1, 6, -1, 9, 10, -1, 12, Y, -1, -1, Y), 1912*542baf77SAaron Kling PINGROUP(can_gpio0_paa0, RSVD0, DMIC3, DMIC5, RSVD3, 0x3028, 0, Y, -1, -1, 6, -1, 9, 10, -1, 12, Y, -1, -1, Y), 1913*542baf77SAaron Kling PINGROUP(can_gpio1_paa1, RSVD0, DMIC3, DMIC5, RSVD3, 0x3030, 0, Y, -1, -1, 6, -1, 9, 10, -1, 12, Y, -1, -1, Y), 1914*542baf77SAaron Kling PINGROUP(can_gpio2_paa2, GPIO, RSVD1, RSVD2, RSVD3, 0x3038, 0, Y, -1, -1, 6, -1, 9, 10, -1, 12, Y, -1, -1, Y), 1915*542baf77SAaron Kling PINGROUP(can_gpio3_paa3, RSVD0, RSVD1, RSVD2, RSVD3, 0x3040, 0, Y, -1, -1, 6, -1, 9, 10, -1, 12, Y, -1, -1, Y), 1916*542baf77SAaron Kling PINGROUP(can_gpio4_paa4, RSVD0, RSVD1, RSVD2, RSVD3, 0x3048, 0, Y, -1, -1, 6, -1, 9, 10, -1, 12, Y, -1, -1, Y), 1917*542baf77SAaron Kling PINGROUP(can_gpio5_paa5, RSVD0, RSVD1, RSVD2, RSVD3, 0x3050, 0, Y, -1, -1, 6, -1, 9, 10, -1, 12, Y, -1, -1, Y), 1918*542baf77SAaron Kling PINGROUP(can_gpio6_paa6, RSVD0, RSVD1, RSVD2, RSVD3, 0x3058, 0, Y, -1, -1, 6, -1, 9, 10, -1, 12, Y, -1, -1, Y), 1919*542baf77SAaron Kling PINGROUP(gpio_sw1_pff1, RSVD0, RSVD1, RSVD2, RSVD3, 0x1000, 0, Y, -1, -1, 6, 8, -1, 10, 11, 12, N, -1, -1, N), 1920*542baf77SAaron Kling PINGROUP(gpio_sw2_pff2, RSVD0, RSVD1, RSVD2, RSVD3, 0x1008, 0, Y, -1, -1, 6, 8, -1, 10, 11, 12, N, -1, -1, N), 1921*542baf77SAaron Kling PINGROUP(gpio_sw3_pff3, RSVD0, RSVD1, RSVD2, RSVD3, 0x1010, 0, Y, -1, -1, 6, 8, -1, 10, 11, 12, N, -1, -1, N), 1922*542baf77SAaron Kling PINGROUP(gpio_sw4_pff4, RSVD0, RSVD1, RSVD2, RSVD3, 0x1018, 0, Y, -1, -1, 6, 8, -1, 10, 11, 12, N, -1, -1, N), 1923*542baf77SAaron Kling PINGROUP(shutdown, RSVD0, RSVD1, RSVD2, RSVD3, 0x1020, 0, Y, -1, -1, 6, 8, -1, -1, -1, 12, N, -1, -1, N), 1924*542baf77SAaron Kling PINGROUP(pmu_int, RSVD0, RSVD1, RSVD2, RSVD3, 0x1028, 0, Y, -1, -1, 6, 8, -1, -1, -1, 12, N, -1, -1, N), 1925*542baf77SAaron Kling PINGROUP(safe_state_ps3, SCE, RSVD1, RSVD2, RSVD3, 0x1030, 0, Y, -1, -1, 6, 8, -1, 10, 11, 12, N, -1, -1, N), 1926*542baf77SAaron Kling PINGROUP(vcomp_alert_ps4, SOC, RSVD1, RSVD2, RSVD3, 0x1038, 0, Y, -1, -1, 6, 8, -1, 10, 11, 12, N, -1, -1, N), 1927*542baf77SAaron Kling PINGROUP(soc_pwr_req, RSVD0, RSVD1, RSVD2, RSVD3, 0x1040, 0, Y, -1, -1, 6, 8, -1, -1, -1, 12, N, -1, -1, N), 1928*542baf77SAaron Kling PINGROUP(batt_oc_ps2, SOC, RSVD1, RSVD2, RSVD3, 0x1048, 0, Y, -1, -1, 6, 8, -1, 10, 11, 12, N, -1, -1, N), 1929*542baf77SAaron Kling PINGROUP(clk_32k_in, RSVD0, RSVD1, RSVD2, RSVD3, 0x1050, 0, Y, -1, -1, 6, 8, -1, -1, -1, -1, N, -1, -1, N), 1930*542baf77SAaron Kling PINGROUP(power_on_pff0, RSVD0, RSVD1, RSVD2, RSVD3, 0x1058, 0, Y, -1, -1, 6, 8, -1, 10, 11, 12, N, -1, -1, N), 1931*542baf77SAaron Kling PINGROUP(pwr_i2c_scl_ps0, I2C5, RSVD1, RSVD2, RSVD3, 0x1060, 0, Y, 5, -1, 6, 8, -1, 10, 11, 12, N, -1, -1, N), 1932*542baf77SAaron Kling PINGROUP(pwr_i2c_sda_ps1, I2C5, RSVD1, RSVD2, RSVD3, 0x1068, 0, Y, 5, -1, 6, 8, -1, 10, 11, 12, N, -1, -1, N), 1933*542baf77SAaron Kling PINGROUP(gpio_dis0_pu0, RSVD0, GP, DCB, DCC, 0x1080, 0, Y, -1, -1, 6, 8, -1, 10, 11, 12, N, -1, -1, N), 1934*542baf77SAaron Kling PINGROUP(gpio_dis1_pu1, RSVD0, RSVD1, DISPLAYA, RSVD3, 0x1088, 0, Y, -1, -1, 6, 8, -1, 10, 11, 12, N, -1, -1, N), 1935*542baf77SAaron Kling PINGROUP(gpio_dis2_pu2, RSVD0, GP, DCA, RSVD3, 0x1090, 0, Y, -1, -1, 6, 8, -1, 10, 11, 12, N, -1, -1, N), 1936*542baf77SAaron Kling PINGROUP(gpio_dis3_pu3, RSVD0, RSVD1, DISPLAYB, DCC, 0x1098, 0, Y, -1, -1, 6, 8, -1, 10, 11, 12, N, -1, -1, N), 1937*542baf77SAaron Kling PINGROUP(gpio_dis4_pu4, RSVD0, SOC, DCA, RSVD3, 0x10a0, 0, Y, -1, -1, 6, 8, -1, 10, 11, 12, N, -1, -1, N), 1938*542baf77SAaron Kling PINGROUP(gpio_dis5_pu5, RSVD0, GP, DCC, DCB, 0x10a8, 0, Y, -1, -1, 6, 8, -1, 10, 11, 12, N, -1, -1, N), 1939*542baf77SAaron Kling }; 1940*542baf77SAaron Kling 1941*542baf77SAaron Kling static const struct tegra_pinctrl_soc_data tegra186_pinctrl_aon = { 1942*542baf77SAaron Kling .pins = tegra186_aon_pins, 1943*542baf77SAaron Kling .npins = ARRAY_SIZE(tegra186_aon_pins), 1944*542baf77SAaron Kling .functions = tegra186_functions, 1945*542baf77SAaron Kling .nfunctions = ARRAY_SIZE(tegra186_functions), 1946*542baf77SAaron Kling .groups = tegra186_aon_groups, 1947*542baf77SAaron Kling .ngroups = ARRAY_SIZE(tegra186_aon_groups), 1948*542baf77SAaron Kling .hsm_in_mux = false, 1949*542baf77SAaron Kling .schmitt_in_mux = true, 1950*542baf77SAaron Kling .drvtype_in_mux = true, 1951*542baf77SAaron Kling .sfsel_in_mux = true, 1952*542baf77SAaron Kling }; 1953*542baf77SAaron Kling 1954*542baf77SAaron Kling static int tegra186_pinctrl_probe(struct platform_device *pdev) 1955*542baf77SAaron Kling { 1956*542baf77SAaron Kling const struct tegra_pinctrl_soc_data *soc = of_device_get_match_data(&pdev->dev); 1957*542baf77SAaron Kling 1958*542baf77SAaron Kling return tegra_pinctrl_probe(pdev, soc); 1959*542baf77SAaron Kling } 1960*542baf77SAaron Kling 1961*542baf77SAaron Kling static const struct of_device_id tegra186_pinctrl_of_match[] = { 1962*542baf77SAaron Kling { .compatible = "nvidia,tegra186-pinmux", .data = &tegra186_pinctrl }, 1963*542baf77SAaron Kling { .compatible = "nvidia,tegra186-pinmux-aon", .data = &tegra186_pinctrl_aon }, 1964*542baf77SAaron Kling { }, 1965*542baf77SAaron Kling }; 1966*542baf77SAaron Kling 1967*542baf77SAaron Kling static struct platform_driver tegra186_pinctrl_driver = { 1968*542baf77SAaron Kling .driver = { 1969*542baf77SAaron Kling .name = "tegra186-pinctrl", 1970*542baf77SAaron Kling .of_match_table = tegra186_pinctrl_of_match, 1971*542baf77SAaron Kling }, 1972*542baf77SAaron Kling .probe = tegra186_pinctrl_probe, 1973*542baf77SAaron Kling }; 1974*542baf77SAaron Kling 1975*542baf77SAaron Kling static int __init tegra186_pinctrl_init(void) 1976*542baf77SAaron Kling { 1977*542baf77SAaron Kling return platform_driver_register(&tegra186_pinctrl_driver); 1978*542baf77SAaron Kling } 1979*542baf77SAaron Kling arch_initcall(tegra186_pinctrl_init); 1980