From e075f3b1467b33df2a925bc562dd022f766c03a9 Mon Sep 17 00:00:00 2001 From: Dave Airlie Date: Fri, 8 Feb 2013 12:07:01 +1000 Subject: [PATCH] --- yaml --- r: 358090 b: refs/heads/master c: 5845b81bdad374f98f809a658ec747d92c9595c4 h: refs/heads/master v: v3 --- [refs] | 2 +- trunk/kernel/printk.c | 9 +++++++++ 2 files changed, 10 insertions(+), 1 deletion(-) diff --git a/[refs] b/[refs] index 0eaafa3a4b61..d10278dea566 100644 --- a/[refs] +++ b/[refs] @@ -1,2 +1,2 @@ --- -refs/heads/master: 054430e773c9a1e26f38e30156eff02dedfffc17 +refs/heads/master: 5845b81bdad374f98f809a658ec747d92c9595c4 diff --git a/trunk/kernel/printk.c b/trunk/kernel/printk.c index 267ce780abe8..357f714ddd49 100644 --- a/trunk/kernel/printk.c +++ b/trunk/kernel/printk.c @@ -87,6 +87,12 @@ static DEFINE_SEMAPHORE(console_sem); struct console *console_drivers; EXPORT_SYMBOL_GPL(console_drivers); +#ifdef CONFIG_LOCKDEP +static struct lockdep_map console_lock_dep_map = { + .name = "console_lock" +}; +#endif + /* * This is used for debugging the mess that is the VT code by * keeping track if we have the console semaphore held. It's @@ -1918,6 +1924,7 @@ void console_lock(void) return; console_locked = 1; console_may_schedule = 1; + mutex_acquire(&console_lock_dep_map, 0, 0, _RET_IP_); } EXPORT_SYMBOL(console_lock); @@ -1939,6 +1946,7 @@ int console_trylock(void) } console_locked = 1; console_may_schedule = 0; + mutex_acquire(&console_lock_dep_map, 0, 1, _RET_IP_); return 1; } EXPORT_SYMBOL(console_trylock); @@ -2099,6 +2107,7 @@ void console_unlock(void) local_irq_restore(flags); } console_locked = 0; + mutex_release(&console_lock_dep_map, 1, _RET_IP_); /* Release the exclusive_console once it is used */ if (unlikely(exclusive_console))