diff options
-rw-r--r-- | drivers/char/random.c | 24 |
1 files changed, 13 insertions, 11 deletions
diff --git a/drivers/char/random.c b/drivers/char/random.c index a2329a11e139..d125a4b792d0 100644 --- a/drivers/char/random.c +++ b/drivers/char/random.c | |||
@@ -765,9 +765,9 @@ static size_t account(struct entropy_store *r, size_t nbytes, int min, | |||
765 | static void extract_buf(struct entropy_store *r, __u8 *out) | 765 | static void extract_buf(struct entropy_store *r, __u8 *out) |
766 | { | 766 | { |
767 | int i; | 767 | int i; |
768 | __u32 data[16], buf[5 + SHA_WORKSPACE_WORDS]; | 768 | __u32 extract[16], hash[5], workspace[SHA_WORKSPACE_WORDS]; |
769 | 769 | ||
770 | sha_init(buf); | 770 | sha_init(hash); |
771 | /* | 771 | /* |
772 | * As we hash the pool, we mix intermediate values of | 772 | * As we hash the pool, we mix intermediate values of |
773 | * the hash back into the pool. This eliminates | 773 | * the hash back into the pool. This eliminates |
@@ -778,9 +778,9 @@ static void extract_buf(struct entropy_store *r, __u8 *out) | |||
778 | */ | 778 | */ |
779 | for (i = 0; i < r->poolinfo->poolwords; i += 16) { | 779 | for (i = 0; i < r->poolinfo->poolwords; i += 16) { |
780 | /* hash blocks of 16 words = 512 bits */ | 780 | /* hash blocks of 16 words = 512 bits */ |
781 | sha_transform(buf, (__u8 *)(r->pool + i), buf + 5); | 781 | sha_transform(hash, (__u8 *)(r->pool + i), workspace); |
782 | /* feed back portion of the resulting hash */ | 782 | /* feed back portion of the resulting hash */ |
783 | add_entropy_words(r, &buf[i % 5], 1); | 783 | add_entropy_words(r, &hash[i % 5], 1); |
784 | } | 784 | } |
785 | 785 | ||
786 | /* | 786 | /* |
@@ -788,19 +788,21 @@ static void extract_buf(struct entropy_store *r, __u8 *out) | |||
788 | * portion of the pool while mixing, and hash one | 788 | * portion of the pool while mixing, and hash one |
789 | * final time. | 789 | * final time. |
790 | */ | 790 | */ |
791 | __add_entropy_words(r, &buf[i % 5], 1, data); | 791 | __add_entropy_words(r, &hash[i % 5], 1, extract); |
792 | sha_transform(buf, (__u8 *)data, buf + 5); | 792 | sha_transform(hash, (__u8 *)extract, workspace); |
793 | memset(extract, 0, sizeof(extract)); | ||
794 | memset(workspace, 0, sizeof(workspace)); | ||
793 | 795 | ||
794 | /* | 796 | /* |
795 | * In case the hash function has some recognizable | 797 | * In case the hash function has some recognizable |
796 | * output pattern, we fold it in half. | 798 | * output pattern, we fold it in half. |
797 | */ | 799 | */ |
798 | 800 | ||
799 | buf[0] ^= buf[3]; | 801 | hash[0] ^= hash[3]; |
800 | buf[1] ^= buf[4]; | 802 | hash[1] ^= hash[4]; |
801 | buf[2] ^= rol32(buf[2], 16); | 803 | hash[2] ^= rol32(hash[2], 16); |
802 | memcpy(out, buf, EXTRACT_SIZE); | 804 | memcpy(out, hash, EXTRACT_SIZE); |
803 | memset(buf, 0, sizeof(buf)); | 805 | memset(hash, 0, sizeof(hash)); |
804 | } | 806 | } |
805 | 807 | ||
806 | static ssize_t extract_entropy(struct entropy_store *r, void *buf, | 808 | static ssize_t extract_entropy(struct entropy_store *r, void *buf, |