Linux Audio

Check our new training course

Linux debugging, profiling, tracing and performance analysis training

Mar 24-27, 2025, special US time zones
Register
Loading...
v6.9.4
   1// SPDX-License-Identifier: GPL-2.0+
   2/*
   3 * Pinctrl data for the NVIDIA Tegra234 pinmux
   4 *
   5 * Copyright (c) 2021-2023, NVIDIA CORPORATION.  All rights reserved.
   6 */
   7
   8#include <linux/mod_devicetable.h>
   9#include <linux/module.h>
  10#include <linux/platform_device.h>
  11#include <linux/property.h>
  12
  13#include <linux/pinctrl/pinctrl.h>
  14#include <linux/pinctrl/pinmux.h>
  15
  16#include "pinctrl-tegra.h"
  17
  18/* Define unique ID for each pins */
  19enum {
  20	TEGRA_PIN_DAP6_SCLK_PA0,
  21	TEGRA_PIN_DAP6_DOUT_PA1,
  22	TEGRA_PIN_DAP6_DIN_PA2,
  23	TEGRA_PIN_DAP6_FS_PA3,
  24	TEGRA_PIN_DAP4_SCLK_PA4,
  25	TEGRA_PIN_DAP4_DOUT_PA5,
  26	TEGRA_PIN_DAP4_DIN_PA6,
  27	TEGRA_PIN_DAP4_FS_PA7,
  28	TEGRA_PIN_SOC_GPIO08_PB0,
  29	TEGRA_PIN_QSPI0_SCK_PC0,
  30	TEGRA_PIN_QSPI0_CS_N_PC1,
  31	TEGRA_PIN_QSPI0_IO0_PC2,
  32	TEGRA_PIN_QSPI0_IO1_PC3,
  33	TEGRA_PIN_QSPI0_IO2_PC4,
  34	TEGRA_PIN_QSPI0_IO3_PC5,
  35	TEGRA_PIN_QSPI1_SCK_PC6,
  36	TEGRA_PIN_QSPI1_CS_N_PC7,
  37	TEGRA_PIN_QSPI1_IO0_PD0,
  38	TEGRA_PIN_QSPI1_IO1_PD1,
  39	TEGRA_PIN_QSPI1_IO2_PD2,
  40	TEGRA_PIN_QSPI1_IO3_PD3,
  41	TEGRA_PIN_EQOS_TXC_PE0,
  42	TEGRA_PIN_EQOS_TD0_PE1,
  43	TEGRA_PIN_EQOS_TD1_PE2,
  44	TEGRA_PIN_EQOS_TD2_PE3,
  45	TEGRA_PIN_EQOS_TD3_PE4,
  46	TEGRA_PIN_EQOS_TX_CTL_PE5,
  47	TEGRA_PIN_EQOS_RD0_PE6,
  48	TEGRA_PIN_EQOS_RD1_PE7,
  49	TEGRA_PIN_EQOS_RD2_PF0,
  50	TEGRA_PIN_EQOS_RD3_PF1,
  51	TEGRA_PIN_EQOS_RX_CTL_PF2,
  52	TEGRA_PIN_EQOS_RXC_PF3,
  53	TEGRA_PIN_EQOS_SMA_MDIO_PF4,
  54	TEGRA_PIN_EQOS_SMA_MDC_PF5,
  55	TEGRA_PIN_SOC_GPIO13_PG0,
  56	TEGRA_PIN_SOC_GPIO14_PG1,
  57	TEGRA_PIN_SOC_GPIO15_PG2,
  58	TEGRA_PIN_SOC_GPIO16_PG3,
  59	TEGRA_PIN_SOC_GPIO17_PG4,
  60	TEGRA_PIN_SOC_GPIO18_PG5,
  61	TEGRA_PIN_SOC_GPIO19_PG6,
  62	TEGRA_PIN_SOC_GPIO20_PG7,
  63	TEGRA_PIN_SOC_GPIO21_PH0,
  64	TEGRA_PIN_SOC_GPIO22_PH1,
  65	TEGRA_PIN_SOC_GPIO06_PH2,
  66	TEGRA_PIN_UART4_TX_PH3,
  67	TEGRA_PIN_UART4_RX_PH4,
  68	TEGRA_PIN_UART4_RTS_PH5,
  69	TEGRA_PIN_UART4_CTS_PH6,
  70	TEGRA_PIN_SOC_GPIO41_PH7,
  71	TEGRA_PIN_SOC_GPIO42_PI0,
  72	TEGRA_PIN_SOC_GPIO43_PI1,
  73	TEGRA_PIN_SOC_GPIO44_PI2,
  74	TEGRA_PIN_GEN1_I2C_SCL_PI3,
  75	TEGRA_PIN_GEN1_I2C_SDA_PI4,
  76	TEGRA_PIN_CPU_PWR_REQ_PI5,
  77	TEGRA_PIN_SOC_GPIO07_PI6,
  78	TEGRA_PIN_SDMMC1_CLK_PJ0,
  79	TEGRA_PIN_SDMMC1_CMD_PJ1,
  80	TEGRA_PIN_SDMMC1_DAT0_PJ2,
  81	TEGRA_PIN_SDMMC1_DAT1_PJ3,
  82	TEGRA_PIN_SDMMC1_DAT2_PJ4,
  83	TEGRA_PIN_SDMMC1_DAT3_PJ5,
  84	TEGRA_PIN_PEX_L0_CLKREQ_N_PK0,
  85	TEGRA_PIN_PEX_L0_RST_N_PK1,
  86	TEGRA_PIN_PEX_L1_CLKREQ_N_PK2,
  87	TEGRA_PIN_PEX_L1_RST_N_PK3,
  88	TEGRA_PIN_PEX_L2_CLKREQ_N_PK4,
  89	TEGRA_PIN_PEX_L2_RST_N_PK5,
  90	TEGRA_PIN_PEX_L3_CLKREQ_N_PK6,
  91	TEGRA_PIN_PEX_L3_RST_N_PK7,
  92	TEGRA_PIN_PEX_L4_CLKREQ_N_PL0,
  93	TEGRA_PIN_PEX_L4_RST_N_PL1,
  94	TEGRA_PIN_PEX_WAKE_N_PL2,
  95	TEGRA_PIN_SOC_GPIO34_PL3,
  96	TEGRA_PIN_DP_AUX_CH0_HPD_PM0,
  97	TEGRA_PIN_DP_AUX_CH1_HPD_PM1,
  98	TEGRA_PIN_DP_AUX_CH2_HPD_PM2,
  99	TEGRA_PIN_DP_AUX_CH3_HPD_PM3,
 100	TEGRA_PIN_SOC_GPIO55_PM4,
 101	TEGRA_PIN_SOC_GPIO36_PM5,
 102	TEGRA_PIN_SOC_GPIO53_PM6,
 103	TEGRA_PIN_SOC_GPIO38_PM7,
 104	TEGRA_PIN_DP_AUX_CH3_N_PN0,
 105	TEGRA_PIN_SOC_GPIO39_PN1,
 106	TEGRA_PIN_SOC_GPIO40_PN2,
 107	TEGRA_PIN_DP_AUX_CH1_P_PN3,
 108	TEGRA_PIN_DP_AUX_CH1_N_PN4,
 109	TEGRA_PIN_DP_AUX_CH2_P_PN5,
 110	TEGRA_PIN_DP_AUX_CH2_N_PN6,
 111	TEGRA_PIN_DP_AUX_CH3_P_PN7,
 112	TEGRA_PIN_EXTPERIPH1_CLK_PP0,
 113	TEGRA_PIN_EXTPERIPH2_CLK_PP1,
 114	TEGRA_PIN_CAM_I2C_SCL_PP2,
 115	TEGRA_PIN_CAM_I2C_SDA_PP3,
 116	TEGRA_PIN_SOC_GPIO23_PP4,
 117	TEGRA_PIN_SOC_GPIO24_PP5,
 118	TEGRA_PIN_SOC_GPIO25_PP6,
 119	TEGRA_PIN_PWR_I2C_SCL_PP7,
 120	TEGRA_PIN_PWR_I2C_SDA_PQ0,
 121	TEGRA_PIN_SOC_GPIO28_PQ1,
 122	TEGRA_PIN_SOC_GPIO29_PQ2,
 123	TEGRA_PIN_SOC_GPIO30_PQ3,
 124	TEGRA_PIN_SOC_GPIO31_PQ4,
 125	TEGRA_PIN_SOC_GPIO32_PQ5,
 126	TEGRA_PIN_SOC_GPIO33_PQ6,
 127	TEGRA_PIN_SOC_GPIO35_PQ7,
 128	TEGRA_PIN_SOC_GPIO37_PR0,
 129	TEGRA_PIN_SOC_GPIO56_PR1,
 130	TEGRA_PIN_UART1_TX_PR2,
 131	TEGRA_PIN_UART1_RX_PR3,
 132	TEGRA_PIN_UART1_RTS_PR4,
 133	TEGRA_PIN_UART1_CTS_PR5,
 134	TEGRA_PIN_GPU_PWR_REQ_PX0,
 135	TEGRA_PIN_CV_PWR_REQ_PX1,
 136	TEGRA_PIN_GP_PWM2_PX2,
 137	TEGRA_PIN_GP_PWM3_PX3,
 138	TEGRA_PIN_UART2_TX_PX4,
 139	TEGRA_PIN_UART2_RX_PX5,
 140	TEGRA_PIN_UART2_RTS_PX6,
 141	TEGRA_PIN_UART2_CTS_PX7,
 142	TEGRA_PIN_SPI3_SCK_PY0,
 143	TEGRA_PIN_SPI3_MISO_PY1,
 144	TEGRA_PIN_SPI3_MOSI_PY2,
 145	TEGRA_PIN_SPI3_CS0_PY3,
 146	TEGRA_PIN_SPI3_CS1_PY4,
 147	TEGRA_PIN_UART5_TX_PY5,
 148	TEGRA_PIN_UART5_RX_PY6,
 149	TEGRA_PIN_UART5_RTS_PY7,
 150	TEGRA_PIN_UART5_CTS_PZ0,
 151	TEGRA_PIN_USB_VBUS_EN0_PZ1,
 152	TEGRA_PIN_USB_VBUS_EN1_PZ2,
 153	TEGRA_PIN_SPI1_SCK_PZ3,
 154	TEGRA_PIN_SPI1_MISO_PZ4,
 155	TEGRA_PIN_SPI1_MOSI_PZ5,
 156	TEGRA_PIN_SPI1_CS0_PZ6,
 157	TEGRA_PIN_SPI1_CS1_PZ7,
 158	TEGRA_PIN_SPI5_SCK_PAC0,
 159	TEGRA_PIN_SPI5_MISO_PAC1,
 160	TEGRA_PIN_SPI5_MOSI_PAC2,
 161	TEGRA_PIN_SPI5_CS0_PAC3,
 162	TEGRA_PIN_SOC_GPIO57_PAC4,
 163	TEGRA_PIN_SOC_GPIO58_PAC5,
 164	TEGRA_PIN_SOC_GPIO59_PAC6,
 165	TEGRA_PIN_SOC_GPIO60_PAC7,
 166	TEGRA_PIN_SOC_GPIO45_PAD0,
 167	TEGRA_PIN_SOC_GPIO46_PAD1,
 168	TEGRA_PIN_SOC_GPIO47_PAD2,
 169	TEGRA_PIN_SOC_GPIO48_PAD3,
 170	TEGRA_PIN_UFS0_REF_CLK_PAE0,
 171	TEGRA_PIN_UFS0_RST_N_PAE1,
 172	TEGRA_PIN_PEX_L5_CLKREQ_N_PAF0,
 173	TEGRA_PIN_PEX_L5_RST_N_PAF1,
 174	TEGRA_PIN_PEX_L6_CLKREQ_N_PAF2,
 175	TEGRA_PIN_PEX_L6_RST_N_PAF3,
 176	TEGRA_PIN_PEX_L7_CLKREQ_N_PAG0,
 177	TEGRA_PIN_PEX_L7_RST_N_PAG1,
 178	TEGRA_PIN_PEX_L8_CLKREQ_N_PAG2,
 179	TEGRA_PIN_PEX_L8_RST_N_PAG3,
 180	TEGRA_PIN_PEX_L9_CLKREQ_N_PAG4,
 181	TEGRA_PIN_PEX_L9_RST_N_PAG5,
 182	TEGRA_PIN_PEX_L10_CLKREQ_N_PAG6,
 183	TEGRA_PIN_PEX_L10_RST_N_PAG7,
 184	TEGRA_PIN_EQOS_COMP,
 185	TEGRA_PIN_QSPI_COMP,
 186	TEGRA_PIN_SDMMC1_COMP,
 187};
 188
 189enum {
 190	TEGRA_PIN_CAN0_DOUT_PAA0,
 191	TEGRA_PIN_CAN0_DIN_PAA1,
 192	TEGRA_PIN_CAN1_DOUT_PAA2,
 193	TEGRA_PIN_CAN1_DIN_PAA3,
 194	TEGRA_PIN_CAN0_STB_PAA4,
 195	TEGRA_PIN_CAN0_EN_PAA5,
 196	TEGRA_PIN_SOC_GPIO49_PAA6,
 197	TEGRA_PIN_CAN0_ERR_PAA7,
 198	TEGRA_PIN_CAN1_STB_PBB0,
 199	TEGRA_PIN_CAN1_EN_PBB1,
 200	TEGRA_PIN_SOC_GPIO50_PBB2,
 201	TEGRA_PIN_CAN1_ERR_PBB3,
 202	TEGRA_PIN_SPI2_SCK_PCC0,
 203	TEGRA_PIN_SPI2_MISO_PCC1,
 204	TEGRA_PIN_SPI2_MOSI_PCC2,
 205	TEGRA_PIN_SPI2_CS0_PCC3,
 206	TEGRA_PIN_TOUCH_CLK_PCC4,
 207	TEGRA_PIN_UART3_TX_PCC5,
 208	TEGRA_PIN_UART3_RX_PCC6,
 209	TEGRA_PIN_GEN2_I2C_SCL_PCC7,
 210	TEGRA_PIN_GEN2_I2C_SDA_PDD0,
 211	TEGRA_PIN_GEN8_I2C_SCL_PDD1,
 212	TEGRA_PIN_GEN8_I2C_SDA_PDD2,
 213	TEGRA_PIN_SCE_ERROR_PEE0,
 214	TEGRA_PIN_VCOMP_ALERT_PEE1,
 215	TEGRA_PIN_AO_RETENTION_N_PEE2,
 216	TEGRA_PIN_BATT_OC_PEE3,
 217	TEGRA_PIN_POWER_ON_PEE4,
 218	TEGRA_PIN_SOC_GPIO26_PEE5,
 219	TEGRA_PIN_SOC_GPIO27_PEE6,
 220	TEGRA_PIN_BOOTV_CTL_N_PEE7,
 221	TEGRA_PIN_HDMI_CEC_PGG0,
 222};
 223
 224/* Table for pin descriptor */
 225static const struct pinctrl_pin_desc tegra234_pins[] = {
 226	PINCTRL_PIN(TEGRA_PIN_DAP6_SCLK_PA0, "DAP6_SCLK_PA0"),
 227	PINCTRL_PIN(TEGRA_PIN_DAP6_DOUT_PA1, "DAP6_DOUT_PA1"),
 228	PINCTRL_PIN(TEGRA_PIN_DAP6_DIN_PA2, "DAP6_DIN_PA2"),
 229	PINCTRL_PIN(TEGRA_PIN_DAP6_FS_PA3, "DAP6_FS_PA3"),
 230	PINCTRL_PIN(TEGRA_PIN_DAP4_SCLK_PA4, "DAP4_SCLK_PA4"),
 231	PINCTRL_PIN(TEGRA_PIN_DAP4_DOUT_PA5, "DAP4_DOUT_PA5"),
 232	PINCTRL_PIN(TEGRA_PIN_DAP4_DIN_PA6, "DAP4_DIN_PA6"),
 233	PINCTRL_PIN(TEGRA_PIN_DAP4_FS_PA7, "DAP4_FS_PA7"),
 234	PINCTRL_PIN(TEGRA_PIN_SOC_GPIO08_PB0, "SOC_GPIO08_PB0"),
 235	PINCTRL_PIN(TEGRA_PIN_QSPI0_SCK_PC0, "QSPI0_SCK_PC0"),
 236	PINCTRL_PIN(TEGRA_PIN_QSPI0_CS_N_PC1, "QSPI0_CS_N_PC1"),
 237	PINCTRL_PIN(TEGRA_PIN_QSPI0_IO0_PC2, "QSPI0_IO0_PC2"),
 238	PINCTRL_PIN(TEGRA_PIN_QSPI0_IO1_PC3, "QSPI0_IO1_PC3"),
 239	PINCTRL_PIN(TEGRA_PIN_QSPI0_IO2_PC4, "QSPI0_IO2_PC4"),
 240	PINCTRL_PIN(TEGRA_PIN_QSPI0_IO3_PC5, "QSPI0_IO3_PC5"),
 241	PINCTRL_PIN(TEGRA_PIN_QSPI1_SCK_PC6, "QSPI1_SCK_PC6"),
 242	PINCTRL_PIN(TEGRA_PIN_QSPI1_CS_N_PC7, "QSPI1_CS_N_PC7"),
 243	PINCTRL_PIN(TEGRA_PIN_QSPI1_IO0_PD0, "QSPI1_IO0_PD0"),
 244	PINCTRL_PIN(TEGRA_PIN_QSPI1_IO1_PD1, "QSPI1_IO1_PD1"),
 245	PINCTRL_PIN(TEGRA_PIN_QSPI1_IO2_PD2, "QSPI1_IO2_PD2"),
 246	PINCTRL_PIN(TEGRA_PIN_QSPI1_IO3_PD3, "QSPI1_IO3_PD3"),
 247	PINCTRL_PIN(TEGRA_PIN_EQOS_TXC_PE0, "EQOS_TXC_PE0"),
 248	PINCTRL_PIN(TEGRA_PIN_EQOS_TD0_PE1, "EQOS_TD0_PE1"),
 249	PINCTRL_PIN(TEGRA_PIN_EQOS_TD1_PE2, "EQOS_TD1_PE2"),
 250	PINCTRL_PIN(TEGRA_PIN_EQOS_TD2_PE3, "EQOS_TD2_PE3"),
 251	PINCTRL_PIN(TEGRA_PIN_EQOS_TD3_PE4, "EQOS_TD3_PE4"),
 252	PINCTRL_PIN(TEGRA_PIN_EQOS_TX_CTL_PE5, "EQOS_TX_CTL_PE5"),
 253	PINCTRL_PIN(TEGRA_PIN_EQOS_RD0_PE6, "EQOS_RD0_PE6"),
 254	PINCTRL_PIN(TEGRA_PIN_EQOS_RD1_PE7, "EQOS_RD1_PE7"),
 255	PINCTRL_PIN(TEGRA_PIN_EQOS_RD2_PF0, "EQOS_RD2_PF0"),
 256	PINCTRL_PIN(TEGRA_PIN_EQOS_RD3_PF1, "EQOS_RD3_PF1"),
 257	PINCTRL_PIN(TEGRA_PIN_EQOS_RX_CTL_PF2, "EQOS_RX_CTL_PF2"),
 258	PINCTRL_PIN(TEGRA_PIN_EQOS_RXC_PF3, "EQOS_RXC_PF3"),
 259	PINCTRL_PIN(TEGRA_PIN_EQOS_SMA_MDIO_PF4, "EQOS_SMA_MDIO_PF4"),
 260	PINCTRL_PIN(TEGRA_PIN_EQOS_SMA_MDC_PF5, "EQOS_SMA_MDC_PF5"),
 261	PINCTRL_PIN(TEGRA_PIN_SOC_GPIO13_PG0, "SOC_GPIO13_PG0"),
 262	PINCTRL_PIN(TEGRA_PIN_SOC_GPIO14_PG1, "SOC_GPIO14_PG1"),
 263	PINCTRL_PIN(TEGRA_PIN_SOC_GPIO15_PG2, "SOC_GPIO15_PG2"),
 264	PINCTRL_PIN(TEGRA_PIN_SOC_GPIO16_PG3, "SOC_GPIO16_PG3"),
 265	PINCTRL_PIN(TEGRA_PIN_SOC_GPIO17_PG4, "SOC_GPIO17_PG4"),
 266	PINCTRL_PIN(TEGRA_PIN_SOC_GPIO18_PG5, "SOC_GPIO18_PG5"),
 267	PINCTRL_PIN(TEGRA_PIN_SOC_GPIO19_PG6, "SOC_GPIO19_PG6"),
 268	PINCTRL_PIN(TEGRA_PIN_SOC_GPIO20_PG7, "SOC_GPIO20_PG7"),
 269	PINCTRL_PIN(TEGRA_PIN_SOC_GPIO21_PH0, "SOC_GPIO21_PH0"),
 270	PINCTRL_PIN(TEGRA_PIN_SOC_GPIO22_PH1, "SOC_GPIO22_PH1"),
 271	PINCTRL_PIN(TEGRA_PIN_SOC_GPIO06_PH2, "SOC_GPIO06_PH2"),
 272	PINCTRL_PIN(TEGRA_PIN_UART4_TX_PH3, "UART4_TX_PH3"),
 273	PINCTRL_PIN(TEGRA_PIN_UART4_RX_PH4, "UART4_RX_PH4"),
 274	PINCTRL_PIN(TEGRA_PIN_UART4_RTS_PH5, "UART4_RTS_PH5"),
 275	PINCTRL_PIN(TEGRA_PIN_UART4_CTS_PH6, "UART4_CTS_PH6"),
 276	PINCTRL_PIN(TEGRA_PIN_SOC_GPIO41_PH7, "SOC_GPIO41_PH7"),
 277	PINCTRL_PIN(TEGRA_PIN_SOC_GPIO42_PI0, "SOC_GPIO42_PI0"),
 278	PINCTRL_PIN(TEGRA_PIN_SOC_GPIO43_PI1, "SOC_GPIO43_PI1"),
 279	PINCTRL_PIN(TEGRA_PIN_SOC_GPIO44_PI2, "SOC_GPIO44_PI2"),
 280	PINCTRL_PIN(TEGRA_PIN_GEN1_I2C_SCL_PI3, "GEN1_I2C_SCL_PI3"),
 281	PINCTRL_PIN(TEGRA_PIN_GEN1_I2C_SDA_PI4, "GEN1_I2C_SDA_PI4"),
 282	PINCTRL_PIN(TEGRA_PIN_CPU_PWR_REQ_PI5, "CPU_PWR_REQ_PI5"),
 283	PINCTRL_PIN(TEGRA_PIN_SOC_GPIO07_PI6, "SOC_GPIO07_PI6"),
 284	PINCTRL_PIN(TEGRA_PIN_SDMMC1_CLK_PJ0, "SDMMC1_CLK_PJ0"),
 285	PINCTRL_PIN(TEGRA_PIN_SDMMC1_CMD_PJ1, "SDMMC1_CMD_PJ1"),
 286	PINCTRL_PIN(TEGRA_PIN_SDMMC1_DAT0_PJ2, "SDMMC1_DAT0_PJ2"),
 287	PINCTRL_PIN(TEGRA_PIN_SDMMC1_DAT1_PJ3, "SDMMC1_DAT1_PJ3"),
 288	PINCTRL_PIN(TEGRA_PIN_SDMMC1_DAT2_PJ4, "SDMMC1_DAT2_PJ4"),
 289	PINCTRL_PIN(TEGRA_PIN_SDMMC1_DAT3_PJ5, "SDMMC1_DAT3_PJ5"),
 290	PINCTRL_PIN(TEGRA_PIN_PEX_L0_CLKREQ_N_PK0, "PEX_L0_CLKREQ_N_PK0"),
 291	PINCTRL_PIN(TEGRA_PIN_PEX_L0_RST_N_PK1, "PEX_L0_RST_N_PK1"),
 292	PINCTRL_PIN(TEGRA_PIN_PEX_L1_CLKREQ_N_PK2, "PEX_L1_CLKREQ_N_PK2"),
 293	PINCTRL_PIN(TEGRA_PIN_PEX_L1_RST_N_PK3, "PEX_L1_RST_N_PK3"),
 294	PINCTRL_PIN(TEGRA_PIN_PEX_L2_CLKREQ_N_PK4, "PEX_L2_CLKREQ_N_PK4"),
 295	PINCTRL_PIN(TEGRA_PIN_PEX_L2_RST_N_PK5, "PEX_L2_RST_N_PK5"),
 296	PINCTRL_PIN(TEGRA_PIN_PEX_L3_CLKREQ_N_PK6, "PEX_L3_CLKREQ_N_PK6"),
 297	PINCTRL_PIN(TEGRA_PIN_PEX_L3_RST_N_PK7, "PEX_L3_RST_N_PK7"),
 298	PINCTRL_PIN(TEGRA_PIN_PEX_L4_CLKREQ_N_PL0, "PEX_L4_CLKREQ_N_PL0"),
 299	PINCTRL_PIN(TEGRA_PIN_PEX_L4_RST_N_PL1, "PEX_L4_RST_N_PL1"),
 300	PINCTRL_PIN(TEGRA_PIN_PEX_WAKE_N_PL2, "PEX_WAKE_N_PL2"),
 301	PINCTRL_PIN(TEGRA_PIN_SOC_GPIO34_PL3, "SOC_GPIO34_PL3"),
 302	PINCTRL_PIN(TEGRA_PIN_DP_AUX_CH0_HPD_PM0, "DP_AUX_CH0_HPD_PM0"),
 303	PINCTRL_PIN(TEGRA_PIN_DP_AUX_CH1_HPD_PM1, "DP_AUX_CH1_HPD_PM1"),
 304	PINCTRL_PIN(TEGRA_PIN_DP_AUX_CH2_HPD_PM2, "DP_AUX_CH2_HPD_PM2"),
 305	PINCTRL_PIN(TEGRA_PIN_DP_AUX_CH3_HPD_PM3, "DP_AUX_CH3_HPD_PM3"),
 306	PINCTRL_PIN(TEGRA_PIN_SOC_GPIO55_PM4, "SOC_GPIO55_PM4"),
 307	PINCTRL_PIN(TEGRA_PIN_SOC_GPIO36_PM5, "SOC_GPIO36_PM5"),
 308	PINCTRL_PIN(TEGRA_PIN_SOC_GPIO53_PM6, "SOC_GPIO53_PM6"),
 309	PINCTRL_PIN(TEGRA_PIN_SOC_GPIO38_PM7, "SOC_GPIO38_PM7"),
 310	PINCTRL_PIN(TEGRA_PIN_DP_AUX_CH3_N_PN0, "DP_AUX_CH3_N_PN0"),
 311	PINCTRL_PIN(TEGRA_PIN_SOC_GPIO39_PN1, "SOC_GPIO39_PN1"),
 312	PINCTRL_PIN(TEGRA_PIN_SOC_GPIO40_PN2, "SOC_GPIO40_PN2"),
 313	PINCTRL_PIN(TEGRA_PIN_DP_AUX_CH1_P_PN3, "DP_AUX_CH1_P_PN3"),
 314	PINCTRL_PIN(TEGRA_PIN_DP_AUX_CH1_N_PN4, "DP_AUX_CH1_N_PN4"),
 315	PINCTRL_PIN(TEGRA_PIN_DP_AUX_CH2_P_PN5, "DP_AUX_CH2_P_PN5"),
 316	PINCTRL_PIN(TEGRA_PIN_DP_AUX_CH2_N_PN6, "DP_AUX_CH2_N_PN6"),
 317	PINCTRL_PIN(TEGRA_PIN_DP_AUX_CH3_P_PN7, "DP_AUX_CH3_P_PN7"),
 318	PINCTRL_PIN(TEGRA_PIN_EXTPERIPH1_CLK_PP0, "EXTPERIPH1_CLK_PP0"),
 319	PINCTRL_PIN(TEGRA_PIN_EXTPERIPH2_CLK_PP1, "EXTPERIPH2_CLK_PP1"),
 320	PINCTRL_PIN(TEGRA_PIN_CAM_I2C_SCL_PP2, "CAM_I2C_SCL_PP2"),
 321	PINCTRL_PIN(TEGRA_PIN_CAM_I2C_SDA_PP3, "CAM_I2C_SDA_PP3"),
 322	PINCTRL_PIN(TEGRA_PIN_SOC_GPIO23_PP4, "SOC_GPIO23_PP4"),
 323	PINCTRL_PIN(TEGRA_PIN_SOC_GPIO24_PP5, "SOC_GPIO24_PP5"),
 324	PINCTRL_PIN(TEGRA_PIN_SOC_GPIO25_PP6, "SOC_GPIO25_PP6"),
 325	PINCTRL_PIN(TEGRA_PIN_PWR_I2C_SCL_PP7, "PWR_I2C_SCL_PP7"),
 326	PINCTRL_PIN(TEGRA_PIN_PWR_I2C_SDA_PQ0, "PWR_I2C_SDA_PQ0"),
 327	PINCTRL_PIN(TEGRA_PIN_SOC_GPIO28_PQ1, "SOC_GPIO28_PQ1"),
 328	PINCTRL_PIN(TEGRA_PIN_SOC_GPIO29_PQ2, "SOC_GPIO29_PQ2"),
 329	PINCTRL_PIN(TEGRA_PIN_SOC_GPIO30_PQ3, "SOC_GPIO30_PQ3"),
 330	PINCTRL_PIN(TEGRA_PIN_SOC_GPIO31_PQ4, "SOC_GPIO31_PQ4"),
 331	PINCTRL_PIN(TEGRA_PIN_SOC_GPIO32_PQ5, "SOC_GPIO32_PQ5"),
 332	PINCTRL_PIN(TEGRA_PIN_SOC_GPIO33_PQ6, "SOC_GPIO33_PQ6"),
 333	PINCTRL_PIN(TEGRA_PIN_SOC_GPIO35_PQ7, "SOC_GPIO35_PQ7"),
 334	PINCTRL_PIN(TEGRA_PIN_SOC_GPIO37_PR0, "SOC_GPIO37_PR0"),
 335	PINCTRL_PIN(TEGRA_PIN_SOC_GPIO56_PR1, "SOC_GPIO56_PR1"),
 336	PINCTRL_PIN(TEGRA_PIN_UART1_TX_PR2, "UART1_TX_PR2"),
 337	PINCTRL_PIN(TEGRA_PIN_UART1_RX_PR3, "UART1_RX_PR3"),
 338	PINCTRL_PIN(TEGRA_PIN_UART1_RTS_PR4, "UART1_RTS_PR4"),
 339	PINCTRL_PIN(TEGRA_PIN_UART1_CTS_PR5, "UART1_CTS_PR5"),
 340	PINCTRL_PIN(TEGRA_PIN_GPU_PWR_REQ_PX0, "GPU_PWR_REQ_PX0"),
 341	PINCTRL_PIN(TEGRA_PIN_CV_PWR_REQ_PX1, "CV_PWR_REQ_PX1"),
 342	PINCTRL_PIN(TEGRA_PIN_GP_PWM2_PX2, "GP_PWM2_PX2"),
 343	PINCTRL_PIN(TEGRA_PIN_GP_PWM3_PX3, "GP_PWM3_PX3"),
 344	PINCTRL_PIN(TEGRA_PIN_UART2_TX_PX4, "UART2_TX_PX4"),
 345	PINCTRL_PIN(TEGRA_PIN_UART2_RX_PX5, "UART2_RX_PX5"),
 346	PINCTRL_PIN(TEGRA_PIN_UART2_RTS_PX6, "UART2_RTS_PX6"),
 347	PINCTRL_PIN(TEGRA_PIN_UART2_CTS_PX7, "UART2_CTS_PX7"),
 348	PINCTRL_PIN(TEGRA_PIN_SPI3_SCK_PY0, "SPI3_SCK_PY0"),
 349	PINCTRL_PIN(TEGRA_PIN_SPI3_MISO_PY1, "SPI3_MISO_PY1"),
 350	PINCTRL_PIN(TEGRA_PIN_SPI3_MOSI_PY2, "SPI3_MOSI_PY2"),
 351	PINCTRL_PIN(TEGRA_PIN_SPI3_CS0_PY3, "SPI3_CS0_PY3"),
 352	PINCTRL_PIN(TEGRA_PIN_SPI3_CS1_PY4, "SPI3_CS1_PY4"),
 353	PINCTRL_PIN(TEGRA_PIN_UART5_TX_PY5, "UART5_TX_PY5"),
 354	PINCTRL_PIN(TEGRA_PIN_UART5_RX_PY6, "UART5_RX_PY6"),
 355	PINCTRL_PIN(TEGRA_PIN_UART5_RTS_PY7, "UART5_RTS_PY7"),
 356	PINCTRL_PIN(TEGRA_PIN_UART5_CTS_PZ0, "UART5_CTS_PZ0"),
 357	PINCTRL_PIN(TEGRA_PIN_USB_VBUS_EN0_PZ1, "USB_VBUS_EN0_PZ1"),
 358	PINCTRL_PIN(TEGRA_PIN_USB_VBUS_EN1_PZ2, "USB_VBUS_EN1_PZ2"),
 359	PINCTRL_PIN(TEGRA_PIN_SPI1_SCK_PZ3, "SPI1_SCK_PZ3"),
 360	PINCTRL_PIN(TEGRA_PIN_SPI1_MISO_PZ4, "SPI1_MISO_PZ4"),
 361	PINCTRL_PIN(TEGRA_PIN_SPI1_MOSI_PZ5, "SPI1_MOSI_PZ5"),
 362	PINCTRL_PIN(TEGRA_PIN_SPI1_CS0_PZ6, "SPI1_CS0_PZ6"),
 363	PINCTRL_PIN(TEGRA_PIN_SPI1_CS1_PZ7, "SPI1_CS1_PZ7"),
 364	PINCTRL_PIN(TEGRA_PIN_SPI5_SCK_PAC0, "SPI5_SCK_PAC0"),
 365	PINCTRL_PIN(TEGRA_PIN_SPI5_MISO_PAC1, "SPI5_MISO_PAC1"),
 366	PINCTRL_PIN(TEGRA_PIN_SPI5_MOSI_PAC2, "SPI5_MOSI_PAC2"),
 367	PINCTRL_PIN(TEGRA_PIN_SPI5_CS0_PAC3, "SPI5_CS0_PAC3"),
 368	PINCTRL_PIN(TEGRA_PIN_SOC_GPIO57_PAC4, "SOC_GPIO57_PAC4"),
 369	PINCTRL_PIN(TEGRA_PIN_SOC_GPIO58_PAC5, "SOC_GPIO58_PAC5"),
 370	PINCTRL_PIN(TEGRA_PIN_SOC_GPIO59_PAC6, "SOC_GPIO59_PAC6"),
 371	PINCTRL_PIN(TEGRA_PIN_SOC_GPIO60_PAC7, "SOC_GPIO60_PAC7"),
 372	PINCTRL_PIN(TEGRA_PIN_SOC_GPIO45_PAD0, "SOC_GPIO45_PAD0"),
 373	PINCTRL_PIN(TEGRA_PIN_SOC_GPIO46_PAD1, "SOC_GPIO46_PAD1"),
 374	PINCTRL_PIN(TEGRA_PIN_SOC_GPIO47_PAD2, "SOC_GPIO47_PAD2"),
 375	PINCTRL_PIN(TEGRA_PIN_SOC_GPIO48_PAD3, "SOC_GPIO48_PAD3"),
 376	PINCTRL_PIN(TEGRA_PIN_UFS0_REF_CLK_PAE0, "UFS0_REF_CLK_PAE0"),
 377	PINCTRL_PIN(TEGRA_PIN_UFS0_RST_N_PAE1, "UFS0_RST_N_PAE1"),
 378	PINCTRL_PIN(TEGRA_PIN_PEX_L5_CLKREQ_N_PAF0, "PEX_L5_CLKREQ_N_PAF0"),
 379	PINCTRL_PIN(TEGRA_PIN_PEX_L5_RST_N_PAF1, "PEX_L5_RST_N_PAF1"),
 380	PINCTRL_PIN(TEGRA_PIN_PEX_L6_CLKREQ_N_PAF2, "PEX_L6_CLKREQ_N_PAF2"),
 381	PINCTRL_PIN(TEGRA_PIN_PEX_L6_RST_N_PAF3, "PEX_L6_RST_N_PAF3"),
 382	PINCTRL_PIN(TEGRA_PIN_PEX_L7_CLKREQ_N_PAG0, "PEX_L7_CLKREQ_N_PAG0"),
 383	PINCTRL_PIN(TEGRA_PIN_PEX_L7_RST_N_PAG1, "PEX_L7_RST_N_PAG1"),
 384	PINCTRL_PIN(TEGRA_PIN_PEX_L8_CLKREQ_N_PAG2, "PEX_L8_CLKREQ_N_PAG2"),
 385	PINCTRL_PIN(TEGRA_PIN_PEX_L8_RST_N_PAG3, "PEX_L8_RST_N_PAG3"),
 386	PINCTRL_PIN(TEGRA_PIN_PEX_L9_CLKREQ_N_PAG4, "PEX_L9_CLKREQ_N_PAG4"),
 387	PINCTRL_PIN(TEGRA_PIN_PEX_L9_RST_N_PAG5, "PEX_L9_RST_N_PAG5"),
 388	PINCTRL_PIN(TEGRA_PIN_PEX_L10_CLKREQ_N_PAG6, "PEX_L10_CLKREQ_N_PAG6"),
 389	PINCTRL_PIN(TEGRA_PIN_PEX_L10_RST_N_PAG7, "PEX_L10_RST_N_PAG7"),
 390	PINCTRL_PIN(TEGRA_PIN_EQOS_COMP, "EQOS_COMP"),
 391	PINCTRL_PIN(TEGRA_PIN_QSPI_COMP, "QSPI_COMP"),
 392	PINCTRL_PIN(TEGRA_PIN_SDMMC1_COMP, "SDMMC1_COMP"),
 393};
 394
 395static const unsigned int dap6_sclk_pa0_pins[] = {
 396	TEGRA_PIN_DAP6_SCLK_PA0,
 397};
 398
 399static const unsigned int dap6_dout_pa1_pins[] = {
 400	TEGRA_PIN_DAP6_DOUT_PA1,
 401};
 402
 403static const unsigned int dap6_din_pa2_pins[] = {
 404	TEGRA_PIN_DAP6_DIN_PA2,
 405};
 406
 407static const unsigned int dap6_fs_pa3_pins[] = {
 408	TEGRA_PIN_DAP6_FS_PA3,
 409};
 410
 411static const unsigned int dap4_sclk_pa4_pins[] = {
 412	TEGRA_PIN_DAP4_SCLK_PA4,
 413};
 414
 415static const unsigned int dap4_dout_pa5_pins[] = {
 416	TEGRA_PIN_DAP4_DOUT_PA5,
 417};
 418
 419static const unsigned int dap4_din_pa6_pins[] = {
 420	TEGRA_PIN_DAP4_DIN_PA6,
 421};
 422
 423static const unsigned int dap4_fs_pa7_pins[] = {
 424	TEGRA_PIN_DAP4_FS_PA7,
 425};
 426
 427static const unsigned int soc_gpio08_pb0_pins[] = {
 428	TEGRA_PIN_SOC_GPIO08_PB0,
 429};
 430
 431static const unsigned int qspi0_sck_pc0_pins[] = {
 432	TEGRA_PIN_QSPI0_SCK_PC0,
 433};
 434
 435static const unsigned int qspi0_cs_n_pc1_pins[] = {
 436	TEGRA_PIN_QSPI0_CS_N_PC1,
 437};
 438
 439static const unsigned int qspi0_io0_pc2_pins[] = {
 440	TEGRA_PIN_QSPI0_IO0_PC2,
 441};
 442
 443static const unsigned int qspi0_io1_pc3_pins[] = {
 444	TEGRA_PIN_QSPI0_IO1_PC3,
 445};
 446
 447static const unsigned int qspi0_io2_pc4_pins[] = {
 448	TEGRA_PIN_QSPI0_IO2_PC4,
 449};
 450
 451static const unsigned int qspi0_io3_pc5_pins[] = {
 452	TEGRA_PIN_QSPI0_IO3_PC5,
 453};
 454
 455static const unsigned int qspi1_sck_pc6_pins[] = {
 456	TEGRA_PIN_QSPI1_SCK_PC6,
 457};
 458
 459static const unsigned int qspi1_cs_n_pc7_pins[] = {
 460	TEGRA_PIN_QSPI1_CS_N_PC7,
 461};
 462
 463static const unsigned int qspi1_io0_pd0_pins[] = {
 464	TEGRA_PIN_QSPI1_IO0_PD0,
 465};
 466
 467static const unsigned int qspi1_io1_pd1_pins[] = {
 468	TEGRA_PIN_QSPI1_IO1_PD1,
 469};
 470
 471static const unsigned int qspi1_io2_pd2_pins[] = {
 472	TEGRA_PIN_QSPI1_IO2_PD2,
 473};
 474
 475static const unsigned int qspi1_io3_pd3_pins[] = {
 476	TEGRA_PIN_QSPI1_IO3_PD3,
 477};
 478
 479static const unsigned int eqos_txc_pe0_pins[] = {
 480	TEGRA_PIN_EQOS_TXC_PE0,
 481};
 482
 483static const unsigned int eqos_td0_pe1_pins[] = {
 484	TEGRA_PIN_EQOS_TD0_PE1,
 485};
 486
 487static const unsigned int eqos_td1_pe2_pins[] = {
 488	TEGRA_PIN_EQOS_TD1_PE2,
 489};
 490
 491static const unsigned int eqos_td2_pe3_pins[] = {
 492	TEGRA_PIN_EQOS_TD2_PE3,
 493};
 494
 495static const unsigned int eqos_td3_pe4_pins[] = {
 496	TEGRA_PIN_EQOS_TD3_PE4,
 497};
 498
 499static const unsigned int eqos_tx_ctl_pe5_pins[] = {
 500	TEGRA_PIN_EQOS_TX_CTL_PE5,
 501};
 502
 503static const unsigned int eqos_rd0_pe6_pins[] = {
 504	TEGRA_PIN_EQOS_RD0_PE6,
 505};
 506
 507static const unsigned int eqos_rd1_pe7_pins[] = {
 508	TEGRA_PIN_EQOS_RD1_PE7,
 509};
 510
 511static const unsigned int eqos_rd2_pf0_pins[] = {
 512	TEGRA_PIN_EQOS_RD2_PF0,
 513};
 514
 515static const unsigned int eqos_rd3_pf1_pins[] = {
 516	TEGRA_PIN_EQOS_RD3_PF1,
 517};
 518
 519static const unsigned int eqos_rx_ctl_pf2_pins[] = {
 520	TEGRA_PIN_EQOS_RX_CTL_PF2,
 521};
 522
 523static const unsigned int eqos_rxc_pf3_pins[] = {
 524	TEGRA_PIN_EQOS_RXC_PF3,
 525};
 526
 527static const unsigned int eqos_sma_mdio_pf4_pins[] = {
 528	TEGRA_PIN_EQOS_SMA_MDIO_PF4,
 529};
 530
 531static const unsigned int eqos_sma_mdc_pf5_pins[] = {
 532	TEGRA_PIN_EQOS_SMA_MDC_PF5,
 533};
 534
 535static const unsigned int soc_gpio13_pg0_pins[] = {
 536	TEGRA_PIN_SOC_GPIO13_PG0,
 537};
 538
 539static const unsigned int soc_gpio14_pg1_pins[] = {
 540	TEGRA_PIN_SOC_GPIO14_PG1,
 541};
 542
 543static const unsigned int soc_gpio15_pg2_pins[] = {
 544	TEGRA_PIN_SOC_GPIO15_PG2,
 545};
 546
 547static const unsigned int soc_gpio16_pg3_pins[] = {
 548	TEGRA_PIN_SOC_GPIO16_PG3,
 549};
 550
 551static const unsigned int soc_gpio17_pg4_pins[] = {
 552	TEGRA_PIN_SOC_GPIO17_PG4,
 553};
 554
 555static const unsigned int soc_gpio18_pg5_pins[] = {
 556	TEGRA_PIN_SOC_GPIO18_PG5,
 557};
 558
 559static const unsigned int soc_gpio19_pg6_pins[] = {
 560	TEGRA_PIN_SOC_GPIO19_PG6,
 561};
 562
 563static const unsigned int soc_gpio20_pg7_pins[] = {
 564	TEGRA_PIN_SOC_GPIO20_PG7,
 565};
 566
 567static const unsigned int soc_gpio21_ph0_pins[] = {
 568	TEGRA_PIN_SOC_GPIO21_PH0,
 569};
 570
 571static const unsigned int soc_gpio22_ph1_pins[] = {
 572	TEGRA_PIN_SOC_GPIO22_PH1,
 573};
 574
 575static const unsigned int soc_gpio06_ph2_pins[] = {
 576	TEGRA_PIN_SOC_GPIO06_PH2,
 577};
 578
 579static const unsigned int uart4_tx_ph3_pins[] = {
 580	TEGRA_PIN_UART4_TX_PH3,
 581};
 582
 583static const unsigned int uart4_rx_ph4_pins[] = {
 584	TEGRA_PIN_UART4_RX_PH4,
 585};
 586
 587static const unsigned int uart4_rts_ph5_pins[] = {
 588	TEGRA_PIN_UART4_RTS_PH5,
 589};
 590
 591static const unsigned int uart4_cts_ph6_pins[] = {
 592	TEGRA_PIN_UART4_CTS_PH6,
 593};
 594
 595static const unsigned int soc_gpio41_ph7_pins[] = {
 596	TEGRA_PIN_SOC_GPIO41_PH7,
 597};
 598
 599static const unsigned int soc_gpio42_pi0_pins[] = {
 600	TEGRA_PIN_SOC_GPIO42_PI0,
 601};
 602
 603static const unsigned int soc_gpio43_pi1_pins[] = {
 604	TEGRA_PIN_SOC_GPIO43_PI1,
 605};
 606
 607static const unsigned int soc_gpio44_pi2_pins[] = {
 608	TEGRA_PIN_SOC_GPIO44_PI2,
 609};
 610
 611static const unsigned int gen1_i2c_scl_pi3_pins[] = {
 612	TEGRA_PIN_GEN1_I2C_SCL_PI3,
 613};
 614
 615static const unsigned int gen1_i2c_sda_pi4_pins[] = {
 616	TEGRA_PIN_GEN1_I2C_SDA_PI4,
 617};
 618
 619static const unsigned int cpu_pwr_req_pi5_pins[] = {
 620	TEGRA_PIN_CPU_PWR_REQ_PI5,
 621};
 622
 623static const unsigned int soc_gpio07_pi6_pins[] = {
 624	TEGRA_PIN_SOC_GPIO07_PI6,
 625};
 626
 627static const unsigned int sdmmc1_clk_pj0_pins[] = {
 628	TEGRA_PIN_SDMMC1_CLK_PJ0,
 629};
 630
 631static const unsigned int sdmmc1_cmd_pj1_pins[] = {
 632	TEGRA_PIN_SDMMC1_CMD_PJ1,
 633};
 634
 635static const unsigned int sdmmc1_dat0_pj2_pins[] = {
 636	TEGRA_PIN_SDMMC1_DAT0_PJ2,
 637};
 638
 639static const unsigned int sdmmc1_dat1_pj3_pins[] = {
 640	TEGRA_PIN_SDMMC1_DAT1_PJ3,
 641};
 642
 643static const unsigned int sdmmc1_dat2_pj4_pins[] = {
 644	TEGRA_PIN_SDMMC1_DAT2_PJ4,
 645};
 646
 647static const unsigned int sdmmc1_dat3_pj5_pins[] = {
 648	TEGRA_PIN_SDMMC1_DAT3_PJ5,
 649};
 650
 651static const unsigned int pex_l0_clkreq_n_pk0_pins[] = {
 652	TEGRA_PIN_PEX_L0_CLKREQ_N_PK0,
 653};
 654
 655static const unsigned int pex_l0_rst_n_pk1_pins[] = {
 656	TEGRA_PIN_PEX_L0_RST_N_PK1,
 657};
 658
 659static const unsigned int pex_l1_clkreq_n_pk2_pins[] = {
 660	TEGRA_PIN_PEX_L1_CLKREQ_N_PK2,
 661};
 662
 663static const unsigned int pex_l1_rst_n_pk3_pins[] = {
 664	TEGRA_PIN_PEX_L1_RST_N_PK3,
 665};
 666
 667static const unsigned int pex_l2_clkreq_n_pk4_pins[] = {
 668	TEGRA_PIN_PEX_L2_CLKREQ_N_PK4,
 669};
 670
 671static const unsigned int pex_l2_rst_n_pk5_pins[] = {
 672	TEGRA_PIN_PEX_L2_RST_N_PK5,
 673};
 674
 675static const unsigned int pex_l3_clkreq_n_pk6_pins[] = {
 676	TEGRA_PIN_PEX_L3_CLKREQ_N_PK6,
 677};
 678
 679static const unsigned int pex_l3_rst_n_pk7_pins[] = {
 680	TEGRA_PIN_PEX_L3_RST_N_PK7,
 681};
 682
 683static const unsigned int pex_l4_clkreq_n_pl0_pins[] = {
 684	TEGRA_PIN_PEX_L4_CLKREQ_N_PL0,
 685};
 686
 687static const unsigned int pex_l4_rst_n_pl1_pins[] = {
 688	TEGRA_PIN_PEX_L4_RST_N_PL1,
 689};
 690
 691static const unsigned int pex_wake_n_pl2_pins[] = {
 692	TEGRA_PIN_PEX_WAKE_N_PL2,
 693};
 694
 695static const unsigned int soc_gpio34_pl3_pins[] = {
 696	TEGRA_PIN_SOC_GPIO34_PL3,
 697};
 698
 699static const unsigned int dp_aux_ch0_hpd_pm0_pins[] = {
 700	TEGRA_PIN_DP_AUX_CH0_HPD_PM0,
 701};
 702
 703static const unsigned int dp_aux_ch1_hpd_pm1_pins[] = {
 704	TEGRA_PIN_DP_AUX_CH1_HPD_PM1,
 705};
 706
 707static const unsigned int dp_aux_ch2_hpd_pm2_pins[] = {
 708	TEGRA_PIN_DP_AUX_CH2_HPD_PM2,
 709};
 710
 711static const unsigned int dp_aux_ch3_hpd_pm3_pins[] = {
 712	TEGRA_PIN_DP_AUX_CH3_HPD_PM3,
 713};
 714
 715static const unsigned int soc_gpio55_pm4_pins[] = {
 716	TEGRA_PIN_SOC_GPIO55_PM4,
 717};
 718
 719static const unsigned int soc_gpio36_pm5_pins[] = {
 720	TEGRA_PIN_SOC_GPIO36_PM5,
 721};
 722
 723static const unsigned int soc_gpio53_pm6_pins[] = {
 724	TEGRA_PIN_SOC_GPIO53_PM6,
 725};
 726
 727static const unsigned int soc_gpio38_pm7_pins[] = {
 728	TEGRA_PIN_SOC_GPIO38_PM7,
 729};
 730
 731static const unsigned int dp_aux_ch3_n_pn0_pins[] = {
 732	TEGRA_PIN_DP_AUX_CH3_N_PN0,
 733};
 734
 735static const unsigned int soc_gpio39_pn1_pins[] = {
 736	TEGRA_PIN_SOC_GPIO39_PN1,
 737};
 738
 739static const unsigned int soc_gpio40_pn2_pins[] = {
 740	TEGRA_PIN_SOC_GPIO40_PN2,
 741};
 742
 743static const unsigned int dp_aux_ch1_p_pn3_pins[] = {
 744	TEGRA_PIN_DP_AUX_CH1_P_PN3,
 745};
 746
 747static const unsigned int dp_aux_ch1_n_pn4_pins[] = {
 748	TEGRA_PIN_DP_AUX_CH1_N_PN4,
 749};
 750
 751static const unsigned int dp_aux_ch2_p_pn5_pins[] = {
 752	TEGRA_PIN_DP_AUX_CH2_P_PN5,
 753};
 754
 755static const unsigned int dp_aux_ch2_n_pn6_pins[] = {
 756	TEGRA_PIN_DP_AUX_CH2_N_PN6,
 757};
 758
 759static const unsigned int dp_aux_ch3_p_pn7_pins[] = {
 760	TEGRA_PIN_DP_AUX_CH3_P_PN7,
 761};
 762
 763static const unsigned int extperiph1_clk_pp0_pins[] = {
 764	TEGRA_PIN_EXTPERIPH1_CLK_PP0,
 765};
 766
 767static const unsigned int extperiph2_clk_pp1_pins[] = {
 768	TEGRA_PIN_EXTPERIPH2_CLK_PP1,
 769};
 770
 771static const unsigned int cam_i2c_scl_pp2_pins[] = {
 772	TEGRA_PIN_CAM_I2C_SCL_PP2,
 773};
 774
 775static const unsigned int cam_i2c_sda_pp3_pins[] = {
 776	TEGRA_PIN_CAM_I2C_SDA_PP3,
 777};
 778
 779static const unsigned int soc_gpio23_pp4_pins[] = {
 780	TEGRA_PIN_SOC_GPIO23_PP4,
 781};
 782
 783static const unsigned int soc_gpio24_pp5_pins[] = {
 784	TEGRA_PIN_SOC_GPIO24_PP5,
 785};
 786
 787static const unsigned int soc_gpio25_pp6_pins[] = {
 788	TEGRA_PIN_SOC_GPIO25_PP6,
 789};
 790
 791static const unsigned int pwr_i2c_scl_pp7_pins[] = {
 792	TEGRA_PIN_PWR_I2C_SCL_PP7,
 793};
 794
 795static const unsigned int pwr_i2c_sda_pq0_pins[] = {
 796	TEGRA_PIN_PWR_I2C_SDA_PQ0,
 797};
 798
 799static const unsigned int soc_gpio28_pq1_pins[] = {
 800	TEGRA_PIN_SOC_GPIO28_PQ1,
 801};
 802
 803static const unsigned int soc_gpio29_pq2_pins[] = {
 804	TEGRA_PIN_SOC_GPIO29_PQ2,
 805};
 806
 807static const unsigned int soc_gpio30_pq3_pins[] = {
 808	TEGRA_PIN_SOC_GPIO30_PQ3,
 809};
 810
 811static const unsigned int soc_gpio31_pq4_pins[] = {
 812	TEGRA_PIN_SOC_GPIO31_PQ4,
 813};
 814
 815static const unsigned int soc_gpio32_pq5_pins[] = {
 816	TEGRA_PIN_SOC_GPIO32_PQ5,
 817};
 818
 819static const unsigned int soc_gpio33_pq6_pins[] = {
 820	TEGRA_PIN_SOC_GPIO33_PQ6,
 821};
 822
 823static const unsigned int soc_gpio35_pq7_pins[] = {
 824	TEGRA_PIN_SOC_GPIO35_PQ7,
 825};
 826
 827static const unsigned int soc_gpio37_pr0_pins[] = {
 828	TEGRA_PIN_SOC_GPIO37_PR0,
 829};
 830
 831static const unsigned int soc_gpio56_pr1_pins[] = {
 832	TEGRA_PIN_SOC_GPIO56_PR1,
 833};
 834
 835static const unsigned int uart1_tx_pr2_pins[] = {
 836	TEGRA_PIN_UART1_TX_PR2,
 837};
 838
 839static const unsigned int uart1_rx_pr3_pins[] = {
 840	TEGRA_PIN_UART1_RX_PR3,
 841};
 842
 843static const unsigned int uart1_rts_pr4_pins[] = {
 844	TEGRA_PIN_UART1_RTS_PR4,
 845};
 846
 847static const unsigned int uart1_cts_pr5_pins[] = {
 848	TEGRA_PIN_UART1_CTS_PR5,
 849};
 850
 851static const unsigned int gpu_pwr_req_px0_pins[] = {
 852	TEGRA_PIN_GPU_PWR_REQ_PX0,
 853};
 854
 855static const unsigned int cv_pwr_req_px1_pins[] = {
 856	TEGRA_PIN_CV_PWR_REQ_PX1,
 857};
 858
 859static const unsigned int gp_pwm2_px2_pins[] = {
 860	TEGRA_PIN_GP_PWM2_PX2,
 861};
 862
 863static const unsigned int gp_pwm3_px3_pins[] = {
 864	TEGRA_PIN_GP_PWM3_PX3,
 865};
 866
 867static const unsigned int uart2_tx_px4_pins[] = {
 868	TEGRA_PIN_UART2_TX_PX4,
 869};
 870
 871static const unsigned int uart2_rx_px5_pins[] = {
 872	TEGRA_PIN_UART2_RX_PX5,
 873};
 874
 875static const unsigned int uart2_rts_px6_pins[] = {
 876	TEGRA_PIN_UART2_RTS_PX6,
 877};
 878
 879static const unsigned int uart2_cts_px7_pins[] = {
 880	TEGRA_PIN_UART2_CTS_PX7,
 881};
 882
 883static const unsigned int spi3_sck_py0_pins[] = {
 884	TEGRA_PIN_SPI3_SCK_PY0,
 885};
 886
 887static const unsigned int spi3_miso_py1_pins[] = {
 888	TEGRA_PIN_SPI3_MISO_PY1,
 889};
 890
 891static const unsigned int spi3_mosi_py2_pins[] = {
 892	TEGRA_PIN_SPI3_MOSI_PY2,
 893};
 894
 895static const unsigned int spi3_cs0_py3_pins[] = {
 896	TEGRA_PIN_SPI3_CS0_PY3,
 897};
 898
 899static const unsigned int spi3_cs1_py4_pins[] = {
 900	TEGRA_PIN_SPI3_CS1_PY4,
 901};
 902
 903static const unsigned int uart5_tx_py5_pins[] = {
 904	TEGRA_PIN_UART5_TX_PY5,
 905};
 906
 907static const unsigned int uart5_rx_py6_pins[] = {
 908	TEGRA_PIN_UART5_RX_PY6,
 909};
 910
 911static const unsigned int uart5_rts_py7_pins[] = {
 912	TEGRA_PIN_UART5_RTS_PY7,
 913};
 914
 915static const unsigned int uart5_cts_pz0_pins[] = {
 916	TEGRA_PIN_UART5_CTS_PZ0,
 917};
 918
 919static const unsigned int usb_vbus_en0_pz1_pins[] = {
 920	TEGRA_PIN_USB_VBUS_EN0_PZ1,
 921};
 922
 923static const unsigned int usb_vbus_en1_pz2_pins[] = {
 924	TEGRA_PIN_USB_VBUS_EN1_PZ2,
 925};
 926
 927static const unsigned int spi1_sck_pz3_pins[] = {
 928	TEGRA_PIN_SPI1_SCK_PZ3,
 929};
 930
 931static const unsigned int spi1_miso_pz4_pins[] = {
 932	TEGRA_PIN_SPI1_MISO_PZ4,
 933};
 934
 935static const unsigned int spi1_mosi_pz5_pins[] = {
 936	TEGRA_PIN_SPI1_MOSI_PZ5,
 937};
 938
 939static const unsigned int spi1_cs0_pz6_pins[] = {
 940	TEGRA_PIN_SPI1_CS0_PZ6,
 941};
 942
 943static const unsigned int spi1_cs1_pz7_pins[] = {
 944	TEGRA_PIN_SPI1_CS1_PZ7,
 945};
 946
 947static const unsigned int can0_dout_paa0_pins[] = {
 948	TEGRA_PIN_CAN0_DOUT_PAA0,
 949};
 950
 951static const unsigned int can0_din_paa1_pins[] = {
 952	TEGRA_PIN_CAN0_DIN_PAA1,
 953};
 954
 955static const unsigned int can1_dout_paa2_pins[] = {
 956	TEGRA_PIN_CAN1_DOUT_PAA2,
 957};
 958
 959static const unsigned int can1_din_paa3_pins[] = {
 960	TEGRA_PIN_CAN1_DIN_PAA3,
 961};
 962
 963static const unsigned int can0_stb_paa4_pins[] = {
 964	TEGRA_PIN_CAN0_STB_PAA4,
 965};
 966
 967static const unsigned int can0_en_paa5_pins[] = {
 968	TEGRA_PIN_CAN0_EN_PAA5,
 969};
 970
 971static const unsigned int soc_gpio49_paa6_pins[] = {
 972	TEGRA_PIN_SOC_GPIO49_PAA6,
 973};
 974
 975static const unsigned int can0_err_paa7_pins[] = {
 976	TEGRA_PIN_CAN0_ERR_PAA7,
 977};
 978
 979static const unsigned int spi5_sck_pac0_pins[] = {
 980	TEGRA_PIN_SPI5_SCK_PAC0,
 981};
 982
 983static const unsigned int spi5_miso_pac1_pins[] = {
 984	TEGRA_PIN_SPI5_MISO_PAC1,
 985};
 986
 987static const unsigned int spi5_mosi_pac2_pins[] = {
 988	TEGRA_PIN_SPI5_MOSI_PAC2,
 989};
 990
 991static const unsigned int spi5_cs0_pac3_pins[] = {
 992	TEGRA_PIN_SPI5_CS0_PAC3,
 993};
 994
 995static const unsigned int soc_gpio57_pac4_pins[] = {
 996	TEGRA_PIN_SOC_GPIO57_PAC4,
 997};
 998
 999static const unsigned int soc_gpio58_pac5_pins[] = {
1000	TEGRA_PIN_SOC_GPIO58_PAC5,
1001};
1002
1003static const unsigned int soc_gpio59_pac6_pins[] = {
1004	TEGRA_PIN_SOC_GPIO59_PAC6,
1005};
1006
1007static const unsigned int soc_gpio60_pac7_pins[] = {
1008	TEGRA_PIN_SOC_GPIO60_PAC7,
1009};
1010
1011static const unsigned int soc_gpio45_pad0_pins[] = {
1012	TEGRA_PIN_SOC_GPIO45_PAD0,
1013};
1014
1015static const unsigned int soc_gpio46_pad1_pins[] = {
1016	TEGRA_PIN_SOC_GPIO46_PAD1,
1017};
1018
1019static const unsigned int soc_gpio47_pad2_pins[] = {
1020	TEGRA_PIN_SOC_GPIO47_PAD2,
1021};
1022
1023static const unsigned int soc_gpio48_pad3_pins[] = {
1024	TEGRA_PIN_SOC_GPIO48_PAD3,
1025};
1026
1027static const unsigned int ufs0_ref_clk_pae0_pins[] = {
1028	TEGRA_PIN_UFS0_REF_CLK_PAE0,
1029};
1030
1031static const unsigned int ufs0_rst_n_pae1_pins[] = {
1032	TEGRA_PIN_UFS0_RST_N_PAE1,
1033};
1034
1035static const unsigned int pex_l5_clkreq_n_paf0_pins[] = {
1036	TEGRA_PIN_PEX_L5_CLKREQ_N_PAF0,
1037};
1038
1039static const unsigned int pex_l5_rst_n_paf1_pins[] = {
1040	TEGRA_PIN_PEX_L5_RST_N_PAF1,
1041};
1042
1043static const unsigned int pex_l6_clkreq_n_paf2_pins[] = {
1044	TEGRA_PIN_PEX_L6_CLKREQ_N_PAF2,
1045};
1046
1047static const unsigned int pex_l6_rst_n_paf3_pins[] = {
1048	TEGRA_PIN_PEX_L6_RST_N_PAF3,
1049};
1050
1051static const unsigned int pex_l7_clkreq_n_pag0_pins[] = {
1052	TEGRA_PIN_PEX_L7_CLKREQ_N_PAG0,
1053};
1054
1055static const unsigned int pex_l7_rst_n_pag1_pins[] = {
1056	TEGRA_PIN_PEX_L7_RST_N_PAG1,
1057};
1058
1059static const unsigned int pex_l8_clkreq_n_pag2_pins[] = {
1060	TEGRA_PIN_PEX_L8_CLKREQ_N_PAG2,
1061};
1062
1063static const unsigned int pex_l8_rst_n_pag3_pins[] = {
1064	TEGRA_PIN_PEX_L8_RST_N_PAG3,
1065};
1066
1067static const unsigned int pex_l9_clkreq_n_pag4_pins[] = {
1068	TEGRA_PIN_PEX_L9_CLKREQ_N_PAG4,
1069};
1070
1071static const unsigned int pex_l9_rst_n_pag5_pins[] = {
1072	TEGRA_PIN_PEX_L9_RST_N_PAG5,
1073};
1074
1075static const unsigned int pex_l10_clkreq_n_pag6_pins[] = {
1076	TEGRA_PIN_PEX_L10_CLKREQ_N_PAG6,
1077};
1078
1079static const unsigned int pex_l10_rst_n_pag7_pins[] = {
1080	TEGRA_PIN_PEX_L10_RST_N_PAG7,
1081};
1082
1083static const unsigned int can1_stb_pbb0_pins[] = {
1084	TEGRA_PIN_CAN1_STB_PBB0,
1085};
1086
1087static const unsigned int can1_en_pbb1_pins[] = {
1088	TEGRA_PIN_CAN1_EN_PBB1,
1089};
1090
1091static const unsigned int soc_gpio50_pbb2_pins[] = {
1092	TEGRA_PIN_SOC_GPIO50_PBB2,
1093};
1094
1095static const unsigned int can1_err_pbb3_pins[] = {
1096	TEGRA_PIN_CAN1_ERR_PBB3,
1097};
1098
1099static const unsigned int spi2_sck_pcc0_pins[] = {
1100	TEGRA_PIN_SPI2_SCK_PCC0,
1101};
1102
1103static const unsigned int spi2_miso_pcc1_pins[] = {
1104	TEGRA_PIN_SPI2_MISO_PCC1,
1105};
1106
1107static const unsigned int spi2_mosi_pcc2_pins[] = {
1108	TEGRA_PIN_SPI2_MOSI_PCC2,
1109};
1110
1111static const unsigned int spi2_cs0_pcc3_pins[] = {
1112	TEGRA_PIN_SPI2_CS0_PCC3,
1113};
1114
1115static const unsigned int touch_clk_pcc4_pins[] = {
1116	TEGRA_PIN_TOUCH_CLK_PCC4,
1117};
1118
1119static const unsigned int uart3_tx_pcc5_pins[] = {
1120	TEGRA_PIN_UART3_TX_PCC5,
1121};
1122
1123static const unsigned int uart3_rx_pcc6_pins[] = {
1124	TEGRA_PIN_UART3_RX_PCC6,
1125};
1126
1127static const unsigned int gen2_i2c_scl_pcc7_pins[] = {
1128	TEGRA_PIN_GEN2_I2C_SCL_PCC7,
1129};
1130
1131static const unsigned int gen2_i2c_sda_pdd0_pins[] = {
1132	TEGRA_PIN_GEN2_I2C_SDA_PDD0,
1133};
1134
1135static const unsigned int gen8_i2c_scl_pdd1_pins[] = {
1136	TEGRA_PIN_GEN8_I2C_SCL_PDD1,
1137};
1138
1139static const unsigned int gen8_i2c_sda_pdd2_pins[] = {
1140	TEGRA_PIN_GEN8_I2C_SDA_PDD2,
1141};
1142
1143static const unsigned int sce_error_pee0_pins[] = {
1144	TEGRA_PIN_SCE_ERROR_PEE0,
1145};
1146
1147static const unsigned int vcomp_alert_pee1_pins[] = {
1148	TEGRA_PIN_VCOMP_ALERT_PEE1,
1149};
1150
1151static const unsigned int ao_retention_n_pee2_pins[] = {
1152	TEGRA_PIN_AO_RETENTION_N_PEE2,
1153};
1154
1155static const unsigned int batt_oc_pee3_pins[] = {
1156	TEGRA_PIN_BATT_OC_PEE3,
1157};
1158
1159static const unsigned int power_on_pee4_pins[] = {
1160	TEGRA_PIN_POWER_ON_PEE4,
1161};
1162
1163static const unsigned int soc_gpio26_pee5_pins[] = {
1164	TEGRA_PIN_SOC_GPIO26_PEE5,
1165};
1166
1167static const unsigned int soc_gpio27_pee6_pins[] = {
1168	TEGRA_PIN_SOC_GPIO27_PEE6,
1169};
1170
1171static const unsigned int bootv_ctl_n_pee7_pins[] = {
1172	TEGRA_PIN_BOOTV_CTL_N_PEE7,
1173};
1174
1175static const unsigned int hdmi_cec_pgg0_pins[] = {
1176	TEGRA_PIN_HDMI_CEC_PGG0,
1177};
1178
1179static const unsigned int eqos_comp_pins[] = {
1180	TEGRA_PIN_EQOS_COMP,
1181};
1182
1183static const unsigned int qspi_comp_pins[] = {
1184	TEGRA_PIN_QSPI_COMP,
1185};
1186
1187static const unsigned int sdmmc1_comp_pins[] = {
1188	TEGRA_PIN_SDMMC1_COMP,
1189};
1190
1191/* Define unique ID for each function */
1192enum tegra_mux_dt {
1193	TEGRA_MUX_GP,
1194	TEGRA_MUX_UARTC,
1195	TEGRA_MUX_I2C8,
1196	TEGRA_MUX_SPI2,
1197	TEGRA_MUX_I2C2,
1198	TEGRA_MUX_CAN1,
1199	TEGRA_MUX_CAN0,
1200	TEGRA_MUX_RSVD0,
1201	TEGRA_MUX_ETH0,
1202	TEGRA_MUX_ETH2,
1203	TEGRA_MUX_ETH1,
1204	TEGRA_MUX_DP,
1205	TEGRA_MUX_ETH3,
1206	TEGRA_MUX_I2C4,
1207	TEGRA_MUX_I2C7,
1208	TEGRA_MUX_I2C9,
1209	TEGRA_MUX_EQOS,
1210	TEGRA_MUX_PE2,
1211	TEGRA_MUX_PE1,
1212	TEGRA_MUX_PE0,
1213	TEGRA_MUX_PE3,
1214	TEGRA_MUX_PE4,
1215	TEGRA_MUX_PE5,
1216	TEGRA_MUX_PE6,
1217	TEGRA_MUX_PE10,
1218	TEGRA_MUX_PE7,
1219	TEGRA_MUX_PE8,
1220	TEGRA_MUX_PE9,
1221	TEGRA_MUX_QSPI0,
1222	TEGRA_MUX_QSPI1,
1223	TEGRA_MUX_QSPI,
1224	TEGRA_MUX_SDMMC1,
1225	TEGRA_MUX_SCE,
1226	TEGRA_MUX_SOC,
1227	TEGRA_MUX_GPIO,
1228	TEGRA_MUX_HDMI,
1229	TEGRA_MUX_UFS0,
1230	TEGRA_MUX_SPI3,
1231	TEGRA_MUX_SPI1,
1232	TEGRA_MUX_UARTB,
1233	TEGRA_MUX_UARTE,
1234	TEGRA_MUX_USB,
1235	TEGRA_MUX_EXTPERIPH2,
1236	TEGRA_MUX_EXTPERIPH1,
1237	TEGRA_MUX_I2C3,
1238	TEGRA_MUX_VI0,
1239	TEGRA_MUX_I2C5,
1240	TEGRA_MUX_UARTA,
1241	TEGRA_MUX_UARTD,
1242	TEGRA_MUX_I2C1,
1243	TEGRA_MUX_I2S4,
1244	TEGRA_MUX_I2S6,
1245	TEGRA_MUX_AUD,
1246	TEGRA_MUX_SPI5,
1247	TEGRA_MUX_TOUCH,
1248	TEGRA_MUX_UARTJ,
1249	TEGRA_MUX_RSVD1,
1250	TEGRA_MUX_WDT,
1251	TEGRA_MUX_TSC,
1252	TEGRA_MUX_DMIC3,
1253	TEGRA_MUX_LED,
1254	TEGRA_MUX_VI0_ALT,
1255	TEGRA_MUX_I2S5,
1256	TEGRA_MUX_NV,
1257	TEGRA_MUX_EXTPERIPH3,
1258	TEGRA_MUX_EXTPERIPH4,
1259	TEGRA_MUX_SPI4,
1260	TEGRA_MUX_CCLA,
1261	TEGRA_MUX_I2S2,
1262	TEGRA_MUX_I2S1,
1263	TEGRA_MUX_I2S8,
1264	TEGRA_MUX_I2S3,
1265	TEGRA_MUX_RSVD2,
1266	TEGRA_MUX_DMIC5,
1267	TEGRA_MUX_DCA,
1268	TEGRA_MUX_DISPLAYB,
1269	TEGRA_MUX_DISPLAYA,
1270	TEGRA_MUX_VI1,
1271	TEGRA_MUX_DCB,
1272	TEGRA_MUX_DMIC1,
1273	TEGRA_MUX_DMIC4,
1274	TEGRA_MUX_I2S7,
1275	TEGRA_MUX_DMIC2,
1276	TEGRA_MUX_DSPK0,
1277	TEGRA_MUX_RSVD3,
1278	TEGRA_MUX_TSC_ALT,
1279	TEGRA_MUX_ISTCTRL,
1280	TEGRA_MUX_VI1_ALT,
1281	TEGRA_MUX_DSPK1,
1282	TEGRA_MUX_IGPU,
1283};
1284
1285/* Make list of each function name */
1286#define TEGRA_PIN_FUNCTION(lid) #lid
1287
1288static const char * const tegra234_functions[] = {
1289	TEGRA_PIN_FUNCTION(gp),
1290	TEGRA_PIN_FUNCTION(uartc),
1291	TEGRA_PIN_FUNCTION(i2c8),
1292	TEGRA_PIN_FUNCTION(spi2),
1293	TEGRA_PIN_FUNCTION(i2c2),
1294	TEGRA_PIN_FUNCTION(can1),
1295	TEGRA_PIN_FUNCTION(can0),
1296	TEGRA_PIN_FUNCTION(rsvd0),
1297	TEGRA_PIN_FUNCTION(eth0),
1298	TEGRA_PIN_FUNCTION(eth2),
1299	TEGRA_PIN_FUNCTION(eth1),
1300	TEGRA_PIN_FUNCTION(dp),
1301	TEGRA_PIN_FUNCTION(eth3),
1302	TEGRA_PIN_FUNCTION(i2c4),
1303	TEGRA_PIN_FUNCTION(i2c7),
1304	TEGRA_PIN_FUNCTION(i2c9),
1305	TEGRA_PIN_FUNCTION(eqos),
1306	TEGRA_PIN_FUNCTION(pe2),
1307	TEGRA_PIN_FUNCTION(pe1),
1308	TEGRA_PIN_FUNCTION(pe0),
1309	TEGRA_PIN_FUNCTION(pe3),
1310	TEGRA_PIN_FUNCTION(pe4),
1311	TEGRA_PIN_FUNCTION(pe5),
1312	TEGRA_PIN_FUNCTION(pe6),
1313	TEGRA_PIN_FUNCTION(pe10),
1314	TEGRA_PIN_FUNCTION(pe7),
1315	TEGRA_PIN_FUNCTION(pe8),
1316	TEGRA_PIN_FUNCTION(pe9),
1317	TEGRA_PIN_FUNCTION(qspi0),
1318	TEGRA_PIN_FUNCTION(qspi1),
1319	TEGRA_PIN_FUNCTION(qspi),
1320	TEGRA_PIN_FUNCTION(sdmmc1),
1321	TEGRA_PIN_FUNCTION(sce),
1322	TEGRA_PIN_FUNCTION(soc),
1323	TEGRA_PIN_FUNCTION(gpio),
1324	TEGRA_PIN_FUNCTION(hdmi),
1325	TEGRA_PIN_FUNCTION(ufs0),
1326	TEGRA_PIN_FUNCTION(spi3),
1327	TEGRA_PIN_FUNCTION(spi1),
1328	TEGRA_PIN_FUNCTION(uartb),
1329	TEGRA_PIN_FUNCTION(uarte),
1330	TEGRA_PIN_FUNCTION(usb),
1331	TEGRA_PIN_FUNCTION(extperiph2),
1332	TEGRA_PIN_FUNCTION(extperiph1),
1333	TEGRA_PIN_FUNCTION(i2c3),
1334	TEGRA_PIN_FUNCTION(vi0),
1335	TEGRA_PIN_FUNCTION(i2c5),
1336	TEGRA_PIN_FUNCTION(uarta),
1337	TEGRA_PIN_FUNCTION(uartd),
1338	TEGRA_PIN_FUNCTION(i2c1),
1339	TEGRA_PIN_FUNCTION(i2s4),
1340	TEGRA_PIN_FUNCTION(i2s6),
1341	TEGRA_PIN_FUNCTION(aud),
1342	TEGRA_PIN_FUNCTION(spi5),
1343	TEGRA_PIN_FUNCTION(touch),
1344	TEGRA_PIN_FUNCTION(uartj),
1345	TEGRA_PIN_FUNCTION(rsvd1),
1346	TEGRA_PIN_FUNCTION(wdt),
1347	TEGRA_PIN_FUNCTION(tsc),
1348	TEGRA_PIN_FUNCTION(dmic3),
1349	TEGRA_PIN_FUNCTION(led),
1350	TEGRA_PIN_FUNCTION(vi0_alt),
1351	TEGRA_PIN_FUNCTION(i2s5),
1352	TEGRA_PIN_FUNCTION(nv),
1353	TEGRA_PIN_FUNCTION(extperiph3),
1354	TEGRA_PIN_FUNCTION(extperiph4),
1355	TEGRA_PIN_FUNCTION(spi4),
1356	TEGRA_PIN_FUNCTION(ccla),
1357	TEGRA_PIN_FUNCTION(i2s2),
1358	TEGRA_PIN_FUNCTION(i2s1),
1359	TEGRA_PIN_FUNCTION(i2s8),
1360	TEGRA_PIN_FUNCTION(i2s3),
1361	TEGRA_PIN_FUNCTION(rsvd2),
1362	TEGRA_PIN_FUNCTION(dmic5),
1363	TEGRA_PIN_FUNCTION(dca),
1364	TEGRA_PIN_FUNCTION(displayb),
1365	TEGRA_PIN_FUNCTION(displaya),
1366	TEGRA_PIN_FUNCTION(vi1),
1367	TEGRA_PIN_FUNCTION(dcb),
1368	TEGRA_PIN_FUNCTION(dmic1),
1369	TEGRA_PIN_FUNCTION(dmic4),
1370	TEGRA_PIN_FUNCTION(i2s7),
1371	TEGRA_PIN_FUNCTION(dmic2),
1372	TEGRA_PIN_FUNCTION(dspk0),
1373	TEGRA_PIN_FUNCTION(rsvd3),
1374	TEGRA_PIN_FUNCTION(tsc_alt),
1375	TEGRA_PIN_FUNCTION(istctrl),
1376	TEGRA_PIN_FUNCTION(vi1_alt),
1377	TEGRA_PIN_FUNCTION(dspk1),
1378	TEGRA_PIN_FUNCTION(igpu),
1379};
1380
1381#define PINGROUP_REG_Y(r) ((r))
1382#define PINGROUP_REG_N(r) -1
1383
1384#define DRV_PINGROUP_Y(r) ((r))
1385#define DRV_PINGROUP_N(r) -1
1386
1387#define DRV_PINGROUP_ENTRY_N(pg_name)				\
1388		.drv_reg = -1,					\
1389		.drv_bank = -1,					\
1390		.drvdn_bit = -1,				\
1391		.drvup_bit = -1,				\
1392		.slwr_bit = -1,					\
1393		.slwf_bit = -1
1394
1395#define DRV_PINGROUP_ENTRY_Y(r, drvdn_b, drvdn_w, drvup_b,	\
1396			     drvup_w, slwr_b, slwr_w, slwf_b,	\
1397			     slwf_w, bank)			\
1398		.drv_reg = DRV_PINGROUP_Y(r),			\
1399		.drv_bank = bank,				\
1400		.drvdn_bit = drvdn_b,				\
1401		.drvdn_width = drvdn_w,				\
1402		.drvup_bit = drvup_b,				\
1403		.drvup_width = drvup_w,				\
1404		.slwr_bit = slwr_b,				\
1405		.slwr_width = slwr_w,				\
1406		.slwf_bit = slwf_b,				\
1407		.slwf_width = slwf_w
1408
1409#define PIN_PINGROUP_ENTRY_N(pg_name)				\
1410		.mux_reg = -1,					\
1411		.pupd_reg = -1,					\
1412		.tri_reg = -1,					\
1413		.einput_bit = -1,				\
1414		.e_io_hv_bit = -1,				\
1415		.odrain_bit = -1,				\
1416		.lock_bit = -1,					\
1417		.parked_bit = -1,				\
1418		.lpmd_bit = -1,					\
1419		.drvtype_bit = -1,				\
1420		.lpdr_bit = -1,					\
1421		.pbias_buf_bit = -1,				\
1422		.preemp_bit = -1,				\
1423		.rfu_in_bit = -1
1424
1425#define PIN_PINGROUP_ENTRY_Y(r, bank, pupd, e_io_hv, e_lpbk, e_input,	\
1426				e_lpdr, e_pbias_buf, gpio_sfio_sel,	\
1427				schmitt_b)				\
1428		.mux_reg = PINGROUP_REG_Y(r),			\
1429		.lpmd_bit = -1,					\
1430		.lock_bit = -1,					\
1431		.hsm_bit = -1,					\
1432		.mux_bank = bank,				\
1433		.mux_bit = 0,					\
1434		.pupd_reg = PINGROUP_REG_##pupd(r),		\
1435		.pupd_bank = bank,				\
1436		.pupd_bit = 2,					\
1437		.tri_reg = PINGROUP_REG_Y(r),			\
1438		.tri_bank = bank,				\
1439		.tri_bit = 4,					\
1440		.einput_bit = e_input,				\
1441		.sfsel_bit = gpio_sfio_sel,			\
1442		.schmitt_bit = schmitt_b,			\
1443		.drvtype_bit = 13,				\
1444		.lpdr_bit = e_lpdr,				\
1445
1446/* main drive pin groups */
1447#define	drive_soc_gpio08_pb0			DRV_PINGROUP_ENTRY_Y(0x500c,	12,	5,	20,	5,	-1,	-1,	-1,	-1,	0)
1448#define	drive_soc_gpio36_pm5			DRV_PINGROUP_ENTRY_Y(0x10004,	12,	5,	20,	5,	-1,	-1,	-1,	-1,	0)
1449#define	drive_soc_gpio53_pm6			DRV_PINGROUP_ENTRY_Y(0x1000c,	12,	5,	20,	5,	-1,	-1,	-1,	-1,	0)
1450#define	drive_soc_gpio55_pm4			DRV_PINGROUP_ENTRY_Y(0x10014,	12,	5,	20,	5,	-1,	-1,	-1,	-1,	0)
1451#define	drive_soc_gpio38_pm7			DRV_PINGROUP_ENTRY_Y(0x1001c,	12,	5,	20,	5,	-1,	-1,	-1,	-1,	0)
1452#define	drive_soc_gpio39_pn1			DRV_PINGROUP_ENTRY_Y(0x10024,	12,	5,	20,	5,	-1,	-1,	-1,	-1,	0)
1453#define	drive_soc_gpio40_pn2			DRV_PINGROUP_ENTRY_Y(0x1002c,	12,	5,	20,	5,	-1,	-1,	-1,	-1,	0)
1454#define	drive_dp_aux_ch0_hpd_pm0		DRV_PINGROUP_ENTRY_Y(0x10034,	12,	5,	20,	5,	-1,	-1,	-1,	-1,	0)
1455#define	drive_dp_aux_ch1_hpd_pm1		DRV_PINGROUP_ENTRY_Y(0x1003c,	12,	5,	20,	5,	-1,	-1,	-1,	-1,	0)
1456#define	drive_dp_aux_ch2_hpd_pm2		DRV_PINGROUP_ENTRY_Y(0x10044,	12,	5,	20,	5,	-1,	-1,	-1,	-1,	0)
1457#define	drive_dp_aux_ch3_hpd_pm3		DRV_PINGROUP_ENTRY_Y(0x1004c,	12,	5,	20,	5,	-1,	-1,	-1,	-1,	0)
1458#define	drive_dp_aux_ch1_p_pn3			DRV_PINGROUP_ENTRY_Y(0x10054,	12,	5,	20,	5,	-1,	-1,	-1,	-1,	0)
1459#define	drive_dp_aux_ch1_n_pn4			DRV_PINGROUP_ENTRY_Y(0x1005c,	12,	5,	20,	5,	-1,	-1,	-1,	-1,	0)
1460#define	drive_dp_aux_ch2_p_pn5			DRV_PINGROUP_ENTRY_Y(0x10064,	12,	5,	20,	5,	-1,	-1,	-1,	-1,	0)
1461#define	drive_dp_aux_ch2_n_pn6			DRV_PINGROUP_ENTRY_Y(0x1006c,	12,	5,	20,	5,	-1,	-1,	-1,	-1,	0)
1462#define	drive_dp_aux_ch3_p_pn7			DRV_PINGROUP_ENTRY_Y(0x10074,	12,	5,	20,	5,	-1,	-1,	-1,	-1,	0)
1463#define	drive_dp_aux_ch3_n_pn0			DRV_PINGROUP_ENTRY_Y(0x1007c,	12,	5,	20,	5,	-1,	-1,	-1,	-1,	0)
1464#define	drive_pex_l2_clkreq_n_pk4		DRV_PINGROUP_ENTRY_Y(0x7004,	12,	5,	20,	5,	-1,	-1,	-1,	-1,	0)
1465#define	drive_pex_wake_n_pl2			DRV_PINGROUP_ENTRY_Y(0x700c,	12,	5,	20,	5,	-1,	-1,	-1,	-1,	0)
1466#define	drive_pex_l1_clkreq_n_pk2		DRV_PINGROUP_ENTRY_Y(0x7014,	12,	5,	20,	5,	-1,	-1,	-1,	-1,	0)
1467#define	drive_pex_l1_rst_n_pk3			DRV_PINGROUP_ENTRY_Y(0x701c,	12,	5,	20,	5,	-1,	-1,	-1,	-1,	0)
1468#define	drive_pex_l0_clkreq_n_pk0		DRV_PINGROUP_ENTRY_Y(0x7024,	12,	5,	20,	5,	-1,	-1,	-1,	-1,	0)
1469#define	drive_pex_l0_rst_n_pk1			DRV_PINGROUP_ENTRY_Y(0x702c,	12,	5,	20,	5,	-1,	-1,	-1,	-1,	0)
1470#define	drive_pex_l2_rst_n_pk5			DRV_PINGROUP_ENTRY_Y(0x7034,	12,	5,	20,	5,	-1,	-1,	-1,	-1,	0)
1471#define	drive_pex_l3_clkreq_n_pk6		DRV_PINGROUP_ENTRY_Y(0x703c,	12,	5,	20,	5,	-1,	-1,	-1,	-1,	0)
1472#define	drive_pex_l3_rst_n_pk7			DRV_PINGROUP_ENTRY_Y(0x7044,	12,	5,	20,	5,	-1,	-1,	-1,	-1,	0)
1473#define	drive_pex_l4_clkreq_n_pl0		DRV_PINGROUP_ENTRY_Y(0x704c,	12,	5,	20,	5,	-1,	-1,	-1,	-1,	0)
1474#define	drive_pex_l4_rst_n_pl1			DRV_PINGROUP_ENTRY_Y(0x7054,	12,	5,	20,	5,	-1,	-1,	-1,	-1,	0)
1475#define	drive_soc_gpio34_pl3			DRV_PINGROUP_ENTRY_Y(0x705c,	12,	5,	20,	5,	-1,	-1,	-1,	-1,	0)
1476#define	drive_pex_l5_clkreq_n_paf0		DRV_PINGROUP_ENTRY_Y(0x14004,	12,	5,	20,	5,	-1,	-1,	-1,	-1,	0)
1477#define	drive_pex_l5_rst_n_paf1			DRV_PINGROUP_ENTRY_Y(0x1400c,	12,	5,	20,	5,	-1,	-1,	-1,	-1,	0)
1478#define	drive_pex_l6_clkreq_n_paf2		DRV_PINGROUP_ENTRY_Y(0x14014,	12,	5,	20,	5,	-1,	-1,	-1,	-1,	0)
1479#define	drive_pex_l6_rst_n_paf3			DRV_PINGROUP_ENTRY_Y(0x1401c,	12,	5,	20,	5,	-1,	-1,	-1,	-1,	0)
1480#define	drive_pex_l10_clkreq_n_pag6		DRV_PINGROUP_ENTRY_Y(0x19004,	12,	5,	20,	5,	-1,	-1,	-1,	-1,	0)
1481#define	drive_pex_l10_rst_n_pag7		DRV_PINGROUP_ENTRY_Y(0x1900c,	12,	5,	20,	5,	-1,	-1,	-1,	-1,	0)
1482#define	drive_pex_l7_clkreq_n_pag0		DRV_PINGROUP_ENTRY_Y(0x19014,	12,	5,	20,	5,	-1,	-1,	-1,	-1,	0)
1483#define	drive_pex_l7_rst_n_pag1			DRV_PINGROUP_ENTRY_Y(0x1901c,	12,	5,	20,	5,	-1,	-1,	-1,	-1,	0)
1484#define	drive_pex_l8_clkreq_n_pag2		DRV_PINGROUP_ENTRY_Y(0x19024,	12,	5,	20,	5,	-1,	-1,	-1,	-1,	0)
1485#define	drive_pex_l8_rst_n_pag3			DRV_PINGROUP_ENTRY_Y(0x1902c,	12,	5,	20,	5,	-1,	-1,	-1,	-1,	0)
1486#define	drive_pex_l9_clkreq_n_pag4		DRV_PINGROUP_ENTRY_Y(0x19034,	12,	5,	20,	5,	-1,	-1,	-1,	-1,	0)
1487#define	drive_pex_l9_rst_n_pag5			DRV_PINGROUP_ENTRY_Y(0x1903c,	12,	5,	20,	5,	-1,	-1,	-1,	-1,	0)
1488#define	drive_sdmmc1_clk_pj0			DRV_PINGROUP_ENTRY_Y(0x8004,	28,	2,	30,	2,	-1,	-1,	-1,	-1,	0)
1489#define	drive_sdmmc1_cmd_pj1			DRV_PINGROUP_ENTRY_Y(0x800c,	28,	2,	30,	2,	-1,	-1,	-1,	-1,	0)
1490#define	drive_sdmmc1_dat3_pj5			DRV_PINGROUP_ENTRY_Y(0x801c,	28,	2,	30,	2,	-1,	-1,	-1,	-1,	0)
1491#define	drive_sdmmc1_dat2_pj4			DRV_PINGROUP_ENTRY_Y(0x8024,	28,	2,	30,	2,	-1,	-1,	-1,	-1,	0)
1492#define	drive_sdmmc1_dat1_pj3			DRV_PINGROUP_ENTRY_Y(0x802c,	28,	2,	30,	2,	-1,	-1,	-1,	-1,	0)
1493#define	drive_sdmmc1_dat0_pj2			DRV_PINGROUP_ENTRY_Y(0x8034,	28,	2,	30,	2,	-1,	-1,	-1,	-1,	0)
1494#define	drive_ufs0_rst_n_pae1			DRV_PINGROUP_ENTRY_Y(0x11004,	12,	5,	24,	5,	-1,	-1,	-1,	-1,	0)
1495#define	drive_ufs0_ref_clk_pae0			DRV_PINGROUP_ENTRY_Y(0x1100c,	12,	5,	24,	5,	-1,	-1,	-1,	-1,	0)
1496#define	drive_spi3_miso_py1			DRV_PINGROUP_ENTRY_Y(0xd004,	12,	5,	20,	5,	-1,	-1,	-1,	-1,	0)
1497#define	drive_spi1_cs0_pz6			DRV_PINGROUP_ENTRY_Y(0xd00c,	12,	5,	20,	5,	-1,	-1,	-1,	-1,	0)
1498#define	drive_spi3_cs0_py3			DRV_PINGROUP_ENTRY_Y(0xd014,	12,	5,	20,	5,	-1,	-1,	-1,	-1,	0)
1499#define	drive_spi1_miso_pz4			DRV_PINGROUP_ENTRY_Y(0xd01c,	12,	5,	20,	5,	-1,	-1,	-1,	-1,	0)
1500#define	drive_spi3_cs1_py4			DRV_PINGROUP_ENTRY_Y(0xd024,	12,	5,	20,	5,	-1,	-1,	-1,	-1,	0)
1501#define	drive_spi1_sck_pz3			DRV_PINGROUP_ENTRY_Y(0xd02c,	12,	5,	20,	5,	-1,	-1,	-1,	-1,	0)
1502#define	drive_spi3_sck_py0			DRV_PINGROUP_ENTRY_Y(0xd034,	12,	5,	20,	5,	-1,	-1,	-1,	-1,	0)
1503#define	drive_spi1_cs1_pz7			DRV_PINGROUP_ENTRY_Y(0xd03c,	12,	5,	20,	5,	-1,	-1,	-1,	-1,	0)
1504#define	drive_spi1_mosi_pz5			DRV_PINGROUP_ENTRY_Y(0xd044,	12,	5,	20,	5,	-1,	-1,	-1,	-1,	0)
1505#define	drive_spi3_mosi_py2			DRV_PINGROUP_ENTRY_Y(0xd04c,	12,	5,	20,	5,	-1,	-1,	-1,	-1,	0)
1506#define	drive_uart2_tx_px4			DRV_PINGROUP_ENTRY_Y(0xd054,	12,	5,	20,	5,	-1,	-1,	-1,	-1,	0)
1507#define	drive_uart2_rx_px5			DRV_PINGROUP_ENTRY_Y(0xd05c,	12,	5,	20,	5,	-1,	-1,	-1,	-1,	0)
1508#define	drive_uart2_rts_px6			DRV_PINGROUP_ENTRY_Y(0xd064,	12,	5,	20,	5,	-1,	-1,	-1,	-1,	0)
1509#define	drive_uart2_cts_px7			DRV_PINGROUP_ENTRY_Y(0xd06c,	12,	5,	20,	5,	-1,	-1,	-1,	-1,	0)
1510#define	drive_uart5_tx_py5			DRV_PINGROUP_ENTRY_Y(0xd074,	12,	5,	20,	5,	-1,	-1,	-1,	-1,	0)
1511#define	drive_uart5_rx_py6			DRV_PINGROUP_ENTRY_Y(0xd07c,	12,	5,	20,	5,	-1,	-1,	-1,	-1,	0)
1512#define	drive_uart5_rts_py7			DRV_PINGROUP_ENTRY_Y(0xd084,	12,	5,	20,	5,	-1,	-1,	-1,	-1,	0)
1513#define	drive_uart5_cts_pz0			DRV_PINGROUP_ENTRY_Y(0xd08c,	12,	5,	20,	5,	-1,	-1,	-1,	-1,	0)
1514#define	drive_gpu_pwr_req_px0			DRV_PINGROUP_ENTRY_Y(0xd094,	12,	5,	20,	5,	-1,	-1,	-1,	-1,	0)
1515#define	drive_gp_pwm3_px3			DRV_PINGROUP_ENTRY_Y(0xd09c,	12,	5,	20,	5,	-1,	-1,	-1,	-1,	0)
1516#define	drive_gp_pwm2_px2			DRV_PINGROUP_ENTRY_Y(0xd0a4,	12,	5,	20,	5,	-1,	-1,	-1,	-1,	0)
1517#define	drive_cv_pwr_req_px1			DRV_PINGROUP_ENTRY_Y(0xd0ac,	12,	5,	20,	5,	-1,	-1,	-1,	-1,	0)
1518#define	drive_usb_vbus_en0_pz1			DRV_PINGROUP_ENTRY_Y(0xd0b4,	12,	5,	20,	5,	-1,	-1,	-1,	-1,	0)
1519#define	drive_usb_vbus_en1_pz2			DRV_PINGROUP_ENTRY_Y(0xd0bc,	12,	5,	20,	5,	-1,	-1,	-1,	-1,	0)
1520#define	drive_extperiph2_clk_pp1		DRV_PINGROUP_ENTRY_Y(0x0004,	12,	5,	20,	5,	-1,	-1,	-1,	-1,	0)
1521#define	drive_extperiph1_clk_pp0		DRV_PINGROUP_ENTRY_Y(0x000c,	12,	5,	20,	5,	-1,	-1,	-1,	-1,	0)
1522#define	drive_cam_i2c_sda_pp3			DRV_PINGROUP_ENTRY_Y(0x0014,	12,	5,	20,	5,	-1,	-1,	-1,	-1,	0)
1523#define	drive_cam_i2c_scl_pp2			DRV_PINGROUP_ENTRY_Y(0x001c,	12,	5,	20,	5,	-1,	-1,	-1,	-1,	0)
1524#define	drive_soc_gpio23_pp4			DRV_PINGROUP_ENTRY_Y(0x0024,	12,	5,	20,	5,	-1,	-1,	-1,	-1,	0)
1525#define	drive_soc_gpio24_pp5			DRV_PINGROUP_ENTRY_Y(0x002c,	12,	5,	20,	5,	-1,	-1,	-1,	-1,	0)
1526#define	drive_soc_gpio25_pp6			DRV_PINGROUP_ENTRY_Y(0x0034,	12,	5,	20,	5,	-1,	-1,	-1,	-1,	0)
1527#define	drive_pwr_i2c_scl_pp7			DRV_PINGROUP_ENTRY_Y(0x003c,	12,	5,	20,	5,	-1,	-1,	-1,	-1,	0)
1528#define	drive_pwr_i2c_sda_pq0			DRV_PINGROUP_ENTRY_Y(0x0044,	12,	5,	20,	5,	-1,	-1,	-1,	-1,	0)
1529#define	drive_soc_gpio28_pq1			DRV_PINGROUP_ENTRY_Y(0x004c,	12,	5,	20,	5,	-1,	-1,	-1,	-1,	0)
1530#define	drive_soc_gpio29_pq2			DRV_PINGROUP_ENTRY_Y(0x0054,	12,	5,	20,	5,	-1,	-1,	-1,	-1,	0)
1531#define	drive_soc_gpio30_pq3			DRV_PINGROUP_ENTRY_Y(0x005c,	12,	5,	20,	5,	-1,	-1,	-1,	-1,	0)
1532#define	drive_soc_gpio31_pq4			DRV_PINGROUP_ENTRY_Y(0x0064,	12,	5,	20,	5,	-1,	-1,	-1,	-1,	0)
1533#define	drive_soc_gpio32_pq5			DRV_PINGROUP_ENTRY_Y(0x006c,	12,	5,	20,	5,	-1,	-1,	-1,	-1,	0)
1534#define	drive_soc_gpio33_pq6			DRV_PINGROUP_ENTRY_Y(0x0074,	12,	5,	20,	5,	-1,	-1,	-1,	-1,	0)
1535#define	drive_soc_gpio35_pq7			DRV_PINGROUP_ENTRY_Y(0x007c,	12,	5,	20,	5,	-1,	-1,	-1,	-1,	0)
1536#define	drive_soc_gpio37_pr0			DRV_PINGROUP_ENTRY_Y(0x0084,	12,	5,	20,	5,	-1,	-1,	-1,	-1,	0)
1537#define	drive_soc_gpio56_pr1			DRV_PINGROUP_ENTRY_Y(0x008c,	12,	5,	20,	5,	-1,	-1,	-1,	-1,	0)
1538#define	drive_uart1_cts_pr5			DRV_PINGROUP_ENTRY_Y(0x0094,	12,	5,	20,	5,	-1,	-1,	-1,	-1,	0)
1539#define	drive_uart1_rts_pr4			DRV_PINGROUP_ENTRY_Y(0x009c,	12,	5,	20,	5,	-1,	-1,	-1,	-1,	0)
1540#define	drive_uart1_rx_pr3			DRV_PINGROUP_ENTRY_Y(0x00a4,	12,	5,	20,	5,	-1,	-1,	-1,	-1,	0)
1541#define	drive_uart1_tx_pr2			DRV_PINGROUP_ENTRY_Y(0x00ac,	12,	5,	20,	5,	-1,	-1,	-1,	-1,	0)
1542#define	drive_cpu_pwr_req_pi5			DRV_PINGROUP_ENTRY_Y(0x4004,	12,	5,	20,	5,	-1,	-1,	-1,	-1,	0)
1543#define	drive_uart4_cts_ph6			DRV_PINGROUP_ENTRY_Y(0x400c,	12,	5,	20,	5,	-1,	-1,	-1,	-1,	0)
1544#define	drive_uart4_rts_ph5			DRV_PINGROUP_ENTRY_Y(0x4014,	12,	5,	20,	5,	-1,	-1,	-1,	-1,	0)
1545#define	drive_uart4_rx_ph4			DRV_PINGROUP_ENTRY_Y(0x401c,	12,	5,	20,	5,	-1,	-1,	-1,	-1,	0)
1546#define	drive_uart4_tx_ph3			DRV_PINGROUP_ENTRY_Y(0x4024,	12,	5,	20,	5,	-1,	-1,	-1,	-1,	0)
1547#define	drive_gen1_i2c_scl_pi3			DRV_PINGROUP_ENTRY_Y(0x402c,	12,	5,	20,	5,	-1,	-1,	-1,	-1,	0)
1548#define	drive_gen1_i2c_sda_pi4			DRV_PINGROUP_ENTRY_Y(0x4034,	12,	5,	20,	5,	-1,	-1,	-1,	-1,	0)
1549#define	drive_soc_gpio20_pg7			DRV_PINGROUP_ENTRY_Y(0x403c,	12,	5,	20,	5,	-1,	-1,	-1,	-1,	0)
1550#define	drive_soc_gpio21_ph0			DRV_PINGROUP_ENTRY_Y(0x4044,	12,	5,	20,	5,	-1,	-1,	-1,	-1,	0)
1551#define	drive_soc_gpio22_ph1			DRV_PINGROUP_ENTRY_Y(0x404c,	12,	5,	20,	5,	-1,	-1,	-1,	-1,	0)
1552#define	drive_soc_gpio13_pg0			DRV_PINGROUP_ENTRY_Y(0x4054,	12,	5,	20,	5,	-1,	-1,	-1,	-1,	0)
1553#define	drive_soc_gpio14_pg1			DRV_PINGROUP_ENTRY_Y(0x405c,	12,	5,	20,	5,	-1,	-1,	-1,	-1,	0)
1554#define	drive_soc_gpio15_pg2			DRV_PINGROUP_ENTRY_Y(0x4064,	12,	5,	20,	5,	-1,	-1,	-1,	-1,	0)
1555#define	drive_soc_gpio16_pg3			DRV_PINGROUP_ENTRY_Y(0x406c,	12,	5,	20,	5,	-1,	-1,	-1,	-1,	0)
1556#define	drive_soc_gpio17_pg4			DRV_PINGROUP_ENTRY_Y(0x4074,	12,	5,	20,	5,	-1,	-1,	-1,	-1,	0)
1557#define	drive_soc_gpio18_pg5			DRV_PINGROUP_ENTRY_Y(0x407c,	12,	5,	20,	5,	-1,	-1,	-1,	-1,	0)
1558#define	drive_soc_gpio19_pg6			DRV_PINGROUP_ENTRY_Y(0x4084,	12,	5,	20,	5,	-1,	-1,	-1,	-1,	0)
1559#define	drive_soc_gpio41_ph7			DRV_PINGROUP_ENTRY_Y(0x408c,	12,	5,	20,	5,	-1,	-1,	-1,	-1,	0)
1560#define	drive_soc_gpio42_pi0			DRV_PINGROUP_ENTRY_Y(0x4094,	12,	5,	20,	5,	-1,	-1,	-1,	-1,	0)
1561#define	drive_soc_gpio43_pi1			DRV_PINGROUP_ENTRY_Y(0x409c,	12,	5,	20,	5,	-1,	-1,	-1,	-1,	0)
1562#define	drive_soc_gpio44_pi2			DRV_PINGROUP_ENTRY_Y(0x40a4,	12,	5,	20,	5,	-1,	-1,	-1,	-1,	0)
1563#define	drive_soc_gpio06_ph2			DRV_PINGROUP_ENTRY_Y(0x40ac,	12,	5,	20,	5,	-1,	-1,	-1,	-1,	0)
1564#define	drive_soc_gpio07_pi6			DRV_PINGROUP_ENTRY_Y(0x40b4,	12,	5,	20,	5,	-1,	-1,	-1,	-1,	0)
1565#define	drive_dap4_sclk_pa4			DRV_PINGROUP_ENTRY_Y(0x2004,	12,	5,	20,	5,	-1,	-1,	-1,	-1,	0)
1566#define	drive_dap4_dout_pa5			DRV_PINGROUP_ENTRY_Y(0x200c,	12,	5,	20,	5,	-1,	-1,	-1,	-1,	0)
1567#define	drive_dap4_din_pa6			DRV_PINGROUP_ENTRY_Y(0x2014,	12,	5,	20,	5,	-1,	-1,	-1,	-1,	0)
1568#define	drive_dap4_fs_pa7			DRV_PINGROUP_ENTRY_Y(0x201c,	12,	5,	20,	5,	-1,	-1,	-1,	-1,	0)
1569#define	drive_dap6_sclk_pa0			DRV_PINGROUP_ENTRY_Y(0x2024,	12,	5,	20,	5,	-1,	-1,	-1,	-1,	0)
1570#define	drive_dap6_dout_pa1			DRV_PINGROUP_ENTRY_Y(0x202c,	12,	5,	20,	5,	-1,	-1,	-1,	-1,	0)
1571#define	drive_dap6_din_pa2			DRV_PINGROUP_ENTRY_Y(0x2034,	12,	5,	20,	5,	-1,	-1,	-1,	-1,	0)
1572#define	drive_dap6_fs_pa3			DRV_PINGROUP_ENTRY_Y(0x203c,	12,	5,	20,	5,	-1,	-1,	-1,	-1,	0)
1573#define	drive_soc_gpio45_pad0			DRV_PINGROUP_ENTRY_Y(0x18004,	12,	5,	20,	5,	-1,	-1,	-1,	-1,	0)
1574#define	drive_soc_gpio46_pad1			DRV_PINGROUP_ENTRY_Y(0x1800c,	12,	5,	20,	5,	-1,	-1,	-1,	-1,	0)
1575#define	drive_soc_gpio47_pad2			DRV_PINGROUP_ENTRY_Y(0x18014,	12,	5,	20,	5,	-1,	-1,	-1,	-1,	0)
1576#define	drive_soc_gpio48_pad3			DRV_PINGROUP_ENTRY_Y(0x1801c,	12,	5,	20,	5,	-1,	-1,	-1,	-1,	0)
1577#define	drive_soc_gpio57_pac4			DRV_PINGROUP_ENTRY_Y(0x18024,	12,	5,	20,	5,	-1,	-1,	-1,	-1,	0)
1578#define	drive_soc_gpio58_pac5			DRV_PINGROUP_ENTRY_Y(0x1802c,	12,	5,	20,	5,	-1,	-1,	-1,	-1,	0)
1579#define	drive_soc_gpio59_pac6			DRV_PINGROUP_ENTRY_Y(0x18034,	12,	5,	20,	5,	-1,	-1,	-1,	-1,	0)
1580#define	drive_soc_gpio60_pac7			DRV_PINGROUP_ENTRY_Y(0x1803c,	12,	5,	20,	5,	-1,	-1,	-1,	-1,	0)
1581#define	drive_spi5_cs0_pac3			DRV_PINGROUP_ENTRY_Y(0x18044,	12,	5,	20,	5,	-1,	-1,	-1,	-1,	0)
1582#define	drive_spi5_miso_pac1			DRV_PINGROUP_ENTRY_Y(0x1804c,	12,	5,	20,	5,	-1,	-1,	-1,	-1,	0)
1583#define	drive_spi5_mosi_pac2			DRV_PINGROUP_ENTRY_Y(0x18054,	12,	5,	20,	5,	-1,	-1,	-1,	-1,	0)
1584#define	drive_spi5_sck_pac0			DRV_PINGROUP_ENTRY_Y(0x1805c,	12,	5,	20,	5,	-1,	-1,	-1,	-1,	0)
1585#define	drive_eqos_td3_pe4			DRV_PINGROUP_ENTRY_N(no_entry)
1586#define	drive_eqos_td2_pe3			DRV_PINGROUP_ENTRY_N(no_entry)
1587#define	drive_eqos_td1_pe2			DRV_PINGROUP_ENTRY_N(no_entry)
1588#define	drive_eqos_td0_pe1			DRV_PINGROUP_ENTRY_N(no_entry)
1589#define	drive_eqos_rd3_pf1			DRV_PINGROUP_ENTRY_N(no_entry)
1590#define	drive_eqos_rd2_pf0			DRV_PINGROUP_ENTRY_N(no_entry)
1591#define	drive_eqos_rd1_pe7			DRV_PINGROUP_ENTRY_N(no_entry)
1592#define	drive_eqos_sma_mdio_pf4			DRV_PINGROUP_ENTRY_N(no_entry)
1593#define	drive_eqos_rd0_pe6			DRV_PINGROUP_ENTRY_N(no_entry)
1594#define	drive_eqos_sma_mdc_pf5			DRV_PINGROUP_ENTRY_N(no_entry)
1595#define	drive_eqos_comp				DRV_PINGROUP_ENTRY_N(no_entry)
1596#define	drive_eqos_txc_pe0			DRV_PINGROUP_ENTRY_N(no_entry)
1597#define	drive_eqos_rxc_pf3			DRV_PINGROUP_ENTRY_N(no_entry)
1598#define	drive_eqos_tx_ctl_pe5			DRV_PINGROUP_ENTRY_N(no_entry)
1599#define	drive_eqos_rx_ctl_pf2			DRV_PINGROUP_ENTRY_N(no_entry)
1600#define	drive_qspi0_io3_pc5			DRV_PINGROUP_ENTRY_N(no_entry)
1601#define	drive_qspi0_io2_pc4			DRV_PINGROUP_ENTRY_N(no_entry)
1602#define	drive_qspi0_io1_pc3			DRV_PINGROUP_ENTRY_N(no_entry)
1603#define	drive_qspi0_io0_pc2			DRV_PINGROUP_ENTRY_N(no_entry)
1604#define	drive_qspi0_sck_pc0			DRV_PINGROUP_ENTRY_N(no_entry)
1605#define	drive_qspi0_cs_n_pc1			DRV_PINGROUP_ENTRY_N(no_entry)
1606#define	drive_qspi1_io3_pd3			DRV_PINGROUP_ENTRY_N(no_entry)
1607#define	drive_qspi1_io2_pd2			DRV_PINGROUP_ENTRY_N(no_entry)
1608#define	drive_qspi1_io1_pd1			DRV_PINGROUP_ENTRY_N(no_entry)
1609#define	drive_qspi1_io0_pd0			DRV_PINGROUP_ENTRY_N(no_entry)
1610#define	drive_qspi1_sck_pc6			DRV_PINGROUP_ENTRY_N(no_entry)
1611#define	drive_qspi1_cs_n_pc7			DRV_PINGROUP_ENTRY_N(no_entry)
1612#define	drive_qspi_comp				DRV_PINGROUP_ENTRY_N(no_entry)
1613#define	drive_sdmmc1_comp			DRV_PINGROUP_ENTRY_N(no_entry)
1614
1615#define PINGROUP(pg_name, f0, f1, f2, f3, r, bank, pupd, e_io_hv, e_lpbk, e_input, e_lpdr, e_pbias_buf,	\
1616			gpio_sfio_sel, schmitt_b)							\
1617	{								\
1618		.name = #pg_name,					\
1619		.pins = pg_name##_pins,					\
1620		.npins = ARRAY_SIZE(pg_name##_pins),			\
1621			.funcs = {					\
1622				TEGRA_MUX_##f0,				\
1623				TEGRA_MUX_##f1,				\
1624				TEGRA_MUX_##f2,				\
1625				TEGRA_MUX_##f3,				\
1626			},						\
1627		PIN_PINGROUP_ENTRY_Y(r, bank, pupd, e_io_hv, e_lpbk,	\
1628					e_input, e_lpdr, e_pbias_buf,	\
1629					gpio_sfio_sel, schmitt_b)	\
1630		drive_##pg_name,					\
1631	}
1632
1633static const struct tegra_pingroup tegra234_groups[] = {
1634	PINGROUP(soc_gpio08_pb0,	RSVD0,		RSVD1,		RSVD2,		RSVD3,		0x5008,		0,	Y,	-1,	7,	6,	8,	-1,	10,	12),
1635	PINGROUP(soc_gpio36_pm5,	ETH0,		RSVD1,		DCA,		RSVD3,		0x10000,	0,	Y,	-1,	7,	6,	8,	-1,	10,	12),
1636	PINGROUP(soc_gpio53_pm6,	ETH0,		RSVD1,		DCA,		RSVD3,		0x10008,	0,	Y,	-1,	7,	6,	8,	-1,	10,	12),
1637	PINGROUP(soc_gpio55_pm4,	ETH2,		RSVD1,		RSVD2,		RSVD3,		0x10010,	0,	Y,	-1,	7,	6,	8,	-1,	10,	12),
1638	PINGROUP(soc_gpio38_pm7,	ETH1,		RSVD1,		RSVD2,		RSVD3,		0x10018,	0,	Y,	-1,	7,	6,	8,	-1,	10,	12),
1639	PINGROUP(soc_gpio39_pn1,	GP,		RSVD1,		RSVD2,		RSVD3,		0x10020,	0,	Y,	-1,	7,	6,	8,	-1,	10,	12),
1640	PINGROUP(soc_gpio40_pn2,	ETH1,		RSVD1,		RSVD2,		RSVD3,		0x10028,	0,	Y,	-1,	7,	6,	8,	-1,	10,	12),
1641	PINGROUP(dp_aux_ch0_hpd_pm0,	DP,		RSVD1,		RSVD2,		RSVD3,		0x10030,	0,	Y,	5,	7,	6,	8,	-1,	10,	12),
1642	PINGROUP(dp_aux_ch1_hpd_pm1,	ETH3,		RSVD1,		RSVD2,		RSVD3,		0x10038,	0,	Y,	5,	7,	6,	8,	-1,	10,	12),
1643	PINGROUP(dp_aux_ch2_hpd_pm2,	ETH3,		RSVD1,		DISPLAYB,	RSVD3,		0x10040,	0,	Y,	5,	7,	6,	8,	-1,	10,	12),
1644	PINGROUP(dp_aux_ch3_hpd_pm3,	ETH2,		RSVD1,		DISPLAYA,	RSVD3,		0x10048,	0,	Y,	5,	7,	6,	8,	-1,	10,	12),
1645	PINGROUP(dp_aux_ch1_p_pn3,	I2C4,		RSVD1,		RSVD2,		RSVD3,		0x10050,	0,	Y,	5,	7,	6,	8,	-1,	10,	12),
1646	PINGROUP(dp_aux_ch1_n_pn4,	I2C4,		RSVD1,		RSVD2,		RSVD3,		0x10058,	0,	Y,	5,	7,	6,	8,	-1,	10,	12),
1647	PINGROUP(dp_aux_ch2_p_pn5,	I2C7,		RSVD1,		RSVD2,		RSVD3,		0x10060,	0,	Y,	5,	7,	6,	8,	-1,	10,	12),
1648	PINGROUP(dp_aux_ch2_n_pn6,	I2C7,		RSVD1,		RSVD2,		RSVD3,		0x10068,	0,	Y,	5,	7,	6,	8,	-1,	10,	12),
1649	PINGROUP(dp_aux_ch3_p_pn7,	I2C9,		RSVD1,		RSVD2,		RSVD3,		0x10070,	0,	Y,	5,	7,	6,	8,	-1,	10,	12),
1650	PINGROUP(dp_aux_ch3_n_pn0,	I2C9,		RSVD1,		RSVD2,		RSVD3,		0x10078,	0,	Y,	5,	7,	6,	8,	-1,	10,	12),
1651	PINGROUP(eqos_td3_pe4,		EQOS,		RSVD1,		RSVD2,		RSVD3,		0x15000,	0,	Y,	-1,	5,	6,	-1,	-1,	10,	12),
1652	PINGROUP(eqos_td2_pe3,		EQOS,		RSVD1,		RSVD2,		RSVD3,		0x15008,	0,	Y,	-1,	5,	6,	-1,	-1,	10,	12),
1653	PINGROUP(eqos_td1_pe2,		EQOS,		RSVD1,		RSVD2,		RSVD3,		0x15010,	0,	Y,	-1,	5,	6,	-1,	-1,	10,	12),
1654	PINGROUP(eqos_td0_pe1,		EQOS,		RSVD1,		RSVD2,		RSVD3,		0x15018,	0,	Y,	-1,	5,	6,	-1,	-1,	10,	12),
1655	PINGROUP(eqos_rd3_pf1,		EQOS,		RSVD1,		RSVD2,		RSVD3,		0x15020,	0,	Y,	-1,	5,	6,	-1,	-1,	10,	12),
1656	PINGROUP(eqos_rd2_pf0,		EQOS,		RSVD1,		RSVD2,		RSVD3,		0x15028,	0,	Y,	-1,	5,	6,	-1,	-1,	10,	12),
1657	PINGROUP(eqos_rd1_pe7,		EQOS,		RSVD1,		RSVD2,		RSVD3,		0x15030,	0,	Y,	-1,	5,	6,	-1,	-1,	10,	12),
1658	PINGROUP(eqos_sma_mdio_pf4,	EQOS,		RSVD1,		RSVD2,		RSVD3,		0x15038,	0,	Y,	-1,	5,	6,	-1,	-1,	10,	12),
1659	PINGROUP(eqos_rd0_pe6,		EQOS,		RSVD1,		RSVD2,		RSVD3,		0x15040,	0,	Y,	-1,	5,	6,	-1,	-1,	10,	12),
1660	PINGROUP(eqos_sma_mdc_pf5,	EQOS,		RSVD1,		RSVD2,		RSVD3,		0x15048,	0,	Y,	-1,	5,	6,	-1,	-1,	10,	12),
1661	PINGROUP(eqos_comp,		EQOS,		RSVD1,		RSVD2,		RSVD3,		0x15050,	0,	N,	-1,	-1,	-1,	-1,	-1,	-1,	-1),
1662	PINGROUP(eqos_txc_pe0,		EQOS,		RSVD1,		RSVD2,		RSVD3,		0x15058,	0,	Y,	-1,	5,	6,	-1,	-1,	10,	12),
1663	PINGROUP(eqos_rxc_pf3,		EQOS,		RSVD1,		RSVD2,		RSVD3,		0x15060,	0,	Y,	-1,	5,	6,	-1,	-1,	10,	12),
1664	PINGROUP(eqos_tx_ctl_pe5,	EQOS,		RSVD1,		RSVD2,		RSVD3,		0x15068,	0,	Y,	-1,	5,	6,	-1,	-1,	10,	12),
1665	PINGROUP(eqos_rx_ctl_pf2,	EQOS,		RSVD1,		RSVD2,		RSVD3,		0x15070,	0,	Y,	-1,	5,	6,	-1,	-1,	10,	12),
1666	PINGROUP(pex_l2_clkreq_n_pk4,	PE2,		RSVD1,		RSVD2,		RSVD3,		0x7000,		0,	Y,	5,	7,	6,	8,	-1,	10,	12),
1667	PINGROUP(pex_wake_n_pl2,	RSVD0,		RSVD1,		RSVD2,		RSVD3,		0x7008,		0,	Y,	5,	7,	6,	8,	-1,	10,	12),
1668	PINGROUP(pex_l1_clkreq_n_pk2,	PE1,		RSVD1,		RSVD2,		RSVD3,		0x7010,		0,	Y,	5,	7,	6,	8,	-1,	10,	12),
1669	PINGROUP(pex_l1_rst_n_pk3,	PE1,		RSVD1,		RSVD2,		RSVD3,		0x7018,		0,	Y,	5,	7,	6,	8,	-1,	10,	12),
1670	PINGROUP(pex_l0_clkreq_n_pk0,	PE0,		RSVD1,		RSVD2,		RSVD3,		0x7020,		0,	Y,	5,	7,	6,	8,	-1,	10,	12),
1671	PINGROUP(pex_l0_rst_n_pk1,	PE0,		RSVD1,		RSVD2,		RSVD3,		0x7028,		0,	Y,	5,	7,	6,	8,	-1,	10,	12),
1672	PINGROUP(pex_l2_rst_n_pk5,	PE2,		RSVD1,		RSVD2,		RSVD3,		0x7030,		0,	Y,	5,	7,	6,	8,	-1,	10,	12),
1673	PINGROUP(pex_l3_clkreq_n_pk6,	PE3,		RSVD1,		RSVD2,		RSVD3,		0x7038,		0,	Y,	5,	7,	6,	8,	-1,	10,	12),
1674	PINGROUP(pex_l3_rst_n_pk7,	PE3,		RSVD1,		RSVD2,		RSVD3,		0x7040,		0,	Y,	5,	7,	6,	8,	-1,	10,	12),
1675	PINGROUP(pex_l4_clkreq_n_pl0,	PE4,		RSVD1,		RSVD2,		RSVD3,		0x7048,		0,	Y,	5,	7,	6,	8,	-1,	10,	12),
1676	PINGROUP(pex_l4_rst_n_pl1,	PE4,		RSVD1,		RSVD2,		RSVD3,		0x7050,		0,	Y,	5,	7,	6,	8,	-1,	10,	12),
1677	PINGROUP(soc_gpio34_pl3,	RSVD0,		RSVD1,		RSVD2,		RSVD3,		0x7058,		0,	Y,	5,	7,	6,	8,	-1,	10,	12),
1678	PINGROUP(pex_l5_clkreq_n_paf0,	PE5,		RSVD1,		RSVD2,		RSVD3,		0x14000,	0,	Y,	5,	7,	6,	8,	-1,	10,	12),
1679	PINGROUP(pex_l5_rst_n_paf1,	PE5,		RSVD1,		RSVD2,		RSVD3,		0x14008,	0,	Y,	5,	7,	6,	8,	-1,	10,	12),
1680	PINGROUP(pex_l6_clkreq_n_paf2,  PE6,		RSVD1,		RSVD2,		RSVD3,		0x14010,	0,	Y,	5,	7,	6,	8,	-1,	10,	12),
1681	PINGROUP(pex_l6_rst_n_paf3,	PE6,		RSVD1,		RSVD2,		RSVD3,		0x14018,	0,	Y,	5,	7,	6,	8,	-1,	10,	12),
1682	PINGROUP(pex_l10_clkreq_n_pag6,	PE10,		RSVD1,		RSVD2,		RSVD3,		0x19000,	0,	Y,	5,	7,	6,	8,	-1,	10,	12),
1683	PINGROUP(pex_l10_rst_n_pag7,	PE10,		RSVD1,		RSVD2,		RSVD3,		0x19008,	0,	Y,	5,	7,	6,	8,	-1,	10,	12),
1684	PINGROUP(pex_l7_clkreq_n_pag0,	PE7,		RSVD1,		RSVD2,		RSVD3,		0x19010,	0,	Y,	5,	7,	6,	8,	-1,	10,	12),
1685	PINGROUP(pex_l7_rst_n_pag1,	PE7,		RSVD1,		RSVD2,		RSVD3,		0x19018,	0,	Y,	5,	7,	6,	8,	-1,	10,	12),
1686	PINGROUP(pex_l8_clkreq_n_pag2,	PE8,		RSVD1,		RSVD2,		RSVD3,		0x19020,	0,	Y,	5,	7,	6,	8,	-1,	10,	12),
1687	PINGROUP(pex_l8_rst_n_pag3,	PE8,		RSVD1,		RSVD2,		RSVD3,		0x19028,	0,	Y,	5,	7,	6,	8,	-1,	10,	12),
1688	PINGROUP(pex_l9_clkreq_n_pag4,	PE9,		RSVD1,		RSVD2,		RSVD3,		0x19030,	0,	Y,	5,	7,	6,	8,	-1,	10,	12),
1689	PINGROUP(pex_l9_rst_n_pag5,	PE9,		RSVD1,		RSVD2,		RSVD3,		0x19038,	0,	Y,	5,	7,	6,	8,	-1,	10,	12),
1690	PINGROUP(qspi0_io3_pc5,		QSPI0,		RSVD1,		RSVD2,		RSVD3,		0xB000,		0,	Y,	-1,	5,	6,	-1,	-1,	10,	12),
1691	PINGROUP(qspi0_io2_pc4,		QSPI0,		RSVD1,		RSVD2,		RSVD3,		0xB008,		0,	Y,	-1,	5,	6,	-1,	-1,	10,	12),
1692	PINGROUP(qspi0_io1_pc3,		QSPI0,		RSVD1,		RSVD2,		RSVD3,		0xB010,		0,	Y,	-1,	5,	6,	-1,	-1,	10,	12),
1693	PINGROUP(qspi0_io0_pc2,		QSPI0,		RSVD1,		RSVD2,		RSVD3,		0xB018,		0,	Y,	-1,	5,	6,	-1,	-1,	10,	12),
1694	PINGROUP(qspi0_sck_pc0,		QSPI0,		RSVD1,		RSVD2,		RSVD3,		0xB020,		0,	Y,	-1,	5,	6,	-1,	-1,	10,	12),
1695	PINGROUP(qspi0_cs_n_pc1,	QSPI0,		RSVD1,		RSVD2,		RSVD3,		0xB028,		0,	Y,	-1,	5,	6,	-1,	-1,	10,	12),
1696	PINGROUP(qspi1_io3_pd3,		QSPI1,		RSVD1,		RSVD2,		RSVD3,		0xB030,		0,	Y,	-1,	5,	6,	-1,	-1,	10,	12),
1697	PINGROUP(qspi1_io2_pd2,		QSPI1,		RSVD1,		RSVD2,		RSVD3,		0xB038,		0,	Y,	-1,	5,	6,	-1,	-1,	10,	12),
1698	PINGROUP(qspi1_io1_pd1,		QSPI1,		RSVD1,		RSVD2,		RSVD3,		0xB040,		0,	Y,	-1,	5,	6,	-1,	-1,	10,	12),
1699	PINGROUP(qspi1_io0_pd0,		QSPI1,		RSVD1,		RSVD2,		RSVD3,		0xB048,		0,	Y,	-1,	5,	6,	-1,	-1,	10,	12),
1700	PINGROUP(qspi1_sck_pc6,		QSPI1,		RSVD1,		RSVD2,		RSVD3,		0xB050,		0,	Y,	-1,	5,	6,	-1,	-1,	10,	12),
1701	PINGROUP(qspi1_cs_n_pc7,	QSPI1,		RSVD1,		RSVD2,		RSVD3,		0xB058,		0,	Y,	-1,	5,	6,	-1,	-1,	10,	12),
1702	PINGROUP(qspi_comp,		QSPI,		RSVD1,		RSVD2,		RSVD3,		0xB060,		0,	N,	-1,	-1,	-1,	-1,	-1,	-1,	-1),
1703	PINGROUP(sdmmc1_clk_pj0,	SDMMC1,		RSVD1,		RSVD2,		RSVD3,		0x8000,		0,	Y,	-1,	5,	6,	-1,	9,	10,	12),
1704	PINGROUP(sdmmc1_cmd_pj1,	SDMMC1,		RSVD1,		RSVD2,		RSVD3,		0x8008,		0,	Y,	-1,	5,	6,	-1,	9,	10,	12),
1705	PINGROUP(sdmmc1_comp,		SDMMC1,		RSVD1,		RSVD2,		RSVD3,		0x8010,		0,	N,	-1,	-1,	-1,	-1,	-1,	-1,	-1),
1706	PINGROUP(sdmmc1_dat3_pj5,	SDMMC1,		RSVD1,		RSVD2,		RSVD3,		0x8018,		0,	Y,	-1,	5,	6,	-1,	9,	10,	12),
1707	PINGROUP(sdmmc1_dat2_pj4,	SDMMC1,		RSVD1,		RSVD2,		RSVD3,		0x8020,		0,	Y,	-1,	5,	6,	-1,	9,	10,	12),
1708	PINGROUP(sdmmc1_dat1_pj3,	SDMMC1,		RSVD1,		RSVD2,		RSVD3,		0x8028,		0,	Y,	-1,	5,	6,	-1,	9,	10,	12),
1709	PINGROUP(sdmmc1_dat0_pj2,	SDMMC1,		RSVD1,		RSVD2,		RSVD3,		0x8030,		0,	Y,	-1,	5,	6,	-1,	9,	10,	12),
1710	PINGROUP(ufs0_rst_n_pae1,	UFS0,		RSVD1,		RSVD2,		RSVD3,		0x11000,	0,	Y,	-1,	5,	6,	-1,	-1,	10,	12),
1711	PINGROUP(ufs0_ref_clk_pae0,	UFS0,		RSVD1,		RSVD2,		RSVD3,		0x11008,	0,	Y,	-1,	5,	6,	-1,	-1,	10,	12),
1712	PINGROUP(spi3_miso_py1,		SPI3,		RSVD1,		RSVD2,		RSVD3,		0xD000,		0,	Y,	5,	7,	6,	8,	-1,	10,	12),
1713	PINGROUP(spi1_cs0_pz6,		SPI1,		RSVD1,		RSVD2,		RSVD3,		0xD008,		0,	Y,	5,	7,	6,	8,	-1,	10,	12),
1714	PINGROUP(spi3_cs0_py3,		SPI3,		RSVD1,		RSVD2,		RSVD3,		0xD010,		0,	Y,	5,	7,	6,	8,	-1,	10,	12),
1715	PINGROUP(spi1_miso_pz4,		SPI1,		RSVD1,		RSVD2,		RSVD3,		0xD018,		0,	Y,	5,	7,	6,	8,	-1,	10,	12),
1716	PINGROUP(spi3_cs1_py4,		SPI3,		RSVD1,		RSVD2,		RSVD3,		0xD020,		0,	Y,	5,	7,	6,	8,	-1,	10,	12),
1717	PINGROUP(spi1_sck_pz3,		SPI1,		RSVD1,		RSVD2,		RSVD3,		0xD028,		0,	Y,	5,	7,	6,	8,	-1,	10,	12),
1718	PINGROUP(spi3_sck_py0,		SPI3,		RSVD1,		RSVD2,		RSVD3,		0xD030,		0,	Y,	5,	7,	6,	8,	-1,	10,	12),
1719	PINGROUP(spi1_cs1_pz7,		SPI1,		RSVD1,		RSVD2,		RSVD3,		0xD038,		0,	Y,	5,	7,	6,	8,	-1,	10,	12),
1720	PINGROUP(spi1_mosi_pz5,		SPI1,		RSVD1,		RSVD2,		RSVD3,		0xD040,		0,	Y,	5,	7,	6,	8,	-1,	10,	12),
1721	PINGROUP(spi3_mosi_py2,		SPI3,		RSVD1,		RSVD2,		RSVD3,		0xD048,		0,	Y,	5,	7,	6,	8,	-1,	10,	12),
1722	PINGROUP(uart2_tx_px4,		UARTB,		RSVD1,		RSVD2,		RSVD3,		0xD050,		0,	Y,	5,	7,	6,	8,	-1,	10,	12),
1723	PINGROUP(uart2_rx_px5,		UARTB,		RSVD1,		RSVD2,		RSVD3,		0xD058,		0,	Y,	5,	7,	6,	8,	-1,	10,	12),
1724	PINGROUP(uart2_rts_px6,		UARTB,		RSVD1,		RSVD2,		RSVD3,		0xD060,		0,	Y,	-1,	7,	6,	8,	-1,	10,	12),
1725	PINGROUP(uart2_cts_px7,		UARTB,		RSVD1,		RSVD2,		RSVD3,		0xD068,		0,	Y,	-1,	7,	6,	8,	-1,	10,	12),
1726	PINGROUP(uart5_tx_py5,		UARTE,		RSVD1,		RSVD2,		RSVD3,		0xD070,		0,	Y,	-1,	7,	6,	8,	-1,	10,	12),
1727	PINGROUP(uart5_rx_py6,		UARTE,		RSVD1,		RSVD2,		RSVD3,		0xD078,		0,	Y,	-1,	7,	6,	8,	-1,	10,	12),
1728	PINGROUP(uart5_rts_py7,		UARTE,		RSVD1,		RSVD2,		RSVD3,		0xD080,		0,	Y,	-1,	7,	6,	8,	-1,	10,	12),
1729	PINGROUP(uart5_cts_pz0,		UARTE,		RSVD1,		RSVD2,		RSVD3,		0xD088,		0,	Y,	-1,	7,	6,	8,	-1,	10,	12),
1730	PINGROUP(gpu_pwr_req_px0,	RSVD0,		RSVD1,		RSVD2,		RSVD3,		0xD090,		0,	Y,	-1,	7,	6,	8,	-1,	10,	12),
1731	PINGROUP(gp_pwm3_px3,		GP,		RSVD1,		RSVD2,		RSVD3,		0xD098,		0,	Y,	5,	7,	6,	8,	-1,	10,	12),
1732	PINGROUP(gp_pwm2_px2,		GP,		RSVD1,		RSVD2,		RSVD3,		0xD0A0,		0,	Y,	5,	7,	6,	8,	-1,	10,	12),
1733	PINGROUP(cv_pwr_req_px1,	RSVD0,		RSVD1,		RSVD2,		RSVD3,		0xD0A8,		0,	Y,	-1,	7,	6,	8,	-1,	10,	12),
1734	PINGROUP(usb_vbus_en0_pz1,	USB,		RSVD1,		RSVD2,		RSVD3,		0xD0B0,		0,	Y,	5,	7,	6,	8,	-1,	10,	12),
1735	PINGROUP(usb_vbus_en1_pz2,	USB,		RSVD1,		RSVD2,		RSVD3,		0xD0B8,		0,	Y,	5,	7,	6,	8,	-1,	10,	12),
1736	PINGROUP(extperiph2_clk_pp1,	EXTPERIPH2,	RSVD1,		RSVD2,		RSVD3,		0x0000,		0,	Y,	-1,	7,	6,	8,	-1,	10,	12),
1737	PINGROUP(extperiph1_clk_pp0,	EXTPERIPH1,	RSVD1,		RSVD2,		RSVD3,		0x0008,		0,	Y,	-1,	7,	6,	8,	-1,	10,	12),
1738	PINGROUP(cam_i2c_sda_pp3,	I2C3,		VI0,		RSVD2,		VI1,		0x0010,		0,	Y,	5,	7,	6,	8,	-1,	10,	12),
1739	PINGROUP(cam_i2c_scl_pp2,	I2C3,		VI0,		VI0_ALT,	VI1,		0x0018,		0,	Y,	5,	7,	6,	8,	-1,	10,	12),
1740	PINGROUP(soc_gpio23_pp4,	VI0,		VI0_ALT,	VI1,		VI1_ALT,	0x0020,		0,	Y,	5,	7,	6,	8,	-1,	10,	12),
1741	PINGROUP(soc_gpio24_pp5,	VI0,		SOC,		VI1,		VI1_ALT,	0x0028,		0,	Y,	5,	7,	6,	8,	-1,	10,	12),
1742	PINGROUP(soc_gpio25_pp6,	VI0,		I2S5,		VI1,		DMIC1,		0x0030,		0,	Y,	5,	7,	6,	8,	-1,	10,	12),
1743	PINGROUP(pwr_i2c_scl_pp7,	I2C5,		RSVD1,		RSVD2,		RSVD3,		0x0038,		0,	Y,	5,	7,	6,	8,	-1,	10,	12),
1744	PINGROUP(pwr_i2c_sda_pq0,	I2C5,		RSVD1,		RSVD2,		RSVD3,		0x0040,		0,	Y,	5,	7,	6,	8,	-1,	10,	12),
1745	PINGROUP(soc_gpio28_pq1,	VI0,		RSVD1,		VI1,		RSVD3,		0x0048,		0,	Y,	5,	7,	6,	8,	-1,	10,	12),
1746	PINGROUP(soc_gpio29_pq2,	RSVD0,		NV,		RSVD2,		RSVD3,		0x0050,		0,	Y,	5,	7,	6,	8,	-1,	10,	12),
1747	PINGROUP(soc_gpio30_pq3,	RSVD0,		WDT,		RSVD2,		RSVD3,		0x0058,		0,	Y,	5,	7,	6,	8,	-1,	10,	12),
1748	PINGROUP(soc_gpio31_pq4,	RSVD0,		RSVD1,		RSVD2,		RSVD3,		0x0060,		0,	Y,	5,	7,	6,	8,	-1,	10,	12),
1749	PINGROUP(soc_gpio32_pq5,	RSVD0,		EXTPERIPH3,	DCB,		RSVD3,		0x0068,		0,	Y,	5,	7,	6,	8,	-1,	10,	12),
1750	PINGROUP(soc_gpio33_pq6,	RSVD0,		EXTPERIPH4,	DCB,		RSVD3,		0x0070,		0,	Y,	5,	7,	6,	8,	-1,	10,	12),
1751	PINGROUP(soc_gpio35_pq7,	RSVD0,		I2S5,		DMIC1,		RSVD3,		0x0078,		0,	Y,	5,	7,	6,	8,	-1,	10,	12),
1752	PINGROUP(soc_gpio37_pr0,	GP,		I2S5,		DMIC4,		DSPK1,		0x0080,		0,	Y,	5,	7,	6,	8,	-1,	10,	12),
1753	PINGROUP(soc_gpio56_pr1,	RSVD0,		I2S5,		DMIC4,		DSPK1,		0x0088,		0,	Y,	5,	7,	6,	8,	-1,	10,	12),
1754	PINGROUP(uart1_cts_pr5,		UARTA,		RSVD1,		RSVD2,		RSVD3,		0x0090,		0,	Y,	-1,	7,	6,	8,	-1,	10,	12),
1755	PINGROUP(uart1_rts_pr4,		UARTA,		RSVD1,		RSVD2,		RSVD3,		0x0098,		0,	Y,	-1,	7,	6,	8,	-1,	10,	12),
1756	PINGROUP(uart1_rx_pr3,		UARTA,		RSVD1,		RSVD2,		RSVD3,		0x00A0,		0,	Y,	-1,	7,	6,	8,	-1,	10,	12),
1757	PINGROUP(uart1_tx_pr2,		UARTA,		RSVD1,		RSVD2,		RSVD3,		0x00A8,		0,	Y,	-1,	7,	6,	8,	-1,	10,	12),
1758	PINGROUP(cpu_pwr_req_pi5,	RSVD0,		RSVD1,		RSVD2,		RSVD3,		0x4000,		0,	Y,	-1,	7,	6,	8,	-1,	10,	12),
1759	PINGROUP(uart4_cts_ph6,		UARTD,		RSVD1,		I2S7,		RSVD3,		0x4008,		0,	Y,	-1,	7,	6,	8,	-1,	10,	12),
1760	PINGROUP(uart4_rts_ph5,		UARTD,		SPI4,		RSVD2,		RSVD3,		0x4010,		0,	Y,	-1,	7,	6,	8,	-1,	10,	12),
1761	PINGROUP(uart4_rx_ph4,		UARTD,		RSVD1,		I2S7,		RSVD3,		0x4018,		0,	Y,	-1,	7,	6,	8,	-1,	10,	12),
1762	PINGROUP(uart4_tx_ph3,		UARTD,		SPI4,		RSVD2,		RSVD3,		0x4020,		0,	Y,	-1,	7,	6,	8,	-1,	10,	12),
1763	PINGROUP(gen1_i2c_scl_pi3,	I2C1,		RSVD1,		RSVD2,		RSVD3,		0x4028,		0,	Y,	5,	7,	6,	8,	-1,	10,	12),
1764	PINGROUP(gen1_i2c_sda_pi4,	I2C1,		RSVD1,		RSVD2,		RSVD3,		0x4030,		0,	Y,	5,	7,	6,	8,	-1,	10,	12),
1765	PINGROUP(soc_gpio20_pg7,	RSVD0,		SDMMC1,		RSVD2,		RSVD3,		0x4038,		0,	Y,	-1,	7,	6,	8,	-1,	10,	12),
1766	PINGROUP(soc_gpio21_ph0,	RSVD0,		GP,		I2S7,		RSVD3,		0x4040,		0,	Y,	-1,	7,	6,	8,	-1,	10,	12),
1767	PINGROUP(soc_gpio22_ph1,	RSVD0,		RSVD1,		I2S7,		RSVD3,		0x4048,		0,	Y,	-1,	7,	6,	8,	-1,	10,	12),
1768	PINGROUP(soc_gpio13_pg0,	RSVD0,		RSVD1,		RSVD2,		RSVD3,		0x4050,		0,	Y,	-1,	7,	6,	8,	-1,	10,	12),
1769	PINGROUP(soc_gpio14_pg1,	RSVD0,		SPI4,		RSVD2,		RSVD3,		0x4058,		0,	Y,	-1,	7,	6,	8,	-1,	10,	12),
1770	PINGROUP(soc_gpio15_pg2,	RSVD0,		SPI4,		RSVD2,		RSVD3,		0x4060,		0,	Y,	-1,	7,	6,	8,	-1,	10,	12),
1771	PINGROUP(soc_gpio16_pg3,	RSVD0,		SPI4,		RSVD2,		RSVD3,		0x4068,		0,	Y,	-1,	7,	6,	8,	-1,	10,	12),
1772	PINGROUP(soc_gpio17_pg4,	RSVD0,		CCLA,		RSVD2,		RSVD3,		0x4070,		0,	Y,	-1,	7,	6,	8,	-1,	10,	12),
1773	PINGROUP(soc_gpio18_pg5,	RSVD0,		RSVD1,		RSVD2,		RSVD3,		0x4078,		0,	Y,	-1,	7,	6,	8,	-1,	10,	12),
1774	PINGROUP(soc_gpio19_pg6,	GP,		RSVD1,		RSVD2,		RSVD3,		0x4080,		0,	Y,	-1,	7,	6,	8,	-1,	10,	12),
1775	PINGROUP(soc_gpio41_ph7,	RSVD0,		I2S2,		RSVD2,		RSVD3,		0x4088,		0,	Y,	-1,	7,	6,	8,	-1,	10,	12),
1776	PINGROUP(soc_gpio42_pi0,	RSVD0,		I2S2,		RSVD2,		RSVD3,		0x4090,		0,	Y,	-1,	7,	6,	8,	-1,	10,	12),
1777	PINGROUP(soc_gpio43_pi1,	RSVD0,		I2S2,		RSVD2,		RSVD3,		0x4098,		0,	Y,	-1,	7,	6,	8,	-1,	10,	12),
1778	PINGROUP(soc_gpio44_pi2,	RSVD0,		I2S2,		RSVD2,		RSVD3,		0x40A0,		0,	Y,	-1,	7,	6,	8,	-1,	10,	12),
1779	PINGROUP(soc_gpio06_ph2,	RSVD0,		RSVD1,		RSVD2,		RSVD3,		0x40A8,		0,	Y,	-1,	7,	6,	8,	-1,	10,	12),
1780	PINGROUP(soc_gpio07_pi6,	GP,		RSVD1,		RSVD2,		RSVD3,		0x40B0,		0,	Y,	-1,	7,	6,	8,	-1,	10,	12),
1781	PINGROUP(dap4_sclk_pa4,		I2S4,		RSVD1,		RSVD2,		RSVD3,		0x2000,		0,	Y,	-1,	7,	6,	8,	-1,	10,	12),
1782	PINGROUP(dap4_dout_pa5,		I2S4,		RSVD1,		RSVD2,		RSVD3,		0x2008,		0,	Y,	-1,	7,	6,	8,	-1,	10,	12),
1783	PINGROUP(dap4_din_pa6,		I2S4,		RSVD1,		RSVD2,		RSVD3,		0x2010,		0,	Y,	-1,	7,	6,	8,	-1,	10,	12),
1784	PINGROUP(dap4_fs_pa7,		I2S4,		RSVD1,		RSVD2,		RSVD3,		0x2018,		0,	Y,	-1,	7,	6,	8,	-1,	10,	12),
1785	PINGROUP(dap6_sclk_pa0,		I2S6,		RSVD1,		RSVD2,		RSVD3,		0x2020,		0,	Y,	-1,	7,	6,	8,	-1,	10,	12),
1786	PINGROUP(dap6_dout_pa1,		I2S6,		RSVD1,		RSVD2,		RSVD3,		0x2028,		0,	Y,	-1,	7,	6,	8,	-1,	10,	12),
1787	PINGROUP(dap6_din_pa2,		I2S6,		RSVD1,		RSVD2,		RSVD3,		0x2030,		0,	Y,	-1,	7,	6,	8,	-1,	10,	12),
1788	PINGROUP(dap6_fs_pa3,		I2S6,		RSVD1,		RSVD2,		RSVD3,		0x2038,		0,	Y,	-1,	7,	6,	8,	-1,	10,	12),
1789	PINGROUP(soc_gpio45_pad0,	RSVD0,		I2S1,		RSVD2,		RSVD3,		0x18000,	0,	Y,	-1,	7,	6,	8,	-1,	10,	12),
1790	PINGROUP(soc_gpio46_pad1,	RSVD0,		I2S1,		RSVD2,		RSVD3,		0x18008,	0,	Y,	-1,	7,	6,	8,	-1,	10,	12),
1791	PINGROUP(soc_gpio47_pad2,	RSVD0,		I2S1,		RSVD2,		RSVD3,		0x18010,	0,	Y,	-1,	7,	6,	8,	-1,	10,	12),
1792	PINGROUP(soc_gpio48_pad3,	RSVD0,		I2S1,		RSVD2,		RSVD3,		0x18018,	0,	Y,	-1,	7,	6,	8,	-1,	10,	12),
1793	PINGROUP(soc_gpio57_pac4,	RSVD0,		I2S8,		RSVD2,		SDMMC1,		0x18020,	0,	Y,	-1,	7,	6,	8,	-1,	10,	12),
1794	PINGROUP(soc_gpio58_pac5,	RSVD0,		I2S8,		RSVD2,		SDMMC1,		0x18028,	0,	Y,	-1,	7,	6,	8,	-1,	10,	12),
1795	PINGROUP(soc_gpio59_pac6,	AUD,		I2S8,		RSVD2,		RSVD3,		0x18030,	0,	Y,	-1,	7,	6,	8,	-1,	10,	12),
1796	PINGROUP(soc_gpio60_pac7,	RSVD0,		I2S8,		NV,		IGPU,		0x18038,	0,	Y,	-1,	7,	6,	8,	-1,	10,	12),
1797	PINGROUP(spi5_cs0_pac3,		SPI5,		I2S3,		DMIC2,		RSVD3,		0x18040,	0,	Y,	-1,	7,	6,	8,	-1,	10,	12),
1798	PINGROUP(spi5_miso_pac1,	SPI5,		I2S3,		DSPK0,		RSVD3,		0x18048,	0,	Y,	-1,	7,	6,	8,	-1,	10,	12),
1799	PINGROUP(spi5_mosi_pac2,	SPI5,		I2S3,		DMIC2,		RSVD3,		0x18050,	0,	Y,	-1,	7,	6,	8,	-1,	10,	12),
1800	PINGROUP(spi5_sck_pac0,		SPI5,		I2S3,		DSPK0,		RSVD3,		0x18058,	0,	Y,	-1,	7,	6,	8,	-1,	10,	12),
1801
1802};
1803
1804static const struct tegra_pinctrl_soc_data tegra234_pinctrl = {
1805	.pins = tegra234_pins,
1806	.npins = ARRAY_SIZE(tegra234_pins),
1807	.functions = tegra234_functions,
1808	.nfunctions = ARRAY_SIZE(tegra234_functions),
1809	.groups = tegra234_groups,
1810	.ngroups = ARRAY_SIZE(tegra234_groups),
1811	.hsm_in_mux = false,
1812	.schmitt_in_mux = true,
1813	.drvtype_in_mux = true,
1814	.sfsel_in_mux = true,
1815};
1816
1817static const struct pinctrl_pin_desc tegra234_aon_pins[] = {
1818	PINCTRL_PIN(TEGRA_PIN_CAN0_DOUT_PAA0, "CAN0_DOUT_PAA0"),
1819	PINCTRL_PIN(TEGRA_PIN_CAN0_DIN_PAA1, "CAN0_DIN_PAA1"),
1820	PINCTRL_PIN(TEGRA_PIN_CAN1_DOUT_PAA2, "CAN1_DOUT_PAA2"),
1821	PINCTRL_PIN(TEGRA_PIN_CAN1_DIN_PAA3, "CAN1_DIN_PAA3"),
1822	PINCTRL_PIN(TEGRA_PIN_CAN0_STB_PAA4, "CAN0_STB_PAA4"),
1823	PINCTRL_PIN(TEGRA_PIN_CAN0_EN_PAA5, "CAN0_EN_PAA5"),
1824	PINCTRL_PIN(TEGRA_PIN_SOC_GPIO49_PAA6, "SOC_GPIO49_PAA6"),
1825	PINCTRL_PIN(TEGRA_PIN_CAN0_ERR_PAA7, "CAN0_ERR_PAA7"),
1826	PINCTRL_PIN(TEGRA_PIN_CAN1_STB_PBB0, "CAN1_STB_PBB0"),
1827	PINCTRL_PIN(TEGRA_PIN_CAN1_EN_PBB1, "CAN1_EN_PBB1"),
1828	PINCTRL_PIN(TEGRA_PIN_SOC_GPIO50_PBB2, "SOC_GPIO50_PBB2"),
1829	PINCTRL_PIN(TEGRA_PIN_CAN1_ERR_PBB3, "CAN1_ERR_PBB3"),
1830	PINCTRL_PIN(TEGRA_PIN_SPI2_SCK_PCC0, "SPI2_SCK_PCC0"),
1831	PINCTRL_PIN(TEGRA_PIN_SPI2_MISO_PCC1, "SPI2_MISO_PCC1"),
1832	PINCTRL_PIN(TEGRA_PIN_SPI2_MOSI_PCC2, "SPI2_MOSI_PCC2"),
1833	PINCTRL_PIN(TEGRA_PIN_SPI2_CS0_PCC3, "SPI2_CS0_PCC3"),
1834	PINCTRL_PIN(TEGRA_PIN_TOUCH_CLK_PCC4, "TOUCH_CLK_PCC4"),
1835	PINCTRL_PIN(TEGRA_PIN_UART3_TX_PCC5, "UART3_TX_PCC5"),
1836	PINCTRL_PIN(TEGRA_PIN_UART3_RX_PCC6, "UART3_RX_PCC6"),
1837	PINCTRL_PIN(TEGRA_PIN_GEN2_I2C_SCL_PCC7, "GEN2_I2C_SCL_PCC7"),
1838	PINCTRL_PIN(TEGRA_PIN_GEN2_I2C_SDA_PDD0, "GEN2_I2C_SDA_PDD0"),
1839	PINCTRL_PIN(TEGRA_PIN_GEN8_I2C_SCL_PDD1, "GEN8_I2C_SCL_PDD1"),
1840	PINCTRL_PIN(TEGRA_PIN_GEN8_I2C_SDA_PDD2, "GEN8_I2C_SDA_PDD2"),
1841	PINCTRL_PIN(TEGRA_PIN_SCE_ERROR_PEE0, "SCE_ERROR_PEE0"),
1842	PINCTRL_PIN(TEGRA_PIN_VCOMP_ALERT_PEE1, "VCOMP_ALERT_PEE1"),
1843	PINCTRL_PIN(TEGRA_PIN_AO_RETENTION_N_PEE2, "AO_RETENTION_N_PEE2"),
1844	PINCTRL_PIN(TEGRA_PIN_BATT_OC_PEE3, "BATT_OC_PEE3"),
1845	PINCTRL_PIN(TEGRA_PIN_POWER_ON_PEE4, "POWER_ON_PEE4"),
1846	PINCTRL_PIN(TEGRA_PIN_SOC_GPIO26_PEE5, "SOC_GPIO26_PEE5"),
1847	PINCTRL_PIN(TEGRA_PIN_SOC_GPIO27_PEE6, "SOC_GPIO27_PEE6"),
1848	PINCTRL_PIN(TEGRA_PIN_BOOTV_CTL_N_PEE7, "BOOTV_CTL_N_PEE7"),
1849	PINCTRL_PIN(TEGRA_PIN_HDMI_CEC_PGG0, "HDMI_CEC_PGG0"),
1850};
1851
1852/* AON drive pin groups */
1853#define	drive_touch_clk_pcc4			DRV_PINGROUP_ENTRY_Y(0x2004,	12,	5,	20,	5,	-1,	-1,	-1,	-1,	0)
1854#define	drive_uart3_rx_pcc6			DRV_PINGROUP_ENTRY_Y(0x200c,	12,	5,	20,	5,	-1,	-1,	-1,	-1,	0)
1855#define	drive_uart3_tx_pcc5			DRV_PINGROUP_ENTRY_Y(0x2014,	12,	5,	20,	5,	-1,	-1,	-1,	-1,	0)
1856#define	drive_gen8_i2c_sda_pdd2			DRV_PINGROUP_ENTRY_Y(0x201c,	12,	5,	20,	5,	-1,	-1,	-1,	-1,	0)
1857#define	drive_gen8_i2c_scl_pdd1			DRV_PINGROUP_ENTRY_Y(0x2024,	12,	5,	20,	5,	-1,	-1,	-1,	-1,	0)
1858#define	drive_spi2_mosi_pcc2			DRV_PINGROUP_ENTRY_Y(0x202c,	12,	5,	20,	5,	-1,	-1,	-1,	-1,	0)
1859#define	drive_gen2_i2c_scl_pcc7			DRV_PINGROUP_ENTRY_Y(0x2034,	12,	5,	20,	5,	-1,	-1,	-1,	-1,	0)
1860#define	drive_spi2_cs0_pcc3			DRV_PINGROUP_ENTRY_Y(0x203c,	12,	5,	20,	5,	-1,	-1,	-1,	-1,	0)
1861#define	drive_gen2_i2c_sda_pdd0			DRV_PINGROUP_ENTRY_Y(0x2044,	12,	5,	20,	5,	-1,	-1,	-1,	-1,	0)
1862#define	drive_spi2_sck_pcc0			DRV_PINGROUP_ENTRY_Y(0x204c,	12,	5,	20,	5,	-1,	-1,	-1,	-1,	0)
1863#define	drive_spi2_miso_pcc1			DRV_PINGROUP_ENTRY_Y(0x2054,	12,	5,	20,	5,	-1,	-1,	-1,	-1,	0)
1864#define	drive_can1_dout_paa2			DRV_PINGROUP_ENTRY_Y(0x3004,	28,	2,	30,	2,	-1,	-1,	-1,	-1,	0)
1865#define	drive_can1_din_paa3			DRV_PINGROUP_ENTRY_Y(0x300c,	28,	2,	30,	2,	-1,	-1,	-1,	-1,	0)
1866#define	drive_can0_dout_paa0			DRV_PINGROUP_ENTRY_Y(0x3014,	28,	2,	30,	2,	-1,	-1,	-1,	-1,	0)
1867#define	drive_can0_din_paa1			DRV_PINGROUP_ENTRY_Y(0x301c,	28,	2,	30,	2,	-1,	-1,	-1,	-1,	0)
1868#define	drive_can0_stb_paa4			DRV_PINGROUP_ENTRY_Y(0x3024,	28,	2,	30,	2,	-1,	-1,	-1,	-1,	0)
1869#define	drive_can0_en_paa5			DRV_PINGROUP_ENTRY_Y(0x302c,	28,	2,	30,	2,	-1,	-1,	-1,	-1,	0)
1870#define	drive_soc_gpio49_paa6			DRV_PINGROUP_ENTRY_Y(0x3034,	28,	2,	30,	2,	-1,	-1,	-1,	-1,	0)
1871#define	drive_can0_err_paa7			DRV_PINGROUP_ENTRY_Y(0x303c,	28,	2,	30,	2,	-1,	-1,	-1,	-1,	0)
1872#define	drive_can1_stb_pbb0			DRV_PINGROUP_ENTRY_Y(0x3044,	28,	2,	30,	2,	-1,	-1,	-1,	-1,	0)
1873#define	drive_can1_en_pbb1			DRV_PINGROUP_ENTRY_Y(0x304c,	28,	2,	30,	2,	-1,	-1,	-1,	-1,	0)
1874#define	drive_soc_gpio50_pbb2			DRV_PINGROUP_ENTRY_Y(0x3054,	28,	2,	30,	2,	-1,	-1,	-1,	-1,	0)
1875#define	drive_can1_err_pbb3			DRV_PINGROUP_ENTRY_Y(0x305c,	28,	2,	30,	2,	-1,	-1,	-1,	-1,	0)
1876#define	drive_sce_error_pee0			DRV_PINGROUP_ENTRY_Y(0x1014,	12,	5,	20,	5,	-1,	-1,	-1,	-1,	0)
1877#define	drive_batt_oc_pee3			DRV_PINGROUP_ENTRY_Y(0x1024,	12,	5,	20,	5,	-1,	-1,	-1,	-1,	0)
1878#define	drive_bootv_ctl_n_pee7			DRV_PINGROUP_ENTRY_Y(0x102c,	12,	5,	20,	5,	-1,	-1,	-1,	-1,	0)
1879#define	drive_power_on_pee4			DRV_PINGROUP_ENTRY_Y(0x103c,	12,	5,	20,	5,	-1,	-1,	-1,	-1,	0)
1880#define	drive_soc_gpio26_pee5			DRV_PINGROUP_ENTRY_Y(0x1044,	12,	5,	20,	5,	-1,	-1,	-1,	-1,	0)
1881#define	drive_soc_gpio27_pee6			DRV_PINGROUP_ENTRY_Y(0x104c,	12,	5,	20,	5,	-1,	-1,	-1,	-1,	0)
1882#define	drive_ao_retention_n_pee2		DRV_PINGROUP_ENTRY_Y(0x1054,	12,	5,	20,	5,	-1,	-1,	-1,	-1,	0)
1883#define	drive_vcomp_alert_pee1			DRV_PINGROUP_ENTRY_Y(0x105c,	12,	5,	20,	5,	-1,	-1,	-1,	-1,	0)
1884#define	drive_hdmi_cec_pgg0			DRV_PINGROUP_ENTRY_Y(0x1064,	12,	5,	20,	5,	-1,	-1,	-1,	-1,	0)
1885
1886static const struct tegra_pingroup tegra234_aon_groups[] = {
1887	PINGROUP(touch_clk_pcc4,	GP,		TOUCH,		RSVD2,		RSVD3,		0x2000,		0,	Y,	5,	7,	6,	8,	-1,	10,	12),
1888	PINGROUP(uart3_rx_pcc6,		UARTC,		UARTJ,		RSVD2,		RSVD3,		0x2008,		0,	Y,	5,	7,	6,	8,	-1,	10,	12),
1889	PINGROUP(uart3_tx_pcc5,		UARTC,		UARTJ,		RSVD2,		RSVD3,		0x2010,		0,	Y,	5,	7,	6,	8,	-1,	10,	12),
1890	PINGROUP(gen8_i2c_sda_pdd2,	I2C8,		RSVD1,		RSVD2,		RSVD3,		0x2018,		0,	Y,	5,	7,	6,	8,	-1,	10,	12),
1891	PINGROUP(gen8_i2c_scl_pdd1,	I2C8,		RSVD1,		RSVD2,		RSVD3,		0x2020,		0,	Y,	5,	7,	6,	8,	-1,	10,	12),
1892	PINGROUP(spi2_mosi_pcc2,	SPI2,		RSVD1,		RSVD2,		RSVD3,		0x2028,		0,	Y,	5,	7,	6,	8,	-1,	10,	12),
1893	PINGROUP(gen2_i2c_scl_pcc7,	I2C2,		RSVD1,		RSVD2,		RSVD3,		0x2030,		0,	Y,	5,	7,	6,	8,	-1,	10,	12),
1894	PINGROUP(spi2_cs0_pcc3,		SPI2,		RSVD1,		RSVD2,		RSVD3,		0x2038,		0,	Y,	5,	7,	6,	8,	-1,	10,	12),
1895	PINGROUP(gen2_i2c_sda_pdd0,	I2C2,		RSVD1,		RSVD2,		RSVD3,		0x2040,		0,	Y,	5,	7,	6,	8,	-1,	10,	12),
1896	PINGROUP(spi2_sck_pcc0,		SPI2,		RSVD1,		RSVD2,		RSVD3,		0x2048,		0,	Y,	5,	7,	6,	8,	-1,	10,	12),
1897	PINGROUP(spi2_miso_pcc1,	SPI2,		RSVD1,		RSVD2,		RSVD3,		0x2050,		0,	Y,	5,	7,	6,	8,	-1,	10,	12),
1898	PINGROUP(can1_dout_paa2,	CAN1,		RSVD1,		RSVD2,		RSVD3,		0x3000,		0,	Y,	-1,	5,	6,	-1,	9,	10,	12),
1899	PINGROUP(can1_din_paa3,		CAN1,		RSVD1,		RSVD2,		RSVD3,		0x3008,		0,	Y,	-1,	5,	6,	-1,	9,	10,	12),
1900	PINGROUP(can0_dout_paa0,	CAN0,		RSVD1,		RSVD2,		RSVD3,		0x3010,		0,	Y,	-1,	5,	6,	-1,	9,	10,	12),
1901	PINGROUP(can0_din_paa1,		CAN0,		RSVD1,		RSVD2,		RSVD3,		0x3018,		0,	Y,	-1,	5,	6,	-1,	9,	10,	12),
1902	PINGROUP(can0_stb_paa4,		RSVD0,		WDT,		TSC,		TSC_ALT,	0x3020,		0,	Y,	-1,	5,	6,	-1,	9,	10,	12),
1903	PINGROUP(can0_en_paa5,		RSVD0,		RSVD1,		RSVD2,		RSVD3,		0x3028,		0,	Y,	-1,	5,	6,	-1,	9,	10,	12),
1904	PINGROUP(soc_gpio49_paa6,	RSVD0,		RSVD1,		RSVD2,		RSVD3,		0x3030,		0,	Y,	-1,	5,	6,	-1,	9,	10,	12),
1905	PINGROUP(can0_err_paa7,		RSVD0,		TSC,		RSVD2,		TSC_ALT,	0x3038,		0,	Y,	-1,	5,	6,	-1,	9,	10,	12),
1906	PINGROUP(can1_stb_pbb0,		RSVD0,		DMIC3,		DMIC5,		RSVD3,		0x3040,		0,	Y,	-1,	5,	6,	-1,	9,	10,	12),
1907	PINGROUP(can1_en_pbb1,		RSVD0,		DMIC3,		DMIC5,		RSVD3,		0x3048,		0,	Y,	-1,	5,	6,	-1,	9,	10,	12),
1908	PINGROUP(soc_gpio50_pbb2,	RSVD0,		TSC,		RSVD2,		TSC_ALT,	0x3050,		0,	Y,	-1,	5,	6,	-1,	9,	10,	12),
1909	PINGROUP(can1_err_pbb3,		RSVD0,		TSC,		RSVD2,		TSC_ALT,	0x3058,		0,	Y,	-1,	5,	6,	-1,	9,	10,	12),
1910	PINGROUP(sce_error_pee0,	SCE,		RSVD1,		RSVD2,		RSVD3,		0x1010,		0,	Y,	5,	7,	6,	8,	-1,	10,	12),
1911	PINGROUP(batt_oc_pee3,		SOC,		RSVD1,		RSVD2,		RSVD3,		0x1020,		0,	Y,	5,	7,	6,	8,	-1,	10,	12),
1912	PINGROUP(bootv_ctl_n_pee7,	RSVD0,		RSVD1,		RSVD2,		RSVD3,		0x1028,		0,	Y,	-1,	7,	6,	8,	-1,	10,	12),
1913	PINGROUP(power_on_pee4,		RSVD0,		RSVD1,		RSVD2,		RSVD3,		0x1038,		0,	Y,	5,	7,	6,	8,	-1,	10,	12),
1914	PINGROUP(soc_gpio26_pee5,	RSVD0,		RSVD1,		RSVD2,		RSVD3,		0x1040,		0,	Y,	5,	7,	6,	8,	-1,	10,	12),
1915	PINGROUP(soc_gpio27_pee6,	RSVD0,		RSVD1,		RSVD2,		RSVD3,		0x1048,		0,	Y,	5,	7,	6,	8,	-1,	10,	12),
1916	PINGROUP(ao_retention_n_pee2,	GPIO,		LED,		RSVD2,		ISTCTRL,	0x1050,		0,	Y,	5,	7,	6,	8,	-1,	10,	12),
1917	PINGROUP(vcomp_alert_pee1,	SOC,		RSVD1,		RSVD2,		RSVD3,		0x1058,		0,	Y,	5,	7,	6,	8,	-1,	10,	12),
1918	PINGROUP(hdmi_cec_pgg0,		HDMI,		RSVD1,		RSVD2,		RSVD3,		0x1060,		0,	Y,	5,	7,	6,	8,	-1,	10,	12),
1919};
1920
1921static const struct tegra_pinctrl_soc_data tegra234_pinctrl_aon = {
1922	.pins = tegra234_aon_pins,
1923	.npins = ARRAY_SIZE(tegra234_aon_pins),
1924	.functions = tegra234_functions,
1925	.nfunctions = ARRAY_SIZE(tegra234_functions),
1926	.groups = tegra234_aon_groups,
1927	.ngroups = ARRAY_SIZE(tegra234_aon_groups),
1928	.hsm_in_mux = false,
1929	.schmitt_in_mux = true,
1930	.drvtype_in_mux = true,
1931	.sfsel_in_mux = true,
1932};
1933
1934static int tegra234_pinctrl_probe(struct platform_device *pdev)
1935{
1936	const struct tegra_pinctrl_soc_data *soc = device_get_match_data(&pdev->dev);
1937
1938	return tegra_pinctrl_probe(pdev, soc);
1939}
1940
1941static const struct of_device_id tegra234_pinctrl_of_match[] = {
1942	{ .compatible = "nvidia,tegra234-pinmux", .data = &tegra234_pinctrl},
1943	{ .compatible = "nvidia,tegra234-pinmux-aon", .data = &tegra234_pinctrl_aon },
1944	{ }
1945};
1946MODULE_DEVICE_TABLE(of, tegra234_pinctrl_of_match);
1947
1948static struct platform_driver tegra234_pinctrl_driver = {
1949	.driver = {
1950		.name = "tegra234-pinctrl",
1951		.of_match_table = tegra234_pinctrl_of_match,
1952	},
1953	.probe = tegra234_pinctrl_probe,
1954};
1955
1956static int __init tegra234_pinctrl_init(void)
1957{
1958	return platform_driver_register(&tegra234_pinctrl_driver);
1959}
1960arch_initcall(tegra234_pinctrl_init);
v6.8
   1// SPDX-License-Identifier: GPL-2.0+
   2/*
   3 * Pinctrl data for the NVIDIA Tegra234 pinmux
   4 *
   5 * Copyright (c) 2021-2023, NVIDIA CORPORATION.  All rights reserved.
   6 */
   7
   8#include <linux/mod_devicetable.h>
   9#include <linux/module.h>
  10#include <linux/platform_device.h>
  11#include <linux/property.h>
  12
  13#include <linux/pinctrl/pinctrl.h>
  14#include <linux/pinctrl/pinmux.h>
  15
  16#include "pinctrl-tegra.h"
  17
  18/* Define unique ID for each pins */
  19enum {
  20	TEGRA_PIN_DAP6_SCLK_PA0,
  21	TEGRA_PIN_DAP6_DOUT_PA1,
  22	TEGRA_PIN_DAP6_DIN_PA2,
  23	TEGRA_PIN_DAP6_FS_PA3,
  24	TEGRA_PIN_DAP4_SCLK_PA4,
  25	TEGRA_PIN_DAP4_DOUT_PA5,
  26	TEGRA_PIN_DAP4_DIN_PA6,
  27	TEGRA_PIN_DAP4_FS_PA7,
  28	TEGRA_PIN_SOC_GPIO08_PB0,
  29	TEGRA_PIN_QSPI0_SCK_PC0,
  30	TEGRA_PIN_QSPI0_CS_N_PC1,
  31	TEGRA_PIN_QSPI0_IO0_PC2,
  32	TEGRA_PIN_QSPI0_IO1_PC3,
  33	TEGRA_PIN_QSPI0_IO2_PC4,
  34	TEGRA_PIN_QSPI0_IO3_PC5,
  35	TEGRA_PIN_QSPI1_SCK_PC6,
  36	TEGRA_PIN_QSPI1_CS_N_PC7,
  37	TEGRA_PIN_QSPI1_IO0_PD0,
  38	TEGRA_PIN_QSPI1_IO1_PD1,
  39	TEGRA_PIN_QSPI1_IO2_PD2,
  40	TEGRA_PIN_QSPI1_IO3_PD3,
  41	TEGRA_PIN_EQOS_TXC_PE0,
  42	TEGRA_PIN_EQOS_TD0_PE1,
  43	TEGRA_PIN_EQOS_TD1_PE2,
  44	TEGRA_PIN_EQOS_TD2_PE3,
  45	TEGRA_PIN_EQOS_TD3_PE4,
  46	TEGRA_PIN_EQOS_TX_CTL_PE5,
  47	TEGRA_PIN_EQOS_RD0_PE6,
  48	TEGRA_PIN_EQOS_RD1_PE7,
  49	TEGRA_PIN_EQOS_RD2_PF0,
  50	TEGRA_PIN_EQOS_RD3_PF1,
  51	TEGRA_PIN_EQOS_RX_CTL_PF2,
  52	TEGRA_PIN_EQOS_RXC_PF3,
  53	TEGRA_PIN_EQOS_SMA_MDIO_PF4,
  54	TEGRA_PIN_EQOS_SMA_MDC_PF5,
  55	TEGRA_PIN_SOC_GPIO13_PG0,
  56	TEGRA_PIN_SOC_GPIO14_PG1,
  57	TEGRA_PIN_SOC_GPIO15_PG2,
  58	TEGRA_PIN_SOC_GPIO16_PG3,
  59	TEGRA_PIN_SOC_GPIO17_PG4,
  60	TEGRA_PIN_SOC_GPIO18_PG5,
  61	TEGRA_PIN_SOC_GPIO19_PG6,
  62	TEGRA_PIN_SOC_GPIO20_PG7,
  63	TEGRA_PIN_SOC_GPIO21_PH0,
  64	TEGRA_PIN_SOC_GPIO22_PH1,
  65	TEGRA_PIN_SOC_GPIO06_PH2,
  66	TEGRA_PIN_UART4_TX_PH3,
  67	TEGRA_PIN_UART4_RX_PH4,
  68	TEGRA_PIN_UART4_RTS_PH5,
  69	TEGRA_PIN_UART4_CTS_PH6,
  70	TEGRA_PIN_SOC_GPIO41_PH7,
  71	TEGRA_PIN_SOC_GPIO42_PI0,
  72	TEGRA_PIN_SOC_GPIO43_PI1,
  73	TEGRA_PIN_SOC_GPIO44_PI2,
  74	TEGRA_PIN_GEN1_I2C_SCL_PI3,
  75	TEGRA_PIN_GEN1_I2C_SDA_PI4,
  76	TEGRA_PIN_CPU_PWR_REQ_PI5,
  77	TEGRA_PIN_SOC_GPIO07_PI6,
  78	TEGRA_PIN_SDMMC1_CLK_PJ0,
  79	TEGRA_PIN_SDMMC1_CMD_PJ1,
  80	TEGRA_PIN_SDMMC1_DAT0_PJ2,
  81	TEGRA_PIN_SDMMC1_DAT1_PJ3,
  82	TEGRA_PIN_SDMMC1_DAT2_PJ4,
  83	TEGRA_PIN_SDMMC1_DAT3_PJ5,
  84	TEGRA_PIN_PEX_L0_CLKREQ_N_PK0,
  85	TEGRA_PIN_PEX_L0_RST_N_PK1,
  86	TEGRA_PIN_PEX_L1_CLKREQ_N_PK2,
  87	TEGRA_PIN_PEX_L1_RST_N_PK3,
  88	TEGRA_PIN_PEX_L2_CLKREQ_N_PK4,
  89	TEGRA_PIN_PEX_L2_RST_N_PK5,
  90	TEGRA_PIN_PEX_L3_CLKREQ_N_PK6,
  91	TEGRA_PIN_PEX_L3_RST_N_PK7,
  92	TEGRA_PIN_PEX_L4_CLKREQ_N_PL0,
  93	TEGRA_PIN_PEX_L4_RST_N_PL1,
  94	TEGRA_PIN_PEX_WAKE_N_PL2,
  95	TEGRA_PIN_SOC_GPIO34_PL3,
  96	TEGRA_PIN_DP_AUX_CH0_HPD_PM0,
  97	TEGRA_PIN_DP_AUX_CH1_HPD_PM1,
  98	TEGRA_PIN_DP_AUX_CH2_HPD_PM2,
  99	TEGRA_PIN_DP_AUX_CH3_HPD_PM3,
 100	TEGRA_PIN_SOC_GPIO55_PM4,
 101	TEGRA_PIN_SOC_GPIO36_PM5,
 102	TEGRA_PIN_SOC_GPIO53_PM6,
 103	TEGRA_PIN_SOC_GPIO38_PM7,
 104	TEGRA_PIN_DP_AUX_CH3_N_PN0,
 105	TEGRA_PIN_SOC_GPIO39_PN1,
 106	TEGRA_PIN_SOC_GPIO40_PN2,
 107	TEGRA_PIN_DP_AUX_CH1_P_PN3,
 108	TEGRA_PIN_DP_AUX_CH1_N_PN4,
 109	TEGRA_PIN_DP_AUX_CH2_P_PN5,
 110	TEGRA_PIN_DP_AUX_CH2_N_PN6,
 111	TEGRA_PIN_DP_AUX_CH3_P_PN7,
 112	TEGRA_PIN_EXTPERIPH1_CLK_PP0,
 113	TEGRA_PIN_EXTPERIPH2_CLK_PP1,
 114	TEGRA_PIN_CAM_I2C_SCL_PP2,
 115	TEGRA_PIN_CAM_I2C_SDA_PP3,
 116	TEGRA_PIN_SOC_GPIO23_PP4,
 117	TEGRA_PIN_SOC_GPIO24_PP5,
 118	TEGRA_PIN_SOC_GPIO25_PP6,
 119	TEGRA_PIN_PWR_I2C_SCL_PP7,
 120	TEGRA_PIN_PWR_I2C_SDA_PQ0,
 121	TEGRA_PIN_SOC_GPIO28_PQ1,
 122	TEGRA_PIN_SOC_GPIO29_PQ2,
 123	TEGRA_PIN_SOC_GPIO30_PQ3,
 124	TEGRA_PIN_SOC_GPIO31_PQ4,
 125	TEGRA_PIN_SOC_GPIO32_PQ5,
 126	TEGRA_PIN_SOC_GPIO33_PQ6,
 127	TEGRA_PIN_SOC_GPIO35_PQ7,
 128	TEGRA_PIN_SOC_GPIO37_PR0,
 129	TEGRA_PIN_SOC_GPIO56_PR1,
 130	TEGRA_PIN_UART1_TX_PR2,
 131	TEGRA_PIN_UART1_RX_PR3,
 132	TEGRA_PIN_UART1_RTS_PR4,
 133	TEGRA_PIN_UART1_CTS_PR5,
 134	TEGRA_PIN_GPU_PWR_REQ_PX0,
 135	TEGRA_PIN_CV_PWR_REQ_PX1,
 136	TEGRA_PIN_GP_PWM2_PX2,
 137	TEGRA_PIN_GP_PWM3_PX3,
 138	TEGRA_PIN_UART2_TX_PX4,
 139	TEGRA_PIN_UART2_RX_PX5,
 140	TEGRA_PIN_UART2_RTS_PX6,
 141	TEGRA_PIN_UART2_CTS_PX7,
 142	TEGRA_PIN_SPI3_SCK_PY0,
 143	TEGRA_PIN_SPI3_MISO_PY1,
 144	TEGRA_PIN_SPI3_MOSI_PY2,
 145	TEGRA_PIN_SPI3_CS0_PY3,
 146	TEGRA_PIN_SPI3_CS1_PY4,
 147	TEGRA_PIN_UART5_TX_PY5,
 148	TEGRA_PIN_UART5_RX_PY6,
 149	TEGRA_PIN_UART5_RTS_PY7,
 150	TEGRA_PIN_UART5_CTS_PZ0,
 151	TEGRA_PIN_USB_VBUS_EN0_PZ1,
 152	TEGRA_PIN_USB_VBUS_EN1_PZ2,
 153	TEGRA_PIN_SPI1_SCK_PZ3,
 154	TEGRA_PIN_SPI1_MISO_PZ4,
 155	TEGRA_PIN_SPI1_MOSI_PZ5,
 156	TEGRA_PIN_SPI1_CS0_PZ6,
 157	TEGRA_PIN_SPI1_CS1_PZ7,
 158	TEGRA_PIN_SPI5_SCK_PAC0,
 159	TEGRA_PIN_SPI5_MISO_PAC1,
 160	TEGRA_PIN_SPI5_MOSI_PAC2,
 161	TEGRA_PIN_SPI5_CS0_PAC3,
 162	TEGRA_PIN_SOC_GPIO57_PAC4,
 163	TEGRA_PIN_SOC_GPIO58_PAC5,
 164	TEGRA_PIN_SOC_GPIO59_PAC6,
 165	TEGRA_PIN_SOC_GPIO60_PAC7,
 166	TEGRA_PIN_SOC_GPIO45_PAD0,
 167	TEGRA_PIN_SOC_GPIO46_PAD1,
 168	TEGRA_PIN_SOC_GPIO47_PAD2,
 169	TEGRA_PIN_SOC_GPIO48_PAD3,
 170	TEGRA_PIN_UFS0_REF_CLK_PAE0,
 171	TEGRA_PIN_UFS0_RST_N_PAE1,
 172	TEGRA_PIN_PEX_L5_CLKREQ_N_PAF0,
 173	TEGRA_PIN_PEX_L5_RST_N_PAF1,
 174	TEGRA_PIN_PEX_L6_CLKREQ_N_PAF2,
 175	TEGRA_PIN_PEX_L6_RST_N_PAF3,
 176	TEGRA_PIN_PEX_L7_CLKREQ_N_PAG0,
 177	TEGRA_PIN_PEX_L7_RST_N_PAG1,
 178	TEGRA_PIN_PEX_L8_CLKREQ_N_PAG2,
 179	TEGRA_PIN_PEX_L8_RST_N_PAG3,
 180	TEGRA_PIN_PEX_L9_CLKREQ_N_PAG4,
 181	TEGRA_PIN_PEX_L9_RST_N_PAG5,
 182	TEGRA_PIN_PEX_L10_CLKREQ_N_PAG6,
 183	TEGRA_PIN_PEX_L10_RST_N_PAG7,
 184	TEGRA_PIN_EQOS_COMP,
 185	TEGRA_PIN_QSPI_COMP,
 186	TEGRA_PIN_SDMMC1_COMP,
 187};
 188
 189enum {
 190	TEGRA_PIN_CAN0_DOUT_PAA0,
 191	TEGRA_PIN_CAN0_DIN_PAA1,
 192	TEGRA_PIN_CAN1_DOUT_PAA2,
 193	TEGRA_PIN_CAN1_DIN_PAA3,
 194	TEGRA_PIN_CAN0_STB_PAA4,
 195	TEGRA_PIN_CAN0_EN_PAA5,
 196	TEGRA_PIN_SOC_GPIO49_PAA6,
 197	TEGRA_PIN_CAN0_ERR_PAA7,
 198	TEGRA_PIN_CAN1_STB_PBB0,
 199	TEGRA_PIN_CAN1_EN_PBB1,
 200	TEGRA_PIN_SOC_GPIO50_PBB2,
 201	TEGRA_PIN_CAN1_ERR_PBB3,
 202	TEGRA_PIN_SPI2_SCK_PCC0,
 203	TEGRA_PIN_SPI2_MISO_PCC1,
 204	TEGRA_PIN_SPI2_MOSI_PCC2,
 205	TEGRA_PIN_SPI2_CS0_PCC3,
 206	TEGRA_PIN_TOUCH_CLK_PCC4,
 207	TEGRA_PIN_UART3_TX_PCC5,
 208	TEGRA_PIN_UART3_RX_PCC6,
 209	TEGRA_PIN_GEN2_I2C_SCL_PCC7,
 210	TEGRA_PIN_GEN2_I2C_SDA_PDD0,
 211	TEGRA_PIN_GEN8_I2C_SCL_PDD1,
 212	TEGRA_PIN_GEN8_I2C_SDA_PDD2,
 213	TEGRA_PIN_SCE_ERROR_PEE0,
 214	TEGRA_PIN_VCOMP_ALERT_PEE1,
 215	TEGRA_PIN_AO_RETENTION_N_PEE2,
 216	TEGRA_PIN_BATT_OC_PEE3,
 217	TEGRA_PIN_POWER_ON_PEE4,
 218	TEGRA_PIN_SOC_GPIO26_PEE5,
 219	TEGRA_PIN_SOC_GPIO27_PEE6,
 220	TEGRA_PIN_BOOTV_CTL_N_PEE7,
 221	TEGRA_PIN_HDMI_CEC_PGG0,
 222};
 223
 224/* Table for pin descriptor */
 225static const struct pinctrl_pin_desc tegra234_pins[] = {
 226	PINCTRL_PIN(TEGRA_PIN_DAP6_SCLK_PA0, "DAP6_SCLK_PA0"),
 227	PINCTRL_PIN(TEGRA_PIN_DAP6_DOUT_PA1, "DAP6_DOUT_PA1"),
 228	PINCTRL_PIN(TEGRA_PIN_DAP6_DIN_PA2, "DAP6_DIN_PA2"),
 229	PINCTRL_PIN(TEGRA_PIN_DAP6_FS_PA3, "DAP6_FS_PA3"),
 230	PINCTRL_PIN(TEGRA_PIN_DAP4_SCLK_PA4, "DAP4_SCLK_PA4"),
 231	PINCTRL_PIN(TEGRA_PIN_DAP4_DOUT_PA5, "DAP4_DOUT_PA5"),
 232	PINCTRL_PIN(TEGRA_PIN_DAP4_DIN_PA6, "DAP4_DIN_PA6"),
 233	PINCTRL_PIN(TEGRA_PIN_DAP4_FS_PA7, "DAP4_FS_PA7"),
 234	PINCTRL_PIN(TEGRA_PIN_SOC_GPIO08_PB0, "SOC_GPIO08_PB0"),
 235	PINCTRL_PIN(TEGRA_PIN_QSPI0_SCK_PC0, "QSPI0_SCK_PC0"),
 236	PINCTRL_PIN(TEGRA_PIN_QSPI0_CS_N_PC1, "QSPI0_CS_N_PC1"),
 237	PINCTRL_PIN(TEGRA_PIN_QSPI0_IO0_PC2, "QSPI0_IO0_PC2"),
 238	PINCTRL_PIN(TEGRA_PIN_QSPI0_IO1_PC3, "QSPI0_IO1_PC3"),
 239	PINCTRL_PIN(TEGRA_PIN_QSPI0_IO2_PC4, "QSPI0_IO2_PC4"),
 240	PINCTRL_PIN(TEGRA_PIN_QSPI0_IO3_PC5, "QSPI0_IO3_PC5"),
 241	PINCTRL_PIN(TEGRA_PIN_QSPI1_SCK_PC6, "QSPI1_SCK_PC6"),
 242	PINCTRL_PIN(TEGRA_PIN_QSPI1_CS_N_PC7, "QSPI1_CS_N_PC7"),
 243	PINCTRL_PIN(TEGRA_PIN_QSPI1_IO0_PD0, "QSPI1_IO0_PD0"),
 244	PINCTRL_PIN(TEGRA_PIN_QSPI1_IO1_PD1, "QSPI1_IO1_PD1"),
 245	PINCTRL_PIN(TEGRA_PIN_QSPI1_IO2_PD2, "QSPI1_IO2_PD2"),
 246	PINCTRL_PIN(TEGRA_PIN_QSPI1_IO3_PD3, "QSPI1_IO3_PD3"),
 247	PINCTRL_PIN(TEGRA_PIN_EQOS_TXC_PE0, "EQOS_TXC_PE0"),
 248	PINCTRL_PIN(TEGRA_PIN_EQOS_TD0_PE1, "EQOS_TD0_PE1"),
 249	PINCTRL_PIN(TEGRA_PIN_EQOS_TD1_PE2, "EQOS_TD1_PE2"),
 250	PINCTRL_PIN(TEGRA_PIN_EQOS_TD2_PE3, "EQOS_TD2_PE3"),
 251	PINCTRL_PIN(TEGRA_PIN_EQOS_TD3_PE4, "EQOS_TD3_PE4"),
 252	PINCTRL_PIN(TEGRA_PIN_EQOS_TX_CTL_PE5, "EQOS_TX_CTL_PE5"),
 253	PINCTRL_PIN(TEGRA_PIN_EQOS_RD0_PE6, "EQOS_RD0_PE6"),
 254	PINCTRL_PIN(TEGRA_PIN_EQOS_RD1_PE7, "EQOS_RD1_PE7"),
 255	PINCTRL_PIN(TEGRA_PIN_EQOS_RD2_PF0, "EQOS_RD2_PF0"),
 256	PINCTRL_PIN(TEGRA_PIN_EQOS_RD3_PF1, "EQOS_RD3_PF1"),
 257	PINCTRL_PIN(TEGRA_PIN_EQOS_RX_CTL_PF2, "EQOS_RX_CTL_PF2"),
 258	PINCTRL_PIN(TEGRA_PIN_EQOS_RXC_PF3, "EQOS_RXC_PF3"),
 259	PINCTRL_PIN(TEGRA_PIN_EQOS_SMA_MDIO_PF4, "EQOS_SMA_MDIO_PF4"),
 260	PINCTRL_PIN(TEGRA_PIN_EQOS_SMA_MDC_PF5, "EQOS_SMA_MDC_PF5"),
 261	PINCTRL_PIN(TEGRA_PIN_SOC_GPIO13_PG0, "SOC_GPIO13_PG0"),
 262	PINCTRL_PIN(TEGRA_PIN_SOC_GPIO14_PG1, "SOC_GPIO14_PG1"),
 263	PINCTRL_PIN(TEGRA_PIN_SOC_GPIO15_PG2, "SOC_GPIO15_PG2"),
 264	PINCTRL_PIN(TEGRA_PIN_SOC_GPIO16_PG3, "SOC_GPIO16_PG3"),
 265	PINCTRL_PIN(TEGRA_PIN_SOC_GPIO17_PG4, "SOC_GPIO17_PG4"),
 266	PINCTRL_PIN(TEGRA_PIN_SOC_GPIO18_PG5, "SOC_GPIO18_PG5"),
 267	PINCTRL_PIN(TEGRA_PIN_SOC_GPIO19_PG6, "SOC_GPIO19_PG6"),
 268	PINCTRL_PIN(TEGRA_PIN_SOC_GPIO20_PG7, "SOC_GPIO20_PG7"),
 269	PINCTRL_PIN(TEGRA_PIN_SOC_GPIO21_PH0, "SOC_GPIO21_PH0"),
 270	PINCTRL_PIN(TEGRA_PIN_SOC_GPIO22_PH1, "SOC_GPIO22_PH1"),
 271	PINCTRL_PIN(TEGRA_PIN_SOC_GPIO06_PH2, "SOC_GPIO06_PH2"),
 272	PINCTRL_PIN(TEGRA_PIN_UART4_TX_PH3, "UART4_TX_PH3"),
 273	PINCTRL_PIN(TEGRA_PIN_UART4_RX_PH4, "UART4_RX_PH4"),
 274	PINCTRL_PIN(TEGRA_PIN_UART4_RTS_PH5, "UART4_RTS_PH5"),
 275	PINCTRL_PIN(TEGRA_PIN_UART4_CTS_PH6, "UART4_CTS_PH6"),
 276	PINCTRL_PIN(TEGRA_PIN_SOC_GPIO41_PH7, "SOC_GPIO41_PH7"),
 277	PINCTRL_PIN(TEGRA_PIN_SOC_GPIO42_PI0, "SOC_GPIO42_PI0"),
 278	PINCTRL_PIN(TEGRA_PIN_SOC_GPIO43_PI1, "SOC_GPIO43_PI1"),
 279	PINCTRL_PIN(TEGRA_PIN_SOC_GPIO44_PI2, "SOC_GPIO44_PI2"),
 280	PINCTRL_PIN(TEGRA_PIN_GEN1_I2C_SCL_PI3, "GEN1_I2C_SCL_PI3"),
 281	PINCTRL_PIN(TEGRA_PIN_GEN1_I2C_SDA_PI4, "GEN1_I2C_SDA_PI4"),
 282	PINCTRL_PIN(TEGRA_PIN_CPU_PWR_REQ_PI5, "CPU_PWR_REQ_PI5"),
 283	PINCTRL_PIN(TEGRA_PIN_SOC_GPIO07_PI6, "SOC_GPIO07_PI6"),
 284	PINCTRL_PIN(TEGRA_PIN_SDMMC1_CLK_PJ0, "SDMMC1_CLK_PJ0"),
 285	PINCTRL_PIN(TEGRA_PIN_SDMMC1_CMD_PJ1, "SDMMC1_CMD_PJ1"),
 286	PINCTRL_PIN(TEGRA_PIN_SDMMC1_DAT0_PJ2, "SDMMC1_DAT0_PJ2"),
 287	PINCTRL_PIN(TEGRA_PIN_SDMMC1_DAT1_PJ3, "SDMMC1_DAT1_PJ3"),
 288	PINCTRL_PIN(TEGRA_PIN_SDMMC1_DAT2_PJ4, "SDMMC1_DAT2_PJ4"),
 289	PINCTRL_PIN(TEGRA_PIN_SDMMC1_DAT3_PJ5, "SDMMC1_DAT3_PJ5"),
 290	PINCTRL_PIN(TEGRA_PIN_PEX_L0_CLKREQ_N_PK0, "PEX_L0_CLKREQ_N_PK0"),
 291	PINCTRL_PIN(TEGRA_PIN_PEX_L0_RST_N_PK1, "PEX_L0_RST_N_PK1"),
 292	PINCTRL_PIN(TEGRA_PIN_PEX_L1_CLKREQ_N_PK2, "PEX_L1_CLKREQ_N_PK2"),
 293	PINCTRL_PIN(TEGRA_PIN_PEX_L1_RST_N_PK3, "PEX_L1_RST_N_PK3"),
 294	PINCTRL_PIN(TEGRA_PIN_PEX_L2_CLKREQ_N_PK4, "PEX_L2_CLKREQ_N_PK4"),
 295	PINCTRL_PIN(TEGRA_PIN_PEX_L2_RST_N_PK5, "PEX_L2_RST_N_PK5"),
 296	PINCTRL_PIN(TEGRA_PIN_PEX_L3_CLKREQ_N_PK6, "PEX_L3_CLKREQ_N_PK6"),
 297	PINCTRL_PIN(TEGRA_PIN_PEX_L3_RST_N_PK7, "PEX_L3_RST_N_PK7"),
 298	PINCTRL_PIN(TEGRA_PIN_PEX_L4_CLKREQ_N_PL0, "PEX_L4_CLKREQ_N_PL0"),
 299	PINCTRL_PIN(TEGRA_PIN_PEX_L4_RST_N_PL1, "PEX_L4_RST_N_PL1"),
 300	PINCTRL_PIN(TEGRA_PIN_PEX_WAKE_N_PL2, "PEX_WAKE_N_PL2"),
 301	PINCTRL_PIN(TEGRA_PIN_SOC_GPIO34_PL3, "SOC_GPIO34_PL3"),
 302	PINCTRL_PIN(TEGRA_PIN_DP_AUX_CH0_HPD_PM0, "DP_AUX_CH0_HPD_PM0"),
 303	PINCTRL_PIN(TEGRA_PIN_DP_AUX_CH1_HPD_PM1, "DP_AUX_CH1_HPD_PM1"),
 304	PINCTRL_PIN(TEGRA_PIN_DP_AUX_CH2_HPD_PM2, "DP_AUX_CH2_HPD_PM2"),
 305	PINCTRL_PIN(TEGRA_PIN_DP_AUX_CH3_HPD_PM3, "DP_AUX_CH3_HPD_PM3"),
 306	PINCTRL_PIN(TEGRA_PIN_SOC_GPIO55_PM4, "SOC_GPIO55_PM4"),
 307	PINCTRL_PIN(TEGRA_PIN_SOC_GPIO36_PM5, "SOC_GPIO36_PM5"),
 308	PINCTRL_PIN(TEGRA_PIN_SOC_GPIO53_PM6, "SOC_GPIO53_PM6"),
 309	PINCTRL_PIN(TEGRA_PIN_SOC_GPIO38_PM7, "SOC_GPIO38_PM7"),
 310	PINCTRL_PIN(TEGRA_PIN_DP_AUX_CH3_N_PN0, "DP_AUX_CH3_N_PN0"),
 311	PINCTRL_PIN(TEGRA_PIN_SOC_GPIO39_PN1, "SOC_GPIO39_PN1"),
 312	PINCTRL_PIN(TEGRA_PIN_SOC_GPIO40_PN2, "SOC_GPIO40_PN2"),
 313	PINCTRL_PIN(TEGRA_PIN_DP_AUX_CH1_P_PN3, "DP_AUX_CH1_P_PN3"),
 314	PINCTRL_PIN(TEGRA_PIN_DP_AUX_CH1_N_PN4, "DP_AUX_CH1_N_PN4"),
 315	PINCTRL_PIN(TEGRA_PIN_DP_AUX_CH2_P_PN5, "DP_AUX_CH2_P_PN5"),
 316	PINCTRL_PIN(TEGRA_PIN_DP_AUX_CH2_N_PN6, "DP_AUX_CH2_N_PN6"),
 317	PINCTRL_PIN(TEGRA_PIN_DP_AUX_CH3_P_PN7, "DP_AUX_CH3_P_PN7"),
 318	PINCTRL_PIN(TEGRA_PIN_EXTPERIPH1_CLK_PP0, "EXTPERIPH1_CLK_PP0"),
 319	PINCTRL_PIN(TEGRA_PIN_EXTPERIPH2_CLK_PP1, "EXTPERIPH2_CLK_PP1"),
 320	PINCTRL_PIN(TEGRA_PIN_CAM_I2C_SCL_PP2, "CAM_I2C_SCL_PP2"),
 321	PINCTRL_PIN(TEGRA_PIN_CAM_I2C_SDA_PP3, "CAM_I2C_SDA_PP3"),
 322	PINCTRL_PIN(TEGRA_PIN_SOC_GPIO23_PP4, "SOC_GPIO23_PP4"),
 323	PINCTRL_PIN(TEGRA_PIN_SOC_GPIO24_PP5, "SOC_GPIO24_PP5"),
 324	PINCTRL_PIN(TEGRA_PIN_SOC_GPIO25_PP6, "SOC_GPIO25_PP6"),
 325	PINCTRL_PIN(TEGRA_PIN_PWR_I2C_SCL_PP7, "PWR_I2C_SCL_PP7"),
 326	PINCTRL_PIN(TEGRA_PIN_PWR_I2C_SDA_PQ0, "PWR_I2C_SDA_PQ0"),
 327	PINCTRL_PIN(TEGRA_PIN_SOC_GPIO28_PQ1, "SOC_GPIO28_PQ1"),
 328	PINCTRL_PIN(TEGRA_PIN_SOC_GPIO29_PQ2, "SOC_GPIO29_PQ2"),
 329	PINCTRL_PIN(TEGRA_PIN_SOC_GPIO30_PQ3, "SOC_GPIO30_PQ3"),
 330	PINCTRL_PIN(TEGRA_PIN_SOC_GPIO31_PQ4, "SOC_GPIO31_PQ4"),
 331	PINCTRL_PIN(TEGRA_PIN_SOC_GPIO32_PQ5, "SOC_GPIO32_PQ5"),
 332	PINCTRL_PIN(TEGRA_PIN_SOC_GPIO33_PQ6, "SOC_GPIO33_PQ6"),
 333	PINCTRL_PIN(TEGRA_PIN_SOC_GPIO35_PQ7, "SOC_GPIO35_PQ7"),
 334	PINCTRL_PIN(TEGRA_PIN_SOC_GPIO37_PR0, "SOC_GPIO37_PR0"),
 335	PINCTRL_PIN(TEGRA_PIN_SOC_GPIO56_PR1, "SOC_GPIO56_PR1"),
 336	PINCTRL_PIN(TEGRA_PIN_UART1_TX_PR2, "UART1_TX_PR2"),
 337	PINCTRL_PIN(TEGRA_PIN_UART1_RX_PR3, "UART1_RX_PR3"),
 338	PINCTRL_PIN(TEGRA_PIN_UART1_RTS_PR4, "UART1_RTS_PR4"),
 339	PINCTRL_PIN(TEGRA_PIN_UART1_CTS_PR5, "UART1_CTS_PR5"),
 340	PINCTRL_PIN(TEGRA_PIN_GPU_PWR_REQ_PX0, "GPU_PWR_REQ_PX0"),
 341	PINCTRL_PIN(TEGRA_PIN_CV_PWR_REQ_PX1, "CV_PWR_REQ_PX1"),
 342	PINCTRL_PIN(TEGRA_PIN_GP_PWM2_PX2, "GP_PWM2_PX2"),
 343	PINCTRL_PIN(TEGRA_PIN_GP_PWM3_PX3, "GP_PWM3_PX3"),
 344	PINCTRL_PIN(TEGRA_PIN_UART2_TX_PX4, "UART2_TX_PX4"),
 345	PINCTRL_PIN(TEGRA_PIN_UART2_RX_PX5, "UART2_RX_PX5"),
 346	PINCTRL_PIN(TEGRA_PIN_UART2_RTS_PX6, "UART2_RTS_PX6"),
 347	PINCTRL_PIN(TEGRA_PIN_UART2_CTS_PX7, "UART2_CTS_PX7"),
 348	PINCTRL_PIN(TEGRA_PIN_SPI3_SCK_PY0, "SPI3_SCK_PY0"),
 349	PINCTRL_PIN(TEGRA_PIN_SPI3_MISO_PY1, "SPI3_MISO_PY1"),
 350	PINCTRL_PIN(TEGRA_PIN_SPI3_MOSI_PY2, "SPI3_MOSI_PY2"),
 351	PINCTRL_PIN(TEGRA_PIN_SPI3_CS0_PY3, "SPI3_CS0_PY3"),
 352	PINCTRL_PIN(TEGRA_PIN_SPI3_CS1_PY4, "SPI3_CS1_PY4"),
 353	PINCTRL_PIN(TEGRA_PIN_UART5_TX_PY5, "UART5_TX_PY5"),
 354	PINCTRL_PIN(TEGRA_PIN_UART5_RX_PY6, "UART5_RX_PY6"),
 355	PINCTRL_PIN(TEGRA_PIN_UART5_RTS_PY7, "UART5_RTS_PY7"),
 356	PINCTRL_PIN(TEGRA_PIN_UART5_CTS_PZ0, "UART5_CTS_PZ0"),
 357	PINCTRL_PIN(TEGRA_PIN_USB_VBUS_EN0_PZ1, "USB_VBUS_EN0_PZ1"),
 358	PINCTRL_PIN(TEGRA_PIN_USB_VBUS_EN1_PZ2, "USB_VBUS_EN1_PZ2"),
 359	PINCTRL_PIN(TEGRA_PIN_SPI1_SCK_PZ3, "SPI1_SCK_PZ3"),
 360	PINCTRL_PIN(TEGRA_PIN_SPI1_MISO_PZ4, "SPI1_MISO_PZ4"),
 361	PINCTRL_PIN(TEGRA_PIN_SPI1_MOSI_PZ5, "SPI1_MOSI_PZ5"),
 362	PINCTRL_PIN(TEGRA_PIN_SPI1_CS0_PZ6, "SPI1_CS0_PZ6"),
 363	PINCTRL_PIN(TEGRA_PIN_SPI1_CS1_PZ7, "SPI1_CS1_PZ7"),
 364	PINCTRL_PIN(TEGRA_PIN_SPI5_SCK_PAC0, "SPI5_SCK_PAC0"),
 365	PINCTRL_PIN(TEGRA_PIN_SPI5_MISO_PAC1, "SPI5_MISO_PAC1"),
 366	PINCTRL_PIN(TEGRA_PIN_SPI5_MOSI_PAC2, "SPI5_MOSI_PAC2"),
 367	PINCTRL_PIN(TEGRA_PIN_SPI5_CS0_PAC3, "SPI5_CS0_PAC3"),
 368	PINCTRL_PIN(TEGRA_PIN_SOC_GPIO57_PAC4, "SOC_GPIO57_PAC4"),
 369	PINCTRL_PIN(TEGRA_PIN_SOC_GPIO58_PAC5, "SOC_GPIO58_PAC5"),
 370	PINCTRL_PIN(TEGRA_PIN_SOC_GPIO59_PAC6, "SOC_GPIO59_PAC6"),
 371	PINCTRL_PIN(TEGRA_PIN_SOC_GPIO60_PAC7, "SOC_GPIO60_PAC7"),
 372	PINCTRL_PIN(TEGRA_PIN_SOC_GPIO45_PAD0, "SOC_GPIO45_PAD0"),
 373	PINCTRL_PIN(TEGRA_PIN_SOC_GPIO46_PAD1, "SOC_GPIO46_PAD1"),
 374	PINCTRL_PIN(TEGRA_PIN_SOC_GPIO47_PAD2, "SOC_GPIO47_PAD2"),
 375	PINCTRL_PIN(TEGRA_PIN_SOC_GPIO48_PAD3, "SOC_GPIO48_PAD3"),
 376	PINCTRL_PIN(TEGRA_PIN_UFS0_REF_CLK_PAE0, "UFS0_REF_CLK_PAE0"),
 377	PINCTRL_PIN(TEGRA_PIN_UFS0_RST_N_PAE1, "UFS0_RST_N_PAE1"),
 378	PINCTRL_PIN(TEGRA_PIN_PEX_L5_CLKREQ_N_PAF0, "PEX_L5_CLKREQ_N_PAF0"),
 379	PINCTRL_PIN(TEGRA_PIN_PEX_L5_RST_N_PAF1, "PEX_L5_RST_N_PAF1"),
 380	PINCTRL_PIN(TEGRA_PIN_PEX_L6_CLKREQ_N_PAF2, "PEX_L6_CLKREQ_N_PAF2"),
 381	PINCTRL_PIN(TEGRA_PIN_PEX_L6_RST_N_PAF3, "PEX_L6_RST_N_PAF3"),
 382	PINCTRL_PIN(TEGRA_PIN_PEX_L7_CLKREQ_N_PAG0, "PEX_L7_CLKREQ_N_PAG0"),
 383	PINCTRL_PIN(TEGRA_PIN_PEX_L7_RST_N_PAG1, "PEX_L7_RST_N_PAG1"),
 384	PINCTRL_PIN(TEGRA_PIN_PEX_L8_CLKREQ_N_PAG2, "PEX_L8_CLKREQ_N_PAG2"),
 385	PINCTRL_PIN(TEGRA_PIN_PEX_L8_RST_N_PAG3, "PEX_L8_RST_N_PAG3"),
 386	PINCTRL_PIN(TEGRA_PIN_PEX_L9_CLKREQ_N_PAG4, "PEX_L9_CLKREQ_N_PAG4"),
 387	PINCTRL_PIN(TEGRA_PIN_PEX_L9_RST_N_PAG5, "PEX_L9_RST_N_PAG5"),
 388	PINCTRL_PIN(TEGRA_PIN_PEX_L10_CLKREQ_N_PAG6, "PEX_L10_CLKREQ_N_PAG6"),
 389	PINCTRL_PIN(TEGRA_PIN_PEX_L10_RST_N_PAG7, "PEX_L10_RST_N_PAG7"),
 390	PINCTRL_PIN(TEGRA_PIN_EQOS_COMP, "EQOS_COMP"),
 391	PINCTRL_PIN(TEGRA_PIN_QSPI_COMP, "QSPI_COMP"),
 392	PINCTRL_PIN(TEGRA_PIN_SDMMC1_COMP, "SDMMC1_COMP"),
 393};
 394
 395static const unsigned int dap6_sclk_pa0_pins[] = {
 396	TEGRA_PIN_DAP6_SCLK_PA0,
 397};
 398
 399static const unsigned int dap6_dout_pa1_pins[] = {
 400	TEGRA_PIN_DAP6_DOUT_PA1,
 401};
 402
 403static const unsigned int dap6_din_pa2_pins[] = {
 404	TEGRA_PIN_DAP6_DIN_PA2,
 405};
 406
 407static const unsigned int dap6_fs_pa3_pins[] = {
 408	TEGRA_PIN_DAP6_FS_PA3,
 409};
 410
 411static const unsigned int dap4_sclk_pa4_pins[] = {
 412	TEGRA_PIN_DAP4_SCLK_PA4,
 413};
 414
 415static const unsigned int dap4_dout_pa5_pins[] = {
 416	TEGRA_PIN_DAP4_DOUT_PA5,
 417};
 418
 419static const unsigned int dap4_din_pa6_pins[] = {
 420	TEGRA_PIN_DAP4_DIN_PA6,
 421};
 422
 423static const unsigned int dap4_fs_pa7_pins[] = {
 424	TEGRA_PIN_DAP4_FS_PA7,
 425};
 426
 427static const unsigned int soc_gpio08_pb0_pins[] = {
 428	TEGRA_PIN_SOC_GPIO08_PB0,
 429};
 430
 431static const unsigned int qspi0_sck_pc0_pins[] = {
 432	TEGRA_PIN_QSPI0_SCK_PC0,
 433};
 434
 435static const unsigned int qspi0_cs_n_pc1_pins[] = {
 436	TEGRA_PIN_QSPI0_CS_N_PC1,
 437};
 438
 439static const unsigned int qspi0_io0_pc2_pins[] = {
 440	TEGRA_PIN_QSPI0_IO0_PC2,
 441};
 442
 443static const unsigned int qspi0_io1_pc3_pins[] = {
 444	TEGRA_PIN_QSPI0_IO1_PC3,
 445};
 446
 447static const unsigned int qspi0_io2_pc4_pins[] = {
 448	TEGRA_PIN_QSPI0_IO2_PC4,
 449};
 450
 451static const unsigned int qspi0_io3_pc5_pins[] = {
 452	TEGRA_PIN_QSPI0_IO3_PC5,
 453};
 454
 455static const unsigned int qspi1_sck_pc6_pins[] = {
 456	TEGRA_PIN_QSPI1_SCK_PC6,
 457};
 458
 459static const unsigned int qspi1_cs_n_pc7_pins[] = {
 460	TEGRA_PIN_QSPI1_CS_N_PC7,
 461};
 462
 463static const unsigned int qspi1_io0_pd0_pins[] = {
 464	TEGRA_PIN_QSPI1_IO0_PD0,
 465};
 466
 467static const unsigned int qspi1_io1_pd1_pins[] = {
 468	TEGRA_PIN_QSPI1_IO1_PD1,
 469};
 470
 471static const unsigned int qspi1_io2_pd2_pins[] = {
 472	TEGRA_PIN_QSPI1_IO2_PD2,
 473};
 474
 475static const unsigned int qspi1_io3_pd3_pins[] = {
 476	TEGRA_PIN_QSPI1_IO3_PD3,
 477};
 478
 479static const unsigned int eqos_txc_pe0_pins[] = {
 480	TEGRA_PIN_EQOS_TXC_PE0,
 481};
 482
 483static const unsigned int eqos_td0_pe1_pins[] = {
 484	TEGRA_PIN_EQOS_TD0_PE1,
 485};
 486
 487static const unsigned int eqos_td1_pe2_pins[] = {
 488	TEGRA_PIN_EQOS_TD1_PE2,
 489};
 490
 491static const unsigned int eqos_td2_pe3_pins[] = {
 492	TEGRA_PIN_EQOS_TD2_PE3,
 493};
 494
 495static const unsigned int eqos_td3_pe4_pins[] = {
 496	TEGRA_PIN_EQOS_TD3_PE4,
 497};
 498
 499static const unsigned int eqos_tx_ctl_pe5_pins[] = {
 500	TEGRA_PIN_EQOS_TX_CTL_PE5,
 501};
 502
 503static const unsigned int eqos_rd0_pe6_pins[] = {
 504	TEGRA_PIN_EQOS_RD0_PE6,
 505};
 506
 507static const unsigned int eqos_rd1_pe7_pins[] = {
 508	TEGRA_PIN_EQOS_RD1_PE7,
 509};
 510
 511static const unsigned int eqos_rd2_pf0_pins[] = {
 512	TEGRA_PIN_EQOS_RD2_PF0,
 513};
 514
 515static const unsigned int eqos_rd3_pf1_pins[] = {
 516	TEGRA_PIN_EQOS_RD3_PF1,
 517};
 518
 519static const unsigned int eqos_rx_ctl_pf2_pins[] = {
 520	TEGRA_PIN_EQOS_RX_CTL_PF2,
 521};
 522
 523static const unsigned int eqos_rxc_pf3_pins[] = {
 524	TEGRA_PIN_EQOS_RXC_PF3,
 525};
 526
 527static const unsigned int eqos_sma_mdio_pf4_pins[] = {
 528	TEGRA_PIN_EQOS_SMA_MDIO_PF4,
 529};
 530
 531static const unsigned int eqos_sma_mdc_pf5_pins[] = {
 532	TEGRA_PIN_EQOS_SMA_MDC_PF5,
 533};
 534
 535static const unsigned int soc_gpio13_pg0_pins[] = {
 536	TEGRA_PIN_SOC_GPIO13_PG0,
 537};
 538
 539static const unsigned int soc_gpio14_pg1_pins[] = {
 540	TEGRA_PIN_SOC_GPIO14_PG1,
 541};
 542
 543static const unsigned int soc_gpio15_pg2_pins[] = {
 544	TEGRA_PIN_SOC_GPIO15_PG2,
 545};
 546
 547static const unsigned int soc_gpio16_pg3_pins[] = {
 548	TEGRA_PIN_SOC_GPIO16_PG3,
 549};
 550
 551static const unsigned int soc_gpio17_pg4_pins[] = {
 552	TEGRA_PIN_SOC_GPIO17_PG4,
 553};
 554
 555static const unsigned int soc_gpio18_pg5_pins[] = {
 556	TEGRA_PIN_SOC_GPIO18_PG5,
 557};
 558
 559static const unsigned int soc_gpio19_pg6_pins[] = {
 560	TEGRA_PIN_SOC_GPIO19_PG6,
 561};
 562
 563static const unsigned int soc_gpio20_pg7_pins[] = {
 564	TEGRA_PIN_SOC_GPIO20_PG7,
 565};
 566
 567static const unsigned int soc_gpio21_ph0_pins[] = {
 568	TEGRA_PIN_SOC_GPIO21_PH0,
 569};
 570
 571static const unsigned int soc_gpio22_ph1_pins[] = {
 572	TEGRA_PIN_SOC_GPIO22_PH1,
 573};
 574
 575static const unsigned int soc_gpio06_ph2_pins[] = {
 576	TEGRA_PIN_SOC_GPIO06_PH2,
 577};
 578
 579static const unsigned int uart4_tx_ph3_pins[] = {
 580	TEGRA_PIN_UART4_TX_PH3,
 581};
 582
 583static const unsigned int uart4_rx_ph4_pins[] = {
 584	TEGRA_PIN_UART4_RX_PH4,
 585};
 586
 587static const unsigned int uart4_rts_ph5_pins[] = {
 588	TEGRA_PIN_UART4_RTS_PH5,
 589};
 590
 591static const unsigned int uart4_cts_ph6_pins[] = {
 592	TEGRA_PIN_UART4_CTS_PH6,
 593};
 594
 595static const unsigned int soc_gpio41_ph7_pins[] = {
 596	TEGRA_PIN_SOC_GPIO41_PH7,
 597};
 598
 599static const unsigned int soc_gpio42_pi0_pins[] = {
 600	TEGRA_PIN_SOC_GPIO42_PI0,
 601};
 602
 603static const unsigned int soc_gpio43_pi1_pins[] = {
 604	TEGRA_PIN_SOC_GPIO43_PI1,
 605};
 606
 607static const unsigned int soc_gpio44_pi2_pins[] = {
 608	TEGRA_PIN_SOC_GPIO44_PI2,
 609};
 610
 611static const unsigned int gen1_i2c_scl_pi3_pins[] = {
 612	TEGRA_PIN_GEN1_I2C_SCL_PI3,
 613};
 614
 615static const unsigned int gen1_i2c_sda_pi4_pins[] = {
 616	TEGRA_PIN_GEN1_I2C_SDA_PI4,
 617};
 618
 619static const unsigned int cpu_pwr_req_pi5_pins[] = {
 620	TEGRA_PIN_CPU_PWR_REQ_PI5,
 621};
 622
 623static const unsigned int soc_gpio07_pi6_pins[] = {
 624	TEGRA_PIN_SOC_GPIO07_PI6,
 625};
 626
 627static const unsigned int sdmmc1_clk_pj0_pins[] = {
 628	TEGRA_PIN_SDMMC1_CLK_PJ0,
 629};
 630
 631static const unsigned int sdmmc1_cmd_pj1_pins[] = {
 632	TEGRA_PIN_SDMMC1_CMD_PJ1,
 633};
 634
 635static const unsigned int sdmmc1_dat0_pj2_pins[] = {
 636	TEGRA_PIN_SDMMC1_DAT0_PJ2,
 637};
 638
 639static const unsigned int sdmmc1_dat1_pj3_pins[] = {
 640	TEGRA_PIN_SDMMC1_DAT1_PJ3,
 641};
 642
 643static const unsigned int sdmmc1_dat2_pj4_pins[] = {
 644	TEGRA_PIN_SDMMC1_DAT2_PJ4,
 645};
 646
 647static const unsigned int sdmmc1_dat3_pj5_pins[] = {
 648	TEGRA_PIN_SDMMC1_DAT3_PJ5,
 649};
 650
 651static const unsigned int pex_l0_clkreq_n_pk0_pins[] = {
 652	TEGRA_PIN_PEX_L0_CLKREQ_N_PK0,
 653};
 654
 655static const unsigned int pex_l0_rst_n_pk1_pins[] = {
 656	TEGRA_PIN_PEX_L0_RST_N_PK1,
 657};
 658
 659static const unsigned int pex_l1_clkreq_n_pk2_pins[] = {
 660	TEGRA_PIN_PEX_L1_CLKREQ_N_PK2,
 661};
 662
 663static const unsigned int pex_l1_rst_n_pk3_pins[] = {
 664	TEGRA_PIN_PEX_L1_RST_N_PK3,
 665};
 666
 667static const unsigned int pex_l2_clkreq_n_pk4_pins[] = {
 668	TEGRA_PIN_PEX_L2_CLKREQ_N_PK4,
 669};
 670
 671static const unsigned int pex_l2_rst_n_pk5_pins[] = {
 672	TEGRA_PIN_PEX_L2_RST_N_PK5,
 673};
 674
 675static const unsigned int pex_l3_clkreq_n_pk6_pins[] = {
 676	TEGRA_PIN_PEX_L3_CLKREQ_N_PK6,
 677};
 678
 679static const unsigned int pex_l3_rst_n_pk7_pins[] = {
 680	TEGRA_PIN_PEX_L3_RST_N_PK7,
 681};
 682
 683static const unsigned int pex_l4_clkreq_n_pl0_pins[] = {
 684	TEGRA_PIN_PEX_L4_CLKREQ_N_PL0,
 685};
 686
 687static const unsigned int pex_l4_rst_n_pl1_pins[] = {
 688	TEGRA_PIN_PEX_L4_RST_N_PL1,
 689};
 690
 691static const unsigned int pex_wake_n_pl2_pins[] = {
 692	TEGRA_PIN_PEX_WAKE_N_PL2,
 693};
 694
 695static const unsigned int soc_gpio34_pl3_pins[] = {
 696	TEGRA_PIN_SOC_GPIO34_PL3,
 697};
 698
 699static const unsigned int dp_aux_ch0_hpd_pm0_pins[] = {
 700	TEGRA_PIN_DP_AUX_CH0_HPD_PM0,
 701};
 702
 703static const unsigned int dp_aux_ch1_hpd_pm1_pins[] = {
 704	TEGRA_PIN_DP_AUX_CH1_HPD_PM1,
 705};
 706
 707static const unsigned int dp_aux_ch2_hpd_pm2_pins[] = {
 708	TEGRA_PIN_DP_AUX_CH2_HPD_PM2,
 709};
 710
 711static const unsigned int dp_aux_ch3_hpd_pm3_pins[] = {
 712	TEGRA_PIN_DP_AUX_CH3_HPD_PM3,
 713};
 714
 715static const unsigned int soc_gpio55_pm4_pins[] = {
 716	TEGRA_PIN_SOC_GPIO55_PM4,
 717};
 718
 719static const unsigned int soc_gpio36_pm5_pins[] = {
 720	TEGRA_PIN_SOC_GPIO36_PM5,
 721};
 722
 723static const unsigned int soc_gpio53_pm6_pins[] = {
 724	TEGRA_PIN_SOC_GPIO53_PM6,
 725};
 726
 727static const unsigned int soc_gpio38_pm7_pins[] = {
 728	TEGRA_PIN_SOC_GPIO38_PM7,
 729};
 730
 731static const unsigned int dp_aux_ch3_n_pn0_pins[] = {
 732	TEGRA_PIN_DP_AUX_CH3_N_PN0,
 733};
 734
 735static const unsigned int soc_gpio39_pn1_pins[] = {
 736	TEGRA_PIN_SOC_GPIO39_PN1,
 737};
 738
 739static const unsigned int soc_gpio40_pn2_pins[] = {
 740	TEGRA_PIN_SOC_GPIO40_PN2,
 741};
 742
 743static const unsigned int dp_aux_ch1_p_pn3_pins[] = {
 744	TEGRA_PIN_DP_AUX_CH1_P_PN3,
 745};
 746
 747static const unsigned int dp_aux_ch1_n_pn4_pins[] = {
 748	TEGRA_PIN_DP_AUX_CH1_N_PN4,
 749};
 750
 751static const unsigned int dp_aux_ch2_p_pn5_pins[] = {
 752	TEGRA_PIN_DP_AUX_CH2_P_PN5,
 753};
 754
 755static const unsigned int dp_aux_ch2_n_pn6_pins[] = {
 756	TEGRA_PIN_DP_AUX_CH2_N_PN6,
 757};
 758
 759static const unsigned int dp_aux_ch3_p_pn7_pins[] = {
 760	TEGRA_PIN_DP_AUX_CH3_P_PN7,
 761};
 762
 763static const unsigned int extperiph1_clk_pp0_pins[] = {
 764	TEGRA_PIN_EXTPERIPH1_CLK_PP0,
 765};
 766
 767static const unsigned int extperiph2_clk_pp1_pins[] = {
 768	TEGRA_PIN_EXTPERIPH2_CLK_PP1,
 769};
 770
 771static const unsigned int cam_i2c_scl_pp2_pins[] = {
 772	TEGRA_PIN_CAM_I2C_SCL_PP2,
 773};
 774
 775static const unsigned int cam_i2c_sda_pp3_pins[] = {
 776	TEGRA_PIN_CAM_I2C_SDA_PP3,
 777};
 778
 779static const unsigned int soc_gpio23_pp4_pins[] = {
 780	TEGRA_PIN_SOC_GPIO23_PP4,
 781};
 782
 783static const unsigned int soc_gpio24_pp5_pins[] = {
 784	TEGRA_PIN_SOC_GPIO24_PP5,
 785};
 786
 787static const unsigned int soc_gpio25_pp6_pins[] = {
 788	TEGRA_PIN_SOC_GPIO25_PP6,
 789};
 790
 791static const unsigned int pwr_i2c_scl_pp7_pins[] = {
 792	TEGRA_PIN_PWR_I2C_SCL_PP7,
 793};
 794
 795static const unsigned int pwr_i2c_sda_pq0_pins[] = {
 796	TEGRA_PIN_PWR_I2C_SDA_PQ0,
 797};
 798
 799static const unsigned int soc_gpio28_pq1_pins[] = {
 800	TEGRA_PIN_SOC_GPIO28_PQ1,
 801};
 802
 803static const unsigned int soc_gpio29_pq2_pins[] = {
 804	TEGRA_PIN_SOC_GPIO29_PQ2,
 805};
 806
 807static const unsigned int soc_gpio30_pq3_pins[] = {
 808	TEGRA_PIN_SOC_GPIO30_PQ3,
 809};
 810
 811static const unsigned int soc_gpio31_pq4_pins[] = {
 812	TEGRA_PIN_SOC_GPIO31_PQ4,
 813};
 814
 815static const unsigned int soc_gpio32_pq5_pins[] = {
 816	TEGRA_PIN_SOC_GPIO32_PQ5,
 817};
 818
 819static const unsigned int soc_gpio33_pq6_pins[] = {
 820	TEGRA_PIN_SOC_GPIO33_PQ6,
 821};
 822
 823static const unsigned int soc_gpio35_pq7_pins[] = {
 824	TEGRA_PIN_SOC_GPIO35_PQ7,
 825};
 826
 827static const unsigned int soc_gpio37_pr0_pins[] = {
 828	TEGRA_PIN_SOC_GPIO37_PR0,
 829};
 830
 831static const unsigned int soc_gpio56_pr1_pins[] = {
 832	TEGRA_PIN_SOC_GPIO56_PR1,
 833};
 834
 835static const unsigned int uart1_tx_pr2_pins[] = {
 836	TEGRA_PIN_UART1_TX_PR2,
 837};
 838
 839static const unsigned int uart1_rx_pr3_pins[] = {
 840	TEGRA_PIN_UART1_RX_PR3,
 841};
 842
 843static const unsigned int uart1_rts_pr4_pins[] = {
 844	TEGRA_PIN_UART1_RTS_PR4,
 845};
 846
 847static const unsigned int uart1_cts_pr5_pins[] = {
 848	TEGRA_PIN_UART1_CTS_PR5,
 849};
 850
 851static const unsigned int gpu_pwr_req_px0_pins[] = {
 852	TEGRA_PIN_GPU_PWR_REQ_PX0,
 853};
 854
 855static const unsigned int cv_pwr_req_px1_pins[] = {
 856	TEGRA_PIN_CV_PWR_REQ_PX1,
 857};
 858
 859static const unsigned int gp_pwm2_px2_pins[] = {
 860	TEGRA_PIN_GP_PWM2_PX2,
 861};
 862
 863static const unsigned int gp_pwm3_px3_pins[] = {
 864	TEGRA_PIN_GP_PWM3_PX3,
 865};
 866
 867static const unsigned int uart2_tx_px4_pins[] = {
 868	TEGRA_PIN_UART2_TX_PX4,
 869};
 870
 871static const unsigned int uart2_rx_px5_pins[] = {
 872	TEGRA_PIN_UART2_RX_PX5,
 873};
 874
 875static const unsigned int uart2_rts_px6_pins[] = {
 876	TEGRA_PIN_UART2_RTS_PX6,
 877};
 878
 879static const unsigned int uart2_cts_px7_pins[] = {
 880	TEGRA_PIN_UART2_CTS_PX7,
 881};
 882
 883static const unsigned int spi3_sck_py0_pins[] = {
 884	TEGRA_PIN_SPI3_SCK_PY0,
 885};
 886
 887static const unsigned int spi3_miso_py1_pins[] = {
 888	TEGRA_PIN_SPI3_MISO_PY1,
 889};
 890
 891static const unsigned int spi3_mosi_py2_pins[] = {
 892	TEGRA_PIN_SPI3_MOSI_PY2,
 893};
 894
 895static const unsigned int spi3_cs0_py3_pins[] = {
 896	TEGRA_PIN_SPI3_CS0_PY3,
 897};
 898
 899static const unsigned int spi3_cs1_py4_pins[] = {
 900	TEGRA_PIN_SPI3_CS1_PY4,
 901};
 902
 903static const unsigned int uart5_tx_py5_pins[] = {
 904	TEGRA_PIN_UART5_TX_PY5,
 905};
 906
 907static const unsigned int uart5_rx_py6_pins[] = {
 908	TEGRA_PIN_UART5_RX_PY6,
 909};
 910
 911static const unsigned int uart5_rts_py7_pins[] = {
 912	TEGRA_PIN_UART5_RTS_PY7,
 913};
 914
 915static const unsigned int uart5_cts_pz0_pins[] = {
 916	TEGRA_PIN_UART5_CTS_PZ0,
 917};
 918
 919static const unsigned int usb_vbus_en0_pz1_pins[] = {
 920	TEGRA_PIN_USB_VBUS_EN0_PZ1,
 921};
 922
 923static const unsigned int usb_vbus_en1_pz2_pins[] = {
 924	TEGRA_PIN_USB_VBUS_EN1_PZ2,
 925};
 926
 927static const unsigned int spi1_sck_pz3_pins[] = {
 928	TEGRA_PIN_SPI1_SCK_PZ3,
 929};
 930
 931static const unsigned int spi1_miso_pz4_pins[] = {
 932	TEGRA_PIN_SPI1_MISO_PZ4,
 933};
 934
 935static const unsigned int spi1_mosi_pz5_pins[] = {
 936	TEGRA_PIN_SPI1_MOSI_PZ5,
 937};
 938
 939static const unsigned int spi1_cs0_pz6_pins[] = {
 940	TEGRA_PIN_SPI1_CS0_PZ6,
 941};
 942
 943static const unsigned int spi1_cs1_pz7_pins[] = {
 944	TEGRA_PIN_SPI1_CS1_PZ7,
 945};
 946
 947static const unsigned int can0_dout_paa0_pins[] = {
 948	TEGRA_PIN_CAN0_DOUT_PAA0,
 949};
 950
 951static const unsigned int can0_din_paa1_pins[] = {
 952	TEGRA_PIN_CAN0_DIN_PAA1,
 953};
 954
 955static const unsigned int can1_dout_paa2_pins[] = {
 956	TEGRA_PIN_CAN1_DOUT_PAA2,
 957};
 958
 959static const unsigned int can1_din_paa3_pins[] = {
 960	TEGRA_PIN_CAN1_DIN_PAA3,
 961};
 962
 963static const unsigned int can0_stb_paa4_pins[] = {
 964	TEGRA_PIN_CAN0_STB_PAA4,
 965};
 966
 967static const unsigned int can0_en_paa5_pins[] = {
 968	TEGRA_PIN_CAN0_EN_PAA5,
 969};
 970
 971static const unsigned int soc_gpio49_paa6_pins[] = {
 972	TEGRA_PIN_SOC_GPIO49_PAA6,
 973};
 974
 975static const unsigned int can0_err_paa7_pins[] = {
 976	TEGRA_PIN_CAN0_ERR_PAA7,
 977};
 978
 979static const unsigned int spi5_sck_pac0_pins[] = {
 980	TEGRA_PIN_SPI5_SCK_PAC0,
 981};
 982
 983static const unsigned int spi5_miso_pac1_pins[] = {
 984	TEGRA_PIN_SPI5_MISO_PAC1,
 985};
 986
 987static const unsigned int spi5_mosi_pac2_pins[] = {
 988	TEGRA_PIN_SPI5_MOSI_PAC2,
 989};
 990
 991static const unsigned int spi5_cs0_pac3_pins[] = {
 992	TEGRA_PIN_SPI5_CS0_PAC3,
 993};
 994
 995static const unsigned int soc_gpio57_pac4_pins[] = {
 996	TEGRA_PIN_SOC_GPIO57_PAC4,
 997};
 998
 999static const unsigned int soc_gpio58_pac5_pins[] = {
1000	TEGRA_PIN_SOC_GPIO58_PAC5,
1001};
1002
1003static const unsigned int soc_gpio59_pac6_pins[] = {
1004	TEGRA_PIN_SOC_GPIO59_PAC6,
1005};
1006
1007static const unsigned int soc_gpio60_pac7_pins[] = {
1008	TEGRA_PIN_SOC_GPIO60_PAC7,
1009};
1010
1011static const unsigned int soc_gpio45_pad0_pins[] = {
1012	TEGRA_PIN_SOC_GPIO45_PAD0,
1013};
1014
1015static const unsigned int soc_gpio46_pad1_pins[] = {
1016	TEGRA_PIN_SOC_GPIO46_PAD1,
1017};
1018
1019static const unsigned int soc_gpio47_pad2_pins[] = {
1020	TEGRA_PIN_SOC_GPIO47_PAD2,
1021};
1022
1023static const unsigned int soc_gpio48_pad3_pins[] = {
1024	TEGRA_PIN_SOC_GPIO48_PAD3,
1025};
1026
1027static const unsigned int ufs0_ref_clk_pae0_pins[] = {
1028	TEGRA_PIN_UFS0_REF_CLK_PAE0,
1029};
1030
1031static const unsigned int ufs0_rst_n_pae1_pins[] = {
1032	TEGRA_PIN_UFS0_RST_N_PAE1,
1033};
1034
1035static const unsigned int pex_l5_clkreq_n_paf0_pins[] = {
1036	TEGRA_PIN_PEX_L5_CLKREQ_N_PAF0,
1037};
1038
1039static const unsigned int pex_l5_rst_n_paf1_pins[] = {
1040	TEGRA_PIN_PEX_L5_RST_N_PAF1,
1041};
1042
1043static const unsigned int pex_l6_clkreq_n_paf2_pins[] = {
1044	TEGRA_PIN_PEX_L6_CLKREQ_N_PAF2,
1045};
1046
1047static const unsigned int pex_l6_rst_n_paf3_pins[] = {
1048	TEGRA_PIN_PEX_L6_RST_N_PAF3,
1049};
1050
1051static const unsigned int pex_l7_clkreq_n_pag0_pins[] = {
1052	TEGRA_PIN_PEX_L7_CLKREQ_N_PAG0,
1053};
1054
1055static const unsigned int pex_l7_rst_n_pag1_pins[] = {
1056	TEGRA_PIN_PEX_L7_RST_N_PAG1,
1057};
1058
1059static const unsigned int pex_l8_clkreq_n_pag2_pins[] = {
1060	TEGRA_PIN_PEX_L8_CLKREQ_N_PAG2,
1061};
1062
1063static const unsigned int pex_l8_rst_n_pag3_pins[] = {
1064	TEGRA_PIN_PEX_L8_RST_N_PAG3,
1065};
1066
1067static const unsigned int pex_l9_clkreq_n_pag4_pins[] = {
1068	TEGRA_PIN_PEX_L9_CLKREQ_N_PAG4,
1069};
1070
1071static const unsigned int pex_l9_rst_n_pag5_pins[] = {
1072	TEGRA_PIN_PEX_L9_RST_N_PAG5,
1073};
1074
1075static const unsigned int pex_l10_clkreq_n_pag6_pins[] = {
1076	TEGRA_PIN_PEX_L10_CLKREQ_N_PAG6,
1077};
1078
1079static const unsigned int pex_l10_rst_n_pag7_pins[] = {
1080	TEGRA_PIN_PEX_L10_RST_N_PAG7,
1081};
1082
1083static const unsigned int can1_stb_pbb0_pins[] = {
1084	TEGRA_PIN_CAN1_STB_PBB0,
1085};
1086
1087static const unsigned int can1_en_pbb1_pins[] = {
1088	TEGRA_PIN_CAN1_EN_PBB1,
1089};
1090
1091static const unsigned int soc_gpio50_pbb2_pins[] = {
1092	TEGRA_PIN_SOC_GPIO50_PBB2,
1093};
1094
1095static const unsigned int can1_err_pbb3_pins[] = {
1096	TEGRA_PIN_CAN1_ERR_PBB3,
1097};
1098
1099static const unsigned int spi2_sck_pcc0_pins[] = {
1100	TEGRA_PIN_SPI2_SCK_PCC0,
1101};
1102
1103static const unsigned int spi2_miso_pcc1_pins[] = {
1104	TEGRA_PIN_SPI2_MISO_PCC1,
1105};
1106
1107static const unsigned int spi2_mosi_pcc2_pins[] = {
1108	TEGRA_PIN_SPI2_MOSI_PCC2,
1109};
1110
1111static const unsigned int spi2_cs0_pcc3_pins[] = {
1112	TEGRA_PIN_SPI2_CS0_PCC3,
1113};
1114
1115static const unsigned int touch_clk_pcc4_pins[] = {
1116	TEGRA_PIN_TOUCH_CLK_PCC4,
1117};
1118
1119static const unsigned int uart3_tx_pcc5_pins[] = {
1120	TEGRA_PIN_UART3_TX_PCC5,
1121};
1122
1123static const unsigned int uart3_rx_pcc6_pins[] = {
1124	TEGRA_PIN_UART3_RX_PCC6,
1125};
1126
1127static const unsigned int gen2_i2c_scl_pcc7_pins[] = {
1128	TEGRA_PIN_GEN2_I2C_SCL_PCC7,
1129};
1130
1131static const unsigned int gen2_i2c_sda_pdd0_pins[] = {
1132	TEGRA_PIN_GEN2_I2C_SDA_PDD0,
1133};
1134
1135static const unsigned int gen8_i2c_scl_pdd1_pins[] = {
1136	TEGRA_PIN_GEN8_I2C_SCL_PDD1,
1137};
1138
1139static const unsigned int gen8_i2c_sda_pdd2_pins[] = {
1140	TEGRA_PIN_GEN8_I2C_SDA_PDD2,
1141};
1142
1143static const unsigned int sce_error_pee0_pins[] = {
1144	TEGRA_PIN_SCE_ERROR_PEE0,
1145};
1146
1147static const unsigned int vcomp_alert_pee1_pins[] = {
1148	TEGRA_PIN_VCOMP_ALERT_PEE1,
1149};
1150
1151static const unsigned int ao_retention_n_pee2_pins[] = {
1152	TEGRA_PIN_AO_RETENTION_N_PEE2,
1153};
1154
1155static const unsigned int batt_oc_pee3_pins[] = {
1156	TEGRA_PIN_BATT_OC_PEE3,
1157};
1158
1159static const unsigned int power_on_pee4_pins[] = {
1160	TEGRA_PIN_POWER_ON_PEE4,
1161};
1162
1163static const unsigned int soc_gpio26_pee5_pins[] = {
1164	TEGRA_PIN_SOC_GPIO26_PEE5,
1165};
1166
1167static const unsigned int soc_gpio27_pee6_pins[] = {
1168	TEGRA_PIN_SOC_GPIO27_PEE6,
1169};
1170
1171static const unsigned int bootv_ctl_n_pee7_pins[] = {
1172	TEGRA_PIN_BOOTV_CTL_N_PEE7,
1173};
1174
1175static const unsigned int hdmi_cec_pgg0_pins[] = {
1176	TEGRA_PIN_HDMI_CEC_PGG0,
1177};
1178
1179static const unsigned int eqos_comp_pins[] = {
1180	TEGRA_PIN_EQOS_COMP,
1181};
1182
1183static const unsigned int qspi_comp_pins[] = {
1184	TEGRA_PIN_QSPI_COMP,
1185};
1186
1187static const unsigned int sdmmc1_comp_pins[] = {
1188	TEGRA_PIN_SDMMC1_COMP,
1189};
1190
1191/* Define unique ID for each function */
1192enum tegra_mux_dt {
1193	TEGRA_MUX_GP,
1194	TEGRA_MUX_UARTC,
1195	TEGRA_MUX_I2C8,
1196	TEGRA_MUX_SPI2,
1197	TEGRA_MUX_I2C2,
1198	TEGRA_MUX_CAN1,
1199	TEGRA_MUX_CAN0,
1200	TEGRA_MUX_RSVD0,
1201	TEGRA_MUX_ETH0,
1202	TEGRA_MUX_ETH2,
1203	TEGRA_MUX_ETH1,
1204	TEGRA_MUX_DP,
1205	TEGRA_MUX_ETH3,
1206	TEGRA_MUX_I2C4,
1207	TEGRA_MUX_I2C7,
1208	TEGRA_MUX_I2C9,
1209	TEGRA_MUX_EQOS,
1210	TEGRA_MUX_PE2,
1211	TEGRA_MUX_PE1,
1212	TEGRA_MUX_PE0,
1213	TEGRA_MUX_PE3,
1214	TEGRA_MUX_PE4,
1215	TEGRA_MUX_PE5,
1216	TEGRA_MUX_PE6,
1217	TEGRA_MUX_PE10,
1218	TEGRA_MUX_PE7,
1219	TEGRA_MUX_PE8,
1220	TEGRA_MUX_PE9,
1221	TEGRA_MUX_QSPI0,
1222	TEGRA_MUX_QSPI1,
1223	TEGRA_MUX_QSPI,
1224	TEGRA_MUX_SDMMC1,
1225	TEGRA_MUX_SCE,
1226	TEGRA_MUX_SOC,
1227	TEGRA_MUX_GPIO,
1228	TEGRA_MUX_HDMI,
1229	TEGRA_MUX_UFS0,
1230	TEGRA_MUX_SPI3,
1231	TEGRA_MUX_SPI1,
1232	TEGRA_MUX_UARTB,
1233	TEGRA_MUX_UARTE,
1234	TEGRA_MUX_USB,
1235	TEGRA_MUX_EXTPERIPH2,
1236	TEGRA_MUX_EXTPERIPH1,
1237	TEGRA_MUX_I2C3,
1238	TEGRA_MUX_VI0,
1239	TEGRA_MUX_I2C5,
1240	TEGRA_MUX_UARTA,
1241	TEGRA_MUX_UARTD,
1242	TEGRA_MUX_I2C1,
1243	TEGRA_MUX_I2S4,
1244	TEGRA_MUX_I2S6,
1245	TEGRA_MUX_AUD,
1246	TEGRA_MUX_SPI5,
1247	TEGRA_MUX_TOUCH,
1248	TEGRA_MUX_UARTJ,
1249	TEGRA_MUX_RSVD1,
1250	TEGRA_MUX_WDT,
1251	TEGRA_MUX_TSC,
1252	TEGRA_MUX_DMIC3,
1253	TEGRA_MUX_LED,
1254	TEGRA_MUX_VI0_ALT,
1255	TEGRA_MUX_I2S5,
1256	TEGRA_MUX_NV,
1257	TEGRA_MUX_EXTPERIPH3,
1258	TEGRA_MUX_EXTPERIPH4,
1259	TEGRA_MUX_SPI4,
1260	TEGRA_MUX_CCLA,
1261	TEGRA_MUX_I2S2,
1262	TEGRA_MUX_I2S1,
1263	TEGRA_MUX_I2S8,
1264	TEGRA_MUX_I2S3,
1265	TEGRA_MUX_RSVD2,
1266	TEGRA_MUX_DMIC5,
1267	TEGRA_MUX_DCA,
1268	TEGRA_MUX_DISPLAYB,
1269	TEGRA_MUX_DISPLAYA,
1270	TEGRA_MUX_VI1,
1271	TEGRA_MUX_DCB,
1272	TEGRA_MUX_DMIC1,
1273	TEGRA_MUX_DMIC4,
1274	TEGRA_MUX_I2S7,
1275	TEGRA_MUX_DMIC2,
1276	TEGRA_MUX_DSPK0,
1277	TEGRA_MUX_RSVD3,
1278	TEGRA_MUX_TSC_ALT,
1279	TEGRA_MUX_ISTCTRL,
1280	TEGRA_MUX_VI1_ALT,
1281	TEGRA_MUX_DSPK1,
1282	TEGRA_MUX_IGPU,
1283};
1284
1285/* Make list of each function name */
1286#define TEGRA_PIN_FUNCTION(lid) #lid
1287
1288static const char * const tegra234_functions[] = {
1289	TEGRA_PIN_FUNCTION(gp),
1290	TEGRA_PIN_FUNCTION(uartc),
1291	TEGRA_PIN_FUNCTION(i2c8),
1292	TEGRA_PIN_FUNCTION(spi2),
1293	TEGRA_PIN_FUNCTION(i2c2),
1294	TEGRA_PIN_FUNCTION(can1),
1295	TEGRA_PIN_FUNCTION(can0),
1296	TEGRA_PIN_FUNCTION(rsvd0),
1297	TEGRA_PIN_FUNCTION(eth0),
1298	TEGRA_PIN_FUNCTION(eth2),
1299	TEGRA_PIN_FUNCTION(eth1),
1300	TEGRA_PIN_FUNCTION(dp),
1301	TEGRA_PIN_FUNCTION(eth3),
1302	TEGRA_PIN_FUNCTION(i2c4),
1303	TEGRA_PIN_FUNCTION(i2c7),
1304	TEGRA_PIN_FUNCTION(i2c9),
1305	TEGRA_PIN_FUNCTION(eqos),
1306	TEGRA_PIN_FUNCTION(pe2),
1307	TEGRA_PIN_FUNCTION(pe1),
1308	TEGRA_PIN_FUNCTION(pe0),
1309	TEGRA_PIN_FUNCTION(pe3),
1310	TEGRA_PIN_FUNCTION(pe4),
1311	TEGRA_PIN_FUNCTION(pe5),
1312	TEGRA_PIN_FUNCTION(pe6),
1313	TEGRA_PIN_FUNCTION(pe10),
1314	TEGRA_PIN_FUNCTION(pe7),
1315	TEGRA_PIN_FUNCTION(pe8),
1316	TEGRA_PIN_FUNCTION(pe9),
1317	TEGRA_PIN_FUNCTION(qspi0),
1318	TEGRA_PIN_FUNCTION(qspi1),
1319	TEGRA_PIN_FUNCTION(qspi),
1320	TEGRA_PIN_FUNCTION(sdmmc1),
1321	TEGRA_PIN_FUNCTION(sce),
1322	TEGRA_PIN_FUNCTION(soc),
1323	TEGRA_PIN_FUNCTION(gpio),
1324	TEGRA_PIN_FUNCTION(hdmi),
1325	TEGRA_PIN_FUNCTION(ufs0),
1326	TEGRA_PIN_FUNCTION(spi3),
1327	TEGRA_PIN_FUNCTION(spi1),
1328	TEGRA_PIN_FUNCTION(uartb),
1329	TEGRA_PIN_FUNCTION(uarte),
1330	TEGRA_PIN_FUNCTION(usb),
1331	TEGRA_PIN_FUNCTION(extperiph2),
1332	TEGRA_PIN_FUNCTION(extperiph1),
1333	TEGRA_PIN_FUNCTION(i2c3),
1334	TEGRA_PIN_FUNCTION(vi0),
1335	TEGRA_PIN_FUNCTION(i2c5),
1336	TEGRA_PIN_FUNCTION(uarta),
1337	TEGRA_PIN_FUNCTION(uartd),
1338	TEGRA_PIN_FUNCTION(i2c1),
1339	TEGRA_PIN_FUNCTION(i2s4),
1340	TEGRA_PIN_FUNCTION(i2s6),
1341	TEGRA_PIN_FUNCTION(aud),
1342	TEGRA_PIN_FUNCTION(spi5),
1343	TEGRA_PIN_FUNCTION(touch),
1344	TEGRA_PIN_FUNCTION(uartj),
1345	TEGRA_PIN_FUNCTION(rsvd1),
1346	TEGRA_PIN_FUNCTION(wdt),
1347	TEGRA_PIN_FUNCTION(tsc),
1348	TEGRA_PIN_FUNCTION(dmic3),
1349	TEGRA_PIN_FUNCTION(led),
1350	TEGRA_PIN_FUNCTION(vi0_alt),
1351	TEGRA_PIN_FUNCTION(i2s5),
1352	TEGRA_PIN_FUNCTION(nv),
1353	TEGRA_PIN_FUNCTION(extperiph3),
1354	TEGRA_PIN_FUNCTION(extperiph4),
1355	TEGRA_PIN_FUNCTION(spi4),
1356	TEGRA_PIN_FUNCTION(ccla),
1357	TEGRA_PIN_FUNCTION(i2s2),
1358	TEGRA_PIN_FUNCTION(i2s1),
1359	TEGRA_PIN_FUNCTION(i2s8),
1360	TEGRA_PIN_FUNCTION(i2s3),
1361	TEGRA_PIN_FUNCTION(rsvd2),
1362	TEGRA_PIN_FUNCTION(dmic5),
1363	TEGRA_PIN_FUNCTION(dca),
1364	TEGRA_PIN_FUNCTION(displayb),
1365	TEGRA_PIN_FUNCTION(displaya),
1366	TEGRA_PIN_FUNCTION(vi1),
1367	TEGRA_PIN_FUNCTION(dcb),
1368	TEGRA_PIN_FUNCTION(dmic1),
1369	TEGRA_PIN_FUNCTION(dmic4),
1370	TEGRA_PIN_FUNCTION(i2s7),
1371	TEGRA_PIN_FUNCTION(dmic2),
1372	TEGRA_PIN_FUNCTION(dspk0),
1373	TEGRA_PIN_FUNCTION(rsvd3),
1374	TEGRA_PIN_FUNCTION(tsc_alt),
1375	TEGRA_PIN_FUNCTION(istctrl),
1376	TEGRA_PIN_FUNCTION(vi1_alt),
1377	TEGRA_PIN_FUNCTION(dspk1),
1378	TEGRA_PIN_FUNCTION(igpu),
1379};
1380
1381#define PINGROUP_REG_Y(r) ((r))
1382#define PINGROUP_REG_N(r) -1
1383
1384#define DRV_PINGROUP_Y(r) ((r))
1385#define DRV_PINGROUP_N(r) -1
1386
1387#define DRV_PINGROUP_ENTRY_N(pg_name)				\
1388		.drv_reg = -1,					\
1389		.drv_bank = -1,					\
1390		.drvdn_bit = -1,				\
1391		.drvup_bit = -1,				\
1392		.slwr_bit = -1,					\
1393		.slwf_bit = -1
1394
1395#define DRV_PINGROUP_ENTRY_Y(r, drvdn_b, drvdn_w, drvup_b,	\
1396			     drvup_w, slwr_b, slwr_w, slwf_b,	\
1397			     slwf_w, bank)			\
1398		.drv_reg = DRV_PINGROUP_Y(r),			\
1399		.drv_bank = bank,				\
1400		.drvdn_bit = drvdn_b,				\
1401		.drvdn_width = drvdn_w,				\
1402		.drvup_bit = drvup_b,				\
1403		.drvup_width = drvup_w,				\
1404		.slwr_bit = slwr_b,				\
1405		.slwr_width = slwr_w,				\
1406		.slwf_bit = slwf_b,				\
1407		.slwf_width = slwf_w
1408
1409#define PIN_PINGROUP_ENTRY_N(pg_name)				\
1410		.mux_reg = -1,					\
1411		.pupd_reg = -1,					\
1412		.tri_reg = -1,					\
1413		.einput_bit = -1,				\
1414		.e_io_hv_bit = -1,				\
1415		.odrain_bit = -1,				\
1416		.lock_bit = -1,					\
1417		.parked_bit = -1,				\
1418		.lpmd_bit = -1,					\
1419		.drvtype_bit = -1,				\
1420		.lpdr_bit = -1,					\
1421		.pbias_buf_bit = -1,				\
1422		.preemp_bit = -1,				\
1423		.rfu_in_bit = -1
1424
1425#define PIN_PINGROUP_ENTRY_Y(r, bank, pupd, e_io_hv, e_lpbk, e_input,	\
1426				e_lpdr, e_pbias_buf, gpio_sfio_sel,	\
1427				schmitt_b)				\
1428		.mux_reg = PINGROUP_REG_Y(r),			\
1429		.lpmd_bit = -1,					\
1430		.lock_bit = -1,					\
1431		.hsm_bit = -1,					\
1432		.mux_bank = bank,				\
1433		.mux_bit = 0,					\
1434		.pupd_reg = PINGROUP_REG_##pupd(r),		\
1435		.pupd_bank = bank,				\
1436		.pupd_bit = 2,					\
1437		.tri_reg = PINGROUP_REG_Y(r),			\
1438		.tri_bank = bank,				\
1439		.tri_bit = 4,					\
1440		.einput_bit = e_input,				\
1441		.sfsel_bit = gpio_sfio_sel,			\
1442		.schmitt_bit = schmitt_b,			\
1443		.drvtype_bit = 13,				\
1444		.lpdr_bit = e_lpdr,				\
1445
1446/* main drive pin groups */
1447#define	drive_soc_gpio08_pb0			DRV_PINGROUP_ENTRY_Y(0x500c,	12,	5,	20,	5,	-1,	-1,	-1,	-1,	0)
1448#define	drive_soc_gpio36_pm5			DRV_PINGROUP_ENTRY_Y(0x10004,	12,	5,	20,	5,	-1,	-1,	-1,	-1,	0)
1449#define	drive_soc_gpio53_pm6			DRV_PINGROUP_ENTRY_Y(0x1000c,	12,	5,	20,	5,	-1,	-1,	-1,	-1,	0)
1450#define	drive_soc_gpio55_pm4			DRV_PINGROUP_ENTRY_Y(0x10014,	12,	5,	20,	5,	-1,	-1,	-1,	-1,	0)
1451#define	drive_soc_gpio38_pm7			DRV_PINGROUP_ENTRY_Y(0x1001c,	12,	5,	20,	5,	-1,	-1,	-1,	-1,	0)
1452#define	drive_soc_gpio39_pn1			DRV_PINGROUP_ENTRY_Y(0x10024,	12,	5,	20,	5,	-1,	-1,	-1,	-1,	0)
1453#define	drive_soc_gpio40_pn2			DRV_PINGROUP_ENTRY_Y(0x1002c,	12,	5,	20,	5,	-1,	-1,	-1,	-1,	0)
1454#define	drive_dp_aux_ch0_hpd_pm0		DRV_PINGROUP_ENTRY_Y(0x10034,	12,	5,	20,	5,	-1,	-1,	-1,	-1,	0)
1455#define	drive_dp_aux_ch1_hpd_pm1		DRV_PINGROUP_ENTRY_Y(0x1003c,	12,	5,	20,	5,	-1,	-1,	-1,	-1,	0)
1456#define	drive_dp_aux_ch2_hpd_pm2		DRV_PINGROUP_ENTRY_Y(0x10044,	12,	5,	20,	5,	-1,	-1,	-1,	-1,	0)
1457#define	drive_dp_aux_ch3_hpd_pm3		DRV_PINGROUP_ENTRY_Y(0x1004c,	12,	5,	20,	5,	-1,	-1,	-1,	-1,	0)
1458#define	drive_dp_aux_ch1_p_pn3			DRV_PINGROUP_ENTRY_Y(0x10054,	12,	5,	20,	5,	-1,	-1,	-1,	-1,	0)
1459#define	drive_dp_aux_ch1_n_pn4			DRV_PINGROUP_ENTRY_Y(0x1005c,	12,	5,	20,	5,	-1,	-1,	-1,	-1,	0)
1460#define	drive_dp_aux_ch2_p_pn5			DRV_PINGROUP_ENTRY_Y(0x10064,	12,	5,	20,	5,	-1,	-1,	-1,	-1,	0)
1461#define	drive_dp_aux_ch2_n_pn6			DRV_PINGROUP_ENTRY_Y(0x1006c,	12,	5,	20,	5,	-1,	-1,	-1,	-1,	0)
1462#define	drive_dp_aux_ch3_p_pn7			DRV_PINGROUP_ENTRY_Y(0x10074,	12,	5,	20,	5,	-1,	-1,	-1,	-1,	0)
1463#define	drive_dp_aux_ch3_n_pn0			DRV_PINGROUP_ENTRY_Y(0x1007c,	12,	5,	20,	5,	-1,	-1,	-1,	-1,	0)
1464#define	drive_pex_l2_clkreq_n_pk4		DRV_PINGROUP_ENTRY_Y(0x7004,	12,	5,	20,	5,	-1,	-1,	-1,	-1,	0)
1465#define	drive_pex_wake_n_pl2			DRV_PINGROUP_ENTRY_Y(0x700c,	12,	5,	20,	5,	-1,	-1,	-1,	-1,	0)
1466#define	drive_pex_l1_clkreq_n_pk2		DRV_PINGROUP_ENTRY_Y(0x7014,	12,	5,	20,	5,	-1,	-1,	-1,	-1,	0)
1467#define	drive_pex_l1_rst_n_pk3			DRV_PINGROUP_ENTRY_Y(0x701c,	12,	5,	20,	5,	-1,	-1,	-1,	-1,	0)
1468#define	drive_pex_l0_clkreq_n_pk0		DRV_PINGROUP_ENTRY_Y(0x7024,	12,	5,	20,	5,	-1,	-1,	-1,	-1,	0)
1469#define	drive_pex_l0_rst_n_pk1			DRV_PINGROUP_ENTRY_Y(0x702c,	12,	5,	20,	5,	-1,	-1,	-1,	-1,	0)
1470#define	drive_pex_l2_rst_n_pk5			DRV_PINGROUP_ENTRY_Y(0x7034,	12,	5,	20,	5,	-1,	-1,	-1,	-1,	0)
1471#define	drive_pex_l3_clkreq_n_pk6		DRV_PINGROUP_ENTRY_Y(0x703c,	12,	5,	20,	5,	-1,	-1,	-1,	-1,	0)
1472#define	drive_pex_l3_rst_n_pk7			DRV_PINGROUP_ENTRY_Y(0x7044,	12,	5,	20,	5,	-1,	-1,	-1,	-1,	0)
1473#define	drive_pex_l4_clkreq_n_pl0		DRV_PINGROUP_ENTRY_Y(0x704c,	12,	5,	20,	5,	-1,	-1,	-1,	-1,	0)
1474#define	drive_pex_l4_rst_n_pl1			DRV_PINGROUP_ENTRY_Y(0x7054,	12,	5,	20,	5,	-1,	-1,	-1,	-1,	0)
1475#define	drive_soc_gpio34_pl3			DRV_PINGROUP_ENTRY_Y(0x705c,	12,	5,	20,	5,	-1,	-1,	-1,	-1,	0)
1476#define	drive_pex_l5_clkreq_n_paf0		DRV_PINGROUP_ENTRY_Y(0x14004,	12,	5,	20,	5,	-1,	-1,	-1,	-1,	0)
1477#define	drive_pex_l5_rst_n_paf1			DRV_PINGROUP_ENTRY_Y(0x1400c,	12,	5,	20,	5,	-1,	-1,	-1,	-1,	0)
1478#define	drive_pex_l6_clkreq_n_paf2		DRV_PINGROUP_ENTRY_Y(0x14014,	12,	5,	20,	5,	-1,	-1,	-1,	-1,	0)
1479#define	drive_pex_l6_rst_n_paf3			DRV_PINGROUP_ENTRY_Y(0x1401c,	12,	5,	20,	5,	-1,	-1,	-1,	-1,	0)
1480#define	drive_pex_l10_clkreq_n_pag6		DRV_PINGROUP_ENTRY_Y(0x19004,	12,	5,	20,	5,	-1,	-1,	-1,	-1,	0)
1481#define	drive_pex_l10_rst_n_pag7		DRV_PINGROUP_ENTRY_Y(0x1900c,	12,	5,	20,	5,	-1,	-1,	-1,	-1,	0)
1482#define	drive_pex_l7_clkreq_n_pag0		DRV_PINGROUP_ENTRY_Y(0x19014,	12,	5,	20,	5,	-1,	-1,	-1,	-1,	0)
1483#define	drive_pex_l7_rst_n_pag1			DRV_PINGROUP_ENTRY_Y(0x1901c,	12,	5,	20,	5,	-1,	-1,	-1,	-1,	0)
1484#define	drive_pex_l8_clkreq_n_pag2		DRV_PINGROUP_ENTRY_Y(0x19024,	12,	5,	20,	5,	-1,	-1,	-1,	-1,	0)
1485#define	drive_pex_l8_rst_n_pag3			DRV_PINGROUP_ENTRY_Y(0x1902c,	12,	5,	20,	5,	-1,	-1,	-1,	-1,	0)
1486#define	drive_pex_l9_clkreq_n_pag4		DRV_PINGROUP_ENTRY_Y(0x19034,	12,	5,	20,	5,	-1,	-1,	-1,	-1,	0)
1487#define	drive_pex_l9_rst_n_pag5			DRV_PINGROUP_ENTRY_Y(0x1903c,	12,	5,	20,	5,	-1,	-1,	-1,	-1,	0)
1488#define	drive_sdmmc1_clk_pj0			DRV_PINGROUP_ENTRY_Y(0x8004,	28,	2,	30,	2,	-1,	-1,	-1,	-1,	0)
1489#define	drive_sdmmc1_cmd_pj1			DRV_PINGROUP_ENTRY_Y(0x800c,	28,	2,	30,	2,	-1,	-1,	-1,	-1,	0)
1490#define	drive_sdmmc1_dat3_pj5			DRV_PINGROUP_ENTRY_Y(0x801c,	28,	2,	30,	2,	-1,	-1,	-1,	-1,	0)
1491#define	drive_sdmmc1_dat2_pj4			DRV_PINGROUP_ENTRY_Y(0x8024,	28,	2,	30,	2,	-1,	-1,	-1,	-1,	0)
1492#define	drive_sdmmc1_dat1_pj3			DRV_PINGROUP_ENTRY_Y(0x802c,	28,	2,	30,	2,	-1,	-1,	-1,	-1,	0)
1493#define	drive_sdmmc1_dat0_pj2			DRV_PINGROUP_ENTRY_Y(0x8034,	28,	2,	30,	2,	-1,	-1,	-1,	-1,	0)
1494#define	drive_ufs0_rst_n_pae1			DRV_PINGROUP_ENTRY_Y(0x11004,	12,	5,	24,	5,	-1,	-1,	-1,	-1,	0)
1495#define	drive_ufs0_ref_clk_pae0			DRV_PINGROUP_ENTRY_Y(0x1100c,	12,	5,	24,	5,	-1,	-1,	-1,	-1,	0)
1496#define	drive_spi3_miso_py1			DRV_PINGROUP_ENTRY_Y(0xd004,	12,	5,	20,	5,	-1,	-1,	-1,	-1,	0)
1497#define	drive_spi1_cs0_pz6			DRV_PINGROUP_ENTRY_Y(0xd00c,	12,	5,	20,	5,	-1,	-1,	-1,	-1,	0)
1498#define	drive_spi3_cs0_py3			DRV_PINGROUP_ENTRY_Y(0xd014,	12,	5,	20,	5,	-1,	-1,	-1,	-1,	0)
1499#define	drive_spi1_miso_pz4			DRV_PINGROUP_ENTRY_Y(0xd01c,	12,	5,	20,	5,	-1,	-1,	-1,	-1,	0)
1500#define	drive_spi3_cs1_py4			DRV_PINGROUP_ENTRY_Y(0xd024,	12,	5,	20,	5,	-1,	-1,	-1,	-1,	0)
1501#define	drive_spi1_sck_pz3			DRV_PINGROUP_ENTRY_Y(0xd02c,	12,	5,	20,	5,	-1,	-1,	-1,	-1,	0)
1502#define	drive_spi3_sck_py0			DRV_PINGROUP_ENTRY_Y(0xd034,	12,	5,	20,	5,	-1,	-1,	-1,	-1,	0)
1503#define	drive_spi1_cs1_pz7			DRV_PINGROUP_ENTRY_Y(0xd03c,	12,	5,	20,	5,	-1,	-1,	-1,	-1,	0)
1504#define	drive_spi1_mosi_pz5			DRV_PINGROUP_ENTRY_Y(0xd044,	12,	5,	20,	5,	-1,	-1,	-1,	-1,	0)
1505#define	drive_spi3_mosi_py2			DRV_PINGROUP_ENTRY_Y(0xd04c,	12,	5,	20,	5,	-1,	-1,	-1,	-1,	0)
1506#define	drive_uart2_tx_px4			DRV_PINGROUP_ENTRY_Y(0xd054,	12,	5,	20,	5,	-1,	-1,	-1,	-1,	0)
1507#define	drive_uart2_rx_px5			DRV_PINGROUP_ENTRY_Y(0xd05c,	12,	5,	20,	5,	-1,	-1,	-1,	-1,	0)
1508#define	drive_uart2_rts_px6			DRV_PINGROUP_ENTRY_Y(0xd064,	12,	5,	20,	5,	-1,	-1,	-1,	-1,	0)
1509#define	drive_uart2_cts_px7			DRV_PINGROUP_ENTRY_Y(0xd06c,	12,	5,	20,	5,	-1,	-1,	-1,	-1,	0)
1510#define	drive_uart5_tx_py5			DRV_PINGROUP_ENTRY_Y(0xd074,	12,	5,	20,	5,	-1,	-1,	-1,	-1,	0)
1511#define	drive_uart5_rx_py6			DRV_PINGROUP_ENTRY_Y(0xd07c,	12,	5,	20,	5,	-1,	-1,	-1,	-1,	0)
1512#define	drive_uart5_rts_py7			DRV_PINGROUP_ENTRY_Y(0xd084,	12,	5,	20,	5,	-1,	-1,	-1,	-1,	0)
1513#define	drive_uart5_cts_pz0			DRV_PINGROUP_ENTRY_Y(0xd08c,	12,	5,	20,	5,	-1,	-1,	-1,	-1,	0)
1514#define	drive_gpu_pwr_req_px0			DRV_PINGROUP_ENTRY_Y(0xd094,	12,	5,	20,	5,	-1,	-1,	-1,	-1,	0)
1515#define	drive_gp_pwm3_px3			DRV_PINGROUP_ENTRY_Y(0xd09c,	12,	5,	20,	5,	-1,	-1,	-1,	-1,	0)
1516#define	drive_gp_pwm2_px2			DRV_PINGROUP_ENTRY_Y(0xd0a4,	12,	5,	20,	5,	-1,	-1,	-1,	-1,	0)
1517#define	drive_cv_pwr_req_px1			DRV_PINGROUP_ENTRY_Y(0xd0ac,	12,	5,	20,	5,	-1,	-1,	-1,	-1,	0)
1518#define	drive_usb_vbus_en0_pz1			DRV_PINGROUP_ENTRY_Y(0xd0b4,	12,	5,	20,	5,	-1,	-1,	-1,	-1,	0)
1519#define	drive_usb_vbus_en1_pz2			DRV_PINGROUP_ENTRY_Y(0xd0bc,	12,	5,	20,	5,	-1,	-1,	-1,	-1,	0)
1520#define	drive_extperiph2_clk_pp1		DRV_PINGROUP_ENTRY_Y(0x0004,	12,	5,	20,	5,	-1,	-1,	-1,	-1,	0)
1521#define	drive_extperiph1_clk_pp0		DRV_PINGROUP_ENTRY_Y(0x000c,	12,	5,	20,	5,	-1,	-1,	-1,	-1,	0)
1522#define	drive_cam_i2c_sda_pp3			DRV_PINGROUP_ENTRY_Y(0x0014,	12,	5,	20,	5,	-1,	-1,	-1,	-1,	0)
1523#define	drive_cam_i2c_scl_pp2			DRV_PINGROUP_ENTRY_Y(0x001c,	12,	5,	20,	5,	-1,	-1,	-1,	-1,	0)
1524#define	drive_soc_gpio23_pp4			DRV_PINGROUP_ENTRY_Y(0x0024,	12,	5,	20,	5,	-1,	-1,	-1,	-1,	0)
1525#define	drive_soc_gpio24_pp5			DRV_PINGROUP_ENTRY_Y(0x002c,	12,	5,	20,	5,	-1,	-1,	-1,	-1,	0)
1526#define	drive_soc_gpio25_pp6			DRV_PINGROUP_ENTRY_Y(0x0034,	12,	5,	20,	5,	-1,	-1,	-1,	-1,	0)
1527#define	drive_pwr_i2c_scl_pp7			DRV_PINGROUP_ENTRY_Y(0x003c,	12,	5,	20,	5,	-1,	-1,	-1,	-1,	0)
1528#define	drive_pwr_i2c_sda_pq0			DRV_PINGROUP_ENTRY_Y(0x0044,	12,	5,	20,	5,	-1,	-1,	-1,	-1,	0)
1529#define	drive_soc_gpio28_pq1			DRV_PINGROUP_ENTRY_Y(0x004c,	12,	5,	20,	5,	-1,	-1,	-1,	-1,	0)
1530#define	drive_soc_gpio29_pq2			DRV_PINGROUP_ENTRY_Y(0x0054,	12,	5,	20,	5,	-1,	-1,	-1,	-1,	0)
1531#define	drive_soc_gpio30_pq3			DRV_PINGROUP_ENTRY_Y(0x005c,	12,	5,	20,	5,	-1,	-1,	-1,	-1,	0)
1532#define	drive_soc_gpio31_pq4			DRV_PINGROUP_ENTRY_Y(0x0064,	12,	5,	20,	5,	-1,	-1,	-1,	-1,	0)
1533#define	drive_soc_gpio32_pq5			DRV_PINGROUP_ENTRY_Y(0x006c,	12,	5,	20,	5,	-1,	-1,	-1,	-1,	0)
1534#define	drive_soc_gpio33_pq6			DRV_PINGROUP_ENTRY_Y(0x0074,	12,	5,	20,	5,	-1,	-1,	-1,	-1,	0)
1535#define	drive_soc_gpio35_pq7			DRV_PINGROUP_ENTRY_Y(0x007c,	12,	5,	20,	5,	-1,	-1,	-1,	-1,	0)
1536#define	drive_soc_gpio37_pr0			DRV_PINGROUP_ENTRY_Y(0x0084,	12,	5,	20,	5,	-1,	-1,	-1,	-1,	0)
1537#define	drive_soc_gpio56_pr1			DRV_PINGROUP_ENTRY_Y(0x008c,	12,	5,	20,	5,	-1,	-1,	-1,	-1,	0)
1538#define	drive_uart1_cts_pr5			DRV_PINGROUP_ENTRY_Y(0x0094,	12,	5,	20,	5,	-1,	-1,	-1,	-1,	0)
1539#define	drive_uart1_rts_pr4			DRV_PINGROUP_ENTRY_Y(0x009c,	12,	5,	20,	5,	-1,	-1,	-1,	-1,	0)
1540#define	drive_uart1_rx_pr3			DRV_PINGROUP_ENTRY_Y(0x00a4,	12,	5,	20,	5,	-1,	-1,	-1,	-1,	0)
1541#define	drive_uart1_tx_pr2			DRV_PINGROUP_ENTRY_Y(0x00ac,	12,	5,	20,	5,	-1,	-1,	-1,	-1,	0)
1542#define	drive_cpu_pwr_req_pi5			DRV_PINGROUP_ENTRY_Y(0x4004,	12,	5,	20,	5,	-1,	-1,	-1,	-1,	0)
1543#define	drive_uart4_cts_ph6			DRV_PINGROUP_ENTRY_Y(0x400c,	12,	5,	20,	5,	-1,	-1,	-1,	-1,	0)
1544#define	drive_uart4_rts_ph5			DRV_PINGROUP_ENTRY_Y(0x4014,	12,	5,	20,	5,	-1,	-1,	-1,	-1,	0)
1545#define	drive_uart4_rx_ph4			DRV_PINGROUP_ENTRY_Y(0x401c,	12,	5,	20,	5,	-1,	-1,	-1,	-1,	0)
1546#define	drive_uart4_tx_ph3			DRV_PINGROUP_ENTRY_Y(0x4024,	12,	5,	20,	5,	-1,	-1,	-1,	-1,	0)
1547#define	drive_gen1_i2c_scl_pi3			DRV_PINGROUP_ENTRY_Y(0x402c,	12,	5,	20,	5,	-1,	-1,	-1,	-1,	0)
1548#define	drive_gen1_i2c_sda_pi4			DRV_PINGROUP_ENTRY_Y(0x4034,	12,	5,	20,	5,	-1,	-1,	-1,	-1,	0)
1549#define	drive_soc_gpio20_pg7			DRV_PINGROUP_ENTRY_Y(0x403c,	12,	5,	20,	5,	-1,	-1,	-1,	-1,	0)
1550#define	drive_soc_gpio21_ph0			DRV_PINGROUP_ENTRY_Y(0x4044,	12,	5,	20,	5,	-1,	-1,	-1,	-1,	0)
1551#define	drive_soc_gpio22_ph1			DRV_PINGROUP_ENTRY_Y(0x404c,	12,	5,	20,	5,	-1,	-1,	-1,	-1,	0)
1552#define	drive_soc_gpio13_pg0			DRV_PINGROUP_ENTRY_Y(0x4054,	12,	5,	20,	5,	-1,	-1,	-1,	-1,	0)
1553#define	drive_soc_gpio14_pg1			DRV_PINGROUP_ENTRY_Y(0x405c,	12,	5,	20,	5,	-1,	-1,	-1,	-1,	0)
1554#define	drive_soc_gpio15_pg2			DRV_PINGROUP_ENTRY_Y(0x4064,	12,	5,	20,	5,	-1,	-1,	-1,	-1,	0)
1555#define	drive_soc_gpio16_pg3			DRV_PINGROUP_ENTRY_Y(0x406c,	12,	5,	20,	5,	-1,	-1,	-1,	-1,	0)
1556#define	drive_soc_gpio17_pg4			DRV_PINGROUP_ENTRY_Y(0x4074,	12,	5,	20,	5,	-1,	-1,	-1,	-1,	0)
1557#define	drive_soc_gpio18_pg5			DRV_PINGROUP_ENTRY_Y(0x407c,	12,	5,	20,	5,	-1,	-1,	-1,	-1,	0)
1558#define	drive_soc_gpio19_pg6			DRV_PINGROUP_ENTRY_Y(0x4084,	12,	5,	20,	5,	-1,	-1,	-1,	-1,	0)
1559#define	drive_soc_gpio41_ph7			DRV_PINGROUP_ENTRY_Y(0x408c,	12,	5,	20,	5,	-1,	-1,	-1,	-1,	0)
1560#define	drive_soc_gpio42_pi0			DRV_PINGROUP_ENTRY_Y(0x4094,	12,	5,	20,	5,	-1,	-1,	-1,	-1,	0)
1561#define	drive_soc_gpio43_pi1			DRV_PINGROUP_ENTRY_Y(0x409c,	12,	5,	20,	5,	-1,	-1,	-1,	-1,	0)
1562#define	drive_soc_gpio44_pi2			DRV_PINGROUP_ENTRY_Y(0x40a4,	12,	5,	20,	5,	-1,	-1,	-1,	-1,	0)
1563#define	drive_soc_gpio06_ph2			DRV_PINGROUP_ENTRY_Y(0x40ac,	12,	5,	20,	5,	-1,	-1,	-1,	-1,	0)
1564#define	drive_soc_gpio07_pi6			DRV_PINGROUP_ENTRY_Y(0x40b4,	12,	5,	20,	5,	-1,	-1,	-1,	-1,	0)
1565#define	drive_dap4_sclk_pa4			DRV_PINGROUP_ENTRY_Y(0x2004,	12,	5,	20,	5,	-1,	-1,	-1,	-1,	0)
1566#define	drive_dap4_dout_pa5			DRV_PINGROUP_ENTRY_Y(0x200c,	12,	5,	20,	5,	-1,	-1,	-1,	-1,	0)
1567#define	drive_dap4_din_pa6			DRV_PINGROUP_ENTRY_Y(0x2014,	12,	5,	20,	5,	-1,	-1,	-1,	-1,	0)
1568#define	drive_dap4_fs_pa7			DRV_PINGROUP_ENTRY_Y(0x201c,	12,	5,	20,	5,	-1,	-1,	-1,	-1,	0)
1569#define	drive_dap6_sclk_pa0			DRV_PINGROUP_ENTRY_Y(0x2024,	12,	5,	20,	5,	-1,	-1,	-1,	-1,	0)
1570#define	drive_dap6_dout_pa1			DRV_PINGROUP_ENTRY_Y(0x202c,	12,	5,	20,	5,	-1,	-1,	-1,	-1,	0)
1571#define	drive_dap6_din_pa2			DRV_PINGROUP_ENTRY_Y(0x2034,	12,	5,	20,	5,	-1,	-1,	-1,	-1,	0)
1572#define	drive_dap6_fs_pa3			DRV_PINGROUP_ENTRY_Y(0x203c,	12,	5,	20,	5,	-1,	-1,	-1,	-1,	0)
1573#define	drive_soc_gpio45_pad0			DRV_PINGROUP_ENTRY_Y(0x18004,	12,	5,	20,	5,	-1,	-1,	-1,	-1,	0)
1574#define	drive_soc_gpio46_pad1			DRV_PINGROUP_ENTRY_Y(0x1800c,	12,	5,	20,	5,	-1,	-1,	-1,	-1,	0)
1575#define	drive_soc_gpio47_pad2			DRV_PINGROUP_ENTRY_Y(0x18014,	12,	5,	20,	5,	-1,	-1,	-1,	-1,	0)
1576#define	drive_soc_gpio48_pad3			DRV_PINGROUP_ENTRY_Y(0x1801c,	12,	5,	20,	5,	-1,	-1,	-1,	-1,	0)
1577#define	drive_soc_gpio57_pac4			DRV_PINGROUP_ENTRY_Y(0x18024,	12,	5,	20,	5,	-1,	-1,	-1,	-1,	0)
1578#define	drive_soc_gpio58_pac5			DRV_PINGROUP_ENTRY_Y(0x1802c,	12,	5,	20,	5,	-1,	-1,	-1,	-1,	0)
1579#define	drive_soc_gpio59_pac6			DRV_PINGROUP_ENTRY_Y(0x18034,	12,	5,	20,	5,	-1,	-1,	-1,	-1,	0)
1580#define	drive_soc_gpio60_pac7			DRV_PINGROUP_ENTRY_Y(0x1803c,	12,	5,	20,	5,	-1,	-1,	-1,	-1,	0)
1581#define	drive_spi5_cs0_pac3			DRV_PINGROUP_ENTRY_Y(0x18044,	12,	5,	20,	5,	-1,	-1,	-1,	-1,	0)
1582#define	drive_spi5_miso_pac1			DRV_PINGROUP_ENTRY_Y(0x1804c,	12,	5,	20,	5,	-1,	-1,	-1,	-1,	0)
1583#define	drive_spi5_mosi_pac2			DRV_PINGROUP_ENTRY_Y(0x18054,	12,	5,	20,	5,	-1,	-1,	-1,	-1,	0)
1584#define	drive_spi5_sck_pac0			DRV_PINGROUP_ENTRY_Y(0x1805c,	12,	5,	20,	5,	-1,	-1,	-1,	-1,	0)
1585#define	drive_eqos_td3_pe4			DRV_PINGROUP_ENTRY_N(no_entry)
1586#define	drive_eqos_td2_pe3			DRV_PINGROUP_ENTRY_N(no_entry)
1587#define	drive_eqos_td1_pe2			DRV_PINGROUP_ENTRY_N(no_entry)
1588#define	drive_eqos_td0_pe1			DRV_PINGROUP_ENTRY_N(no_entry)
1589#define	drive_eqos_rd3_pf1			DRV_PINGROUP_ENTRY_N(no_entry)
1590#define	drive_eqos_rd2_pf0			DRV_PINGROUP_ENTRY_N(no_entry)
1591#define	drive_eqos_rd1_pe7			DRV_PINGROUP_ENTRY_N(no_entry)
1592#define	drive_eqos_sma_mdio_pf4			DRV_PINGROUP_ENTRY_N(no_entry)
1593#define	drive_eqos_rd0_pe6			DRV_PINGROUP_ENTRY_N(no_entry)
1594#define	drive_eqos_sma_mdc_pf5			DRV_PINGROUP_ENTRY_N(no_entry)
1595#define	drive_eqos_comp				DRV_PINGROUP_ENTRY_N(no_entry)
1596#define	drive_eqos_txc_pe0			DRV_PINGROUP_ENTRY_N(no_entry)
1597#define	drive_eqos_rxc_pf3			DRV_PINGROUP_ENTRY_N(no_entry)
1598#define	drive_eqos_tx_ctl_pe5			DRV_PINGROUP_ENTRY_N(no_entry)
1599#define	drive_eqos_rx_ctl_pf2			DRV_PINGROUP_ENTRY_N(no_entry)
1600#define	drive_qspi0_io3_pc5			DRV_PINGROUP_ENTRY_N(no_entry)
1601#define	drive_qspi0_io2_pc4			DRV_PINGROUP_ENTRY_N(no_entry)
1602#define	drive_qspi0_io1_pc3			DRV_PINGROUP_ENTRY_N(no_entry)
1603#define	drive_qspi0_io0_pc2			DRV_PINGROUP_ENTRY_N(no_entry)
1604#define	drive_qspi0_sck_pc0			DRV_PINGROUP_ENTRY_N(no_entry)
1605#define	drive_qspi0_cs_n_pc1			DRV_PINGROUP_ENTRY_N(no_entry)
1606#define	drive_qspi1_io3_pd3			DRV_PINGROUP_ENTRY_N(no_entry)
1607#define	drive_qspi1_io2_pd2			DRV_PINGROUP_ENTRY_N(no_entry)
1608#define	drive_qspi1_io1_pd1			DRV_PINGROUP_ENTRY_N(no_entry)
1609#define	drive_qspi1_io0_pd0			DRV_PINGROUP_ENTRY_N(no_entry)
1610#define	drive_qspi1_sck_pc6			DRV_PINGROUP_ENTRY_N(no_entry)
1611#define	drive_qspi1_cs_n_pc7			DRV_PINGROUP_ENTRY_N(no_entry)
1612#define	drive_qspi_comp				DRV_PINGROUP_ENTRY_N(no_entry)
1613#define	drive_sdmmc1_comp			DRV_PINGROUP_ENTRY_N(no_entry)
1614
1615#define PINGROUP(pg_name, f0, f1, f2, f3, r, bank, pupd, e_io_hv, e_lpbk, e_input, e_lpdr, e_pbias_buf,	\
1616			gpio_sfio_sel, schmitt_b)							\
1617	{								\
1618		.name = #pg_name,					\
1619		.pins = pg_name##_pins,					\
1620		.npins = ARRAY_SIZE(pg_name##_pins),			\
1621			.funcs = {					\
1622				TEGRA_MUX_##f0,				\
1623				TEGRA_MUX_##f1,				\
1624				TEGRA_MUX_##f2,				\
1625				TEGRA_MUX_##f3,				\
1626			},						\
1627		PIN_PINGROUP_ENTRY_Y(r, bank, pupd, e_io_hv, e_lpbk,	\
1628					e_input, e_lpdr, e_pbias_buf,	\
1629					gpio_sfio_sel, schmitt_b)	\
1630		drive_##pg_name,					\
1631	}
1632
1633static const struct tegra_pingroup tegra234_groups[] = {
1634	PINGROUP(soc_gpio08_pb0,	RSVD0,		RSVD1,		RSVD2,		RSVD3,		0x5008,		0,	Y,	-1,	7,	6,	8,	-1,	10,	12),
1635	PINGROUP(soc_gpio36_pm5,	ETH0,		RSVD1,		DCA,		RSVD3,		0x10000,	0,	Y,	-1,	7,	6,	8,	-1,	10,	12),
1636	PINGROUP(soc_gpio53_pm6,	ETH0,		RSVD1,		DCA,		RSVD3,		0x10008,	0,	Y,	-1,	7,	6,	8,	-1,	10,	12),
1637	PINGROUP(soc_gpio55_pm4,	ETH2,		RSVD1,		RSVD2,		RSVD3,		0x10010,	0,	Y,	-1,	7,	6,	8,	-1,	10,	12),
1638	PINGROUP(soc_gpio38_pm7,	ETH1,		RSVD1,		RSVD2,		RSVD3,		0x10018,	0,	Y,	-1,	7,	6,	8,	-1,	10,	12),
1639	PINGROUP(soc_gpio39_pn1,	GP,		RSVD1,		RSVD2,		RSVD3,		0x10020,	0,	Y,	-1,	7,	6,	8,	-1,	10,	12),
1640	PINGROUP(soc_gpio40_pn2,	ETH1,		RSVD1,		RSVD2,		RSVD3,		0x10028,	0,	Y,	-1,	7,	6,	8,	-1,	10,	12),
1641	PINGROUP(dp_aux_ch0_hpd_pm0,	DP,		RSVD1,		RSVD2,		RSVD3,		0x10030,	0,	Y,	5,	7,	6,	8,	-1,	10,	12),
1642	PINGROUP(dp_aux_ch1_hpd_pm1,	ETH3,		RSVD1,		RSVD2,		RSVD3,		0x10038,	0,	Y,	5,	7,	6,	8,	-1,	10,	12),
1643	PINGROUP(dp_aux_ch2_hpd_pm2,	ETH3,		RSVD1,		DISPLAYB,	RSVD3,		0x10040,	0,	Y,	5,	7,	6,	8,	-1,	10,	12),
1644	PINGROUP(dp_aux_ch3_hpd_pm3,	ETH2,		RSVD1,		DISPLAYA,	RSVD3,		0x10048,	0,	Y,	5,	7,	6,	8,	-1,	10,	12),
1645	PINGROUP(dp_aux_ch1_p_pn3,	I2C4,		RSVD1,		RSVD2,		RSVD3,		0x10050,	0,	Y,	5,	7,	6,	8,	-1,	10,	12),
1646	PINGROUP(dp_aux_ch1_n_pn4,	I2C4,		RSVD1,		RSVD2,		RSVD3,		0x10058,	0,	Y,	5,	7,	6,	8,	-1,	10,	12),
1647	PINGROUP(dp_aux_ch2_p_pn5,	I2C7,		RSVD1,		RSVD2,		RSVD3,		0x10060,	0,	Y,	5,	7,	6,	8,	-1,	10,	12),
1648	PINGROUP(dp_aux_ch2_n_pn6,	I2C7,		RSVD1,		RSVD2,		RSVD3,		0x10068,	0,	Y,	5,	7,	6,	8,	-1,	10,	12),
1649	PINGROUP(dp_aux_ch3_p_pn7,	I2C9,		RSVD1,		RSVD2,		RSVD3,		0x10070,	0,	Y,	5,	7,	6,	8,	-1,	10,	12),
1650	PINGROUP(dp_aux_ch3_n_pn0,	I2C9,		RSVD1,		RSVD2,		RSVD3,		0x10078,	0,	Y,	5,	7,	6,	8,	-1,	10,	12),
1651	PINGROUP(eqos_td3_pe4,		EQOS,		RSVD1,		RSVD2,		RSVD3,		0x15000,	0,	Y,	-1,	5,	6,	-1,	-1,	10,	12),
1652	PINGROUP(eqos_td2_pe3,		EQOS,		RSVD1,		RSVD2,		RSVD3,		0x15008,	0,	Y,	-1,	5,	6,	-1,	-1,	10,	12),
1653	PINGROUP(eqos_td1_pe2,		EQOS,		RSVD1,		RSVD2,		RSVD3,		0x15010,	0,	Y,	-1,	5,	6,	-1,	-1,	10,	12),
1654	PINGROUP(eqos_td0_pe1,		EQOS,		RSVD1,		RSVD2,		RSVD3,		0x15018,	0,	Y,	-1,	5,	6,	-1,	-1,	10,	12),
1655	PINGROUP(eqos_rd3_pf1,		EQOS,		RSVD1,		RSVD2,		RSVD3,		0x15020,	0,	Y,	-1,	5,	6,	-1,	-1,	10,	12),
1656	PINGROUP(eqos_rd2_pf0,		EQOS,		RSVD1,		RSVD2,		RSVD3,		0x15028,	0,	Y,	-1,	5,	6,	-1,	-1,	10,	12),
1657	PINGROUP(eqos_rd1_pe7,		EQOS,		RSVD1,		RSVD2,		RSVD3,		0x15030,	0,	Y,	-1,	5,	6,	-1,	-1,	10,	12),
1658	PINGROUP(eqos_sma_mdio_pf4,	EQOS,		RSVD1,		RSVD2,		RSVD3,		0x15038,	0,	Y,	-1,	5,	6,	-1,	-1,	10,	12),
1659	PINGROUP(eqos_rd0_pe6,		EQOS,		RSVD1,		RSVD2,		RSVD3,		0x15040,	0,	Y,	-1,	5,	6,	-1,	-1,	10,	12),
1660	PINGROUP(eqos_sma_mdc_pf5,	EQOS,		RSVD1,		RSVD2,		RSVD3,		0x15048,	0,	Y,	-1,	5,	6,	-1,	-1,	10,	12),
1661	PINGROUP(eqos_comp,		EQOS,		RSVD1,		RSVD2,		RSVD3,		0x15050,	0,	N,	-1,	-1,	-1,	-1,	-1,	-1,	-1),
1662	PINGROUP(eqos_txc_pe0,		EQOS,		RSVD1,		RSVD2,		RSVD3,		0x15058,	0,	Y,	-1,	5,	6,	-1,	-1,	10,	12),
1663	PINGROUP(eqos_rxc_pf3,		EQOS,		RSVD1,		RSVD2,		RSVD3,		0x15060,	0,	Y,	-1,	5,	6,	-1,	-1,	10,	12),
1664	PINGROUP(eqos_tx_ctl_pe5,	EQOS,		RSVD1,		RSVD2,		RSVD3,		0x15068,	0,	Y,	-1,	5,	6,	-1,	-1,	10,	12),
1665	PINGROUP(eqos_rx_ctl_pf2,	EQOS,		RSVD1,		RSVD2,		RSVD3,		0x15070,	0,	Y,	-1,	5,	6,	-1,	-1,	10,	12),
1666	PINGROUP(pex_l2_clkreq_n_pk4,	PE2,		RSVD1,		RSVD2,		RSVD3,		0x7000,		0,	Y,	5,	7,	6,	8,	-1,	10,	12),
1667	PINGROUP(pex_wake_n_pl2,	RSVD0,		RSVD1,		RSVD2,		RSVD3,		0x7008,		0,	Y,	5,	7,	6,	8,	-1,	10,	12),
1668	PINGROUP(pex_l1_clkreq_n_pk2,	PE1,		RSVD1,		RSVD2,		RSVD3,		0x7010,		0,	Y,	5,	7,	6,	8,	-1,	10,	12),
1669	PINGROUP(pex_l1_rst_n_pk3,	PE1,		RSVD1,		RSVD2,		RSVD3,		0x7018,		0,	Y,	5,	7,	6,	8,	-1,	10,	12),
1670	PINGROUP(pex_l0_clkreq_n_pk0,	PE0,		RSVD1,		RSVD2,		RSVD3,		0x7020,		0,	Y,	5,	7,	6,	8,	-1,	10,	12),
1671	PINGROUP(pex_l0_rst_n_pk1,	PE0,		RSVD1,		RSVD2,		RSVD3,		0x7028,		0,	Y,	5,	7,	6,	8,	-1,	10,	12),
1672	PINGROUP(pex_l2_rst_n_pk5,	PE2,		RSVD1,		RSVD2,		RSVD3,		0x7030,		0,	Y,	5,	7,	6,	8,	-1,	10,	12),
1673	PINGROUP(pex_l3_clkreq_n_pk6,	PE3,		RSVD1,		RSVD2,		RSVD3,		0x7038,		0,	Y,	5,	7,	6,	8,	-1,	10,	12),
1674	PINGROUP(pex_l3_rst_n_pk7,	PE3,		RSVD1,		RSVD2,		RSVD3,		0x7040,		0,	Y,	5,	7,	6,	8,	-1,	10,	12),
1675	PINGROUP(pex_l4_clkreq_n_pl0,	PE4,		RSVD1,		RSVD2,		RSVD3,		0x7048,		0,	Y,	5,	7,	6,	8,	-1,	10,	12),
1676	PINGROUP(pex_l4_rst_n_pl1,	PE4,		RSVD1,		RSVD2,		RSVD3,		0x7050,		0,	Y,	5,	7,	6,	8,	-1,	10,	12),
1677	PINGROUP(soc_gpio34_pl3,	RSVD0,		RSVD1,		RSVD2,		RSVD3,		0x7058,		0,	Y,	5,	7,	6,	8,	-1,	10,	12),
1678	PINGROUP(pex_l5_clkreq_n_paf0,	PE5,		RSVD1,		RSVD2,		RSVD3,		0x14000,	0,	Y,	5,	7,	6,	8,	-1,	10,	12),
1679	PINGROUP(pex_l5_rst_n_paf1,	PE5,		RSVD1,		RSVD2,		RSVD3,		0x14008,	0,	Y,	5,	7,	6,	8,	-1,	10,	12),
1680	PINGROUP(pex_l6_clkreq_n_paf2,  PE6,		RSVD1,		RSVD2,		RSVD3,		0x14010,	0,	Y,	5,	7,	6,	8,	-1,	10,	12),
1681	PINGROUP(pex_l6_rst_n_paf3,	PE6,		RSVD1,		RSVD2,		RSVD3,		0x14018,	0,	Y,	5,	7,	6,	8,	-1,	10,	12),
1682	PINGROUP(pex_l10_clkreq_n_pag6,	PE10,		RSVD1,		RSVD2,		RSVD3,		0x19000,	0,	Y,	5,	7,	6,	8,	-1,	10,	12),
1683	PINGROUP(pex_l10_rst_n_pag7,	PE10,		RSVD1,		RSVD2,		RSVD3,		0x19008,	0,	Y,	5,	7,	6,	8,	-1,	10,	12),
1684	PINGROUP(pex_l7_clkreq_n_pag0,	PE7,		RSVD1,		RSVD2,		RSVD3,		0x19010,	0,	Y,	5,	7,	6,	8,	-1,	10,	12),
1685	PINGROUP(pex_l7_rst_n_pag1,	PE7,		RSVD1,		RSVD2,		RSVD3,		0x19018,	0,	Y,	5,	7,	6,	8,	-1,	10,	12),
1686	PINGROUP(pex_l8_clkreq_n_pag2,	PE8,		RSVD1,		RSVD2,		RSVD3,		0x19020,	0,	Y,	5,	7,	6,	8,	-1,	10,	12),
1687	PINGROUP(pex_l8_rst_n_pag3,	PE8,		RSVD1,		RSVD2,		RSVD3,		0x19028,	0,	Y,	5,	7,	6,	8,	-1,	10,	12),
1688	PINGROUP(pex_l9_clkreq_n_pag4,	PE9,		RSVD1,		RSVD2,		RSVD3,		0x19030,	0,	Y,	5,	7,	6,	8,	-1,	10,	12),
1689	PINGROUP(pex_l9_rst_n_pag5,	PE9,		RSVD1,		RSVD2,		RSVD3,		0x19038,	0,	Y,	5,	7,	6,	8,	-1,	10,	12),
1690	PINGROUP(qspi0_io3_pc5,		QSPI0,		RSVD1,		RSVD2,		RSVD3,		0xB000,		0,	Y,	-1,	5,	6,	-1,	-1,	10,	12),
1691	PINGROUP(qspi0_io2_pc4,		QSPI0,		RSVD1,		RSVD2,		RSVD3,		0xB008,		0,	Y,	-1,	5,	6,	-1,	-1,	10,	12),
1692	PINGROUP(qspi0_io1_pc3,		QSPI0,		RSVD1,		RSVD2,		RSVD3,		0xB010,		0,	Y,	-1,	5,	6,	-1,	-1,	10,	12),
1693	PINGROUP(qspi0_io0_pc2,		QSPI0,		RSVD1,		RSVD2,		RSVD3,		0xB018,		0,	Y,	-1,	5,	6,	-1,	-1,	10,	12),
1694	PINGROUP(qspi0_sck_pc0,		QSPI0,		RSVD1,		RSVD2,		RSVD3,		0xB020,		0,	Y,	-1,	5,	6,	-1,	-1,	10,	12),
1695	PINGROUP(qspi0_cs_n_pc1,	QSPI0,		RSVD1,		RSVD2,		RSVD3,		0xB028,		0,	Y,	-1,	5,	6,	-1,	-1,	10,	12),
1696	PINGROUP(qspi1_io3_pd3,		QSPI1,		RSVD1,		RSVD2,		RSVD3,		0xB030,		0,	Y,	-1,	5,	6,	-1,	-1,	10,	12),
1697	PINGROUP(qspi1_io2_pd2,		QSPI1,		RSVD1,		RSVD2,		RSVD3,		0xB038,		0,	Y,	-1,	5,	6,	-1,	-1,	10,	12),
1698	PINGROUP(qspi1_io1_pd1,		QSPI1,		RSVD1,		RSVD2,		RSVD3,		0xB040,		0,	Y,	-1,	5,	6,	-1,	-1,	10,	12),
1699	PINGROUP(qspi1_io0_pd0,		QSPI1,		RSVD1,		RSVD2,		RSVD3,		0xB048,		0,	Y,	-1,	5,	6,	-1,	-1,	10,	12),
1700	PINGROUP(qspi1_sck_pc6,		QSPI1,		RSVD1,		RSVD2,		RSVD3,		0xB050,		0,	Y,	-1,	5,	6,	-1,	-1,	10,	12),
1701	PINGROUP(qspi1_cs_n_pc7,	QSPI1,		RSVD1,		RSVD2,		RSVD3,		0xB058,		0,	Y,	-1,	5,	6,	-1,	-1,	10,	12),
1702	PINGROUP(qspi_comp,		QSPI,		RSVD1,		RSVD2,		RSVD3,		0xB060,		0,	N,	-1,	-1,	-1,	-1,	-1,	-1,	-1),
1703	PINGROUP(sdmmc1_clk_pj0,	SDMMC1,		RSVD1,		RSVD2,		RSVD3,		0x8000,		0,	Y,	-1,	5,	6,	-1,	9,	10,	12),
1704	PINGROUP(sdmmc1_cmd_pj1,	SDMMC1,		RSVD1,		RSVD2,		RSVD3,		0x8008,		0,	Y,	-1,	5,	6,	-1,	9,	10,	12),
1705	PINGROUP(sdmmc1_comp,		SDMMC1,		RSVD1,		RSVD2,		RSVD3,		0x8010,		0,	N,	-1,	-1,	-1,	-1,	-1,	-1,	-1),
1706	PINGROUP(sdmmc1_dat3_pj5,	SDMMC1,		RSVD1,		RSVD2,		RSVD3,		0x8018,		0,	Y,	-1,	5,	6,	-1,	9,	10,	12),
1707	PINGROUP(sdmmc1_dat2_pj4,	SDMMC1,		RSVD1,		RSVD2,		RSVD3,		0x8020,		0,	Y,	-1,	5,	6,	-1,	9,	10,	12),
1708	PINGROUP(sdmmc1_dat1_pj3,	SDMMC1,		RSVD1,		RSVD2,		RSVD3,		0x8028,		0,	Y,	-1,	5,	6,	-1,	9,	10,	12),
1709	PINGROUP(sdmmc1_dat0_pj2,	SDMMC1,		RSVD1,		RSVD2,		RSVD3,		0x8030,		0,	Y,	-1,	5,	6,	-1,	9,	10,	12),
1710	PINGROUP(ufs0_rst_n_pae1,	UFS0,		RSVD1,		RSVD2,		RSVD3,		0x11000,	0,	Y,	-1,	5,	6,	-1,	-1,	10,	12),
1711	PINGROUP(ufs0_ref_clk_pae0,	UFS0,		RSVD1,		RSVD2,		RSVD3,		0x11008,	0,	Y,	-1,	5,	6,	-1,	-1,	10,	12),
1712	PINGROUP(spi3_miso_py1,		SPI3,		RSVD1,		RSVD2,		RSVD3,		0xD000,		0,	Y,	5,	7,	6,	8,	-1,	10,	12),
1713	PINGROUP(spi1_cs0_pz6,		SPI1,		RSVD1,		RSVD2,		RSVD3,		0xD008,		0,	Y,	5,	7,	6,	8,	-1,	10,	12),
1714	PINGROUP(spi3_cs0_py3,		SPI3,		RSVD1,		RSVD2,		RSVD3,		0xD010,		0,	Y,	5,	7,	6,	8,	-1,	10,	12),
1715	PINGROUP(spi1_miso_pz4,		SPI1,		RSVD1,		RSVD2,		RSVD3,		0xD018,		0,	Y,	5,	7,	6,	8,	-1,	10,	12),
1716	PINGROUP(spi3_cs1_py4,		SPI3,		RSVD1,		RSVD2,		RSVD3,		0xD020,		0,	Y,	5,	7,	6,	8,	-1,	10,	12),
1717	PINGROUP(spi1_sck_pz3,		SPI1,		RSVD1,		RSVD2,		RSVD3,		0xD028,		0,	Y,	5,	7,	6,	8,	-1,	10,	12),
1718	PINGROUP(spi3_sck_py0,		SPI3,		RSVD1,		RSVD2,		RSVD3,		0xD030,		0,	Y,	5,	7,	6,	8,	-1,	10,	12),
1719	PINGROUP(spi1_cs1_pz7,		SPI1,		RSVD1,		RSVD2,		RSVD3,		0xD038,		0,	Y,	5,	7,	6,	8,	-1,	10,	12),
1720	PINGROUP(spi1_mosi_pz5,		SPI1,		RSVD1,		RSVD2,		RSVD3,		0xD040,		0,	Y,	5,	7,	6,	8,	-1,	10,	12),
1721	PINGROUP(spi3_mosi_py2,		SPI3,		RSVD1,		RSVD2,		RSVD3,		0xD048,		0,	Y,	5,	7,	6,	8,	-1,	10,	12),
1722	PINGROUP(uart2_tx_px4,		UARTB,		RSVD1,		RSVD2,		RSVD3,		0xD050,		0,	Y,	5,	7,	6,	8,	-1,	10,	12),
1723	PINGROUP(uart2_rx_px5,		UARTB,		RSVD1,		RSVD2,		RSVD3,		0xD058,		0,	Y,	5,	7,	6,	8,	-1,	10,	12),
1724	PINGROUP(uart2_rts_px6,		UARTB,		RSVD1,		RSVD2,		RSVD3,		0xD060,		0,	Y,	-1,	7,	6,	8,	-1,	10,	12),
1725	PINGROUP(uart2_cts_px7,		UARTB,		RSVD1,		RSVD2,		RSVD3,		0xD068,		0,	Y,	-1,	7,	6,	8,	-1,	10,	12),
1726	PINGROUP(uart5_tx_py5,		UARTE,		RSVD1,		RSVD2,		RSVD3,		0xD070,		0,	Y,	-1,	7,	6,	8,	-1,	10,	12),
1727	PINGROUP(uart5_rx_py6,		UARTE,		RSVD1,		RSVD2,		RSVD3,		0xD078,		0,	Y,	-1,	7,	6,	8,	-1,	10,	12),
1728	PINGROUP(uart5_rts_py7,		UARTE,		RSVD1,		RSVD2,		RSVD3,		0xD080,		0,	Y,	-1,	7,	6,	8,	-1,	10,	12),
1729	PINGROUP(uart5_cts_pz0,		UARTE,		RSVD1,		RSVD2,		RSVD3,		0xD088,		0,	Y,	-1,	7,	6,	8,	-1,	10,	12),
1730	PINGROUP(gpu_pwr_req_px0,	RSVD0,		RSVD1,		RSVD2,		RSVD3,		0xD090,		0,	Y,	-1,	7,	6,	8,	-1,	10,	12),
1731	PINGROUP(gp_pwm3_px3,		GP,		RSVD1,		RSVD2,		RSVD3,		0xD098,		0,	Y,	5,	7,	6,	8,	-1,	10,	12),
1732	PINGROUP(gp_pwm2_px2,		GP,		RSVD1,		RSVD2,		RSVD3,		0xD0A0,		0,	Y,	5,	7,	6,	8,	-1,	10,	12),
1733	PINGROUP(cv_pwr_req_px1,	RSVD0,		RSVD1,		RSVD2,		RSVD3,		0xD0A8,		0,	Y,	-1,	7,	6,	8,	-1,	10,	12),
1734	PINGROUP(usb_vbus_en0_pz1,	USB,		RSVD1,		RSVD2,		RSVD3,		0xD0B0,		0,	Y,	5,	7,	6,	8,	-1,	10,	12),
1735	PINGROUP(usb_vbus_en1_pz2,	USB,		RSVD1,		RSVD2,		RSVD3,		0xD0B8,		0,	Y,	5,	7,	6,	8,	-1,	10,	12),
1736	PINGROUP(extperiph2_clk_pp1,	EXTPERIPH2,	RSVD1,		RSVD2,		RSVD3,		0x0000,		0,	Y,	-1,	7,	6,	8,	-1,	10,	12),
1737	PINGROUP(extperiph1_clk_pp0,	EXTPERIPH1,	RSVD1,		RSVD2,		RSVD3,		0x0008,		0,	Y,	-1,	7,	6,	8,	-1,	10,	12),
1738	PINGROUP(cam_i2c_sda_pp3,	I2C3,		VI0,		RSVD2,		VI1,		0x0010,		0,	Y,	5,	7,	6,	8,	-1,	10,	12),
1739	PINGROUP(cam_i2c_scl_pp2,	I2C3,		VI0,		VI0_ALT,	VI1,		0x0018,		0,	Y,	5,	7,	6,	8,	-1,	10,	12),
1740	PINGROUP(soc_gpio23_pp4,	VI0,		VI0_ALT,	VI1,		VI1_ALT,	0x0020,		0,	Y,	5,	7,	6,	8,	-1,	10,	12),
1741	PINGROUP(soc_gpio24_pp5,	VI0,		SOC,		VI1,		VI1_ALT,	0x0028,		0,	Y,	5,	7,	6,	8,	-1,	10,	12),
1742	PINGROUP(soc_gpio25_pp6,	VI0,		I2S5,		VI1,		DMIC1,		0x0030,		0,	Y,	5,	7,	6,	8,	-1,	10,	12),
1743	PINGROUP(pwr_i2c_scl_pp7,	I2C5,		RSVD1,		RSVD2,		RSVD3,		0x0038,		0,	Y,	5,	7,	6,	8,	-1,	10,	12),
1744	PINGROUP(pwr_i2c_sda_pq0,	I2C5,		RSVD1,		RSVD2,		RSVD3,		0x0040,		0,	Y,	5,	7,	6,	8,	-1,	10,	12),
1745	PINGROUP(soc_gpio28_pq1,	VI0,		RSVD1,		VI1,		RSVD3,		0x0048,		0,	Y,	5,	7,	6,	8,	-1,	10,	12),
1746	PINGROUP(soc_gpio29_pq2,	RSVD0,		NV,		RSVD2,		RSVD3,		0x0050,		0,	Y,	5,	7,	6,	8,	-1,	10,	12),
1747	PINGROUP(soc_gpio30_pq3,	RSVD0,		WDT,		RSVD2,		RSVD3,		0x0058,		0,	Y,	5,	7,	6,	8,	-1,	10,	12),
1748	PINGROUP(soc_gpio31_pq4,	RSVD0,		RSVD1,		RSVD2,		RSVD3,		0x0060,		0,	Y,	5,	7,	6,	8,	-1,	10,	12),
1749	PINGROUP(soc_gpio32_pq5,	RSVD0,		EXTPERIPH3,	DCB,		RSVD3,		0x0068,		0,	Y,	5,	7,	6,	8,	-1,	10,	12),
1750	PINGROUP(soc_gpio33_pq6,	RSVD0,		EXTPERIPH4,	DCB,		RSVD3,		0x0070,		0,	Y,	5,	7,	6,	8,	-1,	10,	12),
1751	PINGROUP(soc_gpio35_pq7,	RSVD0,		I2S5,		DMIC1,		RSVD3,		0x0078,		0,	Y,	5,	7,	6,	8,	-1,	10,	12),
1752	PINGROUP(soc_gpio37_pr0,	GP,		I2S5,		DMIC4,		DSPK1,		0x0080,		0,	Y,	5,	7,	6,	8,	-1,	10,	12),
1753	PINGROUP(soc_gpio56_pr1,	RSVD0,		I2S5,		DMIC4,		DSPK1,		0x0088,		0,	Y,	5,	7,	6,	8,	-1,	10,	12),
1754	PINGROUP(uart1_cts_pr5,		UARTA,		RSVD1,		RSVD2,		RSVD3,		0x0090,		0,	Y,	-1,	7,	6,	8,	-1,	10,	12),
1755	PINGROUP(uart1_rts_pr4,		UARTA,		RSVD1,		RSVD2,		RSVD3,		0x0098,		0,	Y,	-1,	7,	6,	8,	-1,	10,	12),
1756	PINGROUP(uart1_rx_pr3,		UARTA,		RSVD1,		RSVD2,		RSVD3,		0x00A0,		0,	Y,	-1,	7,	6,	8,	-1,	10,	12),
1757	PINGROUP(uart1_tx_pr2,		UARTA,		RSVD1,		RSVD2,		RSVD3,		0x00A8,		0,	Y,	-1,	7,	6,	8,	-1,	10,	12),
1758	PINGROUP(cpu_pwr_req_pi5,	RSVD0,		RSVD1,		RSVD2,		RSVD3,		0x4000,		0,	Y,	-1,	7,	6,	8,	-1,	10,	12),
1759	PINGROUP(uart4_cts_ph6,		UARTD,		RSVD1,		I2S7,		RSVD3,		0x4008,		0,	Y,	-1,	7,	6,	8,	-1,	10,	12),
1760	PINGROUP(uart4_rts_ph5,		UARTD,		SPI4,		RSVD2,		RSVD3,		0x4010,		0,	Y,	-1,	7,	6,	8,	-1,	10,	12),
1761	PINGROUP(uart4_rx_ph4,		UARTD,		RSVD1,		I2S7,		RSVD3,		0x4018,		0,	Y,	-1,	7,	6,	8,	-1,	10,	12),
1762	PINGROUP(uart4_tx_ph3,		UARTD,		SPI4,		RSVD2,		RSVD3,		0x4020,		0,	Y,	-1,	7,	6,	8,	-1,	10,	12),
1763	PINGROUP(gen1_i2c_scl_pi3,	I2C1,		RSVD1,		RSVD2,		RSVD3,		0x4028,		0,	Y,	5,	7,	6,	8,	-1,	10,	12),
1764	PINGROUP(gen1_i2c_sda_pi4,	I2C1,		RSVD1,		RSVD2,		RSVD3,		0x4030,		0,	Y,	5,	7,	6,	8,	-1,	10,	12),
1765	PINGROUP(soc_gpio20_pg7,	RSVD0,		SDMMC1,		RSVD2,		RSVD3,		0x4038,		0,	Y,	-1,	7,	6,	8,	-1,	10,	12),
1766	PINGROUP(soc_gpio21_ph0,	RSVD0,		GP,		I2S7,		RSVD3,		0x4040,		0,	Y,	-1,	7,	6,	8,	-1,	10,	12),
1767	PINGROUP(soc_gpio22_ph1,	RSVD0,		RSVD1,		I2S7,		RSVD3,		0x4048,		0,	Y,	-1,	7,	6,	8,	-1,	10,	12),
1768	PINGROUP(soc_gpio13_pg0,	RSVD0,		RSVD1,		RSVD2,		RSVD3,		0x4050,		0,	Y,	-1,	7,	6,	8,	-1,	10,	12),
1769	PINGROUP(soc_gpio14_pg1,	RSVD0,		SPI4,		RSVD2,		RSVD3,		0x4058,		0,	Y,	-1,	7,	6,	8,	-1,	10,	12),
1770	PINGROUP(soc_gpio15_pg2,	RSVD0,		SPI4,		RSVD2,		RSVD3,		0x4060,		0,	Y,	-1,	7,	6,	8,	-1,	10,	12),
1771	PINGROUP(soc_gpio16_pg3,	RSVD0,		SPI4,		RSVD2,		RSVD3,		0x4068,		0,	Y,	-1,	7,	6,	8,	-1,	10,	12),
1772	PINGROUP(soc_gpio17_pg4,	RSVD0,		CCLA,		RSVD2,		RSVD3,		0x4070,		0,	Y,	-1,	7,	6,	8,	-1,	10,	12),
1773	PINGROUP(soc_gpio18_pg5,	RSVD0,		RSVD1,		RSVD2,		RSVD3,		0x4078,		0,	Y,	-1,	7,	6,	8,	-1,	10,	12),
1774	PINGROUP(soc_gpio19_pg6,	GP,		RSVD1,		RSVD2,		RSVD3,		0x4080,		0,	Y,	-1,	7,	6,	8,	-1,	10,	12),
1775	PINGROUP(soc_gpio41_ph7,	RSVD0,		I2S2,		RSVD2,		RSVD3,		0x4088,		0,	Y,	-1,	7,	6,	8,	-1,	10,	12),
1776	PINGROUP(soc_gpio42_pi0,	RSVD0,		I2S2,		RSVD2,		RSVD3,		0x4090,		0,	Y,	-1,	7,	6,	8,	-1,	10,	12),
1777	PINGROUP(soc_gpio43_pi1,	RSVD0,		I2S2,		RSVD2,		RSVD3,		0x4098,		0,	Y,	-1,	7,	6,	8,	-1,	10,	12),
1778	PINGROUP(soc_gpio44_pi2,	RSVD0,		I2S2,		RSVD2,		RSVD3,		0x40A0,		0,	Y,	-1,	7,	6,	8,	-1,	10,	12),
1779	PINGROUP(soc_gpio06_ph2,	RSVD0,		RSVD1,		RSVD2,		RSVD3,		0x40A8,		0,	Y,	-1,	7,	6,	8,	-1,	10,	12),
1780	PINGROUP(soc_gpio07_pi6,	GP,		RSVD1,		RSVD2,		RSVD3,		0x40B0,		0,	Y,	-1,	7,	6,	8,	-1,	10,	12),
1781	PINGROUP(dap4_sclk_pa4,		I2S4,		RSVD1,		RSVD2,		RSVD3,		0x2000,		0,	Y,	-1,	7,	6,	8,	-1,	10,	12),
1782	PINGROUP(dap4_dout_pa5,		I2S4,		RSVD1,		RSVD2,		RSVD3,		0x2008,		0,	Y,	-1,	7,	6,	8,	-1,	10,	12),
1783	PINGROUP(dap4_din_pa6,		I2S4,		RSVD1,		RSVD2,		RSVD3,		0x2010,		0,	Y,	-1,	7,	6,	8,	-1,	10,	12),
1784	PINGROUP(dap4_fs_pa7,		I2S4,		RSVD1,		RSVD2,		RSVD3,		0x2018,		0,	Y,	-1,	7,	6,	8,	-1,	10,	12),
1785	PINGROUP(dap6_sclk_pa0,		I2S6,		RSVD1,		RSVD2,		RSVD3,		0x2020,		0,	Y,	-1,	7,	6,	8,	-1,	10,	12),
1786	PINGROUP(dap6_dout_pa1,		I2S6,		RSVD1,		RSVD2,		RSVD3,		0x2028,		0,	Y,	-1,	7,	6,	8,	-1,	10,	12),
1787	PINGROUP(dap6_din_pa2,		I2S6,		RSVD1,		RSVD2,		RSVD3,		0x2030,		0,	Y,	-1,	7,	6,	8,	-1,	10,	12),
1788	PINGROUP(dap6_fs_pa3,		I2S6,		RSVD1,		RSVD2,		RSVD3,		0x2038,		0,	Y,	-1,	7,	6,	8,	-1,	10,	12),
1789	PINGROUP(soc_gpio45_pad0,	RSVD0,		I2S1,		RSVD2,		RSVD3,		0x18000,	0,	Y,	-1,	7,	6,	8,	-1,	10,	12),
1790	PINGROUP(soc_gpio46_pad1,	RSVD0,		I2S1,		RSVD2,		RSVD3,		0x18008,	0,	Y,	-1,	7,	6,	8,	-1,	10,	12),
1791	PINGROUP(soc_gpio47_pad2,	RSVD0,		I2S1,		RSVD2,		RSVD3,		0x18010,	0,	Y,	-1,	7,	6,	8,	-1,	10,	12),
1792	PINGROUP(soc_gpio48_pad3,	RSVD0,		I2S1,		RSVD2,		RSVD3,		0x18018,	0,	Y,	-1,	7,	6,	8,	-1,	10,	12),
1793	PINGROUP(soc_gpio57_pac4,	RSVD0,		I2S8,		RSVD2,		SDMMC1,		0x18020,	0,	Y,	-1,	7,	6,	8,	-1,	10,	12),
1794	PINGROUP(soc_gpio58_pac5,	RSVD0,		I2S8,		RSVD2,		SDMMC1,		0x18028,	0,	Y,	-1,	7,	6,	8,	-1,	10,	12),
1795	PINGROUP(soc_gpio59_pac6,	AUD,		I2S8,		RSVD2,		RSVD3,		0x18030,	0,	Y,	-1,	7,	6,	8,	-1,	10,	12),
1796	PINGROUP(soc_gpio60_pac7,	RSVD0,		I2S8,		NV,		IGPU,		0x18038,	0,	Y,	-1,	7,	6,	8,	-1,	10,	12),
1797	PINGROUP(spi5_cs0_pac3,		SPI5,		I2S3,		DMIC2,		RSVD3,		0x18040,	0,	Y,	-1,	7,	6,	8,	-1,	10,	12),
1798	PINGROUP(spi5_miso_pac1,	SPI5,		I2S3,		DSPK0,		RSVD3,		0x18048,	0,	Y,	-1,	7,	6,	8,	-1,	10,	12),
1799	PINGROUP(spi5_mosi_pac2,	SPI5,		I2S3,		DMIC2,		RSVD3,		0x18050,	0,	Y,	-1,	7,	6,	8,	-1,	10,	12),
1800	PINGROUP(spi5_sck_pac0,		SPI5,		I2S3,		DSPK0,		RSVD3,		0x18058,	0,	Y,	-1,	7,	6,	8,	-1,	10,	12),
1801
1802};
1803
1804static const struct tegra_pinctrl_soc_data tegra234_pinctrl = {
1805	.pins = tegra234_pins,
1806	.npins = ARRAY_SIZE(tegra234_pins),
1807	.functions = tegra234_functions,
1808	.nfunctions = ARRAY_SIZE(tegra234_functions),
1809	.groups = tegra234_groups,
1810	.ngroups = ARRAY_SIZE(tegra234_groups),
1811	.hsm_in_mux = false,
1812	.schmitt_in_mux = true,
1813	.drvtype_in_mux = true,
1814	.sfsel_in_mux = true,
1815};
1816
1817static const struct pinctrl_pin_desc tegra234_aon_pins[] = {
1818	PINCTRL_PIN(TEGRA_PIN_CAN0_DOUT_PAA0, "CAN0_DOUT_PAA0"),
1819	PINCTRL_PIN(TEGRA_PIN_CAN0_DIN_PAA1, "CAN0_DIN_PAA1"),
1820	PINCTRL_PIN(TEGRA_PIN_CAN1_DOUT_PAA2, "CAN1_DOUT_PAA2"),
1821	PINCTRL_PIN(TEGRA_PIN_CAN1_DIN_PAA3, "CAN1_DIN_PAA3"),
1822	PINCTRL_PIN(TEGRA_PIN_CAN0_STB_PAA4, "CAN0_STB_PAA4"),
1823	PINCTRL_PIN(TEGRA_PIN_CAN0_EN_PAA5, "CAN0_EN_PAA5"),
1824	PINCTRL_PIN(TEGRA_PIN_SOC_GPIO49_PAA6, "SOC_GPIO49_PAA6"),
1825	PINCTRL_PIN(TEGRA_PIN_CAN0_ERR_PAA7, "CAN0_ERR_PAA7"),
1826	PINCTRL_PIN(TEGRA_PIN_CAN1_STB_PBB0, "CAN1_STB_PBB0"),
1827	PINCTRL_PIN(TEGRA_PIN_CAN1_EN_PBB1, "CAN1_EN_PBB1"),
1828	PINCTRL_PIN(TEGRA_PIN_SOC_GPIO50_PBB2, "SOC_GPIO50_PBB2"),
1829	PINCTRL_PIN(TEGRA_PIN_CAN1_ERR_PBB3, "CAN1_ERR_PBB3"),
1830	PINCTRL_PIN(TEGRA_PIN_SPI2_SCK_PCC0, "SPI2_SCK_PCC0"),
1831	PINCTRL_PIN(TEGRA_PIN_SPI2_MISO_PCC1, "SPI2_MISO_PCC1"),
1832	PINCTRL_PIN(TEGRA_PIN_SPI2_MOSI_PCC2, "SPI2_MOSI_PCC2"),
1833	PINCTRL_PIN(TEGRA_PIN_SPI2_CS0_PCC3, "SPI2_CS0_PCC3"),
1834	PINCTRL_PIN(TEGRA_PIN_TOUCH_CLK_PCC4, "TOUCH_CLK_PCC4"),
1835	PINCTRL_PIN(TEGRA_PIN_UART3_TX_PCC5, "UART3_TX_PCC5"),
1836	PINCTRL_PIN(TEGRA_PIN_UART3_RX_PCC6, "UART3_RX_PCC6"),
1837	PINCTRL_PIN(TEGRA_PIN_GEN2_I2C_SCL_PCC7, "GEN2_I2C_SCL_PCC7"),
1838	PINCTRL_PIN(TEGRA_PIN_GEN2_I2C_SDA_PDD0, "GEN2_I2C_SDA_PDD0"),
1839	PINCTRL_PIN(TEGRA_PIN_GEN8_I2C_SCL_PDD1, "GEN8_I2C_SCL_PDD1"),
1840	PINCTRL_PIN(TEGRA_PIN_GEN8_I2C_SDA_PDD2, "GEN8_I2C_SDA_PDD2"),
1841	PINCTRL_PIN(TEGRA_PIN_SCE_ERROR_PEE0, "SCE_ERROR_PEE0"),
1842	PINCTRL_PIN(TEGRA_PIN_VCOMP_ALERT_PEE1, "VCOMP_ALERT_PEE1"),
1843	PINCTRL_PIN(TEGRA_PIN_AO_RETENTION_N_PEE2, "AO_RETENTION_N_PEE2"),
1844	PINCTRL_PIN(TEGRA_PIN_BATT_OC_PEE3, "BATT_OC_PEE3"),
1845	PINCTRL_PIN(TEGRA_PIN_POWER_ON_PEE4, "POWER_ON_PEE4"),
1846	PINCTRL_PIN(TEGRA_PIN_SOC_GPIO26_PEE5, "SOC_GPIO26_PEE5"),
1847	PINCTRL_PIN(TEGRA_PIN_SOC_GPIO27_PEE6, "SOC_GPIO27_PEE6"),
1848	PINCTRL_PIN(TEGRA_PIN_BOOTV_CTL_N_PEE7, "BOOTV_CTL_N_PEE7"),
1849	PINCTRL_PIN(TEGRA_PIN_HDMI_CEC_PGG0, "HDMI_CEC_PGG0"),
1850};
1851
1852/* AON drive pin groups */
1853#define	drive_touch_clk_pcc4			DRV_PINGROUP_ENTRY_Y(0x2004,	12,	5,	20,	5,	-1,	-1,	-1,	-1,	0)
1854#define	drive_uart3_rx_pcc6			DRV_PINGROUP_ENTRY_Y(0x200c,	12,	5,	20,	5,	-1,	-1,	-1,	-1,	0)
1855#define	drive_uart3_tx_pcc5			DRV_PINGROUP_ENTRY_Y(0x2014,	12,	5,	20,	5,	-1,	-1,	-1,	-1,	0)
1856#define	drive_gen8_i2c_sda_pdd2			DRV_PINGROUP_ENTRY_Y(0x201c,	12,	5,	20,	5,	-1,	-1,	-1,	-1,	0)
1857#define	drive_gen8_i2c_scl_pdd1			DRV_PINGROUP_ENTRY_Y(0x2024,	12,	5,	20,	5,	-1,	-1,	-1,	-1,	0)
1858#define	drive_spi2_mosi_pcc2			DRV_PINGROUP_ENTRY_Y(0x202c,	12,	5,	20,	5,	-1,	-1,	-1,	-1,	0)
1859#define	drive_gen2_i2c_scl_pcc7			DRV_PINGROUP_ENTRY_Y(0x2034,	12,	5,	20,	5,	-1,	-1,	-1,	-1,	0)
1860#define	drive_spi2_cs0_pcc3			DRV_PINGROUP_ENTRY_Y(0x203c,	12,	5,	20,	5,	-1,	-1,	-1,	-1,	0)
1861#define	drive_gen2_i2c_sda_pdd0			DRV_PINGROUP_ENTRY_Y(0x2044,	12,	5,	20,	5,	-1,	-1,	-1,	-1,	0)
1862#define	drive_spi2_sck_pcc0			DRV_PINGROUP_ENTRY_Y(0x204c,	12,	5,	20,	5,	-1,	-1,	-1,	-1,	0)
1863#define	drive_spi2_miso_pcc1			DRV_PINGROUP_ENTRY_Y(0x2054,	12,	5,	20,	5,	-1,	-1,	-1,	-1,	0)
1864#define	drive_can1_dout_paa2			DRV_PINGROUP_ENTRY_Y(0x3004,	28,	2,	30,	2,	-1,	-1,	-1,	-1,	0)
1865#define	drive_can1_din_paa3			DRV_PINGROUP_ENTRY_Y(0x300c,	28,	2,	30,	2,	-1,	-1,	-1,	-1,	0)
1866#define	drive_can0_dout_paa0			DRV_PINGROUP_ENTRY_Y(0x3014,	28,	2,	30,	2,	-1,	-1,	-1,	-1,	0)
1867#define	drive_can0_din_paa1			DRV_PINGROUP_ENTRY_Y(0x301c,	28,	2,	30,	2,	-1,	-1,	-1,	-1,	0)
1868#define	drive_can0_stb_paa4			DRV_PINGROUP_ENTRY_Y(0x3024,	28,	2,	30,	2,	-1,	-1,	-1,	-1,	0)
1869#define	drive_can0_en_paa5			DRV_PINGROUP_ENTRY_Y(0x302c,	28,	2,	30,	2,	-1,	-1,	-1,	-1,	0)
1870#define	drive_soc_gpio49_paa6			DRV_PINGROUP_ENTRY_Y(0x3034,	28,	2,	30,	2,	-1,	-1,	-1,	-1,	0)
1871#define	drive_can0_err_paa7			DRV_PINGROUP_ENTRY_Y(0x303c,	28,	2,	30,	2,	-1,	-1,	-1,	-1,	0)
1872#define	drive_can1_stb_pbb0			DRV_PINGROUP_ENTRY_Y(0x3044,	28,	2,	30,	2,	-1,	-1,	-1,	-1,	0)
1873#define	drive_can1_en_pbb1			DRV_PINGROUP_ENTRY_Y(0x304c,	28,	2,	30,	2,	-1,	-1,	-1,	-1,	0)
1874#define	drive_soc_gpio50_pbb2			DRV_PINGROUP_ENTRY_Y(0x3054,	28,	2,	30,	2,	-1,	-1,	-1,	-1,	0)
1875#define	drive_can1_err_pbb3			DRV_PINGROUP_ENTRY_Y(0x305c,	28,	2,	30,	2,	-1,	-1,	-1,	-1,	0)
1876#define	drive_sce_error_pee0			DRV_PINGROUP_ENTRY_Y(0x1014,	12,	5,	20,	5,	-1,	-1,	-1,	-1,	0)
1877#define	drive_batt_oc_pee3			DRV_PINGROUP_ENTRY_Y(0x1024,	12,	5,	20,	5,	-1,	-1,	-1,	-1,	0)
1878#define	drive_bootv_ctl_n_pee7			DRV_PINGROUP_ENTRY_Y(0x102c,	12,	5,	20,	5,	-1,	-1,	-1,	-1,	0)
1879#define	drive_power_on_pee4			DRV_PINGROUP_ENTRY_Y(0x103c,	12,	5,	20,	5,	-1,	-1,	-1,	-1,	0)
1880#define	drive_soc_gpio26_pee5			DRV_PINGROUP_ENTRY_Y(0x1044,	12,	5,	20,	5,	-1,	-1,	-1,	-1,	0)
1881#define	drive_soc_gpio27_pee6			DRV_PINGROUP_ENTRY_Y(0x104c,	12,	5,	20,	5,	-1,	-1,	-1,	-1,	0)
1882#define	drive_ao_retention_n_pee2		DRV_PINGROUP_ENTRY_Y(0x1054,	12,	5,	20,	5,	-1,	-1,	-1,	-1,	0)
1883#define	drive_vcomp_alert_pee1			DRV_PINGROUP_ENTRY_Y(0x105c,	12,	5,	20,	5,	-1,	-1,	-1,	-1,	0)
1884#define	drive_hdmi_cec_pgg0			DRV_PINGROUP_ENTRY_Y(0x1064,	12,	5,	20,	5,	-1,	-1,	-1,	-1,	0)
1885
1886static const struct tegra_pingroup tegra234_aon_groups[] = {
1887	PINGROUP(touch_clk_pcc4,	GP,		TOUCH,		RSVD2,		RSVD3,		0x2000,		0,	Y,	5,	7,	6,	8,	-1,	10,	12),
1888	PINGROUP(uart3_rx_pcc6,		UARTC,		UARTJ,		RSVD2,		RSVD3,		0x2008,		0,	Y,	5,	7,	6,	8,	-1,	10,	12),
1889	PINGROUP(uart3_tx_pcc5,		UARTC,		UARTJ,		RSVD2,		RSVD3,		0x2010,		0,	Y,	5,	7,	6,	8,	-1,	10,	12),
1890	PINGROUP(gen8_i2c_sda_pdd2,	I2C8,		RSVD1,		RSVD2,		RSVD3,		0x2018,		0,	Y,	5,	7,	6,	8,	-1,	10,	12),
1891	PINGROUP(gen8_i2c_scl_pdd1,	I2C8,		RSVD1,		RSVD2,		RSVD3,		0x2020,		0,	Y,	5,	7,	6,	8,	-1,	10,	12),
1892	PINGROUP(spi2_mosi_pcc2,	SPI2,		RSVD1,		RSVD2,		RSVD3,		0x2028,		0,	Y,	5,	7,	6,	8,	-1,	10,	12),
1893	PINGROUP(gen2_i2c_scl_pcc7,	I2C2,		RSVD1,		RSVD2,		RSVD3,		0x2030,		0,	Y,	5,	7,	6,	8,	-1,	10,	12),
1894	PINGROUP(spi2_cs0_pcc3,		SPI2,		RSVD1,		RSVD2,		RSVD3,		0x2038,		0,	Y,	5,	7,	6,	8,	-1,	10,	12),
1895	PINGROUP(gen2_i2c_sda_pdd0,	I2C2,		RSVD1,		RSVD2,		RSVD3,		0x2040,		0,	Y,	5,	7,	6,	8,	-1,	10,	12),
1896	PINGROUP(spi2_sck_pcc0,		SPI2,		RSVD1,		RSVD2,		RSVD3,		0x2048,		0,	Y,	5,	7,	6,	8,	-1,	10,	12),
1897	PINGROUP(spi2_miso_pcc1,	SPI2,		RSVD1,		RSVD2,		RSVD3,		0x2050,		0,	Y,	5,	7,	6,	8,	-1,	10,	12),
1898	PINGROUP(can1_dout_paa2,	CAN1,		RSVD1,		RSVD2,		RSVD3,		0x3000,		0,	Y,	-1,	5,	6,	-1,	9,	10,	12),
1899	PINGROUP(can1_din_paa3,		CAN1,		RSVD1,		RSVD2,		RSVD3,		0x3008,		0,	Y,	-1,	5,	6,	-1,	9,	10,	12),
1900	PINGROUP(can0_dout_paa0,	CAN0,		RSVD1,		RSVD2,		RSVD3,		0x3010,		0,	Y,	-1,	5,	6,	-1,	9,	10,	12),
1901	PINGROUP(can0_din_paa1,		CAN0,		RSVD1,		RSVD2,		RSVD3,		0x3018,		0,	Y,	-1,	5,	6,	-1,	9,	10,	12),
1902	PINGROUP(can0_stb_paa4,		RSVD0,		WDT,		TSC,		TSC_ALT,	0x3020,		0,	Y,	-1,	5,	6,	-1,	9,	10,	12),
1903	PINGROUP(can0_en_paa5,		RSVD0,		RSVD1,		RSVD2,		RSVD3,		0x3028,		0,	Y,	-1,	5,	6,	-1,	9,	10,	12),
1904	PINGROUP(soc_gpio49_paa6,	RSVD0,		RSVD1,		RSVD2,		RSVD3,		0x3030,		0,	Y,	-1,	5,	6,	-1,	9,	10,	12),
1905	PINGROUP(can0_err_paa7,		RSVD0,		TSC,		RSVD2,		TSC_ALT,	0x3038,		0,	Y,	-1,	5,	6,	-1,	9,	10,	12),
1906	PINGROUP(can1_stb_pbb0,		RSVD0,		DMIC3,		DMIC5,		RSVD3,		0x3040,		0,	Y,	-1,	5,	6,	-1,	9,	10,	12),
1907	PINGROUP(can1_en_pbb1,		RSVD0,		DMIC3,		DMIC5,		RSVD3,		0x3048,		0,	Y,	-1,	5,	6,	-1,	9,	10,	12),
1908	PINGROUP(soc_gpio50_pbb2,	RSVD0,		TSC,		RSVD2,		TSC_ALT,	0x3050,		0,	Y,	-1,	5,	6,	-1,	9,	10,	12),
1909	PINGROUP(can1_err_pbb3,		RSVD0,		TSC,		RSVD2,		TSC_ALT,	0x3058,		0,	Y,	-1,	5,	6,	-1,	9,	10,	12),
1910	PINGROUP(sce_error_pee0,	SCE,		RSVD1,		RSVD2,		RSVD3,		0x1010,		0,	Y,	5,	7,	6,	8,	-1,	10,	12),
1911	PINGROUP(batt_oc_pee3,		SOC,		RSVD1,		RSVD2,		RSVD3,		0x1020,		0,	Y,	5,	7,	6,	8,	-1,	10,	12),
1912	PINGROUP(bootv_ctl_n_pee7,	RSVD0,		RSVD1,		RSVD2,		RSVD3,		0x1028,		0,	Y,	-1,	7,	6,	8,	-1,	10,	12),
1913	PINGROUP(power_on_pee4,		RSVD0,		RSVD1,		RSVD2,		RSVD3,		0x1038,		0,	Y,	5,	7,	6,	8,	-1,	10,	12),
1914	PINGROUP(soc_gpio26_pee5,	RSVD0,		RSVD1,		RSVD2,		RSVD3,		0x1040,		0,	Y,	5,	7,	6,	8,	-1,	10,	12),
1915	PINGROUP(soc_gpio27_pee6,	RSVD0,		RSVD1,		RSVD2,		RSVD3,		0x1048,		0,	Y,	5,	7,	6,	8,	-1,	10,	12),
1916	PINGROUP(ao_retention_n_pee2,	GPIO,		LED,		RSVD2,		ISTCTRL,	0x1050,		0,	Y,	5,	7,	6,	8,	-1,	10,	12),
1917	PINGROUP(vcomp_alert_pee1,	SOC,		RSVD1,		RSVD2,		RSVD3,		0x1058,		0,	Y,	5,	7,	6,	8,	-1,	10,	12),
1918	PINGROUP(hdmi_cec_pgg0,		HDMI,		RSVD1,		RSVD2,		RSVD3,		0x1060,		0,	Y,	5,	7,	6,	8,	-1,	10,	12),
1919};
1920
1921static const struct tegra_pinctrl_soc_data tegra234_pinctrl_aon = {
1922	.pins = tegra234_aon_pins,
1923	.npins = ARRAY_SIZE(tegra234_aon_pins),
1924	.functions = tegra234_functions,
1925	.nfunctions = ARRAY_SIZE(tegra234_functions),
1926	.groups = tegra234_aon_groups,
1927	.ngroups = ARRAY_SIZE(tegra234_aon_groups),
1928	.hsm_in_mux = false,
1929	.schmitt_in_mux = true,
1930	.drvtype_in_mux = true,
1931	.sfsel_in_mux = true,
1932};
1933
1934static int tegra234_pinctrl_probe(struct platform_device *pdev)
1935{
1936	const struct tegra_pinctrl_soc_data *soc = device_get_match_data(&pdev->dev);
1937
1938	return tegra_pinctrl_probe(pdev, soc);
1939}
1940
1941static const struct of_device_id tegra234_pinctrl_of_match[] = {
1942	{ .compatible = "nvidia,tegra234-pinmux", .data = &tegra234_pinctrl},
1943	{ .compatible = "nvidia,tegra234-pinmux-aon", .data = &tegra234_pinctrl_aon },
1944	{ }
1945};
1946MODULE_DEVICE_TABLE(of, tegra234_pinctrl_of_match);
1947
1948static struct platform_driver tegra234_pinctrl_driver = {
1949	.driver = {
1950		.name = "tegra234-pinctrl",
1951		.of_match_table = tegra234_pinctrl_of_match,
1952	},
1953	.probe = tegra234_pinctrl_probe,
1954};
1955
1956static int __init tegra234_pinctrl_init(void)
1957{
1958	return platform_driver_register(&tegra234_pinctrl_driver);
1959}
1960arch_initcall(tegra234_pinctrl_init);