]> git.karo-electronics.de Git - karo-tx-linux.git/commitdiff
sysrq,rcu: suppress RCU stall warnings while sysrq runs
authorRik van Riel <riel@redhat.com>
Sat, 17 May 2014 13:19:25 +0000 (23:19 +1000)
committerStephen Rothwell <sfr@canb.auug.org.au>
Tue, 20 May 2014 08:14:11 +0000 (18:14 +1000)
Some sysrq handlers can run for a long time, because they dump a lot of
data onto a serial console.  Having RCU stall warnings pop up in the
middle of them only makes the problem worse.

This patch temporarily disables RCU stall warnings while a sysrq request
is handled.

Signed-off-by: Rik van Riel <riel@redhat.com>
Suggested-by: Paul McKenney <paulmck@linux.vnet.ibm.com>
Signed-off-by: Paul E. McKenney <paulmck@linux.vnet.ibm.com>
Cc: Madper Xie <cxie@redhat.com>
Cc: Randy Dunlap <rdunlap@infradead.org>
Cc: Richard Weinberger <richard@nod.at>
Signed-off-by: Andrew Morton <akpm@linux-foundation.org>
drivers/tty/sysrq.c

index fc67a894a513f8cd580ab0ace21af184760c5fb5..38d5f9ae1cc1b42c86ce3d599bb0853746ee1218 100644 (file)
@@ -46,6 +46,7 @@
 #include <linux/jiffies.h>
 #include <linux/syscalls.h>
 #include <linux/of.h>
+#include <linux/rcupdate.h>
 
 #include <asm/ptrace.h>
 #include <asm/irq_regs.h>
@@ -511,6 +512,7 @@ void __handle_sysrq(int key, bool check_mask)
        int orig_log_level;
        int i;
 
+       rcu_sysrq_start();
        rcu_read_lock();
        /*
         * Raise the apparent loglevel to maximum so that the sysrq header
@@ -554,6 +556,7 @@ void __handle_sysrq(int key, bool check_mask)
                console_loglevel = orig_log_level;
        }
        rcu_read_unlock();
+       rcu_sysrq_end();
 }
 
 void handle_sysrq(int key)