mirror of https://github.com/PCSX2/pcsx2.git
61 lines
1.9 KiB
C
61 lines
1.9 KiB
C
|
/* Aes.h -- AES encryption / decryption
|
||
|
2023-04-02 : Igor Pavlov : Public domain */
|
||
|
|
||
|
#ifndef ZIP7_INC_AES_H
|
||
|
#define ZIP7_INC_AES_H
|
||
|
|
||
|
#include "7zTypes.h"
|
||
|
|
||
|
EXTERN_C_BEGIN
|
||
|
|
||
|
#define AES_BLOCK_SIZE 16
|
||
|
|
||
|
/* Call AesGenTables one time before other AES functions */
|
||
|
void AesGenTables(void);
|
||
|
|
||
|
/* UInt32 pointers must be 16-byte aligned */
|
||
|
|
||
|
/* 16-byte (4 * 32-bit words) blocks: 1 (IV) + 1 (keyMode) + 15 (AES-256 roundKeys) */
|
||
|
#define AES_NUM_IVMRK_WORDS ((1 + 1 + 15) * 4)
|
||
|
|
||
|
/* aes - 16-byte aligned pointer to keyMode+roundKeys sequence */
|
||
|
/* keySize = 16 or 24 or 32 (bytes) */
|
||
|
typedef void (Z7_FASTCALL *AES_SET_KEY_FUNC)(UInt32 *aes, const Byte *key, unsigned keySize);
|
||
|
void Z7_FASTCALL Aes_SetKey_Enc(UInt32 *aes, const Byte *key, unsigned keySize);
|
||
|
void Z7_FASTCALL Aes_SetKey_Dec(UInt32 *aes, const Byte *key, unsigned keySize);
|
||
|
|
||
|
/* ivAes - 16-byte aligned pointer to iv+keyMode+roundKeys sequence: UInt32[AES_NUM_IVMRK_WORDS] */
|
||
|
void AesCbc_Init(UInt32 *ivAes, const Byte *iv); /* iv size is AES_BLOCK_SIZE */
|
||
|
|
||
|
/* data - 16-byte aligned pointer to data */
|
||
|
/* numBlocks - the number of 16-byte blocks in data array */
|
||
|
typedef void (Z7_FASTCALL *AES_CODE_FUNC)(UInt32 *ivAes, Byte *data, size_t numBlocks);
|
||
|
|
||
|
extern AES_CODE_FUNC g_AesCbc_Decode;
|
||
|
#ifndef Z7_SFX
|
||
|
extern AES_CODE_FUNC g_AesCbc_Encode;
|
||
|
extern AES_CODE_FUNC g_AesCtr_Code;
|
||
|
#define k_Aes_SupportedFunctions_HW (1 << 2)
|
||
|
#define k_Aes_SupportedFunctions_HW_256 (1 << 3)
|
||
|
extern UInt32 g_Aes_SupportedFunctions_Flags;
|
||
|
#endif
|
||
|
|
||
|
|
||
|
#define Z7_DECLARE_AES_CODE_FUNC(funcName) \
|
||
|
void Z7_FASTCALL funcName(UInt32 *ivAes, Byte *data, size_t numBlocks);
|
||
|
|
||
|
Z7_DECLARE_AES_CODE_FUNC (AesCbc_Encode)
|
||
|
Z7_DECLARE_AES_CODE_FUNC (AesCbc_Decode)
|
||
|
Z7_DECLARE_AES_CODE_FUNC (AesCtr_Code)
|
||
|
|
||
|
Z7_DECLARE_AES_CODE_FUNC (AesCbc_Encode_HW)
|
||
|
Z7_DECLARE_AES_CODE_FUNC (AesCbc_Decode_HW)
|
||
|
Z7_DECLARE_AES_CODE_FUNC (AesCtr_Code_HW)
|
||
|
|
||
|
Z7_DECLARE_AES_CODE_FUNC (AesCbc_Decode_HW_256)
|
||
|
Z7_DECLARE_AES_CODE_FUNC (AesCtr_Code_HW_256)
|
||
|
|
||
|
EXTERN_C_END
|
||
|
|
||
|
#endif
|