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