diff options
-rw-r--r-- | kernel/lockdep.c | 13 |
1 files changed, 11 insertions, 2 deletions
diff --git a/kernel/lockdep.c b/kernel/lockdep.c index 156fce4960c3..734da579ad13 100644 --- a/kernel/lockdep.c +++ b/kernel/lockdep.c | |||
@@ -375,6 +375,11 @@ unsigned int max_recursion_depth; | |||
375 | * about it later on, in lockdep_info(). | 375 | * about it later on, in lockdep_info(). |
376 | */ | 376 | */ |
377 | static int lockdep_init_error; | 377 | static int lockdep_init_error; |
378 | static unsigned long lockdep_init_trace_data[20]; | ||
379 | static struct stack_trace lockdep_init_trace = { | ||
380 | .max_entries = ARRAY_SIZE(lockdep_init_trace_data), | ||
381 | .entries = lockdep_init_trace_data, | ||
382 | }; | ||
378 | 383 | ||
379 | /* | 384 | /* |
380 | * Various lockdep statistics: | 385 | * Various lockdep statistics: |
@@ -662,6 +667,7 @@ look_up_lock_class(struct lockdep_map *lock, unsigned int subclass) | |||
662 | if (unlikely(!lockdep_initialized)) { | 667 | if (unlikely(!lockdep_initialized)) { |
663 | lockdep_init(); | 668 | lockdep_init(); |
664 | lockdep_init_error = 1; | 669 | lockdep_init_error = 1; |
670 | save_stack_trace(&lockdep_init_trace); | ||
665 | } | 671 | } |
666 | #endif | 672 | #endif |
667 | 673 | ||
@@ -3040,8 +3046,11 @@ void __init lockdep_info(void) | |||
3040 | sizeof(struct held_lock) * MAX_LOCK_DEPTH); | 3046 | sizeof(struct held_lock) * MAX_LOCK_DEPTH); |
3041 | 3047 | ||
3042 | #ifdef CONFIG_DEBUG_LOCKDEP | 3048 | #ifdef CONFIG_DEBUG_LOCKDEP |
3043 | if (lockdep_init_error) | 3049 | if (lockdep_init_error) { |
3044 | printk("WARNING: lockdep init error! Arch code didnt call lockdep_init() early enough?\n"); | 3050 | printk("WARNING: lockdep init error! Arch code didn't call lockdep_init() early enough?\n"); |
3051 | printk("Call stack leading to lockdep invocation was:\n"); | ||
3052 | print_stack_trace(&lockdep_init_trace, 0); | ||
3053 | } | ||
3045 | #endif | 3054 | #endif |
3046 | } | 3055 | } |
3047 | 3056 | ||