123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602 |
- /**
- * @file hv_drv_Hdcp2xRx.h
- * @brief Header file of drv module.
- *
- * @verbatim
- * ==============================================================================
- * ##### How to use #####
- * ==============================================================================
- * (+) Use Hv_Engine_RxCalcMontNPrime(...) calculate the Montgomery NPrime.
- * (+) Use Hv_Engine_RxRsaesOaepEncrypt(...) implements the RSAES-OAEP-Encrypt operation
- * (+) Use Hv_Engine_RxRsaesOaepDecrypt(...) implements the RSAES-OAEP-Decrypt operation.
- * (+) Use Hv_Engine_RxComputeHPrime(...) computes HPrime used during HDCP 2.2 authentication.
- * (+) Use Hv_Engine_RxComputeEkh(...) computes Ekh used during HDCP 2.2 authentication.
- * (+) Use Hv_Engine_RxComputeLPrime(...) computes LPrime used during HDCP 2.2 locality check.
- * (+) Use Hv_Engine_RxComputeKs(...) computes the Ks used during HDCP 2.2 session key exchange.
- * (+) Use Hv_Engine_RxComputeVPrime(...) computes VPrime used during HDCP 2.2 repeater.
- * (+) Use Hv_Engine_RxComputeMPrime(...) computes VPrime used during HDCP 2.2 repeater.
- *
- * @endverbatim
- *
- * @author HiView SoC Software Team
- * @version 1.0.0
- * @date 2022-08-30
- */
- #ifndef HV_DRV_HDCP2X_RX_H /* prevent circular inclusions */
- #define HV_DRV_HDCP2X_RX_H /* by using protection macros */
- #ifdef __cplusplus
- extern "C" {
- #endif
- /***************************** Include Files ********************************/
- #include "hv_vos_Comm.h"
- #include "hv_comm_DataType.h"
- #include "hv_comm_Define.h"
- /************************** Constant Definitions ****************************/
- /************************** Variable Declaration ****************************/
- #define HV_HDCP_2X_RX_AES_SIZE 16 /** AES size size in bytes */
- #define HV_HDCP_2X_RX_SEQNUMV_SIZE 3 /** Repeater seq_num_V size in bytes */
- #define HV_HDCP_2X_RX_RXINFO_SIZE 2 /** Repeater RxInfo size in bytes */
- #define HV_HDCP_2X_RX_V_SIZE 16 /** Repeater V size in bytes */
- #define HV_HDCP_2X_RX_K_SIZE 2 /** Repeater K size in bytes */
- #define HV_HDCP_2X_RX_RECEIVER_ID_LIST_SIZE 5*31
- #define HV_HDCP_2X_RX_EKPUBKM_SIZE 128
- #define HV_HDCP_2X_Rx_EDKEYKS_SIZE 16 /** EDKEYKS size size in bytes */
- #define HV_HDCP_2X_RX_KM_SIZE 16 /** Km size in bytes */
- #define HV_HDCP_2X_RX_M_SIZE 16 /** m size in bytes */
- #define HV_HDCP_2X_RX_EKH_SIZE 16 /** Ekh size size in bytes */
- #define HV_HDCP_2X_RX_HPRIME_SIZE 32 /** HPrime size size in bytes */
- #define HV_HDCP_2X_RX_LPRIME_SIZE 32 /** LPrime size size in bytes */
- #define HV_HDCP_2X_RX_RN_SIZE 8 /** Rn size size in bytes */
- #define HV_HDCP_2X_RX_RIV_SIZE 8 /** Riv size size in bytes */
- #define HV_HDCP_2X_RX_KS_SIZE 16 /** Ks size size in bytes */
- #define HV_HDCP_2X_RX_RTX_SIZE 8 /** Rtx size size in bytes */
- #define HV_HDCP_2X_RX_RRX_SIZE 8 /** Rrx size size in bytes */
- #define HV_HDCP_2X_RX_TXCAPS_SIZE 3 /** TxCaps size size in bytes */
- #define HV_HDCP_2X_RX_RXCAPS_SIZE 3 /** RxCaps size size in bytes */
- #define HV_HDCP_2X_RX_VPRIME_SIZE 32 /** Repeater VPrime size in bytes */
- #define HV_HDCP_2X_RX_SEQNUMM_SIZE 3 /** Repeater seq_num_M size in bytes */
- #define HV_HDCP_2X_RX_MPRIME_SIZE 32 /** Repeater MPrime size in bytes */
- #define HV_HDCP_2X_RX_STREAMID_SIZE 2 /** Repeater MPrime size in bytes */
- #define HV_HDCP_2X_RX_MOD_SIZE 16
- #define HV_HDCP_2X_RX_MAX_MESSAGE_SIZE 534 /**< Maximum message size */
- #define HV_HDCP_2X_RX_N_PRIME_P_SIZE 64
- #define HV_HDCP_2X_RX_N_PRIME_Q_SIZE 64
- /** Hdcp2x Tx size in bytes */
- #define HV_HDCP_2X_TX_E_KPUB_KM_SIZE 128
- #define HV_HDCP_2X_TX_EKH_KM_SIZE 16
- #define HV_HDCP_2X_TX_RN_SIZE 8
- /** Hdcp2x Public Key size in bytes */
- #define HV_HDCP_2X_RX_N_SIZE 128
- #define HV_HDCP_2X_RX_E_SIZE 3
- /** Hdcp2x Private Key size in bytes */
- #define HV_HDCP_2X_RX_P_SIZE 64
- #define HV_HDCP_2X_RX_Q_SIZE 64
- #define HV_HDCP_2X_RX_DP_SIZE 64
- #define HV_HDCP_2X_RX_DQ_SIZE 64
- #define HV_HDCP_2X_RX_QINV_SIZE 64
- /** Hdcp2x Cert size in bytes */
- #define HV_HDCP_2X_RECEIVER_ID_SIZE 5
- #define HV_HDCP_2X_RX_KPUB_SIZE 131
- #define HV_HDCP_2X_RESERVED_SIZE 2
- #define HV_HDCP_2X_SIGN_SIZE 384
- /**
- * These constants are the message identification codes.
- */
- typedef enum
- {
- HV_HDCP_2X_RX_MSG_ID_AKEINIT = 2, /**< AKE_Init message ID */
- HV_HDCP_2X_RX_MSG_ID_AKESENDCERT = 3, /**< AKE_Send_Cert message ID */
- HV_HDCP_2X_RX_MSG_ID_AKENOSTOREDKM = 4, /**< AKE_No_Stored_km message ID */
- HV_HDCP_2X_RX_MSG_ID_AKESTOREDKM = 5, /**< AKE_Stored_km message ID */
- HV_HDCP_2X_RX_MSG_ID_AKESENDHPRIME = 7, /**< AKE_Send_H_prime message ID */
- HV_HDCP_2X_RX_MSG_ID_AKESENDPAIRINGINFO = 8, /**< AKE_Send_Pairing_Info message ID */
- HV_HDCP_2X_RX_MSG_ID_LCINIT = 9, /**< LC_Init message ID */
- HV_HDCP_2X_RX_MSG_ID_LCSENDLPRIME = 10, /**< LC_Send_L_prime message ID */
- HV_HDCP_2X_RX_MSG_ID_SKESENDEKS = 11, /**< SKE_Send_Eks message ID */
- HV_HDCP_2X_RX_MSG_ID_REPEATERAUTHSENDRXIDLIST = 12, /**< RepeaterAuth_Send_ReceiverID_List message ID */
- HV_HDCP_2X_RX_MSG_ID_REPEATERAUTHSENDACK = 15, /**< RepeaterAuth_Send_Ack message ID */
- HV_HDCP_2X_RX_MSG_ID_REPEATERAUTHSTREAMMANAGE = 16, /**< RepeaterAuth_Stream_Manage message ID */
- HV_HDCP_2X_RX_MSG_ID_REPEATERAUTHSTREAMREADY = 17, /**< RepeaterAuth_Stream_Ready message ID */
- HV_HDCP_2X_RX_MSG_ID_INVALID = 0xFF
- } HV_HDCP_2X_RX_MSG_ID;
- /*******HDCP 2.X***********************/
- typedef struct
- {
- /** Montgomery 2^2k mod p array */
- UINT32 AmodP[HV_HDCP_2X_RX_MOD_SIZE];
- /** Montgomery 2^2k mod q array */
- UINT32 AmodQ[HV_HDCP_2X_RX_MOD_SIZE];
- /** Montgomery 2^k mod p array */
- UINT32 CmodP[HV_HDCP_2X_RX_MOD_SIZE];
- /** Montgomery 2^k mod q array */
- UINT32 CmodQ[HV_HDCP_2X_RX_MOD_SIZE];
- } Hdcp2xRxMmult;
- /**
- * This typedef is used to store temporary parameters for computations
- */
- typedef struct _Hdcp2xRxParams
- {
- UCHAR8 Rtx[HV_HDCP_2X_RX_RTX_SIZE];
- UCHAR8 TxCaps[HV_HDCP_2X_RX_TXCAPS_SIZE];
- UCHAR8 Rrx[HV_HDCP_2X_RX_RRX_SIZE];
- UCHAR8 RxCaps[HV_HDCP_2X_RX_RXCAPS_SIZE];
- UCHAR8 Km[HV_HDCP_2X_RX_KM_SIZE];
- UCHAR8 Rn[HV_HDCP_2X_RX_RN_SIZE];
- UCHAR8 HPrime[HV_HDCP_2X_RX_HPRIME_SIZE];
- UCHAR8 LPrime[HV_HDCP_2X_RX_LPRIME_SIZE];
- UCHAR8 EKh[HV_HDCP_2X_RX_EKH_SIZE];
- UCHAR8 EKhKm[HV_HDCP_2X_RX_KM_SIZE];
- UCHAR8 M[HV_HDCP_2X_RX_M_SIZE];
- UCHAR8 Riv[HV_HDCP_2X_RX_RIV_SIZE];
- UCHAR8 Ks[HV_HDCP_2X_RX_KS_SIZE];
- UCHAR8 VPrime[HV_HDCP_2X_RX_VPRIME_SIZE];
- UCHAR8 SeqNumM[HV_HDCP_2X_RX_SEQNUMM_SIZE];
- UCHAR8 StreamIdType[HV_HDCP_2X_RX_STREAMID_SIZE];
- UCHAR8 MPrime[HV_HDCP_2X_RX_MPRIME_SIZE];
- UCHAR8 EDkeyKs[HV_HDCP_2X_Rx_EDKEYKS_SIZE];
- UCHAR8 EKpubKm[HV_HDCP_2X_RX_EKPUBKM_SIZE];
- } Hdcp2xRxParams;
- /**
- * The XHdcp driver instance data. The user is required to
- * allocate a variable of this type for every HDCP-RX device in the
- * system. A pointer to a variable of this type is then passed to the driver
- * API functions.
- */
- typedef struct
- {
- /** DCP public certificate pointer */
- const UCHAR8 *pucPubCert;
- /** RSA private key pointer */
- const UCHAR8 *pucPrivKey;
- /** pU8Lc128 is a pointer to the LC128 key.*/
- const UCHAR8 *pucLc128;
- /** Montgomery NPrimeP array */
- UCHAR8 NPrimeP[HV_HDCP_2X_RX_N_PRIME_P_SIZE];
- /** Montgomery NPrimeQ array */
- UCHAR8 NPrimeQ[HV_HDCP_2X_RX_N_PRIME_Q_SIZE];
- /** HDCP-RX authentication and key exchange parameters */
- Hdcp2xRxParams stParams;
- /** Message size */
- USHORT16 uiMsgSize;
- /** Message structure */
- UCHAR8 aucMsgBuff[HV_HDCP_2X_RX_MAX_MESSAGE_SIZE];
- Hdcp2xRxMmult *pstmmult;
- } Hdcp2xRx;
- /************HDCP2x Rx Send Msg State************ */
- typedef enum _Hdcp2xRxMsgState
- {
- HDCP2X_AKE_SEND_CERT_DONE = 0, /**< Compute Km: Send AKE_Send_Cert */
- HDCP2X_AKE_SEND_HPRIME_DONE, /**< Compute Km: Send AKE_Send_H_prime */
- HDCP2X_AKE_SEND_PAIRING_DONE, /**< Compute Km: Send AKE_Send_H_prime */
- HDCP2X_SEND_LPRIME_DONE, /**< Compute Km: Send AKE_Send_H_prime */
- HDCP2X_SEND_MSG_INVALID
- } Hdcp2xRxMsgState;
- /**
- * This typedef is the RSA private key quintuple definition.
- */
- typedef struct
- {
- UCHAR8 p[HV_HDCP_2X_RX_P_SIZE];
- UCHAR8 q[HV_HDCP_2X_RX_Q_SIZE];
- UCHAR8 dp[HV_HDCP_2X_RX_DP_SIZE];
- UCHAR8 dq[HV_HDCP_2X_RX_DQ_SIZE];
- UCHAR8 qinv[HV_HDCP_2X_RX_QINV_SIZE];
- } HDCP2X_RX_KPriv;
- /**
- * This typedef is the RSA public key definition.
- */
- typedef struct
- {
- UCHAR8 N[HV_HDCP_2X_RX_N_SIZE];
- UCHAR8 e[HV_HDCP_2X_RX_E_SIZE];
- } HDCP2X_RX_Kpub;
- /**
- * This typedef is the DCP public certificate definition.
- */
- typedef struct
- {
- UCHAR8 ReceiverId[HV_HDCP_2X_RECEIVER_ID_SIZE];
- UCHAR8 KpubRx[HV_HDCP_2X_RX_KPUB_SIZE];
- UCHAR8 Reserved[HV_HDCP_2X_RESERVED_SIZE];
- UCHAR8 Signature[HV_HDCP_2X_SIGN_SIZE];
- } HDCP2X_RX_Cert;
- /**
- * This typedef is the AKE_Init message definition.
- */
- typedef struct
- {
- UCHAR8 MsgId;
- UCHAR8 Rtx[HV_HDCP_2X_RX_RTX_SIZE];
- UCHAR8 TxCaps[HV_HDCP_2X_RX_TXCAPS_SIZE];
- } HDCP2X_RX_AKEInit;
- /**
- * This typedef is the AKE_Send_Cert message definition.
- */
- typedef struct
- {
- UCHAR8 MsgId;
- UCHAR8 CertRx[HV_HDCP_2X_RX_CERT_SIZE];
- UCHAR8 Rrx[HV_HDCP_2X_RX_RRX_SIZE];
- UCHAR8 RxCaps[HV_HDCP_2X_RX_RXCAPS_SIZE];
- } HDCP2X_RX_AKESendCert;
- /**
- * This typedef is the AKE_No_Stored_km message definition.
- */
- typedef struct
- {
- UCHAR8 MsgId;
- UCHAR8 EKpubKm[HV_HDCP_2X_RX_EKPUBKM_SIZE];
- } HDCP2X_RX_AKENoStoredKm;
- /**
- * This typedef is the AKE_Stored_km message definition.
- */
- typedef struct
- {
- UCHAR8 MsgId;
- UCHAR8 EKhKm[HV_HDCP_2X_RX_EKH_SIZE];
- UCHAR8 M[HV_HDCP_2X_RX_M_SIZE];
- } HDCP2X_RX_AKEStoredKm;
- /**
- * This typedef is the AKE_Send_H_prime message definition.
- */
- typedef struct
- {
- UCHAR8 MsgId;
- UCHAR8 HPrime[HV_HDCP_2X_RX_HPRIME_SIZE];
- } HDCP2X_RX_AKESendHPrime;
- /**
- * This typedef is the AKE_Send_Pairing_Info message definition.
- */
- typedef struct
- {
- UCHAR8 MsgId;
- UCHAR8 EKhKm[HV_HDCP_2X_RX_EKH_SIZE];
- } HDCP2X_RX_AKESendPairingInfo;
- /**
- * This typedef is the LC_Init message definition.
- */
- typedef struct
- {
- UCHAR8 MsgId;
- UCHAR8 Rn[HV_HDCP_2X_RX_RN_SIZE];
- } HDCP2X_RX_LCInit;
- /**
- * This typdef is the LC_Send_L_prime message definition.
- */
- typedef struct
- {
- UCHAR8 MsgId;
- UCHAR8 LPrime[HV_HDCP_2X_RX_LPRIME_SIZE];
- } HDCP2X_RX_LCSendLPrime;
- /**
- * This typedef is the SKE_Send_Eks message definition.
- */
- typedef struct
- {
- UCHAR8 MsgId;
- UCHAR8 EDkeyKs[HV_HDCP_2X_Rx_EDKEYKS_SIZE];
- UCHAR8 Riv[HV_HDCP_2X_RX_RIV_SIZE];
- } HDCP2X_RX_SKESendEks;
- /**
- * This typedef is the RepeaterAuth_Send_RceiverID_List message definition.
- */
- typedef struct
- {
- UCHAR8 MsgId;
- UCHAR8 RxInfo[HV_HDCP_2X_RX_RXINFO_SIZE];
- UCHAR8 SeqNumV[HV_HDCP_2X_RX_SEQNUMV_SIZE];
- UCHAR8 VPrime[HV_HDCP_2X_RX_VPRIME_SIZE];
- UCHAR8 ReceiverIdList[HV_HDCP_2X_RX_RECEIVER_ID_LIST_SIZE];
- } HDCP2X_RX_RepeaterAuthSendRxIdList;
- /**
- * This typedef is the RepeaterAuth_Send_Ack message definition.
- */
- typedef struct
- {
- UCHAR8 MsgId;
- UCHAR8 V[HV_HDCP_2X_RX_V_SIZE];
- } HDCP2X_RX_RepeaterAuthSendAck;
- /**
- * This typedef is the RepeaterAuth_Stream_Manage message definition.
- */
- typedef struct
- {
- UCHAR8 MsgId;
- UCHAR8 SeqNumM[HV_HDCP_2X_RX_SEQNUMM_SIZE];
- UCHAR8 K[HV_HDCP_2X_RX_K_SIZE];
- UCHAR8 StreamIdType[HV_HDCP_2X_RX_STREAMID_SIZE];
- } HDCP2X_RX_RepeaterAuthStreamManage;
- /**
- * This typedef is the RepeaterAuth_Stream_Ready message definition.
- */
- typedef struct
- {
- UCHAR8 MsgId;
- UCHAR8 MPrime[HV_HDCP_2X_RX_MPRIME_SIZE];
- } HDCP2X_RX_RepeaterAuthStreamReady;
- /**
- * This typedef is the union of all the message types.
- */
- typedef union
- {
- UCHAR8 MsgId;
- HDCP2X_RX_AKEInit AKEInit;
- HDCP2X_RX_AKESendCert AKESendCert;
- HDCP2X_RX_AKENoStoredKm AKENoStoredKm;
- HDCP2X_RX_AKEStoredKm AKEStoredKm;
- HDCP2X_RX_AKESendHPrime AKESendHPrime;
- HDCP2X_RX_AKESendPairingInfo AKESendPairingInfo;
- HDCP2X_RX_LCInit LCInit;
- HDCP2X_RX_LCSendLPrime LCSendLPrime;
- HDCP2X_RX_SKESendEks SKESendEks;
- HDCP2X_RX_RepeaterAuthSendRxIdList RepeaterAuthSendRxIdList;
- HDCP2X_RX_RepeaterAuthSendAck RepeaterAuthSendAck;
- HDCP2X_RX_RepeaterAuthStreamManage RepeaterAuthStreamManage;
- HDCP2X_RX_RepeaterAuthStreamReady RepeaterAuthStreamReady;
- } HDCP2X_RX_Msg;
- /**
- * These constants define the authentication status.
- */
- typedef enum
- {
- HV_HDCP_2X_RX_UNAUTHENTICATED, /**< Unauthenticated */
- HV_HDCP_2X_RX_AUTHENTICATION_BUSY, /**< Authentication Busy */
- HV_HDCP_2X_RX_AUTHENTICATED, /**< Authenticated */
- HV_HDCP_2X_RX_REAUTHENTICATE_REQUESTED /**< Reauthentication requested */
- } HV_HDCP_2X_RX_AuthenticationType;
- /************************** Function Prototypes *****************************/
- /* Crypto Functions */
- /*****************************************************************************/
- /**
- * This function is used to calculate the Montgomery NPrime. NPrime is
- * calculated from the following equation R*Rinv - N*NPrime == 1.
- * For the HDCP2.2 receiver the modulus N has a fixed size
- * of k = 512bits. Given k, the value R = 2^(k), and Rinv is the modular
- * inverse of R.
- *
- * Reference:
- * Analyzing and Comparing Montgomery Multiplication Algorithms
- * IEEE Micro, 16(3):26-33,June 1996
- * By: Cetin Koc, Tolga Acar, and Burton Kaliski
- *
- * @param NPrime is the calculated value and 2*NDigits in Size.
- * @param N is modulus
- * @param NDigits is the integer precision of arguments (N, NPrime), which
- * should always be 16 for the HDCP2.2 receiver.
- *
- * @return HV_SUCCESS or HV_FAILURE.
- *
- * @note None.
- ******************************************************************************/
- Status Hv_Engine_RxCalcMontNPrime(UCHAR8 *NPrime, const UCHAR8 *N, int NDigits);
- /****************************************************************************/
- /**
- * This function implements the RSAES-OAEP-Encrypt operation. The message
- * is encoded using EME-OAEP and then encrypted with the public key
- * using RSAEP.
- *
- * Reference: PKCS#1 v2.1, Section 7.1.1
- *
- * @param KpubRx is the RSA public key structure containing the 1024 bit
- * modulus and 24 bit public exponent.
- * @param Message is the octet string to be encrypted.
- * @param MessageLen is the length of octet string to be encrypted and
- * must be less than or equal to (nLen - 2*hLen - 2)
- * @param MaskingSeed is the random octet string seed of length hLen
- * used by EME-OAEP encoding function.
- *
- * @return HV_SUCCESS or HV_FAILURE.
- *
- * @note None.
- *****************************************************************************/
- Status Hv_Engine_RxRsaesOaepEncrypt(const HDCP2X_RX_Kpub *KpubRx, const UCHAR8 *Message,
- const UINT32 MessageLen, const UCHAR8 *MaskingSeed, UCHAR8 *EncryptedMessage);
- /****************************************************************************/
- /**
- * This function implements the RSAES-OAEP-Decrypt operation. The message is
- * decrypted using RSADP and then decoded using EME-OAEP.
- *
- * Reference: PKCS#1 v2.1, Section 7.1.2
- *
- * @param pstHdcpRxIns is a pointer to the MMULT instance.
- * @param KprivRx is the RSA private key structure containing the quintuple.
- * @param EncryptedMessage is the 128 byte octet string to be decrypted.
- * @param Message is the octet string after decryption.
- * @param MessageLen is the length of the message octet string after decryption.
- *
- * @return HV_SUCCESS or HV_FAILURE.
- *
- * @note None.
- *****************************************************************************/
- Status Hv_Engine_RxRsaesOaepDecrypt(Hdcp2xRx *pstHdcpRxIns, const HDCP2X_RX_KPriv *KprivRx,
- UCHAR8 *EncryptedMessage, UCHAR8 *Message, int *MessageLen);
- /*****************************************************************************/
- /**
- * This function computes HPrime used during HDCP 2.2 authentication and key
- * exchange.
- *
- * Reference: HDCP v2.2, section 2.2
- *
- * @param Rrx is the Rx random generated value.
- * @param RxCaps are the capabilities of the receiver.
- * @param Rtx is the Tx random generated value.
- * @param TxCaps are the capabilities of the receiver.
- * @param Km is the master key generated by tx.
- * @param HPrime is a pointer to the HPrime hash from the HDCP2.2 receiver.
- *
- * @return None.
- *
- * @note None.
- ******************************************************************************/
- VOID Hv_Engine_RxComputeHPrime(const UCHAR8* Rrx, const UCHAR8 *RxCaps, const UCHAR8* Rtx,
- const UCHAR8 *TxCaps, const UCHAR8 *Km, UCHAR8 *HPrime);
- /*****************************************************************************/
- /**
- * This function computes Ekh used during HDCP 2.2 authentication and key
- * exchange for pairing with receiver.
- *
- * Reference: HDCP v2.2, section 2.2.1
- *
- * @param KprivRx is the RSA private key structure containing the quintuple.
- * @param Km is the master key generated by tx.
- * @param M is constructed by concatenating Rtx || Rrx.
- * @param Ekh is the encrypted Km used for pairing.
- *
- * @return None.
- *
- * @note None.
- ******************************************************************************/
- VOID Hv_Engine_RxComputeEkh(const UCHAR8 *KprivRx, const UCHAR8 *Km, const UCHAR8 *M, UCHAR8 *Ekh);
- /*****************************************************************************/
- /**
- * This function computes LPrime used during HDCP 2.2 locality check.
- *
- * Reference: HDCP v2.2, section 2.3
- *
- * @param Rn is the 64-bit psuedo-random nonce generated by the transmitter.
- * @param Km is the 128-bit master key generated by tx.
- * @param Rrx is the 64-bit pseudo-random number generated by the receiver.
- * @param Rtx is the 64-bit pseudo-random number generated by the transmitter.
- * @param LPrime is the 256-bit value generated for locality check.
- *
- * @return None.
- *
- * @note None.
- ******************************************************************************/
- VOID Hv_Engine_RxComputeLPrime(const UCHAR8 *Rn, const UCHAR8 *Km, const UCHAR8 *Rrx, const UCHAR8 *Rtx, UCHAR8 *LPrime);
- /*****************************************************************************/
- /**
- * This function computes the Ks used during HDCP 2.2 session key exchange.
- *
- * Reference: HDCP v2.2, section 2.4
- *
- * @param Rrx is the Rx random generated value.
- * @param Rtx is the Tx random generated value.
- * @param Km is the master key generated by the transmitter.
- * @param Rn is the 64-bit psuedo-random nonce generated by the transmitter.
- * @param Eks is the encrypted session generated by the transmitter.
- * @param Ks is the decrypted session key.
- *
- * @return None.
- *
- * @note None.
- ******************************************************************************/
- VOID Hv_Engine_RxComputeKs(const UCHAR8* Rrx, const UCHAR8* Rtx, const UCHAR8 *Km, const UCHAR8 *Rn,
- const UCHAR8 *Eks, UCHAR8 * Ks);
- /*****************************************************************************/
- /**
- * This function computes VPrime used during HDCP 2.2 repeater
- * authentication.
- *
- * Reference: HDCP v2.2, section 2.3
- *
- * @param ReceiverIdList is a list of downstream receivers IDs in big-endian
- * order. Each receiver ID is 5 Bytes.
- * @param ReceiverIdListSize is the number of receiver Ids in ReceiverIdList.
- * There can be between 1 and 31 devices in the list.
- * @param RxInfo is the 16-bit field in the RepeaterAuth_Send_ReceiverID_List
- * message.
- * @param Km is the 128-bit master key generated by tx.
- * @param Rrx is the 64-bit pseudo-random number generated by the receiver.
- * @param Rtx is the 64-bit pseudo-random number generated by the transmitter.
- * @param VPrime is the 256-bit value generated for repeater authentication.
- *
- * @return None.
- *
- * @note None.
- ******************************************************************************/
- VOID Hv_Engine_RxComputeVPrime(const UCHAR8 *ReceiverIdList, UINT32 ReceiverIdListSize,
- const UCHAR8 *RxInfo, const UCHAR8 *SeqNumV, const UCHAR8 *Km, const UCHAR8 *Rrx,
- const UCHAR8 *Rtx, UCHAR8 *VPrime);
- /*****************************************************************************/
- /**
- * This function computes VPrime used during HDCP 2.2 repeater
- * authentication.
- *
- * Reference: HDCP v2.2, section 2.3
- *
- * @param StreamIdType is the 16-bit field in the RepeaterAuth_Send_ReceiverID_List
- * message.
- * @param SeqNumM is the 24-bit field in the RepeaterAuth_Stream_Manage
- * message.
- * @param Km is the 128-bit master key generated by tx.
- * @param Rrx is the 64-bit pseudo-random number generated by the receiver.
- * @param Rtx is the 64-bit pseudo-random number generated by the transmitter.
- * @param MPrime is the 256-bit value generated for repeater stream
- * management ready.
- *
- * @return None.
- *
- * @note None.
- ******************************************************************************/
- Status Hv_Engine_RxComputeMPrime(const UCHAR8 *StreamIdType, const UCHAR8 *SeqNumM,
- const UCHAR8 *Km, const UCHAR8 *Rrx, const UCHAR8 *Rtx, UCHAR8 *MPrime);
- #ifdef __cplusplus
- }
- #endif
- #endif /* HV_HDCP_2X_RX_H_ */
- /** @} */
|