X-Git-Url: https://git.cryptolib.org/?a=blobdiff_plain;f=cubehash%2Fcubehash.c;h=318d553b18bb47f22837e84e4f7989e294ad248a;hb=7b5401ab9ce23a5da1de8b6c7de3a1aa20ac4cf8;hp=997378f912ef15f6ac318d85345bdbad3f802932;hpb=2f9b301c15c03faa76b7f9c95b18eadaa8d013ae;p=avr-crypto-lib.git diff --git a/cubehash/cubehash.c b/cubehash/cubehash.c index 997378f..318d553 100644 --- a/cubehash/cubehash.c +++ b/cubehash/cubehash.c @@ -26,21 +26,20 @@ */ -#include "memxor.h" +#include "memxor/memxor.h" #include "cubehash.h" +#include "cubehash_rotates.h" +#include "xchg.h" #include #include -static uint32_t rol32(uint32_t a, uint8_t r){ - return (a<>(32-r)); -} /* -• Add x_0jklm into x_1jklm modulo 232 , for each (j, k, l, m). +• Add x_0jklm into x_1jklm modulo 2**32 , for each (j, k, l, m). • Rotate x_0jklm upwards by 7 bits, for each (j, k, l, m). • Swap x_00klm with x_01klm , for each (k, l, m). • Xor x_1jklm into x_0jklm , for each (j, k, l, m). • Swap x_1jk0m with x_1jk1m , for each (j, k, m). -• Add x_0jklm into x_1jklm modulo 232 , for each (j, k, l, m). +• Add x_0jklm into x_1jklm modulo 2**32 , for each (j, k, l, m). • Rotate x_0jklm upwards by 11 bits, for each (j, k, l, m). • Swap x_0j0lm with x_0j1lm , for each (j, l, m). • Xor x_1jklm into x_0jklm , for each (j, k, l, m). @@ -49,52 +48,34 @@ static uint32_t rol32(uint32_t a, uint8_t r){ static void cubehash_round(cubehash_ctx_t* ctx){ uint8_t i; - uint32_t t; - for(i=0; i<16; ++i){ - ctx->a[i+16] += ctx->a[i]; - } - for(i=0; i<16; ++i){ - ctx->a[i] = rol32(ctx->a[i], 7); - } - for(i=0; i<8; ++i){ - t = ctx->a[i]; - ctx->a[i] = ctx->a[i+8]; - ctx->a[i+8] = t; - } - for(i=0; i<16; ++i){ - ctx->a[i] ^= ctx->a[i+16]; - } - for(i=16; i<4*4+16; i+=4){ - t = ctx->a[i]; - ctx->a[i] = ctx->a[i+2]; - ctx->a[i+2] = t; - t = ctx->a[i+1]; - ctx->a[i+1] = ctx->a[i+3]; - ctx->a[i+3] = t; - } - for(i=0; i<16; ++i){ - ctx->a[i+16] += ctx->a[i]; - } + uint32_t t, t2; for(i=0; i<16; ++i){ - ctx->a[i] = rol32(ctx->a[i], 11); + ctx->a[i+16] += t = ctx->a[i]; + ctx->a[i] = rotate7left(t); } - for(i=0; i<4; ++i){ - t = ctx->a[i]; - ctx->a[i] = ctx->a[i+4]; - ctx->a[i+4] = t; - } - for(i=8; i<4+8; ++i){ - t = ctx->a[i]; - ctx->a[i] = ctx->a[i+4]; - ctx->a[i+4] = t; - } - for(i=0; i<16; ++i){ - ctx->a[i] ^= ctx->a[i+16]; + xchg32_array(&(ctx->a[0]), &(ctx->a[8]), 8); + for(i=0; i<16; i+=4){ + t = ctx->a[i+16]; + t2 = ctx->a[i] ^= t; + ctx->a[i+16] = ctx->a[i+18] + t2; + ctx->a[i] = rotate11left(t2); + t2 = ctx->a[i+2] ^= ctx->a[i+18]; + ctx->a[i+18] = t + t2; + ctx->a[i+2] = rotate11left(t2); + t = ctx->a[i+17]; + t2 = ctx->a[i+1] ^= t; + ctx->a[i+17] = ctx->a[i+19] + t2; + ctx->a[i+1] = rotate11left(t2); + t2 = ctx->a[i+3] ^= ctx->a[i+19]; + ctx->a[i+19] = t + t2; + ctx->a[i+3] = rotate11left(t2); } - for(i=16; i<16+16; i+=2){ - t = ctx->a[i]; - ctx->a[i] = ctx->a[i+1]; - ctx->a[i+1] = t; + xchg32_array(&(ctx->a[0]), &(ctx->a[4]), 4); + xchg32_array(&(ctx->a[8]), &(ctx->a[12]), 4); + for(i=0; i<16; i+=2){ + ctx->a[i] ^= t = ctx->a[i+16]; + ctx->a[i+1] ^= ctx->a[i+16] = ctx->a[i+17]; + ctx->a[i+17] = t; } }