1 //<MStar Software>
2 //******************************************************************************
3 // MStar Software
4 // Copyright (c) 2010 - 2012 MStar Semiconductor, Inc. All rights reserved.
5 // All software, firmware and related documentation herein ("MStar Software") are
6 // intellectual property of MStar Semiconductor, Inc. ("MStar") and protected by
7 // law, including, but not limited to, copyright law and international treaties.
8 // Any use, modification, reproduction, retransmission, or republication of all
9 // or part of MStar Software is expressly prohibited, unless prior written
10 // permission has been granted by MStar.
11 //
12 // By accessing, browsing and/or using MStar Software, you acknowledge that you
13 // have read, understood, and agree, to be bound by below terms ("Terms") and to
14 // comply with all applicable laws and regulations:
15 //
16 // 1. MStar shall retain any and all right, ownership and interest to MStar
17 // Software and any modification/derivatives thereof.
18 // No right, ownership, or interest to MStar Software and any
19 // modification/derivatives thereof is transferred to you under Terms.
20 //
21 // 2. You understand that MStar Software might include, incorporate or be
22 // supplied together with third party`s software and the use of MStar
23 // Software may require additional licenses from third parties.
24 // Therefore, you hereby agree it is your sole responsibility to separately
25 // obtain any and all third party right and license necessary for your use of
26 // such third party`s software.
27 //
28 // 3. MStar Software and any modification/derivatives thereof shall be deemed as
29 // MStar`s confidential information and you agree to keep MStar`s
30 // confidential information in strictest confidence and not disclose to any
31 // third party.
32 //
33 // 4. MStar Software is provided on an "AS IS" basis without warranties of any
34 // kind. Any warranties are hereby expressly disclaimed by MStar, including
35 // without limitation, any warranties of merchantability, non-infringement of
36 // intellectual property rights, fitness for a particular purpose, error free
37 // and in conformity with any international standard. You agree to waive any
38 // claim against MStar for any loss, damage, cost or expense that you may
39 // incur related to your use of MStar Software.
40 // In no event shall MStar be liable for any direct, indirect, incidental or
41 // consequential damages, including without limitation, lost of profit or
42 // revenues, lost or damage of data, and unauthorized system use.
43 // You agree that this Section 4 shall still apply without being affected
44 // even if MStar Software has been modified by MStar in accordance with your
45 // request or instruction for your use, except otherwise agreed by both
46 // parties in writing.
47 //
48 // 5. If requested, MStar may from time to time provide technical supports or
49 // services in relation with MStar Software to you for your use of
50 // MStar Software in conjunction with your or your customer`s product
51 // ("Services").
52 // You understand and agree that, except otherwise agreed by both parties in
53 // writing, Services are provided on an "AS IS" basis and the warranty
54 // disclaimer set forth in Section 4 above shall apply.
55 //
56 // 6. Nothing contained herein shall be construed as by implication, estoppels
57 // or otherwise:
58 // (a) conferring any license or right to use MStar name, trademark, service
59 // mark, symbol or any other identification;
60 // (b) obligating MStar or any of its affiliates to furnish any person,
61 // including without limitation, you and your customers, any assistance
62 // of any kind whatsoever, or any information; or
63 // (c) conferring any license or right under any intellectual property right.
64 //
65 // 7. These terms shall be governed by and construed in accordance with the laws
66 // of Taiwan, R.O.C., excluding its conflict of law rules.
67 // Any and all dispute arising out hereof or related hereto shall be finally
68 // settled by arbitration referred to the Chinese Arbitration Association,
69 // Taipei in accordance with the ROC Arbitration Law and the Arbitration
70 // Rules of the Association by three (3) arbitrators appointed in accordance
71 // with the said Rules.
72 // The place of arbitration shall be in Taipei, Taiwan and the language shall
73 // be English.
74 // The arbitration award shall be final and binding to both parties.
75 //
76 //******************************************************************************
77 //<MStar Software>
78 ////////////////////////////////////////////////////////////////////////////////
79 //
80 // Copyright (c) 2006-2009 MStar Semiconductor, Inc.
81 // All rights reserved.
82 //
83 // Unless otherwise stipulated in writing, any and all information contained
84 // herein regardless in any format shall remain the sole proprietary of
85 // MStar Semiconductor Inc. and be kept in strict confidence
86 // ("MStar Confidential Information") by the recipient.
87 // Any unauthorized act including without limitation unauthorized disclosure,
88 // copying, use, reproduction, sale, distribution, modification, disassembling,
89 // reverse engineering and compiling of the contents of MStar Confidential
90 // Information is unlawful and strictly prohibited. MStar hereby reserves the
91 // rights to any and all damages, losses, costs and expenses resulting therefrom.
92 //
93 ////////////////////////////////////////////////////////////////////////////////
94
95 ////////////////////////////////////////////////////////////////////////////////////////////////////
96 // file halHDCP.c
97 // @brief HDCP HAL
98 // @author MStar Semiconductor,Inc.
99 ////////////////////////////////////////////////////////////////////////////////////////////////////
100 /*********************************************************************/
101 /* */
102 /* Includes */
103 /* */
104 /*********************************************************************/
105 #include <stdio.h>
106 #include <string.h>
107 #include "MsCommon.h"
108 #include "MsTypes.h"
109 #include "regHDCP.h"
110 #include "halHDCP.h"
111 #include "drvCPU.h"
112
113 #ifndef HAL_HDCP_C
114 #define HAL_HDCP_C
115
116 /*********************************************************************/
117 /* */
118 /* Defines */
119 /* */
120 /*********************************************************************/
121 #define DEF_HDCP_TX_FUNC_EN 0
122
123 #if(defined(CONFIG_MLOG))
124 #include "ULog.h"
125
126 #define HalHDCPLogInfo(format, args...) ULOGI("HDCP", format, ##args)
127 #define HalHDCPLogWarning(format, args...) ULOGW("HDCP", format, ##args)
128 #define HalHDCPLogDebug(format, args...) ULOGD("HDCP", format, ##args)
129 #define HalHDCPLogError(format, args...) ULOGE("HDCP", format, ##args)
130 #define HalHDCPLogFatal(format, args...) ULOGF("HDCP", format, ##args)
131
132 #else
133
134 #define HalHDCPLogInfo(format, args...) printf(format, ##args)
135 #define HalHDCPLogWarning(format, args...) printf(format, ##args)
136 #define HalHDCPLogDebug(format, args...) printf(format, ##args)
137 #define HalHDCPLogError(format, args...) printf(format, ##args)
138 #define HalHDCPLogFatal(format, args...) printf(format, ##args)
139
140 #endif
141
142
143 #define DEF_SIZE_OF_KSXORLC128 16
144 #define DEF_SIZE_OF_RIV 8
145
146 MS_VIRT _gHDCPRegBase = 0x00U;
147 MS_VIRT _gHDCPPMRegBase = 0x00U;
148
149 #define HDCPREG(bank, addr) (*((volatile MS_U16 *)((_gHDCPRegBase + (bank << 1U)) + (addr << 2U))))
150 #define HDCPPMREG(bank, addr) (*((volatile MS_U16 *)((_gHDCPPMRegBase + (bank << 1U)) + (addr << 2U))))
151
152 #if (DEF_HDCP_TX_FUNC_EN == 1) //if chip don't support TX functoin, don't care
153 #define DEF_HDCP14_TX_KEY_REG_BANK 0x000000U
154 #define DEF_HDCP22_TX_KEY_REG_BANK 0x072700U //0x172700U
155 #define DEF_HDCP14_TX_REG_BANK 0x072B00U //0x172B00U
156 #define DEF_HDCP22_TX_REG_BANK 0x072F00U //0x172F00U
157 #endif
158
159 #define DEF_HDCP14_RX_KEY_REG_BANK 0x000000U
160 #define DEF_HDCP22_RX_KEY_REG_BANK 0x073A00U //0x173A00U
161 #define DEF_HDCP14_RX_REG_BANK 0x071200U //0x171200U
162 #define DEF_HDCP22_RX_REG_BANK 0x071200U //0x171200U
163
164 #define DEF_HDCP14_M0_SIZE 64U //bytes
165
166 /*********************************************************************/
167 /* */
168 /* Functions */
169 /* */
170 /*********************************************************************/
171 /*********************************************************************/
172 /* */
173 /* Internal */
174 /* */
175 /*********************************************************************/
176
MHalHdcpRegRead(MS_U32 bank,MS_U16 address)177 MS_U16 MHalHdcpRegRead(MS_U32 bank, MS_U16 address)
178 {
179 return HDCPREG(bank, address);
180 }
181
MHalHdcpRegWrite(MS_U32 bank,MS_U16 address,MS_U16 reg_data)182 void MHalHdcpRegWrite(MS_U32 bank, MS_U16 address, MS_U16 reg_data)
183 {
184 HDCPREG(bank, address) = reg_data;
185 }
186
MHalHdcpRegMaskWrite(MS_U32 bank,MS_U16 address,MS_U16 reg_mask,MS_U16 reg_data)187 void MHalHdcpRegMaskWrite(MS_U32 bank, MS_U16 address, MS_U16 reg_mask, MS_U16 reg_data)
188 {
189 MS_U16 reg_value;
190
191 reg_value = (HDCPREG(bank, address) & (~reg_mask)) | (reg_data & reg_mask);
192 HDCPREG(bank, address) = reg_value;
193 }
194
MHalHdcpPMRegRead(MS_U32 bank,MS_U16 address)195 MS_U16 MHalHdcpPMRegRead(MS_U32 bank, MS_U16 address)
196 {
197 return HDCPPMREG(bank, address);
198 }
199
MHalHdcpPMRegWrite(MS_U32 bank,MS_U16 address,MS_U16 reg_data)200 void MHalHdcpPMRegWrite(MS_U32 bank, MS_U16 address, MS_U16 reg_data)
201 {
202 HDCPPMREG(bank, address) = reg_data;
203 }
204
MHalHdcpPMRegMaskWrite(MS_U32 bank,MS_U16 address,MS_U16 reg_mask,MS_U16 reg_data)205 void MHalHdcpPMRegMaskWrite(MS_U32 bank, MS_U16 address, MS_U16 reg_mask, MS_U16 reg_data)
206 {
207 MS_U16 reg_value;
208
209 reg_value = (HDCPPMREG(bank, address) & (~reg_mask)) | (reg_data & reg_mask);
210 HDCPPMREG(bank, address) = reg_value;
211 }
212
213 /*********************************************************************/
214 /* */
215 /* External */
216 /* */
217 /*********************************************************************/
MHal_HDCP_HDCP14TxInitHdcp(MS_U8 u8PortIdx)218 void MHal_HDCP_HDCP14TxInitHdcp(MS_U8 u8PortIdx)
219 {
220 return; //this project has no tx port
221 }
222
MHal_HDCP_HDCP14TxLoadKey(MS_U8 * pu8KeyData,MS_BOOL bUseKmNewMode)223 void MHal_HDCP_HDCP14TxLoadKey(MS_U8* pu8KeyData, MS_BOOL bUseKmNewMode)
224 {
225 return; //this project has no tx port
226 }
227
MHal_HDCP_HDCP14TxSetAuthPass(MS_U8 u8PortIdx)228 void MHal_HDCP_HDCP14TxSetAuthPass(MS_U8 u8PortIdx)
229 {
230 return; //this project has no tx port
231 }
232
MHal_HDCP_HDCP14TxEnableENC_EN(MS_U8 u8PortIdx,MS_BOOL bEnable)233 void MHal_HDCP_HDCP14TxEnableENC_EN(MS_U8 u8PortIdx, MS_BOOL bEnable)
234 {
235 return; //this project has no tx port
236 }
237
MHal_HDCP_HDCP14TxProcessAn(MS_U8 u8PortIdx,MS_BOOL bUseInternalAn,MS_U8 * pu8An)238 void MHal_HDCP_HDCP14TxProcessAn(MS_U8 u8PortIdx, MS_BOOL bUseInternalAn, MS_U8* pu8An)
239 {
240 return; //this project has no tx port
241 }
242
243
MHal_HDCP_HDCP14TxGetAKSV(MS_U8 u8PortIdx,MS_U8 * pu8Aksv)244 void MHal_HDCP_HDCP14TxGetAKSV(MS_U8 u8PortIdx, MS_U8* pu8Aksv)
245 {
246 return; //this project has no tx port
247 }
248
249
MHal_HDCP_HDCP14TxCompareRi(MS_U8 u8PortIdx,MS_U8 * pu8SinkRi)250 MS_BOOL MHal_HDCP_HDCP14TxCompareRi(MS_U8 u8PortIdx, MS_U8* pu8SinkRi)
251 {
252 return FALSE; //this project has no tx port
253 }
254
255
MHal_HDCP_HDCP14TxConfigMode(MS_U8 u8PortIdx,MS_U8 u8Mode)256 void MHal_HDCP_HDCP14TxConfigMode(MS_U8 u8PortIdx, MS_U8 u8Mode)
257 {
258 return; //this project has no tx port
259 }
260
261
MHal_HDCP_HDCP14TxGenerateCipher(MS_U8 u8PortIdx,MS_U8 * pu8Bksv)262 void MHal_HDCP_HDCP14TxGenerateCipher(MS_U8 u8PortIdx, MS_U8* pu8Bksv)
263 {
264 return; //this project has no tx port
265
266
267 }
268
MHal_HDCP_HDCP14TxProcessR0(MS_U8 u8PortIdx)269 MS_BOOL MHal_HDCP_HDCP14TxProcessR0(MS_U8 u8PortIdx)
270 {
271 return FALSE; //this project has no tx port
272 }
273
MHal_HDCP_HDCP14TxGetM0(MS_U8 u8PortIdx,MS_U8 * pu8M0)274 void MHal_HDCP_HDCP14TxGetM0(MS_U8 u8PortIdx, MS_U8* pu8M0)
275 {
276 return;
277 }
278
MHal_HDCP_HDCP14GetM0(MS_U8 u8PortIdx,MS_U8 * pu8Data)279 void MHal_HDCP_HDCP14GetM0(MS_U8 u8PortIdx, MS_U8 *pu8Data)
280 {
281 MS_U8 cnt = 0x00;
282 MS_U16 u16BKOffset = 0x00;
283
284 u8PortIdx &= 0x0F;
285 u16BKOffset = u8PortIdx * 0x300;
286
287 for ( cnt = 0; cnt < (DEF_HDCP14_M0_SIZE >> 4); cnt++ )
288 {
289 MS_U16 u16tmpData = 0x00;
290
291 u16tmpData = MHalHdcpRegRead(DEF_HDCP14_RX_REG_BANK + u16BKOffset, 0x0E + cnt);
292
293 *(pu8Data + cnt*2) = (MS_U8)(u16tmpData & 0x00FF);
294 *(pu8Data + cnt*2 + 1) = (MS_U8)((u16tmpData & 0xFF00) >> 8);
295 }
296 }
297
MHal_HDCP_SetBank(MS_U32 u32NonPmBankAddr,MS_U32 u32PmBankAddr)298 void MHal_HDCP_SetBank(MS_U32 u32NonPmBankAddr, MS_U32 u32PmBankAddr)
299 {
300 HalHDCPLogInfo("u32NonPmBankAddr = 0x%X, u32PmBankAddr = 0x%X\r\n", (unsigned int)u32NonPmBankAddr, (unsigned int)u32PmBankAddr);
301 _gHDCPRegBase = u32NonPmBankAddr;
302 _gHDCPPMRegBase = u32PmBankAddr;
303 }
304
MHal_HDCP_HDCP2TxInit(MS_U8 u8PortIdx,MS_BOOL bEnable)305 void MHal_HDCP_HDCP2TxInit(MS_U8 u8PortIdx, MS_BOOL bEnable)
306 {
307 return; //this project has no tx port
308 }
309
MHal_HDCP_HDCP2TxEnableEncrypt(MS_U8 u8PortIdx,MS_BOOL bEnable)310 void MHal_HDCP_HDCP2TxEnableEncrypt(MS_U8 u8PortIdx, MS_BOOL bEnable)
311 {
312 return;
313 }
314
MHal_HDCP_HDCP2TxFillCipherKey(MS_U8 u8PortIdx,MS_U8 * pu8Riv,MS_U8 * pu8KsXORLC128)315 void MHal_HDCP_HDCP2TxFillCipherKey(MS_U8 u8PortIdx, MS_U8 *pu8Riv, MS_U8 *pu8KsXORLC128)
316 {
317 return;
318 }
319
MHal_HDCP_HDCP2TxGetCipherState(MS_U8 u8PortIdx,MS_U8 * pu8State)320 void MHal_HDCP_HDCP2TxGetCipherState(MS_U8 u8PortIdx, MS_U8 *pu8State)
321 {
322 return;
323 }
324
MHal_HDCP_HDCP2RxProcessCipher(MS_U8 u8PortIdx,MS_U8 * pu8Riv,MS_U8 * pu8ContentKey)325 void MHal_HDCP_HDCP2RxProcessCipher(MS_U8 u8PortIdx, MS_U8* pu8Riv, MS_U8 *pu8ContentKey)
326 {
327 MS_U8 cnt = 0;
328 MS_U16 u16BKOffset = 0x00;
329 MS_U16 u16RegOffset = 0x00;
330
331 u16BKOffset = u8PortIdx * 0x300;
332 u16RegOffset = u8PortIdx * 0x0C;
333
334 HalHDCPLogDebug("%s:: PortIdx : BKOffset : RegOffset = 0x%X : 0x%X : 0x%X\r\n", __FUNCTION__, u8PortIdx, u16BKOffset, u16RegOffset);
335
336 //Ks^LC128
337 for ( cnt = 0; cnt < (DEF_SIZE_OF_KSXORLC128>>1); cnt++)
338 MHalHdcpRegWrite(DEF_HDCP22_RX_KEY_REG_BANK, u16RegOffset + 0x30 + (DEF_SIZE_OF_KSXORLC128 >> 1) - 1 - cnt, *(pu8ContentKey + cnt*2 + 1)|(*(pu8ContentKey + cnt*2)<<8));
339
340 //Riv
341 for ( cnt = 0; cnt < (DEF_SIZE_OF_RIV>>1); cnt++)
342 MHalHdcpRegWrite(DEF_HDCP22_RX_KEY_REG_BANK, u16RegOffset + 0x38 + (DEF_SIZE_OF_RIV >> 1) - 1 - cnt, *(pu8Riv + cnt*2 + 1)|(*(pu8Riv + cnt*2)<<8));
343
344 //Set SKE successful
345 MHalHdcpRegMaskWrite(DEF_HDCP22_RX_REG_BANK + u16BKOffset, 0x4E, 0x0001, 0x0001);
346 }
347
MHal_HDCP_HDCP2RxGetCipherState(MS_U8 u8PortIdx,MS_U8 * pu8State)348 void MHal_HDCP_HDCP2RxGetCipherState(MS_U8 u8PortIdx, MS_U8 *pu8State)
349 {
350 MS_U16 u16BKOffset = 0x00;
351 //MS_U16 u16RegOffset = 0x00;
352
353 u16BKOffset = u8PortIdx * 0x300;
354
355 *pu8State = MHalHdcpRegRead(DEF_HDCP22_RX_REG_BANK + u16BKOffset, 0x4E) & 0x01;
356 }
357
358 #endif //#ifndef HAL_HDCP_C
359