changeset 750:88d366bd895e libavutil

Use pointer to hash transform function to make adding SHA-2 support easier.
author kostya
date Thu, 09 Jul 2009 07:23:43 +0000
parents cd5dc764dfbe
children e426c6e3a78a
files sha1.c
diffstat 1 files changed, 6 insertions(+), 3 deletions(-) [+]
line wrap: on
line diff
--- a/sha1.c	Thu Jul 09 07:15:30 2009 +0000
+++ b/sha1.c	Thu Jul 09 07:23:43 2009 +0000
@@ -29,6 +29,8 @@
     uint64_t count;       ///< number of bytes in buffer
     uint8_t  buffer[64];  ///< 512-bit buffer of input values used in hash updating
     uint32_t state[8];    ///< current hash value
+    /** function used to update hash for 512-bit input block */
+    void     (*transform)(uint32_t *state, const uint8_t buffer[64]);
 } AVSHA1;
 
 const int av_sha1_size = sizeof(AVSHA1);
@@ -132,6 +134,7 @@
     ctx->state[2] = 0x98BADCFE;
     ctx->state[3] = 0x10325476;
     ctx->state[4] = 0xC3D2E1F0;
+    ctx->transform = transform;
     ctx->count    = 0;
 }
 
@@ -145,16 +148,16 @@
     for (i = 0; i < len; i++) {
         ctx->buffer[j++] = data[i];
         if (64 == j) {
-            transform(ctx->state, ctx->buffer);
+            ctx->transform(ctx->state, ctx->buffer);
             j = 0;
         }
     }
 #else
     if ((j + len) > 63) {
         memcpy(&ctx->buffer[j], data, (i = 64 - j));
-        transform(ctx->state, ctx->buffer);
+        ctx->transform(ctx->state, ctx->buffer);
         for (; i + 63 < len; i += 64)
-            transform(ctx->state, &data[i]);
+            ctx->transform(ctx->state, &data[i]);
         j = 0;
     } else
         i = 0;