lib: Fix strict-aliasing warning in md5 code.
authorAndreas Schneider <asn@samba.org>
Thu, 9 Jan 2014 13:50:18 +0000 (14:50 +0100)
committerAndreas Schneider <asn@cryptomilk.org>
Thu, 9 Jan 2014 19:42:54 +0000 (20:42 +0100)
If the compiler detects strict aliasing problems it isn't able to
optimize the code.

Signed-off-by: Andreas Schneider <asn@samba.org>
Reviewed-by: Günther Deschner <gd@samba.org>
lib/crypto/md5.c

index b834c912dfb97a931be31675e3fa604397f284a9..352f80f5d110cfe4384f89f6cb37b3529b172a6d 100644 (file)
@@ -137,9 +137,12 @@ _PUBLIC_ void MD5Final(uint8_t digest[16], MD5_CTX *ctx)
     }
     byteReverse(ctx->in, 14);
 
-    /* Append length in bits and transform */
-    ((uint32_t *) ctx->in)[14] = ctx->bits[0];
-    ((uint32_t *) ctx->in)[15] = ctx->bits[1];
+    /* Append length in bits and transform.
+     * Use memcpy to avoid strict-aliasing problems.
+     * This way it can be optimized.
+     */
+    memcpy(&ctx->in[14 * sizeof(uint32_t)], &ctx->bits[0], sizeof(uint32_t));
+    memcpy(&ctx->in[15 * sizeof(uint32_t)], &ctx->bits[1], sizeof(uint32_t));
 
     MD5Transform(ctx->buf, (uint32_t *) ctx->in);
     byteReverse((uint8_t *) ctx->buf, 4);