2 * linux/arch/arm/mach-tegra/pinmux-tegra30-tables.c
4 * Common pinmux configurations for Tegra30 SoCs
6 * Copyright (C) 2010,2011 NVIDIA Corporation
8 * This program is free software; you can redistribute it and/or modify
9 * it under the terms of the GNU General Public License as published by
10 * the Free Software Foundation; either version 2 of the License.
12 * This program is distributed in the hope that 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
17 * You should have received a copy of the GNU General Public License along
18 * with this program; if not, write to the Free Software Foundation, Inc.,
19 * 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
22 #include <linux/kernel.h>
23 #include <linux/errno.h>
24 #include <linux/spinlock.h>
26 #include <linux/init.h>
27 #include <linux/string.h>
29 #include <mach/iomap.h>
30 #include <mach/pinmux.h>
31 #include <mach/pinmux-tegra30.h>
32 #include <mach/suspend.h>
34 #define PINGROUP_REG_A 0x868
35 #define MUXCTL_REG_A 0x3000
37 #define DRIVE_PINGROUP(pg_name, r) \
38 [TEGRA_DRIVE_PINGROUP_ ## pg_name] = { \
41 .reg = ((r) - PINGROUP_REG_A) \
44 static const struct tegra_drive_pingroup_desc tegra_soc_drive_pingroups
[TEGRA_MAX_DRIVE_PINGROUP
] = {
45 DRIVE_PINGROUP(AO1
, 0x868),
46 DRIVE_PINGROUP(AO2
, 0x86c),
47 DRIVE_PINGROUP(AT1
, 0x870),
48 DRIVE_PINGROUP(AT2
, 0x874),
49 DRIVE_PINGROUP(AT3
, 0x878),
50 DRIVE_PINGROUP(AT4
, 0x87c),
51 DRIVE_PINGROUP(AT5
, 0x880),
52 DRIVE_PINGROUP(CDEV1
, 0x884),
53 DRIVE_PINGROUP(CDEV2
, 0x888),
54 DRIVE_PINGROUP(CSUS
, 0x88c),
55 DRIVE_PINGROUP(DAP1
, 0x890),
56 DRIVE_PINGROUP(DAP2
, 0x894),
57 DRIVE_PINGROUP(DAP3
, 0x898),
58 DRIVE_PINGROUP(DAP4
, 0x89c),
59 DRIVE_PINGROUP(DBG
, 0x8a0),
60 DRIVE_PINGROUP(LCD1
, 0x8a4),
61 DRIVE_PINGROUP(LCD2
, 0x8a8),
62 DRIVE_PINGROUP(SDIO2
, 0x8ac),
63 DRIVE_PINGROUP(SDIO3
, 0x8b0),
64 DRIVE_PINGROUP(SPI
, 0x8b4),
65 DRIVE_PINGROUP(UAA
, 0x8b8),
66 DRIVE_PINGROUP(UAB
, 0x8bc),
67 DRIVE_PINGROUP(UART2
, 0x8c0),
68 DRIVE_PINGROUP(UART3
, 0x8c4),
69 DRIVE_PINGROUP(VI1
, 0x8c8),
70 DRIVE_PINGROUP(SDIO1
, 0x8ec),
71 DRIVE_PINGROUP(CRT
, 0x8f8),
72 DRIVE_PINGROUP(DDC
, 0x8fc),
73 DRIVE_PINGROUP(GMA
, 0x900),
74 DRIVE_PINGROUP(GMB
, 0x904),
75 DRIVE_PINGROUP(GMC
, 0x908),
76 DRIVE_PINGROUP(GMD
, 0x90c),
77 DRIVE_PINGROUP(GME
, 0x910),
78 DRIVE_PINGROUP(GMF
, 0x914),
79 DRIVE_PINGROUP(GMG
, 0x918),
80 DRIVE_PINGROUP(GMH
, 0x91c),
81 DRIVE_PINGROUP(OWR
, 0x920),
82 DRIVE_PINGROUP(UAD
, 0x924),
83 DRIVE_PINGROUP(GPV
, 0x928),
84 DRIVE_PINGROUP(DEV3
, 0x92c),
85 DRIVE_PINGROUP(CEC
, 0x938),
88 #define PINGROUP(pg_name, vdd, f0, f1, f2, f3, fs, iod, reg) \
89 [TEGRA_PINGROUP_ ## pg_name] = { \
91 .vddio = TEGRA_VDDIO_ ## vdd, \
98 .func_safe = TEGRA_MUX_ ## fs, \
100 .tri_reg = ((reg) - MUXCTL_REG_A), \
103 .mux_reg = ((reg) - MUXCTL_REG_A), \
106 .pupd_reg = ((reg) - MUXCTL_REG_A), \
108 .io_default = TEGRA_PIN_ ## iod, \
114 static const struct tegra_pingroup_desc tegra_soc_pingroups
[TEGRA_MAX_PINGROUP
] = {
115 /* NAME VDD f0 f1 f2 f3 fSafe io reg */
116 PINGROUP(ULPI_DATA0
, BB
, SPI3
, HSI
, UARTA
, ULPI
, RSVD
, INPUT
, 0x3000),
117 PINGROUP(ULPI_DATA1
, BB
, SPI3
, HSI
, UARTA
, ULPI
, RSVD
, INPUT
, 0x3004),
118 PINGROUP(ULPI_DATA2
, BB
, SPI3
, HSI
, UARTA
, ULPI
, RSVD
, INPUT
, 0x3008),
119 PINGROUP(ULPI_DATA3
, BB
, SPI3
, HSI
, UARTA
, ULPI
, RSVD
, INPUT
, 0x300c),
120 PINGROUP(ULPI_DATA4
, BB
, SPI2
, HSI
, UARTA
, ULPI
, RSVD
, INPUT
, 0x3010),
121 PINGROUP(ULPI_DATA5
, BB
, SPI2
, HSI
, UARTA
, ULPI
, RSVD
, INPUT
, 0x3014),
122 PINGROUP(ULPI_DATA6
, BB
, SPI2
, HSI
, UARTA
, ULPI
, RSVD
, INPUT
, 0x3018),
123 PINGROUP(ULPI_DATA7
, BB
, SPI2
, HSI
, UARTA
, ULPI
, RSVD
, INPUT
, 0x301c),
124 PINGROUP(ULPI_CLK
, BB
, SPI1
, RSVD
, UARTD
, ULPI
, RSVD
, INPUT
, 0x3020),
125 PINGROUP(ULPI_DIR
, BB
, SPI1
, RSVD
, UARTD
, ULPI
, RSVD
, INPUT
, 0x3024),
126 PINGROUP(ULPI_NXT
, BB
, SPI1
, RSVD
, UARTD
, ULPI
, RSVD
, INPUT
, 0x3028),
127 PINGROUP(ULPI_STP
, BB
, SPI1
, RSVD
, UARTD
, ULPI
, RSVD
, INPUT
, 0x302c),
128 PINGROUP(DAP3_FS
, BB
, I2S2
, RSVD1
, DISPLAYA
, DISPLAYB
, RSVD
, INPUT
, 0x3030),
129 PINGROUP(DAP3_DIN
, BB
, I2S2
, RSVD1
, DISPLAYA
, DISPLAYB
, RSVD
, INPUT
, 0x3034),
130 PINGROUP(DAP3_DOUT
, BB
, I2S2
, RSVD1
, DISPLAYA
, DISPLAYB
, RSVD
, INPUT
, 0x3038),
131 PINGROUP(DAP3_SCLK
, BB
, I2S2
, RSVD1
, DISPLAYA
, DISPLAYB
, RSVD
, INPUT
, 0x303c),
132 PINGROUP(GPIO_PV0
, BB
, RSVD
, RSVD
, RSVD
, RSVD
, RSVD
, INPUT
, 0x3040),
133 PINGROUP(GPIO_PV1
, BB
, RSVD
, RSVD
, RSVD
, RSVD
, RSVD
, INPUT
, 0x3044),
134 PINGROUP(SDMMC1_CLK
, SDMMC1
, SDIO1
, RSVD1
, RSVD2
, INVALID
, RSVD
, INPUT
, 0x3048),
135 PINGROUP(SDMMC1_CMD
, SDMMC1
, SDIO1
, RSVD1
, RSVD2
, INVALID
, RSVD
, INPUT
, 0x304c),
136 PINGROUP(SDMMC1_DAT3
, SDMMC1
, SDIO1
, RSVD1
, UARTE
, INVALID
, RSVD
, INPUT
, 0x3050),
137 PINGROUP(SDMMC1_DAT2
, SDMMC1
, SDIO1
, RSVD1
, UARTE
, INVALID
, RSVD
, INPUT
, 0x3054),
138 PINGROUP(SDMMC1_DAT1
, SDMMC1
, SDIO1
, RSVD1
, UARTE
, INVALID
, RSVD
, INPUT
, 0x3058),
139 PINGROUP(SDMMC1_DAT0
, SDMMC1
, SDIO1
, RSVD1
, UARTE
, INVALID
, RSVD
, INPUT
, 0x305c),
140 PINGROUP(GPIO_PV2
, SDMMC1
, OWR
, RSVD1
, RSVD2
, RSVD3
, RSVD
, INPUT
, 0x3060),
141 PINGROUP(GPIO_PV3
, SDMMC1
, INVALID
, RSVD1
, RSVD2
, RSVD3
, RSVD
, INPUT
, 0x3064),
142 PINGROUP(CLK2_OUT
, SDMMC1
, EXTPERIPH2
, RSVD1
, RSVD2
, RSVD3
, RSVD
, INPUT
, 0x3068),
143 PINGROUP(CLK2_REQ
, SDMMC1
, DAP
, RSVD1
, RSVD2
, RSVD3
, RSVD
, INPUT
, 0x306c),
144 PINGROUP(LCD_PWR1
, LCD
, DISPLAYA
, DISPLAYB
, RSVD1
, RSVD2
, RSVD
, OUTPUT
, 0x3070),
145 PINGROUP(LCD_PWR2
, LCD
, DISPLAYA
, DISPLAYB
, SPI5
, INVALID
, RSVD
, OUTPUT
, 0x3074),
146 PINGROUP(LCD_SDIN
, LCD
, DISPLAYA
, DISPLAYB
, SPI5
, RSVD
, RSVD
, OUTPUT
, 0x3078),
147 PINGROUP(LCD_SDOUT
, LCD
, DISPLAYA
, DISPLAYB
, SPI5
, INVALID
, RSVD
, OUTPUT
, 0x307c),
148 PINGROUP(LCD_WR_N
, LCD
, DISPLAYA
, DISPLAYB
, SPI5
, INVALID
, RSVD
, OUTPUT
, 0x3080),
149 PINGROUP(LCD_CS0_N
, LCD
, DISPLAYA
, DISPLAYB
, SPI5
, RSVD
, RSVD
, OUTPUT
, 0x3084),
150 PINGROUP(LCD_DC0
, LCD
, DISPLAYA
, DISPLAYB
, RSVD1
, RSVD2
, RSVD
, OUTPUT
, 0x3088),
151 PINGROUP(LCD_SCK
, LCD
, DISPLAYA
, DISPLAYB
, SPI5
, INVALID
, RSVD
, OUTPUT
, 0x308c),
152 PINGROUP(LCD_PWR0
, LCD
, DISPLAYA
, DISPLAYB
, SPI5
, INVALID
, RSVD
, OUTPUT
, 0x3090),
153 PINGROUP(LCD_PCLK
, LCD
, DISPLAYA
, DISPLAYB
, RSVD1
, RSVD2
, RSVD
, OUTPUT
, 0x3094),
154 PINGROUP(LCD_DE
, LCD
, DISPLAYA
, DISPLAYB
, RSVD1
, RSVD2
, RSVD
, OUTPUT
, 0x3098),
155 PINGROUP(LCD_HSYNC
, LCD
, DISPLAYA
, DISPLAYB
, RSVD1
, RSVD2
, RSVD
, OUTPUT
, 0x309c),
156 PINGROUP(LCD_VSYNC
, LCD
, DISPLAYA
, DISPLAYB
, RSVD1
, RSVD2
, RSVD
, OUTPUT
, 0x30a0),
157 PINGROUP(LCD_D0
, LCD
, DISPLAYA
, DISPLAYB
, RSVD1
, RSVD2
, RSVD
, OUTPUT
, 0x30a4),
158 PINGROUP(LCD_D1
, LCD
, DISPLAYA
, DISPLAYB
, RSVD1
, RSVD2
, RSVD
, OUTPUT
, 0x30a8),
159 PINGROUP(LCD_D2
, LCD
, DISPLAYA
, DISPLAYB
, RSVD1
, RSVD2
, RSVD
, OUTPUT
, 0x30ac),
160 PINGROUP(LCD_D3
, LCD
, DISPLAYA
, DISPLAYB
, RSVD1
, RSVD2
, RSVD
, OUTPUT
, 0x30b0),
161 PINGROUP(LCD_D4
, LCD
, DISPLAYA
, DISPLAYB
, RSVD1
, RSVD2
, RSVD
, OUTPUT
, 0x30b4),
162 PINGROUP(LCD_D5
, LCD
, DISPLAYA
, DISPLAYB
, RSVD1
, RSVD2
, RSVD
, OUTPUT
, 0x30b8),
163 PINGROUP(LCD_D6
, LCD
, DISPLAYA
, DISPLAYB
, RSVD1
, RSVD2
, RSVD
, OUTPUT
, 0x30bc),
164 PINGROUP(LCD_D7
, LCD
, DISPLAYA
, DISPLAYB
, RSVD1
, RSVD2
, RSVD
, OUTPUT
, 0x30c0),
165 PINGROUP(LCD_D8
, LCD
, DISPLAYA
, DISPLAYB
, RSVD1
, RSVD2
, RSVD
, OUTPUT
, 0x30c4),
166 PINGROUP(LCD_D9
, LCD
, DISPLAYA
, DISPLAYB
, RSVD1
, RSVD2
, RSVD
, OUTPUT
, 0x30c8),
167 PINGROUP(LCD_D10
, LCD
, DISPLAYA
, DISPLAYB
, RSVD1
, RSVD2
, RSVD
, OUTPUT
, 0x30cc),
168 PINGROUP(LCD_D11
, LCD
, DISPLAYA
, DISPLAYB
, RSVD1
, RSVD2
, RSVD
, OUTPUT
, 0x30d0),
169 PINGROUP(LCD_D12
, LCD
, DISPLAYA
, DISPLAYB
, RSVD1
, RSVD2
, RSVD
, OUTPUT
, 0x30d4),
170 PINGROUP(LCD_D13
, LCD
, DISPLAYA
, DISPLAYB
, RSVD1
, RSVD2
, RSVD
, OUTPUT
, 0x30d8),
171 PINGROUP(LCD_D14
, LCD
, DISPLAYA
, DISPLAYB
, RSVD1
, RSVD2
, RSVD
, OUTPUT
, 0x30dc),
172 PINGROUP(LCD_D15
, LCD
, DISPLAYA
, DISPLAYB
, RSVD1
, RSVD2
, RSVD
, OUTPUT
, 0x30e0),
173 PINGROUP(LCD_D16
, LCD
, DISPLAYA
, DISPLAYB
, RSVD1
, RSVD2
, RSVD
, OUTPUT
, 0x30e4),
174 PINGROUP(LCD_D17
, LCD
, DISPLAYA
, DISPLAYB
, RSVD1
, RSVD2
, RSVD
, OUTPUT
, 0x30e8),
175 PINGROUP(LCD_D18
, LCD
, DISPLAYA
, DISPLAYB
, RSVD1
, RSVD2
, RSVD
, OUTPUT
, 0x30ec),
176 PINGROUP(LCD_D19
, LCD
, DISPLAYA
, DISPLAYB
, RSVD1
, RSVD2
, RSVD
, OUTPUT
, 0x30f0),
177 PINGROUP(LCD_D20
, LCD
, DISPLAYA
, DISPLAYB
, RSVD1
, RSVD2
, RSVD
, OUTPUT
, 0x30f4),
178 PINGROUP(LCD_D21
, LCD
, DISPLAYA
, DISPLAYB
, RSVD1
, RSVD2
, RSVD
, OUTPUT
, 0x30f8),
179 PINGROUP(LCD_D22
, LCD
, DISPLAYA
, DISPLAYB
, RSVD1
, RSVD2
, RSVD
, OUTPUT
, 0x30fc),
180 PINGROUP(LCD_D23
, LCD
, DISPLAYA
, DISPLAYB
, RSVD1
, RSVD2
, RSVD
, OUTPUT
, 0x3100),
181 PINGROUP(LCD_CS1_N
, LCD
, DISPLAYA
, DISPLAYB
, SPI5
, RSVD2
, RSVD
, OUTPUT
, 0x3104),
182 PINGROUP(LCD_M1
, LCD
, DISPLAYA
, DISPLAYB
, RSVD1
, RSVD2
, RSVD
, OUTPUT
, 0x3108),
183 PINGROUP(LCD_DC1
, LCD
, DISPLAYA
, DISPLAYB
, RSVD1
, RSVD2
, RSVD
, OUTPUT
, 0x310c),
184 PINGROUP(HDMI_INT
, LCD
, RSVD
, RSVD
, RSVD
, RSVD
, RSVD
, INPUT
, 0x3110),
185 PINGROUP(DDC_SCL
, LCD
, I2C4
, RSVD1
, RSVD2
, RSVD3
, RSVD
, INPUT
, 0x3114),
186 PINGROUP(DDC_SDA
, LCD
, I2C4
, RSVD1
, RSVD2
, RSVD3
, RSVD
, INPUT
, 0x3118),
187 PINGROUP(CRT_HSYNC
, LCD
, CRT
, RSVD1
, RSVD2
, RSVD3
, RSVD
, INPUT
, 0x311c),
188 PINGROUP(CRT_VSYNC
, LCD
, CRT
, RSVD1
, RSVD2
, RSVD3
, RSVD
, INPUT
, 0x3120),
189 PINGROUP(VI_D0
, VI
, INVALID
, RSVD1
, VI
, RSVD2
, RSVD
, INPUT
, 0x3124),
190 PINGROUP(VI_D1
, VI
, INVALID
, SDIO2
, VI
, RSVD1
, RSVD
, INPUT
, 0x3128),
191 PINGROUP(VI_D2
, VI
, INVALID
, SDIO2
, VI
, RSVD1
, RSVD
, INPUT
, 0x312c),
192 PINGROUP(VI_D3
, VI
, INVALID
, SDIO2
, VI
, RSVD1
, RSVD
, INPUT
, 0x3130),
193 PINGROUP(VI_D4
, VI
, INVALID
, SDIO2
, VI
, RSVD1
, RSVD
, INPUT
, 0x3134),
194 PINGROUP(VI_D5
, VI
, INVALID
, SDIO2
, VI
, RSVD1
, RSVD
, INPUT
, 0x3138),
195 PINGROUP(VI_D6
, VI
, INVALID
, SDIO2
, VI
, RSVD1
, RSVD
, INPUT
, 0x313c),
196 PINGROUP(VI_D7
, VI
, INVALID
, SDIO2
, VI
, RSVD1
, RSVD
, INPUT
, 0x3140),
197 PINGROUP(VI_D8
, VI
, INVALID
, SDIO2
, VI
, RSVD1
, RSVD
, INPUT
, 0x3144),
198 PINGROUP(VI_D9
, VI
, INVALID
, SDIO2
, VI
, RSVD1
, RSVD
, INPUT
, 0x3148),
199 PINGROUP(VI_D10
, VI
, INVALID
, RSVD1
, VI
, RSVD2
, RSVD
, INPUT
, 0x314c),
200 PINGROUP(VI_D11
, VI
, INVALID
, RSVD1
, VI
, RSVD2
, RSVD
, INPUT
, 0x3150),
201 PINGROUP(VI_PCLK
, VI
, RSVD1
, SDIO2
, VI
, RSVD2
, RSVD
, INPUT
, 0x3154),
202 PINGROUP(VI_MCLK
, VI
, VI
, INVALID
, INVALID
, INVALID
, RSVD
, INPUT
, 0x3158),
203 PINGROUP(VI_VSYNC
, VI
, INVALID
, RSVD1
, VI
, RSVD2
, RSVD
, INPUT
, 0x315c),
204 PINGROUP(VI_HSYNC
, VI
, INVALID
, RSVD1
, VI
, RSVD2
, RSVD
, INPUT
, 0x3160),
205 PINGROUP(UART2_RXD
, UART
, IRDA
, SPDIF
, UARTA
, SPI4
, RSVD
, INPUT
, 0x3164),
206 PINGROUP(UART2_TXD
, UART
, IRDA
, SPDIF
, UARTA
, SPI4
, RSVD
, INPUT
, 0x3168),
207 PINGROUP(UART2_RTS_N
, UART
, UARTA
, UARTB
, GMI
, SPI4
, RSVD
, INPUT
, 0x316c),
208 PINGROUP(UART2_CTS_N
, UART
, UARTA
, UARTB
, GMI
, SPI4
, RSVD
, INPUT
, 0x3170),
209 PINGROUP(UART3_TXD
, UART
, UARTC
, RSVD1
, GMI
, RSVD2
, RSVD
, INPUT
, 0x3174),
210 PINGROUP(UART3_RXD
, UART
, UARTC
, RSVD1
, GMI
, RSVD2
, RSVD
, INPUT
, 0x3178),
211 PINGROUP(UART3_CTS_N
, UART
, UARTC
, RSVD1
, GMI
, RSVD2
, RSVD
, INPUT
, 0x317c),
212 PINGROUP(UART3_RTS_N
, UART
, UARTC
, PWM0
, GMI
, RSVD2
, RSVD
, INPUT
, 0x3180),
213 PINGROUP(GPIO_PU0
, UART
, OWR
, UARTA
, GMI
, RSVD1
, RSVD
, INPUT
, 0x3184),
214 PINGROUP(GPIO_PU1
, UART
, RSVD1
, UARTA
, GMI
, RSVD2
, RSVD
, INPUT
, 0x3188),
215 PINGROUP(GPIO_PU2
, UART
, RSVD1
, UARTA
, GMI
, RSVD2
, RSVD
, INPUT
, 0x318c),
216 PINGROUP(GPIO_PU3
, UART
, PWM0
, UARTA
, GMI
, RSVD1
, RSVD
, INPUT
, 0x3190),
217 PINGROUP(GPIO_PU4
, UART
, PWM1
, UARTA
, GMI
, RSVD1
, RSVD
, INPUT
, 0x3194),
218 PINGROUP(GPIO_PU5
, UART
, PWM2
, UARTA
, GMI
, RSVD1
, RSVD
, INPUT
, 0x3198),
219 PINGROUP(GPIO_PU6
, UART
, PWM3
, UARTA
, GMI
, RSVD1
, RSVD
, INPUT
, 0x319c),
220 PINGROUP(GEN1_I2C_SDA
, UART
, I2C
, RSVD1
, RSVD2
, RSVD3
, RSVD
, INPUT
, 0x31a0),
221 PINGROUP(GEN1_I2C_SCL
, UART
, I2C
, RSVD1
, RSVD2
, RSVD3
, RSVD
, INPUT
, 0x31a4),
222 PINGROUP(DAP4_FS
, UART
, I2S3
, RSVD1
, GMI
, RSVD2
, RSVD
, INPUT
, 0x31a8),
223 PINGROUP(DAP4_DIN
, UART
, I2S3
, RSVD1
, GMI
, RSVD2
, RSVD
, INPUT
, 0x31ac),
224 PINGROUP(DAP4_DOUT
, UART
, I2S3
, RSVD1
, GMI
, RSVD2
, RSVD
, INPUT
, 0x31b0),
225 PINGROUP(DAP4_SCLK
, UART
, I2S3
, RSVD1
, GMI
, RSVD2
, RSVD
, INPUT
, 0x31b4),
226 PINGROUP(CLK3_OUT
, UART
, EXTPERIPH3
, RSVD1
, RSVD2
, RSVD3
, RSVD
, INPUT
, 0x31b8),
227 PINGROUP(CLK3_REQ
, UART
, DEV3
, RSVD1
, RSVD2
, RSVD3
, RSVD
, INPUT
, 0x31bc),
228 PINGROUP(GMI_WP_N
, GMI
, RSVD1
, NAND
, GMI
, GMI_ALT
, RSVD
, INPUT
, 0x31c0),
229 PINGROUP(GMI_IORDY
, GMI
, RSVD1
, NAND
, GMI
, RSVD2
, RSVD
, INPUT
, 0x31c4),
230 PINGROUP(GMI_WAIT
, GMI
, RSVD1
, NAND
, GMI
, RSVD2
, RSVD
, INPUT
, 0x31c8),
231 PINGROUP(GMI_ADV_N
, GMI
, RSVD1
, NAND
, GMI
, RSVD2
, RSVD
, INPUT
, 0x31cc),
232 PINGROUP(GMI_CLK
, GMI
, RSVD1
, NAND
, GMI
, RSVD2
, RSVD
, INPUT
, 0x31d0),
233 PINGROUP(GMI_CS0_N
, GMI
, RSVD1
, NAND
, GMI
, INVALID
, RSVD
, INPUT
, 0x31d4),
234 PINGROUP(GMI_CS1_N
, GMI
, RSVD1
, NAND
, GMI
, DTV
, RSVD
, INPUT
, 0x31d8),
235 PINGROUP(GMI_CS2_N
, GMI
, RSVD1
, NAND
, GMI
, RSVD2
, RSVD
, INPUT
, 0x31dc),
236 PINGROUP(GMI_CS3_N
, GMI
, RSVD1
, NAND
, GMI
, GMI_ALT
, RSVD
, INPUT
, 0x31e0),
237 PINGROUP(GMI_CS4_N
, GMI
, RSVD1
, NAND
, GMI
, RSVD2
, RSVD
, INPUT
, 0x31e4),
238 PINGROUP(GMI_CS6_N
, GMI
, NAND
, NAND_ALT
, GMI
, SATA
, RSVD
, INPUT
, 0x31e8),
239 PINGROUP(GMI_CS7_N
, GMI
, NAND
, NAND_ALT
, GMI
, GMI_ALT
, RSVD
, INPUT
, 0x31ec),
240 PINGROUP(GMI_AD0
, GMI
, RSVD1
, NAND
, GMI
, RSVD2
, RSVD
, INPUT
, 0x31f0),
241 PINGROUP(GMI_AD1
, GMI
, RSVD1
, NAND
, GMI
, RSVD2
, RSVD
, INPUT
, 0x31f4),
242 PINGROUP(GMI_AD2
, GMI
, RSVD1
, NAND
, GMI
, RSVD2
, RSVD
, INPUT
, 0x31f8),
243 PINGROUP(GMI_AD3
, GMI
, RSVD1
, NAND
, GMI
, RSVD2
, RSVD
, INPUT
, 0x31fc),
244 PINGROUP(GMI_AD4
, GMI
, RSVD1
, NAND
, GMI
, RSVD2
, RSVD
, INPUT
, 0x3200),
245 PINGROUP(GMI_AD5
, GMI
, RSVD1
, NAND
, GMI
, RSVD2
, RSVD
, INPUT
, 0x3204),
246 PINGROUP(GMI_AD6
, GMI
, RSVD1
, NAND
, GMI
, RSVD2
, RSVD
, INPUT
, 0x3208),
247 PINGROUP(GMI_AD7
, GMI
, RSVD1
, NAND
, GMI
, RSVD2
, RSVD
, INPUT
, 0x320c),
248 PINGROUP(GMI_AD8
, GMI
, PWM0
, NAND
, GMI
, RSVD2
, RSVD
, INPUT
, 0x3210),
249 PINGROUP(GMI_AD9
, GMI
, PWM1
, NAND
, GMI
, RSVD2
, RSVD
, INPUT
, 0x3214),
250 PINGROUP(GMI_AD10
, GMI
, PWM2
, NAND
, GMI
, RSVD2
, RSVD
, INPUT
, 0x3218),
251 PINGROUP(GMI_AD11
, GMI
, PWM3
, NAND
, GMI
, RSVD2
, RSVD
, INPUT
, 0x321c),
252 PINGROUP(GMI_AD12
, GMI
, RSVD1
, NAND
, GMI
, RSVD2
, RSVD
, INPUT
, 0x3220),
253 PINGROUP(GMI_AD13
, GMI
, RSVD1
, NAND
, GMI
, RSVD2
, RSVD
, INPUT
, 0x3224),
254 PINGROUP(GMI_AD14
, GMI
, RSVD1
, NAND
, GMI
, RSVD2
, RSVD
, INPUT
, 0x3228),
255 PINGROUP(GMI_AD15
, GMI
, RSVD1
, NAND
, GMI
, RSVD2
, RSVD
, INPUT
, 0x322c),
256 PINGROUP(GMI_A16
, GMI
, UARTD
, SPI4
, GMI
, GMI_ALT
, RSVD
, INPUT
, 0x3230),
257 PINGROUP(GMI_A17
, GMI
, UARTD
, SPI4
, GMI
, INVALID
, RSVD
, INPUT
, 0x3234),
258 PINGROUP(GMI_A18
, GMI
, UARTD
, SPI4
, GMI
, INVALID
, RSVD
, INPUT
, 0x3238),
259 PINGROUP(GMI_A19
, GMI
, UARTD
, SPI4
, GMI
, RSVD3
, RSVD
, INPUT
, 0x323c),
260 PINGROUP(GMI_WR_N
, GMI
, RSVD1
, NAND
, GMI
, RSVD3
, RSVD
, INPUT
, 0x3240),
261 PINGROUP(GMI_OE_N
, GMI
, RSVD1
, NAND
, GMI
, RSVD3
, RSVD
, INPUT
, 0x3244),
262 PINGROUP(GMI_DQS
, GMI
, RSVD1
, NAND
, GMI
, RSVD3
, RSVD
, INPUT
, 0x3248),
263 PINGROUP(GMI_RST_N
, GMI
, NAND
, NAND_ALT
, GMI
, RSVD3
, RSVD
, INPUT
, 0x324c),
264 PINGROUP(GEN2_I2C_SCL
, GMI
, I2C2
, INVALID
, GMI
, RSVD3
, RSVD
, INPUT
, 0x3250),
265 PINGROUP(GEN2_I2C_SDA
, GMI
, I2C2
, INVALID
, GMI
, RSVD3
, RSVD
, INPUT
, 0x3254),
266 PINGROUP(SDMMC4_CLK
, SDMMC4
, INVALID
, NAND
, GMI
, SDIO4
, RSVD
, INPUT
, 0x3258),
267 PINGROUP(SDMMC4_CMD
, SDMMC4
, I2C3
, NAND
, GMI
, SDIO4
, RSVD
, INPUT
, 0x325c),
268 PINGROUP(SDMMC4_DAT0
, SDMMC4
, UARTE
, SPI3
, GMI
, SDIO4
, RSVD
, INPUT
, 0x3260),
269 PINGROUP(SDMMC4_DAT1
, SDMMC4
, UARTE
, SPI3
, GMI
, SDIO4
, RSVD
, INPUT
, 0x3264),
270 PINGROUP(SDMMC4_DAT2
, SDMMC4
, UARTE
, SPI3
, GMI
, SDIO4
, RSVD
, INPUT
, 0x3268),
271 PINGROUP(SDMMC4_DAT3
, SDMMC4
, UARTE
, SPI3
, GMI
, SDIO4
, RSVD
, INPUT
, 0x326c),
272 PINGROUP(SDMMC4_DAT4
, SDMMC4
, I2C3
, I2S4
, GMI
, SDIO4
, RSVD
, INPUT
, 0x3270),
273 PINGROUP(SDMMC4_DAT5
, SDMMC4
, VGP3
, I2S4
, GMI
, SDIO4
, RSVD
, INPUT
, 0x3274),
274 PINGROUP(SDMMC4_DAT6
, SDMMC4
, VGP4
, I2S4
, GMI
, SDIO4
, RSVD
, INPUT
, 0x3278),
275 PINGROUP(SDMMC4_DAT7
, SDMMC4
, VGP5
, I2S4
, GMI
, SDIO4
, RSVD
, INPUT
, 0x327c),
276 PINGROUP(SDMMC4_RST_N
, SDMMC4
, VGP6
, RSVD1
, RSVD2
, POPSDMMC4
, RSVD
, INPUT
, 0x3280),
277 PINGROUP(CAM_MCLK
, CAM
, VI
, INVALID
, VI_ALT2
, POPSDMMC4
, RSVD
, INPUT
, 0x3284),
278 PINGROUP(GPIO_PCC1
, CAM
, I2S4
, RSVD1
, RSVD2
, POPSDMMC4
, RSVD
, INPUT
, 0x3288),
279 PINGROUP(GPIO_PBB0
, CAM
, I2S4
, RSVD1
, RSVD2
, POPSDMMC4
, RSVD
, INPUT
, 0x328c),
280 PINGROUP(CAM_I2C_SCL
, CAM
, INVALID
, I2C3
, RSVD2
, POPSDMMC4
, RSVD
, INPUT
, 0x3290),
281 PINGROUP(CAM_I2C_SDA
, CAM
, INVALID
, I2C3
, RSVD2
, POPSDMMC4
, RSVD
, INPUT
, 0x3294),
282 PINGROUP(GPIO_PBB3
, CAM
, VGP3
, DISPLAYA
, DISPLAYB
, POPSDMMC4
, RSVD
, INPUT
, 0x3298),
283 PINGROUP(GPIO_PBB4
, CAM
, VGP4
, DISPLAYA
, DISPLAYB
, POPSDMMC4
, RSVD
, INPUT
, 0x329c),
284 PINGROUP(GPIO_PBB5
, CAM
, VGP5
, DISPLAYA
, DISPLAYB
, POPSDMMC4
, RSVD
, INPUT
, 0x32a0),
285 PINGROUP(GPIO_PBB6
, CAM
, VGP6
, DISPLAYA
, DISPLAYB
, POPSDMMC4
, RSVD
, INPUT
, 0x32a4),
286 PINGROUP(GPIO_PBB7
, CAM
, I2S4
, RSVD1
, RSVD2
, POPSDMMC4
, RSVD
, INPUT
, 0x32a8),
287 PINGROUP(GPIO_PCC2
, CAM
, I2S4
, RSVD1
, RSVD2
, RSVD3
, RSVD
, INPUT
, 0x32ac),
288 PINGROUP(JTAG_RTCK
, SYS
, RTCK
, RSVD1
, RSVD2
, RSVD3
, RSVD
, INPUT
, 0x32b0),
289 PINGROUP(PWR_I2C_SCL
, SYS
, I2CPWR
, RSVD1
, RSVD2
, RSVD3
, RSVD
, INPUT
, 0x32b4),
290 PINGROUP(PWR_I2C_SDA
, SYS
, I2CPWR
, RSVD1
, RSVD2
, RSVD3
, RSVD
, INPUT
, 0x32b8),
291 PINGROUP(KB_ROW0
, SYS
, KBC
, INVALID
, RSVD2
, RSVD3
, RSVD
, INPUT
, 0x32bc),
292 PINGROUP(KB_ROW1
, SYS
, KBC
, INVALID
, RSVD2
, RSVD3
, RSVD
, INPUT
, 0x32c0),
293 PINGROUP(KB_ROW2
, SYS
, KBC
, INVALID
, RSVD2
, RSVD3
, RSVD
, INPUT
, 0x32c4),
294 PINGROUP(KB_ROW3
, SYS
, KBC
, INVALID
, RSVD2
, INVALID
, RSVD
, INPUT
, 0x32c8),
295 PINGROUP(KB_ROW4
, SYS
, KBC
, INVALID
, TRACE
, RSVD3
, RSVD
, INPUT
, 0x32cc),
296 PINGROUP(KB_ROW5
, SYS
, KBC
, INVALID
, TRACE
, OWR
, RSVD
, INPUT
, 0x32d0),
297 PINGROUP(KB_ROW6
, SYS
, KBC
, INVALID
, SDIO2
, INVALID
, RSVD
, INPUT
, 0x32d4),
298 PINGROUP(KB_ROW7
, SYS
, KBC
, INVALID
, SDIO2
, INVALID
, RSVD
, INPUT
, 0x32d8),
299 PINGROUP(KB_ROW8
, SYS
, KBC
, INVALID
, SDIO2
, INVALID
, RSVD
, INPUT
, 0x32dc),
300 PINGROUP(KB_ROW9
, SYS
, KBC
, INVALID
, SDIO2
, INVALID
, RSVD
, INPUT
, 0x32e0),
301 PINGROUP(KB_ROW10
, SYS
, KBC
, INVALID
, SDIO2
, INVALID
, RSVD
, INPUT
, 0x32e4),
302 PINGROUP(KB_ROW11
, SYS
, KBC
, INVALID
, SDIO2
, INVALID
, RSVD
, INPUT
, 0x32e8),
303 PINGROUP(KB_ROW12
, SYS
, KBC
, INVALID
, SDIO2
, INVALID
, RSVD
, INPUT
, 0x32ec),
304 PINGROUP(KB_ROW13
, SYS
, KBC
, INVALID
, SDIO2
, INVALID
, RSVD
, INPUT
, 0x32f0),
305 PINGROUP(KB_ROW14
, SYS
, KBC
, INVALID
, SDIO2
, INVALID
, RSVD
, INPUT
, 0x32f4),
306 PINGROUP(KB_ROW15
, SYS
, KBC
, INVALID
, SDIO2
, INVALID
, RSVD
, INPUT
, 0x32f8),
307 PINGROUP(KB_COL0
, SYS
, KBC
, INVALID
, TRACE
, INVALID
, RSVD
, INPUT
, 0x32fc),
308 PINGROUP(KB_COL1
, SYS
, KBC
, INVALID
, TRACE
, INVALID
, RSVD
, INPUT
, 0x3300),
309 PINGROUP(KB_COL2
, SYS
, KBC
, INVALID
, TRACE
, RSVD
, RSVD
, INPUT
, 0x3304),
310 PINGROUP(KB_COL3
, SYS
, KBC
, INVALID
, TRACE
, RSVD
, RSVD
, INPUT
, 0x3308),
311 PINGROUP(KB_COL4
, SYS
, KBC
, INVALID
, TRACE
, RSVD
, RSVD
, INPUT
, 0x330c),
312 PINGROUP(KB_COL5
, SYS
, KBC
, INVALID
, TRACE
, RSVD
, RSVD
, INPUT
, 0x3310),
313 PINGROUP(KB_COL6
, SYS
, KBC
, INVALID
, TRACE
, INVALID
, RSVD
, INPUT
, 0x3314),
314 PINGROUP(KB_COL7
, SYS
, KBC
, INVALID
, TRACE
, INVALID
, RSVD
, INPUT
, 0x3318),
315 PINGROUP(CLK_32K_OUT
, SYS
, BLINK
, RSVD1
, RSVD2
, RSVD3
, RSVD
, INPUT
, 0x331c),
316 PINGROUP(SYS_CLK_REQ
, SYS
, SYSCLK
, RSVD1
, RSVD2
, RSVD3
, RSVD
, INPUT
, 0x3320),
317 PINGROUP(CORE_PWR_REQ
, SYS
, RSVD
, RSVD
, RSVD
, RSVD
, RSVD
, INPUT
, 0x3324),
318 PINGROUP(CPU_PWR_REQ
, SYS
, RSVD
, RSVD
, RSVD
, RSVD
, RSVD
, INPUT
, 0x3328),
319 PINGROUP(PWR_INT_N
, SYS
, RSVD
, RSVD
, RSVD
, RSVD
, RSVD
, INPUT
, 0x332c),
320 PINGROUP(CLK_32K_IN
, SYS
, RSVD
, RSVD
, RSVD
, RSVD
, RSVD
, INPUT
, 0x3330),
321 PINGROUP(OWR
, SYS
, OWR
, RSVD
, RSVD
, RSVD
, RSVD
, INPUT
, 0x3334),
322 PINGROUP(DAP1_FS
, AUDIO
, I2S0
, HDA
, GMI
, SDIO2
, RSVD
, INPUT
, 0x3338),
323 PINGROUP(DAP1_DIN
, AUDIO
, I2S0
, HDA
, GMI
, SDIO2
, RSVD
, INPUT
, 0x333c),
324 PINGROUP(DAP1_DOUT
, AUDIO
, I2S0
, HDA
, GMI
, SDIO2
, RSVD
, INPUT
, 0x3340),
325 PINGROUP(DAP1_SCLK
, AUDIO
, I2S0
, HDA
, GMI
, SDIO2
, RSVD
, INPUT
, 0x3344),
326 PINGROUP(CLK1_REQ
, AUDIO
, DAP
, HDA
, RSVD2
, RSVD3
, RSVD
, INPUT
, 0x3348),
327 PINGROUP(CLK1_OUT
, AUDIO
, EXTPERIPH1
, RSVD1
, RSVD2
, RSVD3
, RSVD
, INPUT
, 0x334c),
328 PINGROUP(SPDIF_IN
, AUDIO
, SPDIF
, HDA
, INVALID
, DAPSDMMC2
, RSVD
, INPUT
, 0x3350),
329 PINGROUP(SPDIF_OUT
, AUDIO
, SPDIF
, RSVD1
, INVALID
, DAPSDMMC2
, RSVD
, INPUT
, 0x3354),
330 PINGROUP(DAP2_FS
, AUDIO
, I2S1
, HDA
, RSVD2
, GMI
, RSVD
, INPUT
, 0x3358),
331 PINGROUP(DAP2_DIN
, AUDIO
, I2S1
, HDA
, RSVD2
, GMI
, RSVD
, INPUT
, 0x335c),
332 PINGROUP(DAP2_DOUT
, AUDIO
, I2S1
, HDA
, RSVD2
, GMI
, RSVD
, INPUT
, 0x3360),
333 PINGROUP(DAP2_SCLK
, AUDIO
, I2S1
, HDA
, RSVD2
, GMI
, RSVD
, INPUT
, 0x3364),
334 PINGROUP(SPI2_MOSI
, AUDIO
, SPI6
, SPI2
, INVALID
, GMI
, RSVD
, INPUT
, 0x3368),
335 PINGROUP(SPI2_MISO
, AUDIO
, SPI6
, SPI2
, INVALID
, GMI
, RSVD
, INPUT
, 0x336c),
336 PINGROUP(SPI2_CS0_N
, AUDIO
, SPI6
, SPI2
, INVALID
, GMI
, RSVD
, INPUT
, 0x3370),
337 PINGROUP(SPI2_SCK
, AUDIO
, SPI6
, SPI2
, INVALID
, GMI
, RSVD
, INPUT
, 0x3374),
338 PINGROUP(SPI1_MOSI
, AUDIO
, SPI2
, SPI1
, INVALID
, GMI
, RSVD
, INPUT
, 0x3378),
339 PINGROUP(SPI1_SCK
, AUDIO
, SPI2
, SPI1
, INVALID
, GMI
, RSVD
, INPUT
, 0x337c),
340 PINGROUP(SPI1_CS0_N
, AUDIO
, SPI2
, SPI1
, INVALID
, GMI
, RSVD
, INPUT
, 0x3380),
341 PINGROUP(SPI1_MISO
, AUDIO
, INVALID
, SPI1
, INVALID
, RSVD3
, RSVD
, INPUT
, 0x3384),
342 PINGROUP(SPI2_CS1_N
, AUDIO
, INVALID
, SPI2
, INVALID
, INVALID
, RSVD
, INPUT
, 0x3388),
343 PINGROUP(SPI2_CS2_N
, AUDIO
, INVALID
, SPI2
, INVALID
, INVALID
, RSVD
, INPUT
, 0x338c),
344 PINGROUP(SDMMC3_CLK
, SDMMC3
, UARTA
, PWM2
, SDIO3
, INVALID
, RSVD
, INPUT
, 0x3390),
345 PINGROUP(SDMMC3_CMD
, SDMMC3
, UARTA
, PWM3
, SDIO3
, INVALID
, RSVD
, INPUT
, 0x3394),
346 PINGROUP(SDMMC3_DAT0
, SDMMC3
, RSVD
, RSVD1
, SDIO3
, INVALID
, RSVD
, INPUT
, 0x3398),
347 PINGROUP(SDMMC3_DAT1
, SDMMC3
, RSVD
, RSVD1
, SDIO3
, INVALID
, RSVD
, INPUT
, 0x339c),
348 PINGROUP(SDMMC3_DAT2
, SDMMC3
, RSVD
, PWM1
, SDIO3
, INVALID
, RSVD
, INPUT
, 0x33a0),
349 PINGROUP(SDMMC3_DAT3
, SDMMC3
, RSVD
, PWM0
, SDIO3
, INVALID
, RSVD
, INPUT
, 0x33a4),
350 PINGROUP(SDMMC3_DAT4
, SDMMC3
, PWM1
, INVALID
, SDIO3
, INVALID
, RSVD
, INPUT
, 0x33a8),
351 PINGROUP(SDMMC3_DAT5
, SDMMC3
, PWM0
, INVALID
, SDIO3
, INVALID
, RSVD
, INPUT
, 0x33ac),
352 PINGROUP(SDMMC3_DAT6
, SDMMC3
, SPDIF
, INVALID
, SDIO3
, INVALID
, RSVD
, INPUT
, 0x33b0),
353 PINGROUP(SDMMC3_DAT7
, SDMMC3
, SPDIF
, INVALID
, SDIO3
, INVALID
, RSVD
, INPUT
, 0x33b4),
354 PINGROUP(PEX_L0_PRSNT_N
, PEXCTL
, PCIE
, HDA
, RSVD2
, RSVD3
, RSVD
, INPUT
, 0x33b8),
355 PINGROUP(PEX_L0_RST_N
, PEXCTL
, PCIE
, HDA
, RSVD2
, RSVD3
, RSVD
, INPUT
, 0x33bc),
356 PINGROUP(PEX_L0_CLKREQ_N
, PEXCTL
, PCIE
, HDA
, RSVD2
, RSVD3
, RSVD
, INPUT
, 0x33c0),
357 PINGROUP(PEX_WAKE_N
, PEXCTL
, PCIE
, HDA
, RSVD2
, RSVD3
, RSVD
, INPUT
, 0x33c4),
358 PINGROUP(PEX_L1_PRSNT_N
, PEXCTL
, PCIE
, HDA
, RSVD2
, RSVD3
, RSVD
, INPUT
, 0x33c8),
359 PINGROUP(PEX_L1_RST_N
, PEXCTL
, PCIE
, HDA
, RSVD2
, RSVD3
, RSVD
, INPUT
, 0x33cc),
360 PINGROUP(PEX_L1_CLKREQ_N
, PEXCTL
, PCIE
, HDA
, RSVD2
, RSVD3
, RSVD
, INPUT
, 0x33d0),
361 PINGROUP(PEX_L2_PRSNT_N
, PEXCTL
, PCIE
, HDA
, RSVD2
, RSVD3
, RSVD
, INPUT
, 0x33d4),
362 PINGROUP(PEX_L2_RST_N
, PEXCTL
, PCIE
, HDA
, RSVD2
, RSVD3
, RSVD
, INPUT
, 0x33d8),
363 PINGROUP(PEX_L2_CLKREQ_N
, PEXCTL
, PCIE
, HDA
, RSVD2
, RSVD3
, RSVD
, INPUT
, 0x33dc),
364 PINGROUP(HDMI_CEC
, SYS
, CEC
, RSVD1
, RSVD2
, RSVD3
, RSVD
, INPUT
, 0x33e0),
367 void __devinit
tegra30_pinmux_init(const struct tegra_pingroup_desc
**pg
,
368 int *pg_max
, const struct tegra_drive_pingroup_desc
**pgdrive
,
371 *pg
= tegra_soc_pingroups
;
372 *pg_max
= TEGRA_MAX_PINGROUP
;
373 *pgdrive
= tegra_soc_drive_pingroups
;
374 *pgdrive_max
= TEGRA_MAX_DRIVE_PINGROUP
;