diff options
author | Takashi Iwai <tiwai@suse.de> | 2014-04-09 11:50:02 -0400 |
---|---|---|
committer | Takashi Iwai <tiwai@suse.de> | 2014-04-09 11:50:02 -0400 |
commit | 50487c3a4a96d91e25d43d63262773f14961d9de (patch) | |
tree | 9649437556ec56e5ba27e943313f093318b17b81 /lib | |
parent | 17c3ad030213da23158082ea90ebbe2a3940a2d2 (diff) | |
parent | ab5d6fbdb71c183add7431243c7f615c42b643bb (diff) |
Merge tag 'asoc-v3.15-5' of git://git.kernel.org/pub/scm/linux/kernel/git/broonie/sound into for-linus
ASoC: Fixes for v3.15
A smattering of device specific fixes, nothing stands out here except
for the multiplatform fixes for Samsung and the device IDs being added
by Stephen Warren - there's no real code changes from those and they
give better robustness to the enumeration with DT.
Diffstat (limited to 'lib')
-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; |