mirror of
https://github.com/qemu/qemu.git
synced 2025-01-12 16:43:26 +08:00
c8d70e5973
OpenSSL's libcrypto always defines AES symbols with the same names as qemu's local aes code. This is problematic when enabling at least curl as that frequently also uses libcrypto. It might not be noticed when running, but if you try to statically link, everything falls down. An example snippet: LINK qemu-nbd .../libcrypto.a(aes-x86_64.o): In function 'AES_encrypt': (.text+0x460): multiple definition of 'AES_encrypt' crypto/aes.o:aes.c:(.text+0x670): first defined here .../libcrypto.a(aes-x86_64.o): In function 'AES_decrypt': (.text+0x9f0): multiple definition of 'AES_decrypt' crypto/aes.o:aes.c:(.text+0xb30): first defined here .../libcrypto.a(aes-x86_64.o): In function 'AES_cbc_encrypt': (.text+0xf90): multiple definition of 'AES_cbc_encrypt' crypto/aes.o:aes.c:(.text+0xff0): first defined here collect2: error: ld returned 1 exit status .../qemu-2.6.0/rules.mak:105: recipe for target 'qemu-nbd' failed make: *** [qemu-nbd] Error 1 The aes.h header has redefines already for FreeBSD, but go ahead and enable that for everyone since there's no real good reason to not use a namespace all the time. Signed-off-by: Mike Frysinger <vapier@chromium.org> Signed-off-by: Daniel P. Berrange <berrange@redhat.com>
68 lines
2.1 KiB
C
68 lines
2.1 KiB
C
#ifndef QEMU_AES_H
|
|
#define QEMU_AES_H
|
|
|
|
#define AES_MAXNR 14
|
|
#define AES_BLOCK_SIZE 16
|
|
|
|
struct aes_key_st {
|
|
uint32_t rd_key[4 *(AES_MAXNR + 1)];
|
|
int rounds;
|
|
};
|
|
typedef struct aes_key_st AES_KEY;
|
|
|
|
/* FreeBSD/OpenSSL have their own AES functions with the same names in -lcrypto
|
|
* (which might be pulled in via curl), so redefine to avoid conflicts. */
|
|
#define AES_set_encrypt_key QEMU_AES_set_encrypt_key
|
|
#define AES_set_decrypt_key QEMU_AES_set_decrypt_key
|
|
#define AES_encrypt QEMU_AES_encrypt
|
|
#define AES_decrypt QEMU_AES_decrypt
|
|
#define AES_cbc_encrypt QEMU_AES_cbc_encrypt
|
|
|
|
int AES_set_encrypt_key(const unsigned char *userKey, const int bits,
|
|
AES_KEY *key);
|
|
int AES_set_decrypt_key(const unsigned char *userKey, const int bits,
|
|
AES_KEY *key);
|
|
|
|
void AES_encrypt(const unsigned char *in, unsigned char *out,
|
|
const AES_KEY *key);
|
|
void AES_decrypt(const unsigned char *in, unsigned char *out,
|
|
const AES_KEY *key);
|
|
void AES_cbc_encrypt(const unsigned char *in, unsigned char *out,
|
|
const unsigned long length, const AES_KEY *key,
|
|
unsigned char *ivec, const int enc);
|
|
|
|
extern const uint8_t AES_sbox[256];
|
|
extern const uint8_t AES_isbox[256];
|
|
|
|
/* AES ShiftRows and InvShiftRows */
|
|
extern const uint8_t AES_shifts[16];
|
|
extern const uint8_t AES_ishifts[16];
|
|
|
|
/* AES InvMixColumns */
|
|
/* AES_imc[x][0] = [x].[0e, 09, 0d, 0b]; */
|
|
/* AES_imc[x][1] = [x].[0b, 0e, 09, 0d]; */
|
|
/* AES_imc[x][2] = [x].[0d, 0b, 0e, 09]; */
|
|
/* AES_imc[x][3] = [x].[09, 0d, 0b, 0e]; */
|
|
extern const uint32_t AES_imc[256][4];
|
|
|
|
/*
|
|
AES_Te0[x] = S [x].[02, 01, 01, 03];
|
|
AES_Te1[x] = S [x].[03, 02, 01, 01];
|
|
AES_Te2[x] = S [x].[01, 03, 02, 01];
|
|
AES_Te3[x] = S [x].[01, 01, 03, 02];
|
|
AES_Te4[x] = S [x].[01, 01, 01, 01];
|
|
|
|
AES_Td0[x] = Si[x].[0e, 09, 0d, 0b];
|
|
AES_Td1[x] = Si[x].[0b, 0e, 09, 0d];
|
|
AES_Td2[x] = Si[x].[0d, 0b, 0e, 09];
|
|
AES_Td3[x] = Si[x].[09, 0d, 0b, 0e];
|
|
AES_Td4[x] = Si[x].[01, 01, 01, 01];
|
|
*/
|
|
|
|
extern const uint32_t AES_Te0[256], AES_Te1[256], AES_Te2[256],
|
|
AES_Te3[256], AES_Te4[256];
|
|
extern const uint32_t AES_Td0[256], AES_Td1[256], AES_Td2[256],
|
|
AES_Td3[256], AES_Td4[256];
|
|
|
|
#endif
|