xref: /openbmc/linux/drivers/gpu/drm/tegra/hdmi.h (revision 76426e23)
1 /* SPDX-License-Identifier: GPL-2.0-only */
2 /*
3  * Copyright (C) 2012 Avionic Design GmbH
4  * Copyright (C) 2012 NVIDIA CORPORATION.  All rights reserved.
5  */
6 
7 #ifndef TEGRA_HDMI_H
8 #define TEGRA_HDMI_H 1
9 
10 /* register definitions */
11 #define HDMI_CTXSW						0x00
12 
13 #define HDMI_NV_PDISP_SOR_STATE0				0x01
14 #define SOR_STATE_UPDATE (1 << 0)
15 
16 #define HDMI_NV_PDISP_SOR_STATE1				0x02
17 #define SOR_STATE_ASY_HEAD_OPMODE_AWAKE (2 << 0)
18 #define SOR_STATE_ASY_ORMODE_NORMAL     (1 << 2)
19 #define SOR_STATE_ATTACHED              (1 << 3)
20 
21 #define HDMI_NV_PDISP_SOR_STATE2				0x03
22 #define SOR_STATE_ASY_OWNER_NONE         (0 <<  0)
23 #define SOR_STATE_ASY_OWNER_HEAD0        (1 <<  0)
24 #define SOR_STATE_ASY_SUBOWNER_NONE      (0 <<  4)
25 #define SOR_STATE_ASY_SUBOWNER_SUBHEAD0  (1 <<  4)
26 #define SOR_STATE_ASY_SUBOWNER_SUBHEAD1  (2 <<  4)
27 #define SOR_STATE_ASY_SUBOWNER_BOTH      (3 <<  4)
28 #define SOR_STATE_ASY_CRCMODE_ACTIVE     (0 <<  6)
29 #define SOR_STATE_ASY_CRCMODE_COMPLETE   (1 <<  6)
30 #define SOR_STATE_ASY_CRCMODE_NON_ACTIVE (2 <<  6)
31 #define SOR_STATE_ASY_PROTOCOL_SINGLE_TMDS_A (1 << 8)
32 #define SOR_STATE_ASY_PROTOCOL_CUSTOM        (15 << 8)
33 #define SOR_STATE_ASY_HSYNCPOL_POS       (0 << 12)
34 #define SOR_STATE_ASY_HSYNCPOL_NEG       (1 << 12)
35 #define SOR_STATE_ASY_VSYNCPOL_POS       (0 << 13)
36 #define SOR_STATE_ASY_VSYNCPOL_NEG       (1 << 13)
37 #define SOR_STATE_ASY_DEPOL_POS          (0 << 14)
38 #define SOR_STATE_ASY_DEPOL_NEG          (1 << 14)
39 
40 #define HDMI_NV_PDISP_RG_HDCP_AN_MSB				0x04
41 #define HDMI_NV_PDISP_RG_HDCP_AN_LSB				0x05
42 #define HDMI_NV_PDISP_RG_HDCP_CN_MSB				0x06
43 #define HDMI_NV_PDISP_RG_HDCP_CN_LSB				0x07
44 #define HDMI_NV_PDISP_RG_HDCP_AKSV_MSB				0x08
45 #define HDMI_NV_PDISP_RG_HDCP_AKSV_LSB				0x09
46 #define HDMI_NV_PDISP_RG_HDCP_BKSV_MSB				0x0a
47 #define HDMI_NV_PDISP_RG_HDCP_BKSV_LSB				0x0b
48 #define HDMI_NV_PDISP_RG_HDCP_CKSV_MSB				0x0c
49 #define HDMI_NV_PDISP_RG_HDCP_CKSV_LSB				0x0d
50 #define HDMI_NV_PDISP_RG_HDCP_DKSV_MSB				0x0e
51 #define HDMI_NV_PDISP_RG_HDCP_DKSV_LSB				0x0f
52 #define HDMI_NV_PDISP_RG_HDCP_CTRL				0x10
53 #define HDMI_NV_PDISP_RG_HDCP_CMODE				0x11
54 #define HDMI_NV_PDISP_RG_HDCP_MPRIME_MSB			0x12
55 #define HDMI_NV_PDISP_RG_HDCP_MPRIME_LSB			0x13
56 #define HDMI_NV_PDISP_RG_HDCP_SPRIME_MSB			0x14
57 #define HDMI_NV_PDISP_RG_HDCP_SPRIME_LSB2			0x15
58 #define HDMI_NV_PDISP_RG_HDCP_SPRIME_LSB1			0x16
59 #define HDMI_NV_PDISP_RG_HDCP_RI				0x17
60 #define HDMI_NV_PDISP_RG_HDCP_CS_MSB				0x18
61 #define HDMI_NV_PDISP_RG_HDCP_CS_LSB				0x19
62 #define HDMI_NV_PDISP_HDMI_AUDIO_EMU0				0x1a
63 #define HDMI_NV_PDISP_HDMI_AUDIO_EMU_RDATA0			0x1b
64 #define HDMI_NV_PDISP_HDMI_AUDIO_EMU1				0x1c
65 #define HDMI_NV_PDISP_HDMI_AUDIO_EMU2				0x1d
66 
67 #define HDMI_NV_PDISP_HDMI_AUDIO_INFOFRAME_CTRL			0x1e
68 #define HDMI_NV_PDISP_HDMI_AUDIO_INFOFRAME_STATUS		0x1f
69 #define HDMI_NV_PDISP_HDMI_AUDIO_INFOFRAME_HEADER		0x20
70 #define HDMI_NV_PDISP_HDMI_AUDIO_INFOFRAME_SUBPACK0_LOW		0x21
71 #define HDMI_NV_PDISP_HDMI_AUDIO_INFOFRAME_SUBPACK0_HIGH	0x22
72 #define HDMI_NV_PDISP_HDMI_AVI_INFOFRAME_CTRL			0x23
73 #define HDMI_NV_PDISP_HDMI_AVI_INFOFRAME_STATUS			0x24
74 #define HDMI_NV_PDISP_HDMI_AVI_INFOFRAME_HEADER			0x25
75 #define HDMI_NV_PDISP_HDMI_AVI_INFOFRAME_SUBPACK0_LOW		0x26
76 #define HDMI_NV_PDISP_HDMI_AVI_INFOFRAME_SUBPACK0_HIGH		0x27
77 #define HDMI_NV_PDISP_HDMI_AVI_INFOFRAME_SUBPACK1_LOW		0x28
78 #define HDMI_NV_PDISP_HDMI_AVI_INFOFRAME_SUBPACK1_HIGH		0x29
79 
80 #define INFOFRAME_CTRL_ENABLE (1 << 0)
81 
82 #define INFOFRAME_HEADER_TYPE(x)    (((x) & 0xff) <<  0)
83 #define INFOFRAME_HEADER_VERSION(x) (((x) & 0xff) <<  8)
84 #define INFOFRAME_HEADER_LEN(x)     (((x) & 0x0f) << 16)
85 
86 #define HDMI_NV_PDISP_HDMI_GENERIC_CTRL				0x2a
87 #define GENERIC_CTRL_ENABLE (1 <<  0)
88 #define GENERIC_CTRL_OTHER  (1 <<  4)
89 #define GENERIC_CTRL_SINGLE (1 <<  8)
90 #define GENERIC_CTRL_HBLANK (1 << 12)
91 #define GENERIC_CTRL_AUDIO  (1 << 16)
92 
93 #define HDMI_NV_PDISP_HDMI_GENERIC_STATUS			0x2b
94 #define HDMI_NV_PDISP_HDMI_GENERIC_HEADER			0x2c
95 #define HDMI_NV_PDISP_HDMI_GENERIC_SUBPACK0_LOW			0x2d
96 #define HDMI_NV_PDISP_HDMI_GENERIC_SUBPACK0_HIGH		0x2e
97 #define HDMI_NV_PDISP_HDMI_GENERIC_SUBPACK1_LOW			0x2f
98 #define HDMI_NV_PDISP_HDMI_GENERIC_SUBPACK1_HIGH		0x30
99 #define HDMI_NV_PDISP_HDMI_GENERIC_SUBPACK2_LOW			0x31
100 #define HDMI_NV_PDISP_HDMI_GENERIC_SUBPACK2_HIGH		0x32
101 #define HDMI_NV_PDISP_HDMI_GENERIC_SUBPACK3_LOW			0x33
102 #define HDMI_NV_PDISP_HDMI_GENERIC_SUBPACK3_HIGH		0x34
103 
104 #define HDMI_NV_PDISP_HDMI_ACR_CTRL				0x35
105 #define HDMI_NV_PDISP_HDMI_ACR_0320_SUBPACK_LOW			0x36
106 #define HDMI_NV_PDISP_HDMI_ACR_0320_SUBPACK_HIGH		0x37
107 #define HDMI_NV_PDISP_HDMI_ACR_0441_SUBPACK_LOW			0x38
108 #define HDMI_NV_PDISP_HDMI_ACR_0441_SUBPACK_HIGH		0x39
109 #define HDMI_NV_PDISP_HDMI_ACR_0882_SUBPACK_LOW			0x3a
110 #define HDMI_NV_PDISP_HDMI_ACR_0882_SUBPACK_HIGH		0x3b
111 #define HDMI_NV_PDISP_HDMI_ACR_1764_SUBPACK_LOW			0x3c
112 #define HDMI_NV_PDISP_HDMI_ACR_1764_SUBPACK_HIGH		0x3d
113 #define HDMI_NV_PDISP_HDMI_ACR_0480_SUBPACK_LOW			0x3e
114 #define HDMI_NV_PDISP_HDMI_ACR_0480_SUBPACK_HIGH		0x3f
115 #define HDMI_NV_PDISP_HDMI_ACR_0960_SUBPACK_LOW			0x40
116 #define HDMI_NV_PDISP_HDMI_ACR_0960_SUBPACK_HIGH		0x41
117 #define HDMI_NV_PDISP_HDMI_ACR_1920_SUBPACK_LOW			0x42
118 #define HDMI_NV_PDISP_HDMI_ACR_1920_SUBPACK_HIGH		0x43
119 
120 #define ACR_SUBPACK_CTS(x) (((x) & 0xffffff) << 8)
121 #define ACR_SUBPACK_N(x)   (((x) & 0xffffff) << 0)
122 #define ACR_ENABLE         (1 << 31)
123 
124 #define HDMI_NV_PDISP_HDMI_CTRL					0x44
125 #define HDMI_CTRL_REKEY(x)         (((x) & 0x7f) <<  0)
126 #define HDMI_CTRL_MAX_AC_PACKET(x) (((x) & 0x1f) << 16)
127 #define HDMI_CTRL_ENABLE           (1 << 30)
128 
129 #define HDMI_NV_PDISP_HDMI_VSYNC_KEEPOUT			0x45
130 #define HDMI_NV_PDISP_HDMI_VSYNC_WINDOW				0x46
131 #define VSYNC_WINDOW_END(x)   (((x) & 0x3ff) <<  0)
132 #define VSYNC_WINDOW_START(x) (((x) & 0x3ff) << 16)
133 #define VSYNC_WINDOW_ENABLE   (1 << 31)
134 
135 #define HDMI_NV_PDISP_HDMI_GCP_CTRL				0x47
136 #define HDMI_NV_PDISP_HDMI_GCP_STATUS				0x48
137 #define HDMI_NV_PDISP_HDMI_GCP_SUBPACK				0x49
138 #define HDMI_NV_PDISP_HDMI_CHANNEL_STATUS1			0x4a
139 #define HDMI_NV_PDISP_HDMI_CHANNEL_STATUS2			0x4b
140 #define HDMI_NV_PDISP_HDMI_EMU0					0x4c
141 #define HDMI_NV_PDISP_HDMI_EMU1					0x4d
142 #define HDMI_NV_PDISP_HDMI_EMU1_RDATA				0x4e
143 
144 #define HDMI_NV_PDISP_HDMI_SPARE				0x4f
145 #define SPARE_HW_CTS           (1 << 0)
146 #define SPARE_FORCE_SW_CTS     (1 << 1)
147 #define SPARE_CTS_RESET_VAL(x) (((x) & 0x7) << 16)
148 
149 #define HDMI_NV_PDISP_HDMI_SPDIF_CHN_STATUS1			0x50
150 #define HDMI_NV_PDISP_HDMI_SPDIF_CHN_STATUS2			0x51
151 #define HDMI_NV_PDISP_HDMI_HDCPRIF_ROM_CTRL			0x53
152 #define HDMI_NV_PDISP_SOR_CAP					0x54
153 #define HDMI_NV_PDISP_SOR_PWR					0x55
154 #define SOR_PWR_NORMAL_STATE_PD     (0 <<  0)
155 #define SOR_PWR_NORMAL_STATE_PU     (1 <<  0)
156 #define SOR_PWR_NORMAL_START_NORMAL (0 <<  1)
157 #define SOR_PWR_NORMAL_START_ALT    (1 <<  1)
158 #define SOR_PWR_SAFE_STATE_PD       (0 << 16)
159 #define SOR_PWR_SAFE_STATE_PU       (1 << 16)
160 #define SOR_PWR_SETTING_NEW_DONE    (0 << 31)
161 #define SOR_PWR_SETTING_NEW_PENDING (1 << 31)
162 #define SOR_PWR_SETTING_NEW_TRIGGER (1 << 31)
163 
164 #define HDMI_NV_PDISP_SOR_TEST					0x56
165 #define HDMI_NV_PDISP_SOR_PLL0					0x57
166 #define SOR_PLL_PWR            (1 << 0)
167 #define SOR_PLL_PDBG           (1 << 1)
168 #define SOR_PLL_VCAPD          (1 << 2)
169 #define SOR_PLL_PDPORT         (1 << 3)
170 #define SOR_PLL_RESISTORSEL    (1 << 4)
171 #define SOR_PLL_PULLDOWN       (1 << 5)
172 #define SOR_PLL_VCOCAP(x)      (((x) & 0xf) <<  8)
173 #define SOR_PLL_BG_V17_S(x)    (((x) & 0xf) << 12)
174 #define SOR_PLL_FILTER(x)      (((x) & 0xf) << 16)
175 #define SOR_PLL_ICHPMP(x)      (((x) & 0xf) << 24)
176 #define SOR_PLL_TX_REG_LOAD(x) (((x) & 0xf) << 28)
177 
178 #define HDMI_NV_PDISP_SOR_PLL1					0x58
179 #define SOR_PLL_TMDS_TERM_ENABLE (1 << 8)
180 #define SOR_PLL_TMDS_TERMADJ(x)  (((x) & 0xf) <<  9)
181 #define SOR_PLL_LOADADJ(x)       (((x) & 0xf) << 20)
182 #define SOR_PLL_PE_EN            (1 << 28)
183 #define SOR_PLL_HALF_FULL_PE     (1 << 29)
184 #define SOR_PLL_S_D_PIN_PE       (1 << 30)
185 
186 #define HDMI_NV_PDISP_SOR_PLL2					0x59
187 
188 #define HDMI_NV_PDISP_SOR_CSTM					0x5a
189 #define SOR_CSTM_ROTCLK(x) (((x) & 0xf) << 24)
190 #define SOR_CSTM_PLLDIV (1 << 21)
191 #define SOR_CSTM_LVDS_ENABLE (1 << 16)
192 #define SOR_CSTM_MODE_LVDS (0 << 12)
193 #define SOR_CSTM_MODE_TMDS (1 << 12)
194 #define SOR_CSTM_MODE_MASK (3 << 12)
195 
196 #define HDMI_NV_PDISP_SOR_LVDS					0x5b
197 #define HDMI_NV_PDISP_SOR_CRCA					0x5c
198 #define HDMI_NV_PDISP_SOR_CRCB					0x5d
199 #define HDMI_NV_PDISP_SOR_BLANK					0x5e
200 #define HDMI_NV_PDISP_SOR_SEQ_CTL				0x5f
201 #define SOR_SEQ_PU_PC(x)     (((x) & 0xf) <<  0)
202 #define SOR_SEQ_PU_PC_ALT(x) (((x) & 0xf) <<  4)
203 #define SOR_SEQ_PD_PC(x)     (((x) & 0xf) <<  8)
204 #define SOR_SEQ_PD_PC_ALT(x) (((x) & 0xf) << 12)
205 #define SOR_SEQ_PC(x)        (((x) & 0xf) << 16)
206 #define SOR_SEQ_STATUS       (1 << 28)
207 #define SOR_SEQ_SWITCH       (1 << 30)
208 
209 #define HDMI_NV_PDISP_SOR_SEQ_INST(x)				(0x60 + (x))
210 
211 #define SOR_SEQ_INST_WAIT_TIME(x)     (((x) & 0x3ff) << 0)
212 #define SOR_SEQ_INST_WAIT_UNITS_VSYNC (2 << 12)
213 #define SOR_SEQ_INST_HALT             (1 << 15)
214 #define SOR_SEQ_INST_PIN_A_LOW        (0 << 21)
215 #define SOR_SEQ_INST_PIN_A_HIGH       (1 << 21)
216 #define SOR_SEQ_INST_PIN_B_LOW        (0 << 22)
217 #define SOR_SEQ_INST_PIN_B_HIGH       (1 << 22)
218 #define SOR_SEQ_INST_DRIVE_PWM_OUT_LO (1 << 23)
219 
220 #define HDMI_NV_PDISP_SOR_VCRCA0				0x72
221 #define HDMI_NV_PDISP_SOR_VCRCA1				0x73
222 #define HDMI_NV_PDISP_SOR_CCRCA0				0x74
223 #define HDMI_NV_PDISP_SOR_CCRCA1				0x75
224 #define HDMI_NV_PDISP_SOR_EDATAA0				0x76
225 #define HDMI_NV_PDISP_SOR_EDATAA1				0x77
226 #define HDMI_NV_PDISP_SOR_COUNTA0				0x78
227 #define HDMI_NV_PDISP_SOR_COUNTA1				0x79
228 #define HDMI_NV_PDISP_SOR_DEBUGA0				0x7a
229 #define HDMI_NV_PDISP_SOR_DEBUGA1				0x7b
230 #define HDMI_NV_PDISP_SOR_TRIG					0x7c
231 #define HDMI_NV_PDISP_SOR_MSCHECK				0x7d
232 
233 #define HDMI_NV_PDISP_SOR_LANE_DRIVE_CURRENT			0x7e
234 #define DRIVE_CURRENT_LANE0(x)      (((x) & 0x3f) <<  0)
235 #define DRIVE_CURRENT_LANE1(x)      (((x) & 0x3f) <<  8)
236 #define DRIVE_CURRENT_LANE2(x)      (((x) & 0x3f) << 16)
237 #define DRIVE_CURRENT_LANE3(x)      (((x) & 0x3f) << 24)
238 #define DRIVE_CURRENT_LANE0_T114(x) (((x) & 0x7f) <<  0)
239 #define DRIVE_CURRENT_LANE1_T114(x) (((x) & 0x7f) <<  8)
240 #define DRIVE_CURRENT_LANE2_T114(x) (((x) & 0x7f) << 16)
241 #define DRIVE_CURRENT_LANE3_T114(x) (((x) & 0x7f) << 24)
242 
243 #define DRIVE_CURRENT_1_500_mA  0x00
244 #define DRIVE_CURRENT_1_875_mA  0x01
245 #define DRIVE_CURRENT_2_250_mA  0x02
246 #define DRIVE_CURRENT_2_625_mA  0x03
247 #define DRIVE_CURRENT_3_000_mA  0x04
248 #define DRIVE_CURRENT_3_375_mA  0x05
249 #define DRIVE_CURRENT_3_750_mA  0x06
250 #define DRIVE_CURRENT_4_125_mA  0x07
251 #define DRIVE_CURRENT_4_500_mA  0x08
252 #define DRIVE_CURRENT_4_875_mA  0x09
253 #define DRIVE_CURRENT_5_250_mA  0x0a
254 #define DRIVE_CURRENT_5_625_mA  0x0b
255 #define DRIVE_CURRENT_6_000_mA  0x0c
256 #define DRIVE_CURRENT_6_375_mA  0x0d
257 #define DRIVE_CURRENT_6_750_mA  0x0e
258 #define DRIVE_CURRENT_7_125_mA  0x0f
259 #define DRIVE_CURRENT_7_500_mA  0x10
260 #define DRIVE_CURRENT_7_875_mA  0x11
261 #define DRIVE_CURRENT_8_250_mA  0x12
262 #define DRIVE_CURRENT_8_625_mA  0x13
263 #define DRIVE_CURRENT_9_000_mA  0x14
264 #define DRIVE_CURRENT_9_375_mA  0x15
265 #define DRIVE_CURRENT_9_750_mA  0x16
266 #define DRIVE_CURRENT_10_125_mA 0x17
267 #define DRIVE_CURRENT_10_500_mA 0x18
268 #define DRIVE_CURRENT_10_875_mA 0x19
269 #define DRIVE_CURRENT_11_250_mA 0x1a
270 #define DRIVE_CURRENT_11_625_mA 0x1b
271 #define DRIVE_CURRENT_12_000_mA 0x1c
272 #define DRIVE_CURRENT_12_375_mA 0x1d
273 #define DRIVE_CURRENT_12_750_mA 0x1e
274 #define DRIVE_CURRENT_13_125_mA 0x1f
275 #define DRIVE_CURRENT_13_500_mA 0x20
276 #define DRIVE_CURRENT_13_875_mA 0x21
277 #define DRIVE_CURRENT_14_250_mA 0x22
278 #define DRIVE_CURRENT_14_625_mA 0x23
279 #define DRIVE_CURRENT_15_000_mA 0x24
280 #define DRIVE_CURRENT_15_375_mA 0x25
281 #define DRIVE_CURRENT_15_750_mA 0x26
282 #define DRIVE_CURRENT_16_125_mA 0x27
283 #define DRIVE_CURRENT_16_500_mA 0x28
284 #define DRIVE_CURRENT_16_875_mA 0x29
285 #define DRIVE_CURRENT_17_250_mA 0x2a
286 #define DRIVE_CURRENT_17_625_mA 0x2b
287 #define DRIVE_CURRENT_18_000_mA 0x2c
288 #define DRIVE_CURRENT_18_375_mA 0x2d
289 #define DRIVE_CURRENT_18_750_mA 0x2e
290 #define DRIVE_CURRENT_19_125_mA 0x2f
291 #define DRIVE_CURRENT_19_500_mA 0x30
292 #define DRIVE_CURRENT_19_875_mA 0x31
293 #define DRIVE_CURRENT_20_250_mA 0x32
294 #define DRIVE_CURRENT_20_625_mA 0x33
295 #define DRIVE_CURRENT_21_000_mA 0x34
296 #define DRIVE_CURRENT_21_375_mA 0x35
297 #define DRIVE_CURRENT_21_750_mA 0x36
298 #define DRIVE_CURRENT_22_125_mA 0x37
299 #define DRIVE_CURRENT_22_500_mA 0x38
300 #define DRIVE_CURRENT_22_875_mA 0x39
301 #define DRIVE_CURRENT_23_250_mA 0x3a
302 #define DRIVE_CURRENT_23_625_mA 0x3b
303 #define DRIVE_CURRENT_24_000_mA 0x3c
304 #define DRIVE_CURRENT_24_375_mA 0x3d
305 #define DRIVE_CURRENT_24_750_mA 0x3e
306 
307 #define DRIVE_CURRENT_0_000_mA_T114 0x00
308 #define DRIVE_CURRENT_0_400_mA_T114 0x01
309 #define DRIVE_CURRENT_0_800_mA_T114 0x02
310 #define DRIVE_CURRENT_1_200_mA_T114 0x03
311 #define DRIVE_CURRENT_1_600_mA_T114 0x04
312 #define DRIVE_CURRENT_2_000_mA_T114 0x05
313 #define DRIVE_CURRENT_2_400_mA_T114 0x06
314 #define DRIVE_CURRENT_2_800_mA_T114 0x07
315 #define DRIVE_CURRENT_3_200_mA_T114 0x08
316 #define DRIVE_CURRENT_3_600_mA_T114 0x09
317 #define DRIVE_CURRENT_4_000_mA_T114 0x0a
318 #define DRIVE_CURRENT_4_400_mA_T114 0x0b
319 #define DRIVE_CURRENT_4_800_mA_T114 0x0c
320 #define DRIVE_CURRENT_5_200_mA_T114 0x0d
321 #define DRIVE_CURRENT_5_600_mA_T114 0x0e
322 #define DRIVE_CURRENT_6_000_mA_T114 0x0f
323 #define DRIVE_CURRENT_6_400_mA_T114 0x10
324 #define DRIVE_CURRENT_6_800_mA_T114 0x11
325 #define DRIVE_CURRENT_7_200_mA_T114 0x12
326 #define DRIVE_CURRENT_7_600_mA_T114 0x13
327 #define DRIVE_CURRENT_8_000_mA_T114 0x14
328 #define DRIVE_CURRENT_8_400_mA_T114 0x15
329 #define DRIVE_CURRENT_8_800_mA_T114 0x16
330 #define DRIVE_CURRENT_9_200_mA_T114 0x17
331 #define DRIVE_CURRENT_9_600_mA_T114 0x18
332 #define DRIVE_CURRENT_10_000_mA_T114 0x19
333 #define DRIVE_CURRENT_10_400_mA_T114 0x1a
334 #define DRIVE_CURRENT_10_800_mA_T114 0x1b
335 #define DRIVE_CURRENT_11_200_mA_T114 0x1c
336 #define DRIVE_CURRENT_11_600_mA_T114 0x1d
337 #define DRIVE_CURRENT_12_000_mA_T114 0x1e
338 #define DRIVE_CURRENT_12_400_mA_T114 0x1f
339 #define DRIVE_CURRENT_12_800_mA_T114 0x20
340 #define DRIVE_CURRENT_13_200_mA_T114 0x21
341 #define DRIVE_CURRENT_13_600_mA_T114 0x22
342 #define DRIVE_CURRENT_14_000_mA_T114 0x23
343 #define DRIVE_CURRENT_14_400_mA_T114 0x24
344 #define DRIVE_CURRENT_14_800_mA_T114 0x25
345 #define DRIVE_CURRENT_15_200_mA_T114 0x26
346 #define DRIVE_CURRENT_15_600_mA_T114 0x27
347 #define DRIVE_CURRENT_16_000_mA_T114 0x28
348 #define DRIVE_CURRENT_16_400_mA_T114 0x29
349 #define DRIVE_CURRENT_16_800_mA_T114 0x2a
350 #define DRIVE_CURRENT_17_200_mA_T114 0x2b
351 #define DRIVE_CURRENT_17_600_mA_T114 0x2c
352 #define DRIVE_CURRENT_18_000_mA_T114 0x2d
353 #define DRIVE_CURRENT_18_400_mA_T114 0x2e
354 #define DRIVE_CURRENT_18_800_mA_T114 0x2f
355 #define DRIVE_CURRENT_19_200_mA_T114 0x30
356 #define DRIVE_CURRENT_19_600_mA_T114 0x31
357 #define DRIVE_CURRENT_20_000_mA_T114 0x32
358 #define DRIVE_CURRENT_20_400_mA_T114 0x33
359 #define DRIVE_CURRENT_20_800_mA_T114 0x34
360 #define DRIVE_CURRENT_21_200_mA_T114 0x35
361 #define DRIVE_CURRENT_21_600_mA_T114 0x36
362 #define DRIVE_CURRENT_22_000_mA_T114 0x37
363 #define DRIVE_CURRENT_22_400_mA_T114 0x38
364 #define DRIVE_CURRENT_22_800_mA_T114 0x39
365 #define DRIVE_CURRENT_23_200_mA_T114 0x3a
366 #define DRIVE_CURRENT_23_600_mA_T114 0x3b
367 #define DRIVE_CURRENT_24_000_mA_T114 0x3c
368 #define DRIVE_CURRENT_24_400_mA_T114 0x3d
369 #define DRIVE_CURRENT_24_800_mA_T114 0x3e
370 #define DRIVE_CURRENT_25_200_mA_T114 0x3f
371 #define DRIVE_CURRENT_25_400_mA_T114 0x40
372 #define DRIVE_CURRENT_25_800_mA_T114 0x41
373 #define DRIVE_CURRENT_26_200_mA_T114 0x42
374 #define DRIVE_CURRENT_26_600_mA_T114 0x43
375 #define DRIVE_CURRENT_27_000_mA_T114 0x44
376 #define DRIVE_CURRENT_27_400_mA_T114 0x45
377 #define DRIVE_CURRENT_27_800_mA_T114 0x46
378 #define DRIVE_CURRENT_28_200_mA_T114 0x47
379 
380 #define HDMI_NV_PDISP_AUDIO_DEBUG0				0x7f
381 #define HDMI_NV_PDISP_AUDIO_DEBUG1				0x80
382 #define HDMI_NV_PDISP_AUDIO_DEBUG2				0x81
383 
384 #define HDMI_NV_PDISP_AUDIO_FS(x)				(0x82 + (x))
385 #define AUDIO_FS_LOW(x)  (((x) & 0xfff) <<  0)
386 #define AUDIO_FS_HIGH(x) (((x) & 0xfff) << 16)
387 
388 #define HDMI_NV_PDISP_AUDIO_PULSE_WIDTH				0x89
389 #define HDMI_NV_PDISP_AUDIO_THRESHOLD				0x8a
390 #define HDMI_NV_PDISP_AUDIO_CNTRL0				0x8b
391 #define AUDIO_CNTRL0_ERROR_TOLERANCE(x)  (((x) & 0xff) << 0)
392 #define AUDIO_CNTRL0_SOURCE_SELECT_AUTO  (0 << 20)
393 #define AUDIO_CNTRL0_SOURCE_SELECT_SPDIF (1 << 20)
394 #define AUDIO_CNTRL0_SOURCE_SELECT_HDAL  (2 << 20)
395 #define AUDIO_CNTRL0_FRAMES_PER_BLOCK(x) (((x) & 0xff) << 24)
396 
397 #define HDMI_NV_PDISP_AUDIO_N					0x8c
398 #define AUDIO_N_VALUE(x)           (((x) & 0xfffff) << 0)
399 #define AUDIO_N_RESETF             (1 << 20)
400 #define AUDIO_N_GENERATE_NORMAL    (0 << 24)
401 #define AUDIO_N_GENERATE_ALTERNATE (1 << 24)
402 
403 #define HDMI_NV_PDISP_HDCPRIF_ROM_TIMING			0x94
404 #define HDMI_NV_PDISP_SOR_REFCLK				0x95
405 #define SOR_REFCLK_DIV_INT(x)  (((x) & 0xff) << 8)
406 #define SOR_REFCLK_DIV_FRAC(x) (((x) & 0x03) << 6)
407 
408 #define HDMI_NV_PDISP_CRC_CONTROL				0x96
409 #define HDMI_NV_PDISP_INPUT_CONTROL				0x97
410 #define HDMI_SRC_DISPLAYA       (0 << 0)
411 #define HDMI_SRC_DISPLAYB       (1 << 0)
412 #define ARM_VIDEO_RANGE_FULL    (0 << 1)
413 #define ARM_VIDEO_RANGE_LIMITED (1 << 1)
414 
415 #define HDMI_NV_PDISP_SCRATCH					0x98
416 #define HDMI_NV_PDISP_PE_CURRENT				0x99
417 #define PE_CURRENT0(x) (((x) & 0xf) << 0)
418 #define PE_CURRENT1(x) (((x) & 0xf) << 8)
419 #define PE_CURRENT2(x) (((x) & 0xf) << 16)
420 #define PE_CURRENT3(x) (((x) & 0xf) << 24)
421 
422 #define PE_CURRENT_0_0_mA 0x0
423 #define PE_CURRENT_0_5_mA 0x1
424 #define PE_CURRENT_1_0_mA 0x2
425 #define PE_CURRENT_1_5_mA 0x3
426 #define PE_CURRENT_2_0_mA 0x4
427 #define PE_CURRENT_2_5_mA 0x5
428 #define PE_CURRENT_3_0_mA 0x6
429 #define PE_CURRENT_3_5_mA 0x7
430 #define PE_CURRENT_4_0_mA 0x8
431 #define PE_CURRENT_4_5_mA 0x9
432 #define PE_CURRENT_5_0_mA 0xa
433 #define PE_CURRENT_5_5_mA 0xb
434 #define PE_CURRENT_6_0_mA 0xc
435 #define PE_CURRENT_6_5_mA 0xd
436 #define PE_CURRENT_7_0_mA 0xe
437 #define PE_CURRENT_7_5_mA 0xf
438 
439 #define PE_CURRENT_0_mA_T114 0x0
440 #define PE_CURRENT_1_mA_T114 0x1
441 #define PE_CURRENT_2_mA_T114 0x2
442 #define PE_CURRENT_3_mA_T114 0x3
443 #define PE_CURRENT_4_mA_T114 0x4
444 #define PE_CURRENT_5_mA_T114 0x5
445 #define PE_CURRENT_6_mA_T114 0x6
446 #define PE_CURRENT_7_mA_T114 0x7
447 #define PE_CURRENT_8_mA_T114 0x8
448 #define PE_CURRENT_9_mA_T114 0x9
449 #define PE_CURRENT_10_mA_T114 0xa
450 #define PE_CURRENT_11_mA_T114 0xb
451 #define PE_CURRENT_12_mA_T114 0xc
452 #define PE_CURRENT_13_mA_T114 0xd
453 #define PE_CURRENT_14_mA_T114 0xe
454 #define PE_CURRENT_15_mA_T114 0xf
455 
456 #define HDMI_NV_PDISP_KEY_CTRL					0x9a
457 #define HDMI_NV_PDISP_KEY_DEBUG0				0x9b
458 #define HDMI_NV_PDISP_KEY_DEBUG1				0x9c
459 #define HDMI_NV_PDISP_KEY_DEBUG2				0x9d
460 #define HDMI_NV_PDISP_KEY_HDCP_KEY_0				0x9e
461 #define HDMI_NV_PDISP_KEY_HDCP_KEY_1				0x9f
462 #define HDMI_NV_PDISP_KEY_HDCP_KEY_2				0xa0
463 #define HDMI_NV_PDISP_KEY_HDCP_KEY_3				0xa1
464 #define HDMI_NV_PDISP_KEY_HDCP_KEY_TRIG				0xa2
465 #define HDMI_NV_PDISP_KEY_SKEY_INDEX				0xa3
466 
467 #define HDMI_NV_PDISP_SOR_AUDIO_CNTRL0				0xac
468 #define  SOR_AUDIO_CNTRL0_SOURCE_SELECT_AUTO	(0 << 20)
469 #define  SOR_AUDIO_CNTRL0_SOURCE_SELECT_SPDIF	(1 << 20)
470 #define  SOR_AUDIO_CNTRL0_SOURCE_SELECT_HDAL	(2 << 20)
471 #define  SOR_AUDIO_CNTRL0_INJECT_NULLSMPL	(1 << 29)
472 #define HDMI_NV_PDISP_SOR_AUDIO_SPARE0				0xae
473 #define  SOR_AUDIO_SPARE0_HBR_ENABLE		(1 << 27)
474 #define HDMI_NV_PDISP_SOR_AUDIO_HDA_CODEC_SCRATCH0		0xba
475 #define  SOR_AUDIO_HDA_CODEC_SCRATCH0_VALID	(1 << 30)
476 #define  SOR_AUDIO_HDA_CODEC_SCRATCH0_FMT_MASK	0xffff
477 #define HDMI_NV_PDISP_SOR_AUDIO_HDA_CODEC_SCRATCH1		0xbb
478 #define HDMI_NV_PDISP_SOR_AUDIO_HDA_ELD_BUFWR			0xbc
479 #define HDMI_NV_PDISP_SOR_AUDIO_HDA_PRESENSE			0xbd
480 #define  SOR_AUDIO_HDA_PRESENSE_VALID		(1 << 1)
481 #define  SOR_AUDIO_HDA_PRESENSE_PRESENT		(1 << 0)
482 
483 #define HDMI_NV_PDISP_SOR_AUDIO_AVAL_0320    0xbf
484 #define HDMI_NV_PDISP_SOR_AUDIO_AVAL_0441    0xc0
485 #define HDMI_NV_PDISP_SOR_AUDIO_AVAL_0882    0xc1
486 #define HDMI_NV_PDISP_SOR_AUDIO_AVAL_1764    0xc2
487 #define HDMI_NV_PDISP_SOR_AUDIO_AVAL_0480    0xc3
488 #define HDMI_NV_PDISP_SOR_AUDIO_AVAL_0960    0xc4
489 #define HDMI_NV_PDISP_SOR_AUDIO_AVAL_1920    0xc5
490 #define HDMI_NV_PDISP_SOR_AUDIO_AVAL_DEFAULT 0xc5
491 
492 #define HDMI_NV_PDISP_INT_STATUS			0xcc
493 #define  INT_SCRATCH		(1 << 3)
494 #define  INT_CP_REQUEST		(1 << 2)
495 #define  INT_CODEC_SCRATCH1	(1 << 1)
496 #define  INT_CODEC_SCRATCH0	(1 << 0)
497 #define HDMI_NV_PDISP_INT_MASK				0xcd
498 #define HDMI_NV_PDISP_INT_ENABLE			0xce
499 
500 #define HDMI_NV_PDISP_SOR_IO_PEAK_CURRENT		0xd1
501 #define PEAK_CURRENT_LANE0(x) (((x) & 0x7f) <<  0)
502 #define PEAK_CURRENT_LANE1(x) (((x) & 0x7f) <<  8)
503 #define PEAK_CURRENT_LANE2(x) (((x) & 0x7f) << 16)
504 #define PEAK_CURRENT_LANE3(x) (((x) & 0x7f) << 24)
505 
506 #define PEAK_CURRENT_0_000_mA 0x00
507 #define PEAK_CURRENT_0_200_mA 0x01
508 #define PEAK_CURRENT_0_400_mA 0x02
509 #define PEAK_CURRENT_0_600_mA 0x03
510 #define PEAK_CURRENT_0_800_mA 0x04
511 #define PEAK_CURRENT_1_000_mA 0x05
512 #define PEAK_CURRENT_1_200_mA 0x06
513 #define PEAK_CURRENT_1_400_mA 0x07
514 #define PEAK_CURRENT_1_600_mA 0x08
515 #define PEAK_CURRENT_1_800_mA 0x09
516 #define PEAK_CURRENT_2_000_mA 0x0a
517 #define PEAK_CURRENT_2_200_mA 0x0b
518 #define PEAK_CURRENT_2_400_mA 0x0c
519 #define PEAK_CURRENT_2_600_mA 0x0d
520 #define PEAK_CURRENT_2_800_mA 0x0e
521 #define PEAK_CURRENT_3_000_mA 0x0f
522 #define PEAK_CURRENT_3_200_mA 0x10
523 #define PEAK_CURRENT_3_400_mA 0x11
524 #define PEAK_CURRENT_3_600_mA 0x12
525 #define PEAK_CURRENT_3_800_mA 0x13
526 #define PEAK_CURRENT_4_000_mA 0x14
527 #define PEAK_CURRENT_4_200_mA 0x15
528 #define PEAK_CURRENT_4_400_mA 0x16
529 #define PEAK_CURRENT_4_600_mA 0x17
530 #define PEAK_CURRENT_4_800_mA 0x18
531 #define PEAK_CURRENT_5_000_mA 0x19
532 #define PEAK_CURRENT_5_200_mA 0x1a
533 #define PEAK_CURRENT_5_400_mA 0x1b
534 #define PEAK_CURRENT_5_600_mA 0x1c
535 #define PEAK_CURRENT_5_800_mA 0x1d
536 #define PEAK_CURRENT_6_000_mA 0x1e
537 #define PEAK_CURRENT_6_200_mA 0x1f
538 #define PEAK_CURRENT_6_400_mA 0x20
539 #define PEAK_CURRENT_6_600_mA 0x21
540 #define PEAK_CURRENT_6_800_mA 0x22
541 #define PEAK_CURRENT_7_000_mA 0x23
542 #define PEAK_CURRENT_7_200_mA 0x24
543 #define PEAK_CURRENT_7_400_mA 0x25
544 #define PEAK_CURRENT_7_600_mA 0x26
545 #define PEAK_CURRENT_7_800_mA 0x27
546 #define PEAK_CURRENT_8_000_mA 0x28
547 #define PEAK_CURRENT_8_200_mA 0x29
548 #define PEAK_CURRENT_8_400_mA 0x2a
549 #define PEAK_CURRENT_8_600_mA 0x2b
550 #define PEAK_CURRENT_8_800_mA 0x2c
551 #define PEAK_CURRENT_9_000_mA 0x2d
552 #define PEAK_CURRENT_9_200_mA 0x2e
553 #define PEAK_CURRENT_9_400_mA 0x2f
554 
555 #define HDMI_NV_PDISP_SOR_PAD_CTLS0		0xd2
556 
557 #endif /* TEGRA_HDMI_H */
558