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