aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/pinctrl/pinctrl-tegra114.c
diff options
context:
space:
mode:
authorPritesh Raithatha <praithatha@nvidia.com>2013-01-08 02:32:37 -0500
committerLinus Walleij <linus.walleij@linaro.org>2013-01-18 10:14:54 -0500
commitb6ae7a26535bb37c6c023c6f25b7f98904a8ab7c (patch)
treeced45d1f24a8e13c9d81633f61d07c2bf3f4c522 /drivers/pinctrl/pinctrl-tegra114.c
parent348d1bf75c09f854630e9bd161dc2a88aebe2149 (diff)
pinctrl: tegra114: add pinctrl driver for NVIDIA's Tegra114 SoC
This adds a driver for the Tegra114 pinmux, and required parameterization data for Tegra114. The driver uses the common Tegra pincontrol driver utility functions to implement the majority of the driver. This driver is not compatible with the earlier NVIDIA's SoCs, hence add new compatibile as "nvidia,tegra114-pinmux". Originally written by Pritesh. ldewangan: - cleanup the patches, - remove non-require tables. - Use module_platform_driver() for driver registartion. Signed-off-by: Pritesh Raithatha <praithatha@nvidia.com> Signed-off-by: Laxman Dewangan <ldewangan@nvidia.com> Reviewed-by: Stephen Warren <swarren@nvidia.com> Signed-off-by: Linus Walleij <linus.walleij@linaro.org>
Diffstat (limited to 'drivers/pinctrl/pinctrl-tegra114.c')
-rw-r--r--drivers/pinctrl/pinctrl-tegra114.c2757
1 files changed, 2757 insertions, 0 deletions
diff --git a/drivers/pinctrl/pinctrl-tegra114.c b/drivers/pinctrl/pinctrl-tegra114.c
new file mode 100644
index 000000000000..053a8b1b12f1
--- /dev/null
+++ b/drivers/pinctrl/pinctrl-tegra114.c
@@ -0,0 +1,2757 @@
1/*
2 * Pinctrl data and driver for the NVIDIA Tegra114 pinmux
3 *
4 * Copyright (c) 2012-2013, NVIDIA CORPORATION. All rights reserved.
5 *
6 * Arthur: Pritesh Raithatha <praithatha@nvidia.com>
7 *
8 * This program is free software; you can redistribute it and/or modify it
9 * under the terms and conditions of the GNU General Public License,
10 * version 2, as published by the Free Software Foundation.
11 *
12 * This program is distributed in the hope it will be useful, but WITHOUT
13 * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
14 * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for
15 * more details.
16 *
17 * You should have received a copy of the GNU General Public License
18 * along with this program. If not, see <http://www.gnu.org/licenses/>.
19 */
20
21#include <linux/module.h>
22#include <linux/of.h>
23#include <linux/platform_device.h>
24#include <linux/pinctrl/pinctrl.h>
25#include <linux/pinctrl/pinmux.h>
26
27#include "pinctrl-tegra.h"
28
29/*
30 * Most pins affected by the pinmux can also be GPIOs. Define these first.
31 * These must match how the GPIO driver names/numbers its pins.
32 */
33#define _GPIO(offset) (offset)
34
35#define TEGRA_PIN_CLK_32K_OUT_PA0 _GPIO(0)
36#define TEGRA_PIN_UART3_CTS_N_PA1 _GPIO(1)
37#define TEGRA_PIN_DAP2_FS_PA2 _GPIO(2)
38#define TEGRA_PIN_DAP2_SCLK_PA3 _GPIO(3)
39#define TEGRA_PIN_DAP2_DIN_PA4 _GPIO(4)
40#define TEGRA_PIN_DAP2_DOUT_PA5 _GPIO(5)
41#define TEGRA_PIN_SDMMC3_CLK_PA6 _GPIO(6)
42#define TEGRA_PIN_SDMMC3_CMD_PA7 _GPIO(7)
43#define TEGRA_PIN_GMI_A17_PB0 _GPIO(8)
44#define TEGRA_PIN_GMI_A18_PB1 _GPIO(9)
45#define TEGRA_PIN_SDMMC3_DAT3_PB4 _GPIO(12)
46#define TEGRA_PIN_SDMMC3_DAT2_PB5 _GPIO(13)
47#define TEGRA_PIN_SDMMC3_DAT1_PB6 _GPIO(14)
48#define TEGRA_PIN_SDMMC3_DAT0_PB7 _GPIO(15)
49#define TEGRA_PIN_UART3_RTS_N_PC0 _GPIO(16)
50#define TEGRA_PIN_UART2_TXD_PC2 _GPIO(18)
51#define TEGRA_PIN_UART2_RXD_PC3 _GPIO(19)
52#define TEGRA_PIN_GEN1_I2C_SCL_PC4 _GPIO(20)
53#define TEGRA_PIN_GEN1_I2C_SDA_PC5 _GPIO(21)
54#define TEGRA_PIN_GMI_WP_N_PC7 _GPIO(23)
55#define TEGRA_PIN_GMI_AD0_PG0 _GPIO(48)
56#define TEGRA_PIN_GMI_AD1_PG1 _GPIO(49)
57#define TEGRA_PIN_GMI_AD2_PG2 _GPIO(50)
58#define TEGRA_PIN_GMI_AD3_PG3 _GPIO(51)
59#define TEGRA_PIN_GMI_AD4_PG4 _GPIO(52)
60#define TEGRA_PIN_GMI_AD5_PG5 _GPIO(53)
61#define TEGRA_PIN_GMI_AD6_PG6 _GPIO(54)
62#define TEGRA_PIN_GMI_AD7_PG7 _GPIO(55)
63#define TEGRA_PIN_GMI_AD8_PH0 _GPIO(56)
64#define TEGRA_PIN_GMI_AD9_PH1 _GPIO(57)
65#define TEGRA_PIN_GMI_AD10_PH2 _GPIO(58)
66#define TEGRA_PIN_GMI_AD11_PH3 _GPIO(59)
67#define TEGRA_PIN_GMI_AD12_PH4 _GPIO(60)
68#define TEGRA_PIN_GMI_AD13_PH5 _GPIO(61)
69#define TEGRA_PIN_GMI_AD14_PH6 _GPIO(62)
70#define TEGRA_PIN_GMI_AD15_PH7 _GPIO(63)
71#define TEGRA_PIN_GMI_WR_N_PI0 _GPIO(64)
72#define TEGRA_PIN_GMI_OE_N_PI1 _GPIO(65)
73#define TEGRA_PIN_GMI_CS6_N_PI3 _GPIO(67)
74#define TEGRA_PIN_GMI_RST_N_PI4 _GPIO(68)
75#define TEGRA_PIN_GMI_IORDY_PI5 _GPIO(69)
76#define TEGRA_PIN_GMI_CS7_N_PI6 _GPIO(70)
77#define TEGRA_PIN_GMI_WAIT_PI7 _GPIO(71)
78#define TEGRA_PIN_GMI_CS0_N_PJ0 _GPIO(72)
79#define TEGRA_PIN_GMI_CS1_N_PJ2 _GPIO(74)
80#define TEGRA_PIN_GMI_DQS_P_PJ3 _GPIO(75)
81#define TEGRA_PIN_UART2_CTS_N_PJ5 _GPIO(77)
82#define TEGRA_PIN_UART2_RTS_N_PJ6 _GPIO(78)
83#define TEGRA_PIN_GMI_A16_PJ7 _GPIO(79)
84#define TEGRA_PIN_GMI_ADV_N_PK0 _GPIO(80)
85#define TEGRA_PIN_GMI_CLK_PK1 _GPIO(81)
86#define TEGRA_PIN_GMI_CS4_N_PK2 _GPIO(82)
87#define TEGRA_PIN_GMI_CS2_N_PK3 _GPIO(83)
88#define TEGRA_PIN_GMI_CS3_N_PK4 _GPIO(84)
89#define TEGRA_PIN_SPDIF_OUT_PK5 _GPIO(85)
90#define TEGRA_PIN_SPDIF_IN_PK6 _GPIO(86)
91#define TEGRA_PIN_GMI_A19_PK7 _GPIO(87)
92#define TEGRA_PIN_DAP1_FS_PN0 _GPIO(104)
93#define TEGRA_PIN_DAP1_DIN_PN1 _GPIO(105)
94#define TEGRA_PIN_DAP1_DOUT_PN2 _GPIO(106)
95#define TEGRA_PIN_DAP1_SCLK_PN3 _GPIO(107)
96#define TEGRA_PIN_USB_VBUS_EN0_PN4 _GPIO(108)
97#define TEGRA_PIN_USB_VBUS_EN1_PN5 _GPIO(109)
98#define TEGRA_PIN_HDMI_INT_PN7 _GPIO(111)
99#define TEGRA_PIN_ULPI_DATA7_PO0 _GPIO(112)
100#define TEGRA_PIN_ULPI_DATA0_PO1 _GPIO(113)
101#define TEGRA_PIN_ULPI_DATA1_PO2 _GPIO(114)
102#define TEGRA_PIN_ULPI_DATA2_PO3 _GPIO(115)
103#define TEGRA_PIN_ULPI_DATA3_PO4 _GPIO(116)
104#define TEGRA_PIN_ULPI_DATA4_PO5 _GPIO(117)
105#define TEGRA_PIN_ULPI_DATA5_PO6 _GPIO(118)
106#define TEGRA_PIN_ULPI_DATA6_PO7 _GPIO(119)
107#define TEGRA_PIN_DAP3_FS_PP0 _GPIO(120)
108#define TEGRA_PIN_DAP3_DIN_PP1 _GPIO(121)
109#define TEGRA_PIN_DAP3_DOUT_PP2 _GPIO(122)
110#define TEGRA_PIN_DAP3_SCLK_PP3 _GPIO(123)
111#define TEGRA_PIN_DAP4_FS_PP4 _GPIO(124)
112#define TEGRA_PIN_DAP4_DIN_PP5 _GPIO(125)
113#define TEGRA_PIN_DAP4_DOUT_PP6 _GPIO(126)
114#define TEGRA_PIN_DAP4_SCLK_PP7 _GPIO(127)
115#define TEGRA_PIN_KB_COL0_PQ0 _GPIO(128)
116#define TEGRA_PIN_KB_COL1_PQ1 _GPIO(129)
117#define TEGRA_PIN_KB_COL2_PQ2 _GPIO(130)
118#define TEGRA_PIN_KB_COL3_PQ3 _GPIO(131)
119#define TEGRA_PIN_KB_COL4_PQ4 _GPIO(132)
120#define TEGRA_PIN_KB_COL5_PQ5 _GPIO(133)
121#define TEGRA_PIN_KB_COL6_PQ6 _GPIO(134)
122#define TEGRA_PIN_KB_COL7_PQ7 _GPIO(135)
123#define TEGRA_PIN_KB_ROW0_PR0 _GPIO(136)
124#define TEGRA_PIN_KB_ROW1_PR1 _GPIO(137)
125#define TEGRA_PIN_KB_ROW2_PR2 _GPIO(138)
126#define TEGRA_PIN_KB_ROW3_PR3 _GPIO(139)
127#define TEGRA_PIN_KB_ROW4_PR4 _GPIO(140)
128#define TEGRA_PIN_KB_ROW5_PR5 _GPIO(141)
129#define TEGRA_PIN_KB_ROW6_PR6 _GPIO(142)
130#define TEGRA_PIN_KB_ROW7_PR7 _GPIO(143)
131#define TEGRA_PIN_KB_ROW8_PS0 _GPIO(144)
132#define TEGRA_PIN_KB_ROW9_PS1 _GPIO(145)
133#define TEGRA_PIN_KB_ROW10_PS2 _GPIO(146)
134#define TEGRA_PIN_GEN2_I2C_SCL_PT5 _GPIO(157)
135#define TEGRA_PIN_GEN2_I2C_SDA_PT6 _GPIO(158)
136#define TEGRA_PIN_SDMMC4_CMD_PT7 _GPIO(159)
137#define TEGRA_PIN_PU0 _GPIO(160)
138#define TEGRA_PIN_PU1 _GPIO(161)
139#define TEGRA_PIN_PU2 _GPIO(162)
140#define TEGRA_PIN_PU3 _GPIO(163)
141#define TEGRA_PIN_PU4 _GPIO(164)
142#define TEGRA_PIN_PU5 _GPIO(165)
143#define TEGRA_PIN_PU6 _GPIO(166)
144#define TEGRA_PIN_PV0 _GPIO(168)
145#define TEGRA_PIN_PV1 _GPIO(169)
146#define TEGRA_PIN_SDMMC3_CD_N_PV2 _GPIO(170)
147#define TEGRA_PIN_SDMMC1_WP_N_PV3 _GPIO(171)
148#define TEGRA_PIN_DDC_SCL_PV4 _GPIO(172)
149#define TEGRA_PIN_DDC_SDA_PV5 _GPIO(173)
150#define TEGRA_PIN_GPIO_W2_AUD_PW2 _GPIO(178)
151#define TEGRA_PIN_GPIO_W3_AUD_PW3 _GPIO(179)
152#define TEGRA_PIN_CLK1_OUT_PW4 _GPIO(180)
153#define TEGRA_PIN_CLK2_OUT_PW5 _GPIO(181)
154#define TEGRA_PIN_UART3_TXD_PW6 _GPIO(182)
155#define TEGRA_PIN_UART3_RXD_PW7 _GPIO(183)
156#define TEGRA_PIN_DVFS_PWM_PX0 _GPIO(184)
157#define TEGRA_PIN_GPIO_X1_AUD_PX1 _GPIO(185)
158#define TEGRA_PIN_DVFS_CLK_PX2 _GPIO(186)
159#define TEGRA_PIN_GPIO_X3_AUD_PX3 _GPIO(187)
160#define TEGRA_PIN_GPIO_X4_AUD_PX4 _GPIO(188)
161#define TEGRA_PIN_GPIO_X5_AUD_PX5 _GPIO(189)
162#define TEGRA_PIN_GPIO_X6_AUD_PX6 _GPIO(190)
163#define TEGRA_PIN_GPIO_X7_AUD_PX7 _GPIO(191)
164#define TEGRA_PIN_ULPI_CLK_PY0 _GPIO(192)
165#define TEGRA_PIN_ULPI_DIR_PY1 _GPIO(193)
166#define TEGRA_PIN_ULPI_NXT_PY2 _GPIO(194)
167#define TEGRA_PIN_ULPI_STP_PY3 _GPIO(195)
168#define TEGRA_PIN_SDMMC1_DAT3_PY4 _GPIO(196)
169#define TEGRA_PIN_SDMMC1_DAT2_PY5 _GPIO(197)
170#define TEGRA_PIN_SDMMC1_DAT1_PY6 _GPIO(198)
171#define TEGRA_PIN_SDMMC1_DAT0_PY7 _GPIO(199)
172#define TEGRA_PIN_SDMMC1_CLK_PZ0 _GPIO(200)
173#define TEGRA_PIN_SDMMC1_CMD_PZ1 _GPIO(201)
174#define TEGRA_PIN_SYS_CLK_REQ_PZ5 _GPIO(205)
175#define TEGRA_PIN_PWR_I2C_SCL_PZ6 _GPIO(206)
176#define TEGRA_PIN_PWR_I2C_SDA_PZ7 _GPIO(207)
177#define TEGRA_PIN_SDMMC4_DAT0_PAA0 _GPIO(208)
178#define TEGRA_PIN_SDMMC4_DAT1_PAA1 _GPIO(209)
179#define TEGRA_PIN_SDMMC4_DAT2_PAA2 _GPIO(210)
180#define TEGRA_PIN_SDMMC4_DAT3_PAA3 _GPIO(211)
181#define TEGRA_PIN_SDMMC4_DAT4_PAA4 _GPIO(212)
182#define TEGRA_PIN_SDMMC4_DAT5_PAA5 _GPIO(213)
183#define TEGRA_PIN_SDMMC4_DAT6_PAA6 _GPIO(214)
184#define TEGRA_PIN_SDMMC4_DAT7_PAA7 _GPIO(215)
185#define TEGRA_PIN_PBB0 _GPIO(216)
186#define TEGRA_PIN_CAM_I2C_SCL_PBB1 _GPIO(217)
187#define TEGRA_PIN_CAM_I2C_SDA_PBB2 _GPIO(218)
188#define TEGRA_PIN_PBB3 _GPIO(219)
189#define TEGRA_PIN_PBB4 _GPIO(220)
190#define TEGRA_PIN_PBB5 _GPIO(221)
191#define TEGRA_PIN_PBB6 _GPIO(222)
192#define TEGRA_PIN_PBB7 _GPIO(223)
193#define TEGRA_PIN_CAM_MCLK_PCC0 _GPIO(224)
194#define TEGRA_PIN_PCC1 _GPIO(225)
195#define TEGRA_PIN_PCC2 _GPIO(226)
196#define TEGRA_PIN_SDMMC4_CLK_PCC4 _GPIO(228)
197#define TEGRA_PIN_CLK2_REQ_PCC5 _GPIO(229)
198#define TEGRA_PIN_CLK3_OUT_PEE0 _GPIO(240)
199#define TEGRA_PIN_CLK3_REQ_PEE1 _GPIO(241)
200#define TEGRA_PIN_CLK1_REQ_PEE2 _GPIO(242)
201#define TEGRA_PIN_HDMI_CEC_PEE3 _GPIO(243)
202#define TEGRA_PIN_SDMMC3_CLK_LB_OUT_PEE4 _GPIO(244)
203#define TEGRA_PIN_SDMMC3_CLK_LB_IN_PEE5 _GPIO(245)
204
205/* All non-GPIO pins follow */
206#define NUM_GPIOS (TEGRA_PIN_SDMMC3_CLK_LB_IN_PEE5 + 1)
207#define _PIN(offset) (NUM_GPIOS + (offset))
208
209/* Non-GPIO pins */
210#define TEGRA_PIN_CORE_PWR_REQ _PIN(0)
211#define TEGRA_PIN_CPU_PWR_REQ _PIN(1)
212#define TEGRA_PIN_PWR_INT_N _PIN(2)
213#define TEGRA_PIN_RESET_OUT_N _PIN(3)
214#define TEGRA_PIN_OWR _PIN(4)
215
216static const struct pinctrl_pin_desc tegra114_pins[] = {
217 PINCTRL_PIN(TEGRA_PIN_CLK_32K_OUT_PA0, "CLK_32K_OUT PA0"),
218 PINCTRL_PIN(TEGRA_PIN_UART3_CTS_N_PA1, "UART3_CTS_N PA1"),
219 PINCTRL_PIN(TEGRA_PIN_DAP2_FS_PA2, "DAP2_FS PA2"),
220 PINCTRL_PIN(TEGRA_PIN_DAP2_SCLK_PA3, "DAP2_SCLK PA3"),
221 PINCTRL_PIN(TEGRA_PIN_DAP2_DIN_PA4, "DAP2_DIN PA4"),
222 PINCTRL_PIN(TEGRA_PIN_DAP2_DOUT_PA5, "DAP2_DOUT PA5"),
223 PINCTRL_PIN(TEGRA_PIN_SDMMC3_CLK_PA6, "SDMMC3_CLK PA6"),
224 PINCTRL_PIN(TEGRA_PIN_SDMMC3_CMD_PA7, "SDMMC3_CMD PA7"),
225 PINCTRL_PIN(TEGRA_PIN_GMI_A17_PB0, "GMI_A17 PB0"),
226 PINCTRL_PIN(TEGRA_PIN_GMI_A18_PB1, "GMI_A18 PB1"),
227 PINCTRL_PIN(TEGRA_PIN_SDMMC3_DAT3_PB4, "SDMMC3_DAT3 PB4"),
228 PINCTRL_PIN(TEGRA_PIN_SDMMC3_DAT2_PB5, "SDMMC3_DAT2 PB5"),
229 PINCTRL_PIN(TEGRA_PIN_SDMMC3_DAT1_PB6, "SDMMC3_DAT1 PB6"),
230 PINCTRL_PIN(TEGRA_PIN_SDMMC3_DAT0_PB7, "SDMMC3_DAT0 PB7"),
231 PINCTRL_PIN(TEGRA_PIN_UART3_RTS_N_PC0, "UART3_RTS_N PC0"),
232 PINCTRL_PIN(TEGRA_PIN_UART2_TXD_PC2, "UART2_TXD PC2"),
233 PINCTRL_PIN(TEGRA_PIN_UART2_RXD_PC3, "UART2_RXD PC3"),
234 PINCTRL_PIN(TEGRA_PIN_GEN1_I2C_SCL_PC4, "GEN1_I2C_SCL PC4"),
235 PINCTRL_PIN(TEGRA_PIN_GEN1_I2C_SDA_PC5, "GEN1_I2C_SDA PC5"),
236 PINCTRL_PIN(TEGRA_PIN_GMI_WP_N_PC7, "GMI_WP_N PC7"),
237 PINCTRL_PIN(TEGRA_PIN_GMI_AD0_PG0, "GMI_AD0 PG0"),
238 PINCTRL_PIN(TEGRA_PIN_GMI_AD1_PG1, "GMI_AD1 PG1"),
239 PINCTRL_PIN(TEGRA_PIN_GMI_AD2_PG2, "GMI_AD2 PG2"),
240 PINCTRL_PIN(TEGRA_PIN_GMI_AD3_PG3, "GMI_AD3 PG3"),
241 PINCTRL_PIN(TEGRA_PIN_GMI_AD4_PG4, "GMI_AD4 PG4"),
242 PINCTRL_PIN(TEGRA_PIN_GMI_AD5_PG5, "GMI_AD5 PG5"),
243 PINCTRL_PIN(TEGRA_PIN_GMI_AD6_PG6, "GMI_AD6 PG6"),
244 PINCTRL_PIN(TEGRA_PIN_GMI_AD7_PG7, "GMI_AD7 PG7"),
245 PINCTRL_PIN(TEGRA_PIN_GMI_AD8_PH0, "GMI_AD8 PH0"),
246 PINCTRL_PIN(TEGRA_PIN_GMI_AD9_PH1, "GMI_AD9 PH1"),
247 PINCTRL_PIN(TEGRA_PIN_GMI_AD10_PH2, "GMI_AD10 PH2"),
248 PINCTRL_PIN(TEGRA_PIN_GMI_AD11_PH3, "GMI_AD11 PH3"),
249 PINCTRL_PIN(TEGRA_PIN_GMI_AD12_PH4, "GMI_AD12 PH4"),
250 PINCTRL_PIN(TEGRA_PIN_GMI_AD13_PH5, "GMI_AD13 PH5"),
251 PINCTRL_PIN(TEGRA_PIN_GMI_AD14_PH6, "GMI_AD14 PH6"),
252 PINCTRL_PIN(TEGRA_PIN_GMI_AD15_PH7, "GMI_AD15 PH7"),
253 PINCTRL_PIN(TEGRA_PIN_GMI_WR_N_PI0, "GMI_WR_N PI0"),
254 PINCTRL_PIN(TEGRA_PIN_GMI_OE_N_PI1, "GMI_OE_N PI1"),
255 PINCTRL_PIN(TEGRA_PIN_GMI_CS6_N_PI3, "GMI_CS6_N PI3"),
256 PINCTRL_PIN(TEGRA_PIN_GMI_RST_N_PI4, "GMI_RST_N PI4"),
257 PINCTRL_PIN(TEGRA_PIN_GMI_IORDY_PI5, "GMI_IORDY PI5"),
258 PINCTRL_PIN(TEGRA_PIN_GMI_CS7_N_PI6, "GMI_CS7_N PI6"),
259 PINCTRL_PIN(TEGRA_PIN_GMI_WAIT_PI7, "GMI_WAIT PI7"),
260 PINCTRL_PIN(TEGRA_PIN_GMI_CS0_N_PJ0, "GMI_CS0_N PJ0"),
261 PINCTRL_PIN(TEGRA_PIN_GMI_CS1_N_PJ2, "GMI_CS1_N PJ2"),
262 PINCTRL_PIN(TEGRA_PIN_GMI_DQS_P_PJ3, "GMI_DQS_P PJ3"),
263 PINCTRL_PIN(TEGRA_PIN_UART2_CTS_N_PJ5, "UART2_CTS_N PJ5"),
264 PINCTRL_PIN(TEGRA_PIN_UART2_RTS_N_PJ6, "UART2_RTS_N PJ6"),
265 PINCTRL_PIN(TEGRA_PIN_GMI_A16_PJ7, "GMI_A16 PJ7"),
266 PINCTRL_PIN(TEGRA_PIN_GMI_ADV_N_PK0, "GMI_ADV_N PK0"),
267 PINCTRL_PIN(TEGRA_PIN_GMI_CLK_PK1, "GMI_CLK PK1"),
268 PINCTRL_PIN(TEGRA_PIN_GMI_CS4_N_PK2, "GMI_CS4_N PK2"),
269 PINCTRL_PIN(TEGRA_PIN_GMI_CS2_N_PK3, "GMI_CS2_N PK3"),
270 PINCTRL_PIN(TEGRA_PIN_GMI_CS3_N_PK4, "GMI_CS3_N PK4"),
271 PINCTRL_PIN(TEGRA_PIN_SPDIF_OUT_PK5, "SPDIF_OUT PK5"),
272 PINCTRL_PIN(TEGRA_PIN_SPDIF_IN_PK6, "SPDIF_IN PK6"),
273 PINCTRL_PIN(TEGRA_PIN_GMI_A19_PK7, "GMI_A19 PK7"),
274 PINCTRL_PIN(TEGRA_PIN_DAP1_FS_PN0, "DAP1_FS PN0"),
275 PINCTRL_PIN(TEGRA_PIN_DAP1_DIN_PN1, "DAP1_DIN PN1"),
276 PINCTRL_PIN(TEGRA_PIN_DAP1_DOUT_PN2, "DAP1_DOUT PN2"),
277 PINCTRL_PIN(TEGRA_PIN_DAP1_SCLK_PN3, "DAP1_SCLK PN3"),
278 PINCTRL_PIN(TEGRA_PIN_USB_VBUS_EN0_PN4, "USB_VBUS_EN0 PN4"),
279 PINCTRL_PIN(TEGRA_PIN_USB_VBUS_EN1_PN5, "USB_VBUS_EN1 PN5"),
280 PINCTRL_PIN(TEGRA_PIN_HDMI_INT_PN7, "HDMI_INT PN7"),
281 PINCTRL_PIN(TEGRA_PIN_ULPI_DATA7_PO0, "ULPI_DATA7 PO0"),
282 PINCTRL_PIN(TEGRA_PIN_ULPI_DATA0_PO1, "ULPI_DATA0 PO1"),
283 PINCTRL_PIN(TEGRA_PIN_ULPI_DATA1_PO2, "ULPI_DATA1 PO2"),
284 PINCTRL_PIN(TEGRA_PIN_ULPI_DATA2_PO3, "ULPI_DATA2 PO3"),
285 PINCTRL_PIN(TEGRA_PIN_ULPI_DATA3_PO4, "ULPI_DATA3 PO4"),
286 PINCTRL_PIN(TEGRA_PIN_ULPI_DATA4_PO5, "ULPI_DATA4 PO5"),
287 PINCTRL_PIN(TEGRA_PIN_ULPI_DATA5_PO6, "ULPI_DATA5 PO6"),
288 PINCTRL_PIN(TEGRA_PIN_ULPI_DATA6_PO7, "ULPI_DATA6 PO7"),
289 PINCTRL_PIN(TEGRA_PIN_DAP3_FS_PP0, "DAP3_FS PP0"),
290 PINCTRL_PIN(TEGRA_PIN_DAP3_DIN_PP1, "DAP3_DIN PP1"),
291 PINCTRL_PIN(TEGRA_PIN_DAP3_DOUT_PP2, "DAP3_DOUT PP2"),
292 PINCTRL_PIN(TEGRA_PIN_DAP3_SCLK_PP3, "DAP3_SCLK PP3"),
293 PINCTRL_PIN(TEGRA_PIN_DAP4_FS_PP4, "DAP4_FS PP4"),
294 PINCTRL_PIN(TEGRA_PIN_DAP4_DIN_PP5, "DAP4_DIN PP5"),
295 PINCTRL_PIN(TEGRA_PIN_DAP4_DOUT_PP6, "DAP4_DOUT PP6"),
296 PINCTRL_PIN(TEGRA_PIN_DAP4_SCLK_PP7, "DAP4_SCLK PP7"),
297 PINCTRL_PIN(TEGRA_PIN_KB_COL0_PQ0, "KB_COL0 PQ0"),
298 PINCTRL_PIN(TEGRA_PIN_KB_COL1_PQ1, "KB_COL1 PQ1"),
299 PINCTRL_PIN(TEGRA_PIN_KB_COL2_PQ2, "KB_COL2 PQ2"),
300 PINCTRL_PIN(TEGRA_PIN_KB_COL3_PQ3, "KB_COL3 PQ3"),
301 PINCTRL_PIN(TEGRA_PIN_KB_COL4_PQ4, "KB_COL4 PQ4"),
302 PINCTRL_PIN(TEGRA_PIN_KB_COL5_PQ5, "KB_COL5 PQ5"),
303 PINCTRL_PIN(TEGRA_PIN_KB_COL6_PQ6, "KB_COL6 PQ6"),
304 PINCTRL_PIN(TEGRA_PIN_KB_COL7_PQ7, "KB_COL7 PQ7"),
305 PINCTRL_PIN(TEGRA_PIN_KB_ROW0_PR0, "KB_ROW0 PR0"),
306 PINCTRL_PIN(TEGRA_PIN_KB_ROW1_PR1, "KB_ROW1 PR1"),
307 PINCTRL_PIN(TEGRA_PIN_KB_ROW2_PR2, "KB_ROW2 PR2"),
308 PINCTRL_PIN(TEGRA_PIN_KB_ROW3_PR3, "KB_ROW3 PR3"),
309 PINCTRL_PIN(TEGRA_PIN_KB_ROW4_PR4, "KB_ROW4 PR4"),
310 PINCTRL_PIN(TEGRA_PIN_KB_ROW5_PR5, "KB_ROW5 PR5"),
311 PINCTRL_PIN(TEGRA_PIN_KB_ROW6_PR6, "KB_ROW6 PR6"),
312 PINCTRL_PIN(TEGRA_PIN_KB_ROW7_PR7, "KB_ROW7 PR7"),
313 PINCTRL_PIN(TEGRA_PIN_KB_ROW8_PS0, "KB_ROW8 PS0"),
314 PINCTRL_PIN(TEGRA_PIN_KB_ROW9_PS1, "KB_ROW9 PS1"),
315 PINCTRL_PIN(TEGRA_PIN_KB_ROW10_PS2, "KB_ROW10 PS2"),
316 PINCTRL_PIN(TEGRA_PIN_GEN2_I2C_SCL_PT5, "GEN2_I2C_SCL PT5"),
317 PINCTRL_PIN(TEGRA_PIN_GEN2_I2C_SDA_PT6, "GEN2_I2C_SDA PT6"),
318 PINCTRL_PIN(TEGRA_PIN_SDMMC4_CMD_PT7, "SDMMC4_CMD PT7"),
319 PINCTRL_PIN(TEGRA_PIN_PU0, "PU0"),
320 PINCTRL_PIN(TEGRA_PIN_PU1, "PU1"),
321 PINCTRL_PIN(TEGRA_PIN_PU2, "PU2"),
322 PINCTRL_PIN(TEGRA_PIN_PU3, "PU3"),
323 PINCTRL_PIN(TEGRA_PIN_PU4, "PU4"),
324 PINCTRL_PIN(TEGRA_PIN_PU5, "PU5"),
325 PINCTRL_PIN(TEGRA_PIN_PU6, "PU6"),
326 PINCTRL_PIN(TEGRA_PIN_PV0, "PV0"),
327 PINCTRL_PIN(TEGRA_PIN_PV1, "PV1"),
328 PINCTRL_PIN(TEGRA_PIN_SDMMC3_CD_N_PV2, "SDMMC3_CD_N PV2"),
329 PINCTRL_PIN(TEGRA_PIN_SDMMC1_WP_N_PV3, "SDMMC1_WP_N PV3"),
330 PINCTRL_PIN(TEGRA_PIN_DDC_SCL_PV4, "DDC_SCL PV4"),
331 PINCTRL_PIN(TEGRA_PIN_DDC_SDA_PV5, "DDC_SDA PV5"),
332 PINCTRL_PIN(TEGRA_PIN_GPIO_W2_AUD_PW2, "GPIO_W2_AUD PW2"),
333 PINCTRL_PIN(TEGRA_PIN_GPIO_W3_AUD_PW3, "GPIO_W3_AUD PW3"),
334 PINCTRL_PIN(TEGRA_PIN_CLK1_OUT_PW4, "CLK1_OUT PW4"),
335 PINCTRL_PIN(TEGRA_PIN_CLK2_OUT_PW5, "CLK2_OUT PW5"),
336 PINCTRL_PIN(TEGRA_PIN_UART3_TXD_PW6, "UART3_TXD PW6"),
337 PINCTRL_PIN(TEGRA_PIN_UART3_RXD_PW7, "UART3_RXD PW7"),
338 PINCTRL_PIN(TEGRA_PIN_DVFS_PWM_PX0, "DVFS_PWM PX0"),
339 PINCTRL_PIN(TEGRA_PIN_GPIO_X1_AUD_PX1, "GPIO_X1_AUD PX1"),
340 PINCTRL_PIN(TEGRA_PIN_DVFS_CLK_PX2, "DVFS_CLK PX2"),
341 PINCTRL_PIN(TEGRA_PIN_GPIO_X3_AUD_PX3, "GPIO_X3_AUD PX3"),
342 PINCTRL_PIN(TEGRA_PIN_GPIO_X4_AUD_PX4, "GPIO_X4_AUD PX4"),
343 PINCTRL_PIN(TEGRA_PIN_GPIO_X5_AUD_PX5, "GPIO_X5_AUD PX5"),
344 PINCTRL_PIN(TEGRA_PIN_GPIO_X6_AUD_PX6, "GPIO_X6_AUD PX6"),
345 PINCTRL_PIN(TEGRA_PIN_GPIO_X7_AUD_PX7, "GPIO_X7_AUD PX7"),
346 PINCTRL_PIN(TEGRA_PIN_ULPI_CLK_PY0, "ULPI_CLK PY0"),
347 PINCTRL_PIN(TEGRA_PIN_ULPI_DIR_PY1, "ULPI_DIR PY1"),
348 PINCTRL_PIN(TEGRA_PIN_ULPI_NXT_PY2, "ULPI_NXT PY2"),
349 PINCTRL_PIN(TEGRA_PIN_ULPI_STP_PY3, "ULPI_STP PY3"),
350 PINCTRL_PIN(TEGRA_PIN_SDMMC1_DAT3_PY4, "SDMMC1_DAT3 PY4"),
351 PINCTRL_PIN(TEGRA_PIN_SDMMC1_DAT2_PY5, "SDMMC1_DAT2 PY5"),
352 PINCTRL_PIN(TEGRA_PIN_SDMMC1_DAT1_PY6, "SDMMC1_DAT1 PY6"),
353 PINCTRL_PIN(TEGRA_PIN_SDMMC1_DAT0_PY7, "SDMMC1_DAT0 PY7"),
354 PINCTRL_PIN(TEGRA_PIN_SDMMC1_CLK_PZ0, "SDMMC1_CLK PZ0"),
355 PINCTRL_PIN(TEGRA_PIN_SDMMC1_CMD_PZ1, "SDMMC1_CMD PZ1"),
356 PINCTRL_PIN(TEGRA_PIN_SYS_CLK_REQ_PZ5, "SYS_CLK_REQ PZ5"),
357 PINCTRL_PIN(TEGRA_PIN_PWR_I2C_SCL_PZ6, "PWR_I2C_SCL PZ6"),
358 PINCTRL_PIN(TEGRA_PIN_PWR_I2C_SDA_PZ7, "PWR_I2C_SDA PZ7"),
359 PINCTRL_PIN(TEGRA_PIN_SDMMC4_DAT0_PAA0, "SDMMC4_DAT0 PAA0"),
360 PINCTRL_PIN(TEGRA_PIN_SDMMC4_DAT1_PAA1, "SDMMC4_DAT1 PAA1"),
361 PINCTRL_PIN(TEGRA_PIN_SDMMC4_DAT2_PAA2, "SDMMC4_DAT2 PAA2"),
362 PINCTRL_PIN(TEGRA_PIN_SDMMC4_DAT3_PAA3, "SDMMC4_DAT3 PAA3"),
363 PINCTRL_PIN(TEGRA_PIN_SDMMC4_DAT4_PAA4, "SDMMC4_DAT4 PAA4"),
364 PINCTRL_PIN(TEGRA_PIN_SDMMC4_DAT5_PAA5, "SDMMC4_DAT5 PAA5"),
365 PINCTRL_PIN(TEGRA_PIN_SDMMC4_DAT6_PAA6, "SDMMC4_DAT6 PAA6"),
366 PINCTRL_PIN(TEGRA_PIN_SDMMC4_DAT7_PAA7, "SDMMC4_DAT7 PAA7"),
367 PINCTRL_PIN(TEGRA_PIN_PBB0, "PBB0"),
368 PINCTRL_PIN(TEGRA_PIN_CAM_I2C_SCL_PBB1, "CAM_I2C_SCL PBB1"),
369 PINCTRL_PIN(TEGRA_PIN_CAM_I2C_SDA_PBB2, "CAM_I2C_SDA PBB2"),
370 PINCTRL_PIN(TEGRA_PIN_PBB3, "PBB3"),
371 PINCTRL_PIN(TEGRA_PIN_PBB4, "PBB4"),
372 PINCTRL_PIN(TEGRA_PIN_PBB5, "PBB5"),
373 PINCTRL_PIN(TEGRA_PIN_PBB6, "PBB6"),
374 PINCTRL_PIN(TEGRA_PIN_PBB7, "PBB7"),
375 PINCTRL_PIN(TEGRA_PIN_CAM_MCLK_PCC0, "CAM_MCLK PCC0"),
376 PINCTRL_PIN(TEGRA_PIN_PCC1, "PCC1"),
377 PINCTRL_PIN(TEGRA_PIN_PCC2, "PCC2"),
378 PINCTRL_PIN(TEGRA_PIN_SDMMC4_CLK_PCC4, "SDMMC4_CLK PCC4"),
379 PINCTRL_PIN(TEGRA_PIN_CLK2_REQ_PCC5, "CLK2_REQ PCC5"),
380 PINCTRL_PIN(TEGRA_PIN_CLK3_OUT_PEE0, "CLK3_OUT PEE0"),
381 PINCTRL_PIN(TEGRA_PIN_CLK3_REQ_PEE1, "CLK3_REQ PEE1"),
382 PINCTRL_PIN(TEGRA_PIN_CLK1_REQ_PEE2, "CLK1_REQ PEE2"),
383 PINCTRL_PIN(TEGRA_PIN_HDMI_CEC_PEE3, "HDMI_CEC PEE3"),
384 PINCTRL_PIN(TEGRA_PIN_SDMMC3_CLK_LB_OUT_PEE4, "SDMMC3_CLK_LB_OUT PEE4"),
385 PINCTRL_PIN(TEGRA_PIN_SDMMC3_CLK_LB_IN_PEE5, "SDMMC3_CLK_LB_IN PEE5"),
386 PINCTRL_PIN(TEGRA_PIN_CORE_PWR_REQ, "CORE_PWR_REQ"),
387 PINCTRL_PIN(TEGRA_PIN_CPU_PWR_REQ, "CPU_PWR_REQ"),
388 PINCTRL_PIN(TEGRA_PIN_OWR, "OWR"),
389 PINCTRL_PIN(TEGRA_PIN_PWR_INT_N, "PWR_INT_N"),
390 PINCTRL_PIN(TEGRA_PIN_RESET_OUT_N, "RESET_OUT_N"),
391};
392
393static const unsigned clk_32k_out_pa0_pins[] = {
394 TEGRA_PIN_CLK_32K_OUT_PA0,
395};
396
397static const unsigned uart3_cts_n_pa1_pins[] = {
398 TEGRA_PIN_UART3_CTS_N_PA1,
399};
400
401static const unsigned dap2_fs_pa2_pins[] = {
402 TEGRA_PIN_DAP2_FS_PA2,
403};
404
405static const unsigned dap2_sclk_pa3_pins[] = {
406 TEGRA_PIN_DAP2_SCLK_PA3,
407};
408
409static const unsigned dap2_din_pa4_pins[] = {
410 TEGRA_PIN_DAP2_DIN_PA4,
411};
412
413static const unsigned dap2_dout_pa5_pins[] = {
414 TEGRA_PIN_DAP2_DOUT_PA5,
415};
416
417static const unsigned sdmmc3_clk_pa6_pins[] = {
418 TEGRA_PIN_SDMMC3_CLK_PA6,
419};
420
421static const unsigned sdmmc3_cmd_pa7_pins[] = {
422 TEGRA_PIN_SDMMC3_CMD_PA7,
423};
424
425static const unsigned gmi_a17_pb0_pins[] = {
426 TEGRA_PIN_GMI_A17_PB0,
427};
428
429static const unsigned gmi_a18_pb1_pins[] = {
430 TEGRA_PIN_GMI_A18_PB1,
431};
432
433static const unsigned sdmmc3_dat3_pb4_pins[] = {
434 TEGRA_PIN_SDMMC3_DAT3_PB4,
435};
436
437static const unsigned sdmmc3_dat2_pb5_pins[] = {
438 TEGRA_PIN_SDMMC3_DAT2_PB5,
439};
440
441static const unsigned sdmmc3_dat1_pb6_pins[] = {
442 TEGRA_PIN_SDMMC3_DAT1_PB6,
443};
444
445static const unsigned sdmmc3_dat0_pb7_pins[] = {
446 TEGRA_PIN_SDMMC3_DAT0_PB7,
447};
448
449static const unsigned uart3_rts_n_pc0_pins[] = {
450 TEGRA_PIN_UART3_RTS_N_PC0,
451};
452
453static const unsigned uart2_txd_pc2_pins[] = {
454 TEGRA_PIN_UART2_TXD_PC2,
455};
456
457static const unsigned uart2_rxd_pc3_pins[] = {
458 TEGRA_PIN_UART2_RXD_PC3,
459};
460
461static const unsigned gen1_i2c_scl_pc4_pins[] = {
462 TEGRA_PIN_GEN1_I2C_SCL_PC4,
463};
464
465static const unsigned gen1_i2c_sda_pc5_pins[] = {
466 TEGRA_PIN_GEN1_I2C_SDA_PC5,
467};
468
469static const unsigned gmi_wp_n_pc7_pins[] = {
470 TEGRA_PIN_GMI_WP_N_PC7,
471};
472
473static const unsigned gmi_ad0_pg0_pins[] = {
474 TEGRA_PIN_GMI_AD0_PG0,
475};
476
477static const unsigned gmi_ad1_pg1_pins[] = {
478 TEGRA_PIN_GMI_AD1_PG1,
479};
480
481static const unsigned gmi_ad2_pg2_pins[] = {
482 TEGRA_PIN_GMI_AD2_PG2,
483};
484
485static const unsigned gmi_ad3_pg3_pins[] = {
486 TEGRA_PIN_GMI_AD3_PG3,
487};
488
489static const unsigned gmi_ad4_pg4_pins[] = {
490 TEGRA_PIN_GMI_AD4_PG4,
491};
492
493static const unsigned gmi_ad5_pg5_pins[] = {
494 TEGRA_PIN_GMI_AD5_PG5,
495};
496
497static const unsigned gmi_ad6_pg6_pins[] = {
498 TEGRA_PIN_GMI_AD6_PG6,
499};
500
501static const unsigned gmi_ad7_pg7_pins[] = {
502 TEGRA_PIN_GMI_AD7_PG7,
503};
504
505static const unsigned gmi_ad8_ph0_pins[] = {
506 TEGRA_PIN_GMI_AD8_PH0,
507};
508
509static const unsigned gmi_ad9_ph1_pins[] = {
510 TEGRA_PIN_GMI_AD9_PH1,
511};
512
513static const unsigned gmi_ad10_ph2_pins[] = {
514 TEGRA_PIN_GMI_AD10_PH2,
515};
516
517static const unsigned gmi_ad11_ph3_pins[] = {
518 TEGRA_PIN_GMI_AD11_PH3,
519};
520
521static const unsigned gmi_ad12_ph4_pins[] = {
522 TEGRA_PIN_GMI_AD12_PH4,
523};
524
525static const unsigned gmi_ad13_ph5_pins[] = {
526 TEGRA_PIN_GMI_AD13_PH5,
527};
528
529static const unsigned gmi_ad14_ph6_pins[] = {
530 TEGRA_PIN_GMI_AD14_PH6,
531};
532
533static const unsigned gmi_ad15_ph7_pins[] = {
534 TEGRA_PIN_GMI_AD15_PH7,
535};
536
537static const unsigned gmi_wr_n_pi0_pins[] = {
538 TEGRA_PIN_GMI_WR_N_PI0,
539};
540
541static const unsigned gmi_oe_n_pi1_pins[] = {
542 TEGRA_PIN_GMI_OE_N_PI1,
543};
544
545static const unsigned gmi_cs6_n_pi3_pins[] = {
546 TEGRA_PIN_GMI_CS6_N_PI3,
547};
548
549static const unsigned gmi_rst_n_pi4_pins[] = {
550 TEGRA_PIN_GMI_RST_N_PI4,
551};
552
553static const unsigned gmi_iordy_pi5_pins[] = {
554 TEGRA_PIN_GMI_IORDY_PI5,
555};
556
557static const unsigned gmi_cs7_n_pi6_pins[] = {
558 TEGRA_PIN_GMI_CS7_N_PI6,
559};
560
561static const unsigned gmi_wait_pi7_pins[] = {
562 TEGRA_PIN_GMI_WAIT_PI7,
563};
564
565static const unsigned gmi_cs0_n_pj0_pins[] = {
566 TEGRA_PIN_GMI_CS0_N_PJ0,
567};
568
569static const unsigned gmi_cs1_n_pj2_pins[] = {
570 TEGRA_PIN_GMI_CS1_N_PJ2,
571};
572
573static const unsigned gmi_dqs_p_pj3_pins[] = {
574 TEGRA_PIN_GMI_DQS_P_PJ3,
575};
576
577static const unsigned uart2_cts_n_pj5_pins[] = {
578 TEGRA_PIN_UART2_CTS_N_PJ5,
579};
580
581static const unsigned uart2_rts_n_pj6_pins[] = {
582 TEGRA_PIN_UART2_RTS_N_PJ6,
583};
584
585static const unsigned gmi_a16_pj7_pins[] = {
586 TEGRA_PIN_GMI_A16_PJ7,
587};
588
589static const unsigned gmi_adv_n_pk0_pins[] = {
590 TEGRA_PIN_GMI_ADV_N_PK0,
591};
592
593static const unsigned gmi_clk_pk1_pins[] = {
594 TEGRA_PIN_GMI_CLK_PK1,
595};
596
597static const unsigned gmi_cs4_n_pk2_pins[] = {
598 TEGRA_PIN_GMI_CS4_N_PK2,
599};
600
601static const unsigned gmi_cs2_n_pk3_pins[] = {
602 TEGRA_PIN_GMI_CS2_N_PK3,
603};
604
605static const unsigned gmi_cs3_n_pk4_pins[] = {
606 TEGRA_PIN_GMI_CS3_N_PK4,
607};
608
609static const unsigned spdif_out_pk5_pins[] = {
610 TEGRA_PIN_SPDIF_OUT_PK5,
611};
612
613static const unsigned spdif_in_pk6_pins[] = {
614 TEGRA_PIN_SPDIF_IN_PK6,
615};
616
617static const unsigned gmi_a19_pk7_pins[] = {
618 TEGRA_PIN_GMI_A19_PK7,
619};
620
621static const unsigned dap1_fs_pn0_pins[] = {
622 TEGRA_PIN_DAP1_FS_PN0,
623};
624
625static const unsigned dap1_din_pn1_pins[] = {
626 TEGRA_PIN_DAP1_DIN_PN1,
627};
628
629static const unsigned dap1_dout_pn2_pins[] = {
630 TEGRA_PIN_DAP1_DOUT_PN2,
631};
632
633static const unsigned dap1_sclk_pn3_pins[] = {
634 TEGRA_PIN_DAP1_SCLK_PN3,
635};
636
637static const unsigned usb_vbus_en0_pn4_pins[] = {
638 TEGRA_PIN_USB_VBUS_EN0_PN4,
639};
640
641static const unsigned usb_vbus_en1_pn5_pins[] = {
642 TEGRA_PIN_USB_VBUS_EN1_PN5,
643};
644
645static const unsigned hdmi_int_pn7_pins[] = {
646 TEGRA_PIN_HDMI_INT_PN7,
647};
648
649static const unsigned ulpi_data7_po0_pins[] = {
650 TEGRA_PIN_ULPI_DATA7_PO0,
651};
652
653static const unsigned ulpi_data0_po1_pins[] = {
654 TEGRA_PIN_ULPI_DATA0_PO1,
655};
656
657static const unsigned ulpi_data1_po2_pins[] = {
658 TEGRA_PIN_ULPI_DATA1_PO2,
659};
660
661static const unsigned ulpi_data2_po3_pins[] = {
662 TEGRA_PIN_ULPI_DATA2_PO3,
663};
664
665static const unsigned ulpi_data3_po4_pins[] = {
666 TEGRA_PIN_ULPI_DATA3_PO4,
667};
668
669static const unsigned ulpi_data4_po5_pins[] = {
670 TEGRA_PIN_ULPI_DATA4_PO5,
671};
672
673static const unsigned ulpi_data5_po6_pins[] = {
674 TEGRA_PIN_ULPI_DATA5_PO6,
675};
676
677static const unsigned ulpi_data6_po7_pins[] = {
678 TEGRA_PIN_ULPI_DATA6_PO7,
679};
680
681static const unsigned dap3_fs_pp0_pins[] = {
682 TEGRA_PIN_DAP3_FS_PP0,
683};
684
685static const unsigned dap3_din_pp1_pins[] = {
686 TEGRA_PIN_DAP3_DIN_PP1,
687};
688
689static const unsigned dap3_dout_pp2_pins[] = {
690 TEGRA_PIN_DAP3_DOUT_PP2,
691};
692
693static const unsigned dap3_sclk_pp3_pins[] = {
694 TEGRA_PIN_DAP3_SCLK_PP3,
695};
696
697static const unsigned dap4_fs_pp4_pins[] = {
698 TEGRA_PIN_DAP4_FS_PP4,
699};
700
701static const unsigned dap4_din_pp5_pins[] = {
702 TEGRA_PIN_DAP4_DIN_PP5,
703};
704
705static const unsigned dap4_dout_pp6_pins[] = {
706 TEGRA_PIN_DAP4_DOUT_PP6,
707};
708
709static const unsigned dap4_sclk_pp7_pins[] = {
710 TEGRA_PIN_DAP4_SCLK_PP7,
711};
712
713static const unsigned kb_col0_pq0_pins[] = {
714 TEGRA_PIN_KB_COL0_PQ0,
715};
716
717static const unsigned kb_col1_pq1_pins[] = {
718 TEGRA_PIN_KB_COL1_PQ1,
719};
720
721static const unsigned kb_col2_pq2_pins[] = {
722 TEGRA_PIN_KB_COL2_PQ2,
723};
724
725static const unsigned kb_col3_pq3_pins[] = {
726 TEGRA_PIN_KB_COL3_PQ3,
727};
728
729static const unsigned kb_col4_pq4_pins[] = {
730 TEGRA_PIN_KB_COL4_PQ4,
731};
732
733static const unsigned kb_col5_pq5_pins[] = {
734 TEGRA_PIN_KB_COL5_PQ5,
735};
736
737static const unsigned kb_col6_pq6_pins[] = {
738 TEGRA_PIN_KB_COL6_PQ6,
739};
740
741static const unsigned kb_col7_pq7_pins[] = {
742 TEGRA_PIN_KB_COL7_PQ7,
743};
744
745static const unsigned kb_row0_pr0_pins[] = {
746 TEGRA_PIN_KB_ROW0_PR0,
747};
748
749static const unsigned kb_row1_pr1_pins[] = {
750 TEGRA_PIN_KB_ROW1_PR1,
751};
752
753static const unsigned kb_row2_pr2_pins[] = {
754 TEGRA_PIN_KB_ROW2_PR2,
755};
756
757static const unsigned kb_row3_pr3_pins[] = {
758 TEGRA_PIN_KB_ROW3_PR3,
759};
760
761static const unsigned kb_row4_pr4_pins[] = {
762 TEGRA_PIN_KB_ROW4_PR4,
763};
764
765static const unsigned kb_row5_pr5_pins[] = {
766 TEGRA_PIN_KB_ROW5_PR5,
767};
768
769static const unsigned kb_row6_pr6_pins[] = {
770 TEGRA_PIN_KB_ROW6_PR6,
771};
772
773static const unsigned kb_row7_pr7_pins[] = {
774 TEGRA_PIN_KB_ROW7_PR7,
775};
776
777static const unsigned kb_row8_ps0_pins[] = {
778 TEGRA_PIN_KB_ROW8_PS0,
779};
780
781static const unsigned kb_row9_ps1_pins[] = {
782 TEGRA_PIN_KB_ROW9_PS1,
783};
784
785static const unsigned kb_row10_ps2_pins[] = {
786 TEGRA_PIN_KB_ROW10_PS2,
787};
788
789static const unsigned gen2_i2c_scl_pt5_pins[] = {
790 TEGRA_PIN_GEN2_I2C_SCL_PT5,
791};
792
793static const unsigned gen2_i2c_sda_pt6_pins[] = {
794 TEGRA_PIN_GEN2_I2C_SDA_PT6,
795};
796
797static const unsigned sdmmc4_cmd_pt7_pins[] = {
798 TEGRA_PIN_SDMMC4_CMD_PT7,
799};
800
801static const unsigned pu0_pins[] = {
802 TEGRA_PIN_PU0,
803};
804
805static const unsigned pu1_pins[] = {
806 TEGRA_PIN_PU1,
807};
808
809static const unsigned pu2_pins[] = {
810 TEGRA_PIN_PU2,
811};
812
813static const unsigned pu3_pins[] = {
814 TEGRA_PIN_PU3,
815};
816
817static const unsigned pu4_pins[] = {
818 TEGRA_PIN_PU4,
819};
820
821static const unsigned pu5_pins[] = {
822 TEGRA_PIN_PU5,
823};
824
825static const unsigned pu6_pins[] = {
826 TEGRA_PIN_PU6,
827};
828
829static const unsigned pv0_pins[] = {
830 TEGRA_PIN_PV0,
831};
832
833static const unsigned pv1_pins[] = {
834 TEGRA_PIN_PV1,
835};
836
837static const unsigned sdmmc3_cd_n_pv2_pins[] = {
838 TEGRA_PIN_SDMMC3_CD_N_PV2,
839};
840
841static const unsigned sdmmc1_wp_n_pv3_pins[] = {
842 TEGRA_PIN_SDMMC1_WP_N_PV3,
843};
844
845static const unsigned ddc_scl_pv4_pins[] = {
846 TEGRA_PIN_DDC_SCL_PV4,
847};
848
849static const unsigned ddc_sda_pv5_pins[] = {
850 TEGRA_PIN_DDC_SDA_PV5,
851};
852
853static const unsigned gpio_w2_aud_pw2_pins[] = {
854 TEGRA_PIN_GPIO_W2_AUD_PW2,
855};
856
857static const unsigned gpio_w3_aud_pw3_pins[] = {
858 TEGRA_PIN_GPIO_W3_AUD_PW3,
859};
860
861static const unsigned clk1_out_pw4_pins[] = {
862 TEGRA_PIN_CLK1_OUT_PW4,
863};
864
865static const unsigned clk2_out_pw5_pins[] = {
866 TEGRA_PIN_CLK2_OUT_PW5,
867};
868
869static const unsigned uart3_txd_pw6_pins[] = {
870 TEGRA_PIN_UART3_TXD_PW6,
871};
872
873static const unsigned uart3_rxd_pw7_pins[] = {
874 TEGRA_PIN_UART3_RXD_PW7,
875};
876
877static const unsigned dvfs_pwm_px0_pins[] = {
878 TEGRA_PIN_DVFS_PWM_PX0,
879};
880
881static const unsigned gpio_x1_aud_px1_pins[] = {
882 TEGRA_PIN_GPIO_X1_AUD_PX1,
883};
884
885static const unsigned dvfs_clk_px2_pins[] = {
886 TEGRA_PIN_DVFS_CLK_PX2,
887};
888
889static const unsigned gpio_x3_aud_px3_pins[] = {
890 TEGRA_PIN_GPIO_X3_AUD_PX3,
891};
892
893static const unsigned gpio_x4_aud_px4_pins[] = {
894 TEGRA_PIN_GPIO_X4_AUD_PX4,
895};
896
897static const unsigned gpio_x5_aud_px5_pins[] = {
898 TEGRA_PIN_GPIO_X5_AUD_PX5,
899};
900
901static const unsigned gpio_x6_aud_px6_pins[] = {
902 TEGRA_PIN_GPIO_X6_AUD_PX6,
903};
904
905static const unsigned gpio_x7_aud_px7_pins[] = {
906 TEGRA_PIN_GPIO_X7_AUD_PX7,
907};
908
909static const unsigned ulpi_clk_py0_pins[] = {
910 TEGRA_PIN_ULPI_CLK_PY0,
911};
912
913static const unsigned ulpi_dir_py1_pins[] = {
914 TEGRA_PIN_ULPI_DIR_PY1,
915};
916
917static const unsigned ulpi_nxt_py2_pins[] = {
918 TEGRA_PIN_ULPI_NXT_PY2,
919};
920
921static const unsigned ulpi_stp_py3_pins[] = {
922 TEGRA_PIN_ULPI_STP_PY3,
923};
924
925static const unsigned sdmmc1_dat3_py4_pins[] = {
926 TEGRA_PIN_SDMMC1_DAT3_PY4,
927};
928
929static const unsigned sdmmc1_dat2_py5_pins[] = {
930 TEGRA_PIN_SDMMC1_DAT2_PY5,
931};
932
933static const unsigned sdmmc1_dat1_py6_pins[] = {
934 TEGRA_PIN_SDMMC1_DAT1_PY6,
935};
936
937static const unsigned sdmmc1_dat0_py7_pins[] = {
938 TEGRA_PIN_SDMMC1_DAT0_PY7,
939};
940
941static const unsigned sdmmc1_clk_pz0_pins[] = {
942 TEGRA_PIN_SDMMC1_CLK_PZ0,
943};
944
945static const unsigned sdmmc1_cmd_pz1_pins[] = {
946 TEGRA_PIN_SDMMC1_CMD_PZ1,
947};
948
949static const unsigned sys_clk_req_pz5_pins[] = {
950 TEGRA_PIN_SYS_CLK_REQ_PZ5,
951};
952
953static const unsigned pwr_i2c_scl_pz6_pins[] = {
954 TEGRA_PIN_PWR_I2C_SCL_PZ6,
955};
956
957static const unsigned pwr_i2c_sda_pz7_pins[] = {
958 TEGRA_PIN_PWR_I2C_SDA_PZ7,
959};
960
961static const unsigned sdmmc4_dat0_paa0_pins[] = {
962 TEGRA_PIN_SDMMC4_DAT0_PAA0,
963};
964
965static const unsigned sdmmc4_dat1_paa1_pins[] = {
966 TEGRA_PIN_SDMMC4_DAT1_PAA1,
967};
968
969static const unsigned sdmmc4_dat2_paa2_pins[] = {
970 TEGRA_PIN_SDMMC4_DAT2_PAA2,
971};
972
973static const unsigned sdmmc4_dat3_paa3_pins[] = {
974 TEGRA_PIN_SDMMC4_DAT3_PAA3,
975};
976
977static const unsigned sdmmc4_dat4_paa4_pins[] = {
978 TEGRA_PIN_SDMMC4_DAT4_PAA4,
979};
980
981static const unsigned sdmmc4_dat5_paa5_pins[] = {
982 TEGRA_PIN_SDMMC4_DAT5_PAA5,
983};
984
985static const unsigned sdmmc4_dat6_paa6_pins[] = {
986 TEGRA_PIN_SDMMC4_DAT6_PAA6,
987};
988
989static const unsigned sdmmc4_dat7_paa7_pins[] = {
990 TEGRA_PIN_SDMMC4_DAT7_PAA7,
991};
992
993static const unsigned pbb0_pins[] = {
994 TEGRA_PIN_PBB0,
995};
996
997static const unsigned cam_i2c_scl_pbb1_pins[] = {
998 TEGRA_PIN_CAM_I2C_SCL_PBB1,
999};
1000
1001static const unsigned cam_i2c_sda_pbb2_pins[] = {
1002 TEGRA_PIN_CAM_I2C_SDA_PBB2,
1003};
1004
1005static const unsigned pbb3_pins[] = {
1006 TEGRA_PIN_PBB3,
1007};
1008
1009static const unsigned pbb4_pins[] = {
1010 TEGRA_PIN_PBB4,
1011};
1012
1013static const unsigned pbb5_pins[] = {
1014 TEGRA_PIN_PBB5,
1015};
1016
1017static const unsigned pbb6_pins[] = {
1018 TEGRA_PIN_PBB6,
1019};
1020
1021static const unsigned pbb7_pins[] = {
1022 TEGRA_PIN_PBB7,
1023};
1024
1025static const unsigned cam_mclk_pcc0_pins[] = {
1026 TEGRA_PIN_CAM_MCLK_PCC0,
1027};
1028
1029static const unsigned pcc1_pins[] = {
1030 TEGRA_PIN_PCC1,
1031};
1032
1033static const unsigned pcc2_pins[] = {
1034 TEGRA_PIN_PCC2,
1035};
1036
1037static const unsigned sdmmc4_clk_pcc4_pins[] = {
1038 TEGRA_PIN_SDMMC4_CLK_PCC4,
1039};
1040
1041static const unsigned clk2_req_pcc5_pins[] = {
1042 TEGRA_PIN_CLK2_REQ_PCC5,
1043};
1044
1045static const unsigned clk3_out_pee0_pins[] = {
1046 TEGRA_PIN_CLK3_OUT_PEE0,
1047};
1048
1049static const unsigned clk3_req_pee1_pins[] = {
1050 TEGRA_PIN_CLK3_REQ_PEE1,
1051};
1052
1053static const unsigned clk1_req_pee2_pins[] = {
1054 TEGRA_PIN_CLK1_REQ_PEE2,
1055};
1056
1057static const unsigned hdmi_cec_pee3_pins[] = {
1058 TEGRA_PIN_HDMI_CEC_PEE3,
1059};
1060
1061static const unsigned sdmmc3_clk_lb_out_pee4_pins[] = {
1062 TEGRA_PIN_SDMMC3_CLK_LB_OUT_PEE4,
1063};
1064
1065static const unsigned sdmmc3_clk_lb_in_pee5_pins[] = {
1066 TEGRA_PIN_SDMMC3_CLK_LB_IN_PEE5,
1067};
1068
1069static const unsigned core_pwr_req_pins[] = {
1070 TEGRA_PIN_CORE_PWR_REQ,
1071};
1072
1073static const unsigned cpu_pwr_req_pins[] = {
1074 TEGRA_PIN_CPU_PWR_REQ,
1075};
1076
1077static const unsigned owr_pins[] = {
1078 TEGRA_PIN_OWR,
1079};
1080
1081static const unsigned pwr_int_n_pins[] = {
1082 TEGRA_PIN_PWR_INT_N,
1083};
1084
1085static const unsigned reset_out_n_pins[] = {
1086 TEGRA_PIN_RESET_OUT_N,
1087};
1088
1089static const unsigned drive_ao1_pins[] = {
1090 TEGRA_PIN_KB_ROW0_PR0,
1091 TEGRA_PIN_KB_ROW1_PR1,
1092 TEGRA_PIN_KB_ROW2_PR2,
1093 TEGRA_PIN_KB_ROW3_PR3,
1094 TEGRA_PIN_KB_ROW4_PR4,
1095 TEGRA_PIN_KB_ROW5_PR5,
1096 TEGRA_PIN_KB_ROW6_PR6,
1097 TEGRA_PIN_KB_ROW7_PR7,
1098 TEGRA_PIN_PWR_I2C_SCL_PZ6,
1099 TEGRA_PIN_PWR_I2C_SDA_PZ7,
1100};
1101
1102static const unsigned drive_ao2_pins[] = {
1103 TEGRA_PIN_CLK_32K_OUT_PA0,
1104 TEGRA_PIN_KB_COL0_PQ0,
1105 TEGRA_PIN_KB_COL1_PQ1,
1106 TEGRA_PIN_KB_COL2_PQ2,
1107 TEGRA_PIN_KB_COL3_PQ3,
1108 TEGRA_PIN_KB_COL4_PQ4,
1109 TEGRA_PIN_KB_COL5_PQ5,
1110 TEGRA_PIN_KB_COL6_PQ6,
1111 TEGRA_PIN_KB_COL7_PQ7,
1112 TEGRA_PIN_KB_ROW8_PS0,
1113 TEGRA_PIN_KB_ROW9_PS1,
1114 TEGRA_PIN_KB_ROW10_PS2,
1115 TEGRA_PIN_SYS_CLK_REQ_PZ5,
1116 TEGRA_PIN_CORE_PWR_REQ,
1117 TEGRA_PIN_CPU_PWR_REQ,
1118 TEGRA_PIN_RESET_OUT_N,
1119};
1120
1121static const unsigned drive_at1_pins[] = {
1122 TEGRA_PIN_GMI_AD8_PH0,
1123 TEGRA_PIN_GMI_AD9_PH1,
1124 TEGRA_PIN_GMI_AD10_PH2,
1125 TEGRA_PIN_GMI_AD11_PH3,
1126 TEGRA_PIN_GMI_AD12_PH4,
1127 TEGRA_PIN_GMI_AD13_PH5,
1128 TEGRA_PIN_GMI_AD14_PH6,
1129 TEGRA_PIN_GMI_AD15_PH7,
1130
1131 TEGRA_PIN_GMI_IORDY_PI5,
1132 TEGRA_PIN_GMI_CS7_N_PI6,
1133};
1134
1135static const unsigned drive_at2_pins[] = {
1136 TEGRA_PIN_GMI_AD0_PG0,
1137 TEGRA_PIN_GMI_AD1_PG1,
1138 TEGRA_PIN_GMI_AD2_PG2,
1139 TEGRA_PIN_GMI_AD3_PG3,
1140 TEGRA_PIN_GMI_AD4_PG4,
1141 TEGRA_PIN_GMI_AD5_PG5,
1142 TEGRA_PIN_GMI_AD6_PG6,
1143 TEGRA_PIN_GMI_AD7_PG7,
1144
1145 TEGRA_PIN_GMI_WR_N_PI0,
1146 TEGRA_PIN_GMI_OE_N_PI1,
1147 TEGRA_PIN_GMI_CS6_N_PI3,
1148 TEGRA_PIN_GMI_RST_N_PI4,
1149 TEGRA_PIN_GMI_WAIT_PI7,
1150
1151 TEGRA_PIN_GMI_DQS_P_PJ3,
1152
1153 TEGRA_PIN_GMI_ADV_N_PK0,
1154 TEGRA_PIN_GMI_CLK_PK1,
1155 TEGRA_PIN_GMI_CS4_N_PK2,
1156 TEGRA_PIN_GMI_CS2_N_PK3,
1157 TEGRA_PIN_GMI_CS3_N_PK4,
1158};
1159
1160static const unsigned drive_at3_pins[] = {
1161 TEGRA_PIN_GMI_WP_N_PC7,
1162 TEGRA_PIN_GMI_CS0_N_PJ0,
1163};
1164
1165static const unsigned drive_at4_pins[] = {
1166 TEGRA_PIN_GMI_A17_PB0,
1167 TEGRA_PIN_GMI_A18_PB1,
1168 TEGRA_PIN_GMI_CS1_N_PJ2,
1169 TEGRA_PIN_GMI_A16_PJ7,
1170 TEGRA_PIN_GMI_A19_PK7,
1171};
1172
1173static const unsigned drive_at5_pins[] = {
1174 TEGRA_PIN_GEN2_I2C_SCL_PT5,
1175 TEGRA_PIN_GEN2_I2C_SDA_PT6,
1176};
1177
1178static const unsigned drive_cdev1_pins[] = {
1179 TEGRA_PIN_CLK1_OUT_PW4,
1180 TEGRA_PIN_CLK1_REQ_PEE2,
1181};
1182
1183static const unsigned drive_cdev2_pins[] = {
1184 TEGRA_PIN_CLK2_OUT_PW5,
1185 TEGRA_PIN_CLK2_REQ_PCC5,
1186 TEGRA_PIN_SDMMC1_WP_N_PV3,
1187};
1188
1189static const unsigned drive_dap1_pins[] = {
1190 TEGRA_PIN_DAP1_FS_PN0,
1191 TEGRA_PIN_DAP1_DIN_PN1,
1192 TEGRA_PIN_DAP1_DOUT_PN2,
1193 TEGRA_PIN_DAP1_SCLK_PN3,
1194};
1195
1196static const unsigned drive_dap2_pins[] = {
1197 TEGRA_PIN_DAP2_FS_PA2,
1198 TEGRA_PIN_DAP2_SCLK_PA3,
1199 TEGRA_PIN_DAP2_DIN_PA4,
1200 TEGRA_PIN_DAP2_DOUT_PA5,
1201};
1202
1203static const unsigned drive_dap3_pins[] = {
1204 TEGRA_PIN_DAP3_FS_PP0,
1205 TEGRA_PIN_DAP3_DIN_PP1,
1206 TEGRA_PIN_DAP3_DOUT_PP2,
1207 TEGRA_PIN_DAP3_SCLK_PP3,
1208};
1209
1210static const unsigned drive_dap4_pins[] = {
1211 TEGRA_PIN_DAP4_FS_PP4,
1212 TEGRA_PIN_DAP4_DIN_PP5,
1213 TEGRA_PIN_DAP4_DOUT_PP6,
1214 TEGRA_PIN_DAP4_SCLK_PP7,
1215};
1216
1217static const unsigned drive_dbg_pins[] = {
1218 TEGRA_PIN_GEN1_I2C_SCL_PC4,
1219 TEGRA_PIN_GEN1_I2C_SDA_PC5,
1220 TEGRA_PIN_PU0,
1221 TEGRA_PIN_PU1,
1222 TEGRA_PIN_PU2,
1223 TEGRA_PIN_PU3,
1224 TEGRA_PIN_PU4,
1225 TEGRA_PIN_PU5,
1226 TEGRA_PIN_PU6,
1227};
1228
1229static const unsigned drive_sdio3_pins[] = {
1230 TEGRA_PIN_SDMMC3_CLK_PA6,
1231 TEGRA_PIN_SDMMC3_CMD_PA7,
1232 TEGRA_PIN_SDMMC3_DAT3_PB4,
1233 TEGRA_PIN_SDMMC3_DAT2_PB5,
1234 TEGRA_PIN_SDMMC3_DAT1_PB6,
1235 TEGRA_PIN_SDMMC3_DAT0_PB7,
1236 TEGRA_PIN_SDMMC3_CLK_LB_OUT_PEE4,
1237 TEGRA_PIN_SDMMC3_CLK_LB_IN_PEE5,
1238};
1239
1240static const unsigned drive_spi_pins[] = {
1241 TEGRA_PIN_DVFS_PWM_PX0,
1242 TEGRA_PIN_GPIO_X1_AUD_PX1,
1243 TEGRA_PIN_DVFS_CLK_PX2,
1244 TEGRA_PIN_GPIO_X3_AUD_PX3,
1245 TEGRA_PIN_GPIO_X4_AUD_PX4,
1246 TEGRA_PIN_GPIO_X5_AUD_PX5,
1247 TEGRA_PIN_GPIO_X6_AUD_PX6,
1248 TEGRA_PIN_GPIO_X7_AUD_PX7,
1249 TEGRA_PIN_GPIO_W2_AUD_PW2,
1250 TEGRA_PIN_GPIO_W3_AUD_PW3,
1251};
1252
1253static const unsigned drive_uaa_pins[] = {
1254 TEGRA_PIN_ULPI_DATA0_PO1,
1255 TEGRA_PIN_ULPI_DATA1_PO2,
1256 TEGRA_PIN_ULPI_DATA2_PO3,
1257 TEGRA_PIN_ULPI_DATA3_PO4,
1258};
1259
1260static const unsigned drive_uab_pins[] = {
1261 TEGRA_PIN_ULPI_DATA7_PO0,
1262 TEGRA_PIN_ULPI_DATA4_PO5,
1263 TEGRA_PIN_ULPI_DATA5_PO6,
1264 TEGRA_PIN_ULPI_DATA6_PO7,
1265 TEGRA_PIN_PV0,
1266 TEGRA_PIN_PV1,
1267};
1268
1269static const unsigned drive_uart2_pins[] = {
1270 TEGRA_PIN_UART2_TXD_PC2,
1271 TEGRA_PIN_UART2_RXD_PC3,
1272 TEGRA_PIN_UART2_CTS_N_PJ5,
1273 TEGRA_PIN_UART2_RTS_N_PJ6,
1274};
1275
1276static const unsigned drive_uart3_pins[] = {
1277 TEGRA_PIN_UART3_CTS_N_PA1,
1278 TEGRA_PIN_UART3_RTS_N_PC0,
1279 TEGRA_PIN_UART3_TXD_PW6,
1280 TEGRA_PIN_UART3_RXD_PW7,
1281};
1282
1283static const unsigned drive_sdio1_pins[] = {
1284 TEGRA_PIN_SDMMC1_DAT3_PY4,
1285 TEGRA_PIN_SDMMC1_DAT2_PY5,
1286 TEGRA_PIN_SDMMC1_DAT1_PY6,
1287 TEGRA_PIN_SDMMC1_DAT0_PY7,
1288 TEGRA_PIN_SDMMC1_CLK_PZ0,
1289 TEGRA_PIN_SDMMC1_CMD_PZ1,
1290};
1291
1292static const unsigned drive_ddc_pins[] = {
1293 TEGRA_PIN_DDC_SCL_PV4,
1294 TEGRA_PIN_DDC_SDA_PV5,
1295};
1296
1297static const unsigned drive_gma_pins[] = {
1298 TEGRA_PIN_SDMMC4_CLK_PCC4,
1299 TEGRA_PIN_SDMMC4_CMD_PT7,
1300 TEGRA_PIN_SDMMC4_DAT0_PAA0,
1301 TEGRA_PIN_SDMMC4_DAT1_PAA1,
1302 TEGRA_PIN_SDMMC4_DAT2_PAA2,
1303 TEGRA_PIN_SDMMC4_DAT3_PAA3,
1304 TEGRA_PIN_SDMMC4_DAT4_PAA4,
1305 TEGRA_PIN_SDMMC4_DAT5_PAA5,
1306 TEGRA_PIN_SDMMC4_DAT6_PAA6,
1307 TEGRA_PIN_SDMMC4_DAT7_PAA7,
1308};
1309
1310static const unsigned drive_gme_pins[] = {
1311 TEGRA_PIN_PBB0,
1312 TEGRA_PIN_CAM_I2C_SCL_PBB1,
1313 TEGRA_PIN_CAM_I2C_SDA_PBB2,
1314 TEGRA_PIN_PBB3,
1315 TEGRA_PIN_PCC2,
1316};
1317
1318static const unsigned drive_gmf_pins[] = {
1319 TEGRA_PIN_PBB4,
1320 TEGRA_PIN_PBB5,
1321 TEGRA_PIN_PBB6,
1322 TEGRA_PIN_PBB7,
1323};
1324
1325static const unsigned drive_gmg_pins[] = {
1326 TEGRA_PIN_CAM_MCLK_PCC0,
1327};
1328
1329static const unsigned drive_gmh_pins[] = {
1330 TEGRA_PIN_PCC1,
1331};
1332
1333static const unsigned drive_owr_pins[] = {
1334 TEGRA_PIN_SDMMC3_CD_N_PV2,
1335};
1336
1337static const unsigned drive_uda_pins[] = {
1338 TEGRA_PIN_ULPI_CLK_PY0,
1339 TEGRA_PIN_ULPI_DIR_PY1,
1340 TEGRA_PIN_ULPI_NXT_PY2,
1341 TEGRA_PIN_ULPI_STP_PY3,
1342};
1343
1344static const unsigned drive_dev3_pins[] = {
1345 TEGRA_PIN_CLK3_OUT_PEE0,
1346 TEGRA_PIN_CLK3_REQ_PEE1,
1347};
1348
1349enum tegra_mux {
1350 TEGRA_MUX_BLINK,
1351 TEGRA_MUX_CEC,
1352 TEGRA_MUX_CLK12,
1353 TEGRA_MUX_CPU,
1354 TEGRA_MUX_DAP,
1355 TEGRA_MUX_DAP1,
1356 TEGRA_MUX_DAP2,
1357 TEGRA_MUX_DEV3,
1358 TEGRA_MUX_DISPLAYA,
1359 TEGRA_MUX_DISPLAYA_ALT,
1360 TEGRA_MUX_DISPLAYB,
1361 TEGRA_MUX_DTV,
1362 TEGRA_MUX_EMC_DLL,
1363 TEGRA_MUX_EXTPERIPH1,
1364 TEGRA_MUX_EXTPERIPH2,
1365 TEGRA_MUX_EXTPERIPH3,
1366 TEGRA_MUX_GMI,
1367 TEGRA_MUX_GMI_ALT,
1368 TEGRA_MUX_HDA,
1369 TEGRA_MUX_HSI,
1370 TEGRA_MUX_I2C1,
1371 TEGRA_MUX_I2C2,
1372 TEGRA_MUX_I2C3,
1373 TEGRA_MUX_I2C4,
1374 TEGRA_MUX_I2CPWR,
1375 TEGRA_MUX_I2S0,
1376 TEGRA_MUX_I2S1,
1377 TEGRA_MUX_I2S2,
1378 TEGRA_MUX_I2S3,
1379 TEGRA_MUX_I2S4,
1380 TEGRA_MUX_IRDA,
1381 TEGRA_MUX_KBC,
1382 TEGRA_MUX_NAND,
1383 TEGRA_MUX_NAND_ALT,
1384 TEGRA_MUX_OWR,
1385 TEGRA_MUX_PMI,
1386 TEGRA_MUX_PWM0,
1387 TEGRA_MUX_PWM1,
1388 TEGRA_MUX_PWM2,
1389 TEGRA_MUX_PWM3,
1390 TEGRA_MUX_PWRON,
1391 TEGRA_MUX_RESET_OUT_N,
1392 TEGRA_MUX_RSVD1,
1393 TEGRA_MUX_RSVD2,
1394 TEGRA_MUX_RSVD3,
1395 TEGRA_MUX_RSVD4,
1396 TEGRA_MUX_SDMMC1,
1397 TEGRA_MUX_SDMMC2,
1398 TEGRA_MUX_SDMMC3,
1399 TEGRA_MUX_SDMMC4,
1400 TEGRA_MUX_SOC,
1401 TEGRA_MUX_SPDIF,
1402 TEGRA_MUX_SPI1,
1403 TEGRA_MUX_SPI2,
1404 TEGRA_MUX_SPI3,
1405 TEGRA_MUX_SPI4,
1406 TEGRA_MUX_SPI5,
1407 TEGRA_MUX_SPI6,
1408 TEGRA_MUX_SYSCLK,
1409 TEGRA_MUX_TRACE,
1410 TEGRA_MUX_UARTA,
1411 TEGRA_MUX_UARTB,
1412 TEGRA_MUX_UARTC,
1413 TEGRA_MUX_UARTD,
1414 TEGRA_MUX_ULPI,
1415 TEGRA_MUX_USB,
1416 TEGRA_MUX_VGP1,
1417 TEGRA_MUX_VGP2,
1418 TEGRA_MUX_VGP3,
1419 TEGRA_MUX_VGP4,
1420 TEGRA_MUX_VGP5,
1421 TEGRA_MUX_VGP6,
1422 TEGRA_MUX_VI,
1423 TEGRA_MUX_VI_ALT1,
1424 TEGRA_MUX_VI_ALT3,
1425};
1426
1427static const char * const blink_groups[] = {
1428 "clk_32k_out_pa0",
1429};
1430
1431static const char * const cec_groups[] = {
1432 "hdmi_cec_pee3",
1433};
1434
1435static const char * const clk12_groups[] = {
1436 "sdmmc1_wp_n_pv3",
1437 "sdmmc1_clk_pz0",
1438};
1439
1440static const char * const cpu_groups[] = {
1441 "cpu_pwr_req",
1442};
1443
1444static const char * const dap_groups[] = {
1445 "clk1_req_pee2",
1446 "clk2_req_pcc5",
1447};
1448
1449static const char * const dap1_groups[] = {
1450 "clk1_req_pee2",
1451};
1452
1453static const char * const dap2_groups[] = {
1454 "clk1_out_pw4",
1455 "gpio_x4_aud_px4",
1456};
1457
1458static const char * const dev3_groups[] = {
1459 "clk3_req_pee1",
1460};
1461
1462static const char * const displaya_groups[] = {
1463 "dap3_fs_pp0",
1464 "dap3_din_pp1",
1465 "dap3_dout_pp2",
1466 "dap3_sclk_pp3",
1467 "uart3_rts_n_pc0",
1468 "pu3",
1469 "pu4",
1470 "pu5",
1471 "pbb3",
1472 "pbb4",
1473 "pbb5",
1474 "pbb6",
1475 "kb_row3_pr3",
1476 "kb_row4_pr4",
1477 "kb_row5_pr5",
1478 "kb_row6_pr6",
1479 "kb_col3_pq3",
1480 "sdmmc3_dat2_pb5",
1481};
1482
1483static const char * const displaya_alt_groups[] = {
1484 "kb_row6_pr6",
1485};
1486
1487static const char * const displayb_groups[] = {
1488 "dap3_fs_pp0",
1489 "dap3_din_pp1",
1490 "dap3_dout_pp2",
1491 "dap3_sclk_pp3",
1492 "pu3",
1493 "pu4",
1494 "pu5",
1495 "pu6",
1496 "pbb3",
1497 "pbb4",
1498 "pbb5",
1499 "pbb6",
1500 "kb_row3_pr3",
1501 "kb_row4_pr4",
1502 "kb_row5_pr5",
1503 "kb_row6_pr6",
1504 "sdmmc3_dat3_pb4",
1505};
1506
1507static const char * const dtv_groups[] = {
1508 "uart3_cts_n_pa1",
1509 "uart3_rts_n_pc0",
1510 "dap4_fs_pp4",
1511 "dap4_dout_pp6",
1512 "gmi_wait_pi7",
1513 "gmi_ad8_ph0",
1514 "gmi_ad14_ph6",
1515 "gmi_ad15_ph7",
1516};
1517
1518static const char * const emc_dll_groups[] = {
1519 "kb_col0_pq0",
1520 "kb_col1_pq1",
1521};
1522
1523static const char * const extperiph1_groups[] = {
1524 "clk1_out_pw4",
1525};
1526
1527static const char * const extperiph2_groups[] = {
1528 "clk2_out_pw5",
1529};
1530
1531static const char * const extperiph3_groups[] = {
1532 "clk3_out_pee0",
1533};
1534
1535static const char * const gmi_groups[] = {
1536 "gmi_wp_n_pc7",
1537
1538 "gmi_ad0_pg0",
1539 "gmi_ad1_pg1",
1540 "gmi_ad2_pg2",
1541 "gmi_ad3_pg3",
1542 "gmi_ad4_pg4",
1543 "gmi_ad5_pg5",
1544 "gmi_ad6_pg6",
1545 "gmi_ad7_pg7",
1546 "gmi_ad8_ph0",
1547 "gmi_ad9_ph1",
1548 "gmi_ad10_ph2",
1549 "gmi_ad11_ph3",
1550 "gmi_ad12_ph4",
1551 "gmi_ad13_ph5",
1552 "gmi_ad14_ph6",
1553 "gmi_ad15_ph7",
1554 "gmi_wr_n_pi0",
1555 "gmi_oe_n_pi1",
1556 "gmi_cs6_n_pi3",
1557 "gmi_rst_n_pi4",
1558 "gmi_iordy_pi5",
1559 "gmi_cs7_n_pi6",
1560 "gmi_wait_pi7",
1561 "gmi_cs0_n_pj0",
1562 "gmi_cs1_n_pj2",
1563 "gmi_dqs_p_pj3",
1564 "gmi_adv_n_pk0",
1565 "gmi_clk_pk1",
1566 "gmi_cs4_n_pk2",
1567 "gmi_cs2_n_pk3",
1568 "gmi_cs3_n_pk4",
1569 "gmi_a16_pj7",
1570 "gmi_a17_pb0",
1571 "gmi_a18_pb1",
1572 "gmi_a19_pk7",
1573 "gen2_i2c_scl_pt5",
1574 "gen2_i2c_sda_pt6",
1575 "sdmmc4_dat0_paa0",
1576 "sdmmc4_dat1_paa1",
1577 "sdmmc4_dat2_paa2",
1578 "sdmmc4_dat3_paa3",
1579 "sdmmc4_dat4_paa4",
1580 "sdmmc4_dat5_paa5",
1581 "sdmmc4_dat6_paa6",
1582 "sdmmc4_dat7_paa7",
1583 "sdmmc4_clk_pcc4",
1584 "sdmmc4_cmd_pt7",
1585 "dap1_fs_pn0",
1586 "dap1_din_pn1",
1587 "dap1_dout_pn2",
1588 "dap1_sclk_pn3",
1589};
1590
1591static const char * const gmi_alt_groups[] = {
1592 "gmi_wp_n_pc7",
1593 "gmi_cs3_n_pk4",
1594 "gmi_a16_pj7",
1595};
1596
1597static const char * const hda_groups[] = {
1598 "dap1_fs_pn0",
1599 "dap1_din_pn1",
1600 "dap1_dout_pn2",
1601 "dap1_sclk_pn3",
1602 "dap2_fs_pa2",
1603 "dap2_sclk_pa3",
1604 "dap2_din_pa4",
1605 "dap2_dout_pa5",
1606};
1607
1608static const char * const hsi_groups[] = {
1609 "ulpi_data0_po1",
1610 "ulpi_data1_po2",
1611 "ulpi_data2_po3",
1612 "ulpi_data3_po4",
1613 "ulpi_data4_po5",
1614 "ulpi_data5_po6",
1615 "ulpi_data6_po7",
1616 "ulpi_data7_po0",
1617};
1618
1619static const char * const i2c1_groups[] = {
1620 "gen1_i2c_scl_pc4",
1621 "gen1_i2c_sda_pc5",
1622 "gpio_w2_aud_pw2",
1623 "gpio_w3_aud_pw3",
1624};
1625
1626static const char * const i2c2_groups[] = {
1627 "gen2_i2c_scl_pt5",
1628 "gen2_i2c_sda_pt6",
1629};
1630
1631static const char * const i2c3_groups[] = {
1632 "cam_i2c_scl_pbb1",
1633 "cam_i2c_sda_pbb2",
1634};
1635
1636static const char * const i2c4_groups[] = {
1637 "ddc_scl_pv4",
1638 "ddc_sda_pv5",
1639};
1640
1641static const char * const i2cpwr_groups[] = {
1642 "pwr_i2c_scl_pz6",
1643 "pwr_i2c_sda_pz7",
1644};
1645
1646static const char * const i2s0_groups[] = {
1647 "dap1_fs_pn0",
1648 "dap1_din_pn1",
1649 "dap1_dout_pn2",
1650 "dap1_sclk_pn3",
1651};
1652
1653static const char * const i2s1_groups[] = {
1654 "dap2_fs_pa2",
1655 "dap2_sclk_pa3",
1656 "dap2_din_pa4",
1657 "dap2_dout_pa5",
1658};
1659
1660static const char * const i2s2_groups[] = {
1661 "dap3_fs_pp0",
1662 "dap3_din_pp1",
1663 "dap3_dout_pp2",
1664 "dap3_sclk_pp3",
1665};
1666
1667static const char * const i2s3_groups[] = {
1668 "dap4_fs_pp4",
1669 "dap4_din_pp5",
1670 "dap4_dout_pp6",
1671 "dap4_sclk_pp7",
1672};
1673
1674static const char * const i2s4_groups[] = {
1675 "pcc1",
1676 "pbb0",
1677 "pbb7",
1678 "pcc2",
1679};
1680
1681static const char * const irda_groups[] = {
1682 "uart2_rxd_pc3",
1683 "uart2_txd_pc2",
1684};
1685
1686static const char * const kbc_groups[] = {
1687 "kb_row0_pr0",
1688 "kb_row1_pr1",
1689 "kb_row2_pr2",
1690 "kb_row3_pr3",
1691 "kb_row4_pr4",
1692 "kb_row5_pr5",
1693 "kb_row6_pr6",
1694 "kb_row7_pr7",
1695 "kb_row8_ps0",
1696 "kb_row9_ps1",
1697 "kb_row10_ps2",
1698 "kb_col0_pq0",
1699 "kb_col1_pq1",
1700 "kb_col2_pq2",
1701 "kb_col3_pq3",
1702 "kb_col4_pq4",
1703 "kb_col5_pq5",
1704 "kb_col6_pq6",
1705 "kb_col7_pq7",
1706};
1707
1708static const char * const nand_groups[] = {
1709 "gmi_wp_n_pc7",
1710 "gmi_wait_pi7",
1711 "gmi_adv_n_pk0",
1712 "gmi_clk_pk1",
1713 "gmi_cs0_n_pj0",
1714 "gmi_cs1_n_pj2",
1715 "gmi_cs2_n_pk3",
1716 "gmi_cs3_n_pk4",
1717 "gmi_cs4_n_pk2",
1718 "gmi_cs6_n_pi3",
1719 "gmi_cs7_n_pi6",
1720 "gmi_ad0_pg0",
1721 "gmi_ad1_pg1",
1722 "gmi_ad2_pg2",
1723 "gmi_ad3_pg3",
1724 "gmi_ad4_pg4",
1725 "gmi_ad5_pg5",
1726 "gmi_ad6_pg6",
1727 "gmi_ad7_pg7",
1728 "gmi_ad8_ph0",
1729 "gmi_ad9_ph1",
1730 "gmi_ad10_ph2",
1731 "gmi_ad11_ph3",
1732 "gmi_ad12_ph4",
1733 "gmi_ad13_ph5",
1734 "gmi_ad14_ph6",
1735 "gmi_ad15_ph7",
1736 "gmi_wr_n_pi0",
1737 "gmi_oe_n_pi1",
1738 "gmi_dqs_p_pj3",
1739 "gmi_rst_n_pi4",
1740};
1741
1742static const char * const nand_alt_groups[] = {
1743 "gmi_cs6_n_pi3",
1744 "gmi_cs7_n_pi6",
1745 "gmi_rst_n_pi4",
1746};
1747
1748static const char * const owr_groups[] = {
1749 "pu0",
1750 "kb_col4_pq4",
1751 "owr",
1752 "sdmmc3_cd_n_pv2",
1753};
1754
1755static const char * const pmi_groups[] = {
1756 "pwr_int_n",
1757};
1758
1759static const char * const pwm0_groups[] = {
1760 "sdmmc1_dat2_py5",
1761 "uart3_rts_n_pc0",
1762 "pu3",
1763 "gmi_ad8_ph0",
1764 "sdmmc3_dat3_pb4",
1765};
1766
1767static const char * const pwm1_groups[] = {
1768 "sdmmc1_dat1_py6",
1769 "pu4",
1770 "gmi_ad9_ph1",
1771 "sdmmc3_dat2_pb5",
1772};
1773
1774static const char * const pwm2_groups[] = {
1775 "pu5",
1776 "gmi_ad10_ph2",
1777 "kb_col3_pq3",
1778 "sdmmc3_dat1_pb6",
1779};
1780
1781static const char * const pwm3_groups[] = {
1782 "pu6",
1783 "gmi_ad11_ph3",
1784 "sdmmc3_cmd_pa7",
1785};
1786
1787static const char * const pwron_groups[] = {
1788 "core_pwr_req",
1789};
1790
1791static const char * const reset_out_n_groups[] = {
1792 "reset_out_n",
1793};
1794
1795static const char * const rsvd1_groups[] = {
1796 "pv1",
1797 "hdmi_int_pn7",
1798 "pu1",
1799 "pu2",
1800 "gmi_wp_n_pc7",
1801 "gmi_adv_n_pk0",
1802 "gmi_cs0_n_pj0",
1803 "gmi_cs1_n_pj2",
1804 "gmi_ad0_pg0",
1805 "gmi_ad1_pg1",
1806 "gmi_ad2_pg2",
1807 "gmi_ad3_pg3",
1808 "gmi_ad4_pg4",
1809 "gmi_ad5_pg5",
1810 "gmi_ad6_pg6",
1811 "gmi_ad7_pg7",
1812 "gmi_wr_n_pi0",
1813 "gmi_oe_n_pi1",
1814 "gpio_x4_aud_px4",
1815 "gpio_x5_aud_px5",
1816 "gpio_x7_aud_px7",
1817
1818 "reset_out_n",
1819};
1820
1821static const char * const rsvd2_groups[] = {
1822 "pv0",
1823 "pv1",
1824 "sdmmc1_dat0_py7",
1825 "clk2_out_pw5",
1826 "clk2_req_pcc5",
1827 "hdmi_int_pn7",
1828 "ddc_scl_pv4",
1829 "ddc_sda_pv5",
1830 "uart3_txd_pw6",
1831 "uart3_rxd_pw7",
1832 "gen1_i2c_scl_pc4",
1833 "gen1_i2c_sda_pc5",
1834 "dap4_fs_pp4",
1835 "dap4_din_pp5",
1836 "dap4_dout_pp6",
1837 "dap4_sclk_pp7",
1838 "clk3_out_pee0",
1839 "clk3_req_pee1",
1840 "gmi_iordy_pi5",
1841 "gmi_a17_pb0",
1842 "gmi_a18_pb1",
1843 "gen2_i2c_scl_pt5",
1844 "gen2_i2c_sda_pt6",
1845 "sdmmc4_clk_pcc4",
1846 "sdmmc4_cmd_pt7",
1847 "sdmmc4_dat7_paa7",
1848 "pcc1",
1849 "pbb7",
1850 "pcc2",
1851 "pwr_i2c_scl_pz6",
1852 "pwr_i2c_sda_pz7",
1853 "kb_row0_pr0",
1854 "kb_row1_pr1",
1855 "kb_row2_pr2",
1856 "kb_row7_pr7",
1857 "kb_row8_ps0",
1858 "kb_row9_ps1",
1859 "kb_row10_ps2",
1860 "kb_col1_pq1",
1861 "kb_col2_pq2",
1862 "kb_col5_pq5",
1863 "kb_col6_pq6",
1864 "kb_col7_pq7",
1865 "sys_clk_req_pz5",
1866 "core_pwr_req",
1867 "cpu_pwr_req",
1868 "pwr_int_n",
1869 "owr",
1870 "spdif_out_pk5",
1871 "gpio_x1_aud_px1",
1872 "sdmmc3_clk_pa6",
1873 "sdmmc3_dat0_pb7",
1874 "gpio_w2_aud_pw2",
1875 "usb_vbus_en0_pn4",
1876 "usb_vbus_en1_pn5",
1877 "sdmmc3_clk_lb_out_pee4",
1878 "sdmmc3_clk_lb_in_pee5",
1879 "reset_out_n",
1880};
1881
1882static const char * const rsvd3_groups[] = {
1883 "pv0",
1884 "pv1",
1885 "sdmmc1_clk_pz0",
1886 "clk2_out_pw5",
1887 "clk2_req_pcc5",
1888 "hdmi_int_pn7",
1889 "ddc_scl_pv4",
1890 "ddc_sda_pv5",
1891 "uart2_rts_n_pj6",
1892 "uart2_cts_n_pj5",
1893 "uart3_txd_pw6",
1894 "uart3_rxd_pw7",
1895 "pu0",
1896 "pu1",
1897 "pu2",
1898 "gen1_i2c_scl_pc4",
1899 "gen1_i2c_sda_pc5",
1900 "dap4_din_pp5",
1901 "dap4_sclk_pp7",
1902 "clk3_out_pee0",
1903 "clk3_req_pee1",
1904 "pcc1",
1905 "cam_i2c_scl_pbb1",
1906 "cam_i2c_sda_pbb2",
1907 "pbb7",
1908 "pcc2",
1909 "pwr_i2c_scl_pz6",
1910 "pwr_i2c_sda_pz7",
1911 "kb_row0_pr0",
1912 "kb_row1_pr1",
1913 "kb_row2_pr2",
1914 "kb_row3_pr3",
1915 "kb_row9_ps1",
1916 "kb_row10_ps2",
1917 "clk_32k_out_pa0",
1918 "sys_clk_req_pz5",
1919 "core_pwr_req",
1920 "cpu_pwr_req",
1921 "pwr_int_n",
1922 "owr",
1923 "clk1_req_pee2",
1924 "clk1_out_pw4",
1925 "spdif_out_pk5",
1926 "spdif_in_pk6",
1927 "dap2_fs_pa2",
1928 "dap2_sclk_pa3",
1929 "dap2_din_pa4",
1930 "dap2_dout_pa5",
1931 "dvfs_pwm_px0",
1932 "gpio_x1_aud_px1",
1933 "gpio_x3_aud_px3",
1934 "dvfs_clk_px2",
1935 "sdmmc3_clk_pa6",
1936 "sdmmc3_dat0_pb7",
1937 "hdmi_cec_pee3",
1938 "sdmmc3_cd_n_pv2",
1939 "usb_vbus_en0_pn4",
1940 "usb_vbus_en1_pn5",
1941 "sdmmc3_clk_lb_out_pee4",
1942 "sdmmc3_clk_lb_in_pee5",
1943 "reset_out_n",
1944};
1945
1946static const char * const rsvd4_groups[] = {
1947 "pv0",
1948 "pv1",
1949 "sdmmc1_clk_pz0",
1950 "clk2_out_pw5",
1951 "clk2_req_pcc5",
1952 "hdmi_int_pn7",
1953 "ddc_scl_pv4",
1954 "ddc_sda_pv5",
1955 "pu0",
1956 "pu1",
1957 "pu2",
1958 "gen1_i2c_scl_pc4",
1959 "gen1_i2c_sda_pc5",
1960 "dap4_fs_pp4",
1961 "dap4_din_pp5",
1962 "dap4_dout_pp6",
1963 "dap4_sclk_pp7",
1964 "clk3_out_pee0",
1965 "clk3_req_pee1",
1966 "gmi_ad0_pg0",
1967 "gmi_ad1_pg1",
1968 "gmi_ad2_pg2",
1969 "gmi_ad3_pg3",
1970 "gmi_ad4_pg4",
1971 "gmi_ad12_ph4",
1972 "gmi_ad13_ph5",
1973 "gmi_rst_n_pi4",
1974 "gen2_i2c_scl_pt5",
1975 "gen2_i2c_sda_pt6",
1976 "sdmmc4_clk_pcc4",
1977 "sdmmc4_cmd_pt7",
1978 "sdmmc4_dat0_paa0",
1979 "sdmmc4_dat1_paa1",
1980 "sdmmc4_dat2_paa2",
1981 "sdmmc4_dat3_paa3",
1982 "sdmmc4_dat4_paa4",
1983 "sdmmc4_dat5_paa5",
1984 "sdmmc4_dat6_paa6",
1985 "sdmmc4_dat7_paa7",
1986 "cam_mclk_pcc0",
1987 "pcc1",
1988 "cam_i2c_scl_pbb1",
1989 "cam_i2c_sda_pbb2",
1990 "pbb3",
1991 "pbb4",
1992 "pbb5",
1993 "pbb6",
1994 "pbb7",
1995 "pcc2",
1996 "pwr_i2c_scl_pz6",
1997 "pwr_i2c_sda_pz7",
1998 "kb_row0_pr0",
1999 "kb_row1_pr1",
2000 "kb_row2_pr2",
2001 "kb_col2_pq2",
2002 "kb_col5_pq5",
2003 "kb_col6_pq6",
2004 "kb_col7_pq7",
2005 "clk_32k_out_pa0",
2006 "sys_clk_req_pz5",
2007 "core_pwr_req",
2008 "cpu_pwr_req",
2009 "pwr_int_n",
2010 "owr",
2011 "dap1_fs_pn0",
2012 "dap1_din_pn1",
2013 "dap1_dout_pn2",
2014 "dap1_sclk_pn3",
2015 "clk1_req_pee2",
2016 "clk1_out_pw4",
2017 "spdif_in_pk6",
2018 "spdif_out_pk5",
2019 "dap2_fs_pa2",
2020 "dap2_sclk_pa3",
2021 "dap2_din_pa4",
2022 "dap2_dout_pa5",
2023 "dvfs_pwm_px0",
2024 "gpio_x1_aud_px1",
2025 "gpio_x3_aud_px3",
2026 "dvfs_clk_px2",
2027 "gpio_x5_aud_px5",
2028 "gpio_x6_aud_px6",
2029 "gpio_x7_aud_px7",
2030 "sdmmc3_cd_n_pv2",
2031 "usb_vbus_en0_pn4",
2032 "usb_vbus_en1_pn5",
2033 "sdmmc3_clk_lb_in_pee5",
2034 "sdmmc3_clk_lb_out_pee4",
2035};
2036
2037static const char * const sdmmc1_groups[] = {
2038
2039 "sdmmc1_clk_pz0",
2040 "sdmmc1_cmd_pz1",
2041 "sdmmc1_dat3_py4",
2042 "sdmmc1_dat2_py5",
2043 "sdmmc1_dat1_py6",
2044 "sdmmc1_dat0_py7",
2045 "uart3_cts_n_pa1",
2046 "kb_col5_pq5",
2047 "sdmmc1_wp_n_pv3",
2048};
2049
2050static const char * const sdmmc2_groups[] = {
2051 "gmi_iordy_pi5",
2052 "gmi_clk_pk1",
2053 "gmi_cs2_n_pk3",
2054 "gmi_cs3_n_pk4",
2055 "gmi_cs7_n_pi6",
2056 "gmi_ad12_ph4",
2057 "gmi_ad13_ph5",
2058 "gmi_ad14_ph6",
2059 "gmi_ad15_ph7",
2060 "gmi_dqs_p_pj3",
2061};
2062
2063static const char * const sdmmc3_groups[] = {
2064 "kb_col4_pq4",
2065 "sdmmc3_clk_pa6",
2066 "sdmmc3_cmd_pa7",
2067 "sdmmc3_dat0_pb7",
2068 "sdmmc3_dat1_pb6",
2069 "sdmmc3_dat2_pb5",
2070 "sdmmc3_dat3_pb4",
2071 "hdmi_cec_pee3",
2072 "sdmmc3_cd_n_pv2",
2073 "sdmmc3_clk_lb_in_pee5",
2074 "sdmmc3_clk_lb_out_pee4",
2075};
2076
2077static const char * const sdmmc4_groups[] = {
2078 "sdmmc4_clk_pcc4",
2079 "sdmmc4_cmd_pt7",
2080 "sdmmc4_dat0_paa0",
2081 "sdmmc4_dat1_paa1",
2082 "sdmmc4_dat2_paa2",
2083 "sdmmc4_dat3_paa3",
2084 "sdmmc4_dat4_paa4",
2085 "sdmmc4_dat5_paa5",
2086 "sdmmc4_dat6_paa6",
2087 "sdmmc4_dat7_paa7",
2088};
2089
2090static const char * const soc_groups[] = {
2091 "gmi_cs1_n_pj2",
2092 "gmi_oe_n_pi1",
2093 "clk_32k_out_pa0",
2094 "hdmi_cec_pee3",
2095};
2096
2097static const char * const spdif_groups[] = {
2098 "sdmmc1_cmd_pz1",
2099 "sdmmc1_dat3_py4",
2100 "uart2_rxd_pc3",
2101 "uart2_txd_pc2",
2102 "spdif_in_pk6",
2103 "spdif_out_pk5",
2104};
2105
2106static const char * const spi1_groups[] = {
2107 "ulpi_clk_py0",
2108 "ulpi_dir_py1",
2109 "ulpi_nxt_py2",
2110 "ulpi_stp_py3",
2111 "gpio_x3_aud_px3",
2112 "gpio_x4_aud_px4",
2113 "gpio_x5_aud_px5",
2114 "gpio_x6_aud_px6",
2115 "gpio_x7_aud_px7",
2116 "gpio_w3_aud_pw3",
2117};
2118
2119static const char * const spi2_groups[] = {
2120 "ulpi_data4_po5",
2121 "ulpi_data5_po6",
2122 "ulpi_data6_po7",
2123 "ulpi_data7_po0",
2124 "kb_row4_pr4",
2125 "kb_row5_pr5",
2126 "kb_col0_pq0",
2127 "kb_col1_pq1",
2128 "kb_col2_pq2",
2129 "kb_col6_pq6",
2130 "kb_col7_pq7",
2131 "gpio_x4_aud_px4",
2132 "gpio_x5_aud_px5",
2133 "gpio_x6_aud_px6",
2134 "gpio_x7_aud_px7",
2135 "gpio_w2_aud_pw2",
2136 "gpio_w3_aud_pw3",
2137};
2138
2139static const char * const spi3_groups[] = {
2140 "ulpi_data0_po1",
2141 "ulpi_data1_po2",
2142 "ulpi_data2_po3",
2143 "ulpi_data3_po4",
2144 "sdmmc4_dat0_paa0",
2145 "sdmmc4_dat1_paa1",
2146 "sdmmc4_dat2_paa2",
2147 "sdmmc4_dat3_paa3",
2148 "sdmmc4_dat4_paa4",
2149 "sdmmc4_dat5_paa5",
2150 "sdmmc4_dat6_paa6",
2151 "sdmmc3_clk_pa6",
2152 "sdmmc3_cmd_pa7",
2153 "sdmmc3_dat0_pb7",
2154 "sdmmc3_dat1_pb6",
2155 "sdmmc3_dat2_pb5",
2156 "sdmmc3_dat3_pb4",
2157};
2158
2159static const char * const spi4_groups[] = {
2160 "sdmmc1_cmd_pz1",
2161 "sdmmc1_dat3_py4",
2162 "sdmmc1_dat2_py5",
2163 "sdmmc1_dat1_py6",
2164 "sdmmc1_dat0_py7",
2165 "uart2_rxd_pc3",
2166 "uart2_txd_pc2",
2167 "uart2_rts_n_pj6",
2168 "uart2_cts_n_pj5",
2169 "uart3_txd_pw6",
2170 "uart3_rxd_pw7",
2171 "uart3_cts_n_pa1",
2172 "gmi_wait_pi7",
2173 "gmi_cs6_n_pi3",
2174 "gmi_ad5_pg5",
2175 "gmi_ad6_pg6",
2176 "gmi_ad7_pg7",
2177 "gmi_a19_pk7",
2178 "gmi_wr_n_pi0",
2179 "sdmmc1_wp_n_pv3",
2180};
2181
2182static const char * const spi5_groups[] = {
2183 "ulpi_clk_py0",
2184 "ulpi_dir_py1",
2185 "ulpi_nxt_py2",
2186 "ulpi_stp_py3",
2187 "dap3_fs_pp0",
2188 "dap3_din_pp1",
2189 "dap3_dout_pp2",
2190 "dap3_sclk_pp3",
2191};
2192
2193static const char * const spi6_groups[] = {
2194 "dvfs_pwm_px0",
2195 "gpio_x1_aud_px1",
2196 "gpio_x3_aud_px3",
2197 "dvfs_clk_px2",
2198 "gpio_x6_aud_px6",
2199 "gpio_w2_aud_pw2",
2200 "gpio_w3_aud_pw3",
2201};
2202
2203static const char * const sysclk_groups[] = {
2204 "sys_clk_req_pz5",
2205};
2206
2207static const char * const trace_groups[] = {
2208 "gmi_iordy_pi5",
2209 "gmi_adv_n_pk0",
2210 "gmi_clk_pk1",
2211 "gmi_cs2_n_pk3",
2212 "gmi_cs4_n_pk2",
2213 "gmi_a16_pj7",
2214 "gmi_a17_pb0",
2215 "gmi_a18_pb1",
2216 "gmi_a19_pk7",
2217 "gmi_dqs_p_pj3",
2218};
2219
2220static const char * const uarta_groups[] = {
2221 "ulpi_data0_po1",
2222 "ulpi_data1_po2",
2223 "ulpi_data2_po3",
2224 "ulpi_data3_po4",
2225 "ulpi_data4_po5",
2226 "ulpi_data5_po6",
2227 "ulpi_data6_po7",
2228 "ulpi_data7_po0",
2229 "sdmmc1_cmd_pz1",
2230 "sdmmc1_dat3_py4",
2231 "sdmmc1_dat2_py5",
2232 "sdmmc1_dat1_py6",
2233 "sdmmc1_dat0_py7",
2234 "uart2_rxd_pc3",
2235 "uart2_txd_pc2",
2236 "uart2_rts_n_pj6",
2237 "uart2_cts_n_pj5",
2238 "pu0",
2239 "pu1",
2240 "pu2",
2241 "pu3",
2242 "pu4",
2243 "pu5",
2244 "pu6",
2245 "kb_row7_pr7",
2246 "kb_row8_ps0",
2247 "kb_row9_ps1",
2248 "kb_row10_ps2",
2249 "kb_col3_pq3",
2250 "kb_col4_pq4",
2251 "sdmmc3_cmd_pa7",
2252 "sdmmc3_dat1_pb6",
2253 "sdmmc1_wp_n_pv3",
2254};
2255
2256static const char * const uartb_groups[] = {
2257 "uart2_rts_n_pj6",
2258 "uart2_cts_n_pj5",
2259};
2260
2261static const char * const uartc_groups[] = {
2262 "uart3_txd_pw6",
2263 "uart3_rxd_pw7",
2264 "uart3_cts_n_pa1",
2265 "uart3_rts_n_pc0",
2266};
2267
2268static const char * const uartd_groups[] = {
2269 "ulpi_clk_py0",
2270 "ulpi_dir_py1",
2271 "ulpi_nxt_py2",
2272 "ulpi_stp_py3",
2273 "gmi_a16_pj7",
2274 "gmi_a17_pb0",
2275 "gmi_a18_pb1",
2276 "gmi_a19_pk7",
2277};
2278
2279static const char * const ulpi_groups[] = {
2280 "ulpi_data0_po1",
2281 "ulpi_data1_po2",
2282 "ulpi_data2_po3",
2283 "ulpi_data3_po4",
2284 "ulpi_data4_po5",
2285 "ulpi_data5_po6",
2286 "ulpi_data6_po7",
2287 "ulpi_data7_po0",
2288 "ulpi_clk_py0",
2289 "ulpi_dir_py1",
2290 "ulpi_nxt_py2",
2291 "ulpi_stp_py3",
2292};
2293
2294static const char * const usb_groups[] = {
2295 "pv0",
2296 "pu6",
2297 "gmi_cs0_n_pj0",
2298 "gmi_cs4_n_pk2",
2299 "gmi_ad11_ph3",
2300 "kb_col0_pq0",
2301 "spdif_in_pk6",
2302 "usb_vbus_en0_pn4",
2303 "usb_vbus_en1_pn5",
2304};
2305
2306static const char * const vgp1_groups[] = {
2307 "cam_i2c_scl_pbb1",
2308};
2309
2310static const char * const vgp2_groups[] = {
2311 "cam_i2c_sda_pbb2",
2312};
2313
2314static const char * const vgp3_groups[] = {
2315 "pbb3",
2316};
2317
2318static const char * const vgp4_groups[] = {
2319 "pbb4",
2320};
2321
2322static const char * const vgp5_groups[] = {
2323 "pbb5",
2324};
2325
2326static const char * const vgp6_groups[] = {
2327 "pbb6",
2328};
2329
2330static const char * const vi_groups[] = {
2331 "cam_mclk_pcc0",
2332 "pbb0",
2333};
2334
2335static const char * const vi_alt1_groups[] = {
2336 "cam_mclk_pcc0",
2337 "pbb0",
2338};
2339
2340static const char * const vi_alt3_groups[] = {
2341 "cam_mclk_pcc0",
2342 "pbb0",
2343};
2344
2345#define FUNCTION(fname) \
2346 { \
2347 .name = #fname, \
2348 .groups = fname##_groups, \
2349 .ngroups = ARRAY_SIZE(fname##_groups), \
2350 }
2351
2352static const struct tegra_function tegra114_functions[] = {
2353 FUNCTION(blink),
2354 FUNCTION(cec),
2355 FUNCTION(clk12),
2356 FUNCTION(cpu),
2357 FUNCTION(dap),
2358 FUNCTION(dap1),
2359 FUNCTION(dap2),
2360 FUNCTION(dev3),
2361 FUNCTION(displaya),
2362 FUNCTION(displaya_alt),
2363 FUNCTION(displayb),
2364 FUNCTION(dtv),
2365 FUNCTION(emc_dll),
2366 FUNCTION(extperiph1),
2367 FUNCTION(extperiph2),
2368 FUNCTION(extperiph3),
2369 FUNCTION(gmi),
2370 FUNCTION(gmi_alt),
2371 FUNCTION(hda),
2372 FUNCTION(hsi),
2373 FUNCTION(i2c1),
2374 FUNCTION(i2c2),
2375 FUNCTION(i2c3),
2376 FUNCTION(i2c4),
2377 FUNCTION(i2cpwr),
2378 FUNCTION(i2s0),
2379 FUNCTION(i2s1),
2380 FUNCTION(i2s2),
2381 FUNCTION(i2s3),
2382 FUNCTION(i2s4),
2383 FUNCTION(irda),
2384 FUNCTION(kbc),
2385 FUNCTION(nand),
2386 FUNCTION(nand_alt),
2387 FUNCTION(owr),
2388 FUNCTION(pmi),
2389 FUNCTION(pwm0),
2390 FUNCTION(pwm1),
2391 FUNCTION(pwm2),
2392 FUNCTION(pwm3),
2393 FUNCTION(pwron),
2394 FUNCTION(reset_out_n),
2395 FUNCTION(rsvd1),
2396 FUNCTION(rsvd2),
2397 FUNCTION(rsvd3),
2398 FUNCTION(rsvd4),
2399 FUNCTION(sdmmc1),
2400 FUNCTION(sdmmc2),
2401 FUNCTION(sdmmc3),
2402 FUNCTION(sdmmc4),
2403 FUNCTION(soc),
2404 FUNCTION(spdif),
2405 FUNCTION(spi1),
2406 FUNCTION(spi2),
2407 FUNCTION(spi3),
2408 FUNCTION(spi4),
2409 FUNCTION(spi5),
2410 FUNCTION(spi6),
2411 FUNCTION(sysclk),
2412 FUNCTION(trace),
2413 FUNCTION(uarta),
2414 FUNCTION(uartb),
2415 FUNCTION(uartc),
2416 FUNCTION(uartd),
2417 FUNCTION(ulpi),
2418 FUNCTION(usb),
2419 FUNCTION(vgp1),
2420 FUNCTION(vgp2),
2421 FUNCTION(vgp3),
2422 FUNCTION(vgp4),
2423 FUNCTION(vgp5),
2424 FUNCTION(vgp6),
2425 FUNCTION(vi),
2426 FUNCTION(vi_alt1),
2427 FUNCTION(vi_alt3),
2428};
2429
2430#define DRV_PINGROUP_REG_START 0x868 /* bank 0 */
2431#define PINGROUP_REG_START 0x3000 /* bank 1 */
2432
2433#define PINGROUP_REG_Y(r) ((r) - PINGROUP_REG_START)
2434#define PINGROUP_REG_N(r) -1
2435
2436#define PINGROUP(pg_name, f0, f1, f2, f3, f_safe, r, od, ior, rcv_sel) \
2437 { \
2438 .name = #pg_name, \
2439 .pins = pg_name##_pins, \
2440 .npins = ARRAY_SIZE(pg_name##_pins), \
2441 .funcs = { \
2442 TEGRA_MUX_##f0, \
2443 TEGRA_MUX_##f1, \
2444 TEGRA_MUX_##f2, \
2445 TEGRA_MUX_##f3, \
2446 }, \
2447 .func_safe = TEGRA_MUX_##f_safe, \
2448 .mux_reg = PINGROUP_REG_Y(r), \
2449 .mux_bank = 1, \
2450 .mux_bit = 0, \
2451 .pupd_reg = PINGROUP_REG_Y(r), \
2452 .pupd_bank = 1, \
2453 .pupd_bit = 2, \
2454 .tri_reg = PINGROUP_REG_Y(r), \
2455 .tri_bank = 1, \
2456 .tri_bit = 4, \
2457 .einput_reg = PINGROUP_REG_Y(r), \
2458 .einput_bank = 1, \
2459 .einput_bit = 5, \
2460 .odrain_reg = PINGROUP_REG_##od(r), \
2461 .odrain_bank = 1, \
2462 .odrain_bit = 6, \
2463 .lock_reg = PINGROUP_REG_Y(r), \
2464 .lock_bank = 1, \
2465 .lock_bit = 7, \
2466 .ioreset_reg = PINGROUP_REG_##ior(r), \
2467 .ioreset_bank = 1, \
2468 .ioreset_bit = 8, \
2469 .rcv_sel_reg = PINGROUP_REG_##rcv_sel(r), \
2470 .rcv_sel_bank = 1, \
2471 .rcv_sel_bit = 9, \
2472 .drv_reg = -1, \
2473 .drvtype_reg = -1, \
2474 }
2475
2476#define DRV_PINGROUP_DVRTYPE_Y(r) ((r) - DRV_PINGROUP_REG_START)
2477#define DRV_PINGROUP_DVRTYPE_N(r) -1
2478
2479#define DRV_PINGROUP(pg_name, r, hsm_b, schmitt_b, lpmd_b, \
2480 drvdn_b, drvdn_w, drvup_b, drvup_w, \
2481 slwr_b, slwr_w, slwf_b, slwf_w, \
2482 drvtype) \
2483 { \
2484 .name = "drive_" #pg_name, \
2485 .pins = drive_##pg_name##_pins, \
2486 .npins = ARRAY_SIZE(drive_##pg_name##_pins), \
2487 .mux_reg = -1, \
2488 .pupd_reg = -1, \
2489 .tri_reg = -1, \
2490 .einput_reg = -1, \
2491 .odrain_reg = -1, \
2492 .lock_reg = -1, \
2493 .ioreset_reg = -1, \
2494 .rcv_sel_reg = -1, \
2495 .drv_reg = DRV_PINGROUP_DVRTYPE_Y(r), \
2496 .drv_bank = 0, \
2497 .hsm_bit = hsm_b, \
2498 .schmitt_bit = schmitt_b, \
2499 .lpmd_bit = lpmd_b, \
2500 .drvdn_bit = drvdn_b, \
2501 .drvdn_width = drvdn_w, \
2502 .drvup_bit = drvup_b, \
2503 .drvup_width = drvup_w, \
2504 .slwr_bit = slwr_b, \
2505 .slwr_width = slwr_w, \
2506 .slwf_bit = slwf_b, \
2507 .slwf_width = slwf_w, \
2508 .drvtype_reg = DRV_PINGROUP_DVRTYPE_##drvtype(r), \
2509 .drvtype_bank = 0, \
2510 .drvtype_bit = 6, \
2511 }
2512
2513static const struct tegra_pingroup tegra114_groups[] = {
2514 /* pg_name, f0, f1, f2, f3, safe, r, od, ior, rcv_sel */
2515 /* FIXME: Fill in correct data in safe column */
2516 PINGROUP(ulpi_data0_po1, SPI3, HSI, UARTA, ULPI, ULPI, 0x3000, N, N, N),
2517 PINGROUP(ulpi_data1_po2, SPI3, HSI, UARTA, ULPI, ULPI, 0x3004, N, N, N),
2518 PINGROUP(ulpi_data2_po3, SPI3, HSI, UARTA, ULPI, ULPI, 0x3008, N, N, N),
2519 PINGROUP(ulpi_data3_po4, SPI3, HSI, UARTA, ULPI, ULPI, 0x300c, N, N, N),
2520 PINGROUP(ulpi_data4_po5, SPI2, HSI, UARTA, ULPI, ULPI, 0x3010, N, N, N),
2521 PINGROUP(ulpi_data5_po6, SPI2, HSI, UARTA, ULPI, ULPI, 0x3014, N, N, N),
2522 PINGROUP(ulpi_data6_po7, SPI2, HSI, UARTA, ULPI, ULPI, 0x3018, N, N, N),
2523 PINGROUP(ulpi_data7_po0, SPI2, HSI, UARTA, ULPI, ULPI, 0x301c, N, N, N),
2524 PINGROUP(ulpi_clk_py0, SPI1, SPI5, UARTD, ULPI, ULPI, 0x3020, N, N, N),
2525 PINGROUP(ulpi_dir_py1, SPI1, SPI5, UARTD, ULPI, ULPI, 0x3024, N, N, N),
2526 PINGROUP(ulpi_nxt_py2, SPI1, SPI5, UARTD, ULPI, ULPI, 0x3028, N, N, N),
2527 PINGROUP(ulpi_stp_py3, SPI1, SPI5, UARTD, ULPI, ULPI, 0x302c, N, N, N),
2528 PINGROUP(dap3_fs_pp0, I2S2, SPI5, DISPLAYA, DISPLAYB, I2S2, 0x3030, N, N, N),
2529 PINGROUP(dap3_din_pp1, I2S2, SPI5, DISPLAYA, DISPLAYB, I2S2, 0x3034, N, N, N),
2530 PINGROUP(dap3_dout_pp2, I2S2, SPI5, DISPLAYA, DISPLAYB, I2S2, 0x3038, N, N, N),
2531 PINGROUP(dap3_sclk_pp3, I2S2, SPI5, DISPLAYA, DISPLAYB, I2S2, 0x303c, N, N, N),
2532 PINGROUP(pv0, USB, RSVD2, RSVD3, RSVD4, RSVD4, 0x3040, N, N, N),
2533 PINGROUP(pv1, RSVD1, RSVD2, RSVD3, RSVD4, RSVD4, 0x3044, N, N, N),
2534 PINGROUP(sdmmc1_clk_pz0, SDMMC1, CLK12, RSVD3, RSVD4, RSVD4, 0x3048, N, N, N),
2535 PINGROUP(sdmmc1_cmd_pz1, SDMMC1, SPDIF, SPI4, UARTA, SDMMC1, 0x304c, N, N, N),
2536 PINGROUP(sdmmc1_dat3_py4, SDMMC1, SPDIF, SPI4, UARTA, SDMMC1, 0x3050, N, N, N),
2537 PINGROUP(sdmmc1_dat2_py5, SDMMC1, PWM0, SPI4, UARTA, SDMMC1, 0x3054, N, N, N),
2538 PINGROUP(sdmmc1_dat1_py6, SDMMC1, PWM1, SPI4, UARTA, SDMMC1, 0x3058, N, N, N),
2539 PINGROUP(sdmmc1_dat0_py7, SDMMC1, RSVD2, SPI4, UARTA, RSVD2, 0x305c, N, N, N),
2540 PINGROUP(clk2_out_pw5, EXTPERIPH2, RSVD2, RSVD3, RSVD4, RSVD4, 0x3068, N, N, N),
2541 PINGROUP(clk2_req_pcc5, DAP, RSVD2, RSVD3, RSVD4, RSVD4, 0x306c, N, N, N),
2542 PINGROUP(hdmi_int_pn7, RSVD1, RSVD2, RSVD3, RSVD4, RSVD4, 0x3110, N, N, Y),
2543 PINGROUP(ddc_scl_pv4, I2C4, RSVD2, RSVD3, RSVD4, RSVD4, 0x3114, N, N, Y),
2544 PINGROUP(ddc_sda_pv5, I2C4, RSVD2, RSVD3, RSVD4, RSVD4, 0x3118, N, N, Y),
2545 PINGROUP(uart2_rxd_pc3, IRDA, SPDIF, UARTA, SPI4, IRDA, 0x3164, N, N, N),
2546 PINGROUP(uart2_txd_pc2, IRDA, SPDIF, UARTA, SPI4, IRDA, 0x3168, N, N, N),
2547 PINGROUP(uart2_rts_n_pj6, UARTA, UARTB, RSVD3, SPI4, RSVD3, 0x316c, N, N, N),
2548 PINGROUP(uart2_cts_n_pj5, UARTA, UARTB, RSVD3, SPI4, RSVD3, 0x3170, N, N, N),
2549 PINGROUP(uart3_txd_pw6, UARTC, RSVD2, RSVD3, SPI4, RSVD3, 0x3174, N, N, N),
2550 PINGROUP(uart3_rxd_pw7, UARTC, RSVD2, RSVD3, SPI4, RSVD3, 0x3178, N, N, N),
2551 PINGROUP(uart3_cts_n_pa1, UARTC, SDMMC1, DTV, SPI4, UARTC, 0x317c, N, N, N),
2552 PINGROUP(uart3_rts_n_pc0, UARTC, PWM0, DTV, DISPLAYA, UARTC, 0x3180, N, N, N),
2553 PINGROUP(pu0, OWR, UARTA, RSVD3, RSVD4, RSVD4, 0x3184, N, N, N),
2554 PINGROUP(pu1, RSVD1, UARTA, RSVD3, RSVD4, RSVD4, 0x3188, N, N, N),
2555 PINGROUP(pu2, RSVD1, UARTA, RSVD3, RSVD4, RSVD4, 0x318c, N, N, N),
2556 PINGROUP(pu3, PWM0, UARTA, DISPLAYA, DISPLAYB, PWM0, 0x3190, N, N, N),
2557 PINGROUP(pu4, PWM1, UARTA, DISPLAYA, DISPLAYB, PWM1, 0x3194, N, N, N),
2558 PINGROUP(pu5, PWM2, UARTA, DISPLAYA, DISPLAYB, PWM2, 0x3198, N, N, N),
2559 PINGROUP(pu6, PWM3, UARTA, USB, DISPLAYB, PWM3, 0x319c, N, N, N),
2560 PINGROUP(gen1_i2c_sda_pc5, I2C1, RSVD2, RSVD3, RSVD4, RSVD4, 0x31a0, Y, N, N),
2561 PINGROUP(gen1_i2c_scl_pc4, I2C1, RSVD2, RSVD3, RSVD4, RSVD4, 0x31a4, Y, N, N),
2562 PINGROUP(dap4_fs_pp4, I2S3, RSVD2, DTV, RSVD4, RSVD4, 0x31a8, N, N, N),
2563 PINGROUP(dap4_din_pp5, I2S3, RSVD2, RSVD3, RSVD4, RSVD4, 0x31ac, N, N, N),
2564 PINGROUP(dap4_dout_pp6, I2S3, RSVD2, DTV, RSVD4, RSVD4, 0x31b0, N, N, N),
2565 PINGROUP(dap4_sclk_pp7, I2S3, RSVD2, RSVD3, RSVD4, RSVD4, 0x31b4, N, N, N),
2566 PINGROUP(clk3_out_pee0, EXTPERIPH3, RSVD2, RSVD3, RSVD4, RSVD4, 0x31b8, N, N, N),
2567 PINGROUP(clk3_req_pee1, DEV3, RSVD2, RSVD3, RSVD4, RSVD4, 0x31bc, N, N, N),
2568 PINGROUP(gmi_wp_n_pc7, RSVD1, NAND, GMI, GMI_ALT, RSVD1, 0x31c0, N, N, N),
2569 PINGROUP(gmi_iordy_pi5, SDMMC2, RSVD2, GMI, TRACE, RSVD2, 0x31c4, N, N, N),
2570 PINGROUP(gmi_wait_pi7, SPI4, NAND, GMI, DTV, NAND, 0x31c8, N, N, N),
2571 PINGROUP(gmi_adv_n_pk0, RSVD1, NAND, GMI, TRACE, RSVD1, 0x31cc, N, N, N),
2572 PINGROUP(gmi_clk_pk1, SDMMC2, NAND, GMI, TRACE, GMI, 0x31d0, N, N, N),
2573 PINGROUP(gmi_cs0_n_pj0, RSVD1, NAND, GMI, USB, RSVD1, 0x31d4, N, N, N),
2574 PINGROUP(gmi_cs1_n_pj2, RSVD1, NAND, GMI, SOC, RSVD1, 0x31d8, N, N, N),
2575 PINGROUP(gmi_cs2_n_pk3, SDMMC2, NAND, GMI, TRACE, GMI, 0x31dc, N, N, N),
2576 PINGROUP(gmi_cs3_n_pk4, SDMMC2, NAND, GMI, GMI_ALT, GMI, 0x31e0, N, N, N),
2577 PINGROUP(gmi_cs4_n_pk2, USB, NAND, GMI, TRACE, GMI, 0x31e4, N, N, N),
2578 PINGROUP(gmi_cs6_n_pi3, NAND, NAND_ALT, GMI, SPI4, NAND, 0x31e8, N, N, N),
2579 PINGROUP(gmi_cs7_n_pi6, NAND, NAND_ALT, GMI, SDMMC2, NAND, 0x31ec, N, N, N),
2580 PINGROUP(gmi_ad0_pg0, RSVD1, NAND, GMI, RSVD4, RSVD4, 0x31f0, N, N, N),
2581 PINGROUP(gmi_ad1_pg1, RSVD1, NAND, GMI, RSVD4, RSVD4, 0x31f4, N, N, N),
2582 PINGROUP(gmi_ad2_pg2, RSVD1, NAND, GMI, RSVD4, RSVD4, 0x31f8, N, N, N),
2583 PINGROUP(gmi_ad3_pg3, RSVD1, NAND, GMI, RSVD4, RSVD4, 0x31fc, N, N, N),
2584 PINGROUP(gmi_ad4_pg4, RSVD1, NAND, GMI, RSVD4, RSVD4, 0x3200, N, N, N),
2585 PINGROUP(gmi_ad5_pg5, RSVD1, NAND, GMI, SPI4, RSVD1, 0x3204, N, N, N),
2586 PINGROUP(gmi_ad6_pg6, RSVD1, NAND, GMI, SPI4, RSVD1, 0x3208, N, N, N),
2587 PINGROUP(gmi_ad7_pg7, RSVD1, NAND, GMI, SPI4, RSVD1, 0x320c, N, N, N),
2588 PINGROUP(gmi_ad8_ph0, PWM0, NAND, GMI, DTV, GMI, 0x3210, N, N, N),
2589 PINGROUP(gmi_ad9_ph1, PWM1, NAND, GMI, RSVD4, GMI, 0x3214, N, N, N),
2590 PINGROUP(gmi_ad10_ph2, PWM2, NAND, GMI, RSVD4, GMI, 0x3218, N, N, N),
2591 PINGROUP(gmi_ad11_ph3, PWM3, NAND, GMI, USB, GMI, 0x321c, N, N, N),
2592 PINGROUP(gmi_ad12_ph4, SDMMC2, NAND, GMI, RSVD4, RSVD4, 0x3220, N, N, N),
2593 PINGROUP(gmi_ad13_ph5, SDMMC2, NAND, GMI, RSVD4, RSVD4, 0x3224, N, N, N),
2594 PINGROUP(gmi_ad14_ph6, SDMMC2, NAND, GMI, DTV, GMI, 0x3228, N, N, N),
2595 PINGROUP(gmi_ad15_ph7, SDMMC2, NAND, GMI, DTV, GMI, 0x322c, N, N, N),
2596 PINGROUP(gmi_a16_pj7, UARTD, TRACE, GMI, GMI_ALT, GMI, 0x3230, N, N, N),
2597 PINGROUP(gmi_a17_pb0, UARTD, RSVD2, GMI, TRACE, RSVD2, 0x3234, N, N, N),
2598 PINGROUP(gmi_a18_pb1, UARTD, RSVD2, GMI, TRACE, RSVD2, 0x3238, N, N, N),
2599 PINGROUP(gmi_a19_pk7, UARTD, SPI4, GMI, TRACE, GMI, 0x323c, N, N, N),
2600 PINGROUP(gmi_wr_n_pi0, RSVD1, NAND, GMI, SPI4, RSVD1, 0x3240, N, N, N),
2601 PINGROUP(gmi_oe_n_pi1, RSVD1, NAND, GMI, SOC, RSVD1, 0x3244, N, N, N),
2602 PINGROUP(gmi_dqs_p_pj3, SDMMC2, NAND, GMI, TRACE, NAND, 0x3248, N, N, N),
2603 PINGROUP(gmi_rst_n_pi4, NAND, NAND_ALT, GMI, RSVD4, RSVD4, 0x324c, N, N, N),
2604 PINGROUP(gen2_i2c_scl_pt5, I2C2, RSVD2, GMI, RSVD4, RSVD4, 0x3250, Y, N, N),
2605 PINGROUP(gen2_i2c_sda_pt6, I2C2, RSVD2, GMI, RSVD4, RSVD4, 0x3254, Y, N, N),
2606 PINGROUP(sdmmc4_clk_pcc4, SDMMC4, RSVD2, GMI, RSVD4, RSVD4, 0x3258, N, Y, N),
2607 PINGROUP(sdmmc4_cmd_pt7, SDMMC4, RSVD2, GMI, RSVD4, RSVD4, 0x325c, N, Y, N),
2608 PINGROUP(sdmmc4_dat0_paa0, SDMMC4, SPI3, GMI, RSVD4, RSVD4, 0x3260, N, Y, N),
2609 PINGROUP(sdmmc4_dat1_paa1, SDMMC4, SPI3, GMI, RSVD4, RSVD4, 0x3264, N, Y, N),
2610 PINGROUP(sdmmc4_dat2_paa2, SDMMC4, SPI3, GMI, RSVD4, RSVD4, 0x3268, N, Y, N),
2611 PINGROUP(sdmmc4_dat3_paa3, SDMMC4, SPI3, GMI, RSVD4, RSVD4, 0x326c, N, Y, N),
2612 PINGROUP(sdmmc4_dat4_paa4, SDMMC4, SPI3, GMI, RSVD4, RSVD4, 0x3270, N, Y, N),
2613 PINGROUP(sdmmc4_dat5_paa5, SDMMC4, SPI3, GMI, RSVD4, RSVD4, 0x3274, N, Y, N),
2614 PINGROUP(sdmmc4_dat6_paa6, SDMMC4, SPI3, GMI, RSVD4, RSVD4, 0x3278, N, Y, N),
2615 PINGROUP(sdmmc4_dat7_paa7, SDMMC4, RSVD2, GMI, RSVD4, RSVD4, 0x327c, N, Y, N),
2616 PINGROUP(cam_mclk_pcc0, VI, VI_ALT1, VI_ALT3, RSVD4, RSVD4, 0x3284, N, N, N),
2617 PINGROUP(pcc1, I2S4, RSVD2, RSVD3, RSVD4, RSVD4, 0x3288, N, N, N),
2618 PINGROUP(pbb0, I2S4, VI, VI_ALT1, VI_ALT3, I2S4, 0x328c, N, N, N),
2619 PINGROUP(cam_i2c_scl_pbb1, VGP1, I2C3, RSVD3, RSVD4, RSVD4, 0x3290, Y, N, N),
2620 PINGROUP(cam_i2c_sda_pbb2, VGP2, I2C3, RSVD3, RSVD4, RSVD4, 0x3294, Y, N, N),
2621 PINGROUP(pbb3, VGP3, DISPLAYA, DISPLAYB, RSVD4, RSVD4, 0x3298, N, N, N),
2622 PINGROUP(pbb4, VGP4, DISPLAYA, DISPLAYB, RSVD4, RSVD4, 0x329c, N, N, N),
2623 PINGROUP(pbb5, VGP5, DISPLAYA, DISPLAYB, RSVD4, RSVD4, 0x32a0, N, N, N),
2624 PINGROUP(pbb6, VGP6, DISPLAYA, DISPLAYB, RSVD4, RSVD4, 0x32a4, N, N, N),
2625 PINGROUP(pbb7, I2S4, RSVD2, RSVD3, RSVD4, RSVD4, 0x32a8, N, N, N),
2626 PINGROUP(pcc2, I2S4, RSVD2, RSVD3, RSVD4, RSVD4, 0x32ac, N, N, N),
2627 PINGROUP(pwr_i2c_scl_pz6, I2CPWR, RSVD2, RSVD3, RSVD4, RSVD4, 0x32b4, Y, N, N),
2628 PINGROUP(pwr_i2c_sda_pz7, I2CPWR, RSVD2, RSVD3, RSVD4, RSVD4, 0x32b8, Y, N, N),
2629 PINGROUP(kb_row0_pr0, KBC, RSVD2, RSVD3, RSVD4, RSVD4, 0x32bc, N, N, N),
2630 PINGROUP(kb_row1_pr1, KBC, RSVD2, RSVD3, RSVD4, RSVD4, 0x32c0, N, N, N),
2631 PINGROUP(kb_row2_pr2, KBC, RSVD2, RSVD3, RSVD4, RSVD4, 0x32c4, N, N, N),
2632 PINGROUP(kb_row3_pr3, KBC, DISPLAYA, RSVD3, DISPLAYB, RSVD3, 0x32c8, N, N, N),
2633 PINGROUP(kb_row4_pr4, KBC, DISPLAYA, SPI2, DISPLAYB, KBC, 0x32cc, N, N, N),
2634 PINGROUP(kb_row5_pr5, KBC, DISPLAYA, SPI2, DISPLAYB, KBC, 0x32d0, N, N, N),
2635 PINGROUP(kb_row6_pr6, KBC, DISPLAYA, DISPLAYA_ALT, DISPLAYB, KBC, 0x32d4, N, N, N),
2636 PINGROUP(kb_row7_pr7, KBC, RSVD2, RSVD3, UARTA, RSVD2, 0x32d8, N, N, N),
2637 PINGROUP(kb_row8_ps0, KBC, RSVD2, RSVD3, UARTA, RSVD2, 0x32dc, N, N, N),
2638 PINGROUP(kb_row9_ps1, KBC, RSVD2, RSVD3, UARTA, RSVD3, 0x32e0, N, N, N),
2639 PINGROUP(kb_row10_ps2, KBC, RSVD2, RSVD3, UARTA, RSVD3, 0x32e4, N, N, N),
2640 PINGROUP(kb_col0_pq0, KBC, USB, SPI2, EMC_DLL, KBC, 0x32fc, N, N, N),
2641 PINGROUP(kb_col1_pq1, KBC, RSVD2, SPI2, EMC_DLL, RSVD2, 0x3300, N, N, N),
2642 PINGROUP(kb_col2_pq2, KBC, RSVD2, SPI2, RSVD4, RSVD2, 0x3304, N, N, N),
2643 PINGROUP(kb_col3_pq3, KBC, DISPLAYA, PWM2, UARTA, KBC, 0x3308, N, N, N),
2644 PINGROUP(kb_col4_pq4, KBC, OWR, SDMMC3, UARTA, KBC, 0x330c, N, N, N),
2645 PINGROUP(kb_col5_pq5, KBC, RSVD2, SDMMC1, RSVD4, RSVD4, 0x3310, N, N, N),
2646 PINGROUP(kb_col6_pq6, KBC, RSVD2, SPI2, RSVD4, RSVD4, 0x3314, N, N, N),
2647 PINGROUP(kb_col7_pq7, KBC, RSVD2, SPI2, RSVD4, RSVD4, 0x3318, N, N, N),
2648 PINGROUP(clk_32k_out_pa0, BLINK, SOC, RSVD3, RSVD4, RSVD4, 0x331c, N, N, N),
2649 PINGROUP(sys_clk_req_pz5, SYSCLK, RSVD2, RSVD3, RSVD4, RSVD4, 0x3320, N, N, N),
2650 PINGROUP(core_pwr_req, PWRON, RSVD2, RSVD3, RSVD4, RSVD4, 0x3324, N, N, N),
2651 PINGROUP(cpu_pwr_req, CPU, RSVD2, RSVD3, RSVD4, RSVD4, 0x3328, N, N, N),
2652 PINGROUP(pwr_int_n, PMI, RSVD2, RSVD3, RSVD4, RSVD4, 0x332c, N, N, N),
2653 PINGROUP(owr, OWR, RSVD2, RSVD3, RSVD4, RSVD4, 0x3334, N, N, Y),
2654 PINGROUP(dap1_fs_pn0, I2S0, HDA, GMI, RSVD4, RSVD4, 0x3338, N, N, N),
2655 PINGROUP(dap1_din_pn1, I2S0, HDA, GMI, RSVD4, RSVD4, 0x333c, N, N, N),
2656 PINGROUP(dap1_dout_pn2, I2S0, HDA, GMI, RSVD4, RSVD4, 0x3340, N, N, N),
2657 PINGROUP(dap1_sclk_pn3, I2S0, HDA, GMI, RSVD4, RSVD4, 0x3344, N, N, N),
2658 PINGROUP(clk1_req_pee2, DAP, DAP1, RSVD3, RSVD4, RSVD4, 0x3348, N, N, N),
2659 PINGROUP(clk1_out_pw4, EXTPERIPH1, DAP2, RSVD3, RSVD4, RSVD4, 0x334c, N, N, N),
2660 PINGROUP(spdif_in_pk6, SPDIF, USB, RSVD3, RSVD4, RSVD4, 0x3350, N, N, N),
2661 PINGROUP(spdif_out_pk5, SPDIF, RSVD2, RSVD3, RSVD4, RSVD4, 0x3354, N, N, N),
2662 PINGROUP(dap2_fs_pa2, I2S1, HDA, RSVD3, RSVD4, RSVD4, 0x3358, N, N, N),
2663 PINGROUP(dap2_din_pa4, I2S1, HDA, RSVD3, RSVD4, RSVD4, 0x335c, N, N, N),
2664 PINGROUP(dap2_dout_pa5, I2S1, HDA, RSVD3, RSVD4, RSVD4, 0x3360, N, N, N),
2665 PINGROUP(dap2_sclk_pa3, I2S1, HDA, RSVD3, RSVD4, RSVD4, 0x3364, N, N, N),
2666 PINGROUP(dvfs_pwm_px0, SPI6, RSVD2, RSVD3, RSVD4, RSVD4, 0x3368, N, N, N),
2667 PINGROUP(gpio_x1_aud_px1, SPI6, RSVD2, RSVD3, RSVD4, RSVD4, 0x336c, N, N, N),
2668 PINGROUP(gpio_x3_aud_px3, SPI6, SPI1, RSVD3, RSVD4, RSVD4, 0x3370, N, N, N),
2669 PINGROUP(gpio_x4_aud_px4, RSVD1, SPI1, SPI2, DAP2, RSVD1, 0x3378, N, N, N),
2670 PINGROUP(gpio_x5_aud_px5, RSVD1, SPI1, SPI2, RSVD4, RSVD1, 0x337c, N, N, N),
2671 PINGROUP(gpio_x6_aud_px6, SPI6, SPI1, SPI2, RSVD4, RSVD4, 0x3380, N, N, N),
2672 PINGROUP(gpio_x7_aud_px7, RSVD1, SPI1, SPI2, RSVD4, RSVD4, 0x3384, N, N, N),
2673 PINGROUP(sdmmc3_clk_pa6, SDMMC3, RSVD2, RSVD3, SPI3, RSVD3, 0x3390, N, N, N),
2674 PINGROUP(sdmmc3_cmd_pa7, SDMMC3, PWM3, UARTA, SPI3, SDMMC3, 0x3394, N, N, N),
2675 PINGROUP(sdmmc3_dat0_pb7, SDMMC3, RSVD2, RSVD3, SPI3, RSVD3, 0x3398, N, N, N),
2676 PINGROUP(sdmmc3_dat1_pb6, SDMMC3, PWM2, UARTA, SPI3, SDMMC3, 0x339c, N, N, N),
2677 PINGROUP(sdmmc3_dat2_pb5, SDMMC3, PWM1, DISPLAYA, SPI3, SDMMC3, 0x33a0, N, N, N),
2678 PINGROUP(sdmmc3_dat3_pb4, SDMMC3, PWM0, DISPLAYB, SPI3, SDMMC3, 0x33a4, N, N, N),
2679 PINGROUP(hdmi_cec_pee3, CEC, SDMMC3, RSVD3, SOC, RSVD3, 0x33e0, Y, N, N),
2680 PINGROUP(sdmmc1_wp_n_pv3, SDMMC1, CLK12, SPI4, UARTA, SDMMC1, 0x33e4, N, N, N),
2681 PINGROUP(sdmmc3_cd_n_pv2, SDMMC3, OWR, RSVD3, RSVD4, RSVD4, 0x33e8, N, N, N),
2682 PINGROUP(gpio_w2_aud_pw2, SPI6, RSVD2, SPI2, I2C1, RSVD2, 0x33ec, N, N, N),
2683 PINGROUP(gpio_w3_aud_pw3, SPI6, SPI1, SPI2, I2C1, SPI6, 0x33f0, N, N, N),
2684 PINGROUP(usb_vbus_en0_pn4, USB, RSVD2, RSVD3, RSVD4, RSVD4, 0x33f4, Y, N, N),
2685 PINGROUP(usb_vbus_en1_pn5, USB, RSVD2, RSVD3, RSVD4, RSVD4, 0x33f8, Y, N, N),
2686 PINGROUP(sdmmc3_clk_lb_in_pee5, SDMMC3, RSVD2, RSVD3, RSVD4, RSVD4, 0x33fc, N, N, N),
2687 PINGROUP(sdmmc3_clk_lb_out_pee4, SDMMC3, RSVD2, RSVD3, RSVD4, RSVD4, 0x3400, N, N, N),
2688 PINGROUP(reset_out_n, RSVD1, RSVD2, RSVD3, RESET_OUT_N, RSVD3, 0x3408, N, N, N),
2689
2690 /* pg_name, r, hsm_b, schmitt_b, lpmd_b, drvdn_b, drvdn_w, drvup_b, drvup_w, slwr_b, slwr_w, slwf_b, slwf_w, drvtype */
2691 DRV_PINGROUP(ao1, 0x868, 2, 3, 4, 12, 5, 20, 5, 28, 2, 30, 2, N),
2692 DRV_PINGROUP(ao2, 0x86c, 2, 3, 4, 12, 5, 20, 5, 28, 2, 30, 2, N),
2693 DRV_PINGROUP(at1, 0x870, 2, 3, 4, 12, 7, 20, 7, 28, 2, 30, 2, Y),
2694 DRV_PINGROUP(at2, 0x874, 2, 3, 4, 12, 7, 20, 7, 28, 2, 30, 2, Y),
2695 DRV_PINGROUP(at3, 0x878, 2, 3, 4, 12, 7, 20, 7, 28, 2, 30, 2, Y),
2696 DRV_PINGROUP(at4, 0x87c, 2, 3, 4, 12, 7, 20, 7, 28, 2, 30, 2, Y),
2697 DRV_PINGROUP(at5, 0x880, 2, 3, 4, 14, 5, 19, 5, 28, 2, 30, 2, N),
2698 DRV_PINGROUP(cdev1, 0x884, 2, 3, 4, 12, 5, 20, 5, 28, 2, 30, 2, N),
2699 DRV_PINGROUP(cdev2, 0x888, 2, 3, 4, 12, 5, 20, 5, 28, 2, 30, 2, N),
2700 DRV_PINGROUP(dap1, 0x890, 2, 3, 4, 12, 5, 20, 5, 28, 2, 30, 2, N),
2701 DRV_PINGROUP(dap2, 0x894, 2, 3, 4, 12, 5, 20, 5, 28, 2, 30, 2, N),
2702 DRV_PINGROUP(dap3, 0x898, 2, 3, 4, 12, 5, 20, 5, 28, 2, 30, 2, N),
2703 DRV_PINGROUP(dap4, 0x89c, 2, 3, 4, 12, 5, 20, 5, 28, 2, 30, 2, N),
2704 DRV_PINGROUP(dbg, 0x8a0, 2, 3, 4, 12, 5, 20, 5, 28, 2, 30, 2, N),
2705 DRV_PINGROUP(sdio3, 0x8b0, 2, 3, -1, 12, 7, 20, 7, 28, 2, 30, 2, N),
2706 DRV_PINGROUP(spi, 0x8b4, 2, 3, 4, 12, 5, 20, 5, 28, 2, 30, 2, N),
2707 DRV_PINGROUP(uaa, 0x8b8, 2, 3, 4, 12, 5, 20, 5, 28, 2, 30, 2, N),
2708 DRV_PINGROUP(uab, 0x8bc, 2, 3, 4, 12, 5, 20, 5, 28, 2, 30, 2, N),
2709 DRV_PINGROUP(uart2, 0x8c0, 2, 3, 4, 12, 5, 20, 5, 28, 2, 30, 2, N),
2710 DRV_PINGROUP(uart3, 0x8c4, 2, 3, 4, 12, 5, 20, 5, 28, 2, 30, 2, N),
2711 DRV_PINGROUP(sdio1, 0x8ec, 2, 3, -1, 12, 7, 20, 7, 28, 2, 30, 2, N),
2712 DRV_PINGROUP(ddc, 0x8fc, 2, 3, 4, 12, 5, 20, 5, 28, 2, 30, 2, N),
2713 DRV_PINGROUP(gma, 0x900, 2, 3, 4, 14, 5, 20, 5, 28, 2, 30, 2, Y),
2714 DRV_PINGROUP(gme, 0x910, 2, 3, 4, 14, 5, 19, 5, 28, 2, 30, 2, N),
2715 DRV_PINGROUP(gmf, 0x914, 2, 3, 4, 14, 5, 19, 5, 28, 2, 30, 2, N),
2716 DRV_PINGROUP(gmg, 0x918, 2, 3, 4, 14, 5, 19, 5, 28, 2, 30, 2, N),
2717 DRV_PINGROUP(gmh, 0x91c, 2, 3, 4, 14, 5, 19, 5, 28, 2, 30, 2, N),
2718 DRV_PINGROUP(owr, 0x920, 2, 3, 4, 12, 5, 20, 5, 28, 2, 30, 2, N),
2719 DRV_PINGROUP(uda, 0x924, 2, 3, 4, 12, 5, 20, 5, 28, 2, 30, 2, N),
2720};
2721
2722static const struct tegra_pinctrl_soc_data tegra114_pinctrl = {
2723 .ngpios = NUM_GPIOS,
2724 .pins = tegra114_pins,
2725 .npins = ARRAY_SIZE(tegra114_pins),
2726 .functions = tegra114_functions,
2727 .nfunctions = ARRAY_SIZE(tegra114_functions),
2728 .groups = tegra114_groups,
2729 .ngroups = ARRAY_SIZE(tegra114_groups),
2730};
2731
2732static int tegra114_pinctrl_probe(struct platform_device *pdev)
2733{
2734 return tegra_pinctrl_probe(pdev, &tegra114_pinctrl);
2735}
2736
2737static struct of_device_id tegra114_pinctrl_of_match[] = {
2738 { .compatible = "nvidia,tegra114-pinmux", },
2739 { },
2740};
2741MODULE_DEVICE_TABLE(of, tegra114_pinctrl_of_match);
2742
2743static struct platform_driver tegra114_pinctrl_driver = {
2744 .driver = {
2745 .name = "tegra114-pinctrl",
2746 .owner = THIS_MODULE,
2747 .of_match_table = tegra114_pinctrl_of_match,
2748 },
2749 .probe = tegra114_pinctrl_probe,
2750 .remove = tegra_pinctrl_remove,
2751};
2752module_platform_driver(tegra114_pinctrl_driver);
2753
2754MODULE_ALIAS("platform:tegra114-pinctrl");
2755MODULE_AUTHOR("Pritesh Raithatha <praithatha@nvidia.com>");
2756MODULE_DESCRIPTION("NVIDIA Tegra114 pincontrol driver");
2757MODULE_LICENSE("GPL v2");