1
0
Fork 0
mirror of https://github.com/cryb-to/cryb-to.git synced 2025-01-13 23:31:12 +00:00

Remove an unnecessary pointer from struct aes_ctx.

The rk pointer in struct aes_ctx always pointed to the context's buffer and served no purpose whatsoever, but the compiler had no way of knowing that and could therefore not optimize away assignments to and from it.

Note that the removal of rk breaks the ABI, since it changes the size of struct aes_ctx, but we allow ourselves that because neither the API nor the ABI have been fixed yet.
This commit is contained in:
Dag-Erling Smørgrav 2017-03-03 23:34:49 +01:00
parent 95b2518eed
commit d419d7388a
2 changed files with 5 additions and 7 deletions
include/cryb
lib/cipher

View file

@ -40,7 +40,6 @@ CRYB_BEGIN
#define AES_BLOCK_LEN 16 #define AES_BLOCK_LEN 16
#define aes_digest cryb_aes_digest
#define aes_ctx cryb_aes_ctx #define aes_ctx cryb_aes_ctx
#define aes_init cryb_aes_init #define aes_init cryb_aes_init
#define aes_update cryb_aes_update #define aes_update cryb_aes_update
@ -53,8 +52,7 @@ extern cipher_algorithm aes256_cipher;
typedef struct { typedef struct {
int mode; int mode;
int nr; int nr;
uint32_t *rk; uint32_t rk[68];
uint32_t buf[68];
} aes_ctx; } aes_ctx;
void aes_init(aes_ctx *, cipher_mode, const uint8_t *, size_t); void aes_init(aes_ctx *, cipher_mode, const uint8_t *, size_t);

View file

@ -321,7 +321,7 @@ CRYB_DISABLE_COVERAGE
return; return;
CRYB_RESTORE_COVERAGE CRYB_RESTORE_COVERAGE
} }
ctx->rk = RK = ctx->buf; RK = ctx->rk;
for (i = 0; i < (keysize >> 2); i++) for (i = 0; i < (keysize >> 2); i++)
RK[i] = le32dec(key + (i << 2)); RK[i] = le32dec(key + (i << 2));
switch (ctx->nr) { switch (ctx->nr) {
@ -406,7 +406,7 @@ CRYB_DISABLE_COVERAGE
return; return;
CRYB_RESTORE_COVERAGE CRYB_RESTORE_COVERAGE
} }
ctx->rk = RK = ctx->buf; RK = ctx->rk;
aes_setkey_enc(&cty, key, keysize); aes_setkey_enc(&cty, key, keysize);
SK = cty.rk + cty.nr * 4; SK = cty.rk + cty.nr * 4;
*RK++ = *SK++; *RK++ = *SK++;