diff options
| author | David Woodhouse <dwmw2@shinybook.infradead.org> | 2005-06-18 03:36:46 -0400 |
|---|---|---|
| committer | David Woodhouse <dwmw2@shinybook.infradead.org> | 2005-06-18 03:36:46 -0400 |
| commit | 0107b3cf3225aed6ddde4fa8dbcd4ed643b34f4d (patch) | |
| tree | 9b9337ae627fc56a0eda43c60860765f25efaa0b /kernel/sched.c | |
| parent | 1c3f45ab2f7f879ea482501c83899505c31f7539 (diff) | |
| parent | 9ee1c939d1cb936b1f98e8d81aeffab57bae46ab (diff) | |
Merge with master.kernel.org:/pub/scm/linux/kernel/git/torvalds/linux-2.6.git
Diffstat (limited to 'kernel/sched.c')
| -rw-r--r-- | kernel/sched.c | 7 |
1 files changed, 5 insertions, 2 deletions
diff --git a/kernel/sched.c b/kernel/sched.c index 66b2ed784822..f12a0c8a7d98 100644 --- a/kernel/sched.c +++ b/kernel/sched.c | |||
| @@ -3755,19 +3755,22 @@ EXPORT_SYMBOL(cond_resched); | |||
| 3755 | */ | 3755 | */ |
| 3756 | int cond_resched_lock(spinlock_t * lock) | 3756 | int cond_resched_lock(spinlock_t * lock) |
| 3757 | { | 3757 | { |
| 3758 | int ret = 0; | ||
| 3759 | |||
| 3758 | if (need_lockbreak(lock)) { | 3760 | if (need_lockbreak(lock)) { |
| 3759 | spin_unlock(lock); | 3761 | spin_unlock(lock); |
| 3760 | cpu_relax(); | 3762 | cpu_relax(); |
| 3763 | ret = 1; | ||
| 3761 | spin_lock(lock); | 3764 | spin_lock(lock); |
| 3762 | } | 3765 | } |
| 3763 | if (need_resched()) { | 3766 | if (need_resched()) { |
| 3764 | _raw_spin_unlock(lock); | 3767 | _raw_spin_unlock(lock); |
| 3765 | preempt_enable_no_resched(); | 3768 | preempt_enable_no_resched(); |
| 3766 | __cond_resched(); | 3769 | __cond_resched(); |
| 3770 | ret = 1; | ||
| 3767 | spin_lock(lock); | 3771 | spin_lock(lock); |
| 3768 | return 1; | ||
| 3769 | } | 3772 | } |
| 3770 | return 0; | 3773 | return ret; |
| 3771 | } | 3774 | } |
| 3772 | 3775 | ||
| 3773 | EXPORT_SYMBOL(cond_resched_lock); | 3776 | EXPORT_SYMBOL(cond_resched_lock); |
