]> git.cryptolib.org Git - avr-crypto-lib.git/blobdiff - twister-small.c
now comes twister-512
[avr-crypto-lib.git] / twister-small.c
index 0713c960e5e2a4fb66d38a5dd3033dd8b9f316ab..68e8e827b67b96e11212e1455d5386382c943486 100644 (file)
@@ -5,45 +5,51 @@
 #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){
        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){
        uint8_t tmp[64];        
@@ -57,55 +63,45 @@ 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){
        twister_small_nextBlock(ctx, msg);
 }
 
+/*********************************************************************/
+
 void twister256_lastBlock(twister256_ctx_t* ctx, 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){
        twister_state_t ctx;
        twister_small_init(&ctx, 256);
@@ -115,29 +111,42 @@ 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){
        twister_small_nextBlock(ctx, msg);
 }
 
+/*********************************************************************/
+
 void twister224_lastBlock(twister224_ctx_t* ctx, 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){
        twister_state_t ctx;
        twister_small_init(&ctx, 224);
@@ -147,7 +156,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