Donate to e Foundation | Murena handsets with /e/OS | Own a part of Murena! Learn more

Commit 2dac8e54 authored by H. Peter Anvin's avatar H. Peter Anvin
Browse files

random: Adjust the number of loops when initializing



When we are initializing using arch_get_random_long() we only need to
loop enough times to touch all the bytes in the buffer; using
poolwords for that does twice the number of operations necessary on a
64-bit machine, since in the random number generator code "word" means
32 bits.

Signed-off-by: default avatarH. Peter Anvin <hpa@linux.intel.com>
Cc: "Theodore Ts'o" <tytso@mit.edu>
Link: http://lkml.kernel.org/r/1324589281-31931-1-git-send-email-tytso@mit.edu
parent 3e88bdff
Loading
Loading
Loading
Loading
+1 −1
Original line number Diff line number Diff line
@@ -975,7 +975,7 @@ static void init_std_data(struct entropy_store *r)

	now = ktime_get_real();
	mix_pool_bytes(r, &now, sizeof(now));
	for (i = r->poolinfo->poolwords; i; i--) {
	for (i = r->poolinfo->POOLBYTES; i > 0; i -= sizeof flags) {
		if (!arch_get_random_long(&flags))
			break;
		mix_pool_bytes(r, &flags, sizeof(flags));