1 | /* SPDX-License-Identifier: MIT */ |
2 | /* |
3 | * Copyright © 2022 Intel Corporation |
4 | */ |
5 | |
6 | #ifndef __INTEL_HDCP_REGS_H__ |
7 | #define __INTEL_HDCP_REGS_H__ |
8 | |
9 | #include "intel_display_reg_defs.h" |
10 | |
11 | #define TRANS_HDCP(__i915) (DISPLAY_VER(__i915) >= 12) |
12 | |
13 | /* HDCP Key Registers */ |
14 | #define HDCP_KEY_CONF _MMIO(0x66c00) |
15 | #define HDCP_AKSV_SEND_TRIGGER REG_BIT(31) |
16 | #define HDCP_CLEAR_KEYS_TRIGGER REG_BIT(30) |
17 | #define HDCP_KEY_LOAD_TRIGGER REG_BIT(8) |
18 | #define HDCP_KEY_STATUS _MMIO(0x66c04) |
19 | #define HDCP_FUSE_IN_PROGRESS REG_BIT(7) |
20 | #define HDCP_FUSE_ERROR REG_BIT(6) |
21 | #define HDCP_FUSE_DONE REG_BIT(5) |
22 | #define HDCP_KEY_LOAD_STATUS REG_BIT(1) |
23 | #define HDCP_KEY_LOAD_DONE REG_BIT(0) |
24 | #define HDCP_AKSV_LO _MMIO(0x66c10) |
25 | #define HDCP_AKSV_HI _MMIO(0x66c14) |
26 | |
27 | /* HDCP Repeater Registers */ |
28 | #define HDCP_REP_CTL _MMIO(0x66d00) |
29 | #define HDCP_TRANSA_REP_PRESENT REG_BIT(31) |
30 | #define HDCP_TRANSB_REP_PRESENT REG_BIT(30) |
31 | #define HDCP_TRANSC_REP_PRESENT REG_BIT(29) |
32 | #define HDCP_TRANSD_REP_PRESENT REG_BIT(28) |
33 | #define HDCP_DDIB_REP_PRESENT REG_BIT(30) |
34 | #define HDCP_DDIA_REP_PRESENT REG_BIT(29) |
35 | #define HDCP_DDIC_REP_PRESENT REG_BIT(28) |
36 | #define HDCP_DDID_REP_PRESENT REG_BIT(27) |
37 | #define HDCP_DDIF_REP_PRESENT REG_BIT(26) |
38 | #define HDCP_DDIE_REP_PRESENT REG_BIT(25) |
39 | #define HDCP_TRANSA_SHA1_M0 (1 << 20) |
40 | #define HDCP_TRANSB_SHA1_M0 (2 << 20) |
41 | #define HDCP_TRANSC_SHA1_M0 (3 << 20) |
42 | #define HDCP_TRANSD_SHA1_M0 (4 << 20) |
43 | #define HDCP_DDIB_SHA1_M0 (1 << 20) |
44 | #define HDCP_DDIA_SHA1_M0 (2 << 20) |
45 | #define HDCP_DDIC_SHA1_M0 (3 << 20) |
46 | #define HDCP_DDID_SHA1_M0 (4 << 20) |
47 | #define HDCP_DDIF_SHA1_M0 (5 << 20) |
48 | #define HDCP_DDIE_SHA1_M0 (6 << 20) /* Bspec says 5? */ |
49 | #define HDCP_SHA1_BUSY REG_BIT(16) |
50 | #define HDCP_SHA1_READY REG_BIT(17) |
51 | #define HDCP_SHA1_COMPLETE REG_BIT(18) |
52 | #define HDCP_SHA1_V_MATCH REG_BIT(19) |
53 | #define HDCP_SHA1_TEXT_32 (1 << 1) |
54 | #define HDCP_SHA1_COMPLETE_HASH (2 << 1) |
55 | #define HDCP_SHA1_TEXT_24 (4 << 1) |
56 | #define HDCP_SHA1_TEXT_16 (5 << 1) |
57 | #define HDCP_SHA1_TEXT_8 (6 << 1) |
58 | #define HDCP_SHA1_TEXT_0 (7 << 1) |
59 | #define HDCP_SHA_V_PRIME_H0 _MMIO(0x66d04) |
60 | #define HDCP_SHA_V_PRIME_H1 _MMIO(0x66d08) |
61 | #define HDCP_SHA_V_PRIME_H2 _MMIO(0x66d0C) |
62 | #define HDCP_SHA_V_PRIME_H3 _MMIO(0x66d10) |
63 | #define HDCP_SHA_V_PRIME_H4 _MMIO(0x66d14) |
64 | #define HDCP_SHA_V_PRIME(h) _MMIO((0x66d04 + (h) * 4)) |
65 | #define HDCP_SHA_TEXT _MMIO(0x66d18) |
66 | |
67 | /* HDCP Auth Registers */ |
68 | #define _PORTA_HDCP_AUTHENC 0x66800 |
69 | #define _PORTB_HDCP_AUTHENC 0x66500 |
70 | #define _PORTC_HDCP_AUTHENC 0x66600 |
71 | #define _PORTD_HDCP_AUTHENC 0x66700 |
72 | #define _PORTE_HDCP_AUTHENC 0x66A00 |
73 | #define _PORTF_HDCP_AUTHENC 0x66900 |
74 | #define _PORT_HDCP_AUTHENC(port, x) _MMIO(_PICK(port, \ |
75 | _PORTA_HDCP_AUTHENC, \ |
76 | _PORTB_HDCP_AUTHENC, \ |
77 | _PORTC_HDCP_AUTHENC, \ |
78 | _PORTD_HDCP_AUTHENC, \ |
79 | _PORTE_HDCP_AUTHENC, \ |
80 | _PORTF_HDCP_AUTHENC) + (x)) |
81 | #define PORT_HDCP_CONF(port) _PORT_HDCP_AUTHENC(port, 0x0) |
82 | #define _TRANSA_HDCP_CONF 0x66400 |
83 | #define _TRANSB_HDCP_CONF 0x66500 |
84 | #define TRANS_HDCP_CONF(trans) _MMIO_TRANS(trans, _TRANSA_HDCP_CONF, \ |
85 | _TRANSB_HDCP_CONF) |
86 | #define HDCP_CONF(dev_priv, trans, port) \ |
87 | (TRANS_HDCP(dev_priv) ? \ |
88 | TRANS_HDCP_CONF(trans) : \ |
89 | PORT_HDCP_CONF(port)) |
90 | |
91 | #define HDCP_CONF_CAPTURE_AN REG_BIT(0) |
92 | #define HDCP_CONF_AUTH_AND_ENC (REG_BIT(1) | REG_BIT(0)) |
93 | #define PORT_HDCP_ANINIT(port) _PORT_HDCP_AUTHENC(port, 0x4) |
94 | #define _TRANSA_HDCP_ANINIT 0x66404 |
95 | #define _TRANSB_HDCP_ANINIT 0x66504 |
96 | #define TRANS_HDCP_ANINIT(trans) _MMIO_TRANS(trans, \ |
97 | _TRANSA_HDCP_ANINIT, \ |
98 | _TRANSB_HDCP_ANINIT) |
99 | #define HDCP_ANINIT(dev_priv, trans, port) \ |
100 | (TRANS_HDCP(dev_priv) ? \ |
101 | TRANS_HDCP_ANINIT(trans) : \ |
102 | PORT_HDCP_ANINIT(port)) |
103 | |
104 | #define PORT_HDCP_ANLO(port) _PORT_HDCP_AUTHENC(port, 0x8) |
105 | #define _TRANSA_HDCP_ANLO 0x66408 |
106 | #define _TRANSB_HDCP_ANLO 0x66508 |
107 | #define TRANS_HDCP_ANLO(trans) _MMIO_TRANS(trans, _TRANSA_HDCP_ANLO, \ |
108 | _TRANSB_HDCP_ANLO) |
109 | #define HDCP_ANLO(dev_priv, trans, port) \ |
110 | (TRANS_HDCP(dev_priv) ? \ |
111 | TRANS_HDCP_ANLO(trans) : \ |
112 | PORT_HDCP_ANLO(port)) |
113 | |
114 | #define PORT_HDCP_ANHI(port) _PORT_HDCP_AUTHENC(port, 0xC) |
115 | #define _TRANSA_HDCP_ANHI 0x6640C |
116 | #define _TRANSB_HDCP_ANHI 0x6650C |
117 | #define TRANS_HDCP_ANHI(trans) _MMIO_TRANS(trans, _TRANSA_HDCP_ANHI, \ |
118 | _TRANSB_HDCP_ANHI) |
119 | #define HDCP_ANHI(dev_priv, trans, port) \ |
120 | (TRANS_HDCP(dev_priv) ? \ |
121 | TRANS_HDCP_ANHI(trans) : \ |
122 | PORT_HDCP_ANHI(port)) |
123 | |
124 | #define PORT_HDCP_BKSVLO(port) _PORT_HDCP_AUTHENC(port, 0x10) |
125 | #define _TRANSA_HDCP_BKSVLO 0x66410 |
126 | #define _TRANSB_HDCP_BKSVLO 0x66510 |
127 | #define TRANS_HDCP_BKSVLO(trans) _MMIO_TRANS(trans, \ |
128 | _TRANSA_HDCP_BKSVLO, \ |
129 | _TRANSB_HDCP_BKSVLO) |
130 | #define HDCP_BKSVLO(dev_priv, trans, port) \ |
131 | (TRANS_HDCP(dev_priv) ? \ |
132 | TRANS_HDCP_BKSVLO(trans) : \ |
133 | PORT_HDCP_BKSVLO(port)) |
134 | |
135 | #define PORT_HDCP_BKSVHI(port) _PORT_HDCP_AUTHENC(port, 0x14) |
136 | #define _TRANSA_HDCP_BKSVHI 0x66414 |
137 | #define _TRANSB_HDCP_BKSVHI 0x66514 |
138 | #define TRANS_HDCP_BKSVHI(trans) _MMIO_TRANS(trans, \ |
139 | _TRANSA_HDCP_BKSVHI, \ |
140 | _TRANSB_HDCP_BKSVHI) |
141 | #define HDCP_BKSVHI(dev_priv, trans, port) \ |
142 | (TRANS_HDCP(dev_priv) ? \ |
143 | TRANS_HDCP_BKSVHI(trans) : \ |
144 | PORT_HDCP_BKSVHI(port)) |
145 | |
146 | #define PORT_HDCP_RPRIME(port) _PORT_HDCP_AUTHENC(port, 0x18) |
147 | #define _TRANSA_HDCP_RPRIME 0x66418 |
148 | #define _TRANSB_HDCP_RPRIME 0x66518 |
149 | #define TRANS_HDCP_RPRIME(trans) _MMIO_TRANS(trans, \ |
150 | _TRANSA_HDCP_RPRIME, \ |
151 | _TRANSB_HDCP_RPRIME) |
152 | #define HDCP_RPRIME(dev_priv, trans, port) \ |
153 | (TRANS_HDCP(dev_priv) ? \ |
154 | TRANS_HDCP_RPRIME(trans) : \ |
155 | PORT_HDCP_RPRIME(port)) |
156 | |
157 | #define PORT_HDCP_STATUS(port) _PORT_HDCP_AUTHENC(port, 0x1C) |
158 | #define _TRANSA_HDCP_STATUS 0x6641C |
159 | #define _TRANSB_HDCP_STATUS 0x6651C |
160 | #define TRANS_HDCP_STATUS(trans) _MMIO_TRANS(trans, \ |
161 | _TRANSA_HDCP_STATUS, \ |
162 | _TRANSB_HDCP_STATUS) |
163 | #define HDCP_STATUS(dev_priv, trans, port) \ |
164 | (TRANS_HDCP(dev_priv) ? \ |
165 | TRANS_HDCP_STATUS(trans) : \ |
166 | PORT_HDCP_STATUS(port)) |
167 | |
168 | #define HDCP_STATUS_STREAM_A_ENC REG_BIT(31) |
169 | #define HDCP_STATUS_STREAM_B_ENC REG_BIT(30) |
170 | #define HDCP_STATUS_STREAM_C_ENC REG_BIT(29) |
171 | #define HDCP_STATUS_STREAM_D_ENC REG_BIT(28) |
172 | #define HDCP_STATUS_AUTH REG_BIT(21) |
173 | #define HDCP_STATUS_ENC REG_BIT(20) |
174 | #define HDCP_STATUS_RI_MATCH REG_BIT(19) |
175 | #define HDCP_STATUS_R0_READY REG_BIT(18) |
176 | #define HDCP_STATUS_AN_READY REG_BIT(17) |
177 | #define HDCP_STATUS_CIPHER REG_BIT(16) |
178 | #define HDCP_STATUS_FRAME_CNT(x) (((x) >> 8) & 0xff) |
179 | |
180 | /* HDCP2.2 Registers */ |
181 | #define _PORTA_HDCP2_BASE 0x66800 |
182 | #define _PORTB_HDCP2_BASE 0x66500 |
183 | #define _PORTC_HDCP2_BASE 0x66600 |
184 | #define _PORTD_HDCP2_BASE 0x66700 |
185 | #define _PORTE_HDCP2_BASE 0x66A00 |
186 | #define _PORTF_HDCP2_BASE 0x66900 |
187 | #define _PORT_HDCP2_BASE(port, x) _MMIO(_PICK((port), \ |
188 | _PORTA_HDCP2_BASE, \ |
189 | _PORTB_HDCP2_BASE, \ |
190 | _PORTC_HDCP2_BASE, \ |
191 | _PORTD_HDCP2_BASE, \ |
192 | _PORTE_HDCP2_BASE, \ |
193 | _PORTF_HDCP2_BASE) + (x)) |
194 | |
195 | #define PORT_HDCP2_AUTH(port) _PORT_HDCP2_BASE(port, 0x98) |
196 | #define _TRANSA_HDCP2_AUTH 0x66498 |
197 | #define _TRANSB_HDCP2_AUTH 0x66598 |
198 | #define TRANS_HDCP2_AUTH(trans) _MMIO_TRANS(trans, _TRANSA_HDCP2_AUTH, \ |
199 | _TRANSB_HDCP2_AUTH) |
200 | #define AUTH_LINK_AUTHENTICATED REG_BIT(31) |
201 | #define AUTH_LINK_TYPE REG_BIT(30) |
202 | #define AUTH_FORCE_CLR_INPUTCTR REG_BIT(19) |
203 | #define AUTH_CLR_KEYS REG_BIT(18) |
204 | #define HDCP2_AUTH(dev_priv, trans, port) \ |
205 | (TRANS_HDCP(dev_priv) ? \ |
206 | TRANS_HDCP2_AUTH(trans) : \ |
207 | PORT_HDCP2_AUTH(port)) |
208 | |
209 | #define PORT_HDCP2_CTL(port) _PORT_HDCP2_BASE(port, 0xB0) |
210 | #define _TRANSA_HDCP2_CTL 0x664B0 |
211 | #define _TRANSB_HDCP2_CTL 0x665B0 |
212 | #define TRANS_HDCP2_CTL(trans) _MMIO_TRANS(trans, _TRANSA_HDCP2_CTL, \ |
213 | _TRANSB_HDCP2_CTL) |
214 | #define CTL_LINK_ENCRYPTION_REQ REG_BIT(31) |
215 | #define HDCP2_CTL(dev_priv, trans, port) \ |
216 | (TRANS_HDCP(dev_priv) ? \ |
217 | TRANS_HDCP2_CTL(trans) : \ |
218 | PORT_HDCP2_CTL(port)) |
219 | |
220 | #define PORT_HDCP2_STATUS(port) _PORT_HDCP2_BASE(port, 0xB4) |
221 | #define _TRANSA_HDCP2_STATUS 0x664B4 |
222 | #define _TRANSB_HDCP2_STATUS 0x665B4 |
223 | #define TRANS_HDCP2_STATUS(trans) _MMIO_TRANS(trans, \ |
224 | _TRANSA_HDCP2_STATUS, \ |
225 | _TRANSB_HDCP2_STATUS) |
226 | #define LINK_TYPE_STATUS REG_BIT(22) |
227 | #define LINK_AUTH_STATUS REG_BIT(21) |
228 | #define LINK_ENCRYPTION_STATUS REG_BIT(20) |
229 | #define HDCP2_STATUS(dev_priv, trans, port) \ |
230 | (TRANS_HDCP(dev_priv) ? \ |
231 | TRANS_HDCP2_STATUS(trans) : \ |
232 | PORT_HDCP2_STATUS(port)) |
233 | |
234 | #define _PIPEA_HDCP2_STREAM_STATUS 0x668C0 |
235 | #define _PIPEB_HDCP2_STREAM_STATUS 0x665C0 |
236 | #define _PIPEC_HDCP2_STREAM_STATUS 0x666C0 |
237 | #define _PIPED_HDCP2_STREAM_STATUS 0x667C0 |
238 | #define PIPE_HDCP2_STREAM_STATUS(pipe) _MMIO(_PICK((pipe), \ |
239 | _PIPEA_HDCP2_STREAM_STATUS, \ |
240 | _PIPEB_HDCP2_STREAM_STATUS, \ |
241 | _PIPEC_HDCP2_STREAM_STATUS, \ |
242 | _PIPED_HDCP2_STREAM_STATUS)) |
243 | |
244 | #define _TRANSA_HDCP2_STREAM_STATUS 0x664C0 |
245 | #define _TRANSB_HDCP2_STREAM_STATUS 0x665C0 |
246 | #define TRANS_HDCP2_STREAM_STATUS(trans) _MMIO_TRANS(trans, \ |
247 | _TRANSA_HDCP2_STREAM_STATUS, \ |
248 | _TRANSB_HDCP2_STREAM_STATUS) |
249 | #define STREAM_ENCRYPTION_STATUS REG_BIT(31) |
250 | #define STREAM_TYPE_STATUS REG_BIT(30) |
251 | #define HDCP2_STREAM_STATUS(dev_priv, trans, port) \ |
252 | (TRANS_HDCP(dev_priv) ? \ |
253 | TRANS_HDCP2_STREAM_STATUS(trans) : \ |
254 | PIPE_HDCP2_STREAM_STATUS(pipe)) |
255 | |
256 | #define _PORTA_HDCP2_AUTH_STREAM 0x66F00 |
257 | #define _PORTB_HDCP2_AUTH_STREAM 0x66F04 |
258 | #define PORT_HDCP2_AUTH_STREAM(port) _MMIO_PORT(port, \ |
259 | _PORTA_HDCP2_AUTH_STREAM, \ |
260 | _PORTB_HDCP2_AUTH_STREAM) |
261 | #define _TRANSA_HDCP2_AUTH_STREAM 0x66F00 |
262 | #define _TRANSB_HDCP2_AUTH_STREAM 0x66F04 |
263 | #define TRANS_HDCP2_AUTH_STREAM(trans) _MMIO_TRANS(trans, \ |
264 | _TRANSA_HDCP2_AUTH_STREAM, \ |
265 | _TRANSB_HDCP2_AUTH_STREAM) |
266 | #define AUTH_STREAM_TYPE REG_BIT(31) |
267 | #define HDCP2_AUTH_STREAM(dev_priv, trans, port) \ |
268 | (TRANS_HDCP(dev_priv) ? \ |
269 | TRANS_HDCP2_AUTH_STREAM(trans) : \ |
270 | PORT_HDCP2_AUTH_STREAM(port)) |
271 | |
272 | #endif /* __INTEL_HDCP_REGS_H__ */ |
273 | |