Commit 66764b54 authored by Matt Mackall's avatar Matt Mackall Committed by Linus Torvalds

[PATCH] random: Simplify hash folding

Simplify output hash folding
Signed-off-by: default avatarMatt Mackall <mpm@selenic.com>
Signed-off-by: default avatarAndrew Morton <akpm@osdl.org>
Signed-off-by: default avatarLinus Torvalds <torvalds@osdl.org>
parent 3f0564c1
...@@ -1166,15 +1166,10 @@ static void extract_buf(struct entropy_store *r, __u32 *buf) ...@@ -1166,15 +1166,10 @@ static void extract_buf(struct entropy_store *r, __u32 *buf)
* In case the hash function has some recognizable * In case the hash function has some recognizable
* output pattern, we fold it in half. * output pattern, we fold it in half.
*/ */
for (i = 0; i < HASH_BUFFER_SIZE / 2; i++)
buf[i] ^= buf[i + (HASH_BUFFER_SIZE + 1) / 2]; buf[0] ^= buf[3];
buf[1] ^= buf[4];
if (HASH_BUFFER_SIZE & 1) { buf[0] ^= rol32(buf[3], 16);
/* There's a middle word to deal with */
x = buf[HASH_BUFFER_SIZE/2];
x ^= (x >> 16); /* Fold it in half */
((__u16 *)buf)[HASH_BUFFER_SIZE - 1] = (__u16)x;
}
} }
static ssize_t extract_entropy(struct entropy_store *r, void * buf, static ssize_t extract_entropy(struct entropy_store *r, void * buf,
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment