X-Git-Url: https://git.cryptolib.org/?a=blobdiff_plain;f=twister-small.c;h=5fb05368ce9ff7d9255d1553ad38bd06006dff6b;hb=7701e318e4e2bac7f84dbf6e368f1501814948fc;hp=0713c960e5e2a4fb66d38a5dd3033dd8b9f316ab;hpb=4469def3e210fc904cfefc5b158fc6d4dc5f6e47;p=avr-crypto-lib.git diff --git a/twister-small.c b/twister-small.c index 0713c96..5fb0536 100644 --- a/twister-small.c +++ b/twister-small.c @@ -5,49 +5,55 @@ #include "memxor.h" #include "twister-small.h" -static -void maxi_round3(twister_state_t* ctx, void* msg, uint8_t last_null){ - mini_round(ctx, msg); - msg = ((uint8_t*)msg) + 8; - mini_round(ctx, msg); - if(last_null){ - blank_round(ctx); - } else { - msg = ((uint8_t*)msg) + 8; - mini_round(ctx, msg); - } +/*********************************************************************/ + +void twister_small_init(twister_state_t* ctx, uint16_t hashsize_b){ + memset(ctx->s, 0, 64); + ctx->counter=0xffffffffffffffffLL; + ctx->s[0][7] = hashsize_b>>8; + ctx->s[1][7] = hashsize_b&0xff; + ctx->length_counter_b = 0; } -void twister_small_nextBlock(twister_state_t* ctx, void* msg){ +/*********************************************************************/ + +void twister_small_nextBlock(twister_state_t* ctx, const void* msg){ uint8_t tmp[8][8]; /* round 1 */ memcpy(tmp, ctx->s, 64); - maxi_round3(ctx, msg, 0); + twister_mini_round(ctx, msg); + msg = ((uint8_t*)msg) + 8; + twister_mini_round(ctx, msg); + msg = ((uint8_t*)msg) + 8; + twister_mini_round(ctx, msg); + msg = ((uint8_t*)msg) + 8; memxor(ctx->s, tmp, 64); - msg = ((uint8_t*)msg) + 3*8; + /* round 2 */ memcpy(tmp, ctx->s, 64); - maxi_round3(ctx, msg, 0); + twister_mini_round(ctx, msg); + msg = ((uint8_t*)msg) + 8; + twister_mini_round(ctx, msg); + msg = ((uint8_t*)msg) + 8; + twister_mini_round(ctx, msg); + msg = ((uint8_t*)msg) + 8; memxor(ctx->s, tmp, 64); - msg = ((uint8_t*)msg) + 3*8; + /* round 3 */ memcpy(tmp, ctx->s, 64); - maxi_round3(ctx, msg, 1); + twister_mini_round(ctx, msg); + msg = ((uint8_t*)msg) + 8; + twister_mini_round(ctx, msg); + twister_blank_round(ctx); memxor(ctx->s, tmp, 64); ctx->length_counter_b += 512; } -void twister_small_init(twister_state_t* ctx, uint16_t hashsize_b){ - memset(ctx->s, 0, 64); - ctx->counter=0xffffffffffffffffLL; - ctx->s[0][7] = hashsize_b>>8; - ctx->s[1][7] = hashsize_b&0xff; - ctx->length_counter_b = 0; -} +/*********************************************************************/ -void twister_small_lastBlock(twister_state_t* ctx, void* msg, uint16_t length_b){ +void twister_small_lastBlock(twister_state_t* ctx, const void* msg, uint16_t length_b){ uint8_t tmp[64]; - while(length_b>512){ + while(length_b>=512){ twister_small_nextBlock(ctx, msg); msg = ((uint8_t*)msg)+64; length_b -= 512; @@ -57,56 +63,47 @@ void twister_small_lastBlock(twister_state_t* ctx, void* msg, uint16_t length_b) tmp[length_b/8] |= 0x80 >> (length_b&0x07); twister_small_nextBlock(ctx, tmp); ctx->length_counter_b -= 512 - length_b; - mini_round(ctx, &(ctx->length_counter_b)); - blank_round(ctx); + + twister_mini_round(ctx, &(ctx->length_counter_b)); + twister_blank_round(ctx); } +/*********************************************************************/ + void twister_small_ctx2hash(void* dest, twister_state_t* ctx, uint16_t hashsize_b){ - uint8_t tmp[8][8]; - uint8_t j; - uint16_t i=hashsize_b; - while(i>=64){ - i-=64; - memcpy(tmp,ctx->s, 64); - blank_round(ctx); - memxor(ctx->s, tmp, 64); - blank_round(ctx); - for(j=0; j<8; ++j){ - *((uint8_t*)dest) = ctx->s[7-j][0] ^ tmp[7-j][0]; - dest = (uint8_t*)dest + 1; - } - } - if(i>=32){ - memcpy(tmp,ctx->s, 64); - blank_round(ctx); - memxor(ctx->s, tmp, 64); - blank_round(ctx); - for(j=0; j<4; ++j){ - *((uint8_t*)dest) = ctx->s[3-j][0] ^ tmp[3-j][0]; - dest = (uint8_t*)dest + 1; - } - } + twister_ctx2hash(dest, ctx, hashsize_b); } +/*********************************************************************/ +/*********************************************************************/ + #ifndef NO_TWISTER_256 void twister256_init(twister256_ctx_t* ctx){ twister_small_init(ctx, 256); } -void twister256_nextBlock(twister256_ctx_t* ctx, void* msg){ +/*********************************************************************/ + +void twister256_nextBlock(twister256_ctx_t* ctx, const void* msg){ twister_small_nextBlock(ctx, msg); } -void twister256_lastBlock(twister256_ctx_t* ctx, void* msg, uint16_t length_b){ +/*********************************************************************/ + +void twister256_lastBlock(twister256_ctx_t* ctx, const void* msg, uint16_t length_b){ twister_small_lastBlock(ctx, msg, length_b); } +/*********************************************************************/ + void twister256_ctx2hash(void* dest, twister256_ctx_t* ctx){ - twister_small_ctx2hash(dest, ctx, 256); + twister_ctx2hash(dest, ctx, 256); } -void twister256(void* dest, void* msg, uint32_t msg_length_b){ +/*********************************************************************/ + +void twister256(void* dest, const void* msg, uint32_t msg_length_b){ twister_state_t ctx; twister_small_init(&ctx, 256); while(msg_length_b >=512){ @@ -115,30 +112,43 @@ void twister256(void* dest, void* msg, uint32_t msg_length_b){ msg_length_b -= 512; } twister_small_lastBlock(&ctx, msg, msg_length_b); - twister_small_ctx2hash(dest, &ctx, 256); + twister_ctx2hash(dest, &ctx, 256); } +/*********************************************************************/ + #endif +/*********************************************************************/ +/*********************************************************************/ + #ifndef NO_TWISTER_224 void twister224_init(twister224_ctx_t* ctx){ twister_small_init(ctx, 224); } -void twister224_nextBlock(twister224_ctx_t* ctx, void* msg){ +/*********************************************************************/ + +void twister224_nextBlock(twister224_ctx_t* ctx, const void* msg){ twister_small_nextBlock(ctx, msg); } -void twister224_lastBlock(twister224_ctx_t* ctx, void* msg, uint16_t length_b){ +/*********************************************************************/ + +void twister224_lastBlock(twister224_ctx_t* ctx, const void* msg, uint16_t length_b){ twister_small_lastBlock(ctx, msg, length_b); } +/*********************************************************************/ + void twister224_ctx2hash(void* dest, twister224_ctx_t* ctx){ - twister_small_ctx2hash(dest, ctx, 224); + twister_ctx2hash(dest, ctx, 224); } -void twister224(void* dest, void* msg, uint32_t msg_length_b){ +/*********************************************************************/ + +void twister224(void* dest, const void* msg, uint32_t msg_length_b){ twister_state_t ctx; twister_small_init(&ctx, 224); while(msg_length_b >=512){ @@ -147,7 +157,7 @@ void twister224(void* dest, void* msg, uint32_t msg_length_b){ msg_length_b -= 512; } twister_small_lastBlock(&ctx, msg, msg_length_b); - twister_small_ctx2hash(dest, &ctx, 224); + twister_ctx2hash(dest, &ctx, 224); } #endif