GNU Linux-libre 6.9.1-gnu
[releases.git] / 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
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
1633 static 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
1804 static 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
1817 static 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
1886 static 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
1921 static 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
1934 static 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
1941 static 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 };
1946 MODULE_DEVICE_TABLE(of, tegra234_pinctrl_of_match);
1947
1948 static 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
1956 static int __init tegra234_pinctrl_init(void)
1957 {
1958         return platform_driver_register(&tegra234_pinctrl_driver);
1959 }
1960 arch_initcall(tegra234_pinctrl_init);