]> www.wagner.pp.ru Git - openssl-gost/engine.git/blobdiff - gosthash2012.c
Fix Streebog alignment problem
[openssl-gost/engine.git] / gosthash2012.c
index ee534c2f9f838f2ef52797c23e88e63f98b9b5ef..bbe7dcbf83d1cb8932bf24d34b10c5f9540e04dd 100644 (file)
@@ -157,10 +157,13 @@ static void g(union uint512_u *h, const union uint512_u *N,
 
 static INLINE void stage2(gost2012_hash_ctx * CTX, const unsigned char *data)
 {
-    g(&(CTX->h), &(CTX->N), data);
+    union uint512_u m;
+
+    memcpy(&m, data, sizeof(m));
+    g(&(CTX->h), &(CTX->N), (const unsigned char *)&m);
 
     add512(&(CTX->N), &buffer512, &(CTX->N));
-    add512(&(CTX->Sigma), (const union uint512_u *)data, &(CTX->Sigma));
+    add512(&(CTX->Sigma), &m, &(CTX->Sigma));
 }
 
 static INLINE void stage3(gost2012_hash_ctx * CTX)