Linux kernel mirror (for testing) git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git
kernel os linux

pinctrl: tegra: Add Tegra234 pinmux driver

This change adds support for the two pin controllers found on Tegra234.

Signed-off-by: Prathamesh Shete <pshete@nvidia.com>
Signed-off-by: Thierry Reding <treding@nvidia.com>
Reviewed-by: Andy Shevchenko <andriy.shevchenko@linux.intel.com>
Link: https://lore.kernel.org/r/20230605154230.2910847-3-thierry.reding@gmail.com
Signed-off-by: Linus Walleij <linus.walleij@linaro.org>

authored by

Prathamesh Shete and committed by
Linus Walleij
6d8257ca 85798213

+1967
+4
drivers/pinctrl/tegra/Kconfig
··· 28 28 bool 29 29 select PINCTRL_TEGRA 30 30 31 + config PINCTRL_TEGRA234 32 + bool 33 + select PINCTRL_TEGRA 34 + 31 35 config PINCTRL_TEGRA_XUSB 32 36 def_bool y if ARCH_TEGRA 33 37 select GENERIC_PHY
+1
drivers/pinctrl/tegra/Makefile
··· 6 6 obj-$(CONFIG_PINCTRL_TEGRA124) += pinctrl-tegra124.o 7 7 obj-$(CONFIG_PINCTRL_TEGRA210) += pinctrl-tegra210.o 8 8 obj-$(CONFIG_PINCTRL_TEGRA194) += pinctrl-tegra194.o 9 + obj-$(CONFIG_PINCTRL_TEGRA234) += pinctrl-tegra234.o 9 10 obj-$(CONFIG_PINCTRL_TEGRA_XUSB) += pinctrl-tegra-xusb.o
+1961
drivers/pinctrl/tegra/pinctrl-tegra234.c
··· 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 */ 19 + enum { 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 + 189 + enum { 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 */ 225 + static 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 + 395 + static const unsigned int dap6_sclk_pa0_pins[] = { 396 + TEGRA_PIN_DAP6_SCLK_PA0, 397 + }; 398 + 399 + static const unsigned int dap6_dout_pa1_pins[] = { 400 + TEGRA_PIN_DAP6_DOUT_PA1, 401 + }; 402 + 403 + static const unsigned int dap6_din_pa2_pins[] = { 404 + TEGRA_PIN_DAP6_DIN_PA2, 405 + }; 406 + 407 + static const unsigned int dap6_fs_pa3_pins[] = { 408 + TEGRA_PIN_DAP6_FS_PA3, 409 + }; 410 + 411 + static const unsigned int dap4_sclk_pa4_pins[] = { 412 + TEGRA_PIN_DAP4_SCLK_PA4, 413 + }; 414 + 415 + static const unsigned int dap4_dout_pa5_pins[] = { 416 + TEGRA_PIN_DAP4_DOUT_PA5, 417 + }; 418 + 419 + static const unsigned int dap4_din_pa6_pins[] = { 420 + TEGRA_PIN_DAP4_DIN_PA6, 421 + }; 422 + 423 + static const unsigned int dap4_fs_pa7_pins[] = { 424 + TEGRA_PIN_DAP4_FS_PA7, 425 + }; 426 + 427 + static const unsigned int soc_gpio08_pb0_pins[] = { 428 + TEGRA_PIN_SOC_GPIO08_PB0, 429 + }; 430 + 431 + static const unsigned int qspi0_sck_pc0_pins[] = { 432 + TEGRA_PIN_QSPI0_SCK_PC0, 433 + }; 434 + 435 + static const unsigned int qspi0_cs_n_pc1_pins[] = { 436 + TEGRA_PIN_QSPI0_CS_N_PC1, 437 + }; 438 + 439 + static const unsigned int qspi0_io0_pc2_pins[] = { 440 + TEGRA_PIN_QSPI0_IO0_PC2, 441 + }; 442 + 443 + static const unsigned int qspi0_io1_pc3_pins[] = { 444 + TEGRA_PIN_QSPI0_IO1_PC3, 445 + }; 446 + 447 + static const unsigned int qspi0_io2_pc4_pins[] = { 448 + TEGRA_PIN_QSPI0_IO2_PC4, 449 + }; 450 + 451 + static const unsigned int qspi0_io3_pc5_pins[] = { 452 + TEGRA_PIN_QSPI0_IO3_PC5, 453 + }; 454 + 455 + static const unsigned int qspi1_sck_pc6_pins[] = { 456 + TEGRA_PIN_QSPI1_SCK_PC6, 457 + }; 458 + 459 + static const unsigned int qspi1_cs_n_pc7_pins[] = { 460 + TEGRA_PIN_QSPI1_CS_N_PC7, 461 + }; 462 + 463 + static const unsigned int qspi1_io0_pd0_pins[] = { 464 + TEGRA_PIN_QSPI1_IO0_PD0, 465 + }; 466 + 467 + static const unsigned int qspi1_io1_pd1_pins[] = { 468 + TEGRA_PIN_QSPI1_IO1_PD1, 469 + }; 470 + 471 + static const unsigned int qspi1_io2_pd2_pins[] = { 472 + TEGRA_PIN_QSPI1_IO2_PD2, 473 + }; 474 + 475 + static const unsigned int qspi1_io3_pd3_pins[] = { 476 + TEGRA_PIN_QSPI1_IO3_PD3, 477 + }; 478 + 479 + static const unsigned int eqos_txc_pe0_pins[] = { 480 + TEGRA_PIN_EQOS_TXC_PE0, 481 + }; 482 + 483 + static const unsigned int eqos_td0_pe1_pins[] = { 484 + TEGRA_PIN_EQOS_TD0_PE1, 485 + }; 486 + 487 + static const unsigned int eqos_td1_pe2_pins[] = { 488 + TEGRA_PIN_EQOS_TD1_PE2, 489 + }; 490 + 491 + static const unsigned int eqos_td2_pe3_pins[] = { 492 + TEGRA_PIN_EQOS_TD2_PE3, 493 + }; 494 + 495 + static const unsigned int eqos_td3_pe4_pins[] = { 496 + TEGRA_PIN_EQOS_TD3_PE4, 497 + }; 498 + 499 + static const unsigned int eqos_tx_ctl_pe5_pins[] = { 500 + TEGRA_PIN_EQOS_TX_CTL_PE5, 501 + }; 502 + 503 + static const unsigned int eqos_rd0_pe6_pins[] = { 504 + TEGRA_PIN_EQOS_RD0_PE6, 505 + }; 506 + 507 + static const unsigned int eqos_rd1_pe7_pins[] = { 508 + TEGRA_PIN_EQOS_RD1_PE7, 509 + }; 510 + 511 + static const unsigned int eqos_rd2_pf0_pins[] = { 512 + TEGRA_PIN_EQOS_RD2_PF0, 513 + }; 514 + 515 + static const unsigned int eqos_rd3_pf1_pins[] = { 516 + TEGRA_PIN_EQOS_RD3_PF1, 517 + }; 518 + 519 + static const unsigned int eqos_rx_ctl_pf2_pins[] = { 520 + TEGRA_PIN_EQOS_RX_CTL_PF2, 521 + }; 522 + 523 + static const unsigned int eqos_rxc_pf3_pins[] = { 524 + TEGRA_PIN_EQOS_RXC_PF3, 525 + }; 526 + 527 + static const unsigned int eqos_sma_mdio_pf4_pins[] = { 528 + TEGRA_PIN_EQOS_SMA_MDIO_PF4, 529 + }; 530 + 531 + static const unsigned int eqos_sma_mdc_pf5_pins[] = { 532 + TEGRA_PIN_EQOS_SMA_MDC_PF5, 533 + }; 534 + 535 + static const unsigned int soc_gpio13_pg0_pins[] = { 536 + TEGRA_PIN_SOC_GPIO13_PG0, 537 + }; 538 + 539 + static const unsigned int soc_gpio14_pg1_pins[] = { 540 + TEGRA_PIN_SOC_GPIO14_PG1, 541 + }; 542 + 543 + static const unsigned int soc_gpio15_pg2_pins[] = { 544 + TEGRA_PIN_SOC_GPIO15_PG2, 545 + }; 546 + 547 + static const unsigned int soc_gpio16_pg3_pins[] = { 548 + TEGRA_PIN_SOC_GPIO16_PG3, 549 + }; 550 + 551 + static const unsigned int soc_gpio17_pg4_pins[] = { 552 + TEGRA_PIN_SOC_GPIO17_PG4, 553 + }; 554 + 555 + static const unsigned int soc_gpio18_pg5_pins[] = { 556 + TEGRA_PIN_SOC_GPIO18_PG5, 557 + }; 558 + 559 + static const unsigned int soc_gpio19_pg6_pins[] = { 560 + TEGRA_PIN_SOC_GPIO19_PG6, 561 + }; 562 + 563 + static const unsigned int soc_gpio20_pg7_pins[] = { 564 + TEGRA_PIN_SOC_GPIO20_PG7, 565 + }; 566 + 567 + static const unsigned int soc_gpio21_ph0_pins[] = { 568 + TEGRA_PIN_SOC_GPIO21_PH0, 569 + }; 570 + 571 + static const unsigned int soc_gpio22_ph1_pins[] = { 572 + TEGRA_PIN_SOC_GPIO22_PH1, 573 + }; 574 + 575 + static const unsigned int soc_gpio06_ph2_pins[] = { 576 + TEGRA_PIN_SOC_GPIO06_PH2, 577 + }; 578 + 579 + static const unsigned int uart4_tx_ph3_pins[] = { 580 + TEGRA_PIN_UART4_TX_PH3, 581 + }; 582 + 583 + static const unsigned int uart4_rx_ph4_pins[] = { 584 + TEGRA_PIN_UART4_RX_PH4, 585 + }; 586 + 587 + static const unsigned int uart4_rts_ph5_pins[] = { 588 + TEGRA_PIN_UART4_RTS_PH5, 589 + }; 590 + 591 + static const unsigned int uart4_cts_ph6_pins[] = { 592 + TEGRA_PIN_UART4_CTS_PH6, 593 + }; 594 + 595 + static const unsigned int soc_gpio41_ph7_pins[] = { 596 + TEGRA_PIN_SOC_GPIO41_PH7, 597 + }; 598 + 599 + static const unsigned int soc_gpio42_pi0_pins[] = { 600 + TEGRA_PIN_SOC_GPIO42_PI0, 601 + }; 602 + 603 + static const unsigned int soc_gpio43_pi1_pins[] = { 604 + TEGRA_PIN_SOC_GPIO43_PI1, 605 + }; 606 + 607 + static const unsigned int soc_gpio44_pi2_pins[] = { 608 + TEGRA_PIN_SOC_GPIO44_PI2, 609 + }; 610 + 611 + static const unsigned int gen1_i2c_scl_pi3_pins[] = { 612 + TEGRA_PIN_GEN1_I2C_SCL_PI3, 613 + }; 614 + 615 + static const unsigned int gen1_i2c_sda_pi4_pins[] = { 616 + TEGRA_PIN_GEN1_I2C_SDA_PI4, 617 + }; 618 + 619 + static const unsigned int cpu_pwr_req_pi5_pins[] = { 620 + TEGRA_PIN_CPU_PWR_REQ_PI5, 621 + }; 622 + 623 + static const unsigned int soc_gpio07_pi6_pins[] = { 624 + TEGRA_PIN_SOC_GPIO07_PI6, 625 + }; 626 + 627 + static const unsigned int sdmmc1_clk_pj0_pins[] = { 628 + TEGRA_PIN_SDMMC1_CLK_PJ0, 629 + }; 630 + 631 + static const unsigned int sdmmc1_cmd_pj1_pins[] = { 632 + TEGRA_PIN_SDMMC1_CMD_PJ1, 633 + }; 634 + 635 + static const unsigned int sdmmc1_dat0_pj2_pins[] = { 636 + TEGRA_PIN_SDMMC1_DAT0_PJ2, 637 + }; 638 + 639 + static const unsigned int sdmmc1_dat1_pj3_pins[] = { 640 + TEGRA_PIN_SDMMC1_DAT1_PJ3, 641 + }; 642 + 643 + static const unsigned int sdmmc1_dat2_pj4_pins[] = { 644 + TEGRA_PIN_SDMMC1_DAT2_PJ4, 645 + }; 646 + 647 + static const unsigned int sdmmc1_dat3_pj5_pins[] = { 648 + TEGRA_PIN_SDMMC1_DAT3_PJ5, 649 + }; 650 + 651 + static const unsigned int pex_l0_clkreq_n_pk0_pins[] = { 652 + TEGRA_PIN_PEX_L0_CLKREQ_N_PK0, 653 + }; 654 + 655 + static const unsigned int pex_l0_rst_n_pk1_pins[] = { 656 + TEGRA_PIN_PEX_L0_RST_N_PK1, 657 + }; 658 + 659 + static const unsigned int pex_l1_clkreq_n_pk2_pins[] = { 660 + TEGRA_PIN_PEX_L1_CLKREQ_N_PK2, 661 + }; 662 + 663 + static const unsigned int pex_l1_rst_n_pk3_pins[] = { 664 + TEGRA_PIN_PEX_L1_RST_N_PK3, 665 + }; 666 + 667 + static const unsigned int pex_l2_clkreq_n_pk4_pins[] = { 668 + TEGRA_PIN_PEX_L2_CLKREQ_N_PK4, 669 + }; 670 + 671 + static const unsigned int pex_l2_rst_n_pk5_pins[] = { 672 + TEGRA_PIN_PEX_L2_RST_N_PK5, 673 + }; 674 + 675 + static const unsigned int pex_l3_clkreq_n_pk6_pins[] = { 676 + TEGRA_PIN_PEX_L3_CLKREQ_N_PK6, 677 + }; 678 + 679 + static const unsigned int pex_l3_rst_n_pk7_pins[] = { 680 + TEGRA_PIN_PEX_L3_RST_N_PK7, 681 + }; 682 + 683 + static const unsigned int pex_l4_clkreq_n_pl0_pins[] = { 684 + TEGRA_PIN_PEX_L4_CLKREQ_N_PL0, 685 + }; 686 + 687 + static const unsigned int pex_l4_rst_n_pl1_pins[] = { 688 + TEGRA_PIN_PEX_L4_RST_N_PL1, 689 + }; 690 + 691 + static const unsigned int pex_wake_n_pl2_pins[] = { 692 + TEGRA_PIN_PEX_WAKE_N_PL2, 693 + }; 694 + 695 + static const unsigned int soc_gpio34_pl3_pins[] = { 696 + TEGRA_PIN_SOC_GPIO34_PL3, 697 + }; 698 + 699 + static const unsigned int dp_aux_ch0_hpd_pm0_pins[] = { 700 + TEGRA_PIN_DP_AUX_CH0_HPD_PM0, 701 + }; 702 + 703 + static const unsigned int dp_aux_ch1_hpd_pm1_pins[] = { 704 + TEGRA_PIN_DP_AUX_CH1_HPD_PM1, 705 + }; 706 + 707 + static const unsigned int dp_aux_ch2_hpd_pm2_pins[] = { 708 + TEGRA_PIN_DP_AUX_CH2_HPD_PM2, 709 + }; 710 + 711 + static const unsigned int dp_aux_ch3_hpd_pm3_pins[] = { 712 + TEGRA_PIN_DP_AUX_CH3_HPD_PM3, 713 + }; 714 + 715 + static const unsigned int soc_gpio55_pm4_pins[] = { 716 + TEGRA_PIN_SOC_GPIO55_PM4, 717 + }; 718 + 719 + static const unsigned int soc_gpio36_pm5_pins[] = { 720 + TEGRA_PIN_SOC_GPIO36_PM5, 721 + }; 722 + 723 + static const unsigned int soc_gpio53_pm6_pins[] = { 724 + TEGRA_PIN_SOC_GPIO53_PM6, 725 + }; 726 + 727 + static const unsigned int soc_gpio38_pm7_pins[] = { 728 + TEGRA_PIN_SOC_GPIO38_PM7, 729 + }; 730 + 731 + static const unsigned int dp_aux_ch3_n_pn0_pins[] = { 732 + TEGRA_PIN_DP_AUX_CH3_N_PN0, 733 + }; 734 + 735 + static const unsigned int soc_gpio39_pn1_pins[] = { 736 + TEGRA_PIN_SOC_GPIO39_PN1, 737 + }; 738 + 739 + static const unsigned int soc_gpio40_pn2_pins[] = { 740 + TEGRA_PIN_SOC_GPIO40_PN2, 741 + }; 742 + 743 + static const unsigned int dp_aux_ch1_p_pn3_pins[] = { 744 + TEGRA_PIN_DP_AUX_CH1_P_PN3, 745 + }; 746 + 747 + static const unsigned int dp_aux_ch1_n_pn4_pins[] = { 748 + TEGRA_PIN_DP_AUX_CH1_N_PN4, 749 + }; 750 + 751 + static const unsigned int dp_aux_ch2_p_pn5_pins[] = { 752 + TEGRA_PIN_DP_AUX_CH2_P_PN5, 753 + }; 754 + 755 + static const unsigned int dp_aux_ch2_n_pn6_pins[] = { 756 + TEGRA_PIN_DP_AUX_CH2_N_PN6, 757 + }; 758 + 759 + static const unsigned int dp_aux_ch3_p_pn7_pins[] = { 760 + TEGRA_PIN_DP_AUX_CH3_P_PN7, 761 + }; 762 + 763 + static const unsigned int extperiph1_clk_pp0_pins[] = { 764 + TEGRA_PIN_EXTPERIPH1_CLK_PP0, 765 + }; 766 + 767 + static const unsigned int extperiph2_clk_pp1_pins[] = { 768 + TEGRA_PIN_EXTPERIPH2_CLK_PP1, 769 + }; 770 + 771 + static const unsigned int cam_i2c_scl_pp2_pins[] = { 772 + TEGRA_PIN_CAM_I2C_SCL_PP2, 773 + }; 774 + 775 + static const unsigned int cam_i2c_sda_pp3_pins[] = { 776 + TEGRA_PIN_CAM_I2C_SDA_PP3, 777 + }; 778 + 779 + static const unsigned int soc_gpio23_pp4_pins[] = { 780 + TEGRA_PIN_SOC_GPIO23_PP4, 781 + }; 782 + 783 + static const unsigned int soc_gpio24_pp5_pins[] = { 784 + TEGRA_PIN_SOC_GPIO24_PP5, 785 + }; 786 + 787 + static const unsigned int soc_gpio25_pp6_pins[] = { 788 + TEGRA_PIN_SOC_GPIO25_PP6, 789 + }; 790 + 791 + static const unsigned int pwr_i2c_scl_pp7_pins[] = { 792 + TEGRA_PIN_PWR_I2C_SCL_PP7, 793 + }; 794 + 795 + static const unsigned int pwr_i2c_sda_pq0_pins[] = { 796 + TEGRA_PIN_PWR_I2C_SDA_PQ0, 797 + }; 798 + 799 + static const unsigned int soc_gpio28_pq1_pins[] = { 800 + TEGRA_PIN_SOC_GPIO28_PQ1, 801 + }; 802 + 803 + static const unsigned int soc_gpio29_pq2_pins[] = { 804 + TEGRA_PIN_SOC_GPIO29_PQ2, 805 + }; 806 + 807 + static const unsigned int soc_gpio30_pq3_pins[] = { 808 + TEGRA_PIN_SOC_GPIO30_PQ3, 809 + }; 810 + 811 + static const unsigned int soc_gpio31_pq4_pins[] = { 812 + TEGRA_PIN_SOC_GPIO31_PQ4, 813 + }; 814 + 815 + static const unsigned int soc_gpio32_pq5_pins[] = { 816 + TEGRA_PIN_SOC_GPIO32_PQ5, 817 + }; 818 + 819 + static const unsigned int soc_gpio33_pq6_pins[] = { 820 + TEGRA_PIN_SOC_GPIO33_PQ6, 821 + }; 822 + 823 + static const unsigned int soc_gpio35_pq7_pins[] = { 824 + TEGRA_PIN_SOC_GPIO35_PQ7, 825 + }; 826 + 827 + static const unsigned int soc_gpio37_pr0_pins[] = { 828 + TEGRA_PIN_SOC_GPIO37_PR0, 829 + }; 830 + 831 + static const unsigned int soc_gpio56_pr1_pins[] = { 832 + TEGRA_PIN_SOC_GPIO56_PR1, 833 + }; 834 + 835 + static const unsigned int uart1_tx_pr2_pins[] = { 836 + TEGRA_PIN_UART1_TX_PR2, 837 + }; 838 + 839 + static const unsigned int uart1_rx_pr3_pins[] = { 840 + TEGRA_PIN_UART1_RX_PR3, 841 + }; 842 + 843 + static const unsigned int uart1_rts_pr4_pins[] = { 844 + TEGRA_PIN_UART1_RTS_PR4, 845 + }; 846 + 847 + static const unsigned int uart1_cts_pr5_pins[] = { 848 + TEGRA_PIN_UART1_CTS_PR5, 849 + }; 850 + 851 + static const unsigned int gpu_pwr_req_px0_pins[] = { 852 + TEGRA_PIN_GPU_PWR_REQ_PX0, 853 + }; 854 + 855 + static const unsigned int cv_pwr_req_px1_pins[] = { 856 + TEGRA_PIN_CV_PWR_REQ_PX1, 857 + }; 858 + 859 + static const unsigned int gp_pwm2_px2_pins[] = { 860 + TEGRA_PIN_GP_PWM2_PX2, 861 + }; 862 + 863 + static const unsigned int gp_pwm3_px3_pins[] = { 864 + TEGRA_PIN_GP_PWM3_PX3, 865 + }; 866 + 867 + static const unsigned int uart2_tx_px4_pins[] = { 868 + TEGRA_PIN_UART2_TX_PX4, 869 + }; 870 + 871 + static const unsigned int uart2_rx_px5_pins[] = { 872 + TEGRA_PIN_UART2_RX_PX5, 873 + }; 874 + 875 + static const unsigned int uart2_rts_px6_pins[] = { 876 + TEGRA_PIN_UART2_RTS_PX6, 877 + }; 878 + 879 + static const unsigned int uart2_cts_px7_pins[] = { 880 + TEGRA_PIN_UART2_CTS_PX7, 881 + }; 882 + 883 + static const unsigned int spi3_sck_py0_pins[] = { 884 + TEGRA_PIN_SPI3_SCK_PY0, 885 + }; 886 + 887 + static const unsigned int spi3_miso_py1_pins[] = { 888 + TEGRA_PIN_SPI3_MISO_PY1, 889 + }; 890 + 891 + static const unsigned int spi3_mosi_py2_pins[] = { 892 + TEGRA_PIN_SPI3_MOSI_PY2, 893 + }; 894 + 895 + static const unsigned int spi3_cs0_py3_pins[] = { 896 + TEGRA_PIN_SPI3_CS0_PY3, 897 + }; 898 + 899 + static const unsigned int spi3_cs1_py4_pins[] = { 900 + TEGRA_PIN_SPI3_CS1_PY4, 901 + }; 902 + 903 + static const unsigned int uart5_tx_py5_pins[] = { 904 + TEGRA_PIN_UART5_TX_PY5, 905 + }; 906 + 907 + static const unsigned int uart5_rx_py6_pins[] = { 908 + TEGRA_PIN_UART5_RX_PY6, 909 + }; 910 + 911 + static const unsigned int uart5_rts_py7_pins[] = { 912 + TEGRA_PIN_UART5_RTS_PY7, 913 + }; 914 + 915 + static const unsigned int uart5_cts_pz0_pins[] = { 916 + TEGRA_PIN_UART5_CTS_PZ0, 917 + }; 918 + 919 + static const unsigned int usb_vbus_en0_pz1_pins[] = { 920 + TEGRA_PIN_USB_VBUS_EN0_PZ1, 921 + }; 922 + 923 + static const unsigned int usb_vbus_en1_pz2_pins[] = { 924 + TEGRA_PIN_USB_VBUS_EN1_PZ2, 925 + }; 926 + 927 + static const unsigned int spi1_sck_pz3_pins[] = { 928 + TEGRA_PIN_SPI1_SCK_PZ3, 929 + }; 930 + 931 + static const unsigned int spi1_miso_pz4_pins[] = { 932 + TEGRA_PIN_SPI1_MISO_PZ4, 933 + }; 934 + 935 + static const unsigned int spi1_mosi_pz5_pins[] = { 936 + TEGRA_PIN_SPI1_MOSI_PZ5, 937 + }; 938 + 939 + static const unsigned int spi1_cs0_pz6_pins[] = { 940 + TEGRA_PIN_SPI1_CS0_PZ6, 941 + }; 942 + 943 + static const unsigned int spi1_cs1_pz7_pins[] = { 944 + TEGRA_PIN_SPI1_CS1_PZ7, 945 + }; 946 + 947 + static const unsigned int can0_dout_paa0_pins[] = { 948 + TEGRA_PIN_CAN0_DOUT_PAA0, 949 + }; 950 + 951 + static const unsigned int can0_din_paa1_pins[] = { 952 + TEGRA_PIN_CAN0_DIN_PAA1, 953 + }; 954 + 955 + static const unsigned int can1_dout_paa2_pins[] = { 956 + TEGRA_PIN_CAN1_DOUT_PAA2, 957 + }; 958 + 959 + static const unsigned int can1_din_paa3_pins[] = { 960 + TEGRA_PIN_CAN1_DIN_PAA3, 961 + }; 962 + 963 + static const unsigned int can0_stb_paa4_pins[] = { 964 + TEGRA_PIN_CAN0_STB_PAA4, 965 + }; 966 + 967 + static const unsigned int can0_en_paa5_pins[] = { 968 + TEGRA_PIN_CAN0_EN_PAA5, 969 + }; 970 + 971 + static const unsigned int soc_gpio49_paa6_pins[] = { 972 + TEGRA_PIN_SOC_GPIO49_PAA6, 973 + }; 974 + 975 + static const unsigned int can0_err_paa7_pins[] = { 976 + TEGRA_PIN_CAN0_ERR_PAA7, 977 + }; 978 + 979 + static const unsigned int spi5_sck_pac0_pins[] = { 980 + TEGRA_PIN_SPI5_SCK_PAC0, 981 + }; 982 + 983 + static const unsigned int spi5_miso_pac1_pins[] = { 984 + TEGRA_PIN_SPI5_MISO_PAC1, 985 + }; 986 + 987 + static const unsigned int spi5_mosi_pac2_pins[] = { 988 + TEGRA_PIN_SPI5_MOSI_PAC2, 989 + }; 990 + 991 + static const unsigned int spi5_cs0_pac3_pins[] = { 992 + TEGRA_PIN_SPI5_CS0_PAC3, 993 + }; 994 + 995 + static const unsigned int soc_gpio57_pac4_pins[] = { 996 + TEGRA_PIN_SOC_GPIO57_PAC4, 997 + }; 998 + 999 + static const unsigned int soc_gpio58_pac5_pins[] = { 1000 + TEGRA_PIN_SOC_GPIO58_PAC5, 1001 + }; 1002 + 1003 + static const unsigned int soc_gpio59_pac6_pins[] = { 1004 + TEGRA_PIN_SOC_GPIO59_PAC6, 1005 + }; 1006 + 1007 + static const unsigned int soc_gpio60_pac7_pins[] = { 1008 + TEGRA_PIN_SOC_GPIO60_PAC7, 1009 + }; 1010 + 1011 + static const unsigned int soc_gpio45_pad0_pins[] = { 1012 + TEGRA_PIN_SOC_GPIO45_PAD0, 1013 + }; 1014 + 1015 + static const unsigned int soc_gpio46_pad1_pins[] = { 1016 + TEGRA_PIN_SOC_GPIO46_PAD1, 1017 + }; 1018 + 1019 + static const unsigned int soc_gpio47_pad2_pins[] = { 1020 + TEGRA_PIN_SOC_GPIO47_PAD2, 1021 + }; 1022 + 1023 + static const unsigned int soc_gpio48_pad3_pins[] = { 1024 + TEGRA_PIN_SOC_GPIO48_PAD3, 1025 + }; 1026 + 1027 + static const unsigned int ufs0_ref_clk_pae0_pins[] = { 1028 + TEGRA_PIN_UFS0_REF_CLK_PAE0, 1029 + }; 1030 + 1031 + static const unsigned int ufs0_rst_n_pae1_pins[] = { 1032 + TEGRA_PIN_UFS0_RST_N_PAE1, 1033 + }; 1034 + 1035 + static const unsigned int pex_l5_clkreq_n_paf0_pins[] = { 1036 + TEGRA_PIN_PEX_L5_CLKREQ_N_PAF0, 1037 + }; 1038 + 1039 + static const unsigned int pex_l5_rst_n_paf1_pins[] = { 1040 + TEGRA_PIN_PEX_L5_RST_N_PAF1, 1041 + }; 1042 + 1043 + static const unsigned int pex_l6_clkreq_n_paf2_pins[] = { 1044 + TEGRA_PIN_PEX_L6_CLKREQ_N_PAF2, 1045 + }; 1046 + 1047 + static const unsigned int pex_l6_rst_n_paf3_pins[] = { 1048 + TEGRA_PIN_PEX_L6_RST_N_PAF3, 1049 + }; 1050 + 1051 + static const unsigned int pex_l7_clkreq_n_pag0_pins[] = { 1052 + TEGRA_PIN_PEX_L7_CLKREQ_N_PAG0, 1053 + }; 1054 + 1055 + static const unsigned int pex_l7_rst_n_pag1_pins[] = { 1056 + TEGRA_PIN_PEX_L7_RST_N_PAG1, 1057 + }; 1058 + 1059 + static const unsigned int pex_l8_clkreq_n_pag2_pins[] = { 1060 + TEGRA_PIN_PEX_L8_CLKREQ_N_PAG2, 1061 + }; 1062 + 1063 + static const unsigned int pex_l8_rst_n_pag3_pins[] = { 1064 + TEGRA_PIN_PEX_L8_RST_N_PAG3, 1065 + }; 1066 + 1067 + static const unsigned int pex_l9_clkreq_n_pag4_pins[] = { 1068 + TEGRA_PIN_PEX_L9_CLKREQ_N_PAG4, 1069 + }; 1070 + 1071 + static const unsigned int pex_l9_rst_n_pag5_pins[] = { 1072 + TEGRA_PIN_PEX_L9_RST_N_PAG5, 1073 + }; 1074 + 1075 + static const unsigned int pex_l10_clkreq_n_pag6_pins[] = { 1076 + TEGRA_PIN_PEX_L10_CLKREQ_N_PAG6, 1077 + }; 1078 + 1079 + static const unsigned int pex_l10_rst_n_pag7_pins[] = { 1080 + TEGRA_PIN_PEX_L10_RST_N_PAG7, 1081 + }; 1082 + 1083 + static const unsigned int can1_stb_pbb0_pins[] = { 1084 + TEGRA_PIN_CAN1_STB_PBB0, 1085 + }; 1086 + 1087 + static const unsigned int can1_en_pbb1_pins[] = { 1088 + TEGRA_PIN_CAN1_EN_PBB1, 1089 + }; 1090 + 1091 + static const unsigned int soc_gpio50_pbb2_pins[] = { 1092 + TEGRA_PIN_SOC_GPIO50_PBB2, 1093 + }; 1094 + 1095 + static const unsigned int can1_err_pbb3_pins[] = { 1096 + TEGRA_PIN_CAN1_ERR_PBB3, 1097 + }; 1098 + 1099 + static const unsigned int spi2_sck_pcc0_pins[] = { 1100 + TEGRA_PIN_SPI2_SCK_PCC0, 1101 + }; 1102 + 1103 + static const unsigned int spi2_miso_pcc1_pins[] = { 1104 + TEGRA_PIN_SPI2_MISO_PCC1, 1105 + }; 1106 + 1107 + static const unsigned int spi2_mosi_pcc2_pins[] = { 1108 + TEGRA_PIN_SPI2_MOSI_PCC2, 1109 + }; 1110 + 1111 + static const unsigned int spi2_cs0_pcc3_pins[] = { 1112 + TEGRA_PIN_SPI2_CS0_PCC3, 1113 + }; 1114 + 1115 + static const unsigned int touch_clk_pcc4_pins[] = { 1116 + TEGRA_PIN_TOUCH_CLK_PCC4, 1117 + }; 1118 + 1119 + static const unsigned int uart3_tx_pcc5_pins[] = { 1120 + TEGRA_PIN_UART3_TX_PCC5, 1121 + }; 1122 + 1123 + static const unsigned int uart3_rx_pcc6_pins[] = { 1124 + TEGRA_PIN_UART3_RX_PCC6, 1125 + }; 1126 + 1127 + static const unsigned int gen2_i2c_scl_pcc7_pins[] = { 1128 + TEGRA_PIN_GEN2_I2C_SCL_PCC7, 1129 + }; 1130 + 1131 + static const unsigned int gen2_i2c_sda_pdd0_pins[] = { 1132 + TEGRA_PIN_GEN2_I2C_SDA_PDD0, 1133 + }; 1134 + 1135 + static const unsigned int gen8_i2c_scl_pdd1_pins[] = { 1136 + TEGRA_PIN_GEN8_I2C_SCL_PDD1, 1137 + }; 1138 + 1139 + static const unsigned int gen8_i2c_sda_pdd2_pins[] = { 1140 + TEGRA_PIN_GEN8_I2C_SDA_PDD2, 1141 + }; 1142 + 1143 + static const unsigned int sce_error_pee0_pins[] = { 1144 + TEGRA_PIN_SCE_ERROR_PEE0, 1145 + }; 1146 + 1147 + static const unsigned int vcomp_alert_pee1_pins[] = { 1148 + TEGRA_PIN_VCOMP_ALERT_PEE1, 1149 + }; 1150 + 1151 + static const unsigned int ao_retention_n_pee2_pins[] = { 1152 + TEGRA_PIN_AO_RETENTION_N_PEE2, 1153 + }; 1154 + 1155 + static const unsigned int batt_oc_pee3_pins[] = { 1156 + TEGRA_PIN_BATT_OC_PEE3, 1157 + }; 1158 + 1159 + static const unsigned int power_on_pee4_pins[] = { 1160 + TEGRA_PIN_POWER_ON_PEE4, 1161 + }; 1162 + 1163 + static const unsigned int soc_gpio26_pee5_pins[] = { 1164 + TEGRA_PIN_SOC_GPIO26_PEE5, 1165 + }; 1166 + 1167 + static const unsigned int soc_gpio27_pee6_pins[] = { 1168 + TEGRA_PIN_SOC_GPIO27_PEE6, 1169 + }; 1170 + 1171 + static const unsigned int bootv_ctl_n_pee7_pins[] = { 1172 + TEGRA_PIN_BOOTV_CTL_N_PEE7, 1173 + }; 1174 + 1175 + static const unsigned int hdmi_cec_pgg0_pins[] = { 1176 + TEGRA_PIN_HDMI_CEC_PGG0, 1177 + }; 1178 + 1179 + static const unsigned int eqos_comp_pins[] = { 1180 + TEGRA_PIN_EQOS_COMP, 1181 + }; 1182 + 1183 + static const unsigned int qspi_comp_pins[] = { 1184 + TEGRA_PIN_QSPI_COMP, 1185 + }; 1186 + 1187 + static const unsigned int sdmmc1_comp_pins[] = { 1188 + TEGRA_PIN_SDMMC1_COMP, 1189 + }; 1190 + 1191 + /* Define unique ID for each function */ 1192 + enum 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 + 1288 + static 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 + .drv_reg = -1, \ 1446 + 1447 + /* main drive pin groups */ 1448 + #define drive_soc_gpio08_pb0 DRV_PINGROUP_ENTRY_Y(0x500c, 12, 5, 20, 5, -1, -1, -1, -1, 0) 1449 + #define drive_soc_gpio36_pm5 DRV_PINGROUP_ENTRY_Y(0x10004, 12, 5, 20, 5, -1, -1, -1, -1, 0) 1450 + #define drive_soc_gpio53_pm6 DRV_PINGROUP_ENTRY_Y(0x1000c, 12, 5, 20, 5, -1, -1, -1, -1, 0) 1451 + #define drive_soc_gpio55_pm4 DRV_PINGROUP_ENTRY_Y(0x10014, 12, 5, 20, 5, -1, -1, -1, -1, 0) 1452 + #define drive_soc_gpio38_pm7 DRV_PINGROUP_ENTRY_Y(0x1001c, 12, 5, 20, 5, -1, -1, -1, -1, 0) 1453 + #define drive_soc_gpio39_pn1 DRV_PINGROUP_ENTRY_Y(0x10024, 12, 5, 20, 5, -1, -1, -1, -1, 0) 1454 + #define drive_soc_gpio40_pn2 DRV_PINGROUP_ENTRY_Y(0x1002c, 12, 5, 20, 5, -1, -1, -1, -1, 0) 1455 + #define drive_dp_aux_ch0_hpd_pm0 DRV_PINGROUP_ENTRY_Y(0x10034, 12, 5, 20, 5, -1, -1, -1, -1, 0) 1456 + #define drive_dp_aux_ch1_hpd_pm1 DRV_PINGROUP_ENTRY_Y(0x1003c, 12, 5, 20, 5, -1, -1, -1, -1, 0) 1457 + #define drive_dp_aux_ch2_hpd_pm2 DRV_PINGROUP_ENTRY_Y(0x10044, 12, 5, 20, 5, -1, -1, -1, -1, 0) 1458 + #define drive_dp_aux_ch3_hpd_pm3 DRV_PINGROUP_ENTRY_Y(0x1004c, 12, 5, 20, 5, -1, -1, -1, -1, 0) 1459 + #define drive_dp_aux_ch1_p_pn3 DRV_PINGROUP_ENTRY_Y(0x10054, 12, 5, 20, 5, -1, -1, -1, -1, 0) 1460 + #define drive_dp_aux_ch1_n_pn4 DRV_PINGROUP_ENTRY_Y(0x1005c, 12, 5, 20, 5, -1, -1, -1, -1, 0) 1461 + #define drive_dp_aux_ch2_p_pn5 DRV_PINGROUP_ENTRY_Y(0x10064, 12, 5, 20, 5, -1, -1, -1, -1, 0) 1462 + #define drive_dp_aux_ch2_n_pn6 DRV_PINGROUP_ENTRY_Y(0x1006c, 12, 5, 20, 5, -1, -1, -1, -1, 0) 1463 + #define drive_dp_aux_ch3_p_pn7 DRV_PINGROUP_ENTRY_Y(0x10074, 12, 5, 20, 5, -1, -1, -1, -1, 0) 1464 + #define drive_dp_aux_ch3_n_pn0 DRV_PINGROUP_ENTRY_Y(0x1007c, 12, 5, 20, 5, -1, -1, -1, -1, 0) 1465 + #define drive_pex_l2_clkreq_n_pk4 DRV_PINGROUP_ENTRY_Y(0x7004, 12, 5, 20, 5, -1, -1, -1, -1, 0) 1466 + #define drive_pex_wake_n_pl2 DRV_PINGROUP_ENTRY_Y(0x700c, 12, 5, 20, 5, -1, -1, -1, -1, 0) 1467 + #define drive_pex_l1_clkreq_n_pk2 DRV_PINGROUP_ENTRY_Y(0x7014, 12, 5, 20, 5, -1, -1, -1, -1, 0) 1468 + #define drive_pex_l1_rst_n_pk3 DRV_PINGROUP_ENTRY_Y(0x701c, 12, 5, 20, 5, -1, -1, -1, -1, 0) 1469 + #define drive_pex_l0_clkreq_n_pk0 DRV_PINGROUP_ENTRY_Y(0x7024, 12, 5, 20, 5, -1, -1, -1, -1, 0) 1470 + #define drive_pex_l0_rst_n_pk1 DRV_PINGROUP_ENTRY_Y(0x702c, 12, 5, 20, 5, -1, -1, -1, -1, 0) 1471 + #define drive_pex_l2_rst_n_pk5 DRV_PINGROUP_ENTRY_Y(0x7034, 12, 5, 20, 5, -1, -1, -1, -1, 0) 1472 + #define drive_pex_l3_clkreq_n_pk6 DRV_PINGROUP_ENTRY_Y(0x703c, 12, 5, 20, 5, -1, -1, -1, -1, 0) 1473 + #define drive_pex_l3_rst_n_pk7 DRV_PINGROUP_ENTRY_Y(0x7044, 12, 5, 20, 5, -1, -1, -1, -1, 0) 1474 + #define drive_pex_l4_clkreq_n_pl0 DRV_PINGROUP_ENTRY_Y(0x704c, 12, 5, 20, 5, -1, -1, -1, -1, 0) 1475 + #define drive_pex_l4_rst_n_pl1 DRV_PINGROUP_ENTRY_Y(0x7054, 12, 5, 20, 5, -1, -1, -1, -1, 0) 1476 + #define drive_soc_gpio34_pl3 DRV_PINGROUP_ENTRY_Y(0x705c, 12, 5, 20, 5, -1, -1, -1, -1, 0) 1477 + #define drive_pex_l5_clkreq_n_paf0 DRV_PINGROUP_ENTRY_Y(0x14004, 12, 5, 20, 5, -1, -1, -1, -1, 0) 1478 + #define drive_pex_l5_rst_n_paf1 DRV_PINGROUP_ENTRY_Y(0x1400c, 12, 5, 20, 5, -1, -1, -1, -1, 0) 1479 + #define drive_pex_l6_clkreq_n_paf2 DRV_PINGROUP_ENTRY_Y(0x14014, 12, 5, 20, 5, -1, -1, -1, -1, 0) 1480 + #define drive_pex_l6_rst_n_paf3 DRV_PINGROUP_ENTRY_Y(0x1401c, 12, 5, 20, 5, -1, -1, -1, -1, 0) 1481 + #define drive_pex_l10_clkreq_n_pag6 DRV_PINGROUP_ENTRY_Y(0x19004, 12, 5, 20, 5, -1, -1, -1, -1, 0) 1482 + #define drive_pex_l10_rst_n_pag7 DRV_PINGROUP_ENTRY_Y(0x1900c, 12, 5, 20, 5, -1, -1, -1, -1, 0) 1483 + #define drive_pex_l7_clkreq_n_pag0 DRV_PINGROUP_ENTRY_Y(0x19014, 12, 5, 20, 5, -1, -1, -1, -1, 0) 1484 + #define drive_pex_l7_rst_n_pag1 DRV_PINGROUP_ENTRY_Y(0x1901c, 12, 5, 20, 5, -1, -1, -1, -1, 0) 1485 + #define drive_pex_l8_clkreq_n_pag2 DRV_PINGROUP_ENTRY_Y(0x19024, 12, 5, 20, 5, -1, -1, -1, -1, 0) 1486 + #define drive_pex_l8_rst_n_pag3 DRV_PINGROUP_ENTRY_Y(0x1902c, 12, 5, 20, 5, -1, -1, -1, -1, 0) 1487 + #define drive_pex_l9_clkreq_n_pag4 DRV_PINGROUP_ENTRY_Y(0x19034, 12, 5, 20, 5, -1, -1, -1, -1, 0) 1488 + #define drive_pex_l9_rst_n_pag5 DRV_PINGROUP_ENTRY_Y(0x1903c, 12, 5, 20, 5, -1, -1, -1, -1, 0) 1489 + #define drive_sdmmc1_clk_pj0 DRV_PINGROUP_ENTRY_Y(0x8004, 28, 2, 30, 2, -1, -1, -1, -1, 0) 1490 + #define drive_sdmmc1_cmd_pj1 DRV_PINGROUP_ENTRY_Y(0x800c, 28, 2, 30, 2, -1, -1, -1, -1, 0) 1491 + #define drive_sdmmc1_dat3_pj5 DRV_PINGROUP_ENTRY_Y(0x801c, 28, 2, 30, 2, -1, -1, -1, -1, 0) 1492 + #define drive_sdmmc1_dat2_pj4 DRV_PINGROUP_ENTRY_Y(0x8024, 28, 2, 30, 2, -1, -1, -1, -1, 0) 1493 + #define drive_sdmmc1_dat1_pj3 DRV_PINGROUP_ENTRY_Y(0x802c, 28, 2, 30, 2, -1, -1, -1, -1, 0) 1494 + #define drive_sdmmc1_dat0_pj2 DRV_PINGROUP_ENTRY_Y(0x8034, 28, 2, 30, 2, -1, -1, -1, -1, 0) 1495 + #define drive_ufs0_rst_n_pae1 DRV_PINGROUP_ENTRY_Y(0x11004, 12, 5, 24, 5, -1, -1, -1, -1, 0) 1496 + #define drive_ufs0_ref_clk_pae0 DRV_PINGROUP_ENTRY_Y(0x1100c, 12, 5, 24, 5, -1, -1, -1, -1, 0) 1497 + #define drive_spi3_miso_py1 DRV_PINGROUP_ENTRY_Y(0xd004, 12, 5, 20, 5, -1, -1, -1, -1, 0) 1498 + #define drive_spi1_cs0_pz6 DRV_PINGROUP_ENTRY_Y(0xd00c, 12, 5, 20, 5, -1, -1, -1, -1, 0) 1499 + #define drive_spi3_cs0_py3 DRV_PINGROUP_ENTRY_Y(0xd014, 12, 5, 20, 5, -1, -1, -1, -1, 0) 1500 + #define drive_spi1_miso_pz4 DRV_PINGROUP_ENTRY_Y(0xd01c, 12, 5, 20, 5, -1, -1, -1, -1, 0) 1501 + #define drive_spi3_cs1_py4 DRV_PINGROUP_ENTRY_Y(0xd024, 12, 5, 20, 5, -1, -1, -1, -1, 0) 1502 + #define drive_spi1_sck_pz3 DRV_PINGROUP_ENTRY_Y(0xd02c, 12, 5, 20, 5, -1, -1, -1, -1, 0) 1503 + #define drive_spi3_sck_py0 DRV_PINGROUP_ENTRY_Y(0xd034, 12, 5, 20, 5, -1, -1, -1, -1, 0) 1504 + #define drive_spi1_cs1_pz7 DRV_PINGROUP_ENTRY_Y(0xd03c, 12, 5, 20, 5, -1, -1, -1, -1, 0) 1505 + #define drive_spi1_mosi_pz5 DRV_PINGROUP_ENTRY_Y(0xd044, 12, 5, 20, 5, -1, -1, -1, -1, 0) 1506 + #define drive_spi3_mosi_py2 DRV_PINGROUP_ENTRY_Y(0xd04c, 12, 5, 20, 5, -1, -1, -1, -1, 0) 1507 + #define drive_uart2_tx_px4 DRV_PINGROUP_ENTRY_Y(0xd054, 12, 5, 20, 5, -1, -1, -1, -1, 0) 1508 + #define drive_uart2_rx_px5 DRV_PINGROUP_ENTRY_Y(0xd05c, 12, 5, 20, 5, -1, -1, -1, -1, 0) 1509 + #define drive_uart2_rts_px6 DRV_PINGROUP_ENTRY_Y(0xd064, 12, 5, 20, 5, -1, -1, -1, -1, 0) 1510 + #define drive_uart2_cts_px7 DRV_PINGROUP_ENTRY_Y(0xd06c, 12, 5, 20, 5, -1, -1, -1, -1, 0) 1511 + #define drive_uart5_tx_py5 DRV_PINGROUP_ENTRY_Y(0xd074, 12, 5, 20, 5, -1, -1, -1, -1, 0) 1512 + #define drive_uart5_rx_py6 DRV_PINGROUP_ENTRY_Y(0xd07c, 12, 5, 20, 5, -1, -1, -1, -1, 0) 1513 + #define drive_uart5_rts_py7 DRV_PINGROUP_ENTRY_Y(0xd084, 12, 5, 20, 5, -1, -1, -1, -1, 0) 1514 + #define drive_uart5_cts_pz0 DRV_PINGROUP_ENTRY_Y(0xd08c, 12, 5, 20, 5, -1, -1, -1, -1, 0) 1515 + #define drive_gpu_pwr_req_px0 DRV_PINGROUP_ENTRY_Y(0xd094, 12, 5, 20, 5, -1, -1, -1, -1, 0) 1516 + #define drive_gp_pwm3_px3 DRV_PINGROUP_ENTRY_Y(0xd09c, 12, 5, 20, 5, -1, -1, -1, -1, 0) 1517 + #define drive_gp_pwm2_px2 DRV_PINGROUP_ENTRY_Y(0xd0a4, 12, 5, 20, 5, -1, -1, -1, -1, 0) 1518 + #define drive_cv_pwr_req_px1 DRV_PINGROUP_ENTRY_Y(0xd0ac, 12, 5, 20, 5, -1, -1, -1, -1, 0) 1519 + #define drive_usb_vbus_en0_pz1 DRV_PINGROUP_ENTRY_Y(0xd0b4, 12, 5, 20, 5, -1, -1, -1, -1, 0) 1520 + #define drive_usb_vbus_en1_pz2 DRV_PINGROUP_ENTRY_Y(0xd0bc, 12, 5, 20, 5, -1, -1, -1, -1, 0) 1521 + #define drive_extperiph2_clk_pp1 DRV_PINGROUP_ENTRY_Y(0x0004, 12, 5, 20, 5, -1, -1, -1, -1, 0) 1522 + #define drive_extperiph1_clk_pp0 DRV_PINGROUP_ENTRY_Y(0x000c, 12, 5, 20, 5, -1, -1, -1, -1, 0) 1523 + #define drive_cam_i2c_sda_pp3 DRV_PINGROUP_ENTRY_Y(0x0014, 12, 5, 20, 5, -1, -1, -1, -1, 0) 1524 + #define drive_cam_i2c_scl_pp2 DRV_PINGROUP_ENTRY_Y(0x001c, 12, 5, 20, 5, -1, -1, -1, -1, 0) 1525 + #define drive_soc_gpio23_pp4 DRV_PINGROUP_ENTRY_Y(0x0024, 12, 5, 20, 5, -1, -1, -1, -1, 0) 1526 + #define drive_soc_gpio24_pp5 DRV_PINGROUP_ENTRY_Y(0x002c, 12, 5, 20, 5, -1, -1, -1, -1, 0) 1527 + #define drive_soc_gpio25_pp6 DRV_PINGROUP_ENTRY_Y(0x0034, 12, 5, 20, 5, -1, -1, -1, -1, 0) 1528 + #define drive_pwr_i2c_scl_pp7 DRV_PINGROUP_ENTRY_Y(0x003c, 12, 5, 20, 5, -1, -1, -1, -1, 0) 1529 + #define drive_pwr_i2c_sda_pq0 DRV_PINGROUP_ENTRY_Y(0x0044, 12, 5, 20, 5, -1, -1, -1, -1, 0) 1530 + #define drive_soc_gpio28_pq1 DRV_PINGROUP_ENTRY_Y(0x004c, 12, 5, 20, 5, -1, -1, -1, -1, 0) 1531 + #define drive_soc_gpio29_pq2 DRV_PINGROUP_ENTRY_Y(0x0054, 12, 5, 20, 5, -1, -1, -1, -1, 0) 1532 + #define drive_soc_gpio30_pq3 DRV_PINGROUP_ENTRY_Y(0x005c, 12, 5, 20, 5, -1, -1, -1, -1, 0) 1533 + #define drive_soc_gpio31_pq4 DRV_PINGROUP_ENTRY_Y(0x0064, 12, 5, 20, 5, -1, -1, -1, -1, 0) 1534 + #define drive_soc_gpio32_pq5 DRV_PINGROUP_ENTRY_Y(0x006c, 12, 5, 20, 5, -1, -1, -1, -1, 0) 1535 + #define drive_soc_gpio33_pq6 DRV_PINGROUP_ENTRY_Y(0x0074, 12, 5, 20, 5, -1, -1, -1, -1, 0) 1536 + #define drive_soc_gpio35_pq7 DRV_PINGROUP_ENTRY_Y(0x007c, 12, 5, 20, 5, -1, -1, -1, -1, 0) 1537 + #define drive_soc_gpio37_pr0 DRV_PINGROUP_ENTRY_Y(0x0084, 12, 5, 20, 5, -1, -1, -1, -1, 0) 1538 + #define drive_soc_gpio56_pr1 DRV_PINGROUP_ENTRY_Y(0x008c, 12, 5, 20, 5, -1, -1, -1, -1, 0) 1539 + #define drive_uart1_cts_pr5 DRV_PINGROUP_ENTRY_Y(0x0094, 12, 5, 20, 5, -1, -1, -1, -1, 0) 1540 + #define drive_uart1_rts_pr4 DRV_PINGROUP_ENTRY_Y(0x009c, 12, 5, 20, 5, -1, -1, -1, -1, 0) 1541 + #define drive_uart1_rx_pr3 DRV_PINGROUP_ENTRY_Y(0x00a4, 12, 5, 20, 5, -1, -1, -1, -1, 0) 1542 + #define drive_uart1_tx_pr2 DRV_PINGROUP_ENTRY_Y(0x00ac, 12, 5, 20, 5, -1, -1, -1, -1, 0) 1543 + #define drive_cpu_pwr_req_pi5 DRV_PINGROUP_ENTRY_Y(0x4004, 12, 5, 20, 5, -1, -1, -1, -1, 0) 1544 + #define drive_uart4_cts_ph6 DRV_PINGROUP_ENTRY_Y(0x400c, 12, 5, 20, 5, -1, -1, -1, -1, 0) 1545 + #define drive_uart4_rts_ph5 DRV_PINGROUP_ENTRY_Y(0x4014, 12, 5, 20, 5, -1, -1, -1, -1, 0) 1546 + #define drive_uart4_rx_ph4 DRV_PINGROUP_ENTRY_Y(0x401c, 12, 5, 20, 5, -1, -1, -1, -1, 0) 1547 + #define drive_uart4_tx_ph3 DRV_PINGROUP_ENTRY_Y(0x4024, 12, 5, 20, 5, -1, -1, -1, -1, 0) 1548 + #define drive_gen1_i2c_scl_pi3 DRV_PINGROUP_ENTRY_Y(0x402c, 12, 5, 20, 5, -1, -1, -1, -1, 0) 1549 + #define drive_gen1_i2c_sda_pi4 DRV_PINGROUP_ENTRY_Y(0x4034, 12, 5, 20, 5, -1, -1, -1, -1, 0) 1550 + #define drive_soc_gpio20_pg7 DRV_PINGROUP_ENTRY_Y(0x403c, 12, 5, 20, 5, -1, -1, -1, -1, 0) 1551 + #define drive_soc_gpio21_ph0 DRV_PINGROUP_ENTRY_Y(0x4044, 12, 5, 20, 5, -1, -1, -1, -1, 0) 1552 + #define drive_soc_gpio22_ph1 DRV_PINGROUP_ENTRY_Y(0x404c, 12, 5, 20, 5, -1, -1, -1, -1, 0) 1553 + #define drive_soc_gpio13_pg0 DRV_PINGROUP_ENTRY_Y(0x4054, 12, 5, 20, 5, -1, -1, -1, -1, 0) 1554 + #define drive_soc_gpio14_pg1 DRV_PINGROUP_ENTRY_Y(0x405c, 12, 5, 20, 5, -1, -1, -1, -1, 0) 1555 + #define drive_soc_gpio15_pg2 DRV_PINGROUP_ENTRY_Y(0x4064, 12, 5, 20, 5, -1, -1, -1, -1, 0) 1556 + #define drive_soc_gpio16_pg3 DRV_PINGROUP_ENTRY_Y(0x406c, 12, 5, 20, 5, -1, -1, -1, -1, 0) 1557 + #define drive_soc_gpio17_pg4 DRV_PINGROUP_ENTRY_Y(0x4074, 12, 5, 20, 5, -1, -1, -1, -1, 0) 1558 + #define drive_soc_gpio18_pg5 DRV_PINGROUP_ENTRY_Y(0x407c, 12, 5, 20, 5, -1, -1, -1, -1, 0) 1559 + #define drive_soc_gpio19_pg6 DRV_PINGROUP_ENTRY_Y(0x4084, 12, 5, 20, 5, -1, -1, -1, -1, 0) 1560 + #define drive_soc_gpio41_ph7 DRV_PINGROUP_ENTRY_Y(0x408c, 12, 5, 20, 5, -1, -1, -1, -1, 0) 1561 + #define drive_soc_gpio42_pi0 DRV_PINGROUP_ENTRY_Y(0x4094, 12, 5, 20, 5, -1, -1, -1, -1, 0) 1562 + #define drive_soc_gpio43_pi1 DRV_PINGROUP_ENTRY_Y(0x409c, 12, 5, 20, 5, -1, -1, -1, -1, 0) 1563 + #define drive_soc_gpio44_pi2 DRV_PINGROUP_ENTRY_Y(0x40a4, 12, 5, 20, 5, -1, -1, -1, -1, 0) 1564 + #define drive_soc_gpio06_ph2 DRV_PINGROUP_ENTRY_Y(0x40ac, 12, 5, 20, 5, -1, -1, -1, -1, 0) 1565 + #define drive_soc_gpio07_pi6 DRV_PINGROUP_ENTRY_Y(0x40b4, 12, 5, 20, 5, -1, -1, -1, -1, 0) 1566 + #define drive_dap4_sclk_pa4 DRV_PINGROUP_ENTRY_Y(0x2004, 12, 5, 20, 5, -1, -1, -1, -1, 0) 1567 + #define drive_dap4_dout_pa5 DRV_PINGROUP_ENTRY_Y(0x200c, 12, 5, 20, 5, -1, -1, -1, -1, 0) 1568 + #define drive_dap4_din_pa6 DRV_PINGROUP_ENTRY_Y(0x2014, 12, 5, 20, 5, -1, -1, -1, -1, 0) 1569 + #define drive_dap4_fs_pa7 DRV_PINGROUP_ENTRY_Y(0x201c, 12, 5, 20, 5, -1, -1, -1, -1, 0) 1570 + #define drive_dap6_sclk_pa0 DRV_PINGROUP_ENTRY_Y(0x2024, 12, 5, 20, 5, -1, -1, -1, -1, 0) 1571 + #define drive_dap6_dout_pa1 DRV_PINGROUP_ENTRY_Y(0x202c, 12, 5, 20, 5, -1, -1, -1, -1, 0) 1572 + #define drive_dap6_din_pa2 DRV_PINGROUP_ENTRY_Y(0x2034, 12, 5, 20, 5, -1, -1, -1, -1, 0) 1573 + #define drive_dap6_fs_pa3 DRV_PINGROUP_ENTRY_Y(0x203c, 12, 5, 20, 5, -1, -1, -1, -1, 0) 1574 + #define drive_soc_gpio45_pad0 DRV_PINGROUP_ENTRY_Y(0x18004, 12, 5, 20, 5, -1, -1, -1, -1, 0) 1575 + #define drive_soc_gpio46_pad1 DRV_PINGROUP_ENTRY_Y(0x1800c, 12, 5, 20, 5, -1, -1, -1, -1, 0) 1576 + #define drive_soc_gpio47_pad2 DRV_PINGROUP_ENTRY_Y(0x18014, 12, 5, 20, 5, -1, -1, -1, -1, 0) 1577 + #define drive_soc_gpio48_pad3 DRV_PINGROUP_ENTRY_Y(0x1801c, 12, 5, 20, 5, -1, -1, -1, -1, 0) 1578 + #define drive_soc_gpio57_pac4 DRV_PINGROUP_ENTRY_Y(0x18024, 12, 5, 20, 5, -1, -1, -1, -1, 0) 1579 + #define drive_soc_gpio58_pac5 DRV_PINGROUP_ENTRY_Y(0x1802c, 12, 5, 20, 5, -1, -1, -1, -1, 0) 1580 + #define drive_soc_gpio59_pac6 DRV_PINGROUP_ENTRY_Y(0x18034, 12, 5, 20, 5, -1, -1, -1, -1, 0) 1581 + #define drive_soc_gpio60_pac7 DRV_PINGROUP_ENTRY_Y(0x1803c, 12, 5, 20, 5, -1, -1, -1, -1, 0) 1582 + #define drive_spi5_cs0_pac3 DRV_PINGROUP_ENTRY_Y(0x18044, 12, 5, 20, 5, -1, -1, -1, -1, 0) 1583 + #define drive_spi5_miso_pac1 DRV_PINGROUP_ENTRY_Y(0x1804c, 12, 5, 20, 5, -1, -1, -1, -1, 0) 1584 + #define drive_spi5_mosi_pac2 DRV_PINGROUP_ENTRY_Y(0x18054, 12, 5, 20, 5, -1, -1, -1, -1, 0) 1585 + #define drive_spi5_sck_pac0 DRV_PINGROUP_ENTRY_Y(0x1805c, 12, 5, 20, 5, -1, -1, -1, -1, 0) 1586 + #define drive_eqos_td3_pe4 DRV_PINGROUP_ENTRY_N(no_entry) 1587 + #define drive_eqos_td2_pe3 DRV_PINGROUP_ENTRY_N(no_entry) 1588 + #define drive_eqos_td1_pe2 DRV_PINGROUP_ENTRY_N(no_entry) 1589 + #define drive_eqos_td0_pe1 DRV_PINGROUP_ENTRY_N(no_entry) 1590 + #define drive_eqos_rd3_pf1 DRV_PINGROUP_ENTRY_N(no_entry) 1591 + #define drive_eqos_rd2_pf0 DRV_PINGROUP_ENTRY_N(no_entry) 1592 + #define drive_eqos_rd1_pe7 DRV_PINGROUP_ENTRY_N(no_entry) 1593 + #define drive_eqos_sma_mdio_pf4 DRV_PINGROUP_ENTRY_N(no_entry) 1594 + #define drive_eqos_rd0_pe6 DRV_PINGROUP_ENTRY_N(no_entry) 1595 + #define drive_eqos_sma_mdc_pf5 DRV_PINGROUP_ENTRY_N(no_entry) 1596 + #define drive_eqos_comp DRV_PINGROUP_ENTRY_N(no_entry) 1597 + #define drive_eqos_txc_pe0 DRV_PINGROUP_ENTRY_N(no_entry) 1598 + #define drive_eqos_rxc_pf3 DRV_PINGROUP_ENTRY_N(no_entry) 1599 + #define drive_eqos_tx_ctl_pe5 DRV_PINGROUP_ENTRY_N(no_entry) 1600 + #define drive_eqos_rx_ctl_pf2 DRV_PINGROUP_ENTRY_N(no_entry) 1601 + #define drive_qspi0_io3_pc5 DRV_PINGROUP_ENTRY_N(no_entry) 1602 + #define drive_qspi0_io2_pc4 DRV_PINGROUP_ENTRY_N(no_entry) 1603 + #define drive_qspi0_io1_pc3 DRV_PINGROUP_ENTRY_N(no_entry) 1604 + #define drive_qspi0_io0_pc2 DRV_PINGROUP_ENTRY_N(no_entry) 1605 + #define drive_qspi0_sck_pc0 DRV_PINGROUP_ENTRY_N(no_entry) 1606 + #define drive_qspi0_cs_n_pc1 DRV_PINGROUP_ENTRY_N(no_entry) 1607 + #define drive_qspi1_io3_pd3 DRV_PINGROUP_ENTRY_N(no_entry) 1608 + #define drive_qspi1_io2_pd2 DRV_PINGROUP_ENTRY_N(no_entry) 1609 + #define drive_qspi1_io1_pd1 DRV_PINGROUP_ENTRY_N(no_entry) 1610 + #define drive_qspi1_io0_pd0 DRV_PINGROUP_ENTRY_N(no_entry) 1611 + #define drive_qspi1_sck_pc6 DRV_PINGROUP_ENTRY_N(no_entry) 1612 + #define drive_qspi1_cs_n_pc7 DRV_PINGROUP_ENTRY_N(no_entry) 1613 + #define drive_qspi_comp DRV_PINGROUP_ENTRY_N(no_entry) 1614 + #define drive_sdmmc1_comp DRV_PINGROUP_ENTRY_N(no_entry) 1615 + 1616 + #define PINGROUP(pg_name, f0, f1, f2, f3, r, bank, pupd, e_io_hv, e_lpbk, e_input, e_lpdr, e_pbias_buf, \ 1617 + gpio_sfio_sel, schmitt_b) \ 1618 + { \ 1619 + .name = #pg_name, \ 1620 + .pins = pg_name##_pins, \ 1621 + .npins = ARRAY_SIZE(pg_name##_pins), \ 1622 + .funcs = { \ 1623 + TEGRA_MUX_##f0, \ 1624 + TEGRA_MUX_##f1, \ 1625 + TEGRA_MUX_##f2, \ 1626 + TEGRA_MUX_##f3, \ 1627 + }, \ 1628 + PIN_PINGROUP_ENTRY_Y(r, bank, pupd, e_io_hv, e_lpbk, \ 1629 + e_input, e_lpdr, e_pbias_buf, \ 1630 + gpio_sfio_sel, schmitt_b) \ 1631 + drive_##pg_name, \ 1632 + } 1633 + 1634 + static const struct tegra_pingroup tegra234_groups[] = { 1635 + PINGROUP(soc_gpio08_pb0, RSVD0, RSVD1, RSVD2, RSVD3, 0x5008, 0, Y, -1, 7, 6, 8, -1, 10, 12), 1636 + PINGROUP(soc_gpio36_pm5, ETH0, RSVD1, DCA, RSVD3, 0x10000, 0, Y, -1, 7, 6, 8, -1, 10, 12), 1637 + PINGROUP(soc_gpio53_pm6, ETH0, RSVD1, DCA, RSVD3, 0x10008, 0, Y, -1, 7, 6, 8, -1, 10, 12), 1638 + PINGROUP(soc_gpio55_pm4, ETH2, RSVD1, RSVD2, RSVD3, 0x10010, 0, Y, -1, 7, 6, 8, -1, 10, 12), 1639 + PINGROUP(soc_gpio38_pm7, ETH1, RSVD1, RSVD2, RSVD3, 0x10018, 0, Y, -1, 7, 6, 8, -1, 10, 12), 1640 + PINGROUP(soc_gpio39_pn1, GP, RSVD1, RSVD2, RSVD3, 0x10020, 0, Y, -1, 7, 6, 8, -1, 10, 12), 1641 + PINGROUP(soc_gpio40_pn2, ETH1, RSVD1, RSVD2, RSVD3, 0x10028, 0, Y, -1, 7, 6, 8, -1, 10, 12), 1642 + PINGROUP(dp_aux_ch0_hpd_pm0, DP, RSVD1, RSVD2, RSVD3, 0x10030, 0, Y, 5, 7, 6, 8, -1, 10, 12), 1643 + PINGROUP(dp_aux_ch1_hpd_pm1, ETH3, RSVD1, RSVD2, RSVD3, 0x10038, 0, Y, 5, 7, 6, 8, -1, 10, 12), 1644 + PINGROUP(dp_aux_ch2_hpd_pm2, ETH3, RSVD1, DISPLAYB, RSVD3, 0x10040, 0, Y, 5, 7, 6, 8, -1, 10, 12), 1645 + PINGROUP(dp_aux_ch3_hpd_pm3, ETH2, RSVD1, DISPLAYA, RSVD3, 0x10048, 0, Y, 5, 7, 6, 8, -1, 10, 12), 1646 + PINGROUP(dp_aux_ch1_p_pn3, I2C4, RSVD1, RSVD2, RSVD3, 0x10050, 0, Y, 5, 7, 6, 8, -1, 10, 12), 1647 + PINGROUP(dp_aux_ch1_n_pn4, I2C4, RSVD1, RSVD2, RSVD3, 0x10058, 0, Y, 5, 7, 6, 8, -1, 10, 12), 1648 + PINGROUP(dp_aux_ch2_p_pn5, I2C7, RSVD1, RSVD2, RSVD3, 0x10060, 0, Y, 5, 7, 6, 8, -1, 10, 12), 1649 + PINGROUP(dp_aux_ch2_n_pn6, I2C7, RSVD1, RSVD2, RSVD3, 0x10068, 0, Y, 5, 7, 6, 8, -1, 10, 12), 1650 + PINGROUP(dp_aux_ch3_p_pn7, I2C9, RSVD1, RSVD2, RSVD3, 0x10070, 0, Y, 5, 7, 6, 8, -1, 10, 12), 1651 + PINGROUP(dp_aux_ch3_n_pn0, I2C9, RSVD1, RSVD2, RSVD3, 0x10078, 0, Y, 5, 7, 6, 8, -1, 10, 12), 1652 + PINGROUP(eqos_td3_pe4, EQOS, RSVD1, RSVD2, RSVD3, 0x15000, 0, Y, -1, 5, 6, -1, -1, 10, 12), 1653 + PINGROUP(eqos_td2_pe3, EQOS, RSVD1, RSVD2, RSVD3, 0x15008, 0, Y, -1, 5, 6, -1, -1, 10, 12), 1654 + PINGROUP(eqos_td1_pe2, EQOS, RSVD1, RSVD2, RSVD3, 0x15010, 0, Y, -1, 5, 6, -1, -1, 10, 12), 1655 + PINGROUP(eqos_td0_pe1, EQOS, RSVD1, RSVD2, RSVD3, 0x15018, 0, Y, -1, 5, 6, -1, -1, 10, 12), 1656 + PINGROUP(eqos_rd3_pf1, EQOS, RSVD1, RSVD2, RSVD3, 0x15020, 0, Y, -1, 5, 6, -1, -1, 10, 12), 1657 + PINGROUP(eqos_rd2_pf0, EQOS, RSVD1, RSVD2, RSVD3, 0x15028, 0, Y, -1, 5, 6, -1, -1, 10, 12), 1658 + PINGROUP(eqos_rd1_pe7, EQOS, RSVD1, RSVD2, RSVD3, 0x15030, 0, Y, -1, 5, 6, -1, -1, 10, 12), 1659 + PINGROUP(eqos_sma_mdio_pf4, EQOS, RSVD1, RSVD2, RSVD3, 0x15038, 0, Y, -1, 5, 6, -1, -1, 10, 12), 1660 + PINGROUP(eqos_rd0_pe6, EQOS, RSVD1, RSVD2, RSVD3, 0x15040, 0, Y, -1, 5, 6, -1, -1, 10, 12), 1661 + PINGROUP(eqos_sma_mdc_pf5, EQOS, RSVD1, RSVD2, RSVD3, 0x15048, 0, Y, -1, 5, 6, -1, -1, 10, 12), 1662 + PINGROUP(eqos_comp, EQOS, RSVD1, RSVD2, RSVD3, 0x15050, 0, N, -1, -1, -1, -1, -1, -1, -1), 1663 + PINGROUP(eqos_txc_pe0, EQOS, RSVD1, RSVD2, RSVD3, 0x15058, 0, Y, -1, 5, 6, -1, -1, 10, 12), 1664 + PINGROUP(eqos_rxc_pf3, EQOS, RSVD1, RSVD2, RSVD3, 0x15060, 0, Y, -1, 5, 6, -1, -1, 10, 12), 1665 + PINGROUP(eqos_tx_ctl_pe5, EQOS, RSVD1, RSVD2, RSVD3, 0x15068, 0, Y, -1, 5, 6, -1, -1, 10, 12), 1666 + PINGROUP(eqos_rx_ctl_pf2, EQOS, RSVD1, RSVD2, RSVD3, 0x15070, 0, Y, -1, 5, 6, -1, -1, 10, 12), 1667 + PINGROUP(pex_l2_clkreq_n_pk4, PE2, RSVD1, RSVD2, RSVD3, 0x7000, 0, Y, 5, 7, 6, 8, -1, 10, 12), 1668 + PINGROUP(pex_wake_n_pl2, RSVD0, RSVD1, RSVD2, RSVD3, 0x7008, 0, Y, 5, 7, 6, 8, -1, 10, 12), 1669 + PINGROUP(pex_l1_clkreq_n_pk2, PE1, RSVD1, RSVD2, RSVD3, 0x7010, 0, Y, 5, 7, 6, 8, -1, 10, 12), 1670 + PINGROUP(pex_l1_rst_n_pk3, PE1, RSVD1, RSVD2, RSVD3, 0x7018, 0, Y, 5, 7, 6, 8, -1, 10, 12), 1671 + PINGROUP(pex_l0_clkreq_n_pk0, PE0, RSVD1, RSVD2, RSVD3, 0x7020, 0, Y, 5, 7, 6, 8, -1, 10, 12), 1672 + PINGROUP(pex_l0_rst_n_pk1, PE0, RSVD1, RSVD2, RSVD3, 0x7028, 0, Y, 5, 7, 6, 8, -1, 10, 12), 1673 + PINGROUP(pex_l2_rst_n_pk5, PE2, RSVD1, RSVD2, RSVD3, 0x7030, 0, Y, 5, 7, 6, 8, -1, 10, 12), 1674 + PINGROUP(pex_l3_clkreq_n_pk6, PE3, RSVD1, RSVD2, RSVD3, 0x7038, 0, Y, 5, 7, 6, 8, -1, 10, 12), 1675 + PINGROUP(pex_l3_rst_n_pk7, PE3, RSVD1, RSVD2, RSVD3, 0x7040, 0, Y, 5, 7, 6, 8, -1, 10, 12), 1676 + PINGROUP(pex_l4_clkreq_n_pl0, PE4, RSVD1, RSVD2, RSVD3, 0x7048, 0, Y, 5, 7, 6, 8, -1, 10, 12), 1677 + PINGROUP(pex_l4_rst_n_pl1, PE4, RSVD1, RSVD2, RSVD3, 0x7050, 0, Y, 5, 7, 6, 8, -1, 10, 12), 1678 + PINGROUP(soc_gpio34_pl3, RSVD0, RSVD1, RSVD2, RSVD3, 0x7058, 0, Y, 5, 7, 6, 8, -1, 10, 12), 1679 + PINGROUP(pex_l5_clkreq_n_paf0, PE5, RSVD1, RSVD2, RSVD3, 0x14000, 0, Y, 5, 7, 6, 8, -1, 10, 12), 1680 + PINGROUP(pex_l5_rst_n_paf1, PE5, RSVD1, RSVD2, RSVD3, 0x14008, 0, Y, 5, 7, 6, 8, -1, 10, 12), 1681 + PINGROUP(pex_l6_clkreq_n_paf2, PE6, RSVD1, RSVD2, RSVD3, 0x14010, 0, Y, 5, 7, 6, 8, -1, 10, 12), 1682 + PINGROUP(pex_l6_rst_n_paf3, PE6, RSVD1, RSVD2, RSVD3, 0x14018, 0, Y, 5, 7, 6, 8, -1, 10, 12), 1683 + PINGROUP(pex_l10_clkreq_n_pag6, PE10, RSVD1, RSVD2, RSVD3, 0x19000, 0, Y, 5, 7, 6, 8, -1, 10, 12), 1684 + PINGROUP(pex_l10_rst_n_pag7, PE10, RSVD1, RSVD2, RSVD3, 0x19008, 0, Y, 5, 7, 6, 8, -1, 10, 12), 1685 + PINGROUP(pex_l7_clkreq_n_pag0, PE7, RSVD1, RSVD2, RSVD3, 0x19010, 0, Y, 5, 7, 6, 8, -1, 10, 12), 1686 + PINGROUP(pex_l7_rst_n_pag1, PE7, RSVD1, RSVD2, RSVD3, 0x19018, 0, Y, 5, 7, 6, 8, -1, 10, 12), 1687 + PINGROUP(pex_l8_clkreq_n_pag2, PE8, RSVD1, RSVD2, RSVD3, 0x19020, 0, Y, 5, 7, 6, 8, -1, 10, 12), 1688 + PINGROUP(pex_l8_rst_n_pag3, PE8, RSVD1, RSVD2, RSVD3, 0x19028, 0, Y, 5, 7, 6, 8, -1, 10, 12), 1689 + PINGROUP(pex_l9_clkreq_n_pag4, PE9, RSVD1, RSVD2, RSVD3, 0x19030, 0, Y, 5, 7, 6, 8, -1, 10, 12), 1690 + PINGROUP(pex_l9_rst_n_pag5, PE9, RSVD1, RSVD2, RSVD3, 0x19038, 0, Y, 5, 7, 6, 8, -1, 10, 12), 1691 + PINGROUP(qspi0_io3_pc5, QSPI0, RSVD1, RSVD2, RSVD3, 0xB000, 0, Y, -1, 5, 6, -1, -1, 10, 12), 1692 + PINGROUP(qspi0_io2_pc4, QSPI0, RSVD1, RSVD2, RSVD3, 0xB008, 0, Y, -1, 5, 6, -1, -1, 10, 12), 1693 + PINGROUP(qspi0_io1_pc3, QSPI0, RSVD1, RSVD2, RSVD3, 0xB010, 0, Y, -1, 5, 6, -1, -1, 10, 12), 1694 + PINGROUP(qspi0_io0_pc2, QSPI0, RSVD1, RSVD2, RSVD3, 0xB018, 0, Y, -1, 5, 6, -1, -1, 10, 12), 1695 + PINGROUP(qspi0_sck_pc0, QSPI0, RSVD1, RSVD2, RSVD3, 0xB020, 0, Y, -1, 5, 6, -1, -1, 10, 12), 1696 + PINGROUP(qspi0_cs_n_pc1, QSPI0, RSVD1, RSVD2, RSVD3, 0xB028, 0, Y, -1, 5, 6, -1, -1, 10, 12), 1697 + PINGROUP(qspi1_io3_pd3, QSPI1, RSVD1, RSVD2, RSVD3, 0xB030, 0, Y, -1, 5, 6, -1, -1, 10, 12), 1698 + PINGROUP(qspi1_io2_pd2, QSPI1, RSVD1, RSVD2, RSVD3, 0xB038, 0, Y, -1, 5, 6, -1, -1, 10, 12), 1699 + PINGROUP(qspi1_io1_pd1, QSPI1, RSVD1, RSVD2, RSVD3, 0xB040, 0, Y, -1, 5, 6, -1, -1, 10, 12), 1700 + PINGROUP(qspi1_io0_pd0, QSPI1, RSVD1, RSVD2, RSVD3, 0xB048, 0, Y, -1, 5, 6, -1, -1, 10, 12), 1701 + PINGROUP(qspi1_sck_pc6, QSPI1, RSVD1, RSVD2, RSVD3, 0xB050, 0, Y, -1, 5, 6, -1, -1, 10, 12), 1702 + PINGROUP(qspi1_cs_n_pc7, QSPI1, RSVD1, RSVD2, RSVD3, 0xB058, 0, Y, -1, 5, 6, -1, -1, 10, 12), 1703 + PINGROUP(qspi_comp, QSPI, RSVD1, RSVD2, RSVD3, 0xB060, 0, N, -1, -1, -1, -1, -1, -1, -1), 1704 + PINGROUP(sdmmc1_clk_pj0, SDMMC1, RSVD1, RSVD2, RSVD3, 0x8000, 0, Y, -1, 5, 6, -1, 9, 10, 12), 1705 + PINGROUP(sdmmc1_cmd_pj1, SDMMC1, RSVD1, RSVD2, RSVD3, 0x8008, 0, Y, -1, 5, 6, -1, 9, 10, 12), 1706 + PINGROUP(sdmmc1_comp, SDMMC1, RSVD1, RSVD2, RSVD3, 0x8010, 0, N, -1, -1, -1, -1, -1, -1, -1), 1707 + PINGROUP(sdmmc1_dat3_pj5, SDMMC1, RSVD1, RSVD2, RSVD3, 0x8018, 0, Y, -1, 5, 6, -1, 9, 10, 12), 1708 + PINGROUP(sdmmc1_dat2_pj4, SDMMC1, RSVD1, RSVD2, RSVD3, 0x8020, 0, Y, -1, 5, 6, -1, 9, 10, 12), 1709 + PINGROUP(sdmmc1_dat1_pj3, SDMMC1, RSVD1, RSVD2, RSVD3, 0x8028, 0, Y, -1, 5, 6, -1, 9, 10, 12), 1710 + PINGROUP(sdmmc1_dat0_pj2, SDMMC1, RSVD1, RSVD2, RSVD3, 0x8030, 0, Y, -1, 5, 6, -1, 9, 10, 12), 1711 + PINGROUP(ufs0_rst_n_pae1, UFS0, RSVD1, RSVD2, RSVD3, 0x11000, 0, Y, -1, 5, 6, -1, -1, 10, 12), 1712 + PINGROUP(ufs0_ref_clk_pae0, UFS0, RSVD1, RSVD2, RSVD3, 0x11008, 0, Y, -1, 5, 6, -1, -1, 10, 12), 1713 + PINGROUP(spi3_miso_py1, SPI3, RSVD1, RSVD2, RSVD3, 0xD000, 0, Y, 5, 7, 6, 8, -1, 10, 12), 1714 + PINGROUP(spi1_cs0_pz6, SPI1, RSVD1, RSVD2, RSVD3, 0xD008, 0, Y, 5, 7, 6, 8, -1, 10, 12), 1715 + PINGROUP(spi3_cs0_py3, SPI3, RSVD1, RSVD2, RSVD3, 0xD010, 0, Y, 5, 7, 6, 8, -1, 10, 12), 1716 + PINGROUP(spi1_miso_pz4, SPI1, RSVD1, RSVD2, RSVD3, 0xD018, 0, Y, 5, 7, 6, 8, -1, 10, 12), 1717 + PINGROUP(spi3_cs1_py4, SPI3, RSVD1, RSVD2, RSVD3, 0xD020, 0, Y, 5, 7, 6, 8, -1, 10, 12), 1718 + PINGROUP(spi1_sck_pz3, SPI1, RSVD1, RSVD2, RSVD3, 0xD028, 0, Y, 5, 7, 6, 8, -1, 10, 12), 1719 + PINGROUP(spi3_sck_py0, SPI3, RSVD1, RSVD2, RSVD3, 0xD030, 0, Y, 5, 7, 6, 8, -1, 10, 12), 1720 + PINGROUP(spi1_cs1_pz7, SPI1, RSVD1, RSVD2, RSVD3, 0xD038, 0, Y, 5, 7, 6, 8, -1, 10, 12), 1721 + PINGROUP(spi1_mosi_pz5, SPI1, RSVD1, RSVD2, RSVD3, 0xD040, 0, Y, 5, 7, 6, 8, -1, 10, 12), 1722 + PINGROUP(spi3_mosi_py2, SPI3, RSVD1, RSVD2, RSVD3, 0xD048, 0, Y, 5, 7, 6, 8, -1, 10, 12), 1723 + PINGROUP(uart2_tx_px4, UARTB, RSVD1, RSVD2, RSVD3, 0xD050, 0, Y, 5, 7, 6, 8, -1, 10, 12), 1724 + PINGROUP(uart2_rx_px5, UARTB, RSVD1, RSVD2, RSVD3, 0xD058, 0, Y, 5, 7, 6, 8, -1, 10, 12), 1725 + PINGROUP(uart2_rts_px6, UARTB, RSVD1, RSVD2, RSVD3, 0xD060, 0, Y, -1, 7, 6, 8, -1, 10, 12), 1726 + PINGROUP(uart2_cts_px7, UARTB, RSVD1, RSVD2, RSVD3, 0xD068, 0, Y, -1, 7, 6, 8, -1, 10, 12), 1727 + PINGROUP(uart5_tx_py5, UARTE, RSVD1, RSVD2, RSVD3, 0xD070, 0, Y, -1, 7, 6, 8, -1, 10, 12), 1728 + PINGROUP(uart5_rx_py6, UARTE, RSVD1, RSVD2, RSVD3, 0xD078, 0, Y, -1, 7, 6, 8, -1, 10, 12), 1729 + PINGROUP(uart5_rts_py7, UARTE, RSVD1, RSVD2, RSVD3, 0xD080, 0, Y, -1, 7, 6, 8, -1, 10, 12), 1730 + PINGROUP(uart5_cts_pz0, UARTE, RSVD1, RSVD2, RSVD3, 0xD088, 0, Y, -1, 7, 6, 8, -1, 10, 12), 1731 + PINGROUP(gpu_pwr_req_px0, RSVD0, RSVD1, RSVD2, RSVD3, 0xD090, 0, Y, -1, 7, 6, 8, -1, 10, 12), 1732 + PINGROUP(gp_pwm3_px3, GP, RSVD1, RSVD2, RSVD3, 0xD098, 0, Y, 5, 7, 6, 8, -1, 10, 12), 1733 + PINGROUP(gp_pwm2_px2, GP, RSVD1, RSVD2, RSVD3, 0xD0A0, 0, Y, 5, 7, 6, 8, -1, 10, 12), 1734 + PINGROUP(cv_pwr_req_px1, RSVD0, RSVD1, RSVD2, RSVD3, 0xD0A8, 0, Y, -1, 7, 6, 8, -1, 10, 12), 1735 + PINGROUP(usb_vbus_en0_pz1, USB, RSVD1, RSVD2, RSVD3, 0xD0B0, 0, Y, 5, 7, 6, 8, -1, 10, 12), 1736 + PINGROUP(usb_vbus_en1_pz2, USB, RSVD1, RSVD2, RSVD3, 0xD0B8, 0, Y, 5, 7, 6, 8, -1, 10, 12), 1737 + PINGROUP(extperiph2_clk_pp1, EXTPERIPH2, RSVD1, RSVD2, RSVD3, 0x0000, 0, Y, -1, 7, 6, 8, -1, 10, 12), 1738 + PINGROUP(extperiph1_clk_pp0, EXTPERIPH1, RSVD1, RSVD2, RSVD3, 0x0008, 0, Y, -1, 7, 6, 8, -1, 10, 12), 1739 + PINGROUP(cam_i2c_sda_pp3, I2C3, VI0, RSVD2, VI1, 0x0010, 0, Y, 5, 7, 6, 8, -1, 10, 12), 1740 + PINGROUP(cam_i2c_scl_pp2, I2C3, VI0, VI0_ALT, VI1, 0x0018, 0, Y, 5, 7, 6, 8, -1, 10, 12), 1741 + PINGROUP(soc_gpio23_pp4, VI0, VI0_ALT, VI1, VI1_ALT, 0x0020, 0, Y, 5, 7, 6, 8, -1, 10, 12), 1742 + PINGROUP(soc_gpio24_pp5, VI0, SOC, VI1, VI1_ALT, 0x0028, 0, Y, 5, 7, 6, 8, -1, 10, 12), 1743 + PINGROUP(soc_gpio25_pp6, VI0, I2S5, VI1, DMIC1, 0x0030, 0, Y, 5, 7, 6, 8, -1, 10, 12), 1744 + PINGROUP(pwr_i2c_scl_pp7, I2C5, RSVD1, RSVD2, RSVD3, 0x0038, 0, Y, 5, 7, 6, 8, -1, 10, 12), 1745 + PINGROUP(pwr_i2c_sda_pq0, I2C5, RSVD1, RSVD2, RSVD3, 0x0040, 0, Y, 5, 7, 6, 8, -1, 10, 12), 1746 + PINGROUP(soc_gpio28_pq1, VI0, RSVD1, VI1, RSVD3, 0x0048, 0, Y, 5, 7, 6, 8, -1, 10, 12), 1747 + PINGROUP(soc_gpio29_pq2, RSVD0, NV, RSVD2, RSVD3, 0x0050, 0, Y, 5, 7, 6, 8, -1, 10, 12), 1748 + PINGROUP(soc_gpio30_pq3, RSVD0, WDT, RSVD2, RSVD3, 0x0058, 0, Y, 5, 7, 6, 8, -1, 10, 12), 1749 + PINGROUP(soc_gpio31_pq4, RSVD0, RSVD1, RSVD2, RSVD3, 0x0060, 0, Y, 5, 7, 6, 8, -1, 10, 12), 1750 + PINGROUP(soc_gpio32_pq5, RSVD0, EXTPERIPH3, DCB, RSVD3, 0x0068, 0, Y, 5, 7, 6, 8, -1, 10, 12), 1751 + PINGROUP(soc_gpio33_pq6, RSVD0, EXTPERIPH4, DCB, RSVD3, 0x0070, 0, Y, 5, 7, 6, 8, -1, 10, 12), 1752 + PINGROUP(soc_gpio35_pq7, RSVD0, I2S5, DMIC1, RSVD3, 0x0078, 0, Y, 5, 7, 6, 8, -1, 10, 12), 1753 + PINGROUP(soc_gpio37_pr0, GP, I2S5, DMIC4, DSPK1, 0x0080, 0, Y, 5, 7, 6, 8, -1, 10, 12), 1754 + PINGROUP(soc_gpio56_pr1, RSVD0, I2S5, DMIC4, DSPK1, 0x0088, 0, Y, 5, 7, 6, 8, -1, 10, 12), 1755 + PINGROUP(uart1_cts_pr5, UARTA, RSVD1, RSVD2, RSVD3, 0x0090, 0, Y, -1, 7, 6, 8, -1, 10, 12), 1756 + PINGROUP(uart1_rts_pr4, UARTA, RSVD1, RSVD2, RSVD3, 0x0098, 0, Y, -1, 7, 6, 8, -1, 10, 12), 1757 + PINGROUP(uart1_rx_pr3, UARTA, RSVD1, RSVD2, RSVD3, 0x00A0, 0, Y, -1, 7, 6, 8, -1, 10, 12), 1758 + PINGROUP(uart1_tx_pr2, UARTA, RSVD1, RSVD2, RSVD3, 0x00A8, 0, Y, -1, 7, 6, 8, -1, 10, 12), 1759 + PINGROUP(cpu_pwr_req_pi5, RSVD0, RSVD1, RSVD2, RSVD3, 0x4000, 0, Y, -1, 7, 6, 8, -1, 10, 12), 1760 + PINGROUP(uart4_cts_ph6, UARTD, RSVD1, I2S7, RSVD3, 0x4008, 0, Y, -1, 7, 6, 8, -1, 10, 12), 1761 + PINGROUP(uart4_rts_ph5, UARTD, SPI4, RSVD2, RSVD3, 0x4010, 0, Y, -1, 7, 6, 8, -1, 10, 12), 1762 + PINGROUP(uart4_rx_ph4, UARTD, RSVD1, I2S7, RSVD3, 0x4018, 0, Y, -1, 7, 6, 8, -1, 10, 12), 1763 + PINGROUP(uart4_tx_ph3, UARTD, SPI4, RSVD2, RSVD3, 0x4020, 0, Y, -1, 7, 6, 8, -1, 10, 12), 1764 + PINGROUP(gen1_i2c_scl_pi3, I2C1, RSVD1, RSVD2, RSVD3, 0x4028, 0, Y, 5, 7, 6, 8, -1, 10, 12), 1765 + PINGROUP(gen1_i2c_sda_pi4, I2C1, RSVD1, RSVD2, RSVD3, 0x4030, 0, Y, 5, 7, 6, 8, -1, 10, 12), 1766 + PINGROUP(soc_gpio20_pg7, RSVD0, SDMMC1, RSVD2, RSVD3, 0x4038, 0, Y, -1, 7, 6, 8, -1, 10, 12), 1767 + PINGROUP(soc_gpio21_ph0, RSVD0, GP, I2S7, RSVD3, 0x4040, 0, Y, -1, 7, 6, 8, -1, 10, 12), 1768 + PINGROUP(soc_gpio22_ph1, RSVD0, RSVD1, I2S7, RSVD3, 0x4048, 0, Y, -1, 7, 6, 8, -1, 10, 12), 1769 + PINGROUP(soc_gpio13_pg0, RSVD0, RSVD1, RSVD2, RSVD3, 0x4050, 0, Y, -1, 7, 6, 8, -1, 10, 12), 1770 + PINGROUP(soc_gpio14_pg1, RSVD0, SPI4, RSVD2, RSVD3, 0x4058, 0, Y, -1, 7, 6, 8, -1, 10, 12), 1771 + PINGROUP(soc_gpio15_pg2, RSVD0, SPI4, RSVD2, RSVD3, 0x4060, 0, Y, -1, 7, 6, 8, -1, 10, 12), 1772 + PINGROUP(soc_gpio16_pg3, RSVD0, SPI4, RSVD2, RSVD3, 0x4068, 0, Y, -1, 7, 6, 8, -1, 10, 12), 1773 + PINGROUP(soc_gpio17_pg4, RSVD0, CCLA, RSVD2, RSVD3, 0x4070, 0, Y, -1, 7, 6, 8, -1, 10, 12), 1774 + PINGROUP(soc_gpio18_pg5, RSVD0, RSVD1, RSVD2, RSVD3, 0x4078, 0, Y, -1, 7, 6, 8, -1, 10, 12), 1775 + PINGROUP(soc_gpio19_pg6, GP, RSVD1, RSVD2, RSVD3, 0x4080, 0, Y, -1, 7, 6, 8, -1, 10, 12), 1776 + PINGROUP(soc_gpio41_ph7, RSVD0, I2S2, RSVD2, RSVD3, 0x4088, 0, Y, -1, 7, 6, 8, -1, 10, 12), 1777 + PINGROUP(soc_gpio42_pi0, RSVD0, I2S2, RSVD2, RSVD3, 0x4090, 0, Y, -1, 7, 6, 8, -1, 10, 12), 1778 + PINGROUP(soc_gpio43_pi1, RSVD0, I2S2, RSVD2, RSVD3, 0x4098, 0, Y, -1, 7, 6, 8, -1, 10, 12), 1779 + PINGROUP(soc_gpio44_pi2, RSVD0, I2S2, RSVD2, RSVD3, 0x40A0, 0, Y, -1, 7, 6, 8, -1, 10, 12), 1780 + PINGROUP(soc_gpio06_ph2, RSVD0, RSVD1, RSVD2, RSVD3, 0x40A8, 0, Y, -1, 7, 6, 8, -1, 10, 12), 1781 + PINGROUP(soc_gpio07_pi6, GP, RSVD1, RSVD2, RSVD3, 0x40B0, 0, Y, -1, 7, 6, 8, -1, 10, 12), 1782 + PINGROUP(dap4_sclk_pa4, I2S4, RSVD1, RSVD2, RSVD3, 0x2000, 0, Y, -1, 7, 6, 8, -1, 10, 12), 1783 + PINGROUP(dap4_dout_pa5, I2S4, RSVD1, RSVD2, RSVD3, 0x2008, 0, Y, -1, 7, 6, 8, -1, 10, 12), 1784 + PINGROUP(dap4_din_pa6, I2S4, RSVD1, RSVD2, RSVD3, 0x2010, 0, Y, -1, 7, 6, 8, -1, 10, 12), 1785 + PINGROUP(dap4_fs_pa7, I2S4, RSVD1, RSVD2, RSVD3, 0x2018, 0, Y, -1, 7, 6, 8, -1, 10, 12), 1786 + PINGROUP(dap6_sclk_pa0, I2S6, RSVD1, RSVD2, RSVD3, 0x2020, 0, Y, -1, 7, 6, 8, -1, 10, 12), 1787 + PINGROUP(dap6_dout_pa1, I2S6, RSVD1, RSVD2, RSVD3, 0x2028, 0, Y, -1, 7, 6, 8, -1, 10, 12), 1788 + PINGROUP(dap6_din_pa2, I2S6, RSVD1, RSVD2, RSVD3, 0x2030, 0, Y, -1, 7, 6, 8, -1, 10, 12), 1789 + PINGROUP(dap6_fs_pa3, I2S6, RSVD1, RSVD2, RSVD3, 0x2038, 0, Y, -1, 7, 6, 8, -1, 10, 12), 1790 + PINGROUP(soc_gpio45_pad0, RSVD0, I2S1, RSVD2, RSVD3, 0x18000, 0, Y, -1, 7, 6, 8, -1, 10, 12), 1791 + PINGROUP(soc_gpio46_pad1, RSVD0, I2S1, RSVD2, RSVD3, 0x18008, 0, Y, -1, 7, 6, 8, -1, 10, 12), 1792 + PINGROUP(soc_gpio47_pad2, RSVD0, I2S1, RSVD2, RSVD3, 0x18010, 0, Y, -1, 7, 6, 8, -1, 10, 12), 1793 + PINGROUP(soc_gpio48_pad3, RSVD0, I2S1, RSVD2, RSVD3, 0x18018, 0, Y, -1, 7, 6, 8, -1, 10, 12), 1794 + PINGROUP(soc_gpio57_pac4, RSVD0, I2S8, RSVD2, SDMMC1, 0x18020, 0, Y, -1, 7, 6, 8, -1, 10, 12), 1795 + PINGROUP(soc_gpio58_pac5, RSVD0, I2S8, RSVD2, SDMMC1, 0x18028, 0, Y, -1, 7, 6, 8, -1, 10, 12), 1796 + PINGROUP(soc_gpio59_pac6, AUD, I2S8, RSVD2, RSVD3, 0x18030, 0, Y, -1, 7, 6, 8, -1, 10, 12), 1797 + PINGROUP(soc_gpio60_pac7, RSVD0, I2S8, NV, IGPU, 0x18038, 0, Y, -1, 7, 6, 8, -1, 10, 12), 1798 + PINGROUP(spi5_cs0_pac3, SPI5, I2S3, DMIC2, RSVD3, 0x18040, 0, Y, -1, 7, 6, 8, -1, 10, 12), 1799 + PINGROUP(spi5_miso_pac1, SPI5, I2S3, DSPK0, RSVD3, 0x18048, 0, Y, -1, 7, 6, 8, -1, 10, 12), 1800 + PINGROUP(spi5_mosi_pac2, SPI5, I2S3, DMIC2, RSVD3, 0x18050, 0, Y, -1, 7, 6, 8, -1, 10, 12), 1801 + PINGROUP(spi5_sck_pac0, SPI5, I2S3, DSPK0, RSVD3, 0x18058, 0, Y, -1, 7, 6, 8, -1, 10, 12), 1802 + 1803 + }; 1804 + 1805 + static const struct tegra_pinctrl_soc_data tegra234_pinctrl = { 1806 + .pins = tegra234_pins, 1807 + .npins = ARRAY_SIZE(tegra234_pins), 1808 + .functions = tegra234_functions, 1809 + .nfunctions = ARRAY_SIZE(tegra234_functions), 1810 + .groups = tegra234_groups, 1811 + .ngroups = ARRAY_SIZE(tegra234_groups), 1812 + .hsm_in_mux = false, 1813 + .schmitt_in_mux = true, 1814 + .drvtype_in_mux = true, 1815 + .sfsel_in_mux = true, 1816 + }; 1817 + 1818 + static const struct pinctrl_pin_desc tegra234_aon_pins[] = { 1819 + PINCTRL_PIN(TEGRA_PIN_CAN0_DOUT_PAA0, "CAN0_DOUT_PAA0"), 1820 + PINCTRL_PIN(TEGRA_PIN_CAN0_DIN_PAA1, "CAN0_DIN_PAA1"), 1821 + PINCTRL_PIN(TEGRA_PIN_CAN1_DOUT_PAA2, "CAN1_DOUT_PAA2"), 1822 + PINCTRL_PIN(TEGRA_PIN_CAN1_DIN_PAA3, "CAN1_DIN_PAA3"), 1823 + PINCTRL_PIN(TEGRA_PIN_CAN0_STB_PAA4, "CAN0_STB_PAA4"), 1824 + PINCTRL_PIN(TEGRA_PIN_CAN0_EN_PAA5, "CAN0_EN_PAA5"), 1825 + PINCTRL_PIN(TEGRA_PIN_SOC_GPIO49_PAA6, "SOC_GPIO49_PAA6"), 1826 + PINCTRL_PIN(TEGRA_PIN_CAN0_ERR_PAA7, "CAN0_ERR_PAA7"), 1827 + PINCTRL_PIN(TEGRA_PIN_CAN1_STB_PBB0, "CAN1_STB_PBB0"), 1828 + PINCTRL_PIN(TEGRA_PIN_CAN1_EN_PBB1, "CAN1_EN_PBB1"), 1829 + PINCTRL_PIN(TEGRA_PIN_SOC_GPIO50_PBB2, "SOC_GPIO50_PBB2"), 1830 + PINCTRL_PIN(TEGRA_PIN_CAN1_ERR_PBB3, "CAN1_ERR_PBB3"), 1831 + PINCTRL_PIN(TEGRA_PIN_SPI2_SCK_PCC0, "SPI2_SCK_PCC0"), 1832 + PINCTRL_PIN(TEGRA_PIN_SPI2_MISO_PCC1, "SPI2_MISO_PCC1"), 1833 + PINCTRL_PIN(TEGRA_PIN_SPI2_MOSI_PCC2, "SPI2_MOSI_PCC2"), 1834 + PINCTRL_PIN(TEGRA_PIN_SPI2_CS0_PCC3, "SPI2_CS0_PCC3"), 1835 + PINCTRL_PIN(TEGRA_PIN_TOUCH_CLK_PCC4, "TOUCH_CLK_PCC4"), 1836 + PINCTRL_PIN(TEGRA_PIN_UART3_TX_PCC5, "UART3_TX_PCC5"), 1837 + PINCTRL_PIN(TEGRA_PIN_UART3_RX_PCC6, "UART3_RX_PCC6"), 1838 + PINCTRL_PIN(TEGRA_PIN_GEN2_I2C_SCL_PCC7, "GEN2_I2C_SCL_PCC7"), 1839 + PINCTRL_PIN(TEGRA_PIN_GEN2_I2C_SDA_PDD0, "GEN2_I2C_SDA_PDD0"), 1840 + PINCTRL_PIN(TEGRA_PIN_GEN8_I2C_SCL_PDD1, "GEN8_I2C_SCL_PDD1"), 1841 + PINCTRL_PIN(TEGRA_PIN_GEN8_I2C_SDA_PDD2, "GEN8_I2C_SDA_PDD2"), 1842 + PINCTRL_PIN(TEGRA_PIN_SCE_ERROR_PEE0, "SCE_ERROR_PEE0"), 1843 + PINCTRL_PIN(TEGRA_PIN_VCOMP_ALERT_PEE1, "VCOMP_ALERT_PEE1"), 1844 + PINCTRL_PIN(TEGRA_PIN_AO_RETENTION_N_PEE2, "AO_RETENTION_N_PEE2"), 1845 + PINCTRL_PIN(TEGRA_PIN_BATT_OC_PEE3, "BATT_OC_PEE3"), 1846 + PINCTRL_PIN(TEGRA_PIN_POWER_ON_PEE4, "POWER_ON_PEE4"), 1847 + PINCTRL_PIN(TEGRA_PIN_SOC_GPIO26_PEE5, "SOC_GPIO26_PEE5"), 1848 + PINCTRL_PIN(TEGRA_PIN_SOC_GPIO27_PEE6, "SOC_GPIO27_PEE6"), 1849 + PINCTRL_PIN(TEGRA_PIN_BOOTV_CTL_N_PEE7, "BOOTV_CTL_N_PEE7"), 1850 + PINCTRL_PIN(TEGRA_PIN_HDMI_CEC_PGG0, "HDMI_CEC_PGG0"), 1851 + }; 1852 + 1853 + /* AON drive pin groups */ 1854 + #define drive_touch_clk_pcc4 DRV_PINGROUP_ENTRY_Y(0x2004, 12, 5, 20, 5, -1, -1, -1, -1, 0) 1855 + #define drive_uart3_rx_pcc6 DRV_PINGROUP_ENTRY_Y(0x200c, 12, 5, 20, 5, -1, -1, -1, -1, 0) 1856 + #define drive_uart3_tx_pcc5 DRV_PINGROUP_ENTRY_Y(0x2014, 12, 5, 20, 5, -1, -1, -1, -1, 0) 1857 + #define drive_gen8_i2c_sda_pdd2 DRV_PINGROUP_ENTRY_Y(0x201c, 12, 5, 20, 5, -1, -1, -1, -1, 0) 1858 + #define drive_gen8_i2c_scl_pdd1 DRV_PINGROUP_ENTRY_Y(0x2024, 12, 5, 20, 5, -1, -1, -1, -1, 0) 1859 + #define drive_spi2_mosi_pcc2 DRV_PINGROUP_ENTRY_Y(0x202c, 12, 5, 20, 5, -1, -1, -1, -1, 0) 1860 + #define drive_gen2_i2c_scl_pcc7 DRV_PINGROUP_ENTRY_Y(0x2034, 12, 5, 20, 5, -1, -1, -1, -1, 0) 1861 + #define drive_spi2_cs0_pcc3 DRV_PINGROUP_ENTRY_Y(0x203c, 12, 5, 20, 5, -1, -1, -1, -1, 0) 1862 + #define drive_gen2_i2c_sda_pdd0 DRV_PINGROUP_ENTRY_Y(0x2044, 12, 5, 20, 5, -1, -1, -1, -1, 0) 1863 + #define drive_spi2_sck_pcc0 DRV_PINGROUP_ENTRY_Y(0x204c, 12, 5, 20, 5, -1, -1, -1, -1, 0) 1864 + #define drive_spi2_miso_pcc1 DRV_PINGROUP_ENTRY_Y(0x2054, 12, 5, 20, 5, -1, -1, -1, -1, 0) 1865 + #define drive_can1_dout_paa2 DRV_PINGROUP_ENTRY_Y(0x3004, 28, 2, 30, 2, -1, -1, -1, -1, 0) 1866 + #define drive_can1_din_paa3 DRV_PINGROUP_ENTRY_Y(0x300c, 28, 2, 30, 2, -1, -1, -1, -1, 0) 1867 + #define drive_can0_dout_paa0 DRV_PINGROUP_ENTRY_Y(0x3014, 28, 2, 30, 2, -1, -1, -1, -1, 0) 1868 + #define drive_can0_din_paa1 DRV_PINGROUP_ENTRY_Y(0x301c, 28, 2, 30, 2, -1, -1, -1, -1, 0) 1869 + #define drive_can0_stb_paa4 DRV_PINGROUP_ENTRY_Y(0x3024, 28, 2, 30, 2, -1, -1, -1, -1, 0) 1870 + #define drive_can0_en_paa5 DRV_PINGROUP_ENTRY_Y(0x302c, 28, 2, 30, 2, -1, -1, -1, -1, 0) 1871 + #define drive_soc_gpio49_paa6 DRV_PINGROUP_ENTRY_Y(0x3034, 28, 2, 30, 2, -1, -1, -1, -1, 0) 1872 + #define drive_can0_err_paa7 DRV_PINGROUP_ENTRY_Y(0x303c, 28, 2, 30, 2, -1, -1, -1, -1, 0) 1873 + #define drive_can1_stb_pbb0 DRV_PINGROUP_ENTRY_Y(0x3044, 28, 2, 30, 2, -1, -1, -1, -1, 0) 1874 + #define drive_can1_en_pbb1 DRV_PINGROUP_ENTRY_Y(0x304c, 28, 2, 30, 2, -1, -1, -1, -1, 0) 1875 + #define drive_soc_gpio50_pbb2 DRV_PINGROUP_ENTRY_Y(0x3054, 28, 2, 30, 2, -1, -1, -1, -1, 0) 1876 + #define drive_can1_err_pbb3 DRV_PINGROUP_ENTRY_Y(0x305c, 28, 2, 30, 2, -1, -1, -1, -1, 0) 1877 + #define drive_sce_error_pee0 DRV_PINGROUP_ENTRY_Y(0x1014, 12, 5, 20, 5, -1, -1, -1, -1, 0) 1878 + #define drive_batt_oc_pee3 DRV_PINGROUP_ENTRY_Y(0x1024, 12, 5, 20, 5, -1, -1, -1, -1, 0) 1879 + #define drive_bootv_ctl_n_pee7 DRV_PINGROUP_ENTRY_Y(0x102c, 12, 5, 20, 5, -1, -1, -1, -1, 0) 1880 + #define drive_power_on_pee4 DRV_PINGROUP_ENTRY_Y(0x103c, 12, 5, 20, 5, -1, -1, -1, -1, 0) 1881 + #define drive_soc_gpio26_pee5 DRV_PINGROUP_ENTRY_Y(0x1044, 12, 5, 20, 5, -1, -1, -1, -1, 0) 1882 + #define drive_soc_gpio27_pee6 DRV_PINGROUP_ENTRY_Y(0x104c, 12, 5, 20, 5, -1, -1, -1, -1, 0) 1883 + #define drive_ao_retention_n_pee2 DRV_PINGROUP_ENTRY_Y(0x1054, 12, 5, 20, 5, -1, -1, -1, -1, 0) 1884 + #define drive_vcomp_alert_pee1 DRV_PINGROUP_ENTRY_Y(0x105c, 12, 5, 20, 5, -1, -1, -1, -1, 0) 1885 + #define drive_hdmi_cec_pgg0 DRV_PINGROUP_ENTRY_Y(0x1064, 12, 5, 20, 5, -1, -1, -1, -1, 0) 1886 + 1887 + static const struct tegra_pingroup tegra234_aon_groups[] = { 1888 + PINGROUP(touch_clk_pcc4, GP, TOUCH, RSVD2, RSVD3, 0x2000, 0, Y, 5, 7, 6, 8, -1, 10, 12), 1889 + PINGROUP(uart3_rx_pcc6, UARTC, UARTJ, RSVD2, RSVD3, 0x2008, 0, Y, 5, 7, 6, 8, -1, 10, 12), 1890 + PINGROUP(uart3_tx_pcc5, UARTC, UARTJ, RSVD2, RSVD3, 0x2010, 0, Y, 5, 7, 6, 8, -1, 10, 12), 1891 + PINGROUP(gen8_i2c_sda_pdd2, I2C8, RSVD1, RSVD2, RSVD3, 0x2018, 0, Y, 5, 7, 6, 8, -1, 10, 12), 1892 + PINGROUP(gen8_i2c_scl_pdd1, I2C8, RSVD1, RSVD2, RSVD3, 0x2020, 0, Y, 5, 7, 6, 8, -1, 10, 12), 1893 + PINGROUP(spi2_mosi_pcc2, SPI2, RSVD1, RSVD2, RSVD3, 0x2028, 0, Y, 5, 7, 6, 8, -1, 10, 12), 1894 + PINGROUP(gen2_i2c_scl_pcc7, I2C2, RSVD1, RSVD2, RSVD3, 0x2030, 0, Y, 5, 7, 6, 8, -1, 10, 12), 1895 + PINGROUP(spi2_cs0_pcc3, SPI2, RSVD1, RSVD2, RSVD3, 0x2038, 0, Y, 5, 7, 6, 8, -1, 10, 12), 1896 + PINGROUP(gen2_i2c_sda_pdd0, I2C2, RSVD1, RSVD2, RSVD3, 0x2040, 0, Y, 5, 7, 6, 8, -1, 10, 12), 1897 + PINGROUP(spi2_sck_pcc0, SPI2, RSVD1, RSVD2, RSVD3, 0x2048, 0, Y, 5, 7, 6, 8, -1, 10, 12), 1898 + PINGROUP(spi2_miso_pcc1, SPI2, RSVD1, RSVD2, RSVD3, 0x2050, 0, Y, 5, 7, 6, 8, -1, 10, 12), 1899 + PINGROUP(can1_dout_paa2, CAN1, RSVD1, RSVD2, RSVD3, 0x3000, 0, Y, -1, 5, 6, -1, 9, 10, 12), 1900 + PINGROUP(can1_din_paa3, CAN1, RSVD1, RSVD2, RSVD3, 0x3008, 0, Y, -1, 5, 6, -1, 9, 10, 12), 1901 + PINGROUP(can0_dout_paa0, CAN0, RSVD1, RSVD2, RSVD3, 0x3010, 0, Y, -1, 5, 6, -1, 9, 10, 12), 1902 + PINGROUP(can0_din_paa1, CAN0, RSVD1, RSVD2, RSVD3, 0x3018, 0, Y, -1, 5, 6, -1, 9, 10, 12), 1903 + PINGROUP(can0_stb_paa4, RSVD0, WDT, TSC, TSC_ALT, 0x3020, 0, Y, -1, 5, 6, -1, 9, 10, 12), 1904 + PINGROUP(can0_en_paa5, RSVD0, RSVD1, RSVD2, RSVD3, 0x3028, 0, Y, -1, 5, 6, -1, 9, 10, 12), 1905 + PINGROUP(soc_gpio49_paa6, RSVD0, RSVD1, RSVD2, RSVD3, 0x3030, 0, Y, -1, 5, 6, -1, 9, 10, 12), 1906 + PINGROUP(can0_err_paa7, RSVD0, TSC, RSVD2, TSC_ALT, 0x3038, 0, Y, -1, 5, 6, -1, 9, 10, 12), 1907 + PINGROUP(can1_stb_pbb0, RSVD0, DMIC3, DMIC5, RSVD3, 0x3040, 0, Y, -1, 5, 6, -1, 9, 10, 12), 1908 + PINGROUP(can1_en_pbb1, RSVD0, DMIC3, DMIC5, RSVD3, 0x3048, 0, Y, -1, 5, 6, -1, 9, 10, 12), 1909 + PINGROUP(soc_gpio50_pbb2, RSVD0, TSC, RSVD2, TSC_ALT, 0x3050, 0, Y, -1, 5, 6, -1, 9, 10, 12), 1910 + PINGROUP(can1_err_pbb3, RSVD0, TSC, RSVD2, TSC_ALT, 0x3058, 0, Y, -1, 5, 6, -1, 9, 10, 12), 1911 + PINGROUP(sce_error_pee0, SCE, RSVD1, RSVD2, RSVD3, 0x1010, 0, Y, 5, 7, 6, 8, -1, 10, 12), 1912 + PINGROUP(batt_oc_pee3, SOC, RSVD1, RSVD2, RSVD3, 0x1020, 0, Y, 5, 7, 6, 8, -1, 10, 12), 1913 + PINGROUP(bootv_ctl_n_pee7, RSVD0, RSVD1, RSVD2, RSVD3, 0x1028, 0, Y, -1, 7, 6, 8, -1, 10, 12), 1914 + PINGROUP(power_on_pee4, RSVD0, RSVD1, RSVD2, RSVD3, 0x1038, 0, Y, 5, 7, 6, 8, -1, 10, 12), 1915 + PINGROUP(soc_gpio26_pee5, RSVD0, RSVD1, RSVD2, RSVD3, 0x1040, 0, Y, 5, 7, 6, 8, -1, 10, 12), 1916 + PINGROUP(soc_gpio27_pee6, RSVD0, RSVD1, RSVD2, RSVD3, 0x1048, 0, Y, 5, 7, 6, 8, -1, 10, 12), 1917 + PINGROUP(ao_retention_n_pee2, GPIO, LED, RSVD2, ISTCTRL, 0x1050, 0, Y, 5, 7, 6, 8, -1, 10, 12), 1918 + PINGROUP(vcomp_alert_pee1, SOC, RSVD1, RSVD2, RSVD3, 0x1058, 0, Y, 5, 7, 6, 8, -1, 10, 12), 1919 + PINGROUP(hdmi_cec_pgg0, HDMI, RSVD1, RSVD2, RSVD3, 0x1060, 0, Y, 5, 7, 6, 8, -1, 10, 12), 1920 + }; 1921 + 1922 + static const struct tegra_pinctrl_soc_data tegra234_pinctrl_aon = { 1923 + .pins = tegra234_aon_pins, 1924 + .npins = ARRAY_SIZE(tegra234_aon_pins), 1925 + .functions = tegra234_functions, 1926 + .nfunctions = ARRAY_SIZE(tegra234_functions), 1927 + .groups = tegra234_aon_groups, 1928 + .ngroups = ARRAY_SIZE(tegra234_aon_groups), 1929 + .hsm_in_mux = false, 1930 + .schmitt_in_mux = true, 1931 + .drvtype_in_mux = true, 1932 + .sfsel_in_mux = true, 1933 + }; 1934 + 1935 + static int tegra234_pinctrl_probe(struct platform_device *pdev) 1936 + { 1937 + const struct tegra_pinctrl_soc_data *soc = device_get_match_data(&pdev->dev); 1938 + 1939 + return tegra_pinctrl_probe(pdev, soc); 1940 + } 1941 + 1942 + static const struct of_device_id tegra234_pinctrl_of_match[] = { 1943 + { .compatible = "nvidia,tegra234-pinmux", .data = &tegra234_pinctrl}, 1944 + { .compatible = "nvidia,tegra234-pinmux-aon", .data = &tegra234_pinctrl_aon }, 1945 + { } 1946 + }; 1947 + MODULE_DEVICE_TABLE(of, tegra234_pinctrl_of_match); 1948 + 1949 + static struct platform_driver tegra234_pinctrl_driver = { 1950 + .driver = { 1951 + .name = "tegra234-pinctrl", 1952 + .of_match_table = tegra234_pinctrl_of_match, 1953 + }, 1954 + .probe = tegra234_pinctrl_probe, 1955 + }; 1956 + 1957 + static int __init tegra234_pinctrl_init(void) 1958 + { 1959 + return platform_driver_register(&tegra234_pinctrl_driver); 1960 + } 1961 + arch_initcall(tegra234_pinctrl_init);
+1
drivers/soc/tegra/Kconfig
··· 125 125 bool "NVIDIA Tegra234 SoC" 126 126 depends on !CPU_BIG_ENDIAN 127 127 select MAILBOX 128 + select PINCTRL_TEGRA234 128 129 select TEGRA_BPMP 129 130 select TEGRA_HSP_MBOX 130 131 select TEGRA_IVC