hv_drv_HdcpRx.h 32 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963964965966967968969970971972973974975976
  1. /**
  2. * @file hv_drv_HdcpRx.h
  3. * @brief Header file of drv module.
  4. *
  5. * @verbatim
  6. * ==============================================================================
  7. * ##### How to use #####
  8. * ==============================================================================
  9. * (+) Use Hv_Drv_Hdcp_GetComIrqFlag(...) Get Hdcp Irq Flag.
  10. * (+) Use Hv_Drv_Hdcp2x_HdmiRxGetMsgState(...) Get Hdmi Msg State.
  11. * (+) Use Hv_Drv_Hdcp2x_HdmiGetKmStoreStat(...) Get Stored Km State.
  12. * (+) Use Hv_Drv_Hdcp2x_HdmiSetKmStoreStat(...) Set Stored Km State.
  13. * (+) Use Hv_Drv_Hdcp2x_DpGetKmStoreStat(...) Get Stored Km State.
  14. * (+) Use Hv_Drv_Hdcp_DpSetVersion(...) Set Hdcp Version.
  15. * (+) Use Hv_Drv_Hdcp_HdmiGetRole(...) Get Hdcp Rx Role.
  16. * (+) Use Hv_Drv_Hdcp1x_DpSetBcaps(...) Set Hdcp Bcaps.
  17. * (+) Use Hv_Drv_Hdcp1x_DrvDpRxSetState(...) Set Hdcp1x state.
  18. * (+) Use Hv_Drv_Hdcp1x_DpRxB1Computations(...) Hdcp2x action process for WrAksv state.
  19. * (+) Use Hv_Drv_Hdcp1x_HdmiRxB1Computations(...) Hdcp2x action process for WrAksv state.
  20. * (+) Use Hv_Drv_Hdcp1x_HdmiRxInit(...) Hdcp1x init for Hdmi.
  21. * (+) Use Hv_Drv_Hdcp1x_DpRxInit(...) Hdcp1x init for Dp.
  22. * (+) Use Hv_Drv_Hdcp2x_DpRxB0ProcMsgAKESendCert(...) Hdcp2x Action process for WrAKEInit State.
  23. * (+) Use Hv_Drv_Hdcp2x_HdmiRxB0ProcMsgAKESendCert(...) Hdcp2x Action process for WrAKEInit State.
  24. * (+) Use Hv_Drv_Hdcp2x_DpRxB1ProcMsgAKENoStoredKm(...) Hdcp2x Action process for WrNoStoredKm State.
  25. * (+) Use Hv_Drv_Hdcp2x_HdmiRxB1ProcMsgAKENoStoredKm(...) Hdcp2x Action process for WrNoStoredKm State.
  26. * (+) Use Hv_Drv_Hdcp2x_DpRxB1ProcMsgAKEStoredKm(...) Hdcp2x Action process for WrStoredKm State.
  27. * (+) Use Hv_Drv_Hdcp2x_HdmiRxB1ProcMsgAKEStoredKm(...) Hdcp2x Action process for WrStoredKm State.
  28. * (+) Use Hv_Drv_Hdcp2x_DpRxB1ProcAKEPairing(...) Hdcp2x Action process for RdHPrime State.
  29. * (+) Use Hv_Drv_Hdcp2x_HdmiRxB1ProcAKEPairing(...) Hdcp2x Action process for RdHPrime State.
  30. * (+) Use Hv_Drv_Hdcp2x_DpRxB2LCSendLPrime(...) Hdcp2x Action process for WrLPrime State.
  31. * (+) Use Hv_Drv_Hdcp2x_HdmiRxB2LCSendLPrime(...) Hdcp2x Action process for WrLPrime State.
  32. * (+) Use Hv_Drv_Hdcp2x_DpRxB3ComputeKs(...) Hdcp2x Action process for WrAKESendEks State.
  33. * (+) Use Hv_Drv_Hdcp2x_HdmiRxB3ComputeKs(...) Hdcp2x Action process for WrAKESendEks State.
  34. * (+) Use Hv_Drv_Hdcp2x_DpRxB4Authenticated(...) Hdcp2x Action process for ComputeEksDone State.
  35. * (+) Use Hv_Drv_Hdcp2x_HdmiRxB4Authenticated(...) Hdcp2x Action process for ComputeEksDone State.
  36. * (+) Use Hv_Drv_Hdcp2x_HdmiRxInit(...) Hdcp2x init for Hdmi.
  37. * (+) Use Hv_Drv_Hdcp2x_DpRxInit(...) Hdcp2x init for Dp.
  38. * (+) Use Hv_Drv_Hdcp2x_DpSetKmStoreStat(...) Hdcp2x Set Km Stored State for Dp.
  39. * (+) Use Hv_Drv_Hdcp2x_DpResetLinkIntegrityFailure(...) Reset Link Integrity Failure state.
  40. * (+) Use Hv_Drv_Hdcp2x_HdmiResetLinkIntegrityFailure(...) Reset Link Integrity Failure state.
  41. * (+) Use Hv_Drv_Hdcp_SetProcFlag(...) Set Hdcp Process Flag.
  42. * (+) Use Hv_Drv_Hdcp_GetProcFlag(...) Get Hdcp Process Flag.
  43. *
  44. * @endverbatim
  45. *
  46. * @author HiView SoC Software Team
  47. * @version 1.0.0
  48. * @date 2022-08-30
  49. */
  50. #ifndef _HV_DRV_HDCP_RX_H
  51. #define _HV_DRV_HDCP_RX_H
  52. #include "hv_drv_Hdcp1xRx.h"
  53. #include "hv_drv_Hdcp2xRx.h"
  54. #include "hv_comm_Log.h"
  55. #include "hv_comm_Assert.h"
  56. #include "Common/hv_comm_DataType.h"
  57. #include "hv_chip_Config.h"
  58. #include "hv_comm_Define.h"
  59. #define HV_HDCP_1X_SIZE_AKSV 0x05 /**< Aksv Size */
  60. #define HV_HDCP_1X_SIZE_AN 0x08 /**< An Size */
  61. #define HV_HDCP_1X_SIZE_KM 0x02 /**< KM Key Set Size */
  62. #define HV_HDCP_1X_SIZE_KS 0x02 /**< Ks Size */
  63. #define HV_HDCP_1X_SIZE_M0 0x02 /**< M0 Size */
  64. //#define GET_HDCP_IRQ_OK 1
  65. //#define GET_HDCP_IRQ_NOK 0
  66. /************DP HDCP2x RxStatus Status************ */
  67. typedef enum _Hdcp2xDpRxStatusMask
  68. {
  69. HV_HDCP_2X_RX_STATUS_READY = 0x1,
  70. HV_HDCP_2X_RX_STATUS_H_AVAILABLE = 0x2,
  71. HV_HDCP_2X_RX_STATUS_PAIRING_AVAILABLE = 0x4,
  72. HV_HDCP_2X_RX_STATUS_REAUTH_REQ = 0x8,
  73. HV_HDCP_2X_RX_STATUS_LINK_INTERGITY_FAILTURE = 0x10,
  74. HV_HDCP_2X_RX_STATUS_MASK = 0x1F,
  75. HV_HDCP_2X_RX_STATUS_UNDEFIEND = 0xE0
  76. } Hdcp2xDpRxStatusMask;
  77. typedef enum _Hdcp1xRxStatusMask
  78. {
  79. HV_HDCP_1X_RX_STATUS_READY = 0x1,
  80. HV_HDCP_1X_RX_STATUS_R0_AVAILABLE = 0x2,
  81. HV_HDCP_1X_RX_STATUS_LINK_INTERGITY_FAILTURE = 0x4,
  82. HV_HDCP_1X_RX_STATUS_REAUTH_REQ = 0x8,
  83. HV_HDCP_1X_RX_STATUS_MASK = 0xF,
  84. HV_HDCP_1X_RX_STATUS_UNDEFIEND =0xF0
  85. } Hdcp1xRxStatusMask;
  86. /**************HDMI HDCP INT MASK BEGIN**************************** */
  87. typedef enum
  88. {
  89. HV_HDCP_HDMI_1X_READ_00 = 0,
  90. HV_HDCP_HDMI_1X_READ_RI,
  91. HV_HDCP_HDMI_1X_READ_PJ,
  92. HV_HDCP_HDMI_1X_WRITE_AKSV,
  93. HV_HDCP_HDMI_1X_WRITE_AINFO,
  94. HV_HDCP_HDMI_1X_WRITE_An,
  95. HV_HDCP_HDMI_1X_READ_V,
  96. HV_HDCP_HDMI_1X_READ_BAPS,
  97. HV_HDCP_HDMI_1X_KSV_INFO,
  98. HV_HDCP_HDMI_2X_READ_VERSION,
  99. HV_HDCP_HDMI_2X_UNUSED,
  100. HV_HDCP_HDMI_2X_WRITE_MSG,
  101. HV_HDCP_HDMI_2X_READ_RXSTATUS,
  102. HV_HDCP_HDMI_2X_READ_MSG,
  103. HV_HDCP_HDMI_2X_WRITE_AKEINIT,
  104. HV_HDCP_HDMI_2X_WRITE_AKENOSTOREDKM,
  105. HV_HDCP_HDMI_2X_WRITE_AKESTOREDKM,
  106. HV_HDCP_HDMI_2X_WRITE_LCINIT,
  107. HV_HDCP_HDMI_2X_WRITE_SKESENDEKS,
  108. HV_HDCP_HDMI_2X_WRITE_REPEATERAUTHSENDACK,
  109. HV_HDCP_HDMI_2X_WRITE_REPEATERAUTHSTREAMMANAGE
  110. } HdcpRxHdmiIntBit;
  111. typedef enum
  112. {
  113. HV_HDCP_HDMI_1X_READ_00_DONE_INT = (1 <<(HV_HDCP_HDMI_1X_READ_00)),
  114. HV_HDCP_HDMI_1X_READ_RI_DONE_INT = (1 <<(HV_HDCP_HDMI_1X_READ_RI)),
  115. HV_HDCP_HDMI_1X_READ_PJ_DONE_INT = (1 <<(HV_HDCP_HDMI_1X_READ_PJ)),
  116. HV_HDCP_HDMI_1X_WRITE_AKSV_DONE_INT = (1 <<(HV_HDCP_HDMI_1X_WRITE_AKSV)),
  117. HV_HDCP_HDMI_1X_WRITE_AINFO_DONE_INT = (1 <<(HV_HDCP_HDMI_1X_WRITE_AINFO)),
  118. HV_HDCP_HDMI_1X_WRITE_AN_DONE_INT = (1 <<(HV_HDCP_HDMI_1X_WRITE_An)),
  119. HV_HDCP_HDMI_1X_READ_V_DONE_INT = (1 <<(HV_HDCP_HDMI_1X_READ_V)),
  120. HV_HDCP_HDMI_1X_READ_BAPS_DONE_INT = (1 <<(HV_HDCP_HDMI_1X_READ_BAPS)),
  121. HV_HDCP_HDMI_1X_KSV_FIFO_DONE_INT = (1 <<(HV_HDCP_HDMI_1X_KSV_INFO)),
  122. HV_HDCP_HDMI_2X_READ_HDCP_VERSION_DONE_INT = (1 <<(HV_HDCP_HDMI_2X_READ_VERSION)),
  123. HV_HDCP_HDMI_2X_UNUSED_INT = (1 <<(HV_HDCP_HDMI_2X_UNUSED)),
  124. HV_HDCP_HDMI_2X_WTITE_MSG_DONE_INT = (1 <<(HV_HDCP_HDMI_2X_WRITE_MSG)),
  125. HV_HDCP_HDMI_2X_READ_RXSTATUS_DONE_INT = (1 <<(HV_HDCP_HDMI_2X_READ_RXSTATUS)),
  126. HV_HDCP_HDMI_2X_READ_MSG_DONE_INT = (1 <<(HV_HDCP_HDMI_2X_READ_MSG)),
  127. HV_HDCP_HDMI_2X_WRITE_AKEINIT_DONE_INT = (1 <<(HV_HDCP_HDMI_2X_WRITE_AKEINIT)),
  128. HV_HDCP_HDMI_2X_WRITE_AKENOSTOREDKM_DONE_INT = (1 <<(HV_HDCP_HDMI_2X_WRITE_AKENOSTOREDKM)),
  129. HV_HDCP_HDMI_2X_WRITE_AKESTOREDKM_DONE_INT = (1 <<(HV_HDCP_HDMI_2X_WRITE_AKESTOREDKM)),
  130. HV_HDCP_HDMI_2X_WRITE_LCINIT_DONE_INT = (1 <<(HV_HDCP_HDMI_2X_WRITE_LCINIT)),
  131. HV_HDCP_HDMI_2X_WRITE_SKESENDEKS_DONE_INT = (1 <<(HV_HDCP_HDMI_2X_WRITE_SKESENDEKS)),
  132. HV_HDCP_HDMI_2X_WRITE_REPEATERAUTHSENDACK_DONE_INT = (1 <<(HV_HDCP_HDMI_2X_WRITE_REPEATERAUTHSENDACK)),
  133. HV_HDCP_HDMI_2X_WRITE_REPEATERAUTHSTREAMMANAGE_DONE_INT = (1 <<(HV_HDCP_HDMI_2X_WRITE_REPEATERAUTHSTREAMMANAGE)),
  134. HV_HDCP_HDMI_INT_ALL_ENABLE = (0x001FE7FF),
  135. HV_HDCP_HDMI_INT_1X_ALL_ENABLE = (0x000001FF),
  136. HV_HDCP_HDMI_INT_2X_ALL_ENABLE = (0x001FE600)
  137. } HdcpRxHdmiIntBitMask;
  138. /**************HDMI HDCP INT MASK END**************************** */
  139. /************HDCP IRQ Bit Index************ */
  140. typedef enum _HdcpComIrqNum
  141. {
  142. HDCP0_COM_IRQ_DP_LIC = 0,
  143. HDCP0_COM_IRQ_CM,
  144. HDCP_COM_IRQ_AES,
  145. HDCP_COM_IRQ_EME_OAEP_DECRYPY,
  146. HDCP_COM_IRQ_SHA1,
  147. HDCP_COM_IRQ_KMCALC,
  148. HDCP_COM_IRQ_SHA256,
  149. HDCP_COM_IRQ_EME_OAEP_ENCRYPY,
  150. HDCP_COM_IRQ_EME_CERT_SRM,
  151. HDCP_COM_IRQ_WRITE_OFFSET,
  152. HDCP0_COM_IRQ_LOAD_PJ,
  153. HDCP0_COM_IRQ_LOAD_RI,
  154. HDCP0_COM_IRQ_FIRST_INT,
  155. HDCP1_COM_IRQ_LOAD_PJ,
  156. HDCP1_COM_IRQ_LOAD_RI,
  157. HDCP1_COM_IRQ_CM,
  158. HDCP1_COM_IRQ_DP_LIC,
  159. HDCP1_COM_IRQ_FIRST_INT,
  160. } HdcpComIrqNum;
  161. /************HDCP IRQ Bit Mask************ */
  162. typedef enum _HdcpComIrqMask
  163. {
  164. HV_HDCP0_COM_IRQ_DP_LIC_DONE = 0x1,
  165. HV_HDCP0_COM_IRQ_CM_DONE = 0x2,
  166. HV_HDCP_COM_IRQ_AES_DONE = 0x4,
  167. HV_HDCP_COM_IRQ_EME_OAEP_DECRYPY_DONE = 0x8,
  168. HV_HDCP_COM_IRQ_SHA1_DONE = 0x10,
  169. HV_HDCP_COM_IRQ_KMCALC_DONE = 0x20,
  170. HV_HDCP_COM_IRQ_SHA256_DONE = 0x40,
  171. HV_HDCP_COM_IRQ_EME_OAEP_ENCRYPY_DONE = 0x80,
  172. HV_HDCP_COM_IRQ_CERT_SRM_DONE = 0x0100,
  173. HV_HDCP_COM_IRQ_WRITE_OFFSET_DONE = 0x0200,
  174. HV_HDCP0_COM_IRQ_LOAD_PJ_DONE = 0x0400,
  175. HV_HDCP0_COM_IRQ_LOAD_RI_DONE = 0x0800,
  176. HV_HDCP0_COM_IRQ_FIRST_INT_DONE = 0x1000,
  177. HV_HDCP1_COM_IRQ_LOAD_PJ_DONE = 0x2000,
  178. HV_HDCP1_COM_IRQ_LOAD_RI_DONE = 0x4000,
  179. HV_HDCP1_COM_IRQ_CM_DONE = 0x8000,
  180. HV_HDCP1_COM_IRQ_DP_LIC_DONE = 0x010000,
  181. HV_HDCP1_COM_IRQ_FIRST_INT_DONE = 0x020000,
  182. //HV_HDCP_COM_IRQ_MASK = 0x00FFFF,
  183. HV_HDCP_COM_IRQ_MASK = 0x01C0FF,
  184. } HdcpComIrqMask;
  185. /************HDCP CallBack Func************ */
  186. typedef void (*HdcpRxCallBack)(UINT32 uiRxState, void *arg);
  187. /************HDCP Init Params************ */
  188. typedef struct
  189. {
  190. HdcpPortType enPortType;
  191. HdcpVersion enVersion;
  192. HdcpRole enRole;
  193. HdcpRxCallBack pfRxStateFunc;
  194. } HdcpInitParams;
  195. /************HDCP Rx Struct************ */
  196. typedef enum _HdcpExistStat
  197. {
  198. HDCP_EXIST = 0x01,
  199. HDCP_NO_EXIST = 0xFF
  200. }HdcpExistStat;
  201. typedef enum _HdcpLinkStat
  202. {
  203. HDCP_LINK_NONE = 0xFF,
  204. HDCP_LINK_OK = 0x01,
  205. }HdcpLinkStat;
  206. typedef struct _HdcpControl
  207. {
  208. UCHAR8 ucExist;
  209. UCHAR8 ucLinkStatus;
  210. UCHAR8 ucWorkStatus;
  211. }HdcpControl;
  212. #define HS_HAL_HDMI_HDCP_RXSTAT_SIZE 2
  213. typedef enum _Hdcp2xHdmiRxStatusMask
  214. {
  215. HV_HDCP_2X_HDMI_RX_MSG_SIZE_MASK = 0x03FF,
  216. HV_HDCP_2X_HDMI_RX_STATUS_READY_MASK = 0x0400,
  217. HV_HDCP_2X_HDMI_RX_STATUS_REAUTH_REQ_MASK = 0x0800,
  218. HV_HDCP_2X_HDMI_RX_STATUS_MASK = 0x0FFF,
  219. HV_HDCP_2X_HDMI_RX_STATUS_UNDEFIEND = 0xF000,
  220. HV_HDCP_2X_HDMI_RX_VERSION_MASK = 0x04
  221. } Hdcp2xHdmiRxStatusMask;
  222. /*******HDCP 1.X***********************/
  223. typedef struct _Hdcp1xRxParams
  224. {
  225. UCHAR8 AKsv[HV_HDCP_1X_SIZE_AKSV];
  226. UCHAR8 An[HV_HDCP_1X_SIZE_AN];
  227. UINT32 Km[HV_HDCP_1X_SIZE_KM];
  228. UINT32 Ks[HV_HDCP_1X_SIZE_KS];
  229. UINT32 M0[HV_HDCP_1X_SIZE_M0];
  230. USHORT16 R0;
  231. } Hdcp1xRxParams;
  232. typedef struct
  233. {
  234. Hdcp1xRxParams stParams;
  235. UCHAR8 *DKS;
  236. UCHAR8 *BKsv;
  237. UCHAR8 BCaps; /* DP(1) And Hdmi(0) Is Not the same */
  238. } Hdcp1xRx;
  239. /************HDCP Rx Stored Km State************ */
  240. typedef enum _HdcpKmStoreState
  241. {
  242. HV_HDCP_RX_STORED_KM = 0,
  243. HV_HDCP_NO_STORED_KM,
  244. HV_HDCP_STORED_KM_INVALID
  245. } HdcpKmStoreState;
  246. /**********HDCP Event Begin******************* */
  247. typedef enum _HdcpRxEvtId
  248. {
  249. HdcpRxEvt_Invalid,
  250. /*HDCP 2X Start*/
  251. Hdcp2xRxEvt_WrAKEInit,
  252. Hdcp2xRxEvt_WrAKENoStoredKm,
  253. Hdcp2xRxEvt_WrAKEStoredKm,
  254. Hdcp2xRxEvt_RdHPrime,
  255. Hdcp2xRxEvt_WrLcInit,
  256. Hdcp2xRxEvt_WrAKESendEks,
  257. Hdcp2xRxEvt_ComputeEksDone,
  258. Hdcp2xRxEvt_UpdateStreamType,
  259. Hdcp2xRxEvt_LinkIntegrityFailure,
  260. Hdcp2xRxEvt_Max,
  261. /*HDCP 2X End*/
  262. /*HDCP 1X Start*/
  263. Hdcp1xRxEvt_WrAksv,
  264. Hdcp1xRxEvt_Max,
  265. /*HDCP 1X End*/
  266. }HdcpRxEvtId;
  267. /**********HDCP Event End******************* */
  268. typedef struct _HdcpRx
  269. {
  270. /*HDCP2X RX*/
  271. Hdcp2xRxMsgState enHdcp2xMsgState;
  272. Hdcp2xRx stHdcp2xRx;
  273. HdcpKmStoreState enKmStoreState;
  274. /*HDCP1X RX*/
  275. Hdcp1xRx stHdcp1xRx;
  276. }HdcpRx;
  277. /**
  278. * @brief Get Hdcp Irq Flag.
  279. * @param[in] enComIrqType: Hdcp Irq Mask for bit.
  280. * @return HV_TRUE--Get Int Enable Falg, HV_FALSE--Not Get Int Enable Falg.
  281. */
  282. BOOL Hv_Drv_Hdcp_GetComIrqFlag(HdcpComIrqMask enComIrqType);
  283. /**
  284. * @brief Clear Hdcp Irq Flag of Engine.
  285. * @param[in] None.
  286. * @return None.
  287. */
  288. VOID Hv_Drv_Hdcp_ClrIrqMask( );
  289. /**
  290. * @brief Set Hdcp version.
  291. * @param[in] HdcpVersion: HDCP Version.
  292. * @param[in] ucPortIndex: Port index.
  293. * @return None.
  294. */
  295. VOID Hv_Drv_Hdcp_HdmiSetVersion(UINT32 HdcpVersion, UCHAR8 ucPortIndex);
  296. /**
  297. * @brief Enable HDCP Irq.
  298. * @param[in] void.
  299. * @return None.
  300. */
  301. VOID Hv_Drv_Hdcp_ComIrqEnable(void);
  302. /**
  303. * @brief Get Hdcp Rx Version.
  304. * @param[in] ucPortIndex: Port index.
  305. * @return Hdcp Version.
  306. */
  307. UINT32 Hv_Drv_Hdcp_HdmiGetVersion(UCHAR8 ucPortIndex);
  308. /**
  309. * @brief Get Hdcp Rx Role.
  310. * @param[in] ucPortIndex: Port index.
  311. * @return Hdcp Role.
  312. */
  313. UINT32 Hv_Drv_Hdcp_HdmiGetRole(UCHAR8 ucPortIndex);
  314. /**
  315. * @brief Get Hdcp Interrupt flag Mask.
  316. * @param[in] None.
  317. * @return Flag Value of the HDCP Interrupt.
  318. */
  319. UINT32 Hv_Drv_Hdcp_GetIrqFlag(VOID);
  320. /**
  321. * @brief Hdcp Rx Module init.
  322. * @param[in] None.
  323. * @return None.
  324. */
  325. VOID Hv_Drv_Hdcp_RxModuleInit(UCHAR8 ucHdcpPortIndex);
  326. /**
  327. * @brief Hdcp Rx initi for Hdmi.
  328. * @param[in] ucPortIndex: Port index.
  329. * @return None.
  330. */
  331. //VOID Hv_Drv_Hdcp_HdmiSetHdcpPath(UCHAR8 ucHdcpPortIndex);
  332. /**
  333. * @brief Hdcp Rx initi for Hdmi.
  334. * @param[in] ucPortIndex: Port index.
  335. * @return None.
  336. */
  337. VOID Hv_Drv_Hdcp1x_HdmiSetHdcpPath(UCHAR8 ucHdcpPortIndex);
  338. /**
  339. * @brief Hdcp Rx initi for Hdmi.
  340. * @param[in] ucPortIndex: Port index.
  341. * @return None.
  342. */
  343. VOID Hv_Drv_Hdcp2x_HdmiSetHdcpPath(UCHAR8 ucHdcpPortIndex);
  344. /**
  345. * @brief Hdcp Rx initi for DP.
  346. * @param[in] ucPortIndex: Port index.
  347. * @return None.
  348. */
  349. VOID Hv_Drv_Hdcp1x_DpSetHdcpPath(UCHAR8 ucHdcpPortIndex);
  350. /**
  351. * @brief Hdcp Rx initi for DP.
  352. * @param[in] ucPortIndex: Port index.
  353. * @return None.
  354. */
  355. VOID Hv_Drv_Hdcp2x_DpSetHdcpPath(UCHAR8 ucHdcpPortIndex);
  356. /**
  357. * @brief Hdcp Rx initi for Dp.
  358. * @param[in] ucPortIndex: Port index.
  359. * @return None.
  360. */
  361. VOID Hv_Drv_Hdcp_DpRxInit(UCHAR8 ucPortIndex);
  362. /**
  363. * @brief Load Hdcp Keys.
  364. * @param[in] ucPortIndex: Port index.
  365. * @param[in] enPortType: Port Type DP/HDMI.
  366. * @return None.
  367. */
  368. //VOID Hv_Drv_Hdcp_LoadKeys(HdcpPortType enPortType, UCHAR8 ucPortIndex);
  369. /**
  370. * @brief Get Dp Irq Event.
  371. * @param[in] puiIrqMask: Hdcp Irq mask for Dp.
  372. * @param[in] ucPortIndex: Port index.
  373. * @return None.
  374. */
  375. HdcpRxEvtId Hv_Drv_Hdcp_DpGetIrqEvent(const UINT32* puiIrqMask, UCHAR8 ucPortIndex, HdcpKmStoreState enStoreState);
  376. /**
  377. * @brief Get Hdmi Irq Event.
  378. * @param[in] uiIrqMask: Hdcp Irq mask for Hdmi.
  379. * @param[in] ucPortIndex: Port index.
  380. * @return None.
  381. */
  382. HdcpRxEvtId Hv_Drv_Hdcp_HdmiGetIrqEvent(const UINT32 uiIrqMask, UCHAR8 ucPortIndex, HdcpKmStoreState enKmState, Hdcp2xRxMsgState enMsgState);
  383. /**
  384. * @brief Set Hdcp Process Flag.
  385. * @param[in] bProcFlag: True -- Active Process, False--Nor active Process.
  386. * @return None.
  387. */
  388. VOID Hv_Drv_Hdcp2x_HdmiGetRxMsgFromReg(UCHAR8 *pucData, USHORT16 usMsgSize, UCHAR8 ucPortIndex);
  389. /**
  390. * @brief Get Hdcp Process Flag.
  391. * @param[in] None.
  392. * @return Process Flag.
  393. */
  394. //BOOL Hv_Drv_Hdcp_GetProcFlag(VOID);
  395. /**
  396. * @brief Set Hdcp port mask.
  397. * @param[in] Port index.
  398. * @param[in] Port Type DP or Hdmi.
  399. * @param[in] Dp Port index.
  400. * @return HV_SUCCESS or HV_FAILURE.
  401. */
  402. Status Hv_Drv_Hdcp_SetPortMask(UCHAR8 ucPortIndex, HdcpPortType enPortType, UCHAR8 ucHdcpPortIndex);
  403. /**
  404. * @brief Set Hdcp port mask.
  405. * @param[in] Port index.
  406. * @param[in] Port Type DP or Hdmi.
  407. * @return HV_SUCCESS or HV_FAILURE.
  408. */
  409. //Status Hv_Drv_Hdcp_RmPortMask(LinkPortIndex enPortIndex, UINT32 uiHdcpWorkStat);
  410. /**
  411. * @brief Get Valid Hdcp.
  412. * @param[in] Port index.
  413. * @param[in] Port Type DP or Hdmi.
  414. * @return Hdcp port.
  415. */
  416. //UCHAR8 Hv_Drv_Hdcp_GetValidHdcp(LinkPortIndex enPortIndex, UINT32 uiHdcpWorkStat, UCHAR8 ucPxpFlag);
  417. /**
  418. * @brief Hdcp Auto Mux select.
  419. * @param[in] Port index.
  420. * @param[in] Hdcp Work Status.
  421. * @return Hdcp port.
  422. */
  423. //UCHAR8 Hv_Drv_Hdcp_AutoMuxSel(LinkPortIndex enPortIndex, UINT32 uiHdcpWorkStat);
  424. /**
  425. * @brief Hdcp Get Active Port.
  426. * @return Hdcp port.
  427. */
  428. Status Hv_Drv_Hdcp2x_DpRxGetMsg(HdcpRx* pstHdcpRxIns, HV_HDCP_2X_RX_MSG_ID enMsgId, UCHAR8 ucPortIndex);
  429. /**
  430. * @brief Hdcp Dp Mix Clear.
  431. * @param[in] Port index.
  432. * @return None.
  433. */
  434. VOID Hv_Drv_Hdcp_DpMixClr(UCHAR8 ucHdcpPortIndex);
  435. /*******************Hdcp 1x Function Begin***********************************/
  436. /**
  437. * @brief Get Hdcp Rx state.
  438. * @param[in] ucPortIndex: Port index.
  439. * @return Hdcp Rx state.
  440. */
  441. //UINT32 Hv_Drv_Hdcp1x_DpRxGetState(UCHAR8 ucPortIndex);
  442. /**
  443. * @brief Get Hdcp Rx state.
  444. * @param[in] ucPortIndex: Port index.
  445. * @return Hdcp Rx state.
  446. */
  447. //UINT32 Hv_Drv_Hdcp1x_HdmiRxGetState(UCHAR8 ucPortIndex);
  448. /**
  449. * @brief Set Hdcp Bcaps.
  450. * @param[in] Bcaps: HDCP Bcaps Msg.
  451. * @param[in] ucPortIndex: Port index.
  452. * @return None.
  453. */
  454. VOID Hv_Drv_Hdcp1x_DpSetBcaps(UCHAR8 Bcaps, UCHAR8 ucPortIndex);
  455. /**
  456. * @brief Set Hdcp Bcaps.
  457. * @param[in] Bcaps: HDCP Bcaps Msg.
  458. * @param[in] ucPortIndex: Port index.
  459. * @return None.
  460. */
  461. VOID Hv_Drv_Hdcp1x_HdmiSetBcaps(UCHAR8 Bcaps, UCHAR8 ucPortIndex);
  462. /**
  463. * @brief Set Hdcp1x State.
  464. * @param[in] Hdcp1xRxState: Hdcp1x state.
  465. * @param[in] ucPortIndex: Port index.
  466. * @return None.
  467. */
  468. //VOID Hv_Drv_Hdcp1x_DpRxSetState(UINT32 Hdcp1xRxState, UCHAR8 ucPortIndex);
  469. /**
  470. * @brief Set Hdcp1x State.
  471. * @param[in] Hdcp1xRxState: Hdcp1x state.
  472. * @param[in] ucPortIndex: Port index.
  473. * @return None.
  474. */
  475. VOID Hv_Drv_Hdcp1x_DpRxSetRI(USHORT16 usRI, UCHAR8 ucPortIndex);
  476. /**
  477. * @brief Hdcp1x action process for WrAksv state.
  478. * @param[in] enPortType: Port Type.
  479. * @param[in] ucPortIndex: Port index.
  480. * @return Status, 0-HV_SUCCESS, 1-HV_FAILURE.
  481. */
  482. Status Hv_Drv_Hdcp1x_RxB1Computations(HdcpPortType enPortType, UCHAR8 ucPortIndex);
  483. /**
  484. * @brief Hdcp1x action process for WrAksv state.
  485. * @param[in] ucPortIndex: Port index.
  486. * @return Status, 0-HV_SUCCESS, 1-HV_FAILURE.
  487. */
  488. Status Hv_Drv_Hdcp1x_DpRxGetMsg(HdcpRx* pstHdcpRxIns, UCHAR8 ucPortIndex);
  489. /**
  490. * @brief Hdcp1x action process for WrAksv state.
  491. * @param[in] ucPortIndex: RX Port Index.
  492. * @param[in] ucHdcpIndex: HDCP Port Index.
  493. * @return Status, 0-HV_SUCCESS, 1-HV_FAILURE.
  494. */
  495. VOID Hv_Drv_Hdcp1x_NotifyTxIrq(Hdcp1xRxStatusMask enStatusType, UCHAR8 ucPortIndex, UCHAR8 ucHdcpIndex);
  496. /**
  497. * @brief Reset Hdcp Rx Auth state.
  498. * @param[in] ucPortIndex: Port index.
  499. * @return None.
  500. */
  501. VOID Hv_Drv_Hdcp1x_DpRxAuthStart(UCHAR8 ucPortIndex, UCHAR8 ucHdcpPortIndex);
  502. /**
  503. * @brief Hdcp1x init for Hdmi.
  504. * @param[in] ucPortIndex: Port index.
  505. * @return None.
  506. */
  507. VOID Hv_Drv_Hdcp1x_HdmiRxInit(UCHAR8 ucPortIndex);
  508. VOID Hv_Drv_Hdcp1x_DpResetLinkIntegrityFailure(UCHAR8 ucPortIndex);
  509. /**
  510. * @brief Hdcp1x init for Dp.
  511. * @param[in] ucPortIndex: Port index.
  512. * @return None.
  513. */
  514. VOID Hv_Drv_Hdcp1x_HdmiRxSetRI(USHORT16 usRI, UCHAR8 ucPortIndex);
  515. VOID Hv_Drv_Hdcp1x_HdmiRxSetRiSelToHw(UCHAR8 ucPortIndex, UCHAR8 ucHdcpPortIndex);
  516. VOID Hv_Drv_Hdcp1x_HdmiRxAuthStart(UCHAR8 ucPortIndex, UCHAR8 ucHdcpPortIndex);
  517. VOID Hv_Drv_Hdcp1x_HdmiRxSetEessQstc(UCHAR8 ucHdcpPortIndex);
  518. VOID Hv_Drv_Hdcp_HdmiRxClearMsgAfterAutherDone(UCHAR8 ucPortIndex);
  519. VOID Hv_Drv_Hdcp_HdmiCommInit();
  520. VOID Hv_Drv_Hdcp_SetHdmiHdcpVersion(UCHAR8 ucHdcpVersion);
  521. VOID Hv_Drv_Hdcp_RealseDpPath(UCHAR8 ucPortIndex);
  522. VOID Hv_Drv_Hdcp_AttachDpPath(UCHAR8 ucPortIndex);
  523. VOID Hv_Drv_Hdcp_RealseStatus(UCHAR8 ucHdcpPortIndex);
  524. VOID Hv_Drv_Hdcp_RealseHdmiPath(UCHAR8 ucPortIndex);
  525. VOID Hv_Drv_Hdcp_AttachHdmiPath(UCHAR8 ucPortIndex);
  526. /*******************Hdcp 1x Function End***********************************/
  527. /*******************Hdcp 2x Function Begin***********************************/
  528. /**
  529. * @brief Set Rrx Random Value and Rx Caps Role Value.
  530. * @param[in] ucCapRole: Hdcp Rx Caps Role Value.
  531. * @param[out] pstHdcpRxIns : Caps and Rrx Value in the parameter.
  532. * @return 1--Get Int Enable Falg, 0--Not Get Int Enable Falg.
  533. */
  534. VOID Hv_Drv_Hdcp2x_RxGenRrxAndCaps(HdcpRx* pstHdcpRxIns, UCHAR8 ucCapRole);
  535. /**
  536. * @brief Get Hdcp Rx state.
  537. * @param[in] ucPortIndex: Port index.
  538. * @return Hdcp Rx state.
  539. */
  540. Status Hv_Drv_Hdcp2x_RxResetParams(Hdcp2xRx *pstHdcp2xRxIns);
  541. /**
  542. * @brief Get Km Store state.
  543. * @param[in] ucPortIndex: Port index.
  544. * @return Km Store state.
  545. */
  546. //UINT32 Hv_Drv_Hdcp2x_DpGetKmStoreStat(UCHAR8 ucPortIndex);
  547. /**
  548. * @brief Set Km Store state.
  549. * @param[in] KmStoreState: Km Store State.
  550. * @param[in] ucPortIndex: Port index.
  551. * @return None.
  552. */
  553. //VOID Hv_Drv_Hdcp2x_HdmiSetKmStoreStat(UINT32 KmStoreState, UCHAR8 ucPortIndex);
  554. /**
  555. * @brief Get Km Store state.
  556. * @param[in] ucPortIndex: Port index.
  557. * @return Km Store state.
  558. */
  559. UINT32 Hv_Drv_Hdcp2x_HdmiGetKmStoreStat(UCHAR8 ucPortIndex);
  560. /**
  561. * @brief Get Hdcp2x Msg send state.
  562. * @param[in] ucPortIndex: Port index.
  563. * @return Hdcp send Msg State.
  564. */
  565. //UINT32 Hv_Drv_Hdcp2x_HdmiRxGetMsgState(UCHAR8 ucPortIndex);
  566. /**
  567. * @brief Set Hdcp2x RxCaps.
  568. * @param[in] pU8RxCaps: Hdcp RxCaps.
  569. * @param[in] ucPortIndex: Port index.
  570. * @return None.
  571. */
  572. VOID Hv_Drv_Hdcp2x_DpSetRxCaps(const UCHAR8* pU8RxCaps, UCHAR8 ucPortIndex);
  573. /**
  574. * @brief Hdcp2x process for WrAKEInit state.
  575. * @param[in] ucPortIndex: Port index.
  576. * @return Status, 0-HV_SUCCESS, 1-HV_FAILURE.
  577. */
  578. //Status Hv_Drv_Hdcp2x_RxB0ProcMsgAKESendCert(HdcpPortType enPortType, UCHAR8 ucPortIndex);
  579. /**
  580. * @brief Hdcp2x process for WrAKEInit state.
  581. * @param[in] ucPortIndex: Port index.
  582. * @return Status, 0-HV_SUCCESS, 1-HV_FAILURE.
  583. */
  584. VOID Hv_Drv_Hdcp2x_DpRxSaveRrxToReg(UCHAR8* pucRrx, UCHAR8 ucPortIndex);
  585. /**
  586. * @brief Hdcp2x process for WrAKEInit state.
  587. * @param[in] ucPortIndex: Port index.
  588. * @return Status, 0-HV_SUCCESS, 1-HV_FAILURE.
  589. */
  590. Status Hv_Drv_Hdcp2x_HdmiRxB0ProcMsgAKESendCert(UCHAR8 ucPortIndex);
  591. /**
  592. * @brief Hdcp2x process for WrAKENoStoredKm state.
  593. * @param[in] ucPortIndex: Port index.
  594. * @return Status, 0-HV_SUCCESS, 1-HV_FAILURE.
  595. */
  596. //Status Hv_Drv_Hdcp2x_RxB1ProcMsgAKENoStoredKm(HdcpPortType enPortType, UCHAR8 ucPortIndex);
  597. /**
  598. * @brief Hdcp2x process for WrAKENoStoredKm state.
  599. * @param[in] ucPortIndex: RX Port Index.
  600. * @param[in] ucHdcpIndex: HDCP Port Index.
  601. * @return Status, 0-HV_SUCCESS, 1-HV_FAILURE.
  602. */
  603. VOID Hv_Drv_Hdcp2x_NotifyTxIrq(Hdcp2xDpRxStatusMask enStatusType, UCHAR8 ucPortIndex, UCHAR8 ucHdcpIndex);
  604. /**
  605. * @brief Hdcp2x process for WrAKENoStoredKm state.
  606. * @param[in] ucPortIndex: Port index.
  607. * @return Status, 0-HV_SUCCESS, 1-HV_FAILURE.
  608. */
  609. //Status Hv_Drv_Hdcp2x_HdmiRxB1ProcMsgAKENoStoredKm(UCHAR8 ucPortIndex);
  610. /**
  611. * @brief Hdcp2x process for WrAKEStoredKm state.
  612. * @param[in] enPortType: Port Type.
  613. * @param[in] ucPortIndex: Port index.
  614. * @return Status, 0-HV_SUCCESS, 1-HV_FAILURE.
  615. */
  616. VOID Hv_Drv_Hdcp2x_DpSaveHPrimeToReg(UCHAR8* pucHPrime, UCHAR8 ucPortIndex);
  617. /**
  618. * @brief Hdcp2x process for WrAKEStoredKm state.
  619. * @param[in] ucPortIndex: Port index.
  620. * @return Status, 0-HV_SUCCESS, 1-HV_FAILURE.
  621. */
  622. //Status Hv_Drv_Hdcp2x_DpRxB1ProcMsgAKEStoredKm(UCHAR8 ucPortIndex);
  623. /**
  624. * @brief Hdcp2x process for WrAKEStoredKm state.
  625. * @param[in] ucPortIndex: Port index.
  626. * @return Status, 0-HV_SUCCESS, 1-HV_FAILURE.
  627. */
  628. //Status Hv_Drv_Hdcp2x_HdmiRxB1ProcMsgAKEStoredKm(UCHAR8 ucPortIndex);
  629. /**
  630. * @brief Hdcp2x process for RdHPrime state.
  631. * @param[in] ucPortIndex: Port index.
  632. * @return Status, 0-HV_SUCCESS, 1-HV_FAILURE.
  633. */
  634. //Status Hv_Drv_Hdcp2x_RxB1ProcAKEPairing(HdcpPortType enPortType, UCHAR8 ucPortIndex);
  635. //Status Hv_Drv_Hdcp2x_HdmiRxGetMsg(HdcpRx* pstHdcpRxIns, USHORT16 usMsgSize, UCHAR8 ucPortIndex);
  636. /**
  637. * @brief Hdcp2x process for RdHPrime state.
  638. * @param[in] ucPortIndex: Port index.
  639. * @return Status, 0-HV_SUCCESS, 1-HV_FAILURE.
  640. */
  641. //Status Hv_Drv_Hdcp2x_DpRxB1ProcAKEPairing(UCHAR8 ucPortIndex);
  642. /**
  643. * @brief Hdcp2x process for RdHPrime state.
  644. * @param[in] ucPortIndex: Port index.
  645. * @return Status, 0-HV_SUCCESS, 1-HV_FAILURE.
  646. */
  647. VOID Hv_Drv_Hdcp2x_DpSavePairingToReg(UCHAR8* pucEkhKm, UCHAR8 ucPortIndex);
  648. /**
  649. * @brief Clear HDCP Msg Size for Hdcp2x.
  650. * @param[in] ucPortIndex: Port Index.
  651. * @return None.
  652. */
  653. VOID Hv_Drv_Hdcp2x_HdmiClrRxStatSize(UCHAR8 ucPortIndex);
  654. /**
  655. * @brief Set HDCP Re Authered Bit(11).
  656. * @param[in] ucPortIndex: Port Index.
  657. * @return None.
  658. */
  659. VOID Hv_Drv_Hdcp2x_HdmiSetRxStatusReAuth(UCHAR8 ucPortIndex);
  660. /**
  661. * @brief Get HDCP Re Authered Bit(11).
  662. * @param[in] ucPortIndex: Port Index.
  663. * @return UCHAR8.
  664. */
  665. UCHAR8 Hv_Drv_Hdcp_HdmiGetReAuthStatus(UCHAR8 ucPortIndex);
  666. /**
  667. * @brief Hdcp2x process for WrLcInit state.
  668. * @param[in] ucPortIndex: Port index.
  669. * @return Status, 0-HV_SUCCESS, 1-HV_FAILURE.
  670. */
  671. VOID Hv_Drv_Hdcp2x_DpSaveLPrimeToReg(UCHAR8* pucLPrime, UCHAR8 ucPortIndex);
  672. /**
  673. * @brief Hdcp2x process for WrLcInit state.
  674. * @param[in] ucPortIndex: Port index.
  675. * @return Status, 0-HV_SUCCESS, 1-HV_FAILURE.
  676. */
  677. //Status Hv_Drv_Hdcp2x_HdmiRxB2LCSendLPrime(UCHAR8 ucPortIndex);
  678. /**
  679. * @brief Hdcp2x process for WrAKESendEks state.
  680. * @param[in] ucPortIndex: Port index.
  681. * @return Status, 0-HV_SUCCESS, 1-HV_FAILURE.
  682. */
  683. //Status Hv_Drv_Hdcp2x_HdmiRxB3ComputeKsB4Authented(UCHAR8 ucPortIndex);
  684. /**
  685. * @brief Hdcp2x process for WrAKESendEks state.
  686. * @param[in] enPortType: Port Type.
  687. * @param[in] ucPortIndex: Port index.
  688. * @return Status, 0-HV_SUCCESS, 1-HV_FAILURE.
  689. */
  690. //Status Hv_Drv_Hdcp2x_RxB3ComputeKs(HdcpPortType enPortType, UCHAR8 ucPortIndex);
  691. /**
  692. * @brief Hdcp2x process for WrAKESendEks state.
  693. * @param[in] ucPortIndex: Port index.
  694. * @return Status, 0-HV_SUCCESS, 1-HV_FAILURE.
  695. */
  696. //Status Hv_Drv_Hdcp2x_DpRxB3ComputeKs(UCHAR8 ucPortIndex);
  697. /**
  698. * @brief Hdcp2x process for WrAKESendEks state.
  699. * @param[in] ucPortIndex: Port index.
  700. * @return Status, 0-HV_SUCCESS, 1-HV_FAILURE.
  701. */
  702. Status Hv_Drv_Hdcp2x_HdmiRxB3ComputeKs(UCHAR8 ucPortIndex);
  703. /**
  704. * @brief Hdcp2x process for ComputeEksDone state.
  705. * @param[in] enPortType: Port Type.
  706. * @param[in] ucPortIndex: Port index.
  707. * @return Status, 0-HV_SUCCESS, 1-HV_FAILURE.
  708. */
  709. Status Hv_Drv_Hdcp2x_RxB4Authenticated(HdcpPortType enPortType, UCHAR8 ucPortIndex);
  710. /**
  711. * @brief Hdcp2x Link Integrity Check Failure.
  712. * @param[in] enPortType: Port Type.
  713. * @param[in] ucPortIndex: Port index.
  714. * @return Status, 0-HV_SUCCESS, 1-HV_FAILURE.
  715. */
  716. Status Hv_Drv_Hdcp2x_RxB4LinkIntegrityFailure(HdcpPortType enPortType, UCHAR8 ucPortIndex);
  717. /**
  718. * @brief Hdcp2x Link Integrity Check Failure.
  719. * @param[in] enPortType: Port Type.
  720. * @param[in] ucPortIndex: Port index.
  721. * @return Status, 0-HV_SUCCESS, 1-HV_FAILURE.
  722. */
  723. //Status Hv_Drv_Hdcp2x_HdmiRxB4LinkIntegrityFailure(UCHAR8 ucPortIndex);
  724. /**
  725. * @brief Hdcp2x process for ComputeEksDone state.
  726. * @param[in] ucPortIndex: Port index.
  727. * @return Status, 0-HV_SUCCESS, 1-HV_FAILURE.
  728. */
  729. Status Hv_Drv_Hdcp2x_DpRxB4Authenticated(UCHAR8 ucPortIndex);
  730. /**
  731. * @brief Hdcp2x process for ComputeEksDone state.
  732. * @param[in] ucPortIndex: Port index.
  733. * @return Status, 0-HV_SUCCESS, 1-HV_FAILURE.
  734. */
  735. Status Hv_Drv_Hdcp2x_HdmiRxB4Authenticated(UCHAR8 ucPortIndex);
  736. /**
  737. * @brief Hdcp2x init for Hdmi.
  738. * @param[in] ucPortIndex: Port index.
  739. * @return None.
  740. */
  741. VOID Hv_Drv_Hdcp2x_HdmiRxInit(UCHAR8 ucPortIndex);
  742. /**
  743. * @brief Hdcp2x init for Dp.
  744. * @param[in] ucPortIndex: Port index.
  745. * @return None.
  746. */
  747. VOID Hv_Drv_Hdcp2x_DpUpdateStreamType(UCHAR8 ucPortIndex, UCHAR8 ucHdcpPortIndex);
  748. /**
  749. * @brief Hdcp2x Set Km Stored State for Dp.
  750. * @param[in] KmStoreState: Km stored state.
  751. * @param[in] ucPortIndex: Port index.
  752. * @return None.
  753. */
  754. //VOID Hv_Drv_Hdcp2x_DpSetKmStoreStat(UINT32 KmStoreState, UCHAR8 ucPortIndex);
  755. /**
  756. * @brief Set Hdcp2x State.
  757. * @param[in] Hdcp2xRxState: Hdcp2x state.
  758. * @param[in] ucPortIndex: Port index.
  759. * @return None.
  760. */
  761. VOID Hv_Drv_Hdcp2x_DpRxAuthStart(UCHAR8 ucPortIndex, UCHAR8 ucHdcpPortIndex);
  762. /**
  763. * @brief Reset Hdcp Rx Auth state.
  764. * @param[in] ucPortIndex: Port index.
  765. * @return None.
  766. */
  767. //VOID Hv_Drv_Hdcp2x_ResetAuthStat(UCHAR8 ucPortIndex, HdcpPortType enPortType);
  768. /**
  769. * @brief Reset Link Integrity Failure state.
  770. * @param[in] None.
  771. * @return None.
  772. */
  773. VOID Hv_Drv_Hdcp2x_DpResetLinkIntegrityFailure(UCHAR8 ucPortIndex);
  774. /**
  775. * @brief Reset Link Integrity Failure state.
  776. * @param[in] None.
  777. * @return None.
  778. */
  779. VOID Hv_Drv_Hdcp2x_HdmiResetLinkIntegrityFailure(UCHAR8 ucPortIndex);
  780. /**
  781. * @brief Hdcp select for dp and hdmi.
  782. * @param[in] ucPortIndex: Port index.
  783. * @param[in] enPortType: Port Type DP/HDMI.
  784. * @return None.
  785. */
  786. VOID Hv_Drv_Hdcp_InitSel(UCHAR8 ucHdcpPortIndex, UCHAR8 ucValueSet);
  787. /**
  788. * @brief Set Hdcp Lane Clk.
  789. * @param[in] ucPortIndex: Dp Port Index.
  790. * @param[in] ucHdcpPortIndex: Hdcp Port Index.
  791. * @param[in] enPortType: Port Type DP or Hdmi.
  792. * @return None.
  793. */
  794. VOID Hv_Drv_Hdcp_SetLaneClk(UCHAR8 ucValueSet, UCHAR8 ucHdcpPortIndex);
  795. /**
  796. * @brief Update Stream Type.
  797. * @param[in] enPortType: Port Type DP or Hdmi.
  798. * @param[in] ucPortIndex: Dp Port Index.
  799. * @return HV_SUCCESS or HV_FAILURE.
  800. */
  801. VOID Hv_Drv_Hdcp2x_HdmiSetRxStatSize(USHORT16 usMsgSize, UCHAR8 ucPortIndex);
  802. /**
  803. * @brief Check Hdcp exist.
  804. * @param[in] ucPortIndex: Hdcp Port Index.
  805. * @return HV_SUCCESS or HV_FAILURE.
  806. */
  807. Status Hv_Drv_Hdcp_CheckExist(UCHAR8 ucPortIndex);
  808. /**
  809. * @brief Reset HDCP.
  810. * @param[in] ucHdcpPortIndex: HDCP Port Index.
  811. * @return None.
  812. */
  813. VOID Hv_Drv_Hdcp_Reset(UCHAR8 ucHdcpPortIndex);
  814. /**
  815. * @brief HDCP1X clear dp fifo.
  816. * @param[in] ucHdcpPortIndex: HDCP Port Index.
  817. * @return None.
  818. */
  819. VOID Hv_Drv_Hdcp1X_ClrDpFifo(UCHAR8 ucHdcpPortIndex);
  820. /**
  821. * @brief HDCP2X clear dp fifo.
  822. * @param[in] ucHdcpPortIndex: HDCP Port Index.
  823. * @return None.
  824. */
  825. VOID Hv_Drv_Hdcp2X_ClrDpFifo(UCHAR8 ucHdcpPortIndex);
  826. //Status Hv_Drv_Hdcp_DpIsrHandler(UINT32 uiIrqMask, HdcpVersion enVersion);
  827. VOID Hv_Drv_Hdcp2x_HdmiSetRxMsgToReg(UCHAR8 *pucData, USHORT16 usMsgSize, UCHAR8 ucPortIndex);
  828. VOID Hv_Drv_Hdcp1x_HdmiGetRxAksvFromReg(UCHAR8 *pucAKsv, UCHAR8 ucPortIndex);
  829. VOID Hv_Drv_Hdcp1x_HdmiGetRxAnFromReg(UCHAR8 *pucAn, UCHAR8 ucPortIndex);
  830. Status Hv_Drv_Hdcp_LoadLc128(const UCHAR8 *pucLc128);
  831. Status Hv_Drv_Hdcp_LoadPrivateKey(Hdcp2xRxMmult* pstmmult, const HDCP2X_RX_KPriv *PrivateKey);
  832. VOID Hv_Drv_Hdcp_HdmiSaveBksvtoReg(const UCHAR8 *pucBKsv, UCHAR8 ucPortIndex);
  833. Status Hv_Drv_Hdcp_LoadDKSTable(UCHAR8 *pucDKS);
  834. VOID Hv_Drv_Hdcp_DpMuxSel(UCHAR8 ucPortIndex, UCHAR8 ucHdcpPortIndex);
  835. VOID Hv_Drv_Hdcp_HdmiMuxSel(UCHAR8 ucPortIndex, UCHAR8 ucHdcpPortIndex);
  836. VOID Hv_Drv_Hdcp2x_RxSaveKsRivToReg(const UCHAR8* pucKs, const UCHAR8* pucRiv, UCHAR8 ucHdcpPortIndex);
  837. VOID Hv_Drv_Hdcp2x_StartRxAuth(UCHAR8 ucHdcpPortIndex);
  838. VOID Hv_Drv_Hdcp2x_HdmiStartRxAuthCallBack(UCHAR8 ucPortIndex);
  839. VOID Hv_Drv_Hdcp_DpCommInit();
  840. VOID Hv_Drv_Hdcp2x_SetDpHdcpVersion(UCHAR8 ucHdcpVersion);
  841. VOID Hv_Drv_Hdcp_DpLoadPublicCert(const UCHAR8 *pucPubCert, UCHAR8 ucPortIndex);
  842. VOID Hv_Drv_Hdcp_DpSaveBksvtoReg(const UCHAR8 *pucBKsv, UCHAR8 ucPortIndex);
  843. /*******************Hdcp 2x Function End***********************************/
  844. #endif