1// SPDX-License-Identifier: GPL-2.0+
2/*
3 * Copyright (c) 2013-2014, NVIDIA CORPORATION. All rights reserved.
4 */
5
6#include <asm/io.h>
7#include <asm/arch/pinmux.h>
8
9#define PIN(pin, f0, f1, f2, f3)	\
10	{				\
11		.funcs = {		\
12			PMUX_FUNC_##f0,	\
13			PMUX_FUNC_##f1,	\
14			PMUX_FUNC_##f2,	\
15			PMUX_FUNC_##f3,	\
16		},			\
17	}
18
19#define PIN_RESERVED {}
20
21static const struct pmux_pingrp_desc tegra210_pingroups[] = {
22	/*  pin,                  f0,         f1,     f2,    f3 */
23	/* Offset 0x3000 */
24	PIN(SDMMC1_CLK_PM0,       SDMMC1,     RSVD1,  RSVD2, RSVD3),
25	PIN(SDMMC1_CMD_PM1,       SDMMC1,     SPI3,   RSVD2, RSVD3),
26	PIN(SDMMC1_DAT3_PM2,      SDMMC1,     SPI3,   RSVD2, RSVD3),
27	PIN(SDMMC1_DAT2_PM3,      SDMMC1,     SPI3,   RSVD2, RSVD3),
28	PIN(SDMMC1_DAT1_PM4,      SDMMC1,     SPI3,   RSVD2, RSVD3),
29	PIN(SDMMC1_DAT0_PM5,      SDMMC1,     RSVD1,  RSVD2, RSVD3),
30	PIN_RESERVED,
31	PIN(SDMMC3_CLK_PP0,       SDMMC3,     RSVD1,  RSVD2, RSVD3),
32	PIN(SDMMC3_CMD_PP1,       SDMMC3,     RSVD1,  RSVD2, RSVD3),
33	PIN(SDMMC3_DAT0_PP5,      SDMMC3,     RSVD1,  RSVD2, RSVD3),
34	PIN(SDMMC3_DAT1_PP4,      SDMMC3,     RSVD1,  RSVD2, RSVD3),
35	PIN(SDMMC3_DAT2_PP3,      SDMMC3,     RSVD1,  RSVD2, RSVD3),
36	PIN(SDMMC3_DAT3_PP2,      SDMMC3,     RSVD1,  RSVD2, RSVD3),
37	PIN_RESERVED,
38	PIN(PEX_L0_RST_N_PA0,     PE0,        RSVD1,  RSVD2, RSVD3),
39	PIN(PEX_L0_CLKREQ_N_PA1,  PE0,        RSVD1,  RSVD2, RSVD3),
40	PIN(PEX_WAKE_N_PA2,       PE,         RSVD1,  RSVD2, RSVD3),
41	PIN(PEX_L1_RST_N_PA3,     PE1,        RSVD1,  RSVD2, RSVD3),
42	PIN(PEX_L1_CLKREQ_N_PA4,  PE1,        RSVD1,  RSVD2, RSVD3),
43	PIN(SATA_LED_ACTIVE_PA5,  SATA,       RSVD1,  RSVD2, RSVD3),
44	PIN(SPI1_MOSI_PC0,        SPI1,       RSVD1,  RSVD2, RSVD3),
45	PIN(SPI1_MISO_PC1,        SPI1,       RSVD1,  RSVD2, RSVD3),
46	PIN(SPI1_SCK_PC2,         SPI1,       RSVD1,  RSVD2, RSVD3),
47	PIN(SPI1_CS0_PC3,         SPI1,       RSVD1,  RSVD2, RSVD3),
48	PIN(SPI1_CS1_PC4,         SPI1,       RSVD1,  RSVD2, RSVD3),
49	PIN(SPI2_MOSI_PB4,        SPI2,       DTV,    RSVD2, RSVD3),
50	PIN(SPI2_MISO_PB5,        SPI2,       DTV,    RSVD2, RSVD3),
51	PIN(SPI2_SCK_PB6,         SPI2,       DTV,    RSVD2, RSVD3),
52	PIN(SPI2_CS0_PB7,         SPI2,       DTV,    RSVD2, RSVD3),
53	PIN(SPI2_CS1_PDD0,        SPI2,       RSVD1,  RSVD2, RSVD3),
54	PIN(SPI4_MOSI_PC7,        SPI4,       RSVD1,  RSVD2, RSVD3),
55	PIN(SPI4_MISO_PD0,        SPI4,       RSVD1,  RSVD2, RSVD3),
56	PIN(SPI4_SCK_PC5,         SPI4,       RSVD1,  RSVD2, RSVD3),
57	PIN(SPI4_CS0_PC6,         SPI4,       RSVD1,  RSVD2, RSVD3),
58	PIN(QSPI_SCK_PEE0,        QSPI,       RSVD1,  RSVD2, RSVD3),
59	PIN(QSPI_CS_N_PEE1,       QSPI,       RSVD1,  RSVD2, RSVD3),
60	PIN(QSPI_IO0_PEE2,        QSPI,       RSVD1,  RSVD2, RSVD3),
61	PIN(QSPI_IO1_PEE3,        QSPI,       RSVD1,  RSVD2, RSVD3),
62	PIN(QSPI_IO2_PEE4,        QSPI,       RSVD1,  RSVD2, RSVD3),
63	PIN(QSPI_IO3_PEE5,        QSPI,       RSVD1,  RSVD2, RSVD3),
64	PIN_RESERVED,
65	PIN(DMIC1_CLK_PE0,        DMIC1,      I2S3,   RSVD2, RSVD3),
66	PIN(DMIC1_DAT_PE1,        DMIC1,      I2S3,   RSVD2, RSVD3),
67	PIN(DMIC2_CLK_PE2,        DMIC2,      I2S3,   RSVD2, RSVD3),
68	PIN(DMIC2_DAT_PE3,        DMIC2,      I2S3,   RSVD2, RSVD3),
69	PIN(DMIC3_CLK_PE4,        DMIC3,      I2S5A,  RSVD2, RSVD3),
70	PIN(DMIC3_DAT_PE5,        DMIC3,      I2S5A,  RSVD2, RSVD3),
71	PIN(GEN1_I2C_SCL_PJ1,     I2C1,       RSVD1,  RSVD2, RSVD3),
72	PIN(GEN1_I2C_SDA_PJ0,     I2C1,       RSVD1,  RSVD2, RSVD3),
73	PIN(GEN2_I2C_SCL_PJ2,     I2C2,       RSVD1,  RSVD2, RSVD3),
74	PIN(GEN2_I2C_SDA_PJ3,     I2C2,       RSVD1,  RSVD2, RSVD3),
75	PIN(GEN3_I2C_SCL_PF0,     I2C3,       RSVD1,  RSVD2, RSVD3),
76	PIN(GEN3_I2C_SDA_PF1,     I2C3,       RSVD1,  RSVD2, RSVD3),
77	PIN(CAM_I2C_SCL_PS2,      I2C3,       I2CVI,  RSVD2, RSVD3),
78	PIN(CAM_I2C_SDA_PS3,      I2C3,       I2CVI,  RSVD2, RSVD3),
79	PIN(PWR_I2C_SCL_PY3,      I2CPMU,     RSVD1,  RSVD2, RSVD3),
80	PIN(PWR_I2C_SDA_PY4,      I2CPMU,     RSVD1,  RSVD2, RSVD3),
81	PIN(UART1_TX_PU0,         UARTA,      RSVD1,  RSVD2, RSVD3),
82	PIN(UART1_RX_PU1,         UARTA,      RSVD1,  RSVD2, RSVD3),
83	PIN(UART1_RTS_PU2,        UARTA,      RSVD1,  RSVD2, RSVD3),
84	PIN(UART1_CTS_PU3,        UARTA,      RSVD1,  RSVD2, RSVD3),
85	PIN(UART2_TX_PG0,         UARTB,      I2S4A,  SPDIF, UART),
86	PIN(UART2_RX_PG1,         UARTB,      I2S4A,  SPDIF, UART),
87	PIN(UART2_RTS_PG2,        UARTB,      I2S4A,  RSVD2, UART),
88	PIN(UART2_CTS_PG3,        UARTB,      I2S4A,  RSVD2, UART),
89	PIN(UART3_TX_PD1,         UARTC,      SPI4,   RSVD2, RSVD3),
90	PIN(UART3_RX_PD2,         UARTC,      SPI4,   RSVD2, RSVD3),
91	PIN(UART3_RTS_PD3,        UARTC,      SPI4,   RSVD2, RSVD3),
92	PIN(UART3_CTS_PD4,        UARTC,      SPI4,   RSVD2, RSVD3),
93	PIN(UART4_TX_PI4,         UARTD,      UART,   RSVD2, RSVD3),
94	PIN(UART4_RX_PI5,         UARTD,      UART,   RSVD2, RSVD3),
95	PIN(UART4_RTS_PI6,        UARTD,      UART,   RSVD2, RSVD3),
96	PIN(UART4_CTS_PI7,        UARTD,      UART,   RSVD2, RSVD3),
97	PIN(DAP1_FS_PB0,          I2S1,       RSVD1,  RSVD2, RSVD3),
98	PIN(DAP1_DIN_PB1,         I2S1,       RSVD1,  RSVD2, RSVD3),
99	PIN(DAP1_DOUT_PB2,        I2S1,       RSVD1,  RSVD2, RSVD3),
100	PIN(DAP1_SCLK_PB3,        I2S1,       RSVD1,  RSVD2, RSVD3),
101	PIN(DAP2_FS_PAA0,         I2S2,       RSVD1,  RSVD2, RSVD3),
102	PIN(DAP2_DIN_PAA2,        I2S2,       RSVD1,  RSVD2, RSVD3),
103	PIN(DAP2_DOUT_PAA3,       I2S2,       RSVD1,  RSVD2, RSVD3),
104	PIN(DAP2_SCLK_PAA1,       I2S2,       RSVD1,  RSVD2, RSVD3),
105	PIN(DAP4_FS_PJ4,          I2S4B,      RSVD1,  RSVD2, RSVD3),
106	PIN(DAP4_DIN_PJ5,         I2S4B,      RSVD1,  RSVD2, RSVD3),
107	PIN(DAP4_DOUT_PJ6,        I2S4B,      RSVD1,  RSVD2, RSVD3),
108	PIN(DAP4_SCLK_PJ7,        I2S4B,      RSVD1,  RSVD2, RSVD3),
109	PIN(CAM1_MCLK_PS0,        EXTPERIPH3, RSVD1,  RSVD2, RSVD3),
110	PIN(CAM2_MCLK_PS1,        EXTPERIPH3, RSVD1,  RSVD2, RSVD3),
111	PIN(JTAG_RTCK,            JTAG,       RSVD1,  RSVD2, RSVD3),
112	PIN(CLK_32K_IN,           CLK,        RSVD1,  RSVD2, RSVD3),
113	PIN(CLK_32K_OUT_PY5,      SOC,        BLINK,  RSVD2, RSVD3),
114	PIN(BATT_BCL,             BCL,        RSVD1,  RSVD2, RSVD3),
115	PIN(CLK_REQ,              SYS,        RSVD1,  RSVD2, RSVD3),
116	PIN(CPU_PWR_REQ,          CPU,        RSVD1,  RSVD2, RSVD3),
117	PIN(PWR_INT_N,            PMI,        RSVD1,  RSVD2, RSVD3),
118	PIN(SHUTDOWN,             SHUTDOWN,   RSVD1,  RSVD2, RSVD3),
119	PIN(CORE_PWR_REQ,         CORE,       RSVD1,  RSVD2, RSVD3),
120	PIN(AUD_MCLK_PBB0,        AUD,        RSVD1,  RSVD2, RSVD3),
121	PIN(DVFS_PWM_PBB1,        RSVD0,      CLDVFS, SPI3,  RSVD3),
122	PIN(DVFS_CLK_PBB2,        RSVD0,      CLDVFS, SPI3,  RSVD3),
123	PIN(GPIO_X1_AUD_PBB3,     RSVD0,      RSVD1,  SPI3,  RSVD3),
124	PIN(GPIO_X3_AUD_PBB4,     RSVD0,      RSVD1,  SPI3,  RSVD3),
125	PIN(PCC7,                 RSVD0,      RSVD1,  RSVD2, RSVD3),
126	PIN(HDMI_CEC_PCC0,        CEC,        RSVD1,  RSVD2, RSVD3),
127	PIN(HDMI_INT_DP_HPD_PCC1, DP,         RSVD1,  RSVD2, RSVD3),
128	PIN(SPDIF_OUT_PCC2,       SPDIF,      RSVD1,  RSVD2, RSVD3),
129	PIN(SPDIF_IN_PCC3,        SPDIF,      RSVD1,  RSVD2, RSVD3),
130	PIN(USB_VBUS_EN0_PCC4,    USB,        RSVD1,  RSVD2, RSVD3),
131	PIN(USB_VBUS_EN1_PCC5,    USB,        RSVD1,  RSVD2, RSVD3),
132	PIN(DP_HPD0_PCC6,         DP,         RSVD1,  RSVD2, RSVD3),
133	PIN(WIFI_EN_PH0,          RSVD0,      RSVD1,  RSVD2, RSVD3),
134	PIN(WIFI_RST_PH1,         RSVD0,      RSVD1,  RSVD2, RSVD3),
135	PIN(WIFI_WAKE_AP_PH2,     RSVD0,      RSVD1,  RSVD2, RSVD3),
136	PIN(AP_WAKE_BT_PH3,       RSVD0,      UARTB,  SPDIF, RSVD3),
137	PIN(BT_RST_PH4,           RSVD0,      UARTB,  SPDIF, RSVD3),
138	PIN(BT_WAKE_AP_PH5,       RSVD0,      RSVD1,  RSVD2, RSVD3),
139	PIN(AP_WAKE_NFC_PH7,      RSVD0,      RSVD1,  RSVD2, RSVD3),
140	PIN(NFC_EN_PI0,           RSVD0,      RSVD1,  RSVD2, RSVD3),
141	PIN(NFC_INT_PI1,          RSVD0,      RSVD1,  RSVD2, RSVD3),
142	PIN(GPS_EN_PI2,           RSVD0,      RSVD1,  RSVD2, RSVD3),
143	PIN(GPS_RST_PI3,          RSVD0,      RSVD1,  RSVD2, RSVD3),
144	PIN(CAM_RST_PS4,          VGP1,       RSVD1,  RSVD2, RSVD3),
145	PIN(CAM_AF_EN_PS5,        VIMCLK,     VGP2,   RSVD2, RSVD3),
146	PIN(CAM_FLASH_EN_PS6,     VIMCLK,     VGP3,   RSVD2, RSVD3),
147	PIN(CAM1_PWDN_PS7,        VGP4,       RSVD1,  RSVD2, RSVD3),
148	PIN(CAM2_PWDN_PT0,        VGP5,       RSVD1,  RSVD2, RSVD3),
149	PIN(CAM1_STROBE_PT1,      VGP6,       RSVD1,  RSVD2, RSVD3),
150	PIN(LCD_TE_PY2,           DISPLAYA,   RSVD1,  RSVD2, RSVD3),
151	PIN(LCD_BL_PWM_PV0,       DISPLAYA,   PWM0,   SOR0,  RSVD3),
152	PIN(LCD_BL_EN_PV1,        RSVD0,      RSVD1,  RSVD2, RSVD3),
153	PIN(LCD_RST_PV2,          RSVD0,      RSVD1,  RSVD2, RSVD3),
154	PIN(LCD_GPIO1_PV3,        DISPLAYB,   RSVD1,  RSVD2, RSVD3),
155	PIN(LCD_GPIO2_PV4,        DISPLAYB,   PWM1,   RSVD2, SOR1),
156	PIN(AP_READY_PV5,         RSVD0,      RSVD1,  RSVD2, RSVD3),
157	PIN(TOUCH_RST_PV6,        RSVD0,      RSVD1,  RSVD2, RSVD3),
158	PIN(TOUCH_CLK_PV7,        TOUCH,      RSVD1,  RSVD2, RSVD3),
159	PIN(MODEM_WAKE_AP_PX0,    RSVD0,      RSVD1,  RSVD2, RSVD3),
160	PIN(TOUCH_INT_PX1,        RSVD0,      RSVD1,  RSVD2, RSVD3),
161	PIN(MOTION_INT_PX2,       RSVD0,      RSVD1,  RSVD2, RSVD3),
162	PIN(ALS_PROX_INT_PX3,     RSVD0,      RSVD1,  RSVD2, RSVD3),
163	PIN(TEMP_ALERT_PX4,       RSVD0,      RSVD1,  RSVD2, RSVD3),
164	PIN(BUTTON_POWER_ON_PX5,  RSVD0,      RSVD1,  RSVD2, RSVD3),
165	PIN(BUTTON_VOL_UP_PX6,    RSVD0,      RSVD1,  RSVD2, RSVD3),
166	PIN(BUTTON_VOL_DOWN_PX7,  RSVD0,      RSVD1,  RSVD2, RSVD3),
167	PIN(BUTTON_SLIDE_SW_PY0,  RSVD0,      RSVD1,  RSVD2, RSVD3),
168	PIN(BUTTON_HOME_PY1,      RSVD0,      RSVD1,  RSVD2, RSVD3),
169	PIN(PA6,                  SATA,       RSVD1,  RSVD2, RSVD3),
170	PIN(PE6,                  RSVD0,      I2S5A,  PWM2,  RSVD3),
171	PIN(PE7,                  RSVD0,      I2S5A,  PWM3,  RSVD3),
172	PIN(PH6,                  RSVD0,      RSVD1,  RSVD2, RSVD3),
173	PIN(PK0,                  IQC0,       I2S5B,  RSVD2, RSVD3),
174	PIN(PK1,                  IQC0,       I2S5B,  RSVD2, RSVD3),
175	PIN(PK2,                  IQC0,       I2S5B,  RSVD2, RSVD3),
176	PIN(PK3,                  IQC0,       I2S5B,  RSVD2, RSVD3),
177	PIN(PK4,                  IQC1,       RSVD1,  RSVD2, RSVD3),
178	PIN(PK5,                  IQC1,       RSVD1,  RSVD2, RSVD3),
179	PIN(PK6,                  IQC1,       RSVD1,  RSVD2, RSVD3),
180	PIN(PK7,                  IQC1,       RSVD1,  RSVD2, RSVD3),
181	PIN(PL0,                  RSVD0,      RSVD1,  RSVD2, RSVD3),
182	PIN(PL1,                  SOC,        RSVD1,  RSVD2, RSVD3),
183	PIN(PZ0,                  VIMCLK2,    RSVD1,  RSVD2, RSVD3),
184	PIN(PZ1,                  VIMCLK2,    SDMMC1, RSVD2, RSVD3),
185	PIN(PZ2,                  SDMMC3,     CCLA,   RSVD2, RSVD3),
186	PIN(PZ3,                  SDMMC3,     RSVD1,  RSVD2, RSVD3),
187	PIN(PZ4,                  SDMMC1,     RSVD1,  RSVD2, RSVD3),
188	PIN(PZ5,                  SOC,        RSVD1,  RSVD2, RSVD3),
189};
190const struct pmux_pingrp_desc *tegra_soc_pingroups = tegra210_pingroups;
191