1
0
mirror of https://github.com/FFmpeg/FFmpeg.git synced 2024-12-23 12:43:46 +02:00

aes: fix invalid array indexing in init code

This makes the code work with clang/x86_32 and removes several warnings.

Signed-off-by: Mans Rullgard <mans@mansr.com>
This commit is contained in:
Mans Rullgard 2011-07-02 22:10:25 +01:00
parent 21accb3bb2
commit 5d20f19be2

View File

@ -54,6 +54,8 @@ static uint32_t enc_multbl[4][256];
static uint32_t dec_multbl[4][256]; static uint32_t dec_multbl[4][256];
#endif #endif
#define ROT(x, s) ((x << s) | (x >> (32-s)))
static inline void addkey(av_aes_block *dst, const av_aes_block *src, static inline void addkey(av_aes_block *dst, const av_aes_block *src,
const av_aes_block *round_key) const av_aes_block *round_key)
{ {
@ -86,7 +88,6 @@ static void subshift(av_aes_block s0[2], int s, const uint8_t *box)
static inline int mix_core(uint32_t multbl[][256], int a, int b, int c, int d){ static inline int mix_core(uint32_t multbl[][256], int a, int b, int c, int d){
#if CONFIG_SMALL #if CONFIG_SMALL
#define ROT(x,s) ((x<<s)|(x>>(32-s)))
return multbl[0][a] ^ ROT(multbl[0][b], 8) ^ ROT(multbl[0][c], 16) ^ ROT(multbl[0][d], 24); return multbl[0][a] ^ ROT(multbl[0][b], 8) ^ ROT(multbl[0][c], 16) ^ ROT(multbl[0][d], 24);
#else #else
return multbl[0][a] ^ multbl[1][b] ^ multbl[2][c] ^ multbl[3][d]; return multbl[0][a] ^ multbl[1][b] ^ multbl[2][c] ^ multbl[3][d];
@ -143,23 +144,30 @@ void av_aes_crypt(AVAES *a, uint8_t *dst_, const uint8_t *src_,
} }
} }
static void init_multbl2(uint8_t tbl[1024], const int c[4], static void init_multbl2(uint32_t tbl[][256], const int c[4],
const uint8_t *log8, const uint8_t *alog8, const uint8_t *log8, const uint8_t *alog8,
const uint8_t *sbox) const uint8_t *sbox)
{ {
int i, j; int i;
for (i = 0; i < 1024; i++) { for (i = 0; i < 256; i++) {
int x = sbox[i >> 2]; int x = sbox[i];
if (x) if (x) {
tbl[i] = alog8[log8[x] + log8[c[i & 3]]]; int k, l, m, n;
} x = log8[x];
k = alog8[x + log8[c[0]]];
l = alog8[x + log8[c[1]]];
m = alog8[x + log8[c[2]]];
n = alog8[x + log8[c[3]]];
tbl[0][i] = AV_NE(MKBETAG(k,l,m,n), MKTAG(k,l,m,n));
#if !CONFIG_SMALL #if !CONFIG_SMALL
for (j = 256; j < 1024; j++) tbl[1][i] = ROT(tbl[0][i], 8);
for (i = 0; i < 4; i++) tbl[2][i] = ROT(tbl[0][i], 16);
tbl[4*j + i] = tbl[4*j + ((i - 1) & 3) - 1024]; tbl[3][i] = ROT(tbl[0][i], 24);
#endif #endif
} }
}
}
// this is based on the reference AES code by Paulo Barreto and Vincent Rijmen // this is based on the reference AES code by Paulo Barreto and Vincent Rijmen
int av_aes_init(AVAES *a, const uint8_t *key, int key_bits, int decrypt) int av_aes_init(AVAES *a, const uint8_t *key, int key_bits, int decrypt)
@ -187,9 +195,9 @@ int av_aes_init(AVAES *a, const uint8_t *key, int key_bits, int decrypt)
inv_sbox[j] = i; inv_sbox[j] = i;
sbox[i] = j; sbox[i] = j;
} }
init_multbl2(dec_multbl[0], (const int[4]) { 0xe, 0x9, 0xd, 0xb }, init_multbl2(dec_multbl, (const int[4]) { 0xe, 0x9, 0xd, 0xb },
log8, alog8, inv_sbox); log8, alog8, inv_sbox);
init_multbl2(enc_multbl[0], (const int[4]) { 0x2, 0x1, 0x1, 0x3 }, init_multbl2(enc_multbl, (const int[4]) { 0x2, 0x1, 0x1, 0x3 },
log8, alog8, sbox); log8, alog8, sbox);
} }