mirror of
				https://github.com/torvalds/linux.git
				synced 2025-11-04 02:30:34 +02:00 
			
		
		
		
	sysrq: Fix warning in sysrq generated crash.
Commit984d74a720("sysrq: rcu-ify __handle_sysrq") replaced spin_lock_irqsave() calls with rcu_read_lock() calls in sysrq. Since rcu_read_lock() does not disable preemption, faulthandler_disabled() in __do_page_fault() in x86/fault.c returns false. When the code later calls might_sleep() in the pagefault handler, we get the following warning: BUG: sleeping function called from invalid context at ../arch/x86/mm/fault.c:1187 in_atomic(): 0, irqs_disabled(): 0, pid: 4706, name: bash Preemption disabled at:[<ffffffff81484339>] printk+0x48/0x4a To fix this, we release the RCU read lock before we crash. Tested this patch on linux 3.18 by booting off one of our boards. Fixes:984d74a720("sysrq: rcu-ify __handle_sysrq") Signed-off-by: Ani Sinha <ani@arista.com> Reviewed-by: Rik van Riel <riel@redhat.com> Signed-off-by: Paul E. McKenney <paulmck@linux.vnet.ibm.com>
This commit is contained in:
		
							parent
							
								
									648c630c64
								
							
						
					
					
						commit
						984cf355ae
					
				
					 1 changed files with 6 additions and 0 deletions
				
			
		| 
						 | 
				
			
			@ -133,6 +133,12 @@ static void sysrq_handle_crash(int key)
 | 
			
		|||
{
 | 
			
		||||
	char *killer = NULL;
 | 
			
		||||
 | 
			
		||||
	/* we need to release the RCU read lock here,
 | 
			
		||||
	 * otherwise we get an annoying
 | 
			
		||||
	 * 'BUG: sleeping function called from invalid context'
 | 
			
		||||
	 * complaint from the kernel before the panic.
 | 
			
		||||
	 */
 | 
			
		||||
	rcu_read_unlock();
 | 
			
		||||
	panic_on_oops = 1;	/* force panic */
 | 
			
		||||
	wmb();
 | 
			
		||||
	*killer = 1;
 | 
			
		||||
| 
						 | 
				
			
			
 | 
			
		|||
		Loading…
	
		Reference in a new issue