]> git.ipfire.org Git - thirdparty/kernel/stable.git/commitdiff
random: check for crng_init == 0 in add_device_randomness()
authorJason A. Donenfeld <Jason@zx2c4.com>
Sat, 12 Feb 2022 22:57:38 +0000 (23:57 +0100)
committerGreg Kroah-Hartman <gregkh@linuxfoundation.org>
Sat, 25 Jun 2022 09:49:07 +0000 (11:49 +0200)
commit 1daf2f387652bf3a7044aea042f5023b3f6b189b upstream.

This has no real functional change, as crng_pre_init_inject() (and
before that, crng_slow_init()) always checks for == 0, not >= 2. So
correct the outer unlocked change to reflect that. Before this used
crng_ready(), which was not correct.

Cc: Theodore Ts'o <tytso@mit.edu>
Reviewed-by: Dominik Brodowski <linux@dominikbrodowski.net>
Reviewed-by: Eric Biggers <ebiggers@google.com>
Signed-off-by: Jason A. Donenfeld <Jason@zx2c4.com>
Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
drivers/char/random.c

index d349e9f03e7b99858f35c9b9ecf523dd0a731141..84e4f020e727ded81a1e4b4ea36fd4e7905068a3 100644 (file)
@@ -1015,7 +1015,7 @@ void add_device_randomness(const void *buf, size_t size)
        unsigned long time = random_get_entropy() ^ jiffies;
        unsigned long flags;
 
-       if (!crng_ready() && size)
+       if (crng_init == 0 && size)
                crng_pre_init_inject(buf, size, false, false);
 
        spin_lock_irqsave(&input_pool.lock, flags);