aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorIngo Molnar <mingo@elte.hu>2006-07-14 03:24:27 -0400
committerLinus Torvalds <torvalds@g5.osdl.org>2006-07-15 00:53:55 -0400
commit3a5f5e488ceee9e08df3dff3f01b12fafc9e7e68 (patch)
tree12ebd936831e797780b9cf716cc7aaf337b25141
parent2e8f7a3128bb8fac8351a994f1fc325717899308 (diff)
[PATCH] lockdep: core, fix rq-lock handling on __ARCH_WANT_UNLOCKED_CTXSW
On platforms that have __ARCH_WANT_UNLOCKED_CTXSW set and want to implement lock validator support there's a bug in rq->lock handling: in this case we dont 'carry over' the runqueue lock into another task - but still we did a spinlock_release() of it. Fix this by making the spinlock_release() in context_switch() dependent on !__ARCH_WANT_UNLOCKED_CTXSW. (Reported by Ralf Baechle on MIPS, which has __ARCH_WANT_UNLOCKED_CTXSW. This fixes a lockdep-internal BUG message on such platforms.) Signed-off-by: Ingo Molnar <mingo@elte.hu> Cc: Ralf Baechle <ralf@linux-mips.org> Cc: Arjan van de Ven <arjan@linux.intel.com> Signed-off-by: Andrew Morton <akpm@osdl.org> Signed-off-by: Linus Torvalds <torvalds@osdl.org>
-rw-r--r--kernel/sched.c8
1 files changed, 8 insertions, 0 deletions
diff --git a/kernel/sched.c b/kernel/sched.c
index d714611f1691..e9a0b61f12ab 100644
--- a/kernel/sched.c
+++ b/kernel/sched.c
@@ -1788,7 +1788,15 @@ context_switch(struct rq *rq, struct task_struct *prev,
1788 WARN_ON(rq->prev_mm); 1788 WARN_ON(rq->prev_mm);
1789 rq->prev_mm = oldmm; 1789 rq->prev_mm = oldmm;
1790 } 1790 }
1791 /*
1792 * Since the runqueue lock will be released by the next
1793 * task (which is an invalid locking op but in the case
1794 * of the scheduler it's an obvious special-case), so we
1795 * do an early lockdep release here:
1796 */
1797#ifndef __ARCH_WANT_UNLOCKED_CTXSW
1791 spin_release(&rq->lock.dep_map, 1, _THIS_IP_); 1798 spin_release(&rq->lock.dep_map, 1, _THIS_IP_);
1799#endif
1792 1800
1793 /* Here we just switch the register state and the stack. */ 1801 /* Here we just switch the register state and the stack. */
1794 switch_to(prev, next, prev); 1802 switch_to(prev, next, prev);