linux/drivers/pinctrl/pinctrl-tegra30.c
<<
>>
Prefs
   1/*
   2 * Pinctrl data for the NVIDIA Tegra30 pinmux
   3 *
   4 * Copyright (c) 2011-2012, NVIDIA CORPORATION.  All rights reserved.
   5 *
   6 * This program is free software; you can redistribute it and/or modify it
   7 * under the terms and conditions of the GNU General Public License,
   8 * version 2, as published by the Free Software Foundation.
   9 *
  10 * This program is distributed in the hope it will be useful, but WITHOUT
  11 * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
  12 * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License for
  13 * more details.
  14 */
  15
  16#include <linux/module.h>
  17#include <linux/of.h>
  18#include <linux/platform_device.h>
  19#include <linux/pinctrl/pinctrl.h>
  20#include <linux/pinctrl/pinmux.h>
  21
  22#include "pinctrl-tegra.h"
  23
  24/*
  25 * Most pins affected by the pinmux can also be GPIOs. Define these first.
  26 * These must match how the GPIO driver names/numbers its pins.
  27 */
  28#define _GPIO(offset)                           (offset)
  29
  30#define TEGRA_PIN_CLK_32K_OUT_PA0       _GPIO(0)
  31#define TEGRA_PIN_UART3_CTS_N_PA1       _GPIO(1)
  32#define TEGRA_PIN_DAP2_FS_PA2           _GPIO(2)
  33#define TEGRA_PIN_DAP2_SCLK_PA3         _GPIO(3)
  34#define TEGRA_PIN_DAP2_DIN_PA4          _GPIO(4)
  35#define TEGRA_PIN_DAP2_DOUT_PA5         _GPIO(5)
  36#define TEGRA_PIN_SDMMC3_CLK_PA6        _GPIO(6)
  37#define TEGRA_PIN_SDMMC3_CMD_PA7        _GPIO(7)
  38#define TEGRA_PIN_GMI_A17_PB0           _GPIO(8)
  39#define TEGRA_PIN_GMI_A18_PB1           _GPIO(9)
  40#define TEGRA_PIN_LCD_PWR0_PB2          _GPIO(10)
  41#define TEGRA_PIN_LCD_PCLK_PB3          _GPIO(11)
  42#define TEGRA_PIN_SDMMC3_DAT3_PB4       _GPIO(12)
  43#define TEGRA_PIN_SDMMC3_DAT2_PB5       _GPIO(13)
  44#define TEGRA_PIN_SDMMC3_DAT1_PB6       _GPIO(14)
  45#define TEGRA_PIN_SDMMC3_DAT0_PB7       _GPIO(15)
  46#define TEGRA_PIN_UART3_RTS_N_PC0       _GPIO(16)
  47#define TEGRA_PIN_LCD_PWR1_PC1          _GPIO(17)
  48#define TEGRA_PIN_UART2_TXD_PC2         _GPIO(18)
  49#define TEGRA_PIN_UART2_RXD_PC3         _GPIO(19)
  50#define TEGRA_PIN_GEN1_I2C_SCL_PC4      _GPIO(20)
  51#define TEGRA_PIN_GEN1_I2C_SDA_PC5      _GPIO(21)
  52#define TEGRA_PIN_LCD_PWR2_PC6          _GPIO(22)
  53#define TEGRA_PIN_GMI_WP_N_PC7          _GPIO(23)
  54#define TEGRA_PIN_SDMMC3_DAT5_PD0       _GPIO(24)
  55#define TEGRA_PIN_SDMMC3_DAT4_PD1       _GPIO(25)
  56#define TEGRA_PIN_LCD_DC1_PD2           _GPIO(26)
  57#define TEGRA_PIN_SDMMC3_DAT6_PD3       _GPIO(27)
  58#define TEGRA_PIN_SDMMC3_DAT7_PD4       _GPIO(28)
  59#define TEGRA_PIN_VI_D1_PD5             _GPIO(29)
  60#define TEGRA_PIN_VI_VSYNC_PD6          _GPIO(30)
  61#define TEGRA_PIN_VI_HSYNC_PD7          _GPIO(31)
  62#define TEGRA_PIN_LCD_D0_PE0            _GPIO(32)
  63#define TEGRA_PIN_LCD_D1_PE1            _GPIO(33)
  64#define TEGRA_PIN_LCD_D2_PE2            _GPIO(34)
  65#define TEGRA_PIN_LCD_D3_PE3            _GPIO(35)
  66#define TEGRA_PIN_LCD_D4_PE4            _GPIO(36)
  67#define TEGRA_PIN_LCD_D5_PE5            _GPIO(37)
  68#define TEGRA_PIN_LCD_D6_PE6            _GPIO(38)
  69#define TEGRA_PIN_LCD_D7_PE7            _GPIO(39)
  70#define TEGRA_PIN_LCD_D8_PF0            _GPIO(40)
  71#define TEGRA_PIN_LCD_D9_PF1            _GPIO(41)
  72#define TEGRA_PIN_LCD_D10_PF2           _GPIO(42)
  73#define TEGRA_PIN_LCD_D11_PF3           _GPIO(43)
  74#define TEGRA_PIN_LCD_D12_PF4           _GPIO(44)
  75#define TEGRA_PIN_LCD_D13_PF5           _GPIO(45)
  76#define TEGRA_PIN_LCD_D14_PF6           _GPIO(46)
  77#define TEGRA_PIN_LCD_D15_PF7           _GPIO(47)
  78#define TEGRA_PIN_GMI_AD0_PG0           _GPIO(48)
  79#define TEGRA_PIN_GMI_AD1_PG1           _GPIO(49)
  80#define TEGRA_PIN_GMI_AD2_PG2           _GPIO(50)
  81#define TEGRA_PIN_GMI_AD3_PG3           _GPIO(51)
  82#define TEGRA_PIN_GMI_AD4_PG4           _GPIO(52)
  83#define TEGRA_PIN_GMI_AD5_PG5           _GPIO(53)
  84#define TEGRA_PIN_GMI_AD6_PG6           _GPIO(54)
  85#define TEGRA_PIN_GMI_AD7_PG7           _GPIO(55)
  86#define TEGRA_PIN_GMI_AD8_PH0           _GPIO(56)
  87#define TEGRA_PIN_GMI_AD9_PH1           _GPIO(57)
  88#define TEGRA_PIN_GMI_AD10_PH2          _GPIO(58)
  89#define TEGRA_PIN_GMI_AD11_PH3          _GPIO(59)
  90#define TEGRA_PIN_GMI_AD12_PH4          _GPIO(60)
  91#define TEGRA_PIN_GMI_AD13_PH5          _GPIO(61)
  92#define TEGRA_PIN_GMI_AD14_PH6          _GPIO(62)
  93#define TEGRA_PIN_GMI_AD15_PH7          _GPIO(63)
  94#define TEGRA_PIN_GMI_WR_N_PI0          _GPIO(64)
  95#define TEGRA_PIN_GMI_OE_N_PI1          _GPIO(65)
  96#define TEGRA_PIN_GMI_DQS_PI2           _GPIO(66)
  97#define TEGRA_PIN_GMI_CS6_N_PI3         _GPIO(67)
  98#define TEGRA_PIN_GMI_RST_N_PI4         _GPIO(68)
  99#define TEGRA_PIN_GMI_IORDY_PI5         _GPIO(69)
 100#define TEGRA_PIN_GMI_CS7_N_PI6         _GPIO(70)
 101#define TEGRA_PIN_GMI_WAIT_PI7          _GPIO(71)
 102#define TEGRA_PIN_GMI_CS0_N_PJ0         _GPIO(72)
 103#define TEGRA_PIN_LCD_DE_PJ1            _GPIO(73)
 104#define TEGRA_PIN_GMI_CS1_N_PJ2         _GPIO(74)
 105#define TEGRA_PIN_LCD_HSYNC_PJ3         _GPIO(75)
 106#define TEGRA_PIN_LCD_VSYNC_PJ4         _GPIO(76)
 107#define TEGRA_PIN_UART2_CTS_N_PJ5       _GPIO(77)
 108#define TEGRA_PIN_UART2_RTS_N_PJ6       _GPIO(78)
 109#define TEGRA_PIN_GMI_A16_PJ7           _GPIO(79)
 110#define TEGRA_PIN_GMI_ADV_N_PK0         _GPIO(80)
 111#define TEGRA_PIN_GMI_CLK_PK1           _GPIO(81)
 112#define TEGRA_PIN_GMI_CS4_N_PK2         _GPIO(82)
 113#define TEGRA_PIN_GMI_CS2_N_PK3         _GPIO(83)
 114#define TEGRA_PIN_GMI_CS3_N_PK4         _GPIO(84)
 115#define TEGRA_PIN_SPDIF_OUT_PK5         _GPIO(85)
 116#define TEGRA_PIN_SPDIF_IN_PK6          _GPIO(86)
 117#define TEGRA_PIN_GMI_A19_PK7           _GPIO(87)
 118#define TEGRA_PIN_VI_D2_PL0             _GPIO(88)
 119#define TEGRA_PIN_VI_D3_PL1             _GPIO(89)
 120#define TEGRA_PIN_VI_D4_PL2             _GPIO(90)
 121#define TEGRA_PIN_VI_D5_PL3             _GPIO(91)
 122#define TEGRA_PIN_VI_D6_PL4             _GPIO(92)
 123#define TEGRA_PIN_VI_D7_PL5             _GPIO(93)
 124#define TEGRA_PIN_VI_D8_PL6             _GPIO(94)
 125#define TEGRA_PIN_VI_D9_PL7             _GPIO(95)
 126#define TEGRA_PIN_LCD_D16_PM0           _GPIO(96)
 127#define TEGRA_PIN_LCD_D17_PM1           _GPIO(97)
 128#define TEGRA_PIN_LCD_D18_PM2           _GPIO(98)
 129#define TEGRA_PIN_LCD_D19_PM3           _GPIO(99)
 130#define TEGRA_PIN_LCD_D20_PM4           _GPIO(100)
 131#define TEGRA_PIN_LCD_D21_PM5           _GPIO(101)
 132#define TEGRA_PIN_LCD_D22_PM6           _GPIO(102)
 133#define TEGRA_PIN_LCD_D23_PM7           _GPIO(103)
 134#define TEGRA_PIN_DAP1_FS_PN0           _GPIO(104)
 135#define TEGRA_PIN_DAP1_DIN_PN1          _GPIO(105)
 136#define TEGRA_PIN_DAP1_DOUT_PN2         _GPIO(106)
 137#define TEGRA_PIN_DAP1_SCLK_PN3         _GPIO(107)
 138#define TEGRA_PIN_LCD_CS0_N_PN4         _GPIO(108)
 139#define TEGRA_PIN_LCD_SDOUT_PN5         _GPIO(109)
 140#define TEGRA_PIN_LCD_DC0_PN6           _GPIO(110)
 141#define TEGRA_PIN_HDMI_INT_PN7          _GPIO(111)
 142#define TEGRA_PIN_ULPI_DATA7_PO0        _GPIO(112)
 143#define TEGRA_PIN_ULPI_DATA0_PO1        _GPIO(113)
 144#define TEGRA_PIN_ULPI_DATA1_PO2        _GPIO(114)
 145#define TEGRA_PIN_ULPI_DATA2_PO3        _GPIO(115)
 146#define TEGRA_PIN_ULPI_DATA3_PO4        _GPIO(116)
 147#define TEGRA_PIN_ULPI_DATA4_PO5        _GPIO(117)
 148#define TEGRA_PIN_ULPI_DATA5_PO6        _GPIO(118)
 149#define TEGRA_PIN_ULPI_DATA6_PO7        _GPIO(119)
 150#define TEGRA_PIN_DAP3_FS_PP0           _GPIO(120)
 151#define TEGRA_PIN_DAP3_DIN_PP1          _GPIO(121)
 152#define TEGRA_PIN_DAP3_DOUT_PP2         _GPIO(122)
 153#define TEGRA_PIN_DAP3_SCLK_PP3         _GPIO(123)
 154#define TEGRA_PIN_DAP4_FS_PP4           _GPIO(124)
 155#define TEGRA_PIN_DAP4_DIN_PP5          _GPIO(125)
 156#define TEGRA_PIN_DAP4_DOUT_PP6         _GPIO(126)
 157#define TEGRA_PIN_DAP4_SCLK_PP7         _GPIO(127)
 158#define TEGRA_PIN_KB_COL0_PQ0           _GPIO(128)
 159#define TEGRA_PIN_KB_COL1_PQ1           _GPIO(129)
 160#define TEGRA_PIN_KB_COL2_PQ2           _GPIO(130)
 161#define TEGRA_PIN_KB_COL3_PQ3           _GPIO(131)
 162#define TEGRA_PIN_KB_COL4_PQ4           _GPIO(132)
 163#define TEGRA_PIN_KB_COL5_PQ5           _GPIO(133)
 164#define TEGRA_PIN_KB_COL6_PQ6           _GPIO(134)
 165#define TEGRA_PIN_KB_COL7_PQ7           _GPIO(135)
 166#define TEGRA_PIN_KB_ROW0_PR0           _GPIO(136)
 167#define TEGRA_PIN_KB_ROW1_PR1           _GPIO(137)
 168#define TEGRA_PIN_KB_ROW2_PR2           _GPIO(138)
 169#define TEGRA_PIN_KB_ROW3_PR3           _GPIO(139)
 170#define TEGRA_PIN_KB_ROW4_PR4           _GPIO(140)
 171#define TEGRA_PIN_KB_ROW5_PR5           _GPIO(141)
 172#define TEGRA_PIN_KB_ROW6_PR6           _GPIO(142)
 173#define TEGRA_PIN_KB_ROW7_PR7           _GPIO(143)
 174#define TEGRA_PIN_KB_ROW8_PS0           _GPIO(144)
 175#define TEGRA_PIN_KB_ROW9_PS1           _GPIO(145)
 176#define TEGRA_PIN_KB_ROW10_PS2          _GPIO(146)
 177#define TEGRA_PIN_KB_ROW11_PS3          _GPIO(147)
 178#define TEGRA_PIN_KB_ROW12_PS4          _GPIO(148)
 179#define TEGRA_PIN_KB_ROW13_PS5          _GPIO(149)
 180#define TEGRA_PIN_KB_ROW14_PS6          _GPIO(150)
 181#define TEGRA_PIN_KB_ROW15_PS7          _GPIO(151)
 182#define TEGRA_PIN_VI_PCLK_PT0           _GPIO(152)
 183#define TEGRA_PIN_VI_MCLK_PT1           _GPIO(153)
 184#define TEGRA_PIN_VI_D10_PT2            _GPIO(154)
 185#define TEGRA_PIN_VI_D11_PT3            _GPIO(155)
 186#define TEGRA_PIN_VI_D0_PT4             _GPIO(156)
 187#define TEGRA_PIN_GEN2_I2C_SCL_PT5      _GPIO(157)
 188#define TEGRA_PIN_GEN2_I2C_SDA_PT6      _GPIO(158)
 189#define TEGRA_PIN_SDMMC4_CMD_PT7        _GPIO(159)
 190#define TEGRA_PIN_PU0                   _GPIO(160)
 191#define TEGRA_PIN_PU1                   _GPIO(161)
 192#define TEGRA_PIN_PU2                   _GPIO(162)
 193#define TEGRA_PIN_PU3                   _GPIO(163)
 194#define TEGRA_PIN_PU4                   _GPIO(164)
 195#define TEGRA_PIN_PU5                   _GPIO(165)
 196#define TEGRA_PIN_PU6                   _GPIO(166)
 197#define TEGRA_PIN_JTAG_RTCK_PU7         _GPIO(167)
 198#define TEGRA_PIN_PV0                   _GPIO(168)
 199#define TEGRA_PIN_PV1                   _GPIO(169)
 200#define TEGRA_PIN_PV2                   _GPIO(170)
 201#define TEGRA_PIN_PV3                   _GPIO(171)
 202#define TEGRA_PIN_DDC_SCL_PV4           _GPIO(172)
 203#define TEGRA_PIN_DDC_SDA_PV5           _GPIO(173)
 204#define TEGRA_PIN_CRT_HSYNC_PV6         _GPIO(174)
 205#define TEGRA_PIN_CRT_VSYNC_PV7         _GPIO(175)
 206#define TEGRA_PIN_LCD_CS1_N_PW0         _GPIO(176)
 207#define TEGRA_PIN_LCD_M1_PW1            _GPIO(177)
 208#define TEGRA_PIN_SPI2_CS1_N_PW2        _GPIO(178)
 209#define TEGRA_PIN_SPI2_CS2_N_PW3        _GPIO(179)
 210#define TEGRA_PIN_CLK1_OUT_PW4          _GPIO(180)
 211#define TEGRA_PIN_CLK2_OUT_PW5          _GPIO(181)
 212#define TEGRA_PIN_UART3_TXD_PW6         _GPIO(182)
 213#define TEGRA_PIN_UART3_RXD_PW7         _GPIO(183)
 214#define TEGRA_PIN_SPI2_MOSI_PX0         _GPIO(184)
 215#define TEGRA_PIN_SPI2_MISO_PX1         _GPIO(185)
 216#define TEGRA_PIN_SPI2_SCK_PX2          _GPIO(186)
 217#define TEGRA_PIN_SPI2_CS0_N_PX3        _GPIO(187)
 218#define TEGRA_PIN_SPI1_MOSI_PX4         _GPIO(188)
 219#define TEGRA_PIN_SPI1_SCK_PX5          _GPIO(189)
 220#define TEGRA_PIN_SPI1_CS0_N_PX6        _GPIO(190)
 221#define TEGRA_PIN_SPI1_MISO_PX7         _GPIO(191)
 222#define TEGRA_PIN_ULPI_CLK_PY0          _GPIO(192)
 223#define TEGRA_PIN_ULPI_DIR_PY1          _GPIO(193)
 224#define TEGRA_PIN_ULPI_NXT_PY2          _GPIO(194)
 225#define TEGRA_PIN_ULPI_STP_PY3          _GPIO(195)
 226#define TEGRA_PIN_SDMMC1_DAT3_PY4       _GPIO(196)
 227#define TEGRA_PIN_SDMMC1_DAT2_PY5       _GPIO(197)
 228#define TEGRA_PIN_SDMMC1_DAT1_PY6       _GPIO(198)
 229#define TEGRA_PIN_SDMMC1_DAT0_PY7       _GPIO(199)
 230#define TEGRA_PIN_SDMMC1_CLK_PZ0        _GPIO(200)
 231#define TEGRA_PIN_SDMMC1_CMD_PZ1        _GPIO(201)
 232#define TEGRA_PIN_LCD_SDIN_PZ2          _GPIO(202)
 233#define TEGRA_PIN_LCD_WR_N_PZ3          _GPIO(203)
 234#define TEGRA_PIN_LCD_SCK_PZ4           _GPIO(204)
 235#define TEGRA_PIN_SYS_CLK_REQ_PZ5       _GPIO(205)
 236#define TEGRA_PIN_PWR_I2C_SCL_PZ6       _GPIO(206)
 237#define TEGRA_PIN_PWR_I2C_SDA_PZ7       _GPIO(207)
 238#define TEGRA_PIN_SDMMC4_DAT0_PAA0      _GPIO(208)
 239#define TEGRA_PIN_SDMMC4_DAT1_PAA1      _GPIO(209)
 240#define TEGRA_PIN_SDMMC4_DAT2_PAA2      _GPIO(210)
 241#define TEGRA_PIN_SDMMC4_DAT3_PAA3      _GPIO(211)
 242#define TEGRA_PIN_SDMMC4_DAT4_PAA4      _GPIO(212)
 243#define TEGRA_PIN_SDMMC4_DAT5_PAA5      _GPIO(213)
 244#define TEGRA_PIN_SDMMC4_DAT6_PAA6      _GPIO(214)
 245#define TEGRA_PIN_SDMMC4_DAT7_PAA7      _GPIO(215)
 246#define TEGRA_PIN_PBB0                  _GPIO(216)
 247#define TEGRA_PIN_CAM_I2C_SCL_PBB1      _GPIO(217)
 248#define TEGRA_PIN_CAM_I2C_SDA_PBB2      _GPIO(218)
 249#define TEGRA_PIN_PBB3                  _GPIO(219)
 250#define TEGRA_PIN_PBB4                  _GPIO(220)
 251#define TEGRA_PIN_PBB5                  _GPIO(221)
 252#define TEGRA_PIN_PBB6                  _GPIO(222)
 253#define TEGRA_PIN_PBB7                  _GPIO(223)
 254#define TEGRA_PIN_CAM_MCLK_PCC0         _GPIO(224)
 255#define TEGRA_PIN_PCC1                  _GPIO(225)
 256#define TEGRA_PIN_PCC2                  _GPIO(226)
 257#define TEGRA_PIN_SDMMC4_RST_N_PCC3     _GPIO(227)
 258#define TEGRA_PIN_SDMMC4_CLK_PCC4       _GPIO(228)
 259#define TEGRA_PIN_CLK2_REQ_PCC5         _GPIO(229)
 260#define TEGRA_PIN_PEX_L2_RST_N_PCC6     _GPIO(230)
 261#define TEGRA_PIN_PEX_L2_CLKREQ_N_PCC7  _GPIO(231)
 262#define TEGRA_PIN_PEX_L0_PRSNT_N_PDD0   _GPIO(232)
 263#define TEGRA_PIN_PEX_L0_RST_N_PDD1     _GPIO(233)
 264#define TEGRA_PIN_PEX_L0_CLKREQ_N_PDD2  _GPIO(234)
 265#define TEGRA_PIN_PEX_WAKE_N_PDD3       _GPIO(235)
 266#define TEGRA_PIN_PEX_L1_PRSNT_N_PDD4   _GPIO(236)
 267#define TEGRA_PIN_PEX_L1_RST_N_PDD5     _GPIO(237)
 268#define TEGRA_PIN_PEX_L1_CLKREQ_N_PDD6  _GPIO(238)
 269#define TEGRA_PIN_PEX_L2_PRSNT_N_PDD7   _GPIO(239)
 270#define TEGRA_PIN_CLK3_OUT_PEE0         _GPIO(240)
 271#define TEGRA_PIN_CLK3_REQ_PEE1         _GPIO(241)
 272#define TEGRA_PIN_CLK1_REQ_PEE2         _GPIO(242)
 273#define TEGRA_PIN_HDMI_CEC_PEE3         _GPIO(243)
 274#define TEGRA_PIN_PEE4                  _GPIO(244)
 275#define TEGRA_PIN_PEE5                  _GPIO(245)
 276#define TEGRA_PIN_PEE6                  _GPIO(246)
 277#define TEGRA_PIN_PEE7                  _GPIO(247)
 278
 279/* All non-GPIO pins follow */
 280#define NUM_GPIOS                               (TEGRA_PIN_PEE7 + 1)
 281#define _PIN(offset)                            (NUM_GPIOS + (offset))
 282
 283/* Non-GPIO pins */
 284#define TEGRA_PIN_CLK_32K_IN            _PIN(0)
 285#define TEGRA_PIN_CORE_PWR_REQ          _PIN(1)
 286#define TEGRA_PIN_CPU_PWR_REQ           _PIN(2)
 287#define TEGRA_PIN_JTAG_TCK              _PIN(3)
 288#define TEGRA_PIN_JTAG_TDI              _PIN(4)
 289#define TEGRA_PIN_JTAG_TDO              _PIN(5)
 290#define TEGRA_PIN_JTAG_TMS              _PIN(6)
 291#define TEGRA_PIN_JTAG_TRST_N           _PIN(7)
 292#define TEGRA_PIN_OWR                   _PIN(8)
 293#define TEGRA_PIN_PWR_INT_N             _PIN(9)
 294#define TEGRA_PIN_SYS_RESET_N           _PIN(10)
 295#define TEGRA_PIN_TEST_MODE_EN          _PIN(11)
 296
 297static const struct pinctrl_pin_desc tegra30_pins[] = {
 298        PINCTRL_PIN(TEGRA_PIN_CLK_32K_OUT_PA0, "CLK_32K_OUT PA0"),
 299        PINCTRL_PIN(TEGRA_PIN_UART3_CTS_N_PA1, "UART3_CTS_N PA1"),
 300        PINCTRL_PIN(TEGRA_PIN_DAP2_FS_PA2, "DAP2_FS PA2"),
 301        PINCTRL_PIN(TEGRA_PIN_DAP2_SCLK_PA3, "DAP2_SCLK PA3"),
 302        PINCTRL_PIN(TEGRA_PIN_DAP2_DIN_PA4, "DAP2_DIN PA4"),
 303        PINCTRL_PIN(TEGRA_PIN_DAP2_DOUT_PA5, "DAP2_DOUT PA5"),
 304        PINCTRL_PIN(TEGRA_PIN_SDMMC3_CLK_PA6, "SDMMC3_CLK PA6"),
 305        PINCTRL_PIN(TEGRA_PIN_SDMMC3_CMD_PA7, "SDMMC3_CMD PA7"),
 306        PINCTRL_PIN(TEGRA_PIN_GMI_A17_PB0, "GMI_A17 PB0"),
 307        PINCTRL_PIN(TEGRA_PIN_GMI_A18_PB1, "GMI_A18 PB1"),
 308        PINCTRL_PIN(TEGRA_PIN_LCD_PWR0_PB2, "LCD_PWR0 PB2"),
 309        PINCTRL_PIN(TEGRA_PIN_LCD_PCLK_PB3, "LCD_PCLK PB3"),
 310        PINCTRL_PIN(TEGRA_PIN_SDMMC3_DAT3_PB4, "SDMMC3_DAT3 PB4"),
 311        PINCTRL_PIN(TEGRA_PIN_SDMMC3_DAT2_PB5, "SDMMC3_DAT2 PB5"),
 312        PINCTRL_PIN(TEGRA_PIN_SDMMC3_DAT1_PB6, "SDMMC3_DAT1 PB6"),
 313        PINCTRL_PIN(TEGRA_PIN_SDMMC3_DAT0_PB7, "SDMMC3_DAT0 PB7"),
 314        PINCTRL_PIN(TEGRA_PIN_UART3_RTS_N_PC0, "UART3_RTS_N PC0"),
 315        PINCTRL_PIN(TEGRA_PIN_LCD_PWR1_PC1, "LCD_PWR1 PC1"),
 316        PINCTRL_PIN(TEGRA_PIN_UART2_TXD_PC2, "UART2_TXD PC2"),
 317        PINCTRL_PIN(TEGRA_PIN_UART2_RXD_PC3, "UART2_RXD PC3"),
 318        PINCTRL_PIN(TEGRA_PIN_GEN1_I2C_SCL_PC4, "GEN1_I2C_SCL PC4"),
 319        PINCTRL_PIN(TEGRA_PIN_GEN1_I2C_SDA_PC5, "GEN1_I2C_SDA PC5"),
 320        PINCTRL_PIN(TEGRA_PIN_LCD_PWR2_PC6, "LCD_PWR2 PC6"),
 321        PINCTRL_PIN(TEGRA_PIN_GMI_WP_N_PC7, "GMI_WP_N PC7"),
 322        PINCTRL_PIN(TEGRA_PIN_SDMMC3_DAT5_PD0, "SDMMC3_DAT5 PD0"),
 323        PINCTRL_PIN(TEGRA_PIN_SDMMC3_DAT4_PD1, "SDMMC3_DAT4 PD1"),
 324        PINCTRL_PIN(TEGRA_PIN_LCD_DC1_PD2, "LCD_DC1 PD2"),
 325        PINCTRL_PIN(TEGRA_PIN_SDMMC3_DAT6_PD3, "SDMMC3_DAT6 PD3"),
 326        PINCTRL_PIN(TEGRA_PIN_SDMMC3_DAT7_PD4, "SDMMC3_DAT7 PD4"),
 327        PINCTRL_PIN(TEGRA_PIN_VI_D1_PD5, "VI_D1 PD5"),
 328        PINCTRL_PIN(TEGRA_PIN_VI_VSYNC_PD6, "VI_VSYNC PD6"),
 329        PINCTRL_PIN(TEGRA_PIN_VI_HSYNC_PD7, "VI_HSYNC PD7"),
 330        PINCTRL_PIN(TEGRA_PIN_LCD_D0_PE0, "LCD_D0 PE0"),
 331        PINCTRL_PIN(TEGRA_PIN_LCD_D1_PE1, "LCD_D1 PE1"),
 332        PINCTRL_PIN(TEGRA_PIN_LCD_D2_PE2, "LCD_D2 PE2"),
 333        PINCTRL_PIN(TEGRA_PIN_LCD_D3_PE3, "LCD_D3 PE3"),
 334        PINCTRL_PIN(TEGRA_PIN_LCD_D4_PE4, "LCD_D4 PE4"),
 335        PINCTRL_PIN(TEGRA_PIN_LCD_D5_PE5, "LCD_D5 PE5"),
 336        PINCTRL_PIN(TEGRA_PIN_LCD_D6_PE6, "LCD_D6 PE6"),
 337        PINCTRL_PIN(TEGRA_PIN_LCD_D7_PE7, "LCD_D7 PE7"),
 338        PINCTRL_PIN(TEGRA_PIN_LCD_D8_PF0, "LCD_D8 PF0"),
 339        PINCTRL_PIN(TEGRA_PIN_LCD_D9_PF1, "LCD_D9 PF1"),
 340        PINCTRL_PIN(TEGRA_PIN_LCD_D10_PF2, "LCD_D10 PF2"),
 341        PINCTRL_PIN(TEGRA_PIN_LCD_D11_PF3, "LCD_D11 PF3"),
 342        PINCTRL_PIN(TEGRA_PIN_LCD_D12_PF4, "LCD_D12 PF4"),
 343        PINCTRL_PIN(TEGRA_PIN_LCD_D13_PF5, "LCD_D13 PF5"),
 344        PINCTRL_PIN(TEGRA_PIN_LCD_D14_PF6, "LCD_D14 PF6"),
 345        PINCTRL_PIN(TEGRA_PIN_LCD_D15_PF7, "LCD_D15 PF7"),
 346        PINCTRL_PIN(TEGRA_PIN_GMI_AD0_PG0, "GMI_AD0 PG0"),
 347        PINCTRL_PIN(TEGRA_PIN_GMI_AD1_PG1, "GMI_AD1 PG1"),
 348        PINCTRL_PIN(TEGRA_PIN_GMI_AD2_PG2, "GMI_AD2 PG2"),
 349        PINCTRL_PIN(TEGRA_PIN_GMI_AD3_PG3, "GMI_AD3 PG3"),
 350        PINCTRL_PIN(TEGRA_PIN_GMI_AD4_PG4, "GMI_AD4 PG4"),
 351        PINCTRL_PIN(TEGRA_PIN_GMI_AD5_PG5, "GMI_AD5 PG5"),
 352        PINCTRL_PIN(TEGRA_PIN_GMI_AD6_PG6, "GMI_AD6 PG6"),
 353        PINCTRL_PIN(TEGRA_PIN_GMI_AD7_PG7, "GMI_AD7 PG7"),
 354        PINCTRL_PIN(TEGRA_PIN_GMI_AD8_PH0, "GMI_AD8 PH0"),
 355        PINCTRL_PIN(TEGRA_PIN_GMI_AD9_PH1, "GMI_AD9 PH1"),
 356        PINCTRL_PIN(TEGRA_PIN_GMI_AD10_PH2, "GMI_AD10 PH2"),
 357        PINCTRL_PIN(TEGRA_PIN_GMI_AD11_PH3, "GMI_AD11 PH3"),
 358        PINCTRL_PIN(TEGRA_PIN_GMI_AD12_PH4, "GMI_AD12 PH4"),
 359        PINCTRL_PIN(TEGRA_PIN_GMI_AD13_PH5, "GMI_AD13 PH5"),
 360        PINCTRL_PIN(TEGRA_PIN_GMI_AD14_PH6, "GMI_AD14 PH6"),
 361        PINCTRL_PIN(TEGRA_PIN_GMI_AD15_PH7, "GMI_AD15 PH7"),
 362        PINCTRL_PIN(TEGRA_PIN_GMI_WR_N_PI0, "GMI_WR_N PI0"),
 363        PINCTRL_PIN(TEGRA_PIN_GMI_OE_N_PI1, "GMI_OE_N PI1"),
 364        PINCTRL_PIN(TEGRA_PIN_GMI_DQS_PI2, "GMI_DQS PI2"),
 365        PINCTRL_PIN(TEGRA_PIN_GMI_CS6_N_PI3, "GMI_CS6_N PI3"),
 366        PINCTRL_PIN(TEGRA_PIN_GMI_RST_N_PI4, "GMI_RST_N PI4"),
 367        PINCTRL_PIN(TEGRA_PIN_GMI_IORDY_PI5, "GMI_IORDY PI5"),
 368        PINCTRL_PIN(TEGRA_PIN_GMI_CS7_N_PI6, "GMI_CS7_N PI6"),
 369        PINCTRL_PIN(TEGRA_PIN_GMI_WAIT_PI7, "GMI_WAIT PI7"),
 370        PINCTRL_PIN(TEGRA_PIN_GMI_CS0_N_PJ0, "GMI_CS0_N PJ0"),
 371        PINCTRL_PIN(TEGRA_PIN_LCD_DE_PJ1, "LCD_DE PJ1"),
 372        PINCTRL_PIN(TEGRA_PIN_GMI_CS1_N_PJ2, "GMI_CS1_N PJ2"),
 373        PINCTRL_PIN(TEGRA_PIN_LCD_HSYNC_PJ3, "LCD_HSYNC PJ3"),
 374        PINCTRL_PIN(TEGRA_PIN_LCD_VSYNC_PJ4, "LCD_VSYNC PJ4"),
 375        PINCTRL_PIN(TEGRA_PIN_UART2_CTS_N_PJ5, "UART2_CTS_N PJ5"),
 376        PINCTRL_PIN(TEGRA_PIN_UART2_RTS_N_PJ6, "UART2_RTS_N PJ6"),
 377        PINCTRL_PIN(TEGRA_PIN_GMI_A16_PJ7, "GMI_A16 PJ7"),
 378        PINCTRL_PIN(TEGRA_PIN_GMI_ADV_N_PK0, "GMI_ADV_N PK0"),
 379        PINCTRL_PIN(TEGRA_PIN_GMI_CLK_PK1, "GMI_CLK PK1"),
 380        PINCTRL_PIN(TEGRA_PIN_GMI_CS4_N_PK2, "GMI_CS4_N PK2"),
 381        PINCTRL_PIN(TEGRA_PIN_GMI_CS2_N_PK3, "GMI_CS2_N PK3"),
 382        PINCTRL_PIN(TEGRA_PIN_GMI_CS3_N_PK4, "GMI_CS3_N PK4"),
 383        PINCTRL_PIN(TEGRA_PIN_SPDIF_OUT_PK5, "SPDIF_OUT PK5"),
 384        PINCTRL_PIN(TEGRA_PIN_SPDIF_IN_PK6, "SPDIF_IN PK6"),
 385        PINCTRL_PIN(TEGRA_PIN_GMI_A19_PK7, "GMI_A19 PK7"),
 386        PINCTRL_PIN(TEGRA_PIN_VI_D2_PL0, "VI_D2 PL0"),
 387        PINCTRL_PIN(TEGRA_PIN_VI_D3_PL1, "VI_D3 PL1"),
 388        PINCTRL_PIN(TEGRA_PIN_VI_D4_PL2, "VI_D4 PL2"),
 389        PINCTRL_PIN(TEGRA_PIN_VI_D5_PL3, "VI_D5 PL3"),
 390        PINCTRL_PIN(TEGRA_PIN_VI_D6_PL4, "VI_D6 PL4"),
 391        PINCTRL_PIN(TEGRA_PIN_VI_D7_PL5, "VI_D7 PL5"),
 392        PINCTRL_PIN(TEGRA_PIN_VI_D8_PL6, "VI_D8 PL6"),
 393        PINCTRL_PIN(TEGRA_PIN_VI_D9_PL7, "VI_D9 PL7"),
 394        PINCTRL_PIN(TEGRA_PIN_LCD_D16_PM0, "LCD_D16 PM0"),
 395        PINCTRL_PIN(TEGRA_PIN_LCD_D17_PM1, "LCD_D17 PM1"),
 396        PINCTRL_PIN(TEGRA_PIN_LCD_D18_PM2, "LCD_D18 PM2"),
 397        PINCTRL_PIN(TEGRA_PIN_LCD_D19_PM3, "LCD_D19 PM3"),
 398        PINCTRL_PIN(TEGRA_PIN_LCD_D20_PM4, "LCD_D20 PM4"),
 399        PINCTRL_PIN(TEGRA_PIN_LCD_D21_PM5, "LCD_D21 PM5"),
 400        PINCTRL_PIN(TEGRA_PIN_LCD_D22_PM6, "LCD_D22 PM6"),
 401        PINCTRL_PIN(TEGRA_PIN_LCD_D23_PM7, "LCD_D23 PM7"),
 402        PINCTRL_PIN(TEGRA_PIN_DAP1_FS_PN0, "DAP1_FS PN0"),
 403        PINCTRL_PIN(TEGRA_PIN_DAP1_DIN_PN1, "DAP1_DIN PN1"),
 404        PINCTRL_PIN(TEGRA_PIN_DAP1_DOUT_PN2, "DAP1_DOUT PN2"),
 405        PINCTRL_PIN(TEGRA_PIN_DAP1_SCLK_PN3, "DAP1_SCLK PN3"),
 406        PINCTRL_PIN(TEGRA_PIN_LCD_CS0_N_PN4, "LCD_CS0_N PN4"),
 407        PINCTRL_PIN(TEGRA_PIN_LCD_SDOUT_PN5, "LCD_SDOUT PN5"),
 408        PINCTRL_PIN(TEGRA_PIN_LCD_DC0_PN6, "LCD_DC0 PN6"),
 409        PINCTRL_PIN(TEGRA_PIN_HDMI_INT_PN7, "HDMI_INT PN7"),
 410        PINCTRL_PIN(TEGRA_PIN_ULPI_DATA7_PO0, "ULPI_DATA7 PO0"),
 411        PINCTRL_PIN(TEGRA_PIN_ULPI_DATA0_PO1, "ULPI_DATA0 PO1"),
 412        PINCTRL_PIN(TEGRA_PIN_ULPI_DATA1_PO2, "ULPI_DATA1 PO2"),
 413        PINCTRL_PIN(TEGRA_PIN_ULPI_DATA2_PO3, "ULPI_DATA2 PO3"),
 414        PINCTRL_PIN(TEGRA_PIN_ULPI_DATA3_PO4, "ULPI_DATA3 PO4"),
 415        PINCTRL_PIN(TEGRA_PIN_ULPI_DATA4_PO5, "ULPI_DATA4 PO5"),
 416        PINCTRL_PIN(TEGRA_PIN_ULPI_DATA5_PO6, "ULPI_DATA5 PO6"),
 417        PINCTRL_PIN(TEGRA_PIN_ULPI_DATA6_PO7, "ULPI_DATA6 PO7"),
 418        PINCTRL_PIN(TEGRA_PIN_DAP3_FS_PP0, "DAP3_FS PP0"),
 419        PINCTRL_PIN(TEGRA_PIN_DAP3_DIN_PP1, "DAP3_DIN PP1"),
 420        PINCTRL_PIN(TEGRA_PIN_DAP3_DOUT_PP2, "DAP3_DOUT PP2"),
 421        PINCTRL_PIN(TEGRA_PIN_DAP3_SCLK_PP3, "DAP3_SCLK PP3"),
 422        PINCTRL_PIN(TEGRA_PIN_DAP4_FS_PP4, "DAP4_FS PP4"),
 423        PINCTRL_PIN(TEGRA_PIN_DAP4_DIN_PP5, "DAP4_DIN PP5"),
 424        PINCTRL_PIN(TEGRA_PIN_DAP4_DOUT_PP6, "DAP4_DOUT PP6"),
 425        PINCTRL_PIN(TEGRA_PIN_DAP4_SCLK_PP7, "DAP4_SCLK PP7"),
 426        PINCTRL_PIN(TEGRA_PIN_KB_COL0_PQ0, "KB_COL0 PQ0"),
 427        PINCTRL_PIN(TEGRA_PIN_KB_COL1_PQ1, "KB_COL1 PQ1"),
 428        PINCTRL_PIN(TEGRA_PIN_KB_COL2_PQ2, "KB_COL2 PQ2"),
 429        PINCTRL_PIN(TEGRA_PIN_KB_COL3_PQ3, "KB_COL3 PQ3"),
 430        PINCTRL_PIN(TEGRA_PIN_KB_COL4_PQ4, "KB_COL4 PQ4"),
 431        PINCTRL_PIN(TEGRA_PIN_KB_COL5_PQ5, "KB_COL5 PQ5"),
 432        PINCTRL_PIN(TEGRA_PIN_KB_COL6_PQ6, "KB_COL6 PQ6"),
 433        PINCTRL_PIN(TEGRA_PIN_KB_COL7_PQ7, "KB_COL7 PQ7"),
 434        PINCTRL_PIN(TEGRA_PIN_KB_ROW0_PR0, "KB_ROW0 PR0"),
 435        PINCTRL_PIN(TEGRA_PIN_KB_ROW1_PR1, "KB_ROW1 PR1"),
 436        PINCTRL_PIN(TEGRA_PIN_KB_ROW2_PR2, "KB_ROW2 PR2"),
 437        PINCTRL_PIN(TEGRA_PIN_KB_ROW3_PR3, "KB_ROW3 PR3"),
 438        PINCTRL_PIN(TEGRA_PIN_KB_ROW4_PR4, "KB_ROW4 PR4"),
 439        PINCTRL_PIN(TEGRA_PIN_KB_ROW5_PR5, "KB_ROW5 PR5"),
 440        PINCTRL_PIN(TEGRA_PIN_KB_ROW6_PR6, "KB_ROW6 PR6"),
 441        PINCTRL_PIN(TEGRA_PIN_KB_ROW7_PR7, "KB_ROW7 PR7"),
 442        PINCTRL_PIN(TEGRA_PIN_KB_ROW8_PS0, "KB_ROW8 PS0"),
 443        PINCTRL_PIN(TEGRA_PIN_KB_ROW9_PS1, "KB_ROW9 PS1"),
 444        PINCTRL_PIN(TEGRA_PIN_KB_ROW10_PS2, "KB_ROW10 PS2"),
 445        PINCTRL_PIN(TEGRA_PIN_KB_ROW11_PS3, "KB_ROW11 PS3"),
 446        PINCTRL_PIN(TEGRA_PIN_KB_ROW12_PS4, "KB_ROW12 PS4"),
 447        PINCTRL_PIN(TEGRA_PIN_KB_ROW13_PS5, "KB_ROW13 PS5"),
 448        PINCTRL_PIN(TEGRA_PIN_KB_ROW14_PS6, "KB_ROW14 PS6"),
 449        PINCTRL_PIN(TEGRA_PIN_KB_ROW15_PS7, "KB_ROW15 PS7"),
 450        PINCTRL_PIN(TEGRA_PIN_VI_PCLK_PT0, "VI_PCLK PT0"),
 451        PINCTRL_PIN(TEGRA_PIN_VI_MCLK_PT1, "VI_MCLK PT1"),
 452        PINCTRL_PIN(TEGRA_PIN_VI_D10_PT2, "VI_D10 PT2"),
 453        PINCTRL_PIN(TEGRA_PIN_VI_D11_PT3, "VI_D11 PT3"),
 454        PINCTRL_PIN(TEGRA_PIN_VI_D0_PT4, "VI_D0 PT4"),
 455        PINCTRL_PIN(TEGRA_PIN_GEN2_I2C_SCL_PT5, "GEN2_I2C_SCL PT5"),
 456        PINCTRL_PIN(TEGRA_PIN_GEN2_I2C_SDA_PT6, "GEN2_I2C_SDA PT6"),
 457        PINCTRL_PIN(TEGRA_PIN_SDMMC4_CMD_PT7, "SDMMC4_CMD PT7"),
 458        PINCTRL_PIN(TEGRA_PIN_PU0, "PU0"),
 459        PINCTRL_PIN(TEGRA_PIN_PU1, "PU1"),
 460        PINCTRL_PIN(TEGRA_PIN_PU2, "PU2"),
 461        PINCTRL_PIN(TEGRA_PIN_PU3, "PU3"),
 462        PINCTRL_PIN(TEGRA_PIN_PU4, "PU4"),
 463        PINCTRL_PIN(TEGRA_PIN_PU5, "PU5"),
 464        PINCTRL_PIN(TEGRA_PIN_PU6, "PU6"),
 465        PINCTRL_PIN(TEGRA_PIN_JTAG_RTCK_PU7, "JTAG_RTCK PU7"),
 466        PINCTRL_PIN(TEGRA_PIN_PV0, "PV0"),
 467        PINCTRL_PIN(TEGRA_PIN_PV1, "PV1"),
 468        PINCTRL_PIN(TEGRA_PIN_PV2, "PV2"),
 469        PINCTRL_PIN(TEGRA_PIN_PV3, "PV3"),
 470        PINCTRL_PIN(TEGRA_PIN_DDC_SCL_PV4, "DDC_SCL PV4"),
 471        PINCTRL_PIN(TEGRA_PIN_DDC_SDA_PV5, "DDC_SDA PV5"),
 472        PINCTRL_PIN(TEGRA_PIN_CRT_HSYNC_PV6, "CRT_HSYNC PV6"),
 473        PINCTRL_PIN(TEGRA_PIN_CRT_VSYNC_PV7, "CRT_VSYNC PV7"),
 474        PINCTRL_PIN(TEGRA_PIN_LCD_CS1_N_PW0, "LCD_CS1_N PW0"),
 475        PINCTRL_PIN(TEGRA_PIN_LCD_M1_PW1, "LCD_M1 PW1"),
 476        PINCTRL_PIN(TEGRA_PIN_SPI2_CS1_N_PW2, "SPI2_CS1_N PW2"),
 477        PINCTRL_PIN(TEGRA_PIN_SPI2_CS2_N_PW3, "SPI2_CS2_N PW3"),
 478        PINCTRL_PIN(TEGRA_PIN_CLK1_OUT_PW4, "CLK1_OUT PW4"),
 479        PINCTRL_PIN(TEGRA_PIN_CLK2_OUT_PW5, "CLK2_OUT PW5"),
 480        PINCTRL_PIN(TEGRA_PIN_UART3_TXD_PW6, "UART3_TXD PW6"),
 481        PINCTRL_PIN(TEGRA_PIN_UART3_RXD_PW7, "UART3_RXD PW7"),
 482        PINCTRL_PIN(TEGRA_PIN_SPI2_MOSI_PX0, "SPI2_MOSI PX0"),
 483        PINCTRL_PIN(TEGRA_PIN_SPI2_MISO_PX1, "SPI2_MISO PX1"),
 484        PINCTRL_PIN(TEGRA_PIN_SPI2_SCK_PX2, "SPI2_SCK PX2"),
 485        PINCTRL_PIN(TEGRA_PIN_SPI2_CS0_N_PX3, "SPI2_CS0_N PX3"),
 486        PINCTRL_PIN(TEGRA_PIN_SPI1_MOSI_PX4, "SPI1_MOSI PX4"),
 487        PINCTRL_PIN(TEGRA_PIN_SPI1_SCK_PX5, "SPI1_SCK PX5"),
 488        PINCTRL_PIN(TEGRA_PIN_SPI1_CS0_N_PX6, "SPI1_CS0_N PX6"),
 489        PINCTRL_PIN(TEGRA_PIN_SPI1_MISO_PX7, "SPI1_MISO PX7"),
 490        PINCTRL_PIN(TEGRA_PIN_ULPI_CLK_PY0, "ULPI_CLK PY0"),
 491        PINCTRL_PIN(TEGRA_PIN_ULPI_DIR_PY1, "ULPI_DIR PY1"),
 492        PINCTRL_PIN(TEGRA_PIN_ULPI_NXT_PY2, "ULPI_NXT PY2"),
 493        PINCTRL_PIN(TEGRA_PIN_ULPI_STP_PY3, "ULPI_STP PY3"),
 494        PINCTRL_PIN(TEGRA_PIN_SDMMC1_DAT3_PY4, "SDMMC1_DAT3 PY4"),
 495        PINCTRL_PIN(TEGRA_PIN_SDMMC1_DAT2_PY5, "SDMMC1_DAT2 PY5"),
 496        PINCTRL_PIN(TEGRA_PIN_SDMMC1_DAT1_PY6, "SDMMC1_DAT1 PY6"),
 497        PINCTRL_PIN(TEGRA_PIN_SDMMC1_DAT0_PY7, "SDMMC1_DAT0 PY7"),
 498        PINCTRL_PIN(TEGRA_PIN_SDMMC1_CLK_PZ0, "SDMMC1_CLK PZ0"),
 499        PINCTRL_PIN(TEGRA_PIN_SDMMC1_CMD_PZ1, "SDMMC1_CMD PZ1"),
 500        PINCTRL_PIN(TEGRA_PIN_LCD_SDIN_PZ2, "LCD_SDIN PZ2"),
 501        PINCTRL_PIN(TEGRA_PIN_LCD_WR_N_PZ3, "LCD_WR_N PZ3"),
 502        PINCTRL_PIN(TEGRA_PIN_LCD_SCK_PZ4, "LCD_SCK PZ4"),
 503        PINCTRL_PIN(TEGRA_PIN_SYS_CLK_REQ_PZ5, "SYS_CLK_REQ PZ5"),
 504        PINCTRL_PIN(TEGRA_PIN_PWR_I2C_SCL_PZ6, "PWR_I2C_SCL PZ6"),
 505        PINCTRL_PIN(TEGRA_PIN_PWR_I2C_SDA_PZ7, "PWR_I2C_SDA PZ7"),
 506        PINCTRL_PIN(TEGRA_PIN_SDMMC4_DAT0_PAA0, "SDMMC4_DAT0 PAA0"),
 507        PINCTRL_PIN(TEGRA_PIN_SDMMC4_DAT1_PAA1, "SDMMC4_DAT1 PAA1"),
 508        PINCTRL_PIN(TEGRA_PIN_SDMMC4_DAT2_PAA2, "SDMMC4_DAT2 PAA2"),
 509        PINCTRL_PIN(TEGRA_PIN_SDMMC4_DAT3_PAA3, "SDMMC4_DAT3 PAA3"),
 510        PINCTRL_PIN(TEGRA_PIN_SDMMC4_DAT4_PAA4, "SDMMC4_DAT4 PAA4"),
 511        PINCTRL_PIN(TEGRA_PIN_SDMMC4_DAT5_PAA5, "SDMMC4_DAT5 PAA5"),
 512        PINCTRL_PIN(TEGRA_PIN_SDMMC4_DAT6_PAA6, "SDMMC4_DAT6 PAA6"),
 513        PINCTRL_PIN(TEGRA_PIN_SDMMC4_DAT7_PAA7, "SDMMC4_DAT7 PAA7"),
 514        PINCTRL_PIN(TEGRA_PIN_PBB0, "PBB0"),
 515        PINCTRL_PIN(TEGRA_PIN_CAM_I2C_SCL_PBB1, "CAM_I2C_SCL PBB1"),
 516        PINCTRL_PIN(TEGRA_PIN_CAM_I2C_SDA_PBB2, "CAM_I2C_SDA PBB2"),
 517        PINCTRL_PIN(TEGRA_PIN_PBB3, "PBB3"),
 518        PINCTRL_PIN(TEGRA_PIN_PBB4, "PBB4"),
 519        PINCTRL_PIN(TEGRA_PIN_PBB5, "PBB5"),
 520        PINCTRL_PIN(TEGRA_PIN_PBB6, "PBB6"),
 521        PINCTRL_PIN(TEGRA_PIN_PBB7, "PBB7"),
 522        PINCTRL_PIN(TEGRA_PIN_CAM_MCLK_PCC0, "CAM_MCLK PCC0"),
 523        PINCTRL_PIN(TEGRA_PIN_PCC1, "PCC1"),
 524        PINCTRL_PIN(TEGRA_PIN_PCC2, "PCC2"),
 525        PINCTRL_PIN(TEGRA_PIN_SDMMC4_RST_N_PCC3, "SDMMC4_RST_N PCC3"),
 526        PINCTRL_PIN(TEGRA_PIN_SDMMC4_CLK_PCC4, "SDMMC4_CLK PCC4"),
 527        PINCTRL_PIN(TEGRA_PIN_CLK2_REQ_PCC5, "CLK2_REQ PCC5"),
 528        PINCTRL_PIN(TEGRA_PIN_PEX_L2_RST_N_PCC6, "PEX_L2_RST_N PCC6"),
 529        PINCTRL_PIN(TEGRA_PIN_PEX_L2_CLKREQ_N_PCC7, "PEX_L2_CLKREQ_N PCC7"),
 530        PINCTRL_PIN(TEGRA_PIN_PEX_L0_PRSNT_N_PDD0, "PEX_L0_PRSNT_N PDD0"),
 531        PINCTRL_PIN(TEGRA_PIN_PEX_L0_RST_N_PDD1, "PEX_L0_RST_N PDD1"),
 532        PINCTRL_PIN(TEGRA_PIN_PEX_L0_CLKREQ_N_PDD2, "PEX_L0_CLKREQ_N PDD2"),
 533        PINCTRL_PIN(TEGRA_PIN_PEX_WAKE_N_PDD3, "PEX_WAKE_N PDD3"),
 534        PINCTRL_PIN(TEGRA_PIN_PEX_L1_PRSNT_N_PDD4, "PEX_L1_PRSNT_N PDD4"),
 535        PINCTRL_PIN(TEGRA_PIN_PEX_L1_RST_N_PDD5, "PEX_L1_RST_N PDD5"),
 536        PINCTRL_PIN(TEGRA_PIN_PEX_L1_CLKREQ_N_PDD6, "PEX_L1_CLKREQ_N PDD6"),
 537        PINCTRL_PIN(TEGRA_PIN_PEX_L2_PRSNT_N_PDD7, "PEX_L2_PRSNT_N PDD7"),
 538        PINCTRL_PIN(TEGRA_PIN_CLK3_OUT_PEE0, "CLK3_OUT PEE0"),
 539        PINCTRL_PIN(TEGRA_PIN_CLK3_REQ_PEE1, "CLK3_REQ PEE1"),
 540        PINCTRL_PIN(TEGRA_PIN_CLK1_REQ_PEE2, "CLK1_REQ PEE2"),
 541        PINCTRL_PIN(TEGRA_PIN_HDMI_CEC_PEE3, "HDMI_CEC PEE3"),
 542        PINCTRL_PIN(TEGRA_PIN_PEE4, "PEE4"),
 543        PINCTRL_PIN(TEGRA_PIN_PEE5, "PEE5"),
 544        PINCTRL_PIN(TEGRA_PIN_PEE6, "PEE6"),
 545        PINCTRL_PIN(TEGRA_PIN_PEE7, "PEE7"),
 546        PINCTRL_PIN(TEGRA_PIN_CLK_32K_IN, "CLK_32K_IN"),
 547        PINCTRL_PIN(TEGRA_PIN_CORE_PWR_REQ, "CORE_PWR_REQ"),
 548        PINCTRL_PIN(TEGRA_PIN_CPU_PWR_REQ, "CPU_PWR_REQ"),
 549        PINCTRL_PIN(TEGRA_PIN_JTAG_TCK, "JTAG_TCK"),
 550        PINCTRL_PIN(TEGRA_PIN_JTAG_TDI, "JTAG_TDI"),
 551        PINCTRL_PIN(TEGRA_PIN_JTAG_TDO, "JTAG_TDO"),
 552        PINCTRL_PIN(TEGRA_PIN_JTAG_TMS, "JTAG_TMS"),
 553        PINCTRL_PIN(TEGRA_PIN_JTAG_TRST_N, "JTAG_TRST_N"),
 554        PINCTRL_PIN(TEGRA_PIN_OWR, "OWR"),
 555        PINCTRL_PIN(TEGRA_PIN_PWR_INT_N, "PWR_INT_N"),
 556        PINCTRL_PIN(TEGRA_PIN_SYS_RESET_N, "SYS_RESET_N"),
 557        PINCTRL_PIN(TEGRA_PIN_TEST_MODE_EN, "TEST_MODE_EN"),
 558};
 559
 560static const unsigned clk_32k_out_pa0_pins[] = {
 561        TEGRA_PIN_CLK_32K_OUT_PA0,
 562};
 563
 564static const unsigned uart3_cts_n_pa1_pins[] = {
 565        TEGRA_PIN_UART3_CTS_N_PA1,
 566};
 567
 568static const unsigned dap2_fs_pa2_pins[] = {
 569        TEGRA_PIN_DAP2_FS_PA2,
 570};
 571
 572static const unsigned dap2_sclk_pa3_pins[] = {
 573        TEGRA_PIN_DAP2_SCLK_PA3,
 574};
 575
 576static const unsigned dap2_din_pa4_pins[] = {
 577        TEGRA_PIN_DAP2_DIN_PA4,
 578};
 579
 580static const unsigned dap2_dout_pa5_pins[] = {
 581        TEGRA_PIN_DAP2_DOUT_PA5,
 582};
 583
 584static const unsigned sdmmc3_clk_pa6_pins[] = {
 585        TEGRA_PIN_SDMMC3_CLK_PA6,
 586};
 587
 588static const unsigned sdmmc3_cmd_pa7_pins[] = {
 589        TEGRA_PIN_SDMMC3_CMD_PA7,
 590};
 591
 592static const unsigned gmi_a17_pb0_pins[] = {
 593        TEGRA_PIN_GMI_A17_PB0,
 594};
 595
 596static const unsigned gmi_a18_pb1_pins[] = {
 597        TEGRA_PIN_GMI_A18_PB1,
 598};
 599
 600static const unsigned lcd_pwr0_pb2_pins[] = {
 601        TEGRA_PIN_LCD_PWR0_PB2,
 602};
 603
 604static const unsigned lcd_pclk_pb3_pins[] = {
 605        TEGRA_PIN_LCD_PCLK_PB3,
 606};
 607
 608static const unsigned sdmmc3_dat3_pb4_pins[] = {
 609        TEGRA_PIN_SDMMC3_DAT3_PB4,
 610};
 611
 612static const unsigned sdmmc3_dat2_pb5_pins[] = {
 613        TEGRA_PIN_SDMMC3_DAT2_PB5,
 614};
 615
 616static const unsigned sdmmc3_dat1_pb6_pins[] = {
 617        TEGRA_PIN_SDMMC3_DAT1_PB6,
 618};
 619
 620static const unsigned sdmmc3_dat0_pb7_pins[] = {
 621        TEGRA_PIN_SDMMC3_DAT0_PB7,
 622};
 623
 624static const unsigned uart3_rts_n_pc0_pins[] = {
 625        TEGRA_PIN_UART3_RTS_N_PC0,
 626};
 627
 628static const unsigned lcd_pwr1_pc1_pins[] = {
 629        TEGRA_PIN_LCD_PWR1_PC1,
 630};
 631
 632static const unsigned uart2_txd_pc2_pins[] = {
 633        TEGRA_PIN_UART2_TXD_PC2,
 634};
 635
 636static const unsigned uart2_rxd_pc3_pins[] = {
 637        TEGRA_PIN_UART2_RXD_PC3,
 638};
 639
 640static const unsigned gen1_i2c_scl_pc4_pins[] = {
 641        TEGRA_PIN_GEN1_I2C_SCL_PC4,
 642};
 643
 644static const unsigned gen1_i2c_sda_pc5_pins[] = {
 645        TEGRA_PIN_GEN1_I2C_SDA_PC5,
 646};
 647
 648static const unsigned lcd_pwr2_pc6_pins[] = {
 649        TEGRA_PIN_LCD_PWR2_PC6,
 650};
 651
 652static const unsigned gmi_wp_n_pc7_pins[] = {
 653        TEGRA_PIN_GMI_WP_N_PC7,
 654};
 655
 656static const unsigned sdmmc3_dat5_pd0_pins[] = {
 657        TEGRA_PIN_SDMMC3_DAT5_PD0,
 658};
 659
 660static const unsigned sdmmc3_dat4_pd1_pins[] = {
 661        TEGRA_PIN_SDMMC3_DAT4_PD1,
 662};
 663
 664static const unsigned lcd_dc1_pd2_pins[] = {
 665        TEGRA_PIN_LCD_DC1_PD2,
 666};
 667
 668static const unsigned sdmmc3_dat6_pd3_pins[] = {
 669        TEGRA_PIN_SDMMC3_DAT6_PD3,
 670};
 671
 672static const unsigned sdmmc3_dat7_pd4_pins[] = {
 673        TEGRA_PIN_SDMMC3_DAT7_PD4,
 674};
 675
 676static const unsigned vi_d1_pd5_pins[] = {
 677        TEGRA_PIN_VI_D1_PD5,
 678};
 679
 680static const unsigned vi_vsync_pd6_pins[] = {
 681        TEGRA_PIN_VI_VSYNC_PD6,
 682};
 683
 684static const unsigned vi_hsync_pd7_pins[] = {
 685        TEGRA_PIN_VI_HSYNC_PD7,
 686};
 687
 688static const unsigned lcd_d0_pe0_pins[] = {
 689        TEGRA_PIN_LCD_D0_PE0,
 690};
 691
 692static const unsigned lcd_d1_pe1_pins[] = {
 693        TEGRA_PIN_LCD_D1_PE1,
 694};
 695
 696static const unsigned lcd_d2_pe2_pins[] = {
 697        TEGRA_PIN_LCD_D2_PE2,
 698};
 699
 700static const unsigned lcd_d3_pe3_pins[] = {
 701        TEGRA_PIN_LCD_D3_PE3,
 702};
 703
 704static const unsigned lcd_d4_pe4_pins[] = {
 705        TEGRA_PIN_LCD_D4_PE4,
 706};
 707
 708static const unsigned lcd_d5_pe5_pins[] = {
 709        TEGRA_PIN_LCD_D5_PE5,
 710};
 711
 712static const unsigned lcd_d6_pe6_pins[] = {
 713        TEGRA_PIN_LCD_D6_PE6,
 714};
 715
 716static const unsigned lcd_d7_pe7_pins[] = {
 717        TEGRA_PIN_LCD_D7_PE7,
 718};
 719
 720static const unsigned lcd_d8_pf0_pins[] = {
 721        TEGRA_PIN_LCD_D8_PF0,
 722};
 723
 724static const unsigned lcd_d9_pf1_pins[] = {
 725        TEGRA_PIN_LCD_D9_PF1,
 726};
 727
 728static const unsigned lcd_d10_pf2_pins[] = {
 729        TEGRA_PIN_LCD_D10_PF2,
 730};
 731
 732static const unsigned lcd_d11_pf3_pins[] = {
 733        TEGRA_PIN_LCD_D11_PF3,
 734};
 735
 736static const unsigned lcd_d12_pf4_pins[] = {
 737        TEGRA_PIN_LCD_D12_PF4,
 738};
 739
 740static const unsigned lcd_d13_pf5_pins[] = {
 741        TEGRA_PIN_LCD_D13_PF5,
 742};
 743
 744static const unsigned lcd_d14_pf6_pins[] = {
 745        TEGRA_PIN_LCD_D14_PF6,
 746};
 747
 748static const unsigned lcd_d15_pf7_pins[] = {
 749        TEGRA_PIN_LCD_D15_PF7,
 750};
 751
 752static const unsigned gmi_ad0_pg0_pins[] = {
 753        TEGRA_PIN_GMI_AD0_PG0,
 754};
 755
 756static const unsigned gmi_ad1_pg1_pins[] = {
 757        TEGRA_PIN_GMI_AD1_PG1,
 758};
 759
 760static const unsigned gmi_ad2_pg2_pins[] = {
 761        TEGRA_PIN_GMI_AD2_PG2,
 762};
 763
 764static const unsigned gmi_ad3_pg3_pins[] = {
 765        TEGRA_PIN_GMI_AD3_PG3,
 766};
 767
 768static const unsigned gmi_ad4_pg4_pins[] = {
 769        TEGRA_PIN_GMI_AD4_PG4,
 770};
 771
 772static const unsigned gmi_ad5_pg5_pins[] = {
 773        TEGRA_PIN_GMI_AD5_PG5,
 774};
 775
 776static const unsigned gmi_ad6_pg6_pins[] = {
 777        TEGRA_PIN_GMI_AD6_PG6,
 778};
 779
 780static const unsigned gmi_ad7_pg7_pins[] = {
 781        TEGRA_PIN_GMI_AD7_PG7,
 782};
 783
 784static const unsigned gmi_ad8_ph0_pins[] = {
 785        TEGRA_PIN_GMI_AD8_PH0,
 786};
 787
 788static const unsigned gmi_ad9_ph1_pins[] = {
 789        TEGRA_PIN_GMI_AD9_PH1,
 790};
 791
 792static const unsigned gmi_ad10_ph2_pins[] = {
 793        TEGRA_PIN_GMI_AD10_PH2,
 794};
 795
 796static const unsigned gmi_ad11_ph3_pins[] = {
 797        TEGRA_PIN_GMI_AD11_PH3,
 798};
 799
 800static const unsigned gmi_ad12_ph4_pins[] = {
 801        TEGRA_PIN_GMI_AD12_PH4,
 802};
 803
 804static const unsigned gmi_ad13_ph5_pins[] = {
 805        TEGRA_PIN_GMI_AD13_PH5,
 806};
 807
 808static const unsigned gmi_ad14_ph6_pins[] = {
 809        TEGRA_PIN_GMI_AD14_PH6,
 810};
 811
 812static const unsigned gmi_ad15_ph7_pins[] = {
 813        TEGRA_PIN_GMI_AD15_PH7,
 814};
 815
 816static const unsigned gmi_wr_n_pi0_pins[] = {
 817        TEGRA_PIN_GMI_WR_N_PI0,
 818};
 819
 820static const unsigned gmi_oe_n_pi1_pins[] = {
 821        TEGRA_PIN_GMI_OE_N_PI1,
 822};
 823
 824static const unsigned gmi_dqs_pi2_pins[] = {
 825        TEGRA_PIN_GMI_DQS_PI2,
 826};
 827
 828static const unsigned gmi_cs6_n_pi3_pins[] = {
 829        TEGRA_PIN_GMI_CS6_N_PI3,
 830};
 831
 832static const unsigned gmi_rst_n_pi4_pins[] = {
 833        TEGRA_PIN_GMI_RST_N_PI4,
 834};
 835
 836static const unsigned gmi_iordy_pi5_pins[] = {
 837        TEGRA_PIN_GMI_IORDY_PI5,
 838};
 839
 840static const unsigned gmi_cs7_n_pi6_pins[] = {
 841        TEGRA_PIN_GMI_CS7_N_PI6,
 842};
 843
 844static const unsigned gmi_wait_pi7_pins[] = {
 845        TEGRA_PIN_GMI_WAIT_PI7,
 846};
 847
 848static const unsigned gmi_cs0_n_pj0_pins[] = {
 849        TEGRA_PIN_GMI_CS0_N_PJ0,
 850};
 851
 852static const unsigned lcd_de_pj1_pins[] = {
 853        TEGRA_PIN_LCD_DE_PJ1,
 854};
 855
 856static const unsigned gmi_cs1_n_pj2_pins[] = {
 857        TEGRA_PIN_GMI_CS1_N_PJ2,
 858};
 859
 860static const unsigned lcd_hsync_pj3_pins[] = {
 861        TEGRA_PIN_LCD_HSYNC_PJ3,
 862};
 863
 864static const unsigned lcd_vsync_pj4_pins[] = {
 865        TEGRA_PIN_LCD_VSYNC_PJ4,
 866};
 867
 868static const unsigned uart2_cts_n_pj5_pins[] = {
 869        TEGRA_PIN_UART2_CTS_N_PJ5,
 870};
 871
 872static const unsigned uart2_rts_n_pj6_pins[] = {
 873        TEGRA_PIN_UART2_RTS_N_PJ6,
 874};
 875
 876static const unsigned gmi_a16_pj7_pins[] = {
 877        TEGRA_PIN_GMI_A16_PJ7,
 878};
 879
 880static const unsigned gmi_adv_n_pk0_pins[] = {
 881        TEGRA_PIN_GMI_ADV_N_PK0,
 882};
 883
 884static const unsigned gmi_clk_pk1_pins[] = {
 885        TEGRA_PIN_GMI_CLK_PK1,
 886};
 887
 888static const unsigned gmi_cs4_n_pk2_pins[] = {
 889        TEGRA_PIN_GMI_CS4_N_PK2,
 890};
 891
 892static const unsigned gmi_cs2_n_pk3_pins[] = {
 893        TEGRA_PIN_GMI_CS2_N_PK3,
 894};
 895
 896static const unsigned gmi_cs3_n_pk4_pins[] = {
 897        TEGRA_PIN_GMI_CS3_N_PK4,
 898};
 899
 900static const unsigned spdif_out_pk5_pins[] = {
 901        TEGRA_PIN_SPDIF_OUT_PK5,
 902};
 903
 904static const unsigned spdif_in_pk6_pins[] = {
 905        TEGRA_PIN_SPDIF_IN_PK6,
 906};
 907
 908static const unsigned gmi_a19_pk7_pins[] = {
 909        TEGRA_PIN_GMI_A19_PK7,
 910};
 911
 912static const unsigned vi_d2_pl0_pins[] = {
 913        TEGRA_PIN_VI_D2_PL0,
 914};
 915
 916static const unsigned vi_d3_pl1_pins[] = {
 917        TEGRA_PIN_VI_D3_PL1,
 918};
 919
 920static const unsigned vi_d4_pl2_pins[] = {
 921        TEGRA_PIN_VI_D4_PL2,
 922};
 923
 924static const unsigned vi_d5_pl3_pins[] = {
 925        TEGRA_PIN_VI_D5_PL3,
 926};
 927
 928static const unsigned vi_d6_pl4_pins[] = {
 929        TEGRA_PIN_VI_D6_PL4,
 930};
 931
 932static const unsigned vi_d7_pl5_pins[] = {
 933        TEGRA_PIN_VI_D7_PL5,
 934};
 935
 936static const unsigned vi_d8_pl6_pins[] = {
 937        TEGRA_PIN_VI_D8_PL6,
 938};
 939
 940static const unsigned vi_d9_pl7_pins[] = {
 941        TEGRA_PIN_VI_D9_PL7,
 942};
 943
 944static const unsigned lcd_d16_pm0_pins[] = {
 945        TEGRA_PIN_LCD_D16_PM0,
 946};
 947
 948static const unsigned lcd_d17_pm1_pins[] = {
 949        TEGRA_PIN_LCD_D17_PM1,
 950};
 951
 952static const unsigned lcd_d18_pm2_pins[] = {
 953        TEGRA_PIN_LCD_D18_PM2,
 954};
 955
 956static const unsigned lcd_d19_pm3_pins[] = {
 957        TEGRA_PIN_LCD_D19_PM3,
 958};
 959
 960static const unsigned lcd_d20_pm4_pins[] = {
 961        TEGRA_PIN_LCD_D20_PM4,
 962};
 963
 964static const unsigned lcd_d21_pm5_pins[] = {
 965        TEGRA_PIN_LCD_D21_PM5,
 966};
 967
 968static const unsigned lcd_d22_pm6_pins[] = {
 969        TEGRA_PIN_LCD_D22_PM6,
 970};
 971
 972static const unsigned lcd_d23_pm7_pins[] = {
 973        TEGRA_PIN_LCD_D23_PM7,
 974};
 975
 976static const unsigned dap1_fs_pn0_pins[] = {
 977        TEGRA_PIN_DAP1_FS_PN0,
 978};
 979
 980static const unsigned dap1_din_pn1_pins[] = {
 981        TEGRA_PIN_DAP1_DIN_PN1,
 982};
 983
 984static const unsigned dap1_dout_pn2_pins[] = {
 985        TEGRA_PIN_DAP1_DOUT_PN2,
 986};
 987
 988static const unsigned dap1_sclk_pn3_pins[] = {
 989        TEGRA_PIN_DAP1_SCLK_PN3,
 990};
 991
 992static const unsigned lcd_cs0_n_pn4_pins[] = {
 993        TEGRA_PIN_LCD_CS0_N_PN4,
 994};
 995
 996static const unsigned lcd_sdout_pn5_pins[] = {
 997        TEGRA_PIN_LCD_SDOUT_PN5,
 998};
 999
1000static const unsigned lcd_dc0_pn6_pins[] = {
1001        TEGRA_PIN_LCD_DC0_PN6,
1002};
1003
1004static const unsigned hdmi_int_pn7_pins[] = {
1005        TEGRA_PIN_HDMI_INT_PN7,
1006};
1007
1008static const unsigned ulpi_data7_po0_pins[] = {
1009        TEGRA_PIN_ULPI_DATA7_PO0,
1010};
1011
1012static const unsigned ulpi_data0_po1_pins[] = {
1013        TEGRA_PIN_ULPI_DATA0_PO1,
1014};
1015
1016static const unsigned ulpi_data1_po2_pins[] = {
1017        TEGRA_PIN_ULPI_DATA1_PO2,
1018};
1019
1020static const unsigned ulpi_data2_po3_pins[] = {
1021        TEGRA_PIN_ULPI_DATA2_PO3,
1022};
1023
1024static const unsigned ulpi_data3_po4_pins[] = {
1025        TEGRA_PIN_ULPI_DATA3_PO4,
1026};
1027
1028static const unsigned ulpi_data4_po5_pins[] = {
1029        TEGRA_PIN_ULPI_DATA4_PO5,
1030};
1031
1032static const unsigned ulpi_data5_po6_pins[] = {
1033        TEGRA_PIN_ULPI_DATA5_PO6,
1034};
1035
1036static const unsigned ulpi_data6_po7_pins[] = {
1037        TEGRA_PIN_ULPI_DATA6_PO7,
1038};
1039
1040static const unsigned dap3_fs_pp0_pins[] = {
1041        TEGRA_PIN_DAP3_FS_PP0,
1042};
1043
1044static const unsigned dap3_din_pp1_pins[] = {
1045        TEGRA_PIN_DAP3_DIN_PP1,
1046};
1047
1048static const unsigned dap3_dout_pp2_pins[] = {
1049        TEGRA_PIN_DAP3_DOUT_PP2,
1050};
1051
1052static const unsigned dap3_sclk_pp3_pins[] = {
1053        TEGRA_PIN_DAP3_SCLK_PP3,
1054};
1055
1056static const unsigned dap4_fs_pp4_pins[] = {
1057        TEGRA_PIN_DAP4_FS_PP4,
1058};
1059
1060static const unsigned dap4_din_pp5_pins[] = {
1061        TEGRA_PIN_DAP4_DIN_PP5,
1062};
1063
1064static const unsigned dap4_dout_pp6_pins[] = {
1065        TEGRA_PIN_DAP4_DOUT_PP6,
1066};
1067
1068static const unsigned dap4_sclk_pp7_pins[] = {
1069        TEGRA_PIN_DAP4_SCLK_PP7,
1070};
1071
1072static const unsigned kb_col0_pq0_pins[] = {
1073        TEGRA_PIN_KB_COL0_PQ0,
1074};
1075
1076static const unsigned kb_col1_pq1_pins[] = {
1077        TEGRA_PIN_KB_COL1_PQ1,
1078};
1079
1080static const unsigned kb_col2_pq2_pins[] = {
1081        TEGRA_PIN_KB_COL2_PQ2,
1082};
1083
1084static const unsigned kb_col3_pq3_pins[] = {
1085        TEGRA_PIN_KB_COL3_PQ3,
1086};
1087
1088static const unsigned kb_col4_pq4_pins[] = {
1089        TEGRA_PIN_KB_COL4_PQ4,
1090};
1091
1092static const unsigned kb_col5_pq5_pins[] = {
1093        TEGRA_PIN_KB_COL5_PQ5,
1094};
1095
1096static const unsigned kb_col6_pq6_pins[] = {
1097        TEGRA_PIN_KB_COL6_PQ6,
1098};
1099
1100static const unsigned kb_col7_pq7_pins[] = {
1101        TEGRA_PIN_KB_COL7_PQ7,
1102};
1103
1104static const unsigned kb_row0_pr0_pins[] = {
1105        TEGRA_PIN_KB_ROW0_PR0,
1106};
1107
1108static const unsigned kb_row1_pr1_pins[] = {
1109        TEGRA_PIN_KB_ROW1_PR1,
1110};
1111
1112static const unsigned kb_row2_pr2_pins[] = {
1113        TEGRA_PIN_KB_ROW2_PR2,
1114};
1115
1116static const unsigned kb_row3_pr3_pins[] = {
1117        TEGRA_PIN_KB_ROW3_PR3,
1118};
1119
1120static const unsigned kb_row4_pr4_pins[] = {
1121        TEGRA_PIN_KB_ROW4_PR4,
1122};
1123
1124static const unsigned kb_row5_pr5_pins[] = {
1125        TEGRA_PIN_KB_ROW5_PR5,
1126};
1127
1128static const unsigned kb_row6_pr6_pins[] = {
1129        TEGRA_PIN_KB_ROW6_PR6,
1130};
1131
1132static const unsigned kb_row7_pr7_pins[] = {
1133        TEGRA_PIN_KB_ROW7_PR7,
1134};
1135
1136static const unsigned kb_row8_ps0_pins[] = {
1137        TEGRA_PIN_KB_ROW8_PS0,
1138};
1139
1140static const unsigned kb_row9_ps1_pins[] = {
1141        TEGRA_PIN_KB_ROW9_PS1,
1142};
1143
1144static const unsigned kb_row10_ps2_pins[] = {
1145        TEGRA_PIN_KB_ROW10_PS2,
1146};
1147
1148static const unsigned kb_row11_ps3_pins[] = {
1149        TEGRA_PIN_KB_ROW11_PS3,
1150};
1151
1152static const unsigned kb_row12_ps4_pins[] = {
1153        TEGRA_PIN_KB_ROW12_PS4,
1154};
1155
1156static const unsigned kb_row13_ps5_pins[] = {
1157        TEGRA_PIN_KB_ROW13_PS5,
1158};
1159
1160static const unsigned kb_row14_ps6_pins[] = {
1161        TEGRA_PIN_KB_ROW14_PS6,
1162};
1163
1164static const unsigned kb_row15_ps7_pins[] = {
1165        TEGRA_PIN_KB_ROW15_PS7,
1166};
1167
1168static const unsigned vi_pclk_pt0_pins[] = {
1169        TEGRA_PIN_VI_PCLK_PT0,
1170};
1171
1172static const unsigned vi_mclk_pt1_pins[] = {
1173        TEGRA_PIN_VI_MCLK_PT1,
1174};
1175
1176static const unsigned vi_d10_pt2_pins[] = {
1177        TEGRA_PIN_VI_D10_PT2,
1178};
1179
1180static const unsigned vi_d11_pt3_pins[] = {
1181        TEGRA_PIN_VI_D11_PT3,
1182};
1183
1184static const unsigned vi_d0_pt4_pins[] = {
1185        TEGRA_PIN_VI_D0_PT4,
1186};
1187
1188static const unsigned gen2_i2c_scl_pt5_pins[] = {
1189        TEGRA_PIN_GEN2_I2C_SCL_PT5,
1190};
1191
1192static const unsigned gen2_i2c_sda_pt6_pins[] = {
1193        TEGRA_PIN_GEN2_I2C_SDA_PT6,
1194};
1195
1196static const unsigned sdmmc4_cmd_pt7_pins[] = {
1197        TEGRA_PIN_SDMMC4_CMD_PT7,
1198};
1199
1200static const unsigned pu0_pins[] = {
1201        TEGRA_PIN_PU0,
1202};
1203
1204static const unsigned pu1_pins[] = {
1205        TEGRA_PIN_PU1,
1206};
1207
1208static const unsigned pu2_pins[] = {
1209        TEGRA_PIN_PU2,
1210};
1211
1212static const unsigned pu3_pins[] = {
1213        TEGRA_PIN_PU3,
1214};
1215
1216static const unsigned pu4_pins[] = {
1217        TEGRA_PIN_PU4,
1218};
1219
1220static const unsigned pu5_pins[] = {
1221        TEGRA_PIN_PU5,
1222};
1223
1224static const unsigned pu6_pins[] = {
1225        TEGRA_PIN_PU6,
1226};
1227
1228static const unsigned jtag_rtck_pu7_pins[] = {
1229        TEGRA_PIN_JTAG_RTCK_PU7,
1230};
1231
1232static const unsigned pv0_pins[] = {
1233        TEGRA_PIN_PV0,
1234};
1235
1236static const unsigned pv1_pins[] = {
1237        TEGRA_PIN_PV1,
1238};
1239
1240static const unsigned pv2_pins[] = {
1241        TEGRA_PIN_PV2,
1242};
1243
1244static const unsigned pv3_pins[] = {
1245        TEGRA_PIN_PV3,
1246};
1247
1248static const unsigned ddc_scl_pv4_pins[] = {
1249        TEGRA_PIN_DDC_SCL_PV4,
1250};
1251
1252static const unsigned ddc_sda_pv5_pins[] = {
1253        TEGRA_PIN_DDC_SDA_PV5,
1254};
1255
1256static const unsigned crt_hsync_pv6_pins[] = {
1257        TEGRA_PIN_CRT_HSYNC_PV6,
1258};
1259
1260static const unsigned crt_vsync_pv7_pins[] = {
1261        TEGRA_PIN_CRT_VSYNC_PV7,
1262};
1263
1264static const unsigned lcd_cs1_n_pw0_pins[] = {
1265        TEGRA_PIN_LCD_CS1_N_PW0,
1266};
1267
1268static const unsigned lcd_m1_pw1_pins[] = {
1269        TEGRA_PIN_LCD_M1_PW1,
1270};
1271
1272static const unsigned spi2_cs1_n_pw2_pins[] = {
1273        TEGRA_PIN_SPI2_CS1_N_PW2,
1274};
1275
1276static const unsigned spi2_cs2_n_pw3_pins[] = {
1277        TEGRA_PIN_SPI2_CS2_N_PW3,
1278};
1279
1280static const unsigned clk1_out_pw4_pins[] = {
1281        TEGRA_PIN_CLK1_OUT_PW4,
1282};
1283
1284static const unsigned clk2_out_pw5_pins[] = {
1285        TEGRA_PIN_CLK2_OUT_PW5,
1286};
1287
1288static const unsigned uart3_txd_pw6_pins[] = {
1289        TEGRA_PIN_UART3_TXD_PW6,
1290};
1291
1292static const unsigned uart3_rxd_pw7_pins[] = {
1293        TEGRA_PIN_UART3_RXD_PW7,
1294};
1295
1296static const unsigned spi2_mosi_px0_pins[] = {
1297        TEGRA_PIN_SPI2_MOSI_PX0,
1298};
1299
1300static const unsigned spi2_miso_px1_pins[] = {
1301        TEGRA_PIN_SPI2_MISO_PX1,
1302};
1303
1304static const unsigned spi2_sck_px2_pins[] = {
1305        TEGRA_PIN_SPI2_SCK_PX2,
1306};
1307
1308static const unsigned spi2_cs0_n_px3_pins[] = {
1309        TEGRA_PIN_SPI2_CS0_N_PX3,
1310};
1311
1312static const unsigned spi1_mosi_px4_pins[] = {
1313        TEGRA_PIN_SPI1_MOSI_PX4,
1314};
1315
1316static const unsigned spi1_sck_px5_pins[] = {
1317        TEGRA_PIN_SPI1_SCK_PX5,
1318};
1319
1320static const unsigned spi1_cs0_n_px6_pins[] = {
1321        TEGRA_PIN_SPI1_CS0_N_PX6,
1322};
1323
1324static const unsigned spi1_miso_px7_pins[] = {
1325        TEGRA_PIN_SPI1_MISO_PX7,
1326};
1327
1328static const unsigned ulpi_clk_py0_pins[] = {
1329        TEGRA_PIN_ULPI_CLK_PY0,
1330};
1331
1332static const unsigned ulpi_dir_py1_pins[] = {
1333        TEGRA_PIN_ULPI_DIR_PY1,
1334};
1335
1336static const unsigned ulpi_nxt_py2_pins[] = {
1337        TEGRA_PIN_ULPI_NXT_PY2,
1338};
1339
1340static const unsigned ulpi_stp_py3_pins[] = {
1341        TEGRA_PIN_ULPI_STP_PY3,
1342};
1343
1344static const unsigned sdmmc1_dat3_py4_pins[] = {
1345        TEGRA_PIN_SDMMC1_DAT3_PY4,
1346};
1347
1348static const unsigned sdmmc1_dat2_py5_pins[] = {
1349        TEGRA_PIN_SDMMC1_DAT2_PY5,
1350};
1351
1352static const unsigned sdmmc1_dat1_py6_pins[] = {
1353        TEGRA_PIN_SDMMC1_DAT1_PY6,
1354};
1355
1356static const unsigned sdmmc1_dat0_py7_pins[] = {
1357        TEGRA_PIN_SDMMC1_DAT0_PY7,
1358};
1359
1360static const unsigned sdmmc1_clk_pz0_pins[] = {
1361        TEGRA_PIN_SDMMC1_CLK_PZ0,
1362};
1363
1364static const unsigned sdmmc1_cmd_pz1_pins[] = {
1365        TEGRA_PIN_SDMMC1_CMD_PZ1,
1366};
1367
1368static const unsigned lcd_sdin_pz2_pins[] = {
1369        TEGRA_PIN_LCD_SDIN_PZ2,
1370};
1371
1372static const unsigned lcd_wr_n_pz3_pins[] = {
1373        TEGRA_PIN_LCD_WR_N_PZ3,
1374};
1375
1376static const unsigned lcd_sck_pz4_pins[] = {
1377        TEGRA_PIN_LCD_SCK_PZ4,
1378};
1379
1380static const unsigned sys_clk_req_pz5_pins[] = {
1381        TEGRA_PIN_SYS_CLK_REQ_PZ5,
1382};
1383
1384static const unsigned pwr_i2c_scl_pz6_pins[] = {
1385        TEGRA_PIN_PWR_I2C_SCL_PZ6,
1386};
1387
1388static const unsigned pwr_i2c_sda_pz7_pins[] = {
1389        TEGRA_PIN_PWR_I2C_SDA_PZ7,
1390};
1391
1392static const unsigned sdmmc4_dat0_paa0_pins[] = {
1393        TEGRA_PIN_SDMMC4_DAT0_PAA0,
1394};
1395
1396static const unsigned sdmmc4_dat1_paa1_pins[] = {
1397        TEGRA_PIN_SDMMC4_DAT1_PAA1,
1398};
1399
1400static const unsigned sdmmc4_dat2_paa2_pins[] = {
1401        TEGRA_PIN_SDMMC4_DAT2_PAA2,
1402};
1403
1404static const unsigned sdmmc4_dat3_paa3_pins[] = {
1405        TEGRA_PIN_SDMMC4_DAT3_PAA3,
1406};
1407
1408static const unsigned sdmmc4_dat4_paa4_pins[] = {
1409        TEGRA_PIN_SDMMC4_DAT4_PAA4,
1410};
1411
1412static const unsigned sdmmc4_dat5_paa5_pins[] = {
1413        TEGRA_PIN_SDMMC4_DAT5_PAA5,
1414};
1415
1416static const unsigned sdmmc4_dat6_paa6_pins[] = {
1417        TEGRA_PIN_SDMMC4_DAT6_PAA6,
1418};
1419
1420static const unsigned sdmmc4_dat7_paa7_pins[] = {
1421        TEGRA_PIN_SDMMC4_DAT7_PAA7,
1422};
1423
1424static const unsigned pbb0_pins[] = {
1425        TEGRA_PIN_PBB0,
1426};
1427
1428static const unsigned cam_i2c_scl_pbb1_pins[] = {
1429        TEGRA_PIN_CAM_I2C_SCL_PBB1,
1430};
1431
1432static const unsigned cam_i2c_sda_pbb2_pins[] = {
1433        TEGRA_PIN_CAM_I2C_SDA_PBB2,
1434};
1435
1436static const unsigned pbb3_pins[] = {
1437        TEGRA_PIN_PBB3,
1438};
1439
1440static const unsigned pbb4_pins[] = {
1441        TEGRA_PIN_PBB4,
1442};
1443
1444static const unsigned pbb5_pins[] = {
1445        TEGRA_PIN_PBB5,
1446};
1447
1448static const unsigned pbb6_pins[] = {
1449        TEGRA_PIN_PBB6,
1450};
1451
1452static const unsigned pbb7_pins[] = {
1453        TEGRA_PIN_PBB7,
1454};
1455
1456static const unsigned cam_mclk_pcc0_pins[] = {
1457        TEGRA_PIN_CAM_MCLK_PCC0,
1458};
1459
1460static const unsigned pcc1_pins[] = {
1461        TEGRA_PIN_PCC1,
1462};
1463
1464static const unsigned pcc2_pins[] = {
1465        TEGRA_PIN_PCC2,
1466};
1467
1468static const unsigned sdmmc4_rst_n_pcc3_pins[] = {
1469        TEGRA_PIN_SDMMC4_RST_N_PCC3,
1470};
1471
1472static const unsigned sdmmc4_clk_pcc4_pins[] = {
1473        TEGRA_PIN_SDMMC4_CLK_PCC4,
1474};
1475
1476static const unsigned clk2_req_pcc5_pins[] = {
1477        TEGRA_PIN_CLK2_REQ_PCC5,
1478};
1479
1480static const unsigned pex_l2_rst_n_pcc6_pins[] = {
1481        TEGRA_PIN_PEX_L2_RST_N_PCC6,
1482};
1483
1484static const unsigned pex_l2_clkreq_n_pcc7_pins[] = {
1485        TEGRA_PIN_PEX_L2_CLKREQ_N_PCC7,
1486};
1487
1488static const unsigned pex_l0_prsnt_n_pdd0_pins[] = {
1489        TEGRA_PIN_PEX_L0_PRSNT_N_PDD0,
1490};
1491
1492static const unsigned pex_l0_rst_n_pdd1_pins[] = {
1493        TEGRA_PIN_PEX_L0_RST_N_PDD1,
1494};
1495
1496static const unsigned pex_l0_clkreq_n_pdd2_pins[] = {
1497        TEGRA_PIN_PEX_L0_CLKREQ_N_PDD2,
1498};
1499
1500static const unsigned pex_wake_n_pdd3_pins[] = {
1501        TEGRA_PIN_PEX_WAKE_N_PDD3,
1502};
1503
1504static const unsigned pex_l1_prsnt_n_pdd4_pins[] = {
1505        TEGRA_PIN_PEX_L1_PRSNT_N_PDD4,
1506};
1507
1508static const unsigned pex_l1_rst_n_pdd5_pins[] = {
1509        TEGRA_PIN_PEX_L1_RST_N_PDD5,
1510};
1511
1512static const unsigned pex_l1_clkreq_n_pdd6_pins[] = {
1513        TEGRA_PIN_PEX_L1_CLKREQ_N_PDD6,
1514};
1515
1516static const unsigned pex_l2_prsnt_n_pdd7_pins[] = {
1517        TEGRA_PIN_PEX_L2_PRSNT_N_PDD7,
1518};
1519
1520static const unsigned clk3_out_pee0_pins[] = {
1521        TEGRA_PIN_CLK3_OUT_PEE0,
1522};
1523
1524static const unsigned clk3_req_pee1_pins[] = {
1525        TEGRA_PIN_CLK3_REQ_PEE1,
1526};
1527
1528static const unsigned clk1_req_pee2_pins[] = {
1529        TEGRA_PIN_CLK1_REQ_PEE2,
1530};
1531
1532static const unsigned hdmi_cec_pee3_pins[] = {
1533        TEGRA_PIN_HDMI_CEC_PEE3,
1534};
1535
1536static const unsigned clk_32k_in_pins[] = {
1537        TEGRA_PIN_CLK_32K_IN,
1538};
1539
1540static const unsigned core_pwr_req_pins[] = {
1541        TEGRA_PIN_CORE_PWR_REQ,
1542};
1543
1544static const unsigned cpu_pwr_req_pins[] = {
1545        TEGRA_PIN_CPU_PWR_REQ,
1546};
1547
1548static const unsigned owr_pins[] = {
1549        TEGRA_PIN_OWR,
1550};
1551
1552static const unsigned pwr_int_n_pins[] = {
1553        TEGRA_PIN_PWR_INT_N,
1554};
1555
1556static const unsigned drive_ao1_pins[] = {
1557        TEGRA_PIN_KB_ROW0_PR0,
1558        TEGRA_PIN_KB_ROW1_PR1,
1559        TEGRA_PIN_KB_ROW2_PR2,
1560        TEGRA_PIN_KB_ROW3_PR3,
1561        TEGRA_PIN_KB_ROW4_PR4,
1562        TEGRA_PIN_KB_ROW5_PR5,
1563        TEGRA_PIN_KB_ROW6_PR6,
1564        TEGRA_PIN_KB_ROW7_PR7,
1565        TEGRA_PIN_PWR_I2C_SCL_PZ6,
1566        TEGRA_PIN_PWR_I2C_SDA_PZ7,
1567        TEGRA_PIN_SYS_RESET_N,
1568};
1569
1570static const unsigned drive_ao2_pins[] = {
1571        TEGRA_PIN_CLK_32K_OUT_PA0,
1572        TEGRA_PIN_KB_COL0_PQ0,
1573        TEGRA_PIN_KB_COL1_PQ1,
1574        TEGRA_PIN_KB_COL2_PQ2,
1575        TEGRA_PIN_KB_COL3_PQ3,
1576        TEGRA_PIN_KB_COL4_PQ4,
1577        TEGRA_PIN_KB_COL5_PQ5,
1578        TEGRA_PIN_KB_COL6_PQ6,
1579        TEGRA_PIN_KB_COL7_PQ7,
1580        TEGRA_PIN_KB_ROW8_PS0,
1581        TEGRA_PIN_KB_ROW9_PS1,
1582        TEGRA_PIN_KB_ROW10_PS2,
1583        TEGRA_PIN_KB_ROW11_PS3,
1584        TEGRA_PIN_KB_ROW12_PS4,
1585        TEGRA_PIN_KB_ROW13_PS5,
1586        TEGRA_PIN_KB_ROW14_PS6,
1587        TEGRA_PIN_KB_ROW15_PS7,
1588        TEGRA_PIN_SYS_CLK_REQ_PZ5,
1589        TEGRA_PIN_CLK_32K_IN,
1590        TEGRA_PIN_CORE_PWR_REQ,
1591        TEGRA_PIN_CPU_PWR_REQ,
1592        TEGRA_PIN_PWR_INT_N,
1593};
1594
1595static const unsigned drive_at1_pins[] = {
1596        TEGRA_PIN_GMI_AD8_PH0,
1597        TEGRA_PIN_GMI_AD9_PH1,
1598        TEGRA_PIN_GMI_AD10_PH2,
1599        TEGRA_PIN_GMI_AD11_PH3,
1600        TEGRA_PIN_GMI_AD12_PH4,
1601        TEGRA_PIN_GMI_AD13_PH5,
1602        TEGRA_PIN_GMI_AD14_PH6,
1603        TEGRA_PIN_GMI_AD15_PH7,
1604        TEGRA_PIN_GMI_IORDY_PI5,
1605        TEGRA_PIN_GMI_CS7_N_PI6,
1606};
1607
1608static const unsigned drive_at2_pins[] = {
1609        TEGRA_PIN_GMI_AD0_PG0,
1610        TEGRA_PIN_GMI_AD1_PG1,
1611        TEGRA_PIN_GMI_AD2_PG2,
1612        TEGRA_PIN_GMI_AD3_PG3,
1613        TEGRA_PIN_GMI_AD4_PG4,
1614        TEGRA_PIN_GMI_AD5_PG5,
1615        TEGRA_PIN_GMI_AD6_PG6,
1616        TEGRA_PIN_GMI_AD7_PG7,
1617        TEGRA_PIN_GMI_WR_N_PI0,
1618        TEGRA_PIN_GMI_OE_N_PI1,
1619        TEGRA_PIN_GMI_DQS_PI2,
1620        TEGRA_PIN_GMI_CS6_N_PI3,
1621        TEGRA_PIN_GMI_RST_N_PI4,
1622        TEGRA_PIN_GMI_WAIT_PI7,
1623        TEGRA_PIN_GMI_ADV_N_PK0,
1624        TEGRA_PIN_GMI_CLK_PK1,
1625        TEGRA_PIN_GMI_CS4_N_PK2,
1626        TEGRA_PIN_GMI_CS2_N_PK3,
1627        TEGRA_PIN_GMI_CS3_N_PK4,
1628};
1629
1630static const unsigned drive_at3_pins[] = {
1631        TEGRA_PIN_GMI_WP_N_PC7,
1632        TEGRA_PIN_GMI_CS0_N_PJ0,
1633};
1634
1635static const unsigned drive_at4_pins[] = {
1636        TEGRA_PIN_GMI_A17_PB0,
1637        TEGRA_PIN_GMI_A18_PB1,
1638        TEGRA_PIN_GMI_CS1_N_PJ2,
1639        TEGRA_PIN_GMI_A16_PJ7,
1640        TEGRA_PIN_GMI_A19_PK7,
1641};
1642
1643static const unsigned drive_at5_pins[] = {
1644        TEGRA_PIN_GEN2_I2C_SCL_PT5,
1645        TEGRA_PIN_GEN2_I2C_SDA_PT6,
1646};
1647
1648static const unsigned drive_cdev1_pins[] = {
1649        TEGRA_PIN_CLK1_OUT_PW4,
1650        TEGRA_PIN_CLK1_REQ_PEE2,
1651};
1652
1653static const unsigned drive_cdev2_pins[] = {
1654        TEGRA_PIN_CLK2_OUT_PW5,
1655        TEGRA_PIN_CLK2_REQ_PCC5,
1656};
1657
1658static const unsigned drive_cec_pins[] = {
1659        TEGRA_PIN_HDMI_CEC_PEE3,
1660};
1661
1662static const unsigned drive_crt_pins[] = {
1663        TEGRA_PIN_CRT_HSYNC_PV6,
1664        TEGRA_PIN_CRT_VSYNC_PV7,
1665};
1666
1667static const unsigned drive_csus_pins[] = {
1668        TEGRA_PIN_VI_MCLK_PT1,
1669};
1670
1671static const unsigned drive_dap1_pins[] = {
1672        TEGRA_PIN_SPDIF_OUT_PK5,
1673        TEGRA_PIN_SPDIF_IN_PK6,
1674        TEGRA_PIN_DAP1_FS_PN0,
1675        TEGRA_PIN_DAP1_DIN_PN1,
1676        TEGRA_PIN_DAP1_DOUT_PN2,
1677        TEGRA_PIN_DAP1_SCLK_PN3,
1678};
1679
1680static const unsigned drive_dap2_pins[] = {
1681        TEGRA_PIN_DAP2_FS_PA2,
1682        TEGRA_PIN_DAP2_SCLK_PA3,
1683        TEGRA_PIN_DAP2_DIN_PA4,
1684        TEGRA_PIN_DAP2_DOUT_PA5,
1685};
1686
1687static const unsigned drive_dap3_pins[] = {
1688        TEGRA_PIN_DAP3_FS_PP0,
1689        TEGRA_PIN_DAP3_DIN_PP1,
1690        TEGRA_PIN_DAP3_DOUT_PP2,
1691        TEGRA_PIN_DAP3_SCLK_PP3,
1692};
1693
1694static const unsigned drive_dap4_pins[] = {
1695        TEGRA_PIN_DAP4_FS_PP4,
1696        TEGRA_PIN_DAP4_DIN_PP5,
1697        TEGRA_PIN_DAP4_DOUT_PP6,
1698        TEGRA_PIN_DAP4_SCLK_PP7,
1699};
1700
1701static const unsigned drive_dbg_pins[] = {
1702        TEGRA_PIN_GEN1_I2C_SCL_PC4,
1703        TEGRA_PIN_GEN1_I2C_SDA_PC5,
1704        TEGRA_PIN_PU0,
1705        TEGRA_PIN_PU1,
1706        TEGRA_PIN_PU2,
1707        TEGRA_PIN_PU3,
1708        TEGRA_PIN_PU4,
1709        TEGRA_PIN_PU5,
1710        TEGRA_PIN_PU6,
1711        TEGRA_PIN_JTAG_RTCK_PU7,
1712        TEGRA_PIN_JTAG_TCK,
1713        TEGRA_PIN_JTAG_TDI,
1714        TEGRA_PIN_JTAG_TDO,
1715        TEGRA_PIN_JTAG_TMS,
1716        TEGRA_PIN_JTAG_TRST_N,
1717        TEGRA_PIN_TEST_MODE_EN,
1718};
1719
1720static const unsigned drive_ddc_pins[] = {
1721        TEGRA_PIN_DDC_SCL_PV4,
1722        TEGRA_PIN_DDC_SDA_PV5,
1723};
1724
1725static const unsigned drive_dev3_pins[] = {
1726        TEGRA_PIN_CLK3_OUT_PEE0,
1727        TEGRA_PIN_CLK3_REQ_PEE1,
1728};
1729
1730static const unsigned drive_gma_pins[] = {
1731        TEGRA_PIN_SDMMC4_DAT0_PAA0,
1732        TEGRA_PIN_SDMMC4_DAT1_PAA1,
1733        TEGRA_PIN_SDMMC4_DAT2_PAA2,
1734        TEGRA_PIN_SDMMC4_DAT3_PAA3,
1735        TEGRA_PIN_SDMMC4_RST_N_PCC3,
1736};
1737
1738static const unsigned drive_gmb_pins[] = {
1739        TEGRA_PIN_SDMMC4_DAT4_PAA4,
1740        TEGRA_PIN_SDMMC4_DAT5_PAA5,
1741        TEGRA_PIN_SDMMC4_DAT6_PAA6,
1742        TEGRA_PIN_SDMMC4_DAT7_PAA7,
1743};
1744
1745static const unsigned drive_gmc_pins[] = {
1746        TEGRA_PIN_SDMMC4_CLK_PCC4,
1747};
1748
1749static const unsigned drive_gmd_pins[] = {
1750        TEGRA_PIN_SDMMC4_CMD_PT7,
1751};
1752
1753static const unsigned drive_gme_pins[] = {
1754        TEGRA_PIN_PBB0,
1755        TEGRA_PIN_CAM_I2C_SCL_PBB1,
1756        TEGRA_PIN_CAM_I2C_SDA_PBB2,
1757        TEGRA_PIN_PBB3,
1758        TEGRA_PIN_PCC2,
1759};
1760
1761static const unsigned drive_gmf_pins[] = {
1762        TEGRA_PIN_PBB4,
1763        TEGRA_PIN_PBB5,
1764        TEGRA_PIN_PBB6,
1765        TEGRA_PIN_PBB7,
1766};
1767
1768static const unsigned drive_gmg_pins[] = {
1769        TEGRA_PIN_CAM_MCLK_PCC0,
1770};
1771
1772static const unsigned drive_gmh_pins[] = {
1773        TEGRA_PIN_PCC1,
1774};
1775
1776static const unsigned drive_gpv_pins[] = {
1777        TEGRA_PIN_PEX_L2_RST_N_PCC6,
1778        TEGRA_PIN_PEX_L2_CLKREQ_N_PCC7,
1779        TEGRA_PIN_PEX_L0_PRSNT_N_PDD0,
1780        TEGRA_PIN_PEX_L0_RST_N_PDD1,
1781        TEGRA_PIN_PEX_L0_CLKREQ_N_PDD2,
1782        TEGRA_PIN_PEX_WAKE_N_PDD3,
1783        TEGRA_PIN_PEX_L1_PRSNT_N_PDD4,
1784        TEGRA_PIN_PEX_L1_RST_N_PDD5,
1785        TEGRA_PIN_PEX_L1_CLKREQ_N_PDD6,
1786        TEGRA_PIN_PEX_L2_PRSNT_N_PDD7,
1787};
1788
1789static const unsigned drive_lcd1_pins[] = {
1790        TEGRA_PIN_LCD_PWR1_PC1,
1791        TEGRA_PIN_LCD_PWR2_PC6,
1792        TEGRA_PIN_LCD_CS0_N_PN4,
1793        TEGRA_PIN_LCD_SDOUT_PN5,
1794        TEGRA_PIN_LCD_DC0_PN6,
1795        TEGRA_PIN_LCD_SDIN_PZ2,
1796        TEGRA_PIN_LCD_WR_N_PZ3,
1797        TEGRA_PIN_LCD_SCK_PZ4,
1798};
1799
1800static const unsigned drive_lcd2_pins[] = {
1801        TEGRA_PIN_LCD_PWR0_PB2,
1802        TEGRA_PIN_LCD_PCLK_PB3,
1803        TEGRA_PIN_LCD_DC1_PD2,
1804        TEGRA_PIN_LCD_D0_PE0,
1805        TEGRA_PIN_LCD_D1_PE1,
1806        TEGRA_PIN_LCD_D2_PE2,
1807        TEGRA_PIN_LCD_D3_PE3,
1808        TEGRA_PIN_LCD_D4_PE4,
1809        TEGRA_PIN_LCD_D5_PE5,
1810        TEGRA_PIN_LCD_D6_PE6,
1811        TEGRA_PIN_LCD_D7_PE7,
1812        TEGRA_PIN_LCD_D8_PF0,
1813        TEGRA_PIN_LCD_D9_PF1,
1814        TEGRA_PIN_LCD_D10_PF2,
1815        TEGRA_PIN_LCD_D11_PF3,
1816        TEGRA_PIN_LCD_D12_PF4,
1817        TEGRA_PIN_LCD_D13_PF5,
1818        TEGRA_PIN_LCD_D14_PF6,
1819        TEGRA_PIN_LCD_D15_PF7,
1820        TEGRA_PIN_LCD_DE_PJ1,
1821        TEGRA_PIN_LCD_HSYNC_PJ3,
1822        TEGRA_PIN_LCD_VSYNC_PJ4,
1823        TEGRA_PIN_LCD_D16_PM0,
1824        TEGRA_PIN_LCD_D17_PM1,
1825        TEGRA_PIN_LCD_D18_PM2,
1826        TEGRA_PIN_LCD_D19_PM3,
1827        TEGRA_PIN_LCD_D20_PM4,
1828        TEGRA_PIN_LCD_D21_PM5,
1829        TEGRA_PIN_LCD_D22_PM6,
1830        TEGRA_PIN_LCD_D23_PM7,
1831        TEGRA_PIN_HDMI_INT_PN7,
1832        TEGRA_PIN_LCD_CS1_N_PW0,
1833        TEGRA_PIN_LCD_M1_PW1,
1834};
1835
1836static const unsigned drive_owr_pins[] = {
1837        TEGRA_PIN_OWR,
1838};
1839
1840static const unsigned drive_sdio1_pins[] = {
1841        TEGRA_PIN_SDMMC1_DAT3_PY4,
1842        TEGRA_PIN_SDMMC1_DAT2_PY5,
1843        TEGRA_PIN_SDMMC1_DAT1_PY6,
1844        TEGRA_PIN_SDMMC1_DAT0_PY7,
1845        TEGRA_PIN_SDMMC1_CLK_PZ0,
1846        TEGRA_PIN_SDMMC1_CMD_PZ1,
1847};
1848
1849static const unsigned drive_sdio2_pins[] = {
1850        TEGRA_PIN_SDMMC3_DAT5_PD0,
1851        TEGRA_PIN_SDMMC3_DAT4_PD1,
1852        TEGRA_PIN_SDMMC3_DAT6_PD3,
1853        TEGRA_PIN_SDMMC3_DAT7_PD4,
1854};
1855
1856static const unsigned drive_sdio3_pins[] = {
1857        TEGRA_PIN_SDMMC3_CLK_PA6,
1858        TEGRA_PIN_SDMMC3_CMD_PA7,
1859        TEGRA_PIN_SDMMC3_DAT3_PB4,
1860        TEGRA_PIN_SDMMC3_DAT2_PB5,
1861        TEGRA_PIN_SDMMC3_DAT1_PB6,
1862        TEGRA_PIN_SDMMC3_DAT0_PB7,
1863};
1864
1865static const unsigned drive_spi_pins[] = {
1866        TEGRA_PIN_SPI2_CS1_N_PW2,
1867        TEGRA_PIN_SPI2_CS2_N_PW3,
1868        TEGRA_PIN_SPI2_MOSI_PX0,
1869        TEGRA_PIN_SPI2_MISO_PX1,
1870        TEGRA_PIN_SPI2_SCK_PX2,
1871        TEGRA_PIN_SPI2_CS0_N_PX3,
1872        TEGRA_PIN_SPI1_MOSI_PX4,
1873        TEGRA_PIN_SPI1_SCK_PX5,
1874        TEGRA_PIN_SPI1_CS0_N_PX6,
1875        TEGRA_PIN_SPI1_MISO_PX7,
1876};
1877
1878static const unsigned drive_uaa_pins[] = {
1879        TEGRA_PIN_ULPI_DATA0_PO1,
1880        TEGRA_PIN_ULPI_DATA1_PO2,
1881        TEGRA_PIN_ULPI_DATA2_PO3,
1882        TEGRA_PIN_ULPI_DATA3_PO4,
1883};
1884
1885static const unsigned drive_uab_pins[] = {
1886        TEGRA_PIN_ULPI_DATA7_PO0,
1887        TEGRA_PIN_ULPI_DATA4_PO5,
1888        TEGRA_PIN_ULPI_DATA5_PO6,
1889        TEGRA_PIN_ULPI_DATA6_PO7,
1890        TEGRA_PIN_PV0,
1891        TEGRA_PIN_PV1,
1892        TEGRA_PIN_PV2,
1893        TEGRA_PIN_PV3,
1894};
1895
1896static const unsigned drive_uart2_pins[] = {
1897        TEGRA_PIN_UART2_TXD_PC2,
1898        TEGRA_PIN_UART2_RXD_PC3,
1899        TEGRA_PIN_UART2_CTS_N_PJ5,
1900        TEGRA_PIN_UART2_RTS_N_PJ6,
1901};
1902
1903static const unsigned drive_uart3_pins[] = {
1904        TEGRA_PIN_UART3_CTS_N_PA1,
1905        TEGRA_PIN_UART3_RTS_N_PC0,
1906        TEGRA_PIN_UART3_TXD_PW6,
1907        TEGRA_PIN_UART3_RXD_PW7,
1908};
1909
1910static const unsigned drive_uda_pins[] = {
1911        TEGRA_PIN_ULPI_CLK_PY0,
1912        TEGRA_PIN_ULPI_DIR_PY1,
1913        TEGRA_PIN_ULPI_NXT_PY2,
1914        TEGRA_PIN_ULPI_STP_PY3,
1915};
1916
1917static const unsigned drive_vi1_pins[] = {
1918        TEGRA_PIN_VI_D1_PD5,
1919        TEGRA_PIN_VI_VSYNC_PD6,
1920        TEGRA_PIN_VI_HSYNC_PD7,
1921        TEGRA_PIN_VI_D2_PL0,
1922        TEGRA_PIN_VI_D3_PL1,
1923        TEGRA_PIN_VI_D4_PL2,
1924        TEGRA_PIN_VI_D5_PL3,
1925        TEGRA_PIN_VI_D6_PL4,
1926        TEGRA_PIN_VI_D7_PL5,
1927        TEGRA_PIN_VI_D8_PL6,
1928        TEGRA_PIN_VI_D9_PL7,
1929        TEGRA_PIN_VI_PCLK_PT0,
1930        TEGRA_PIN_VI_D10_PT2,
1931        TEGRA_PIN_VI_D11_PT3,
1932        TEGRA_PIN_VI_D0_PT4,
1933};
1934
1935enum tegra_mux {
1936        TEGRA_MUX_BLINK,
1937        TEGRA_MUX_CEC,
1938        TEGRA_MUX_CLK_12M_OUT,
1939        TEGRA_MUX_CLK_32K_IN,
1940        TEGRA_MUX_CORE_PWR_REQ,
1941        TEGRA_MUX_CPU_PWR_REQ,
1942        TEGRA_MUX_CRT,
1943        TEGRA_MUX_DAP,
1944        TEGRA_MUX_DDR,
1945        TEGRA_MUX_DEV3,
1946        TEGRA_MUX_DISPLAYA,
1947        TEGRA_MUX_DISPLAYB,
1948        TEGRA_MUX_DTV,
1949        TEGRA_MUX_EXTPERIPH1,
1950        TEGRA_MUX_EXTPERIPH2,
1951        TEGRA_MUX_EXTPERIPH3,
1952        TEGRA_MUX_GMI,
1953        TEGRA_MUX_GMI_ALT,
1954        TEGRA_MUX_HDA,
1955        TEGRA_MUX_HDCP,
1956        TEGRA_MUX_HDMI,
1957        TEGRA_MUX_HSI,
1958        TEGRA_MUX_I2C1,
1959        TEGRA_MUX_I2C2,
1960        TEGRA_MUX_I2C3,
1961        TEGRA_MUX_I2C4,
1962        TEGRA_MUX_I2CPWR,
1963        TEGRA_MUX_I2S0,
1964        TEGRA_MUX_I2S1,
1965        TEGRA_MUX_I2S2,
1966        TEGRA_MUX_I2S3,
1967        TEGRA_MUX_I2S4,
1968        TEGRA_MUX_INVALID,
1969        TEGRA_MUX_KBC,
1970        TEGRA_MUX_MIO,
1971        TEGRA_MUX_NAND,
1972        TEGRA_MUX_NAND_ALT,
1973        TEGRA_MUX_OWR,
1974        TEGRA_MUX_PCIE,
1975        TEGRA_MUX_PWM0,
1976        TEGRA_MUX_PWM1,
1977        TEGRA_MUX_PWM2,
1978        TEGRA_MUX_PWM3,
1979        TEGRA_MUX_PWR_INT_N,
1980        TEGRA_MUX_RSVD1,
1981        TEGRA_MUX_RSVD2,
1982        TEGRA_MUX_RSVD3,
1983        TEGRA_MUX_RSVD4,
1984        TEGRA_MUX_RTCK,
1985        TEGRA_MUX_SATA,
1986        TEGRA_MUX_SDMMC1,
1987        TEGRA_MUX_SDMMC2,
1988        TEGRA_MUX_SDMMC3,
1989        TEGRA_MUX_SDMMC4,
1990        TEGRA_MUX_SPDIF,
1991        TEGRA_MUX_SPI1,
1992        TEGRA_MUX_SPI2,
1993        TEGRA_MUX_SPI2_ALT,
1994        TEGRA_MUX_SPI3,
1995        TEGRA_MUX_SPI4,
1996        TEGRA_MUX_SPI5,
1997        TEGRA_MUX_SPI6,
1998        TEGRA_MUX_SYSCLK,
1999        TEGRA_MUX_TEST,
2000        TEGRA_MUX_TRACE,
2001        TEGRA_MUX_UARTA,
2002        TEGRA_MUX_UARTB,
2003        TEGRA_MUX_UARTC,
2004        TEGRA_MUX_UARTD,
2005        TEGRA_MUX_UARTE,
2006        TEGRA_MUX_ULPI,
2007        TEGRA_MUX_VGP1,
2008        TEGRA_MUX_VGP2,
2009        TEGRA_MUX_VGP3,
2010        TEGRA_MUX_VGP4,
2011        TEGRA_MUX_VGP5,
2012        TEGRA_MUX_VGP6,
2013        TEGRA_MUX_VI,
2014        TEGRA_MUX_VI_ALT1,
2015        TEGRA_MUX_VI_ALT2,
2016        TEGRA_MUX_VI_ALT3,
2017};
2018static const char * const blink_groups[] = {
2019        "clk_32k_out_pa0",
2020};
2021
2022static const char * const cec_groups[] = {
2023        "hdmi_cec_pee3",
2024        "owr",
2025};
2026
2027static const char * const clk_12m_out_groups[] = {
2028        "pv3",
2029};
2030
2031static const char * const clk_32k_in_groups[] = {
2032        "clk_32k_in",
2033};
2034
2035static const char * const core_pwr_req_groups[] = {
2036        "core_pwr_req",
2037};
2038
2039static const char * const cpu_pwr_req_groups[] = {
2040        "cpu_pwr_req",
2041};
2042
2043static const char * const crt_groups[] = {
2044        "crt_hsync_pv6",
2045        "crt_vsync_pv7",
2046};
2047
2048static const char * const dap_groups[] = {
2049        "clk1_req_pee2",
2050        "clk2_req_pcc5",
2051};
2052
2053static const char * const ddr_groups[] = {
2054        "vi_d0_pt4",
2055        "vi_d1_pd5",
2056        "vi_d10_pt2",
2057        "vi_d11_pt3",
2058        "vi_d2_pl0",
2059        "vi_d3_pl1",
2060        "vi_d4_pl2",
2061        "vi_d5_pl3",
2062        "vi_d6_pl4",
2063        "vi_d7_pl5",
2064        "vi_d8_pl6",
2065        "vi_d9_pl7",
2066        "vi_hsync_pd7",
2067        "vi_vsync_pd6",
2068};
2069
2070static const char * const dev3_groups[] = {
2071        "clk3_req_pee1",
2072};
2073
2074static const char * const displaya_groups[] = {
2075        "dap3_din_pp1",
2076        "dap3_dout_pp2",
2077        "dap3_fs_pp0",
2078        "dap3_sclk_pp3",
2079        "pbb3",
2080        "pbb4",
2081        "pbb5",
2082        "pbb6",
2083        "lcd_cs0_n_pn4",
2084        "lcd_cs1_n_pw0",
2085        "lcd_d0_pe0",
2086        "lcd_d1_pe1",
2087        "lcd_d10_pf2",
2088        "lcd_d11_pf3",
2089        "lcd_d12_pf4",
2090        "lcd_d13_pf5",
2091        "lcd_d14_pf6",
2092        "lcd_d15_pf7",
2093        "lcd_d16_pm0",
2094        "lcd_d17_pm1",
2095        "lcd_d18_pm2",
2096        "lcd_d19_pm3",
2097        "lcd_d2_pe2",
2098        "lcd_d20_pm4",
2099        "lcd_d21_pm5",
2100        "lcd_d22_pm6",
2101        "lcd_d23_pm7",
2102        "lcd_d3_pe3",
2103        "lcd_d4_pe4",
2104        "lcd_d5_pe5",
2105        "lcd_d6_pe6",
2106        "lcd_d7_pe7",
2107        "lcd_d8_pf0",
2108        "lcd_d9_pf1",
2109        "lcd_dc0_pn6",
2110        "lcd_dc1_pd2",
2111        "lcd_de_pj1",
2112        "lcd_hsync_pj3",
2113        "lcd_m1_pw1",
2114        "lcd_pclk_pb3",
2115        "lcd_pwr0_pb2",
2116        "lcd_pwr1_pc1",
2117        "lcd_pwr2_pc6",
2118        "lcd_sck_pz4",
2119        "lcd_sdin_pz2",
2120        "lcd_sdout_pn5",
2121        "lcd_vsync_pj4",
2122        "lcd_wr_n_pz3",
2123};
2124
2125static const char * const displayb_groups[] = {
2126        "dap3_din_pp1",
2127        "dap3_dout_pp2",
2128        "dap3_fs_pp0",
2129        "dap3_sclk_pp3",
2130        "pbb3",
2131        "pbb4",
2132        "pbb5",
2133        "pbb6",
2134        "lcd_cs0_n_pn4",
2135        "lcd_cs1_n_pw0",
2136        "lcd_d0_pe0",
2137        "lcd_d1_pe1",
2138        "lcd_d10_pf2",
2139        "lcd_d11_pf3",
2140        "lcd_d12_pf4",
2141        "lcd_d13_pf5",
2142        "lcd_d14_pf6",
2143        "lcd_d15_pf7",
2144        "lcd_d16_pm0",
2145        "lcd_d17_pm1",
2146        "lcd_d18_pm2",
2147        "lcd_d19_pm3",
2148        "lcd_d2_pe2",
2149        "lcd_d20_pm4",
2150        "lcd_d21_pm5",
2151        "lcd_d22_pm6",
2152        "lcd_d23_pm7",
2153        "lcd_d3_pe3",
2154        "lcd_d4_pe4",
2155        "lcd_d5_pe5",
2156        "lcd_d6_pe6",
2157        "lcd_d7_pe7",
2158        "lcd_d8_pf0",
2159        "lcd_d9_pf1",
2160        "lcd_dc0_pn6",
2161        "lcd_dc1_pd2",
2162        "lcd_de_pj1",
2163        "lcd_hsync_pj3",
2164        "lcd_m1_pw1",
2165        "lcd_pclk_pb3",
2166        "lcd_pwr0_pb2",
2167        "lcd_pwr1_pc1",
2168        "lcd_pwr2_pc6",
2169        "lcd_sck_pz4",
2170        "lcd_sdin_pz2",
2171        "lcd_sdout_pn5",
2172        "lcd_vsync_pj4",
2173        "lcd_wr_n_pz3",
2174};
2175
2176static const char * const dtv_groups[] = {
2177        "gmi_a17_pb0",
2178        "gmi_a18_pb1",
2179        "gmi_cs0_n_pj0",
2180        "gmi_cs1_n_pj2",
2181};
2182
2183static const char * const extperiph1_groups[] = {
2184        "clk1_out_pw4",
2185};
2186
2187static const char * const extperiph2_groups[] = {
2188        "clk2_out_pw5",
2189};
2190
2191static const char * const extperiph3_groups[] = {
2192        "clk3_out_pee0",
2193};
2194
2195static const char * const gmi_groups[] = {
2196        "dap1_din_pn1",
2197        "dap1_dout_pn2",
2198        "dap1_fs_pn0",
2199        "dap1_sclk_pn3",
2200        "dap2_din_pa4",
2201        "dap2_dout_pa5",
2202        "dap2_fs_pa2",
2203        "dap2_sclk_pa3",
2204        "dap4_din_pp5",
2205        "dap4_dout_pp6",
2206        "dap4_fs_pp4",
2207        "dap4_sclk_pp7",
2208        "gen2_i2c_scl_pt5",
2209        "gen2_i2c_sda_pt6",
2210        "gmi_a16_pj7",
2211        "gmi_a17_pb0",
2212        "gmi_a18_pb1",
2213        "gmi_a19_pk7",
2214        "gmi_ad0_pg0",
2215        "gmi_ad1_pg1",
2216        "gmi_ad10_ph2",
2217        "gmi_ad11_ph3",
2218        "gmi_ad12_ph4",
2219        "gmi_ad13_ph5",
2220        "gmi_ad14_ph6",
2221        "gmi_ad15_ph7",
2222        "gmi_ad2_pg2",
2223        "gmi_ad3_pg3",
2224        "gmi_ad4_pg4",
2225        "gmi_ad5_pg5",
2226        "gmi_ad6_pg6",
2227        "gmi_ad7_pg7",
2228        "gmi_ad8_ph0",
2229        "gmi_ad9_ph1",
2230        "gmi_adv_n_pk0",
2231        "gmi_clk_pk1",
2232        "gmi_cs0_n_pj0",
2233        "gmi_cs1_n_pj2",
2234        "gmi_cs2_n_pk3",
2235        "gmi_cs3_n_pk4",
2236        "gmi_cs4_n_pk2",
2237        "gmi_cs6_n_pi3",
2238        "gmi_cs7_n_pi6",
2239        "gmi_dqs_pi2",
2240        "gmi_iordy_pi5",
2241        "gmi_oe_n_pi1",
2242        "gmi_rst_n_pi4",
2243        "gmi_wait_pi7",
2244        "gmi_wp_n_pc7",
2245        "gmi_wr_n_pi0",
2246        "pu0",
2247        "pu1",
2248        "pu2",
2249        "pu3",
2250        "pu4",
2251        "pu5",
2252        "pu6",
2253        "sdmmc4_clk_pcc4",
2254        "sdmmc4_cmd_pt7",
2255        "sdmmc4_dat0_paa0",
2256        "sdmmc4_dat1_paa1",
2257        "sdmmc4_dat2_paa2",
2258        "sdmmc4_dat3_paa3",
2259        "sdmmc4_dat4_paa4",
2260        "sdmmc4_dat5_paa5",
2261        "sdmmc4_dat6_paa6",
2262        "sdmmc4_dat7_paa7",
2263        "spi1_cs0_n_px6",
2264        "spi1_mosi_px4",
2265        "spi1_sck_px5",
2266        "spi2_cs0_n_px3",
2267        "spi2_miso_px1",
2268        "spi2_mosi_px0",
2269        "spi2_sck_px2",
2270        "uart2_cts_n_pj5",
2271        "uart2_rts_n_pj6",
2272        "uart3_cts_n_pa1",
2273        "uart3_rts_n_pc0",
2274        "uart3_rxd_pw7",
2275        "uart3_txd_pw6",
2276};
2277
2278static const char * const gmi_alt_groups[] = {
2279        "gmi_a16_pj7",
2280        "gmi_cs3_n_pk4",
2281        "gmi_cs7_n_pi6",
2282        "gmi_wp_n_pc7",
2283};
2284
2285static const char * const hda_groups[] = {
2286        "clk1_req_pee2",
2287        "dap1_din_pn1",
2288        "dap1_dout_pn2",
2289        "dap1_fs_pn0",
2290        "dap1_sclk_pn3",
2291        "dap2_din_pa4",
2292        "dap2_dout_pa5",
2293        "dap2_fs_pa2",
2294        "dap2_sclk_pa3",
2295        "pex_l0_clkreq_n_pdd2",
2296        "pex_l0_prsnt_n_pdd0",
2297        "pex_l0_rst_n_pdd1",
2298        "pex_l1_clkreq_n_pdd6",
2299        "pex_l1_prsnt_n_pdd4",
2300        "pex_l1_rst_n_pdd5",
2301        "pex_l2_clkreq_n_pcc7",
2302        "pex_l2_prsnt_n_pdd7",
2303        "pex_l2_rst_n_pcc6",
2304        "pex_wake_n_pdd3",
2305        "spdif_in_pk6",
2306};
2307
2308static const char * const hdcp_groups[] = {
2309        "gen2_i2c_scl_pt5",
2310        "gen2_i2c_sda_pt6",
2311        "lcd_pwr0_pb2",
2312        "lcd_pwr2_pc6",
2313        "lcd_sck_pz4",
2314        "lcd_sdout_pn5",
2315        "lcd_wr_n_pz3",
2316};
2317
2318static const char * const hdmi_groups[] = {
2319        "hdmi_int_pn7",
2320};
2321
2322static const char * const hsi_groups[] = {
2323        "ulpi_data0_po1",
2324        "ulpi_data1_po2",
2325        "ulpi_data2_po3",
2326        "ulpi_data3_po4",
2327        "ulpi_data4_po5",
2328        "ulpi_data5_po6",
2329        "ulpi_data6_po7",
2330        "ulpi_data7_po0",
2331};
2332
2333static const char * const i2c1_groups[] = {
2334        "gen1_i2c_scl_pc4",
2335        "gen1_i2c_sda_pc5",
2336        "spdif_in_pk6",
2337        "spdif_out_pk5",
2338        "spi2_cs1_n_pw2",
2339        "spi2_cs2_n_pw3",
2340};
2341
2342static const char * const i2c2_groups[] = {
2343        "gen2_i2c_scl_pt5",
2344        "gen2_i2c_sda_pt6",
2345};
2346
2347static const char * const i2c3_groups[] = {
2348        "cam_i2c_scl_pbb1",
2349        "cam_i2c_sda_pbb2",
2350        "sdmmc4_cmd_pt7",
2351        "sdmmc4_dat4_paa4",
2352};
2353
2354static const char * const i2c4_groups[] = {
2355        "ddc_scl_pv4",
2356        "ddc_sda_pv5",
2357};
2358
2359static const char * const i2cpwr_groups[] = {
2360        "pwr_i2c_scl_pz6",
2361        "pwr_i2c_sda_pz7",
2362};
2363
2364static const char * const i2s0_groups[] = {
2365        "dap1_din_pn1",
2366        "dap1_dout_pn2",
2367        "dap1_fs_pn0",
2368        "dap1_sclk_pn3",
2369};
2370
2371static const char * const i2s1_groups[] = {
2372        "dap2_din_pa4",
2373        "dap2_dout_pa5",
2374        "dap2_fs_pa2",
2375        "dap2_sclk_pa3",
2376};
2377
2378static const char * const i2s2_groups[] = {
2379        "dap3_din_pp1",
2380        "dap3_dout_pp2",
2381        "dap3_fs_pp0",
2382        "dap3_sclk_pp3",
2383};
2384
2385static const char * const i2s3_groups[] = {
2386        "dap4_din_pp5",
2387        "dap4_dout_pp6",
2388        "dap4_fs_pp4",
2389        "dap4_sclk_pp7",
2390};
2391
2392static const char * const i2s4_groups[] = {
2393        "pbb0",
2394        "pbb7",
2395        "pcc1",
2396        "pcc2",
2397        "sdmmc4_dat4_paa4",
2398        "sdmmc4_dat5_paa5",
2399        "sdmmc4_dat6_paa6",
2400        "sdmmc4_dat7_paa7",
2401};
2402
2403static const char * const invalid_groups[] = {
2404        "kb_row3_pr3",
2405        "sdmmc4_clk_pcc4",
2406};
2407
2408static const char * const kbc_groups[] = {
2409        "kb_col0_pq0",
2410        "kb_col1_pq1",
2411        "kb_col2_pq2",
2412        "kb_col3_pq3",
2413        "kb_col4_pq4",
2414        "kb_col5_pq5",
2415        "kb_col6_pq6",
2416        "kb_col7_pq7",
2417        "kb_row0_pr0",
2418        "kb_row1_pr1",
2419        "kb_row10_ps2",
2420        "kb_row11_ps3",
2421        "kb_row12_ps4",
2422        "kb_row13_ps5",
2423        "kb_row14_ps6",
2424        "kb_row15_ps7",
2425        "kb_row2_pr2",
2426        "kb_row3_pr3",
2427        "kb_row4_pr4",
2428        "kb_row5_pr5",
2429        "kb_row6_pr6",
2430        "kb_row7_pr7",
2431        "kb_row8_ps0",
2432        "kb_row9_ps1",
2433};
2434
2435static const char * const mio_groups[] = {
2436        "kb_col6_pq6",
2437        "kb_col7_pq7",
2438        "kb_row10_ps2",
2439        "kb_row11_ps3",
2440        "kb_row12_ps4",
2441        "kb_row13_ps5",
2442        "kb_row14_ps6",
2443        "kb_row15_ps7",
2444        "kb_row6_pr6",
2445        "kb_row7_pr7",
2446        "kb_row8_ps0",
2447        "kb_row9_ps1",
2448};
2449
2450static const char * const nand_groups[] = {
2451        "gmi_ad0_pg0",
2452        "gmi_ad1_pg1",
2453        "gmi_ad10_ph2",
2454        "gmi_ad11_ph3",
2455        "gmi_ad12_ph4",
2456        "gmi_ad13_ph5",
2457        "gmi_ad14_ph6",
2458        "gmi_ad15_ph7",
2459        "gmi_ad2_pg2",
2460        "gmi_ad3_pg3",
2461        "gmi_ad4_pg4",
2462        "gmi_ad5_pg5",
2463        "gmi_ad6_pg6",
2464        "gmi_ad7_pg7",
2465        "gmi_ad8_ph0",
2466        "gmi_ad9_ph1",
2467        "gmi_adv_n_pk0",
2468        "gmi_clk_pk1",
2469        "gmi_cs0_n_pj0",
2470        "gmi_cs1_n_pj2",
2471        "gmi_cs2_n_pk3",
2472        "gmi_cs3_n_pk4",
2473        "gmi_cs4_n_pk2",
2474        "gmi_cs6_n_pi3",
2475        "gmi_cs7_n_pi6",
2476        "gmi_dqs_pi2",
2477        "gmi_iordy_pi5",
2478        "gmi_oe_n_pi1",
2479        "gmi_rst_n_pi4",
2480        "gmi_wait_pi7",
2481        "gmi_wp_n_pc7",
2482        "gmi_wr_n_pi0",
2483        "kb_col0_pq0",
2484        "kb_col1_pq1",
2485        "kb_col2_pq2",
2486        "kb_col3_pq3",
2487        "kb_col4_pq4",
2488        "kb_col5_pq5",
2489        "kb_col6_pq6",
2490        "kb_col7_pq7",
2491        "kb_row0_pr0",
2492        "kb_row1_pr1",
2493        "kb_row10_ps2",
2494        "kb_row11_ps3",
2495        "kb_row12_ps4",
2496        "kb_row13_ps5",
2497        "kb_row14_ps6",
2498        "kb_row15_ps7",
2499        "kb_row2_pr2",
2500        "kb_row3_pr3",
2501        "kb_row4_pr4",
2502        "kb_row5_pr5",
2503        "kb_row6_pr6",
2504        "kb_row7_pr7",
2505        "kb_row8_ps0",
2506        "kb_row9_ps1",
2507        "sdmmc4_clk_pcc4",
2508        "sdmmc4_cmd_pt7",
2509};
2510
2511static const char * const nand_alt_groups[] = {
2512        "gmi_cs6_n_pi3",
2513        "gmi_cs7_n_pi6",
2514        "gmi_rst_n_pi4",
2515};
2516
2517static const char * const owr_groups[] = {
2518        "pu0",
2519        "pv2",
2520        "kb_row5_pr5",
2521        "owr",
2522};
2523
2524static const char * const pcie_groups[] = {
2525        "pex_l0_clkreq_n_pdd2",
2526        "pex_l0_prsnt_n_pdd0",
2527        "pex_l0_rst_n_pdd1",
2528        "pex_l1_clkreq_n_pdd6",
2529        "pex_l1_prsnt_n_pdd4",
2530        "pex_l1_rst_n_pdd5",
2531        "pex_l2_clkreq_n_pcc7",
2532        "pex_l2_prsnt_n_pdd7",
2533        "pex_l2_rst_n_pcc6",
2534        "pex_wake_n_pdd3",
2535};
2536
2537static const char * const pwm0_groups[] = {
2538        "gmi_ad8_ph0",
2539        "pu3",
2540        "sdmmc3_dat3_pb4",
2541        "sdmmc3_dat5_pd0",
2542        "uart3_rts_n_pc0",
2543};
2544
2545static const char * const pwm1_groups[] = {
2546        "gmi_ad9_ph1",
2547        "pu4",
2548        "sdmmc3_dat2_pb5",
2549        "sdmmc3_dat4_pd1",
2550};
2551
2552static const char * const pwm2_groups[] = {
2553        "gmi_ad10_ph2",
2554        "pu5",
2555        "sdmmc3_clk_pa6",
2556};
2557
2558static const char * const pwm3_groups[] = {
2559        "gmi_ad11_ph3",
2560        "pu6",
2561        "sdmmc3_cmd_pa7",
2562};
2563
2564static const char * const pwr_int_n_groups[] = {
2565        "pwr_int_n",
2566};
2567
2568static const char * const rsvd1_groups[] = {
2569        "gmi_ad0_pg0",
2570        "gmi_ad1_pg1",
2571        "gmi_ad12_ph4",
2572        "gmi_ad13_ph5",
2573        "gmi_ad14_ph6",
2574        "gmi_ad15_ph7",
2575        "gmi_ad2_pg2",
2576        "gmi_ad3_pg3",
2577        "gmi_ad4_pg4",
2578        "gmi_ad5_pg5",
2579        "gmi_ad6_pg6",
2580        "gmi_ad7_pg7",
2581        "gmi_adv_n_pk0",
2582        "gmi_clk_pk1",
2583        "gmi_cs0_n_pj0",
2584        "gmi_cs1_n_pj2",
2585        "gmi_cs2_n_pk3",
2586        "gmi_cs3_n_pk4",
2587        "gmi_cs4_n_pk2",
2588        "gmi_dqs_pi2",
2589        "gmi_iordy_pi5",
2590        "gmi_oe_n_pi1",
2591        "gmi_wait_pi7",
2592        "gmi_wp_n_pc7",
2593        "gmi_wr_n_pi0",
2594        "pu1",
2595        "pu2",
2596        "pv0",
2597        "pv1",
2598        "sdmmc3_dat0_pb7",
2599        "sdmmc3_dat1_pb6",
2600        "sdmmc3_dat2_pb5",
2601        "sdmmc3_dat3_pb4",
2602        "vi_pclk_pt0",
2603};
2604
2605static const char * const rsvd2_groups[] = {
2606        "clk1_out_pw4",
2607        "clk2_out_pw5",
2608        "clk2_req_pcc5",
2609        "clk3_out_pee0",
2610        "clk3_req_pee1",
2611        "clk_32k_in",
2612        "clk_32k_out_pa0",
2613        "core_pwr_req",
2614        "cpu_pwr_req",
2615        "crt_hsync_pv6",
2616        "crt_vsync_pv7",
2617        "dap3_din_pp1",
2618        "dap3_dout_pp2",
2619        "dap3_fs_pp0",
2620        "dap3_sclk_pp3",
2621        "dap4_din_pp5",
2622        "dap4_dout_pp6",
2623        "dap4_fs_pp4",
2624        "dap4_sclk_pp7",
2625        "ddc_scl_pv4",
2626        "ddc_sda_pv5",
2627        "gen1_i2c_scl_pc4",
2628        "gen1_i2c_sda_pc5",
2629        "pbb0",
2630        "pbb7",
2631        "pcc1",
2632        "pcc2",
2633        "pv0",
2634        "pv1",
2635        "pv2",
2636        "pv3",
2637        "hdmi_cec_pee3",
2638        "hdmi_int_pn7",
2639        "jtag_rtck_pu7",
2640        "pwr_i2c_scl_pz6",
2641        "pwr_i2c_sda_pz7",
2642        "pwr_int_n",
2643        "sdmmc1_clk_pz0",
2644        "sdmmc1_cmd_pz1",
2645        "sdmmc1_dat0_py7",
2646        "sdmmc1_dat1_py6",
2647        "sdmmc1_dat2_py5",
2648        "sdmmc1_dat3_py4",
2649        "sdmmc3_dat0_pb7",
2650        "sdmmc3_dat1_pb6",
2651        "sdmmc4_rst_n_pcc3",
2652        "spdif_out_pk5",
2653        "sys_clk_req_pz5",
2654        "uart3_cts_n_pa1",
2655        "uart3_rxd_pw7",
2656        "uart3_txd_pw6",
2657        "ulpi_clk_py0",
2658        "ulpi_dir_py1",
2659        "ulpi_nxt_py2",
2660        "ulpi_stp_py3",
2661        "vi_d0_pt4",
2662        "vi_d10_pt2",
2663        "vi_d11_pt3",
2664        "vi_hsync_pd7",
2665        "vi_vsync_pd6",
2666};
2667
2668static const char * const rsvd3_groups[] = {
2669        "cam_i2c_scl_pbb1",
2670        "cam_i2c_sda_pbb2",
2671        "clk1_out_pw4",
2672        "clk1_req_pee2",
2673        "clk2_out_pw5",
2674        "clk2_req_pcc5",
2675        "clk3_out_pee0",
2676        "clk3_req_pee1",
2677        "clk_32k_in",
2678        "clk_32k_out_pa0",
2679        "core_pwr_req",
2680        "cpu_pwr_req",
2681        "crt_hsync_pv6",
2682        "crt_vsync_pv7",
2683        "dap2_din_pa4",
2684        "dap2_dout_pa5",
2685        "dap2_fs_pa2",
2686        "dap2_sclk_pa3",
2687        "ddc_scl_pv4",
2688        "ddc_sda_pv5",
2689        "gen1_i2c_scl_pc4",
2690        "gen1_i2c_sda_pc5",
2691        "pbb0",
2692        "pbb7",
2693        "pcc1",
2694        "pcc2",
2695        "pv0",
2696        "pv1",
2697        "pv2",
2698        "pv3",
2699        "hdmi_cec_pee3",
2700        "hdmi_int_pn7",
2701        "jtag_rtck_pu7",
2702        "kb_row0_pr0",
2703        "kb_row1_pr1",
2704        "kb_row2_pr2",
2705        "kb_row3_pr3",
2706        "lcd_d0_pe0",
2707        "lcd_d1_pe1",
2708        "lcd_d10_pf2",
2709        "lcd_d11_pf3",
2710        "lcd_d12_pf4",
2711        "lcd_d13_pf5",
2712        "lcd_d14_pf6",
2713        "lcd_d15_pf7",
2714        "lcd_d16_pm0",
2715        "lcd_d17_pm1",
2716        "lcd_d18_pm2",
2717        "lcd_d19_pm3",
2718        "lcd_d2_pe2",
2719        "lcd_d20_pm4",
2720        "lcd_d21_pm5",
2721        "lcd_d22_pm6",
2722        "lcd_d23_pm7",
2723        "lcd_d3_pe3",
2724        "lcd_d4_pe4",
2725        "lcd_d5_pe5",
2726        "lcd_d6_pe6",
2727        "lcd_d7_pe7",
2728        "lcd_d8_pf0",
2729        "lcd_d9_pf1",
2730        "lcd_dc0_pn6",
2731        "lcd_dc1_pd2",
2732        "lcd_de_pj1",
2733        "lcd_hsync_pj3",
2734        "lcd_m1_pw1",
2735        "lcd_pclk_pb3",
2736        "lcd_pwr1_pc1",
2737        "lcd_vsync_pj4",
2738        "owr",
2739        "pex_l0_clkreq_n_pdd2",
2740        "pex_l0_prsnt_n_pdd0",
2741        "pex_l0_rst_n_pdd1",
2742        "pex_l1_clkreq_n_pdd6",
2743        "pex_l1_prsnt_n_pdd4",
2744        "pex_l1_rst_n_pdd5",
2745        "pex_l2_clkreq_n_pcc7",
2746        "pex_l2_prsnt_n_pdd7",
2747        "pex_l2_rst_n_pcc6",
2748        "pex_wake_n_pdd3",
2749        "pwr_i2c_scl_pz6",
2750        "pwr_i2c_sda_pz7",
2751        "pwr_int_n",
2752        "sdmmc1_clk_pz0",
2753        "sdmmc1_cmd_pz1",
2754        "sdmmc4_rst_n_pcc3",
2755        "sys_clk_req_pz5",
2756};
2757
2758static const char * const rsvd4_groups[] = {
2759        "clk1_out_pw4",
2760        "clk1_req_pee2",
2761        "clk2_out_pw5",
2762        "clk2_req_pcc5",
2763        "clk3_out_pee0",
2764        "clk3_req_pee1",
2765        "clk_32k_in",
2766        "clk_32k_out_pa0",
2767        "core_pwr_req",
2768        "cpu_pwr_req",
2769        "crt_hsync_pv6",
2770        "crt_vsync_pv7",
2771        "dap4_din_pp5",
2772        "dap4_dout_pp6",
2773        "dap4_fs_pp4",
2774        "dap4_sclk_pp7",
2775        "ddc_scl_pv4",
2776        "ddc_sda_pv5",
2777        "gen1_i2c_scl_pc4",
2778        "gen1_i2c_sda_pc5",
2779        "gen2_i2c_scl_pt5",
2780        "gen2_i2c_sda_pt6",
2781        "gmi_a19_pk7",
2782        "gmi_ad0_pg0",
2783        "gmi_ad1_pg1",
2784        "gmi_ad10_ph2",
2785        "gmi_ad11_ph3",
2786        "gmi_ad12_ph4",
2787        "gmi_ad13_ph5",
2788        "gmi_ad14_ph6",
2789        "gmi_ad15_ph7",
2790        "gmi_ad2_pg2",
2791        "gmi_ad3_pg3",
2792        "gmi_ad4_pg4",
2793        "gmi_ad5_pg5",
2794        "gmi_ad6_pg6",
2795        "gmi_ad7_pg7",
2796        "gmi_ad8_ph0",
2797        "gmi_ad9_ph1",
2798        "gmi_adv_n_pk0",
2799        "gmi_clk_pk1",
2800        "gmi_cs2_n_pk3",
2801        "gmi_cs4_n_pk2",
2802        "gmi_dqs_pi2",
2803        "gmi_iordy_pi5",
2804        "gmi_oe_n_pi1",
2805        "gmi_rst_n_pi4",
2806        "gmi_wait_pi7",
2807        "gmi_wr_n_pi0",
2808        "pcc2",
2809        "pu0",
2810        "pu1",
2811        "pu2",
2812        "pu3",
2813        "pu4",
2814        "pu5",
2815        "pu6",
2816        "pv0",
2817        "pv1",
2818        "pv2",
2819        "pv3",
2820        "hdmi_cec_pee3",
2821        "hdmi_int_pn7",
2822        "jtag_rtck_pu7",
2823        "kb_col2_pq2",
2824        "kb_col3_pq3",
2825        "kb_col4_pq4",
2826        "kb_col5_pq5",
2827        "kb_row0_pr0",
2828        "kb_row1_pr1",
2829        "kb_row2_pr2",
2830        "kb_row4_pr4",
2831        "lcd_cs0_n_pn4",
2832        "lcd_cs1_n_pw0",
2833        "lcd_d0_pe0",
2834        "lcd_d1_pe1",
2835        "lcd_d10_pf2",
2836        "lcd_d11_pf3",
2837        "lcd_d12_pf4",
2838        "lcd_d13_pf5",
2839        "lcd_d14_pf6",
2840        "lcd_d15_pf7",
2841        "lcd_d16_pm0",
2842        "lcd_d17_pm1",
2843        "lcd_d18_pm2",
2844        "lcd_d19_pm3",
2845        "lcd_d2_pe2",
2846        "lcd_d20_pm4",
2847        "lcd_d21_pm5",
2848        "lcd_d22_pm6",
2849        "lcd_d23_pm7",
2850        "lcd_d3_pe3",
2851        "lcd_d4_pe4",
2852        "lcd_d5_pe5",
2853        "lcd_d6_pe6",
2854        "lcd_d7_pe7",
2855        "lcd_d8_pf0",
2856        "lcd_d9_pf1",
2857        "lcd_dc0_pn6",
2858        "lcd_dc1_pd2",
2859        "lcd_de_pj1",
2860        "lcd_hsync_pj3",
2861        "lcd_m1_pw1",
2862        "lcd_pclk_pb3",
2863        "lcd_pwr1_pc1",
2864        "lcd_sdin_pz2",
2865        "lcd_vsync_pj4",
2866        "owr",
2867        "pex_l0_clkreq_n_pdd2",
2868        "pex_l0_prsnt_n_pdd0",
2869        "pex_l0_rst_n_pdd1",
2870        "pex_l1_clkreq_n_pdd6",
2871        "pex_l1_prsnt_n_pdd4",
2872        "pex_l1_rst_n_pdd5",
2873        "pex_l2_clkreq_n_pcc7",
2874        "pex_l2_prsnt_n_pdd7",
2875        "pex_l2_rst_n_pcc6",
2876        "pex_wake_n_pdd3",
2877        "pwr_i2c_scl_pz6",
2878        "pwr_i2c_sda_pz7",
2879        "pwr_int_n",
2880        "spi1_miso_px7",
2881        "sys_clk_req_pz5",
2882        "uart3_cts_n_pa1",
2883        "uart3_rts_n_pc0",
2884        "uart3_rxd_pw7",
2885        "uart3_txd_pw6",
2886        "vi_d0_pt4",
2887        "vi_d1_pd5",
2888        "vi_d10_pt2",
2889        "vi_d11_pt3",
2890        "vi_d2_pl0",
2891        "vi_d3_pl1",
2892        "vi_d4_pl2",
2893        "vi_d5_pl3",
2894        "vi_d6_pl4",
2895        "vi_d7_pl5",
2896        "vi_d8_pl6",
2897        "vi_d9_pl7",
2898        "vi_hsync_pd7",
2899        "vi_pclk_pt0",
2900        "vi_vsync_pd6",
2901};
2902
2903static const char * const rtck_groups[] = {
2904        "jtag_rtck_pu7",
2905};
2906
2907static const char * const sata_groups[] = {
2908        "gmi_cs6_n_pi3",
2909};
2910
2911static const char * const sdmmc1_groups[] = {
2912        "sdmmc1_clk_pz0",
2913        "sdmmc1_cmd_pz1",
2914        "sdmmc1_dat0_py7",
2915        "sdmmc1_dat1_py6",
2916        "sdmmc1_dat2_py5",
2917        "sdmmc1_dat3_py4",
2918};
2919
2920static const char * const sdmmc2_groups[] = {
2921        "dap1_din_pn1",
2922        "dap1_dout_pn2",
2923        "dap1_fs_pn0",
2924        "dap1_sclk_pn3",
2925        "kb_row10_ps2",
2926        "kb_row11_ps3",
2927        "kb_row12_ps4",
2928        "kb_row13_ps5",
2929        "kb_row14_ps6",
2930        "kb_row15_ps7",
2931        "kb_row6_pr6",
2932        "kb_row7_pr7",
2933        "kb_row8_ps0",
2934        "kb_row9_ps1",
2935        "spdif_in_pk6",
2936        "spdif_out_pk5",
2937        "vi_d1_pd5",
2938        "vi_d2_pl0",
2939        "vi_d3_pl1",
2940        "vi_d4_pl2",
2941        "vi_d5_pl3",
2942        "vi_d6_pl4",
2943        "vi_d7_pl5",
2944        "vi_d8_pl6",
2945        "vi_d9_pl7",
2946        "vi_pclk_pt0",
2947};
2948
2949static const char * const sdmmc3_groups[] = {
2950        "sdmmc3_clk_pa6",
2951        "sdmmc3_cmd_pa7",
2952        "sdmmc3_dat0_pb7",
2953        "sdmmc3_dat1_pb6",
2954        "sdmmc3_dat2_pb5",
2955        "sdmmc3_dat3_pb4",
2956        "sdmmc3_dat4_pd1",
2957        "sdmmc3_dat5_pd0",
2958        "sdmmc3_dat6_pd3",
2959        "sdmmc3_dat7_pd4",
2960};
2961
2962static const char * const sdmmc4_groups[] = {
2963        "cam_i2c_scl_pbb1",
2964        "cam_i2c_sda_pbb2",
2965        "cam_mclk_pcc0",
2966        "pbb0",
2967        "pbb3",
2968        "pbb4",
2969        "pbb5",
2970        "pbb6",
2971        "pbb7",
2972        "pcc1",
2973        "sdmmc4_clk_pcc4",
2974        "sdmmc4_cmd_pt7",
2975        "sdmmc4_dat0_paa0",
2976        "sdmmc4_dat1_paa1",
2977        "sdmmc4_dat2_paa2",
2978        "sdmmc4_dat3_paa3",
2979        "sdmmc4_dat4_paa4",
2980        "sdmmc4_dat5_paa5",
2981        "sdmmc4_dat6_paa6",
2982        "sdmmc4_dat7_paa7",
2983        "sdmmc4_rst_n_pcc3",
2984};
2985
2986static const char * const spdif_groups[] = {
2987        "sdmmc3_dat6_pd3",
2988        "sdmmc3_dat7_pd4",
2989        "spdif_in_pk6",
2990        "spdif_out_pk5",
2991        "uart2_rxd_pc3",
2992        "uart2_txd_pc2",
2993};
2994
2995static const char * const spi1_groups[] = {
2996        "spi1_cs0_n_px6",
2997        "spi1_miso_px7",
2998        "spi1_mosi_px4",
2999        "spi1_sck_px5",
3000        "ulpi_clk_py0",
3001        "ulpi_dir_py1",
3002        "ulpi_nxt_py2",
3003        "ulpi_stp_py3",
3004};
3005
3006static const char * const spi2_groups[] = {
3007        "sdmmc3_cmd_pa7",
3008        "sdmmc3_dat4_pd1",
3009        "sdmmc3_dat5_pd0",
3010        "sdmmc3_dat6_pd3",
3011        "sdmmc3_dat7_pd4",
3012        "spi1_cs0_n_px6",
3013        "spi1_mosi_px4",
3014        "spi1_sck_px5",
3015        "spi2_cs0_n_px3",
3016        "spi2_cs1_n_pw2",
3017        "spi2_cs2_n_pw3",
3018        "spi2_miso_px1",
3019        "spi2_mosi_px0",
3020        "spi2_sck_px2",
3021        "ulpi_data4_po5",
3022        "ulpi_data5_po6",
3023        "ulpi_data6_po7",
3024        "ulpi_data7_po0",
3025};
3026
3027static const char * const spi2_alt_groups[] = {
3028        "spi1_cs0_n_px6",
3029        "spi1_miso_px7",
3030        "spi1_mosi_px4",
3031        "spi1_sck_px5",
3032        "spi2_cs1_n_pw2",
3033        "spi2_cs2_n_pw3",
3034};
3035
3036static const char * const spi3_groups[] = {
3037        "sdmmc3_clk_pa6",
3038        "sdmmc3_dat0_pb7",
3039        "sdmmc3_dat1_pb6",
3040        "sdmmc3_dat2_pb5",
3041        "sdmmc3_dat3_pb4",
3042        "sdmmc4_dat0_paa0",
3043        "sdmmc4_dat1_paa1",
3044        "sdmmc4_dat2_paa2",
3045        "sdmmc4_dat3_paa3",
3046        "spi1_miso_px7",
3047        "spi2_cs0_n_px3",
3048        "spi2_cs1_n_pw2",
3049        "spi2_cs2_n_pw3",
3050        "spi2_miso_px1",
3051        "spi2_mosi_px0",
3052        "spi2_sck_px2",
3053        "ulpi_data0_po1",
3054        "ulpi_data1_po2",
3055        "ulpi_data2_po3",
3056        "ulpi_data3_po4",
3057};
3058
3059static const char * const spi4_groups[] = {
3060        "gmi_a16_pj7",
3061        "gmi_a17_pb0",
3062        "gmi_a18_pb1",
3063        "gmi_a19_pk7",
3064        "sdmmc3_dat4_pd1",
3065        "sdmmc3_dat5_pd0",
3066        "sdmmc3_dat6_pd3",
3067        "sdmmc3_dat7_pd4",
3068        "uart2_cts_n_pj5",
3069        "uart2_rts_n_pj6",
3070        "uart2_rxd_pc3",
3071        "uart2_txd_pc2",
3072};
3073
3074static const char * const spi5_groups[] = {
3075        "lcd_cs0_n_pn4",
3076        "lcd_cs1_n_pw0",
3077        "lcd_pwr0_pb2",
3078        "lcd_pwr2_pc6",
3079        "lcd_sck_pz4",
3080        "lcd_sdin_pz2",
3081        "lcd_sdout_pn5",
3082        "lcd_wr_n_pz3",
3083};
3084
3085static const char * const spi6_groups[] = {
3086        "spi2_cs0_n_px3",
3087        "spi2_miso_px1",
3088        "spi2_mosi_px0",
3089        "spi2_sck_px2",
3090};
3091
3092static const char * const sysclk_groups[] = {
3093        "sys_clk_req_pz5",
3094};
3095
3096static const char * const test_groups[] = {
3097        "kb_col0_pq0",
3098        "kb_col1_pq1",
3099};
3100
3101static const char * const trace_groups[] = {
3102        "kb_col0_pq0",
3103        "kb_col1_pq1",
3104        "kb_col2_pq2",
3105        "kb_col3_pq3",
3106        "kb_col4_pq4",
3107        "kb_col5_pq5",
3108        "kb_col6_pq6",
3109        "kb_col7_pq7",
3110        "kb_row4_pr4",
3111        "kb_row5_pr5",
3112};
3113
3114static const char * const uarta_groups[] = {
3115        "pu0",
3116        "pu1",
3117        "pu2",
3118        "pu3",
3119        "pu4",
3120        "pu5",
3121        "pu6",
3122        "sdmmc1_clk_pz0",
3123        "sdmmc1_cmd_pz1",
3124        "sdmmc1_dat0_py7",
3125        "sdmmc1_dat1_py6",
3126        "sdmmc1_dat2_py5",
3127        "sdmmc1_dat3_py4",
3128        "sdmmc3_clk_pa6",
3129        "sdmmc3_cmd_pa7",
3130        "uart2_cts_n_pj5",
3131        "uart2_rts_n_pj6",
3132        "uart2_rxd_pc3",
3133        "uart2_txd_pc2",
3134        "ulpi_data0_po1",
3135        "ulpi_data1_po2",
3136        "ulpi_data2_po3",
3137        "ulpi_data3_po4",
3138        "ulpi_data4_po5",
3139        "ulpi_data5_po6",
3140        "ulpi_data6_po7",
3141        "ulpi_data7_po0",
3142};
3143
3144static const char * const uartb_groups[] = {
3145        "uart2_cts_n_pj5",
3146        "uart2_rts_n_pj6",
3147        "uart2_rxd_pc3",
3148        "uart2_txd_pc2",
3149};
3150
3151static const char * const uartc_groups[] = {
3152        "uart3_cts_n_pa1",
3153        "uart3_rts_n_pc0",
3154        "uart3_rxd_pw7",
3155        "uart3_txd_pw6",
3156};
3157
3158static const char * const uartd_groups[] = {
3159        "gmi_a16_pj7",
3160        "gmi_a17_pb0",
3161        "gmi_a18_pb1",
3162        "gmi_a19_pk7",
3163        "ulpi_clk_py0",
3164        "ulpi_dir_py1",
3165        "ulpi_nxt_py2",
3166        "ulpi_stp_py3",
3167};
3168
3169static const char * const uarte_groups[] = {
3170        "sdmmc1_dat0_py7",
3171        "sdmmc1_dat1_py6",
3172        "sdmmc1_dat2_py5",
3173        "sdmmc1_dat3_py4",
3174        "sdmmc4_dat0_paa0",
3175        "sdmmc4_dat1_paa1",
3176        "sdmmc4_dat2_paa2",
3177        "sdmmc4_dat3_paa3",
3178};
3179
3180static const char * const ulpi_groups[] = {
3181        "ulpi_clk_py0",
3182        "ulpi_data0_po1",
3183        "ulpi_data1_po2",
3184        "ulpi_data2_po3",
3185        "ulpi_data3_po4",
3186        "ulpi_data4_po5",
3187        "ulpi_data5_po6",
3188        "ulpi_data6_po7",
3189        "ulpi_data7_po0",
3190        "ulpi_dir_py1",
3191        "ulpi_nxt_py2",
3192        "ulpi_stp_py3",
3193};
3194
3195static const char * const vgp1_groups[] = {
3196        "cam_i2c_scl_pbb1",
3197};
3198
3199static const char * const vgp2_groups[] = {
3200        "cam_i2c_sda_pbb2",
3201};
3202
3203static const char * const vgp3_groups[] = {
3204        "pbb3",
3205        "sdmmc4_dat5_paa5",
3206};
3207
3208static const char * const vgp4_groups[] = {
3209        "pbb4",
3210        "sdmmc4_dat6_paa6",
3211};
3212
3213static const char * const vgp5_groups[] = {
3214        "pbb5",
3215        "sdmmc4_dat7_paa7",
3216};
3217
3218static const char * const vgp6_groups[] = {
3219        "pbb6",
3220        "sdmmc4_rst_n_pcc3",
3221};
3222
3223static const char * const vi_groups[] = {
3224        "cam_mclk_pcc0",
3225        "vi_d0_pt4",
3226        "vi_d1_pd5",
3227        "vi_d10_pt2",
3228        "vi_d11_pt3",
3229        "vi_d2_pl0",
3230        "vi_d3_pl1",
3231        "vi_d4_pl2",
3232        "vi_d5_pl3",
3233        "vi_d6_pl4",
3234        "vi_d7_pl5",
3235        "vi_d8_pl6",
3236        "vi_d9_pl7",
3237        "vi_hsync_pd7",
3238        "vi_mclk_pt1",
3239        "vi_pclk_pt0",
3240        "vi_vsync_pd6",
3241};
3242
3243static const char * const vi_alt1_groups[] = {
3244        "cam_mclk_pcc0",
3245        "vi_mclk_pt1",
3246};
3247
3248static const char * const vi_alt2_groups[] = {
3249        "vi_mclk_pt1",
3250};
3251
3252static const char * const vi_alt3_groups[] = {
3253        "cam_mclk_pcc0",
3254        "vi_mclk_pt1",
3255};
3256
3257#define FUNCTION(fname)                                 \
3258        {                                               \
3259                .name = #fname,                         \
3260                .groups = fname##_groups,               \
3261                .ngroups = ARRAY_SIZE(fname##_groups),  \
3262        }
3263
3264static const struct tegra_function tegra30_functions[] = {
3265        FUNCTION(blink),
3266        FUNCTION(cec),
3267        FUNCTION(clk_12m_out),
3268        FUNCTION(clk_32k_in),
3269        FUNCTION(core_pwr_req),
3270        FUNCTION(cpu_pwr_req),
3271        FUNCTION(crt),
3272        FUNCTION(dap),
3273        FUNCTION(ddr),
3274        FUNCTION(dev3),
3275        FUNCTION(displaya),
3276        FUNCTION(displayb),
3277        FUNCTION(dtv),
3278        FUNCTION(extperiph1),
3279        FUNCTION(extperiph2),
3280        FUNCTION(extperiph3),
3281        FUNCTION(gmi),
3282        FUNCTION(gmi_alt),
3283        FUNCTION(hda),
3284        FUNCTION(hdcp),
3285        FUNCTION(hdmi),
3286        FUNCTION(hsi),
3287        FUNCTION(i2c1),
3288        FUNCTION(i2c2),
3289        FUNCTION(i2c3),
3290        FUNCTION(i2c4),
3291        FUNCTION(i2cpwr),
3292        FUNCTION(i2s0),
3293        FUNCTION(i2s1),
3294        FUNCTION(i2s2),
3295        FUNCTION(i2s3),
3296        FUNCTION(i2s4),
3297        FUNCTION(invalid),
3298        FUNCTION(kbc),
3299        FUNCTION(mio),
3300        FUNCTION(nand),
3301        FUNCTION(nand_alt),
3302        FUNCTION(owr),
3303        FUNCTION(pcie),
3304        FUNCTION(pwm0),
3305        FUNCTION(pwm1),
3306        FUNCTION(pwm2),
3307        FUNCTION(pwm3),
3308        FUNCTION(pwr_int_n),
3309        FUNCTION(rsvd1),
3310        FUNCTION(rsvd2),
3311        FUNCTION(rsvd3),
3312        FUNCTION(rsvd4),
3313        FUNCTION(rtck),
3314        FUNCTION(sata),
3315        FUNCTION(sdmmc1),
3316        FUNCTION(sdmmc2),
3317        FUNCTION(sdmmc3),
3318        FUNCTION(sdmmc4),
3319        FUNCTION(spdif),
3320        FUNCTION(spi1),
3321        FUNCTION(spi2),
3322        FUNCTION(spi2_alt),
3323        FUNCTION(spi3),
3324        FUNCTION(spi4),
3325        FUNCTION(spi5),
3326        FUNCTION(spi6),
3327        FUNCTION(sysclk),
3328        FUNCTION(test),
3329        FUNCTION(trace),
3330        FUNCTION(uarta),
3331        FUNCTION(uartb),
3332        FUNCTION(uartc),
3333        FUNCTION(uartd),
3334        FUNCTION(uarte),
3335        FUNCTION(ulpi),
3336        FUNCTION(vgp1),
3337        FUNCTION(vgp2),
3338        FUNCTION(vgp3),
3339        FUNCTION(vgp4),
3340        FUNCTION(vgp5),
3341        FUNCTION(vgp6),
3342        FUNCTION(vi),
3343        FUNCTION(vi_alt1),
3344        FUNCTION(vi_alt2),
3345        FUNCTION(vi_alt3),
3346};
3347
3348#define DRV_PINGROUP_REG_A      0x868   /* bank 0 */
3349#define PINGROUP_REG_A          0x3000  /* bank 1 */
3350
3351#define PINGROUP_REG_Y(r) ((r) - PINGROUP_REG_A)
3352#define PINGROUP_REG_N(r) -1
3353
3354#define PINGROUP(pg_name, f0, f1, f2, f3, f_safe, r, od, ior)   \
3355        {                                                       \
3356                .name = #pg_name,                               \
3357                .pins = pg_name##_pins,                         \
3358                .npins = ARRAY_SIZE(pg_name##_pins),            \
3359                .funcs = {                                      \
3360                        TEGRA_MUX_ ## f0,                       \
3361                        TEGRA_MUX_ ## f1,                       \
3362                        TEGRA_MUX_ ## f2,                       \
3363                        TEGRA_MUX_ ## f3,                       \
3364                },                                              \
3365                .func_safe = TEGRA_MUX_ ## f_safe,              \
3366                .mux_reg = PINGROUP_REG_Y(r),                   \
3367                .mux_bank = 1,                                  \
3368                .mux_bit = 0,                                   \
3369                .pupd_reg = PINGROUP_REG_Y(r),                  \
3370                .pupd_bank = 1,                                 \
3371                .pupd_bit = 2,                                  \
3372                .tri_reg = PINGROUP_REG_Y(r),                   \
3373                .tri_bank = 1,                                  \
3374                .tri_bit = 4,                                   \
3375                .einput_reg = PINGROUP_REG_Y(r),                \
3376                .einput_bank = 1,                               \
3377                .einput_bit = 5,                                \
3378                .odrain_reg = PINGROUP_REG_##od(r),             \
3379                .odrain_bank = 1,                               \
3380                .odrain_bit = 6,                                \
3381                .lock_reg = PINGROUP_REG_Y(r),                  \
3382                .lock_bank = 1,                                 \
3383                .lock_bit = 7,                                  \
3384                .ioreset_reg = PINGROUP_REG_##ior(r),           \
3385                .ioreset_bank = 1,                              \
3386                .ioreset_bit = 8,                               \
3387                .rcv_sel_reg = -1,                              \
3388                .drv_reg = -1,                                  \
3389                .drvtype_reg = -1,                              \
3390        }
3391
3392#define DRV_PINGROUP(pg_name, r, hsm_b, schmitt_b, lpmd_b,      \
3393                     drvdn_b, drvdn_w, drvup_b, drvup_w,        \
3394                     slwr_b, slwr_w, slwf_b, slwf_w)            \
3395        {                                                       \
3396                .name = "drive_" #pg_name,                      \
3397                .pins = drive_##pg_name##_pins,                 \
3398                .npins = ARRAY_SIZE(drive_##pg_name##_pins),    \
3399                .mux_reg = -1,                                  \
3400                .pupd_reg = -1,                                 \
3401                .tri_reg = -1,                                  \
3402                .einput_reg = -1,                               \
3403                .odrain_reg = -1,                               \
3404                .lock_reg = -1,                                 \
3405                .ioreset_reg = -1,                              \
3406                .rcv_sel_reg = -1,                              \
3407                .drv_reg = ((r) - DRV_PINGROUP_REG_A),          \
3408                .drv_bank = 0,                                  \
3409                .hsm_bit = hsm_b,                               \
3410                .schmitt_bit = schmitt_b,                       \
3411                .lpmd_bit = lpmd_b,                             \
3412                .drvdn_bit = drvdn_b,                           \
3413                .drvdn_width = drvdn_w,                         \
3414                .drvup_bit = drvup_b,                           \
3415                .drvup_width = drvup_w,                         \
3416                .slwr_bit = slwr_b,                             \
3417                .slwr_width = slwr_w,                           \
3418                .slwf_bit = slwf_b,                             \
3419                .slwf_width = slwf_w,                           \
3420                .drvtype_reg = -1,                              \
3421        }
3422
3423static const struct tegra_pingroup tegra30_groups[] = {
3424        /*       pg_name,              f0,           f1,           f2,           f3,           safe,         r,      od, ior */
3425        /* FIXME: Fill in correct data in safe column */
3426        PINGROUP(clk_32k_out_pa0,      BLINK,        RSVD2,        RSVD3,        RSVD4,        RSVD4,        0x331c, N, N),
3427        PINGROUP(uart3_cts_n_pa1,      UARTC,        RSVD2,        GMI,          RSVD4,        RSVD4,        0x317c, N, N),
3428        PINGROUP(dap2_fs_pa2,          I2S1,         HDA,          RSVD3,        GMI,          RSVD3,        0x3358, N, N),
3429        PINGROUP(dap2_sclk_pa3,        I2S1,         HDA,          RSVD3,        GMI,          RSVD3,        0x3364, N, N),
3430        PINGROUP(dap2_din_pa4,         I2S1,         HDA,          RSVD3,        GMI,          RSVD3,        0x335c, N, N),
3431        PINGROUP(dap2_dout_pa5,        I2S1,         HDA,          RSVD3,        GMI,          RSVD3,        0x3360, N, N),
3432        PINGROUP(sdmmc3_clk_pa6,       UARTA,        PWM2,         SDMMC3,       SPI3,         SPI3,         0x3390, N, N),
3433        PINGROUP(sdmmc3_cmd_pa7,       UARTA,        PWM3,         SDMMC3,       SPI2,         SPI2,         0x3394, N, N),
3434        PINGROUP(gmi_a17_pb0,          UARTD,        SPI4,         GMI,          DTV,          DTV,          0x3234, N, N),
3435        PINGROUP(gmi_a18_pb1,          UARTD,        SPI4,         GMI,          DTV,          DTV,          0x3238, N, N),
3436        PINGROUP(lcd_pwr0_pb2,         DISPLAYA,     DISPLAYB,     SPI5,         HDCP,         HDCP,         0x3090, N, N),
3437        PINGROUP(lcd_pclk_pb3,         DISPLAYA,     DISPLAYB,     RSVD3,        RSVD4,        RSVD4,        0x3094, N, N),
3438        PINGROUP(sdmmc3_dat3_pb4,      RSVD1,        PWM0,         SDMMC3,       SPI3,         RSVD1,        0x33a4, N, N),
3439        PINGROUP(sdmmc3_dat2_pb5,      RSVD1,        PWM1,         SDMMC3,       SPI3,         RSVD1,        0x33a0, N, N),
3440        PINGROUP(sdmmc3_dat1_pb6,      RSVD1,        RSVD2,        SDMMC3,       SPI3,         RSVD2,        0x339c, N, N),
3441        PINGROUP(sdmmc3_dat0_pb7,      RSVD1,        RSVD2,        SDMMC3,       SPI3,         RSVD2,        0x3398, N, N),
3442        PINGROUP(uart3_rts_n_pc0,      UARTC,        PWM0,         GMI,          RSVD4,        RSVD4,        0x3180, N, N),
3443        PINGROUP(lcd_pwr1_pc1,         DISPLAYA,     DISPLAYB,     RSVD3,        RSVD4,        RSVD4,        0x3070, N, N),
3444        PINGROUP(uart2_txd_pc2,        UARTB,        SPDIF,        UARTA,        SPI4,         SPI4,         0x3168, N, N),
3445        PINGROUP(uart2_rxd_pc3,        UARTB,        SPDIF,        UARTA,        SPI4,         SPI4,         0x3164, N, N),
3446        PINGROUP(gen1_i2c_scl_pc4,     I2C1,         RSVD2,        RSVD3,        RSVD4,        RSVD4,        0x31a4, Y, N),
3447        PINGROUP(gen1_i2c_sda_pc5,     I2C1,         RSVD2,        RSVD3,        RSVD4,        RSVD4,        0x31a0, Y, N),
3448        PINGROUP(lcd_pwr2_pc6,         DISPLAYA,     DISPLAYB,     SPI5,         HDCP,         HDCP,         0x3074, N, N),
3449        PINGROUP(gmi_wp_n_pc7,         RSVD1,        NAND,         GMI,          GMI_ALT,      RSVD1,        0x31c0, N, N),
3450        PINGROUP(sdmmc3_dat5_pd0,      PWM0,         SPI4,         SDMMC3,       SPI2,         SPI2,         0x33ac, N, N),
3451        PINGROUP(sdmmc3_dat4_pd1,      PWM1,         SPI4,         SDMMC3,       SPI2,         SPI2,         0x33a8, N, N),
3452        PINGROUP(lcd_dc1_pd2,          DISPLAYA,     DISPLAYB,     RSVD3,        RSVD4,        RSVD4,        0x310c, N, N),
3453        PINGROUP(sdmmc3_dat6_pd3,      SPDIF,        SPI4,         SDMMC3,       SPI2,         SPI2,         0x33b0, N, N),
3454        PINGROUP(sdmmc3_dat7_pd4,      SPDIF,        SPI4,         SDMMC3,       SPI2,         SPI2,         0x33b4, N, N),
3455        PINGROUP(vi_d1_pd5,            DDR,          SDMMC2,       VI,           RSVD4,        RSVD4,        0x3128, N, Y),
3456        PINGROUP(vi_vsync_pd6,         DDR,          RSVD2,        VI,           RSVD4,        RSVD4,        0x315c, N, Y),
3457        PINGROUP(vi_hsync_pd7,         DDR,          RSVD2,        VI,           RSVD4,        RSVD4,        0x3160, N, Y),
3458        PINGROUP(lcd_d0_pe0,           DISPLAYA,     DISPLAYB,     RSVD3,        RSVD4,        RSVD4,        0x30a4, N, N),
3459        PINGROUP(lcd_d1_pe1,           DISPLAYA,     DISPLAYB,     RSVD3,        RSVD4,        RSVD4,        0x30a8, N, N),
3460        PINGROUP(lcd_d2_pe2,           DISPLAYA,     DISPLAYB,     RSVD3,        RSVD4,        RSVD4,        0x30ac, N, N),
3461        PINGROUP(lcd_d3_pe3,           DISPLAYA,     DISPLAYB,     RSVD3,        RSVD4,        RSVD4,        0x30b0, N, N),
3462        PINGROUP(lcd_d4_pe4,           DISPLAYA,     DISPLAYB,     RSVD3,        RSVD4,        RSVD4,        0x30b4, N, N),
3463        PINGROUP(lcd_d5_pe5,           DISPLAYA,     DISPLAYB,     RSVD3,        RSVD4,        RSVD4,        0x30b8, N, N),
3464        PINGROUP(lcd_d6_pe6,           DISPLAYA,     DISPLAYB,     RSVD3,        RSVD4,        RSVD4,        0x30bc, N, N),
3465        PINGROUP(lcd_d7_pe7,           DISPLAYA,     DISPLAYB,     RSVD3,        RSVD4,        RSVD4,        0x30c0, N, N),
3466        PINGROUP(lcd_d8_pf0,           DISPLAYA,     DISPLAYB,     RSVD3,        RSVD4,        RSVD4,        0x30c4, N, N),
3467        PINGROUP(lcd_d9_pf1,           DISPLAYA,     DISPLAYB,     RSVD3,        RSVD4,        RSVD4,        0x30c8, N, N),
3468        PINGROUP(lcd_d10_pf2,          DISPLAYA,     DISPLAYB,     RSVD3,        RSVD4,        RSVD4,        0x30cc, N, N),
3469        PINGROUP(lcd_d11_pf3,          DISPLAYA,     DISPLAYB,     RSVD3,        RSVD4,        RSVD4,        0x30d0, N, N),
3470        PINGROUP(lcd_d12_pf4,          DISPLAYA,     DISPLAYB,     RSVD3,        RSVD4,        RSVD4,        0x30d4, N, N),
3471        PINGROUP(lcd_d13_pf5,          DISPLAYA,     DISPLAYB,     RSVD3,        RSVD4,        RSVD4,        0x30d8, N, N),
3472        PINGROUP(lcd_d14_pf6,          DISPLAYA,     DISPLAYB,     RSVD3,        RSVD4,        RSVD4,        0x30dc, N, N),
3473        PINGROUP(lcd_d15_pf7,          DISPLAYA,     DISPLAYB,     RSVD3,        RSVD4,        RSVD4,        0x30e0, N, N),
3474        PINGROUP(gmi_ad0_pg0,          RSVD1,        NAND,         GMI,          RSVD4,        RSVD4,        0x31f0, N, N),
3475        PINGROUP(gmi_ad1_pg1,          RSVD1,        NAND,         GMI,          RSVD4,        RSVD4,        0x31f4, N, N),
3476        PINGROUP(gmi_ad2_pg2,          RSVD1,        NAND,         GMI,          RSVD4,        RSVD4,        0x31f8, N, N),
3477        PINGROUP(gmi_ad3_pg3,          RSVD1,        NAND,         GMI,          RSVD4,        RSVD4,        0x31fc, N, N),
3478        PINGROUP(gmi_ad4_pg4,          RSVD1,        NAND,         GMI,          RSVD4,        RSVD4,        0x3200, N, N),
3479        PINGROUP(gmi_ad5_pg5,          RSVD1,        NAND,         GMI,          RSVD4,        RSVD4,        0x3204, N, N),
3480        PINGROUP(gmi_ad6_pg6,          RSVD1,        NAND,         GMI,          RSVD4,        RSVD4,        0x3208, N, N),
3481        PINGROUP(gmi_ad7_pg7,          RSVD1,        NAND,         GMI,          RSVD4,        RSVD4,        0x320c, N, N),
3482        PINGROUP(gmi_ad8_ph0,          PWM0,         NAND,         GMI,          RSVD4,        RSVD4,        0x3210, N, N),
3483        PINGROUP(gmi_ad9_ph1,          PWM1,         NAND,         GMI,          RSVD4,        RSVD4,        0x3214, N, N),
3484        PINGROUP(gmi_ad10_ph2,         PWM2,         NAND,         GMI,          RSVD4,        RSVD4,        0x3218, N, N),
3485        PINGROUP(gmi_ad11_ph3,         PWM3,         NAND,         GMI,          RSVD4,        RSVD4,        0x321c, N, N),
3486        PINGROUP(gmi_ad12_ph4,         RSVD1,        NAND,         GMI,          RSVD4,        RSVD4,        0x3220, N, N),
3487        PINGROUP(gmi_ad13_ph5,         RSVD1,        NAND,         GMI,          RSVD4,        RSVD4,        0x3224, N, N),
3488        PINGROUP(gmi_ad14_ph6,         RSVD1,        NAND,         GMI,          RSVD4,        RSVD4,        0x3228, N, N),
3489        PINGROUP(gmi_ad15_ph7,         RSVD1,        NAND,         GMI,          RSVD4,        RSVD4,        0x322c, N, N),
3490        PINGROUP(gmi_wr_n_pi0,         RSVD1,        NAND,         GMI,          RSVD4,        RSVD4,        0x3240, N, N),
3491        PINGROUP(gmi_oe_n_pi1,         RSVD1,        NAND,         GMI,          RSVD4,        RSVD4,        0x3244, N, N),
3492        PINGROUP(gmi_dqs_pi2,          RSVD1,        NAND,         GMI,          RSVD4,        RSVD4,        0x3248, N, N),
3493        PINGROUP(gmi_cs6_n_pi3,        NAND,         NAND_ALT,     GMI,          SATA,         SATA,         0x31e8, N, N),
3494        PINGROUP(gmi_rst_n_pi4,        NAND,         NAND_ALT,     GMI,          RSVD4,        RSVD4,        0x324c, N, N),
3495        PINGROUP(gmi_iordy_pi5,        RSVD1,        NAND,         GMI,          RSVD4,        RSVD4,        0x31c4, N, N),
3496        PINGROUP(gmi_cs7_n_pi6,        NAND,         NAND_ALT,     GMI,          GMI_ALT,      GMI_ALT,      0x31ec, N, N),
3497        PINGROUP(gmi_wait_pi7,         RSVD1,        NAND,         GMI,          RSVD4,        RSVD4,        0x31c8, N, N),
3498        PINGROUP(gmi_cs0_n_pj0,        RSVD1,        NAND,         GMI,          DTV,          RSVD1,        0x31d4, N, N),
3499        PINGROUP(lcd_de_pj1,           DISPLAYA,     DISPLAYB,     RSVD3,        RSVD4,        RSVD4,        0x3098, N, N),
3500        PINGROUP(gmi_cs1_n_pj2,        RSVD1,        NAND,         GMI,          DTV,          RSVD1,        0x31d8, N, N),
3501        PINGROUP(lcd_hsync_pj3,        DISPLAYA,     DISPLAYB,     RSVD3,        RSVD4,        RSVD4,        0x309c, N, N),
3502        PINGROUP(lcd_vsync_pj4,        DISPLAYA,     DISPLAYB,     RSVD3,        RSVD4,        RSVD4,        0x30a0, N, N),
3503        PINGROUP(uart2_cts_n_pj5,      UARTA,        UARTB,        GMI,          SPI4,         SPI4,         0x3170, N, N),
3504        PINGROUP(uart2_rts_n_pj6,      UARTA,        UARTB,        GMI,          SPI4,         SPI4,         0x316c, N, N),
3505        PINGROUP(gmi_a16_pj7,          UARTD,        SPI4,         GMI,          GMI_ALT,      GMI_ALT,      0x3230, N, N),
3506        PINGROUP(gmi_adv_n_pk0,        RSVD1,        NAND,         GMI,          RSVD4,        RSVD4,        0x31cc, N, N),
3507        PINGROUP(gmi_clk_pk1,          RSVD1,        NAND,         GMI,          RSVD4,        RSVD4,        0x31d0, N, N),
3508        PINGROUP(gmi_cs4_n_pk2,        RSVD1,        NAND,         GMI,          RSVD4,        RSVD4,        0x31e4, N, N),
3509        PINGROUP(gmi_cs2_n_pk3,        RSVD1,        NAND,         GMI,          RSVD4,        RSVD4,        0x31dc, N, N),
3510        PINGROUP(gmi_cs3_n_pk4,        RSVD1,        NAND,         GMI,          GMI_ALT,      RSVD1,        0x31e0, N, N),
3511        PINGROUP(spdif_out_pk5,        SPDIF,        RSVD2,        I2C1,         SDMMC2,       RSVD2,        0x3354, N, N),
3512        PINGROUP(spdif_in_pk6,         SPDIF,        HDA,          I2C1,         SDMMC2,       SDMMC2,       0x3350, N, N),
3513        PINGROUP(gmi_a19_pk7,          UARTD,        SPI4,         GMI,          RSVD4,        RSVD4,        0x323c, N, N),
3514        PINGROUP(vi_d2_pl0,            DDR,          SDMMC2,       VI,           RSVD4,        RSVD4,        0x312c, N, Y),
3515        PINGROUP(vi_d3_pl1,            DDR,          SDMMC2,       VI,           RSVD4,        RSVD4,        0x3130, N, Y),
3516        PINGROUP(vi_d4_pl2,            DDR,          SDMMC2,       VI,           RSVD4,        RSVD4,        0x3134, N, Y),
3517        PINGROUP(vi_d5_pl3,            DDR,          SDMMC2,       VI,           RSVD4,        RSVD4,        0x3138, N, Y),
3518        PINGROUP(vi_d6_pl4,            DDR,          SDMMC2,       VI,           RSVD4,        RSVD4,        0x313c, N, Y),
3519        PINGROUP(vi_d7_pl5,            DDR,          SDMMC2,       VI,           RSVD4,        RSVD4,        0x3140, N, Y),
3520        PINGROUP(vi_d8_pl6,            DDR,          SDMMC2,       VI,           RSVD4,        RSVD4,        0x3144, N, Y),
3521        PINGROUP(vi_d9_pl7,            DDR,          SDMMC2,       VI,           RSVD4,        RSVD4,        0x3148, N, Y),
3522        PINGROUP(lcd_d16_pm0,          DISPLAYA,     DISPLAYB,     RSVD3,        RSVD4,        RSVD4,        0x30e4, N, N),
3523        PINGROUP(lcd_d17_pm1,          DISPLAYA,     DISPLAYB,     RSVD3,        RSVD4,        RSVD4,        0x30e8, N, N),
3524        PINGROUP(lcd_d18_pm2,          DISPLAYA,     DISPLAYB,     RSVD3,        RSVD4,        RSVD4,        0x30ec, N, N),
3525        PINGROUP(lcd_d19_pm3,          DISPLAYA,     DISPLAYB,     RSVD3,        RSVD4,        RSVD4,        0x30f0, N, N),
3526        PINGROUP(lcd_d20_pm4,          DISPLAYA,     DISPLAYB,     RSVD3,        RSVD4,        RSVD4,        0x30f4, N, N),
3527        PINGROUP(lcd_d21_pm5,          DISPLAYA,     DISPLAYB,     RSVD3,        RSVD4,        RSVD4,        0x30f8, N, N),
3528        PINGROUP(lcd_d22_pm6,          DISPLAYA,     DISPLAYB,     RSVD3,        RSVD4,        RSVD4,        0x30fc, N, N),
3529        PINGROUP(lcd_d23_pm7,          DISPLAYA,     DISPLAYB,     RSVD3,        RSVD4,        RSVD4,        0x3100, N, N),
3530        PINGROUP(dap1_fs_pn0,          I2S0,         HDA,          GMI,          SDMMC2,       SDMMC2,       0x3338, N, N),
3531        PINGROUP(dap1_din_pn1,         I2S0,         HDA,          GMI,          SDMMC2,       SDMMC2,       0x333c, N, N),
3532        PINGROUP(dap1_dout_pn2,        I2S0,         HDA,          GMI,          SDMMC2,       SDMMC2,       0x3340, N, N),
3533        PINGROUP(dap1_sclk_pn3,        I2S0,         HDA,          GMI,          SDMMC2,       SDMMC2,       0x3344, N, N),
3534        PINGROUP(lcd_cs0_n_pn4,        DISPLAYA,     DISPLAYB,     SPI5,         RSVD4,        RSVD4,        0x3084, N, N),
3535        PINGROUP(lcd_sdout_pn5,        DISPLAYA,     DISPLAYB,     SPI5,         HDCP,         HDCP,         0x307c, N, N),
3536        PINGROUP(lcd_dc0_pn6,          DISPLAYA,     DISPLAYB,     RSVD3,        RSVD4,        RSVD4,        0x3088, N, N),
3537        PINGROUP(hdmi_int_pn7,         HDMI,         RSVD2,        RSVD3,        RSVD4,        RSVD4,        0x3110, N, N),
3538        PINGROUP(ulpi_data7_po0,       SPI2,         HSI,          UARTA,        ULPI,         ULPI,         0x301c, N, N),
3539        PINGROUP(ulpi_data0_po1,       SPI3,         HSI,          UARTA,        ULPI,         ULPI,         0x3000, N, N),
3540        PINGROUP(ulpi_data1_po2,       SPI3,         HSI,          UARTA,        ULPI,         ULPI,         0x3004, N, N),
3541        PINGROUP(ulpi_data2_po3,       SPI3,         HSI,          UARTA,        ULPI,         ULPI,         0x3008, N, N),
3542        PINGROUP(ulpi_data3_po4,       SPI3,         HSI,          UARTA,        ULPI,         ULPI,         0x300c, N, N),
3543        PINGROUP(ulpi_data4_po5,       SPI2,         HSI,          UARTA,        ULPI,         ULPI,         0x3010, N, N),
3544        PINGROUP(ulpi_data5_po6,       SPI2,         HSI,          UARTA,        ULPI,         ULPI,         0x3014, N, N),
3545        PINGROUP(ulpi_data6_po7,       SPI2,         HSI,          UARTA,        ULPI,         ULPI,         0x3018, N, N),
3546        PINGROUP(dap3_fs_pp0,          I2S2,         RSVD2,        DISPLAYA,     DISPLAYB,     RSVD2,        0x3030, N, N),
3547        PINGROUP(dap3_din_pp1,         I2S2,         RSVD2,        DISPLAYA,     DISPLAYB,     RSVD2,        0x3034, N, N),
3548        PINGROUP(dap3_dout_pp2,        I2S2,         RSVD2,        DISPLAYA,     DISPLAYB,     RSVD2,        0x3038, N, N),
3549        PINGROUP(dap3_sclk_pp3,        I2S2,         RSVD2,        DISPLAYA,     DISPLAYB,     RSVD2,        0x303c, N, N),
3550        PINGROUP(dap4_fs_pp4,          I2S3,         RSVD2,        GMI,          RSVD4,        RSVD4,        0x31a8, N, N),
3551        PINGROUP(dap4_din_pp5,         I2S3,         RSVD2,        GMI,          RSVD4,        RSVD4,        0x31ac, N, N),
3552        PINGROUP(dap4_dout_pp6,        I2S3,         RSVD2,        GMI,          RSVD4,        RSVD4,        0x31b0, N, N),
3553        PINGROUP(dap4_sclk_pp7,        I2S3,         RSVD2,        GMI,          RSVD4,        RSVD4,        0x31b4, N, N),
3554        PINGROUP(kb_col0_pq0,          KBC,          NAND,         TRACE,        TEST,         TEST,         0x32fc, N, N),
3555        PINGROUP(kb_col1_pq1,          KBC,          NAND,         TRACE,        TEST,         TEST,         0x3300, N, N),
3556        PINGROUP(kb_col2_pq2,          KBC,          NAND,         TRACE,        RSVD4,        RSVD4,        0x3304, N, N),
3557        PINGROUP(kb_col3_pq3,          KBC,          NAND,         TRACE,        RSVD4,        RSVD4,        0x3308, N, N),
3558        PINGROUP(kb_col4_pq4,          KBC,          NAND,         TRACE,        RSVD4,        RSVD4,        0x330c, N, N),
3559        PINGROUP(kb_col5_pq5,          KBC,          NAND,         TRACE,        RSVD4,        RSVD4,        0x3310, N, N),
3560        PINGROUP(kb_col6_pq6,          KBC,          NAND,         TRACE,        MIO,          MIO,          0x3314, N, N),
3561        PINGROUP(kb_col7_pq7,          KBC,          NAND,         TRACE,        MIO,          MIO,          0x3318, N, N),
3562        PINGROUP(kb_row0_pr0,          KBC,          NAND,         RSVD3,        RSVD4,        RSVD4,        0x32bc, N, N),
3563        PINGROUP(kb_row1_pr1,          KBC,          NAND,         RSVD3,        RSVD4,        RSVD4,        0x32c0, N, N),
3564        PINGROUP(kb_row2_pr2,          KBC,          NAND,         RSVD3,        RSVD4,        RSVD4,        0x32c4, N, N),
3565        PINGROUP(kb_row3_pr3,          KBC,          NAND,         RSVD3,        INVALID,      RSVD3,        0x32c8, N, N),
3566        PINGROUP(kb_row4_pr4,          KBC,          NAND,         TRACE,        RSVD4,        RSVD4,        0x32cc, N, N),
3567        PINGROUP(kb_row5_pr5,          KBC,          NAND,         TRACE,        OWR,          OWR,          0x32d0, N, N),
3568        PINGROUP(kb_row6_pr6,          KBC,          NAND,         SDMMC2,       MIO,          MIO,          0x32d4, N, N),
3569        PINGROUP(kb_row7_pr7,          KBC,          NAND,         SDMMC2,       MIO,          MIO,          0x32d8, N, N),
3570        PINGROUP(kb_row8_ps0,          KBC,          NAND,         SDMMC2,       MIO,          MIO,          0x32dc, N, N),
3571        PINGROUP(kb_row9_ps1,          KBC,          NAND,         SDMMC2,       MIO,          MIO,          0x32e0, N, N),
3572        PINGROUP(kb_row10_ps2,         KBC,          NAND,         SDMMC2,       MIO,          MIO,          0x32e4, N, N),
3573        PINGROUP(kb_row11_ps3,         KBC,          NAND,         SDMMC2,       MIO,          MIO,          0x32e8, N, N),
3574        PINGROUP(kb_row12_ps4,         KBC,          NAND,         SDMMC2,       MIO,          MIO,          0x32ec, N, N),
3575        PINGROUP(kb_row13_ps5,         KBC,          NAND,         SDMMC2,       MIO,          MIO,          0x32f0, N, N),
3576        PINGROUP(kb_row14_ps6,         KBC,          NAND,         SDMMC2,       MIO,          MIO,          0x32f4, N, N),
3577        PINGROUP(kb_row15_ps7,         KBC,          NAND,         SDMMC2,       MIO,          MIO,          0x32f8, N, N),
3578        PINGROUP(vi_pclk_pt0,          RSVD1,        SDMMC2,       VI,           RSVD4,        RSVD4,        0x3154, N, Y),
3579        PINGROUP(vi_mclk_pt1,          VI,           VI_ALT1,      VI_ALT2,      VI_ALT3,      VI_ALT3,      0x3158, N, Y),
3580        PINGROUP(vi_d10_pt2,           DDR,          RSVD2,        VI,           RSVD4,        RSVD4,        0x314c, N, Y),
3581        PINGROUP(vi_d11_pt3,           DDR,          RSVD2,        VI,           RSVD4,        RSVD4,        0x3150, N, Y),
3582        PINGROUP(vi_d0_pt4,            DDR,          RSVD2,        VI,           RSVD4,        RSVD4,        0x3124, N, Y),
3583        PINGROUP(gen2_i2c_scl_pt5,     I2C2,         HDCP,         GMI,          RSVD4,        RSVD4,        0x3250, Y, N),
3584        PINGROUP(gen2_i2c_sda_pt6,     I2C2,         HDCP,         GMI,          RSVD4,        RSVD4,        0x3254, Y, N),
3585        PINGROUP(sdmmc4_cmd_pt7,       I2C3,         NAND,         GMI,          SDMMC4,       SDMMC4,       0x325c, N, Y),
3586        PINGROUP(pu0,                  OWR,          UARTA,        GMI,          RSVD4,        RSVD4,        0x3184, N, N),
3587        PINGROUP(pu1,                  RSVD1,        UARTA,        GMI,          RSVD4,        RSVD4,        0x3188, N, N),
3588        PINGROUP(pu2,                  RSVD1,        UARTA,        GMI,          RSVD4,        RSVD4,        0x318c, N, N),
3589        PINGROUP(pu3,                  PWM0,         UARTA,        GMI,          RSVD4,        RSVD4,        0x3190, N, N),
3590        PINGROUP(pu4,                  PWM1,         UARTA,        GMI,          RSVD4,        RSVD4,        0x3194, N, N),
3591        PINGROUP(pu5,                  PWM2,         UARTA,        GMI,          RSVD4,        RSVD4,        0x3198, N, N),
3592        PINGROUP(pu6,                  PWM3,         UARTA,        GMI,          RSVD4,        RSVD4,        0x319c, N, N),
3593        PINGROUP(jtag_rtck_pu7,        RTCK,         RSVD2,        RSVD3,        RSVD4,        RSVD4,        0x32b0, N, N),
3594        PINGROUP(pv0,                  RSVD1,        RSVD2,        RSVD3,        RSVD4,        RSVD4,        0x3040, N, N),
3595        PINGROUP(pv1,                  RSVD1,        RSVD2,        RSVD3,        RSVD4,        RSVD4,        0x3044, N, N),
3596        PINGROUP(pv2,                  OWR,          RSVD2,        RSVD3,        RSVD4,        RSVD4,        0x3060, N, N),
3597        PINGROUP(pv3,                  CLK_12M_OUT,  RSVD2,        RSVD3,        RSVD4,        RSVD4,        0x3064, N, N),
3598        PINGROUP(ddc_scl_pv4,          I2C4,         RSVD2,        RSVD3,        RSVD4,        RSVD4,        0x3114, N, N),
3599        PINGROUP(ddc_sda_pv5,          I2C4,         RSVD2,        RSVD3,        RSVD4,        RSVD4,        0x3118, N, N),
3600        PINGROUP(crt_hsync_pv6,        CRT,          RSVD2,        RSVD3,        RSVD4,        RSVD4,        0x311c, N, N),
3601        PINGROUP(crt_vsync_pv7,        CRT,          RSVD2,        RSVD3,        RSVD4,        RSVD4,        0x3120, N, N),
3602        PINGROUP(lcd_cs1_n_pw0,        DISPLAYA,     DISPLAYB,     SPI5,         RSVD4,        RSVD4,        0x3104, N, N),
3603        PINGROUP(lcd_m1_pw1,           DISPLAYA,     DISPLAYB,     RSVD3,        RSVD4,        RSVD4,        0x3108, N, N),
3604        PINGROUP(spi2_cs1_n_pw2,       SPI3,         SPI2,         SPI2_ALT,     I2C1,         I2C1,         0x3388, N, N),
3605        PINGROUP(spi2_cs2_n_pw3,       SPI3,         SPI2,         SPI2_ALT,     I2C1,         I2C1,         0x338c, N, N),
3606        PINGROUP(clk1_out_pw4,         EXTPERIPH1,   RSVD2,        RSVD3,        RSVD4,        RSVD4,        0x334c, N, N),
3607        PINGROUP(clk2_out_pw5,         EXTPERIPH2,   RSVD2,        RSVD3,        RSVD4,        RSVD4,        0x3068, N, N),
3608        PINGROUP(uart3_txd_pw6,        UARTC,        RSVD2,        GMI,          RSVD4,        RSVD4,        0x3174, N, N),
3609        PINGROUP(uart3_rxd_pw7,        UARTC,        RSVD2,        GMI,          RSVD4,        RSVD4,        0x3178, N, N),
3610        PINGROUP(spi2_mosi_px0,        SPI6,         SPI2,         SPI3,         GMI,          GMI,          0x3368, N, N),
3611        PINGROUP(spi2_miso_px1,        SPI6,         SPI2,         SPI3,         GMI,          GMI,          0x336c, N, N),
3612        PINGROUP(spi2_sck_px2,         SPI6,         SPI2,         SPI3,         GMI,          GMI,          0x3374, N, N),
3613        PINGROUP(spi2_cs0_n_px3,       SPI6,         SPI2,         SPI3,         GMI,          GMI,          0x3370, N, N),
3614        PINGROUP(spi1_mosi_px4,        SPI2,         SPI1,         SPI2_ALT,     GMI,          GMI,          0x3378, N, N),
3615        PINGROUP(spi1_sck_px5,         SPI2,         SPI1,         SPI2_ALT,     GMI,          GMI,          0x337c, N, N),
3616        PINGROUP(spi1_cs0_n_px6,       SPI2,         SPI1,         SPI2_ALT,     GMI,          GMI,          0x3380, N, N),
3617        PINGROUP(spi1_miso_px7,        SPI3,         SPI1,         SPI2_ALT,     RSVD4,        RSVD4,        0x3384, N, N),
3618        PINGROUP(ulpi_clk_py0,         SPI1,         RSVD2,        UARTD,        ULPI,         RSVD2,        0x3020, N, N),
3619        PINGROUP(ulpi_dir_py1,         SPI1,         RSVD2,        UARTD,        ULPI,         RSVD2,        0x3024, N, N),
3620        PINGROUP(ulpi_nxt_py2,         SPI1,         RSVD2,        UARTD,        ULPI,         RSVD2,        0x3028, N, N),
3621        PINGROUP(ulpi_stp_py3,         SPI1,         RSVD2,        UARTD,        ULPI,         RSVD2,        0x302c, N, N),
3622        PINGROUP(sdmmc1_dat3_py4,      SDMMC1,       RSVD2,        UARTE,        UARTA,        RSVD2,        0x3050, N, N),
3623        PINGROUP(sdmmc1_dat2_py5,      SDMMC1,       RSVD2,        UARTE,        UARTA,        RSVD2,        0x3054, N, N),
3624        PINGROUP(sdmmc1_dat1_py6,      SDMMC1,       RSVD2,        UARTE,        UARTA,        RSVD2,        0x3058, N, N),
3625        PINGROUP(sdmmc1_dat0_py7,      SDMMC1,       RSVD2,        UARTE,        UARTA,        RSVD2,        0x305c, N, N),
3626        PINGROUP(sdmmc1_clk_pz0,       SDMMC1,       RSVD2,        RSVD3,        UARTA,        RSVD3,        0x3048, N, N),
3627        PINGROUP(sdmmc1_cmd_pz1,       SDMMC1,       RSVD2,        RSVD3,        UARTA,        RSVD3,        0x304c, N, N),
3628        PINGROUP(lcd_sdin_pz2,         DISPLAYA,     DISPLAYB,     SPI5,         RSVD4,        RSVD4,        0x3078, N, N),
3629        PINGROUP(lcd_wr_n_pz3,         DISPLAYA,     DISPLAYB,     SPI5,         HDCP,         HDCP,         0x3080, N, N),
3630        PINGROUP(lcd_sck_pz4,          DISPLAYA,     DISPLAYB,     SPI5,         HDCP,         HDCP,         0x308c, N, N),
3631        PINGROUP(sys_clk_req_pz5,      SYSCLK,       RSVD2,        RSVD3,        RSVD4,        RSVD4,        0x3320, N, N),
3632        PINGROUP(pwr_i2c_scl_pz6,      I2CPWR,       RSVD2,        RSVD3,        RSVD4,        RSVD4,        0x32b4, Y, N),
3633        PINGROUP(pwr_i2c_sda_pz7,      I2CPWR,       RSVD2,        RSVD3,        RSVD4,        RSVD4,        0x32b8, Y, N),
3634        PINGROUP(sdmmc4_dat0_paa0,     UARTE,        SPI3,         GMI,          SDMMC4,       SDMMC4,       0x3260, N, Y),
3635        PINGROUP(sdmmc4_dat1_paa1,     UARTE,        SPI3,         GMI,          SDMMC4,       SDMMC4,       0x3264, N, Y),
3636        PINGROUP(sdmmc4_dat2_paa2,     UARTE,        SPI3,         GMI,          SDMMC4,       SDMMC4,       0x3268, N, Y),
3637        PINGROUP(sdmmc4_dat3_paa3,     UARTE,        SPI3,         GMI,          SDMMC4,       SDMMC4,       0x326c, N, Y),
3638        PINGROUP(sdmmc4_dat4_paa4,     I2C3,         I2S4,         GMI,          SDMMC4,       SDMMC4,       0x3270, N, Y),
3639        PINGROUP(sdmmc4_dat5_paa5,     VGP3,         I2S4,         GMI,          SDMMC4,       SDMMC4,       0x3274, N, Y),
3640        PINGROUP(sdmmc4_dat6_paa6,     VGP4,         I2S4,         GMI,          SDMMC4,       SDMMC4,       0x3278, N, Y),
3641        PINGROUP(sdmmc4_dat7_paa7,     VGP5,         I2S4,         GMI,          SDMMC4,       SDMMC4,       0x327c, N, Y),
3642        PINGROUP(pbb0,                 I2S4,         RSVD2,        RSVD3,        SDMMC4,       RSVD3,        0x328c, N, N),
3643        PINGROUP(cam_i2c_scl_pbb1,     VGP1,         I2C3,         RSVD3,        SDMMC4,       RSVD3,        0x3290, Y, N),
3644        PINGROUP(cam_i2c_sda_pbb2,     VGP2,         I2C3,         RSVD3,        SDMMC4,       RSVD3,        0x3294, Y, N),
3645        PINGROUP(pbb3,                 VGP3,         DISPLAYA,     DISPLAYB,     SDMMC4,       SDMMC4,       0x3298, N, N),
3646        PINGROUP(pbb4,                 VGP4,         DISPLAYA,     DISPLAYB,     SDMMC4,       SDMMC4,       0x329c, N, N),
3647        PINGROUP(pbb5,                 VGP5,         DISPLAYA,     DISPLAYB,     SDMMC4,       SDMMC4,       0x32a0, N, N),
3648        PINGROUP(pbb6,                 VGP6,         DISPLAYA,     DISPLAYB,     SDMMC4,       SDMMC4,       0x32a4, N, N),
3649        PINGROUP(pbb7,                 I2S4,         RSVD2,        RSVD3,        SDMMC4,       RSVD3,        0x32a8, N, N),
3650        PINGROUP(cam_mclk_pcc0,        VI,           VI_ALT1,      VI_ALT3,      SDMMC4,       SDMMC4,       0x3284, N, N),
3651        PINGROUP(pcc1,                 I2S4,         RSVD2,        RSVD3,        SDMMC4,       RSVD3,        0x3288, N, N),
3652        PINGROUP(pcc2,                 I2S4,         RSVD2,        RSVD3,        RSVD4,        RSVD4,        0x32ac, N, N),
3653        PINGROUP(sdmmc4_rst_n_pcc3,    VGP6,         RSVD2,        RSVD3,        SDMMC4,       RSVD3,        0x3280, N, Y),
3654        PINGROUP(sdmmc4_clk_pcc4,      INVALID,      NAND,         GMI,          SDMMC4,       SDMMC4,       0x3258, N, Y),
3655        PINGROUP(clk2_req_pcc5,        DAP,          RSVD2,        RSVD3,        RSVD4,        RSVD4,        0x306c, N, N),
3656        PINGROUP(pex_l2_rst_n_pcc6,    PCIE,         HDA,          RSVD3,        RSVD4,        RSVD4,        0x33d8, N, N),
3657        PINGROUP(pex_l2_clkreq_n_pcc7, PCIE,         HDA,          RSVD3,        RSVD4,        RSVD4,        0x33dc, N, N),
3658        PINGROUP(pex_l0_prsnt_n_pdd0,  PCIE,         HDA,          RSVD3,        RSVD4,        RSVD4,        0x33b8, N, N),
3659        PINGROUP(pex_l0_rst_n_pdd1,    PCIE,         HDA,          RSVD3,        RSVD4,        RSVD4,        0x33bc, N, N),
3660        PINGROUP(pex_l0_clkreq_n_pdd2, PCIE,         HDA,          RSVD3,        RSVD4,        RSVD4,        0x33c0, N, N),
3661        PINGROUP(pex_wake_n_pdd3,      PCIE,         HDA,          RSVD3,        RSVD4,        RSVD4,        0x33c4, N, N),
3662        PINGROUP(pex_l1_prsnt_n_pdd4,  PCIE,         HDA,          RSVD3,        RSVD4,        RSVD4,        0x33c8, N, N),
3663        PINGROUP(pex_l1_rst_n_pdd5,    PCIE,         HDA,          RSVD3,        RSVD4,        RSVD4,        0x33cc, N, N),
3664        PINGROUP(pex_l1_clkreq_n_pdd6, PCIE,         HDA,          RSVD3,        RSVD4,        RSVD4,        0x33d0, N, N),
3665        PINGROUP(pex_l2_prsnt_n_pdd7,  PCIE,         HDA,          RSVD3,        RSVD4,        RSVD4,        0x33d4, N, N),
3666        PINGROUP(clk3_out_pee0,        EXTPERIPH3,   RSVD2,        RSVD3,        RSVD4,        RSVD4,        0x31b8, N, N),
3667        PINGROUP(clk3_req_pee1,        DEV3,         RSVD2,        RSVD3,        RSVD4,        RSVD4,        0x31bc, N, N),
3668        PINGROUP(clk1_req_pee2,        DAP,          HDA,          RSVD3,        RSVD4,        RSVD4,        0x3348, N, N),
3669        PINGROUP(hdmi_cec_pee3,        CEC,          RSVD2,        RSVD3,        RSVD4,        RSVD4,        0x33e0, Y, N),
3670        PINGROUP(clk_32k_in,           CLK_32K_IN,   RSVD2,        RSVD3,        RSVD4,        RSVD4,        0x3330, N, N),
3671        PINGROUP(core_pwr_req,         CORE_PWR_REQ, RSVD2,        RSVD3,        RSVD4,        RSVD4,        0x3324, N, N),
3672        PINGROUP(cpu_pwr_req,          CPU_PWR_REQ,  RSVD2,        RSVD3,        RSVD4,        RSVD4,        0x3328, N, N),
3673        PINGROUP(owr,                  OWR,          CEC,          RSVD3,        RSVD4,        RSVD4,        0x3334, N, N),
3674        PINGROUP(pwr_int_n,            PWR_INT_N,    RSVD2,        RSVD3,        RSVD4,        RSVD4,        0x332c, N, N),
3675        /* 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 */
3676        DRV_PINGROUP(ao1,   0x868,  2,  3,  4,  12,  5,  20,  5,  28,  2,  30,  2),
3677        DRV_PINGROUP(ao2,   0x86c,  2,  3,  4,  12,  5,  20,  5,  28,  2,  30,  2),
3678        DRV_PINGROUP(at1,   0x870,  2,  3,  4,  14,  5,  19,  5,  24,  2,  28,  2),
3679        DRV_PINGROUP(at2,   0x874,  2,  3,  4,  14,  5,  19,  5,  24,  2,  28,  2),
3680        DRV_PINGROUP(at3,   0x878,  2,  3,  4,  14,  5,  19,  5,  28,  2,  30,  2),
3681        DRV_PINGROUP(at4,   0x87c,  2,  3,  4,  14,  5,  19,  5,  28,  2,  30,  2),
3682        DRV_PINGROUP(at5,   0x880,  2,  3,  4,  14,  5,  19,  5,  28,  2,  30,  2),
3683        DRV_PINGROUP(cdev1, 0x884,  2,  3,  4,  12,  5,  20,  5,  28,  2,  30,  2),
3684        DRV_PINGROUP(cdev2, 0x888,  2,  3,  4,  12,  5,  20,  5,  28,  2,  30,  2),
3685        DRV_PINGROUP(cec,   0x938,  2,  3,  4,  12,  5,  20,  5,  28,  2,  30,  2),
3686        DRV_PINGROUP(crt,   0x8f8,  2,  3,  4,  12,  5,  20,  5,  28,  2,  30,  2),
3687        DRV_PINGROUP(csus,  0x88c, -1, -1, -1,  12,  5,  19,  5,  24,  4,  28,  4),
3688        DRV_PINGROUP(dap1,  0x890,  2,  3,  4,  12,  5,  20,  5,  28,  2,  30,  2),
3689        DRV_PINGROUP(dap2,  0x894,  2,  3,  4,  12,  5,  20,  5,  28,  2,  30,  2),
3690        DRV_PINGROUP(dap3,  0x898,  2,  3,  4,  12,  5,  20,  5,  28,  2,  30,  2),
3691        DRV_PINGROUP(dap4,  0x89c,  2,  3,  4,  12,  5,  20,  5,  28,  2,  30,  2),
3692        DRV_PINGROUP(dbg,   0x8a0,  2,  3,  4,  12,  5,  20,  5,  28,  2,  30,  2),
3693        DRV_PINGROUP(ddc,   0x8fc,  2,  3,  4,  12,  5,  20,  5,  28,  2,  30,  2),
3694        DRV_PINGROUP(dev3,  0x92c,  2,  3,  4,  12,  5,  20,  5,  28,  2,  30,  2),
3695        DRV_PINGROUP(gma,   0x900, -1, -1, -1,  14,  5,  19,  5,  24,  4,  28,  4),
3696        DRV_PINGROUP(gmb,   0x904, -1, -1, -1,  14,  5,  19,  5,  24,  4,  28,  4),
3697        DRV_PINGROUP(gmc,   0x908, -1, -1, -1,  14,  5,  19,  5,  24,  4,  28,  4),
3698        DRV_PINGROUP(gmd,   0x90c, -1, -1, -1,  14,  5,  19,  5,  24,  4,  28,  4),
3699        DRV_PINGROUP(gme,   0x910,  2,  3,  4,  14,  5,  19,  5,  28,  2,  30,  2),
3700        DRV_PINGROUP(gmf,   0x914,  2,  3,  4,  14,  5,  19,  5,  28,  2,  30,  2),
3701        DRV_PINGROUP(gmg,   0x918,  2,  3,  4,  14,  5,  19,  5,  28,  2,  30,  2),
3702        DRV_PINGROUP(gmh,   0x91c,  2,  3,  4,  14,  5,  19,  5,  28,  2,  30,  2),
3703        DRV_PINGROUP(gpv,   0x928,  2,  3,  4,  12,  5,  20,  5,  28,  2,  30,  2),
3704        DRV_PINGROUP(lcd1,  0x8a4,  2,  3,  4,  12,  5,  20,  5,  28,  2,  30,  2),
3705        DRV_PINGROUP(lcd2,  0x8a8,  2,  3,  4,  12,  5,  20,  5,  28,  2,  30,  2),
3706        DRV_PINGROUP(owr,   0x920,  2,  3,  4,  12,  5,  20,  5,  28,  2,  30,  2),
3707        DRV_PINGROUP(sdio1, 0x8ec,  2,  3, -1,  12,  7,  20,  7,  28,  2,  30,  2),
3708        DRV_PINGROUP(sdio2, 0x8ac,  2,  3, -1,  12,  7,  20,  7,  28,  2,  30,  2),
3709        DRV_PINGROUP(sdio3, 0x8b0,  2,  3, -1,  12,  7,  20,  7,  28,  2,  30,  2),
3710        DRV_PINGROUP(spi,   0x8b4,  2,  3,  4,  12,  5,  20,  5,  28,  2,  30,  2),
3711        DRV_PINGROUP(uaa,   0x8b8,  2,  3,  4,  12,  5,  20,  5,  28,  2,  30,  2),
3712        DRV_PINGROUP(uab,   0x8bc,  2,  3,  4,  12,  5,  20,  5,  28,  2,  30,  2),
3713        DRV_PINGROUP(uart2, 0x8c0,  2,  3,  4,  12,  5,  20,  5,  28,  2,  30,  2),
3714        DRV_PINGROUP(uart3, 0x8c4,  2,  3,  4,  12,  5,  20,  5,  28,  2,  30,  2),
3715        DRV_PINGROUP(uda,   0x924,  2,  3,  4,  12,  5,  20,  5,  28,  2,  30,  2),
3716        DRV_PINGROUP(vi1,   0x8c8, -1, -1, -1,  14,  5,  19,  5,  24,  4,  28,  4),
3717};
3718
3719static const struct tegra_pinctrl_soc_data tegra30_pinctrl = {
3720        .ngpios = NUM_GPIOS,
3721        .pins = tegra30_pins,
3722        .npins = ARRAY_SIZE(tegra30_pins),
3723        .functions = tegra30_functions,
3724        .nfunctions = ARRAY_SIZE(tegra30_functions),
3725        .groups = tegra30_groups,
3726        .ngroups = ARRAY_SIZE(tegra30_groups),
3727};
3728
3729static int tegra30_pinctrl_probe(struct platform_device *pdev)
3730{
3731        return tegra_pinctrl_probe(pdev, &tegra30_pinctrl);
3732}
3733
3734static struct of_device_id tegra30_pinctrl_of_match[] = {
3735        { .compatible = "nvidia,tegra30-pinmux", },
3736        { },
3737};
3738
3739static struct platform_driver tegra30_pinctrl_driver = {
3740        .driver = {
3741                .name = "tegra30-pinctrl",
3742                .owner = THIS_MODULE,
3743                .of_match_table = tegra30_pinctrl_of_match,
3744        },
3745        .probe = tegra30_pinctrl_probe,
3746        .remove = tegra_pinctrl_remove,
3747};
3748
3749static int __init tegra30_pinctrl_init(void)
3750{
3751        return platform_driver_register(&tegra30_pinctrl_driver);
3752}
3753arch_initcall(tegra30_pinctrl_init);
3754
3755static void __exit tegra30_pinctrl_exit(void)
3756{
3757        platform_driver_unregister(&tegra30_pinctrl_driver);
3758}
3759module_exit(tegra30_pinctrl_exit);
3760
3761MODULE_AUTHOR("Stephen Warren <swarren@nvidia.com>");
3762MODULE_DESCRIPTION("NVIDIA Tegra30 pinctrl driver");
3763MODULE_LICENSE("GPL v2");
3764MODULE_DEVICE_TABLE(of, tegra30_pinctrl_of_match);
3765