random: avoid checking crng_ready() twice in random_init()
authorJason A. Donenfeld <Jason@zx2c4.com>
Tue, 7 Jun 2022 07:44:07 +0000 (09:44 +0200)
committerJason A. Donenfeld <Jason@zx2c4.com>
Fri, 10 Jun 2022 09:09:36 +0000 (11:09 +0200)
The current flow expands to:

    if (crng_ready())
       ...
    else if (...)
        if (!crng_ready())
            ...

The second crng_ready() call is redundant, but can't so easily be
optimized out by the compiler.

This commit simplifies that to:

    if (crng_ready()
        ...
    else if (...)
        ...

Fixes: 560181c27b58 ("random: move initialization functions out of hot pages")
Cc: stable@vger.kernel.org
Cc: Dominik Brodowski <linux@dominikbrodowski.net>
Signed-off-by: Jason A. Donenfeld <Jason@zx2c4.com>
drivers/char/random.c

index b691b9d5950331257af811d7c6f50fe113b77c51..4862d4d3ec49c1c3b2dec9941de48bb8fd6f2213 100644 (file)
@@ -801,7 +801,7 @@ int __init random_init(const char *command_line)
        if (crng_ready())
                crng_reseed();
        else if (trust_cpu)
-               credit_init_bits(arch_bytes * 8);
+               _credit_init_bits(arch_bytes * 8);
        used_arch_random = arch_bytes * 8 >= POOL_READY_BITS;
 
        WARN_ON(register_pm_notifier(&pm_notifier));