diff options
| author | David Vrabel <david.vrabel@citrix.com> | 2014-04-07 08:52:12 -0400 |
|---|---|---|
| committer | David Vrabel <david.vrabel@citrix.com> | 2014-04-07 08:52:12 -0400 |
| commit | 2c5cb2770392fb9c5d8518688c8bc61986d70dc6 (patch) | |
| tree | b19210e709de6ee0d22b67ef605a569500cf1a18 /lib/random32.c | |
| parent | cd979883b9ede90643e019f33cb317933eb867b4 (diff) | |
| parent | 683b6c6f82a60fabf47012581c2cfbf1b037ab95 (diff) | |
Merge commit '683b6c6f82a60fabf47012581c2cfbf1b037ab95' into stable/for-linus-3.15
This merge of the irq-core-for-linus branch broke the ARM build when
Xen is enabled.
Conflicts:
drivers/xen/events/events_base.c
Diffstat (limited to 'lib/random32.c')
| -rw-r--r-- | lib/random32.c | 13 |
1 files changed, 12 insertions, 1 deletions
diff --git a/lib/random32.c b/lib/random32.c index 1e5b2df44291..614896778700 100644 --- a/lib/random32.c +++ b/lib/random32.c | |||
| @@ -244,8 +244,19 @@ static void __prandom_reseed(bool late) | |||
| 244 | static bool latch = false; | 244 | static bool latch = false; |
| 245 | static DEFINE_SPINLOCK(lock); | 245 | static DEFINE_SPINLOCK(lock); |
| 246 | 246 | ||
| 247 | /* Asking for random bytes might result in bytes getting | ||
| 248 | * moved into the nonblocking pool and thus marking it | ||
| 249 | * as initialized. In this case we would double back into | ||
| 250 | * this function and attempt to do a late reseed. | ||
| 251 | * Ignore the pointless attempt to reseed again if we're | ||
| 252 | * already waiting for bytes when the nonblocking pool | ||
| 253 | * got initialized. | ||
| 254 | */ | ||
| 255 | |||
| 247 | /* only allow initial seeding (late == false) once */ | 256 | /* only allow initial seeding (late == false) once */ |
| 248 | spin_lock_irqsave(&lock, flags); | 257 | if (!spin_trylock_irqsave(&lock, flags)) |
| 258 | return; | ||
| 259 | |||
| 249 | if (latch && !late) | 260 | if (latch && !late) |
| 250 | goto out; | 261 | goto out; |
| 251 | latch = true; | 262 | latch = true; |
