]> 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>
Thu, 22 May 2014 00:54:34 +0000 (10:54 +1000)
committerStephen Rothwell <sfr@canb.auug.org.au>
Wed, 4 Jun 2014 07:51:11 +0000 (17:51 +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 7430e87d73525ef7ff7be16ad3bb27166720a494..454b65898e2c6eaa9434b1df84a0958926a0e06d 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)