Bladeren bron

random: Wake up all getrandom(2) callers when pool is ready

If more than one application invokes getrandom(2) before the pool
is ready, then all bar one will be stuck forever because we use
wake_up_interruptible which wakes up a single task.

This patch replaces it with wake_up_all.

Signed-off-by: Herbert Xu <herbert@gondor.apana.org.au>
Herbert Xu 10 jaren geleden
bovenliggende
commit
1d9de44e26
1 gewijzigde bestanden met toevoegingen van 1 en 1 verwijderingen
  1. 1 1
      drivers/char/random.c

+ 1 - 1
drivers/char/random.c

@@ -660,7 +660,7 @@ retry:
 		r->entropy_total = 0;
 		r->entropy_total = 0;
 		if (r == &nonblocking_pool) {
 		if (r == &nonblocking_pool) {
 			prandom_reseed_late();
 			prandom_reseed_late();
-			wake_up_interruptible(&urandom_init_wait);
+			wake_up_all(&urandom_init_wait);
 			pr_notice("random: %s pool is initialized\n", r->name);
 			pr_notice("random: %s pool is initialized\n", r->name);
 		}
 		}
 	}
 	}