aboutsummaryrefslogtreecommitdiffstats
path: root/kernel
diff options
context:
space:
mode:
authorRafael J. Wysocki <rjw@sisk.pl>2012-03-28 17:29:45 -0400
committerRafael J. Wysocki <rjw@sisk.pl>2012-03-28 17:29:45 -0400
commitfe2e39d8782d885755139304d8dba0b3e5bfa878 (patch)
tree200fb998fe94b9ccd93d07c59656b8f5ab62c5d7 /kernel
parent9a4768d849d28a79566aa37de19b9852d2da8ec4 (diff)
firmware_class: Rework usermodehelper check
Instead of two functions, read_lock_usermodehelper() and usermodehelper_is_disabled(), used in combination, introduce usermodehelper_read_trylock() that will only return with umhelper_sem held if usermodehelper_disabled is unset (and will return -EAGAIN otherwise) and make _request_firmware() use it. Rename read_unlock_usermodehelper() to usermodehelper_read_unlock() to follow the naming convention of the new function. Signed-off-by: Rafael J. Wysocki <rjw@sisk.pl> Acked-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org> Cc: stable@vger.kernel.org
Diffstat (limited to 'kernel')
-rw-r--r--kernel/kmod.c24
1 files changed, 11 insertions, 13 deletions
diff --git a/kernel/kmod.c b/kernel/kmod.c
index 957a7aab8ebc..4079ac1d5e79 100644
--- a/kernel/kmod.c
+++ b/kernel/kmod.c
@@ -339,17 +339,24 @@ static DECLARE_WAIT_QUEUE_HEAD(running_helpers_waitq);
339 */ 339 */
340#define RUNNING_HELPERS_TIMEOUT (5 * HZ) 340#define RUNNING_HELPERS_TIMEOUT (5 * HZ)
341 341
342void read_lock_usermodehelper(void) 342int usermodehelper_read_trylock(void)
343{ 343{
344 int ret = 0;
345
344 down_read(&umhelper_sem); 346 down_read(&umhelper_sem);
347 if (usermodehelper_disabled) {
348 up_read(&umhelper_sem);
349 ret = -EAGAIN;
350 }
351 return ret;
345} 352}
346EXPORT_SYMBOL_GPL(read_lock_usermodehelper); 353EXPORT_SYMBOL_GPL(usermodehelper_read_trylock);
347 354
348void read_unlock_usermodehelper(void) 355void usermodehelper_read_unlock(void)
349{ 356{
350 up_read(&umhelper_sem); 357 up_read(&umhelper_sem);
351} 358}
352EXPORT_SYMBOL_GPL(read_unlock_usermodehelper); 359EXPORT_SYMBOL_GPL(usermodehelper_read_unlock);
353 360
354/** 361/**
355 * usermodehelper_disable - prevent new helpers from being started 362 * usermodehelper_disable - prevent new helpers from being started
@@ -390,15 +397,6 @@ void usermodehelper_enable(void)
390 up_write(&umhelper_sem); 397 up_write(&umhelper_sem);
391} 398}
392 399
393/**
394 * usermodehelper_is_disabled - check if new helpers are allowed to be started
395 */
396bool usermodehelper_is_disabled(void)
397{
398 return usermodehelper_disabled;
399}
400EXPORT_SYMBOL_GPL(usermodehelper_is_disabled);
401
402static void helper_lock(void) 400static void helper_lock(void)
403{ 401{
404 atomic_inc(&running_helpers); 402 atomic_inc(&running_helpers);