diff options
author | Michal Simek <monstr@monstr.eu> | 2009-12-10 06:07:02 -0500 |
---|---|---|
committer | Michal Simek <monstr@monstr.eu> | 2009-12-14 02:40:09 -0500 |
commit | bf2d809668907c69b554459764b36584e4d57e4a (patch) | |
tree | 8f3e16925a34645ffd14e6d171937b37a06fba41 /arch/microblaze/Kconfig | |
parent | 519e9f417388ba055b7604db5f4f492f7c84f427 (diff) |
microblaze: Lockdep support
Microblaze needs to do lock_init very soon because MMU init calls lock functions.
Here is the explanation from Peter Zijlstra why we have to enable
__ARCH_WANTS_INTERRUPTS_ON_CTSW.
"So we schedule while holding rq->lock (for obvious reasons), but since
lockdep tracks held locks per tasks, we need to transfer the held state
from the prev to the next task. We do this by explicity calling
spin_release(&rq->lock) in context_switch() right before switch_to(),
and calling spin_acquire(&rq->lock) in
finish_task_switch()->finish_lock_switch().
Now, for some reason lockdep thinks that interrupts got enabled over the
context switch (git grep __ARCH_WANTS_INTERRUPTS_ON_CTSW arch/microblaze
doesn't seem to turn up anything).
Clearly trying to acquire the rq->lock with interrupts enabled is a bad
idea and lockdep warns you about this."
Signed-off-by: Michal Simek <monstr@monstr.eu>
Diffstat (limited to 'arch/microblaze/Kconfig')
-rw-r--r-- | arch/microblaze/Kconfig | 3 |
1 files changed, 3 insertions, 0 deletions
diff --git a/arch/microblaze/Kconfig b/arch/microblaze/Kconfig index 8e1c4f7d3e6e..5ba4dcd56cad 100644 --- a/arch/microblaze/Kconfig +++ b/arch/microblaze/Kconfig | |||
@@ -60,6 +60,9 @@ config GENERIC_CSUM | |||
60 | config STACKTRACE_SUPPORT | 60 | config STACKTRACE_SUPPORT |
61 | def_bool y | 61 | def_bool y |
62 | 62 | ||
63 | config LOCKDEP_SUPPORT | ||
64 | def_bool y | ||
65 | |||
63 | config PCI | 66 | config PCI |
64 | def_bool n | 67 | def_bool n |
65 | 68 | ||