|
@@ -18,6 +18,7 @@
|
|
|
#include <linux/types.h>
|
|
|
#include <crypto/sha3.h>
|
|
|
#include <asm/byteorder.h>
|
|
|
+#include <asm/unaligned.h>
|
|
|
|
|
|
#define KECCAK_ROUNDS 24
|
|
|
|
|
@@ -149,7 +150,7 @@ static int sha3_update(struct shash_desc *desc, const u8 *data,
|
|
|
unsigned int i;
|
|
|
|
|
|
for (i = 0; i < sctx->rsizw; i++)
|
|
|
- sctx->st[i] ^= ((u64 *) src)[i];
|
|
|
+ sctx->st[i] ^= get_unaligned_le64(src + 8 * i);
|
|
|
keccakf(sctx->st);
|
|
|
|
|
|
done += sctx->rsiz;
|
|
@@ -174,7 +175,7 @@ static int sha3_final(struct shash_desc *desc, u8 *out)
|
|
|
sctx->buf[sctx->rsiz - 1] |= 0x80;
|
|
|
|
|
|
for (i = 0; i < sctx->rsizw; i++)
|
|
|
- sctx->st[i] ^= ((u64 *) sctx->buf)[i];
|
|
|
+ sctx->st[i] ^= get_unaligned_le64(sctx->buf + 8 * i);
|
|
|
|
|
|
keccakf(sctx->st);
|
|
|
|