xref: /linux/drivers/gpu/drm/tegra/hdmi.h (revision 2ccb396e9dd4536cfb7e8c4fd892d215c7aec2b6)
1dee8268fSThierry Reding /*
2dee8268fSThierry Reding  * Copyright (C) 2012 Avionic Design GmbH
3dee8268fSThierry Reding  * Copyright (C) 2012 NVIDIA CORPORATION.  All rights reserved.
4dee8268fSThierry Reding  *
5dee8268fSThierry Reding  * This program is free software; you can redistribute it and/or modify
6dee8268fSThierry Reding  * it under the terms of the GNU General Public License version 2 as
7dee8268fSThierry Reding  * published by the Free Software Foundation.
8dee8268fSThierry Reding  */
9dee8268fSThierry Reding 
10dee8268fSThierry Reding #ifndef TEGRA_HDMI_H
11dee8268fSThierry Reding #define TEGRA_HDMI_H 1
12dee8268fSThierry Reding 
13dee8268fSThierry Reding /* register definitions */
14dee8268fSThierry Reding #define HDMI_CTXSW						0x00
15dee8268fSThierry Reding 
16dee8268fSThierry Reding #define HDMI_NV_PDISP_SOR_STATE0				0x01
17dee8268fSThierry Reding #define SOR_STATE_UPDATE (1 << 0)
18dee8268fSThierry Reding 
19dee8268fSThierry Reding #define HDMI_NV_PDISP_SOR_STATE1				0x02
20dee8268fSThierry Reding #define SOR_STATE_ASY_HEAD_OPMODE_AWAKE (2 << 0)
21dee8268fSThierry Reding #define SOR_STATE_ASY_ORMODE_NORMAL     (1 << 2)
22dee8268fSThierry Reding #define SOR_STATE_ATTACHED              (1 << 3)
23dee8268fSThierry Reding 
24dee8268fSThierry Reding #define HDMI_NV_PDISP_SOR_STATE2				0x03
25dee8268fSThierry Reding #define SOR_STATE_ASY_OWNER_NONE         (0 <<  0)
26dee8268fSThierry Reding #define SOR_STATE_ASY_OWNER_HEAD0        (1 <<  0)
27dee8268fSThierry Reding #define SOR_STATE_ASY_SUBOWNER_NONE      (0 <<  4)
28dee8268fSThierry Reding #define SOR_STATE_ASY_SUBOWNER_SUBHEAD0  (1 <<  4)
29dee8268fSThierry Reding #define SOR_STATE_ASY_SUBOWNER_SUBHEAD1  (2 <<  4)
30dee8268fSThierry Reding #define SOR_STATE_ASY_SUBOWNER_BOTH      (3 <<  4)
31dee8268fSThierry Reding #define SOR_STATE_ASY_CRCMODE_ACTIVE     (0 <<  6)
32dee8268fSThierry Reding #define SOR_STATE_ASY_CRCMODE_COMPLETE   (1 <<  6)
33dee8268fSThierry Reding #define SOR_STATE_ASY_CRCMODE_NON_ACTIVE (2 <<  6)
34dee8268fSThierry Reding #define SOR_STATE_ASY_PROTOCOL_SINGLE_TMDS_A (1 << 8)
35dee8268fSThierry Reding #define SOR_STATE_ASY_PROTOCOL_CUSTOM        (15 << 8)
36dee8268fSThierry Reding #define SOR_STATE_ASY_HSYNCPOL_POS       (0 << 12)
37dee8268fSThierry Reding #define SOR_STATE_ASY_HSYNCPOL_NEG       (1 << 12)
38dee8268fSThierry Reding #define SOR_STATE_ASY_VSYNCPOL_POS       (0 << 13)
39dee8268fSThierry Reding #define SOR_STATE_ASY_VSYNCPOL_NEG       (1 << 13)
40dee8268fSThierry Reding #define SOR_STATE_ASY_DEPOL_POS          (0 << 14)
41dee8268fSThierry Reding #define SOR_STATE_ASY_DEPOL_NEG          (1 << 14)
42dee8268fSThierry Reding 
43dee8268fSThierry Reding #define HDMI_NV_PDISP_RG_HDCP_AN_MSB				0x04
44dee8268fSThierry Reding #define HDMI_NV_PDISP_RG_HDCP_AN_LSB				0x05
45dee8268fSThierry Reding #define HDMI_NV_PDISP_RG_HDCP_CN_MSB				0x06
46dee8268fSThierry Reding #define HDMI_NV_PDISP_RG_HDCP_CN_LSB				0x07
47dee8268fSThierry Reding #define HDMI_NV_PDISP_RG_HDCP_AKSV_MSB				0x08
48dee8268fSThierry Reding #define HDMI_NV_PDISP_RG_HDCP_AKSV_LSB				0x09
49dee8268fSThierry Reding #define HDMI_NV_PDISP_RG_HDCP_BKSV_MSB				0x0a
50dee8268fSThierry Reding #define HDMI_NV_PDISP_RG_HDCP_BKSV_LSB				0x0b
51dee8268fSThierry Reding #define HDMI_NV_PDISP_RG_HDCP_CKSV_MSB				0x0c
52dee8268fSThierry Reding #define HDMI_NV_PDISP_RG_HDCP_CKSV_LSB				0x0d
53dee8268fSThierry Reding #define HDMI_NV_PDISP_RG_HDCP_DKSV_MSB				0x0e
54dee8268fSThierry Reding #define HDMI_NV_PDISP_RG_HDCP_DKSV_LSB				0x0f
55dee8268fSThierry Reding #define HDMI_NV_PDISP_RG_HDCP_CTRL				0x10
56dee8268fSThierry Reding #define HDMI_NV_PDISP_RG_HDCP_CMODE				0x11
57dee8268fSThierry Reding #define HDMI_NV_PDISP_RG_HDCP_MPRIME_MSB			0x12
58dee8268fSThierry Reding #define HDMI_NV_PDISP_RG_HDCP_MPRIME_LSB			0x13
59dee8268fSThierry Reding #define HDMI_NV_PDISP_RG_HDCP_SPRIME_MSB			0x14
60dee8268fSThierry Reding #define HDMI_NV_PDISP_RG_HDCP_SPRIME_LSB2			0x15
61dee8268fSThierry Reding #define HDMI_NV_PDISP_RG_HDCP_SPRIME_LSB1			0x16
62dee8268fSThierry Reding #define HDMI_NV_PDISP_RG_HDCP_RI				0x17
63dee8268fSThierry Reding #define HDMI_NV_PDISP_RG_HDCP_CS_MSB				0x18
64dee8268fSThierry Reding #define HDMI_NV_PDISP_RG_HDCP_CS_LSB				0x19
65dee8268fSThierry Reding #define HDMI_NV_PDISP_HDMI_AUDIO_EMU0				0x1a
66dee8268fSThierry Reding #define HDMI_NV_PDISP_HDMI_AUDIO_EMU_RDATA0			0x1b
67dee8268fSThierry Reding #define HDMI_NV_PDISP_HDMI_AUDIO_EMU1				0x1c
68dee8268fSThierry Reding #define HDMI_NV_PDISP_HDMI_AUDIO_EMU2				0x1d
69dee8268fSThierry Reding 
70dee8268fSThierry Reding #define HDMI_NV_PDISP_HDMI_AUDIO_INFOFRAME_CTRL			0x1e
71dee8268fSThierry Reding #define HDMI_NV_PDISP_HDMI_AUDIO_INFOFRAME_STATUS		0x1f
72dee8268fSThierry Reding #define HDMI_NV_PDISP_HDMI_AUDIO_INFOFRAME_HEADER		0x20
73dee8268fSThierry Reding #define HDMI_NV_PDISP_HDMI_AUDIO_INFOFRAME_SUBPACK0_LOW		0x21
74dee8268fSThierry Reding #define HDMI_NV_PDISP_HDMI_AUDIO_INFOFRAME_SUBPACK0_HIGH	0x22
75dee8268fSThierry Reding #define HDMI_NV_PDISP_HDMI_AVI_INFOFRAME_CTRL			0x23
76dee8268fSThierry Reding #define HDMI_NV_PDISP_HDMI_AVI_INFOFRAME_STATUS			0x24
77dee8268fSThierry Reding #define HDMI_NV_PDISP_HDMI_AVI_INFOFRAME_HEADER			0x25
78dee8268fSThierry Reding #define HDMI_NV_PDISP_HDMI_AVI_INFOFRAME_SUBPACK0_LOW		0x26
79dee8268fSThierry Reding #define HDMI_NV_PDISP_HDMI_AVI_INFOFRAME_SUBPACK0_HIGH		0x27
80dee8268fSThierry Reding #define HDMI_NV_PDISP_HDMI_AVI_INFOFRAME_SUBPACK1_LOW		0x28
81dee8268fSThierry Reding #define HDMI_NV_PDISP_HDMI_AVI_INFOFRAME_SUBPACK1_HIGH		0x29
82dee8268fSThierry Reding 
83dee8268fSThierry Reding #define INFOFRAME_CTRL_ENABLE (1 << 0)
84dee8268fSThierry Reding 
85dee8268fSThierry Reding #define INFOFRAME_HEADER_TYPE(x)    (((x) & 0xff) <<  0)
86dee8268fSThierry Reding #define INFOFRAME_HEADER_VERSION(x) (((x) & 0xff) <<  8)
87dee8268fSThierry Reding #define INFOFRAME_HEADER_LEN(x)     (((x) & 0x0f) << 16)
88dee8268fSThierry Reding 
89dee8268fSThierry Reding #define HDMI_NV_PDISP_HDMI_GENERIC_CTRL				0x2a
90dee8268fSThierry Reding #define GENERIC_CTRL_ENABLE (1 <<  0)
91dee8268fSThierry Reding #define GENERIC_CTRL_OTHER  (1 <<  4)
92dee8268fSThierry Reding #define GENERIC_CTRL_SINGLE (1 <<  8)
93dee8268fSThierry Reding #define GENERIC_CTRL_HBLANK (1 << 12)
94dee8268fSThierry Reding #define GENERIC_CTRL_AUDIO  (1 << 16)
95dee8268fSThierry Reding 
96dee8268fSThierry Reding #define HDMI_NV_PDISP_HDMI_GENERIC_STATUS			0x2b
97dee8268fSThierry Reding #define HDMI_NV_PDISP_HDMI_GENERIC_HEADER			0x2c
98dee8268fSThierry Reding #define HDMI_NV_PDISP_HDMI_GENERIC_SUBPACK0_LOW			0x2d
99dee8268fSThierry Reding #define HDMI_NV_PDISP_HDMI_GENERIC_SUBPACK0_HIGH		0x2e
100dee8268fSThierry Reding #define HDMI_NV_PDISP_HDMI_GENERIC_SUBPACK1_LOW			0x2f
101dee8268fSThierry Reding #define HDMI_NV_PDISP_HDMI_GENERIC_SUBPACK1_HIGH		0x30
102dee8268fSThierry Reding #define HDMI_NV_PDISP_HDMI_GENERIC_SUBPACK2_LOW			0x31
103dee8268fSThierry Reding #define HDMI_NV_PDISP_HDMI_GENERIC_SUBPACK2_HIGH		0x32
104dee8268fSThierry Reding #define HDMI_NV_PDISP_HDMI_GENERIC_SUBPACK3_LOW			0x33
105dee8268fSThierry Reding #define HDMI_NV_PDISP_HDMI_GENERIC_SUBPACK3_HIGH		0x34
106dee8268fSThierry Reding 
107dee8268fSThierry Reding #define HDMI_NV_PDISP_HDMI_ACR_CTRL				0x35
108dee8268fSThierry Reding #define HDMI_NV_PDISP_HDMI_ACR_0320_SUBPACK_LOW			0x36
109dee8268fSThierry Reding #define HDMI_NV_PDISP_HDMI_ACR_0320_SUBPACK_HIGH		0x37
110dee8268fSThierry Reding #define HDMI_NV_PDISP_HDMI_ACR_0441_SUBPACK_LOW			0x38
111dee8268fSThierry Reding #define HDMI_NV_PDISP_HDMI_ACR_0441_SUBPACK_HIGH		0x39
112dee8268fSThierry Reding #define HDMI_NV_PDISP_HDMI_ACR_0882_SUBPACK_LOW			0x3a
113dee8268fSThierry Reding #define HDMI_NV_PDISP_HDMI_ACR_0882_SUBPACK_HIGH		0x3b
114dee8268fSThierry Reding #define HDMI_NV_PDISP_HDMI_ACR_1764_SUBPACK_LOW			0x3c
115dee8268fSThierry Reding #define HDMI_NV_PDISP_HDMI_ACR_1764_SUBPACK_HIGH		0x3d
116dee8268fSThierry Reding #define HDMI_NV_PDISP_HDMI_ACR_0480_SUBPACK_LOW			0x3e
117dee8268fSThierry Reding #define HDMI_NV_PDISP_HDMI_ACR_0480_SUBPACK_HIGH		0x3f
118dee8268fSThierry Reding #define HDMI_NV_PDISP_HDMI_ACR_0960_SUBPACK_LOW			0x40
119dee8268fSThierry Reding #define HDMI_NV_PDISP_HDMI_ACR_0960_SUBPACK_HIGH		0x41
120dee8268fSThierry Reding #define HDMI_NV_PDISP_HDMI_ACR_1920_SUBPACK_LOW			0x42
121dee8268fSThierry Reding #define HDMI_NV_PDISP_HDMI_ACR_1920_SUBPACK_HIGH		0x43
122dee8268fSThierry Reding 
123dee8268fSThierry Reding #define ACR_SUBPACK_CTS(x) (((x) & 0xffffff) << 8)
124dee8268fSThierry Reding #define ACR_SUBPACK_N(x)   (((x) & 0xffffff) << 0)
125dee8268fSThierry Reding #define ACR_ENABLE         (1 << 31)
126dee8268fSThierry Reding 
127dee8268fSThierry Reding #define HDMI_NV_PDISP_HDMI_CTRL					0x44
128dee8268fSThierry Reding #define HDMI_CTRL_REKEY(x)         (((x) & 0x7f) <<  0)
129dee8268fSThierry Reding #define HDMI_CTRL_MAX_AC_PACKET(x) (((x) & 0x1f) << 16)
130dee8268fSThierry Reding #define HDMI_CTRL_ENABLE           (1 << 30)
131dee8268fSThierry Reding 
132dee8268fSThierry Reding #define HDMI_NV_PDISP_HDMI_VSYNC_KEEPOUT			0x45
133dee8268fSThierry Reding #define HDMI_NV_PDISP_HDMI_VSYNC_WINDOW				0x46
134dee8268fSThierry Reding #define VSYNC_WINDOW_END(x)   (((x) & 0x3ff) <<  0)
135dee8268fSThierry Reding #define VSYNC_WINDOW_START(x) (((x) & 0x3ff) << 16)
136dee8268fSThierry Reding #define VSYNC_WINDOW_ENABLE   (1 << 31)
137dee8268fSThierry Reding 
138dee8268fSThierry Reding #define HDMI_NV_PDISP_HDMI_GCP_CTRL				0x47
139dee8268fSThierry Reding #define HDMI_NV_PDISP_HDMI_GCP_STATUS				0x48
140dee8268fSThierry Reding #define HDMI_NV_PDISP_HDMI_GCP_SUBPACK				0x49
141dee8268fSThierry Reding #define HDMI_NV_PDISP_HDMI_CHANNEL_STATUS1			0x4a
142dee8268fSThierry Reding #define HDMI_NV_PDISP_HDMI_CHANNEL_STATUS2			0x4b
143dee8268fSThierry Reding #define HDMI_NV_PDISP_HDMI_EMU0					0x4c
144dee8268fSThierry Reding #define HDMI_NV_PDISP_HDMI_EMU1					0x4d
145dee8268fSThierry Reding #define HDMI_NV_PDISP_HDMI_EMU1_RDATA				0x4e
146dee8268fSThierry Reding 
147dee8268fSThierry Reding #define HDMI_NV_PDISP_HDMI_SPARE				0x4f
148dee8268fSThierry Reding #define SPARE_HW_CTS           (1 << 0)
149dee8268fSThierry Reding #define SPARE_FORCE_SW_CTS     (1 << 1)
150dee8268fSThierry Reding #define SPARE_CTS_RESET_VAL(x) (((x) & 0x7) << 16)
151dee8268fSThierry Reding 
152dee8268fSThierry Reding #define HDMI_NV_PDISP_HDMI_SPDIF_CHN_STATUS1			0x50
153dee8268fSThierry Reding #define HDMI_NV_PDISP_HDMI_SPDIF_CHN_STATUS2			0x51
154dee8268fSThierry Reding #define HDMI_NV_PDISP_HDMI_HDCPRIF_ROM_CTRL			0x53
155dee8268fSThierry Reding #define HDMI_NV_PDISP_SOR_CAP					0x54
156dee8268fSThierry Reding #define HDMI_NV_PDISP_SOR_PWR					0x55
157dee8268fSThierry Reding #define SOR_PWR_NORMAL_STATE_PD     (0 <<  0)
158dee8268fSThierry Reding #define SOR_PWR_NORMAL_STATE_PU     (1 <<  0)
159dee8268fSThierry Reding #define SOR_PWR_NORMAL_START_NORMAL (0 <<  1)
160dee8268fSThierry Reding #define SOR_PWR_NORMAL_START_ALT    (1 <<  1)
161dee8268fSThierry Reding #define SOR_PWR_SAFE_STATE_PD       (0 << 16)
162dee8268fSThierry Reding #define SOR_PWR_SAFE_STATE_PU       (1 << 16)
163dee8268fSThierry Reding #define SOR_PWR_SETTING_NEW_DONE    (0 << 31)
164dee8268fSThierry Reding #define SOR_PWR_SETTING_NEW_PENDING (1 << 31)
165dee8268fSThierry Reding #define SOR_PWR_SETTING_NEW_TRIGGER (1 << 31)
166dee8268fSThierry Reding 
167dee8268fSThierry Reding #define HDMI_NV_PDISP_SOR_TEST					0x56
168dee8268fSThierry Reding #define HDMI_NV_PDISP_SOR_PLL0					0x57
169dee8268fSThierry Reding #define SOR_PLL_PWR            (1 << 0)
170dee8268fSThierry Reding #define SOR_PLL_PDBG           (1 << 1)
171dee8268fSThierry Reding #define SOR_PLL_VCAPD          (1 << 2)
172dee8268fSThierry Reding #define SOR_PLL_PDPORT         (1 << 3)
173dee8268fSThierry Reding #define SOR_PLL_RESISTORSEL    (1 << 4)
174dee8268fSThierry Reding #define SOR_PLL_PULLDOWN       (1 << 5)
175dee8268fSThierry Reding #define SOR_PLL_VCOCAP(x)      (((x) & 0xf) <<  8)
176dee8268fSThierry Reding #define SOR_PLL_BG_V17_S(x)    (((x) & 0xf) << 12)
177dee8268fSThierry Reding #define SOR_PLL_FILTER(x)      (((x) & 0xf) << 16)
178dee8268fSThierry Reding #define SOR_PLL_ICHPMP(x)      (((x) & 0xf) << 24)
179dee8268fSThierry Reding #define SOR_PLL_TX_REG_LOAD(x) (((x) & 0xf) << 28)
180dee8268fSThierry Reding 
181dee8268fSThierry Reding #define HDMI_NV_PDISP_SOR_PLL1					0x58
182dee8268fSThierry Reding #define SOR_PLL_TMDS_TERM_ENABLE (1 << 8)
183dee8268fSThierry Reding #define SOR_PLL_TMDS_TERMADJ(x)  (((x) & 0xf) <<  9)
184dee8268fSThierry Reding #define SOR_PLL_LOADADJ(x)       (((x) & 0xf) << 20)
185dee8268fSThierry Reding #define SOR_PLL_PE_EN            (1 << 28)
186dee8268fSThierry Reding #define SOR_PLL_HALF_FULL_PE     (1 << 29)
187dee8268fSThierry Reding #define SOR_PLL_S_D_PIN_PE       (1 << 30)
188dee8268fSThierry Reding 
189dee8268fSThierry Reding #define HDMI_NV_PDISP_SOR_PLL2					0x59
190dee8268fSThierry Reding 
191dee8268fSThierry Reding #define HDMI_NV_PDISP_SOR_CSTM					0x5a
192dee8268fSThierry Reding #define SOR_CSTM_ROTCLK(x) (((x) & 0xf) << 24)
1939cbfc73eSThierry Reding #define SOR_CSTM_PLLDIV (1 << 21)
1949cbfc73eSThierry Reding #define SOR_CSTM_LVDS_ENABLE (1 << 16)
1959cbfc73eSThierry Reding #define SOR_CSTM_MODE_LVDS (0 << 12)
1969cbfc73eSThierry Reding #define SOR_CSTM_MODE_TMDS (1 << 12)
1979cbfc73eSThierry Reding #define SOR_CSTM_MODE_MASK (3 << 12)
198dee8268fSThierry Reding 
199dee8268fSThierry Reding #define HDMI_NV_PDISP_SOR_LVDS					0x5b
200dee8268fSThierry Reding #define HDMI_NV_PDISP_SOR_CRCA					0x5c
201dee8268fSThierry Reding #define HDMI_NV_PDISP_SOR_CRCB					0x5d
202dee8268fSThierry Reding #define HDMI_NV_PDISP_SOR_BLANK					0x5e
203dee8268fSThierry Reding #define HDMI_NV_PDISP_SOR_SEQ_CTL				0x5f
2045c1c071aSThierry Reding #define SOR_SEQ_PU_PC(x)     (((x) & 0xf) <<  0)
205dee8268fSThierry Reding #define SOR_SEQ_PU_PC_ALT(x) (((x) & 0xf) <<  4)
206dee8268fSThierry Reding #define SOR_SEQ_PD_PC(x)     (((x) & 0xf) <<  8)
207dee8268fSThierry Reding #define SOR_SEQ_PD_PC_ALT(x) (((x) & 0xf) << 12)
208dee8268fSThierry Reding #define SOR_SEQ_PC(x)        (((x) & 0xf) << 16)
209dee8268fSThierry Reding #define SOR_SEQ_STATUS       (1 << 28)
210dee8268fSThierry Reding #define SOR_SEQ_SWITCH       (1 << 30)
211dee8268fSThierry Reding 
212dee8268fSThierry Reding #define HDMI_NV_PDISP_SOR_SEQ_INST(x)				(0x60 + (x))
213dee8268fSThierry Reding 
214dee8268fSThierry Reding #define SOR_SEQ_INST_WAIT_TIME(x)     (((x) & 0x3ff) << 0)
215dee8268fSThierry Reding #define SOR_SEQ_INST_WAIT_UNITS_VSYNC (2 << 12)
216dee8268fSThierry Reding #define SOR_SEQ_INST_HALT             (1 << 15)
217dee8268fSThierry Reding #define SOR_SEQ_INST_PIN_A_LOW        (0 << 21)
218dee8268fSThierry Reding #define SOR_SEQ_INST_PIN_A_HIGH       (1 << 21)
219dee8268fSThierry Reding #define SOR_SEQ_INST_PIN_B_LOW        (0 << 22)
220dee8268fSThierry Reding #define SOR_SEQ_INST_PIN_B_HIGH       (1 << 22)
221dee8268fSThierry Reding #define SOR_SEQ_INST_DRIVE_PWM_OUT_LO (1 << 23)
222dee8268fSThierry Reding 
223dee8268fSThierry Reding #define HDMI_NV_PDISP_SOR_VCRCA0				0x72
224dee8268fSThierry Reding #define HDMI_NV_PDISP_SOR_VCRCA1				0x73
225dee8268fSThierry Reding #define HDMI_NV_PDISP_SOR_CCRCA0				0x74
226dee8268fSThierry Reding #define HDMI_NV_PDISP_SOR_CCRCA1				0x75
227dee8268fSThierry Reding #define HDMI_NV_PDISP_SOR_EDATAA0				0x76
228dee8268fSThierry Reding #define HDMI_NV_PDISP_SOR_EDATAA1				0x77
229dee8268fSThierry Reding #define HDMI_NV_PDISP_SOR_COUNTA0				0x78
230dee8268fSThierry Reding #define HDMI_NV_PDISP_SOR_COUNTA1				0x79
231dee8268fSThierry Reding #define HDMI_NV_PDISP_SOR_DEBUGA0				0x7a
232dee8268fSThierry Reding #define HDMI_NV_PDISP_SOR_DEBUGA1				0x7b
233dee8268fSThierry Reding #define HDMI_NV_PDISP_SOR_TRIG					0x7c
234dee8268fSThierry Reding #define HDMI_NV_PDISP_SOR_MSCHECK				0x7d
235dee8268fSThierry Reding 
236dee8268fSThierry Reding #define HDMI_NV_PDISP_SOR_LANE_DRIVE_CURRENT			0x7e
237dee8268fSThierry Reding #define DRIVE_CURRENT_LANE0(x)      (((x) & 0x3f) <<  0)
238dee8268fSThierry Reding #define DRIVE_CURRENT_LANE1(x)      (((x) & 0x3f) <<  8)
239dee8268fSThierry Reding #define DRIVE_CURRENT_LANE2(x)      (((x) & 0x3f) << 16)
240dee8268fSThierry Reding #define DRIVE_CURRENT_LANE3(x)      (((x) & 0x3f) << 24)
2417d1d28acSMikko Perttunen #define DRIVE_CURRENT_LANE0_T114(x) (((x) & 0x7f) <<  0)
2427d1d28acSMikko Perttunen #define DRIVE_CURRENT_LANE1_T114(x) (((x) & 0x7f) <<  8)
2437d1d28acSMikko Perttunen #define DRIVE_CURRENT_LANE2_T114(x) (((x) & 0x7f) << 16)
2447d1d28acSMikko Perttunen #define DRIVE_CURRENT_LANE3_T114(x) (((x) & 0x7f) << 24)
245dee8268fSThierry Reding 
246dee8268fSThierry Reding #define DRIVE_CURRENT_1_500_mA  0x00
247dee8268fSThierry Reding #define DRIVE_CURRENT_1_875_mA  0x01
248dee8268fSThierry Reding #define DRIVE_CURRENT_2_250_mA  0x02
249dee8268fSThierry Reding #define DRIVE_CURRENT_2_625_mA  0x03
250dee8268fSThierry Reding #define DRIVE_CURRENT_3_000_mA  0x04
251dee8268fSThierry Reding #define DRIVE_CURRENT_3_375_mA  0x05
252dee8268fSThierry Reding #define DRIVE_CURRENT_3_750_mA  0x06
253dee8268fSThierry Reding #define DRIVE_CURRENT_4_125_mA  0x07
254dee8268fSThierry Reding #define DRIVE_CURRENT_4_500_mA  0x08
255dee8268fSThierry Reding #define DRIVE_CURRENT_4_875_mA  0x09
256dee8268fSThierry Reding #define DRIVE_CURRENT_5_250_mA  0x0a
257dee8268fSThierry Reding #define DRIVE_CURRENT_5_625_mA  0x0b
258dee8268fSThierry Reding #define DRIVE_CURRENT_6_000_mA  0x0c
259dee8268fSThierry Reding #define DRIVE_CURRENT_6_375_mA  0x0d
260dee8268fSThierry Reding #define DRIVE_CURRENT_6_750_mA  0x0e
261dee8268fSThierry Reding #define DRIVE_CURRENT_7_125_mA  0x0f
262dee8268fSThierry Reding #define DRIVE_CURRENT_7_500_mA  0x10
263dee8268fSThierry Reding #define DRIVE_CURRENT_7_875_mA  0x11
264dee8268fSThierry Reding #define DRIVE_CURRENT_8_250_mA  0x12
265dee8268fSThierry Reding #define DRIVE_CURRENT_8_625_mA  0x13
266dee8268fSThierry Reding #define DRIVE_CURRENT_9_000_mA  0x14
267dee8268fSThierry Reding #define DRIVE_CURRENT_9_375_mA  0x15
268dee8268fSThierry Reding #define DRIVE_CURRENT_9_750_mA  0x16
269dee8268fSThierry Reding #define DRIVE_CURRENT_10_125_mA 0x17
270dee8268fSThierry Reding #define DRIVE_CURRENT_10_500_mA 0x18
271dee8268fSThierry Reding #define DRIVE_CURRENT_10_875_mA 0x19
272dee8268fSThierry Reding #define DRIVE_CURRENT_11_250_mA 0x1a
273dee8268fSThierry Reding #define DRIVE_CURRENT_11_625_mA 0x1b
274dee8268fSThierry Reding #define DRIVE_CURRENT_12_000_mA 0x1c
275dee8268fSThierry Reding #define DRIVE_CURRENT_12_375_mA 0x1d
276dee8268fSThierry Reding #define DRIVE_CURRENT_12_750_mA 0x1e
277dee8268fSThierry Reding #define DRIVE_CURRENT_13_125_mA 0x1f
278dee8268fSThierry Reding #define DRIVE_CURRENT_13_500_mA 0x20
279dee8268fSThierry Reding #define DRIVE_CURRENT_13_875_mA 0x21
280dee8268fSThierry Reding #define DRIVE_CURRENT_14_250_mA 0x22
281dee8268fSThierry Reding #define DRIVE_CURRENT_14_625_mA 0x23
282dee8268fSThierry Reding #define DRIVE_CURRENT_15_000_mA 0x24
283dee8268fSThierry Reding #define DRIVE_CURRENT_15_375_mA 0x25
284dee8268fSThierry Reding #define DRIVE_CURRENT_15_750_mA 0x26
285dee8268fSThierry Reding #define DRIVE_CURRENT_16_125_mA 0x27
286dee8268fSThierry Reding #define DRIVE_CURRENT_16_500_mA 0x28
287dee8268fSThierry Reding #define DRIVE_CURRENT_16_875_mA 0x29
288dee8268fSThierry Reding #define DRIVE_CURRENT_17_250_mA 0x2a
289dee8268fSThierry Reding #define DRIVE_CURRENT_17_625_mA 0x2b
290dee8268fSThierry Reding #define DRIVE_CURRENT_18_000_mA 0x2c
291dee8268fSThierry Reding #define DRIVE_CURRENT_18_375_mA 0x2d
292dee8268fSThierry Reding #define DRIVE_CURRENT_18_750_mA 0x2e
293dee8268fSThierry Reding #define DRIVE_CURRENT_19_125_mA 0x2f
294dee8268fSThierry Reding #define DRIVE_CURRENT_19_500_mA 0x30
295dee8268fSThierry Reding #define DRIVE_CURRENT_19_875_mA 0x31
296dee8268fSThierry Reding #define DRIVE_CURRENT_20_250_mA 0x32
297dee8268fSThierry Reding #define DRIVE_CURRENT_20_625_mA 0x33
298dee8268fSThierry Reding #define DRIVE_CURRENT_21_000_mA 0x34
299dee8268fSThierry Reding #define DRIVE_CURRENT_21_375_mA 0x35
300dee8268fSThierry Reding #define DRIVE_CURRENT_21_750_mA 0x36
301dee8268fSThierry Reding #define DRIVE_CURRENT_22_125_mA 0x37
302dee8268fSThierry Reding #define DRIVE_CURRENT_22_500_mA 0x38
303dee8268fSThierry Reding #define DRIVE_CURRENT_22_875_mA 0x39
304dee8268fSThierry Reding #define DRIVE_CURRENT_23_250_mA 0x3a
305dee8268fSThierry Reding #define DRIVE_CURRENT_23_625_mA 0x3b
306dee8268fSThierry Reding #define DRIVE_CURRENT_24_000_mA 0x3c
307dee8268fSThierry Reding #define DRIVE_CURRENT_24_375_mA 0x3d
308dee8268fSThierry Reding #define DRIVE_CURRENT_24_750_mA 0x3e
309dee8268fSThierry Reding 
3107d1d28acSMikko Perttunen #define DRIVE_CURRENT_0_000_mA_T114 0x00
3117d1d28acSMikko Perttunen #define DRIVE_CURRENT_0_400_mA_T114 0x01
3127d1d28acSMikko Perttunen #define DRIVE_CURRENT_0_800_mA_T114 0x02
3137d1d28acSMikko Perttunen #define DRIVE_CURRENT_1_200_mA_T114 0x03
3147d1d28acSMikko Perttunen #define DRIVE_CURRENT_1_600_mA_T114 0x04
3157d1d28acSMikko Perttunen #define DRIVE_CURRENT_2_000_mA_T114 0x05
3167d1d28acSMikko Perttunen #define DRIVE_CURRENT_2_400_mA_T114 0x06
3177d1d28acSMikko Perttunen #define DRIVE_CURRENT_2_800_mA_T114 0x07
3187d1d28acSMikko Perttunen #define DRIVE_CURRENT_3_200_mA_T114 0x08
3197d1d28acSMikko Perttunen #define DRIVE_CURRENT_3_600_mA_T114 0x09
3207d1d28acSMikko Perttunen #define DRIVE_CURRENT_4_000_mA_T114 0x0a
3217d1d28acSMikko Perttunen #define DRIVE_CURRENT_4_400_mA_T114 0x0b
3227d1d28acSMikko Perttunen #define DRIVE_CURRENT_4_800_mA_T114 0x0c
3237d1d28acSMikko Perttunen #define DRIVE_CURRENT_5_200_mA_T114 0x0d
3247d1d28acSMikko Perttunen #define DRIVE_CURRENT_5_600_mA_T114 0x0e
3257d1d28acSMikko Perttunen #define DRIVE_CURRENT_6_000_mA_T114 0x0f
3267d1d28acSMikko Perttunen #define DRIVE_CURRENT_6_400_mA_T114 0x10
3277d1d28acSMikko Perttunen #define DRIVE_CURRENT_6_800_mA_T114 0x11
3287d1d28acSMikko Perttunen #define DRIVE_CURRENT_7_200_mA_T114 0x12
3297d1d28acSMikko Perttunen #define DRIVE_CURRENT_7_600_mA_T114 0x13
3307d1d28acSMikko Perttunen #define DRIVE_CURRENT_8_000_mA_T114 0x14
3317d1d28acSMikko Perttunen #define DRIVE_CURRENT_8_400_mA_T114 0x15
3327d1d28acSMikko Perttunen #define DRIVE_CURRENT_8_800_mA_T114 0x16
3337d1d28acSMikko Perttunen #define DRIVE_CURRENT_9_200_mA_T114 0x17
3347d1d28acSMikko Perttunen #define DRIVE_CURRENT_9_600_mA_T114 0x18
3357d1d28acSMikko Perttunen #define DRIVE_CURRENT_10_000_mA_T114 0x19
3367d1d28acSMikko Perttunen #define DRIVE_CURRENT_10_400_mA_T114 0x1a
3377d1d28acSMikko Perttunen #define DRIVE_CURRENT_10_800_mA_T114 0x1b
3387d1d28acSMikko Perttunen #define DRIVE_CURRENT_11_200_mA_T114 0x1c
3397d1d28acSMikko Perttunen #define DRIVE_CURRENT_11_600_mA_T114 0x1d
3407d1d28acSMikko Perttunen #define DRIVE_CURRENT_12_000_mA_T114 0x1e
3417d1d28acSMikko Perttunen #define DRIVE_CURRENT_12_400_mA_T114 0x1f
3427d1d28acSMikko Perttunen #define DRIVE_CURRENT_12_800_mA_T114 0x20
3437d1d28acSMikko Perttunen #define DRIVE_CURRENT_13_200_mA_T114 0x21
3447d1d28acSMikko Perttunen #define DRIVE_CURRENT_13_600_mA_T114 0x22
3457d1d28acSMikko Perttunen #define DRIVE_CURRENT_14_000_mA_T114 0x23
3467d1d28acSMikko Perttunen #define DRIVE_CURRENT_14_400_mA_T114 0x24
3477d1d28acSMikko Perttunen #define DRIVE_CURRENT_14_800_mA_T114 0x25
3487d1d28acSMikko Perttunen #define DRIVE_CURRENT_15_200_mA_T114 0x26
3497d1d28acSMikko Perttunen #define DRIVE_CURRENT_15_600_mA_T114 0x27
3507d1d28acSMikko Perttunen #define DRIVE_CURRENT_16_000_mA_T114 0x28
3517d1d28acSMikko Perttunen #define DRIVE_CURRENT_16_400_mA_T114 0x29
3527d1d28acSMikko Perttunen #define DRIVE_CURRENT_16_800_mA_T114 0x2a
3537d1d28acSMikko Perttunen #define DRIVE_CURRENT_17_200_mA_T114 0x2b
3547d1d28acSMikko Perttunen #define DRIVE_CURRENT_17_600_mA_T114 0x2c
3557d1d28acSMikko Perttunen #define DRIVE_CURRENT_18_000_mA_T114 0x2d
3567d1d28acSMikko Perttunen #define DRIVE_CURRENT_18_400_mA_T114 0x2e
3577d1d28acSMikko Perttunen #define DRIVE_CURRENT_18_800_mA_T114 0x2f
3587d1d28acSMikko Perttunen #define DRIVE_CURRENT_19_200_mA_T114 0x30
3597d1d28acSMikko Perttunen #define DRIVE_CURRENT_19_600_mA_T114 0x31
3607d1d28acSMikko Perttunen #define DRIVE_CURRENT_20_000_mA_T114 0x32
3617d1d28acSMikko Perttunen #define DRIVE_CURRENT_20_400_mA_T114 0x33
3627d1d28acSMikko Perttunen #define DRIVE_CURRENT_20_800_mA_T114 0x34
3637d1d28acSMikko Perttunen #define DRIVE_CURRENT_21_200_mA_T114 0x35
3647d1d28acSMikko Perttunen #define DRIVE_CURRENT_21_600_mA_T114 0x36
3657d1d28acSMikko Perttunen #define DRIVE_CURRENT_22_000_mA_T114 0x37
3667d1d28acSMikko Perttunen #define DRIVE_CURRENT_22_400_mA_T114 0x38
3677d1d28acSMikko Perttunen #define DRIVE_CURRENT_22_800_mA_T114 0x39
3687d1d28acSMikko Perttunen #define DRIVE_CURRENT_23_200_mA_T114 0x3a
3697d1d28acSMikko Perttunen #define DRIVE_CURRENT_23_600_mA_T114 0x3b
3707d1d28acSMikko Perttunen #define DRIVE_CURRENT_24_000_mA_T114 0x3c
3717d1d28acSMikko Perttunen #define DRIVE_CURRENT_24_400_mA_T114 0x3d
3727d1d28acSMikko Perttunen #define DRIVE_CURRENT_24_800_mA_T114 0x3e
3737d1d28acSMikko Perttunen #define DRIVE_CURRENT_25_200_mA_T114 0x3f
3747d1d28acSMikko Perttunen #define DRIVE_CURRENT_25_400_mA_T114 0x40
3757d1d28acSMikko Perttunen #define DRIVE_CURRENT_25_800_mA_T114 0x41
3767d1d28acSMikko Perttunen #define DRIVE_CURRENT_26_200_mA_T114 0x42
3777d1d28acSMikko Perttunen #define DRIVE_CURRENT_26_600_mA_T114 0x43
3787d1d28acSMikko Perttunen #define DRIVE_CURRENT_27_000_mA_T114 0x44
3797d1d28acSMikko Perttunen #define DRIVE_CURRENT_27_400_mA_T114 0x45
3807d1d28acSMikko Perttunen #define DRIVE_CURRENT_27_800_mA_T114 0x46
3817d1d28acSMikko Perttunen #define DRIVE_CURRENT_28_200_mA_T114 0x47
3827d1d28acSMikko Perttunen 
383dee8268fSThierry Reding #define HDMI_NV_PDISP_AUDIO_DEBUG0				0x7f
384dee8268fSThierry Reding #define HDMI_NV_PDISP_AUDIO_DEBUG1				0x80
385dee8268fSThierry Reding #define HDMI_NV_PDISP_AUDIO_DEBUG2				0x81
386dee8268fSThierry Reding 
387dee8268fSThierry Reding #define HDMI_NV_PDISP_AUDIO_FS(x)				(0x82 + (x))
388dee8268fSThierry Reding #define AUDIO_FS_LOW(x)  (((x) & 0xfff) <<  0)
389dee8268fSThierry Reding #define AUDIO_FS_HIGH(x) (((x) & 0xfff) << 16)
390dee8268fSThierry Reding 
391dee8268fSThierry Reding #define HDMI_NV_PDISP_AUDIO_PULSE_WIDTH				0x89
392dee8268fSThierry Reding #define HDMI_NV_PDISP_AUDIO_THRESHOLD				0x8a
393dee8268fSThierry Reding #define HDMI_NV_PDISP_AUDIO_CNTRL0				0x8b
394dee8268fSThierry Reding #define AUDIO_CNTRL0_ERROR_TOLERANCE(x)  (((x) & 0xff) << 0)
395dee8268fSThierry Reding #define AUDIO_CNTRL0_SOURCE_SELECT_AUTO  (0 << 20)
396dee8268fSThierry Reding #define AUDIO_CNTRL0_SOURCE_SELECT_SPDIF (1 << 20)
397dee8268fSThierry Reding #define AUDIO_CNTRL0_SOURCE_SELECT_HDAL  (2 << 20)
398dee8268fSThierry Reding #define AUDIO_CNTRL0_FRAMES_PER_BLOCK(x) (((x) & 0xff) << 24)
399dee8268fSThierry Reding 
400dee8268fSThierry Reding #define HDMI_NV_PDISP_AUDIO_N					0x8c
401dee8268fSThierry Reding #define AUDIO_N_VALUE(x)           (((x) & 0xfffff) << 0)
402dee8268fSThierry Reding #define AUDIO_N_RESETF             (1 << 20)
403dee8268fSThierry Reding #define AUDIO_N_GENERATE_NORMAL    (0 << 24)
404dee8268fSThierry Reding #define AUDIO_N_GENERATE_ALTERNATE (1 << 24)
405dee8268fSThierry Reding 
406dee8268fSThierry Reding #define HDMI_NV_PDISP_HDCPRIF_ROM_TIMING			0x94
407dee8268fSThierry Reding #define HDMI_NV_PDISP_SOR_REFCLK				0x95
408dee8268fSThierry Reding #define SOR_REFCLK_DIV_INT(x)  (((x) & 0xff) << 8)
409dee8268fSThierry Reding #define SOR_REFCLK_DIV_FRAC(x) (((x) & 0x03) << 6)
410dee8268fSThierry Reding 
411dee8268fSThierry Reding #define HDMI_NV_PDISP_CRC_CONTROL				0x96
412dee8268fSThierry Reding #define HDMI_NV_PDISP_INPUT_CONTROL				0x97
413dee8268fSThierry Reding #define HDMI_SRC_DISPLAYA       (0 << 0)
414dee8268fSThierry Reding #define HDMI_SRC_DISPLAYB       (1 << 0)
415dee8268fSThierry Reding #define ARM_VIDEO_RANGE_FULL    (0 << 1)
416dee8268fSThierry Reding #define ARM_VIDEO_RANGE_LIMITED (1 << 1)
417dee8268fSThierry Reding 
418dee8268fSThierry Reding #define HDMI_NV_PDISP_SCRATCH					0x98
419dee8268fSThierry Reding #define HDMI_NV_PDISP_PE_CURRENT				0x99
420dee8268fSThierry Reding #define PE_CURRENT0(x) (((x) & 0xf) << 0)
421dee8268fSThierry Reding #define PE_CURRENT1(x) (((x) & 0xf) << 8)
422dee8268fSThierry Reding #define PE_CURRENT2(x) (((x) & 0xf) << 16)
423dee8268fSThierry Reding #define PE_CURRENT3(x) (((x) & 0xf) << 24)
424dee8268fSThierry Reding 
425dee8268fSThierry Reding #define PE_CURRENT_0_0_mA 0x0
426dee8268fSThierry Reding #define PE_CURRENT_0_5_mA 0x1
427dee8268fSThierry Reding #define PE_CURRENT_1_0_mA 0x2
428dee8268fSThierry Reding #define PE_CURRENT_1_5_mA 0x3
429dee8268fSThierry Reding #define PE_CURRENT_2_0_mA 0x4
430dee8268fSThierry Reding #define PE_CURRENT_2_5_mA 0x5
431dee8268fSThierry Reding #define PE_CURRENT_3_0_mA 0x6
432dee8268fSThierry Reding #define PE_CURRENT_3_5_mA 0x7
433dee8268fSThierry Reding #define PE_CURRENT_4_0_mA 0x8
434dee8268fSThierry Reding #define PE_CURRENT_4_5_mA 0x9
435dee8268fSThierry Reding #define PE_CURRENT_5_0_mA 0xa
436dee8268fSThierry Reding #define PE_CURRENT_5_5_mA 0xb
437dee8268fSThierry Reding #define PE_CURRENT_6_0_mA 0xc
438dee8268fSThierry Reding #define PE_CURRENT_6_5_mA 0xd
439dee8268fSThierry Reding #define PE_CURRENT_7_0_mA 0xe
440dee8268fSThierry Reding #define PE_CURRENT_7_5_mA 0xf
441dee8268fSThierry Reding 
4427d1d28acSMikko Perttunen #define PE_CURRENT_0_mA_T114 0x0
4437d1d28acSMikko Perttunen #define PE_CURRENT_1_mA_T114 0x1
4447d1d28acSMikko Perttunen #define PE_CURRENT_2_mA_T114 0x2
4457d1d28acSMikko Perttunen #define PE_CURRENT_3_mA_T114 0x3
4467d1d28acSMikko Perttunen #define PE_CURRENT_4_mA_T114 0x4
4477d1d28acSMikko Perttunen #define PE_CURRENT_5_mA_T114 0x5
4487d1d28acSMikko Perttunen #define PE_CURRENT_6_mA_T114 0x6
4497d1d28acSMikko Perttunen #define PE_CURRENT_7_mA_T114 0x7
4507d1d28acSMikko Perttunen #define PE_CURRENT_8_mA_T114 0x8
4517d1d28acSMikko Perttunen #define PE_CURRENT_9_mA_T114 0x9
4527d1d28acSMikko Perttunen #define PE_CURRENT_10_mA_T114 0xa
4537d1d28acSMikko Perttunen #define PE_CURRENT_11_mA_T114 0xb
4547d1d28acSMikko Perttunen #define PE_CURRENT_12_mA_T114 0xc
4557d1d28acSMikko Perttunen #define PE_CURRENT_13_mA_T114 0xd
4567d1d28acSMikko Perttunen #define PE_CURRENT_14_mA_T114 0xe
4577d1d28acSMikko Perttunen #define PE_CURRENT_15_mA_T114 0xf
4587d1d28acSMikko Perttunen 
459dee8268fSThierry Reding #define HDMI_NV_PDISP_KEY_CTRL					0x9a
460dee8268fSThierry Reding #define HDMI_NV_PDISP_KEY_DEBUG0				0x9b
461dee8268fSThierry Reding #define HDMI_NV_PDISP_KEY_DEBUG1				0x9c
462dee8268fSThierry Reding #define HDMI_NV_PDISP_KEY_DEBUG2				0x9d
463dee8268fSThierry Reding #define HDMI_NV_PDISP_KEY_HDCP_KEY_0				0x9e
464dee8268fSThierry Reding #define HDMI_NV_PDISP_KEY_HDCP_KEY_1				0x9f
465dee8268fSThierry Reding #define HDMI_NV_PDISP_KEY_HDCP_KEY_2				0xa0
466dee8268fSThierry Reding #define HDMI_NV_PDISP_KEY_HDCP_KEY_3				0xa1
467dee8268fSThierry Reding #define HDMI_NV_PDISP_KEY_HDCP_KEY_TRIG				0xa2
468dee8268fSThierry Reding #define HDMI_NV_PDISP_KEY_SKEY_INDEX				0xa3
469dee8268fSThierry Reding 
470dee8268fSThierry Reding #define HDMI_NV_PDISP_SOR_AUDIO_CNTRL0				0xac
471*2ccb396eSThierry Reding #define  SOR_AUDIO_CNTRL0_SOURCE_SELECT_AUTO	(0 << 20)
472*2ccb396eSThierry Reding #define  SOR_AUDIO_CNTRL0_SOURCE_SELECT_SPDIF	(1 << 20)
473*2ccb396eSThierry Reding #define  SOR_AUDIO_CNTRL0_SOURCE_SELECT_HDAL	(2 << 20)
474*2ccb396eSThierry Reding #define  SOR_AUDIO_CNTRL0_INJECT_NULLSMPL	(1 << 29)
475*2ccb396eSThierry Reding #define HDMI_NV_PDISP_SOR_AUDIO_SPARE0				0xae
476*2ccb396eSThierry Reding #define  SOR_AUDIO_SPARE0_HBR_ENABLE		(1 << 27)
477*2ccb396eSThierry Reding #define HDMI_NV_PDISP_SOR_AUDIO_HDA_CODEC_SCRATCH0		0xba
478*2ccb396eSThierry Reding #define  SOR_AUDIO_HDA_CODEC_SCRATCH0_VALID	(1 << 30)
479*2ccb396eSThierry Reding #define  SOR_AUDIO_HDA_CODEC_SCRATCH0_FMT_MASK	0xffff
480*2ccb396eSThierry Reding #define HDMI_NV_PDISP_SOR_AUDIO_HDA_CODEC_SCRATCH1		0xbb
481dee8268fSThierry Reding #define HDMI_NV_PDISP_SOR_AUDIO_HDA_ELD_BUFWR			0xbc
482dee8268fSThierry Reding #define HDMI_NV_PDISP_SOR_AUDIO_HDA_PRESENSE			0xbd
483*2ccb396eSThierry Reding #define  SOR_AUDIO_HDA_PRESENSE_VALID		(1 << 1)
484*2ccb396eSThierry Reding #define  SOR_AUDIO_HDA_PRESENSE_PRESENT		(1 << 0)
485dee8268fSThierry Reding 
486dee8268fSThierry Reding #define HDMI_NV_PDISP_SOR_AUDIO_AVAL_0320    0xbf
487dee8268fSThierry Reding #define HDMI_NV_PDISP_SOR_AUDIO_AVAL_0441    0xc0
488dee8268fSThierry Reding #define HDMI_NV_PDISP_SOR_AUDIO_AVAL_0882    0xc1
489dee8268fSThierry Reding #define HDMI_NV_PDISP_SOR_AUDIO_AVAL_1764    0xc2
490dee8268fSThierry Reding #define HDMI_NV_PDISP_SOR_AUDIO_AVAL_0480    0xc3
491dee8268fSThierry Reding #define HDMI_NV_PDISP_SOR_AUDIO_AVAL_0960    0xc4
492dee8268fSThierry Reding #define HDMI_NV_PDISP_SOR_AUDIO_AVAL_1920    0xc5
493dee8268fSThierry Reding #define HDMI_NV_PDISP_SOR_AUDIO_AVAL_DEFAULT 0xc5
494dee8268fSThierry Reding 
495*2ccb396eSThierry Reding #define HDMI_NV_PDISP_INT_STATUS			0xcc
496*2ccb396eSThierry Reding #define  INT_SCRATCH		(1 << 3)
497*2ccb396eSThierry Reding #define  INT_CP_REQUEST		(1 << 2)
498*2ccb396eSThierry Reding #define  INT_CODEC_SCRATCH1	(1 << 1)
499*2ccb396eSThierry Reding #define  INT_CODEC_SCRATCH0	(1 << 0)
500*2ccb396eSThierry Reding #define HDMI_NV_PDISP_INT_MASK				0xcd
501*2ccb396eSThierry Reding #define HDMI_NV_PDISP_INT_ENABLE			0xce
502*2ccb396eSThierry Reding 
5037d1d28acSMikko Perttunen #define HDMI_NV_PDISP_SOR_IO_PEAK_CURRENT		0xd1
5047d1d28acSMikko Perttunen #define PEAK_CURRENT_LANE0(x) (((x) & 0x7f) <<  0)
5057d1d28acSMikko Perttunen #define PEAK_CURRENT_LANE1(x) (((x) & 0x7f) <<  8)
5067d1d28acSMikko Perttunen #define PEAK_CURRENT_LANE2(x) (((x) & 0x7f) << 16)
5077d1d28acSMikko Perttunen #define PEAK_CURRENT_LANE3(x) (((x) & 0x7f) << 24)
5087d1d28acSMikko Perttunen 
5097d1d28acSMikko Perttunen #define PEAK_CURRENT_0_000_mA 0x00
5107d1d28acSMikko Perttunen #define PEAK_CURRENT_0_200_mA 0x01
5117d1d28acSMikko Perttunen #define PEAK_CURRENT_0_400_mA 0x02
5127d1d28acSMikko Perttunen #define PEAK_CURRENT_0_600_mA 0x03
5137d1d28acSMikko Perttunen #define PEAK_CURRENT_0_800_mA 0x04
5147d1d28acSMikko Perttunen #define PEAK_CURRENT_1_000_mA 0x05
5157d1d28acSMikko Perttunen #define PEAK_CURRENT_1_200_mA 0x06
5167d1d28acSMikko Perttunen #define PEAK_CURRENT_1_400_mA 0x07
5177d1d28acSMikko Perttunen #define PEAK_CURRENT_1_600_mA 0x08
5187d1d28acSMikko Perttunen #define PEAK_CURRENT_1_800_mA 0x09
5197d1d28acSMikko Perttunen #define PEAK_CURRENT_2_000_mA 0x0a
5207d1d28acSMikko Perttunen #define PEAK_CURRENT_2_200_mA 0x0b
5217d1d28acSMikko Perttunen #define PEAK_CURRENT_2_400_mA 0x0c
5227d1d28acSMikko Perttunen #define PEAK_CURRENT_2_600_mA 0x0d
5237d1d28acSMikko Perttunen #define PEAK_CURRENT_2_800_mA 0x0e
5247d1d28acSMikko Perttunen #define PEAK_CURRENT_3_000_mA 0x0f
5257d1d28acSMikko Perttunen #define PEAK_CURRENT_3_200_mA 0x10
5267d1d28acSMikko Perttunen #define PEAK_CURRENT_3_400_mA 0x11
5277d1d28acSMikko Perttunen #define PEAK_CURRENT_3_600_mA 0x12
5287d1d28acSMikko Perttunen #define PEAK_CURRENT_3_800_mA 0x13
5297d1d28acSMikko Perttunen #define PEAK_CURRENT_4_000_mA 0x14
5307d1d28acSMikko Perttunen #define PEAK_CURRENT_4_200_mA 0x15
5317d1d28acSMikko Perttunen #define PEAK_CURRENT_4_400_mA 0x16
5327d1d28acSMikko Perttunen #define PEAK_CURRENT_4_600_mA 0x17
5337d1d28acSMikko Perttunen #define PEAK_CURRENT_4_800_mA 0x18
5347d1d28acSMikko Perttunen #define PEAK_CURRENT_5_000_mA 0x19
5357d1d28acSMikko Perttunen #define PEAK_CURRENT_5_200_mA 0x1a
5367d1d28acSMikko Perttunen #define PEAK_CURRENT_5_400_mA 0x1b
5377d1d28acSMikko Perttunen #define PEAK_CURRENT_5_600_mA 0x1c
5387d1d28acSMikko Perttunen #define PEAK_CURRENT_5_800_mA 0x1d
5397d1d28acSMikko Perttunen #define PEAK_CURRENT_6_000_mA 0x1e
5407d1d28acSMikko Perttunen #define PEAK_CURRENT_6_200_mA 0x1f
5417d1d28acSMikko Perttunen #define PEAK_CURRENT_6_400_mA 0x20
5427d1d28acSMikko Perttunen #define PEAK_CURRENT_6_600_mA 0x21
5437d1d28acSMikko Perttunen #define PEAK_CURRENT_6_800_mA 0x22
5447d1d28acSMikko Perttunen #define PEAK_CURRENT_7_000_mA 0x23
5457d1d28acSMikko Perttunen #define PEAK_CURRENT_7_200_mA 0x24
5467d1d28acSMikko Perttunen #define PEAK_CURRENT_7_400_mA 0x25
5477d1d28acSMikko Perttunen #define PEAK_CURRENT_7_600_mA 0x26
5487d1d28acSMikko Perttunen #define PEAK_CURRENT_7_800_mA 0x27
5497d1d28acSMikko Perttunen #define PEAK_CURRENT_8_000_mA 0x28
5507d1d28acSMikko Perttunen #define PEAK_CURRENT_8_200_mA 0x29
5517d1d28acSMikko Perttunen #define PEAK_CURRENT_8_400_mA 0x2a
5527d1d28acSMikko Perttunen #define PEAK_CURRENT_8_600_mA 0x2b
5537d1d28acSMikko Perttunen #define PEAK_CURRENT_8_800_mA 0x2c
5547d1d28acSMikko Perttunen #define PEAK_CURRENT_9_000_mA 0x2d
5557d1d28acSMikko Perttunen #define PEAK_CURRENT_9_200_mA 0x2e
5567d1d28acSMikko Perttunen #define PEAK_CURRENT_9_400_mA 0x2f
5577d1d28acSMikko Perttunen 
5587d1d28acSMikko Perttunen #define HDMI_NV_PDISP_SOR_PAD_CTLS0		0xd2
5597d1d28acSMikko Perttunen 
560dee8268fSThierry Reding #endif /* TEGRA_HDMI_H */
561