diff options
author | Linus Torvalds <torvalds@linux-foundation.org> | 2008-05-11 19:04:48 -0400 |
---|---|---|
committer | Linus Torvalds <torvalds@linux-foundation.org> | 2008-05-11 19:04:48 -0400 |
commit | c3921ab71507b108d51a0f1ee960f80cd668a93d (patch) | |
tree | b1408b898a8b50f15ad4a0cf1f29e17cc0138485 /kernel | |
parent | 9662369786b9d07fd46d65b0f9e3938a3e01a5d9 (diff) |
Add new 'cond_resched_bkl()' helper function
It acts exactly like a regular 'cond_resched()', but will not get
optimized away when CONFIG_PREEMPT is set.
Normal kernel code is already preemptable in the presense of
CONFIG_PREEMPT, so cond_resched() is optimized away (see commit
02b67cc3ba36bdba351d6c3a00593f4ec550d9d3 "sched: do not do
cond_resched() when CONFIG_PREEMPT").
But when wanting to conditionally reschedule while holding a lock, you
need to use "cond_sched_lock(lock)", and the new function is the BKL
equivalent of that.
Also make fs/locks.c use it.
Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org>
Diffstat (limited to 'kernel')
-rw-r--r-- | kernel/sched.c | 2 |
1 files changed, 0 insertions, 2 deletions
diff --git a/kernel/sched.c b/kernel/sched.c index c51b6565e07c..8841a915545d 100644 --- a/kernel/sched.c +++ b/kernel/sched.c | |||
@@ -5525,7 +5525,6 @@ static void __cond_resched(void) | |||
5525 | } while (need_resched()); | 5525 | } while (need_resched()); |
5526 | } | 5526 | } |
5527 | 5527 | ||
5528 | #if !defined(CONFIG_PREEMPT) || defined(CONFIG_PREEMPT_VOLUNTARY) | ||
5529 | int __sched _cond_resched(void) | 5528 | int __sched _cond_resched(void) |
5530 | { | 5529 | { |
5531 | if (need_resched() && !(preempt_count() & PREEMPT_ACTIVE) && | 5530 | if (need_resched() && !(preempt_count() & PREEMPT_ACTIVE) && |
@@ -5536,7 +5535,6 @@ int __sched _cond_resched(void) | |||
5536 | return 0; | 5535 | return 0; |
5537 | } | 5536 | } |
5538 | EXPORT_SYMBOL(_cond_resched); | 5537 | EXPORT_SYMBOL(_cond_resched); |
5539 | #endif | ||
5540 | 5538 | ||
5541 | /* | 5539 | /* |
5542 | * cond_resched_lock() - if a reschedule is pending, drop the given lock, | 5540 | * cond_resched_lock() - if a reschedule is pending, drop the given lock, |