blob: 328a3e3224d544e8289941ff7574313a87c65fcc [file] [log] [blame]
Tom Warren41b68382011-01-27 10:58:05 +00001/*
2 * (C) Copyright 2010,2011
3 * NVIDIA Corporation <www.nvidia.com>
4 *
Wolfgang Denkd79de1d2013-07-08 09:37:19 +02005 * SPDX-License-Identifier: GPL-2.0+
Tom Warren41b68382011-01-27 10:58:05 +00006 */
7
Stephen Warren9026dfd2014-03-21 12:28:54 -06008#ifndef _TEGRA20_PINMUX_H_
9#define _TEGRA20_PINMUX_H_
Tom Warren41b68382011-01-27 10:58:05 +000010
Simon Glassb70bbf12011-09-21 12:40:06 +000011/*
12 * Pin groups which we adjust. There are three basic attributes of each pin
13 * group which use this enum:
14 *
15 * - function
16 * - pullup / pulldown
17 * - tristate or normal
18 */
Simon Glass80608ed2011-09-21 12:40:05 +000019enum pmux_pingrp {
Simon Glassfa516f62011-08-30 06:23:14 +000020 /* APB_MISC_PP_TRISTATE_REG_A_0 */
Simon Glass80608ed2011-09-21 12:40:05 +000021 PINGRP_ATA,
22 PINGRP_ATB,
23 PINGRP_ATC,
24 PINGRP_ATD,
25 PINGRP_CDEV1,
26 PINGRP_CDEV2,
27 PINGRP_CSUS,
28 PINGRP_DAP1,
Simon Glassfa516f62011-08-30 06:23:14 +000029
Simon Glass80608ed2011-09-21 12:40:05 +000030 PINGRP_DAP2,
31 PINGRP_DAP3,
32 PINGRP_DAP4,
33 PINGRP_DTA,
34 PINGRP_DTB,
35 PINGRP_DTC,
36 PINGRP_DTD,
37 PINGRP_DTE,
Simon Glassfa516f62011-08-30 06:23:14 +000038
Simon Glass80608ed2011-09-21 12:40:05 +000039 PINGRP_GPU,
40 PINGRP_GPV,
41 PINGRP_I2CP,
42 PINGRP_IRTX,
43 PINGRP_IRRX,
44 PINGRP_KBCB,
45 PINGRP_KBCA,
46 PINGRP_PMC,
Simon Glassfa516f62011-08-30 06:23:14 +000047
Simon Glass80608ed2011-09-21 12:40:05 +000048 PINGRP_PTA,
49 PINGRP_RM,
50 PINGRP_KBCE,
51 PINGRP_KBCF,
52 PINGRP_GMA,
53 PINGRP_GMC,
Lucas Stach2249fb62012-05-16 08:21:01 +000054 PINGRP_SDIO1,
Simon Glass80608ed2011-09-21 12:40:05 +000055 PINGRP_OWC,
Simon Glassfa516f62011-08-30 06:23:14 +000056
57 /* 32: APB_MISC_PP_TRISTATE_REG_B_0 */
Simon Glass80608ed2011-09-21 12:40:05 +000058 PINGRP_GME,
59 PINGRP_SDC,
60 PINGRP_SDD,
61 PINGRP_RESERVED0,
62 PINGRP_SLXA,
63 PINGRP_SLXC,
64 PINGRP_SLXD,
65 PINGRP_SLXK,
Simon Glassfa516f62011-08-30 06:23:14 +000066
Simon Glass80608ed2011-09-21 12:40:05 +000067 PINGRP_SPDI,
68 PINGRP_SPDO,
69 PINGRP_SPIA,
70 PINGRP_SPIB,
71 PINGRP_SPIC,
72 PINGRP_SPID,
73 PINGRP_SPIE,
74 PINGRP_SPIF,
Simon Glassfa516f62011-08-30 06:23:14 +000075
Simon Glass80608ed2011-09-21 12:40:05 +000076 PINGRP_SPIG,
77 PINGRP_SPIH,
78 PINGRP_UAA,
79 PINGRP_UAB,
80 PINGRP_UAC,
81 PINGRP_UAD,
82 PINGRP_UCA,
83 PINGRP_UCB,
Simon Glassfa516f62011-08-30 06:23:14 +000084
Simon Glass80608ed2011-09-21 12:40:05 +000085 PINGRP_RESERVED1,
86 PINGRP_ATE,
87 PINGRP_KBCC,
88 PINGRP_RESERVED2,
89 PINGRP_RESERVED3,
90 PINGRP_GMB,
91 PINGRP_GMD,
92 PINGRP_DDC,
Simon Glassfa516f62011-08-30 06:23:14 +000093
94 /* 64: APB_MISC_PP_TRISTATE_REG_C_0 */
Simon Glass80608ed2011-09-21 12:40:05 +000095 PINGRP_LD0,
96 PINGRP_LD1,
97 PINGRP_LD2,
98 PINGRP_LD3,
99 PINGRP_LD4,
100 PINGRP_LD5,
101 PINGRP_LD6,
102 PINGRP_LD7,
Simon Glassfa516f62011-08-30 06:23:14 +0000103
Simon Glass80608ed2011-09-21 12:40:05 +0000104 PINGRP_LD8,
105 PINGRP_LD9,
106 PINGRP_LD10,
107 PINGRP_LD11,
108 PINGRP_LD12,
109 PINGRP_LD13,
110 PINGRP_LD14,
111 PINGRP_LD15,
Simon Glassfa516f62011-08-30 06:23:14 +0000112
Simon Glass80608ed2011-09-21 12:40:05 +0000113 PINGRP_LD16,
114 PINGRP_LD17,
115 PINGRP_LHP0,
116 PINGRP_LHP1,
117 PINGRP_LHP2,
118 PINGRP_LVP0,
119 PINGRP_LVP1,
120 PINGRP_HDINT,
Simon Glassfa516f62011-08-30 06:23:14 +0000121
Simon Glass80608ed2011-09-21 12:40:05 +0000122 PINGRP_LM0,
123 PINGRP_LM1,
124 PINGRP_LVS,
125 PINGRP_LSC0,
126 PINGRP_LSC1,
127 PINGRP_LSCK,
128 PINGRP_LDC,
129 PINGRP_LCSN,
Simon Glassfa516f62011-08-30 06:23:14 +0000130
131 /* 96: APB_MISC_PP_TRISTATE_REG_D_0 */
Simon Glass80608ed2011-09-21 12:40:05 +0000132 PINGRP_LSPI,
133 PINGRP_LSDA,
134 PINGRP_LSDI,
135 PINGRP_LPW0,
136 PINGRP_LPW1,
137 PINGRP_LPW2,
138 PINGRP_LDI,
139 PINGRP_LHS,
Simon Glassfa516f62011-08-30 06:23:14 +0000140
Simon Glass80608ed2011-09-21 12:40:05 +0000141 PINGRP_LPP,
142 PINGRP_RESERVED4,
143 PINGRP_KBCD,
144 PINGRP_GPU7,
145 PINGRP_DTF,
146 PINGRP_UDA,
147 PINGRP_CRTP,
148 PINGRP_SDB,
Simon Glassb70bbf12011-09-21 12:40:06 +0000149
150 /* these pin groups only have pullup and pull down control */
151 PINGRP_FIRST_NO_MUX,
152 PINGRP_CK32 = PINGRP_FIRST_NO_MUX,
153 PINGRP_DDRC,
154 PINGRP_PMCA,
155 PINGRP_PMCB,
156 PINGRP_PMCC,
157 PINGRP_PMCD,
158 PINGRP_PMCE,
159 PINGRP_XM2C,
160 PINGRP_XM2D,
161
Stephen Warrenf4df6052014-03-21 12:28:56 -0600162 PMUX_PINGRP_COUNT,
Simon Glassb70bbf12011-09-21 12:40:06 +0000163};
164
165/*
166 * Functions which can be assigned to each of the pin groups. The values here
167 * bear no relation to the values programmed into pinmux registers and are
168 * purely a convenience. The translation is done through a table search.
169 */
170enum pmux_func {
171 PMUX_FUNC_AHB_CLK,
172 PMUX_FUNC_APB_CLK,
173 PMUX_FUNC_AUDIO_SYNC,
174 PMUX_FUNC_CRT,
175 PMUX_FUNC_DAP1,
176 PMUX_FUNC_DAP2,
177 PMUX_FUNC_DAP3,
178 PMUX_FUNC_DAP4,
179 PMUX_FUNC_DAP5,
180 PMUX_FUNC_DISPA,
181 PMUX_FUNC_DISPB,
182 PMUX_FUNC_EMC_TEST0_DLL,
183 PMUX_FUNC_EMC_TEST1_DLL,
184 PMUX_FUNC_GMI,
185 PMUX_FUNC_GMI_INT,
186 PMUX_FUNC_HDMI,
187 PMUX_FUNC_I2C,
188 PMUX_FUNC_I2C2,
189 PMUX_FUNC_I2C3,
190 PMUX_FUNC_IDE,
Simon Glassb70bbf12011-09-21 12:40:06 +0000191 PMUX_FUNC_KBC,
192 PMUX_FUNC_MIO,
193 PMUX_FUNC_MIPI_HS,
194 PMUX_FUNC_NAND,
195 PMUX_FUNC_OSC,
196 PMUX_FUNC_OWR,
197 PMUX_FUNC_PCIE,
198 PMUX_FUNC_PLLA_OUT,
199 PMUX_FUNC_PLLC_OUT1,
200 PMUX_FUNC_PLLM_OUT1,
201 PMUX_FUNC_PLLP_OUT2,
202 PMUX_FUNC_PLLP_OUT3,
203 PMUX_FUNC_PLLP_OUT4,
204 PMUX_FUNC_PWM,
205 PMUX_FUNC_PWR_INTR,
206 PMUX_FUNC_PWR_ON,
207 PMUX_FUNC_RTCK,
208 PMUX_FUNC_SDIO1,
209 PMUX_FUNC_SDIO2,
210 PMUX_FUNC_SDIO3,
211 PMUX_FUNC_SDIO4,
212 PMUX_FUNC_SFLASH,
213 PMUX_FUNC_SPDIF,
214 PMUX_FUNC_SPI1,
215 PMUX_FUNC_SPI2,
216 PMUX_FUNC_SPI2_ALT,
217 PMUX_FUNC_SPI3,
218 PMUX_FUNC_SPI4,
219 PMUX_FUNC_TRACE,
220 PMUX_FUNC_TWC,
221 PMUX_FUNC_UARTA,
222 PMUX_FUNC_UARTB,
223 PMUX_FUNC_UARTC,
224 PMUX_FUNC_UARTD,
225 PMUX_FUNC_UARTE,
226 PMUX_FUNC_ULPI,
227 PMUX_FUNC_VI,
228 PMUX_FUNC_VI_SENSOR_CLK,
229 PMUX_FUNC_XIO,
Simon Glassb70bbf12011-09-21 12:40:06 +0000230
Simon Glassb70bbf12011-09-21 12:40:06 +0000231 PMUX_FUNC_COUNT,
232
Stephen Warren8569b3a2014-03-21 12:28:51 -0600233 PMUX_FUNC_RSVD1 = 0x8000,
234 PMUX_FUNC_RSVD2 = 0x8001,
235 PMUX_FUNC_RSVD3 = 0x8002,
236 PMUX_FUNC_RSVD4 = 0x8003,
Simon Glassb70bbf12011-09-21 12:40:06 +0000237};
238
Stephen Warren9026dfd2014-03-21 12:28:54 -0600239#include <asm/arch-tegra/pinmux.h>
Simon Glassb70bbf12011-09-21 12:40:06 +0000240
Stephen Warren9026dfd2014-03-21 12:28:54 -0600241#endif /* _TEGRA20_PINMUX_H_ */