mirror of
				https://git.kernel.org/pub/scm/linux/kernel/git/chenhuacai/linux-loongson
				synced 2025-10-25 13:41:08 +00:00 
			
		
		
		
	 47cab6a722
			
		
	
	
		47cab6a722
		
	
	
	
	
		
			
			As Andrew noted, my previous patch ("debug lockups: Improve lockup
detection") broke/removed SysRq-L support from architecture that do
not provide a __trigger_all_cpu_backtrace implementation.
Restore a fallback path and clean up the SysRq-L machinery a bit:
 - Rename the arch method to arch_trigger_all_cpu_backtrace()
 - Simplify the define
 - Document the method a bit - in the hope of more architectures
   adding support for it.
[ The patch touches Sparc code for the rename. ]
Cc: Paul E. McKenney <paulmck@linux.vnet.ibm.com>
Cc: Peter Zijlstra <a.p.zijlstra@chello.nl>
Cc: Andrew Morton <akpm@linux-foundation.org>
Cc: Linus Torvalds <torvalds@linux-foundation.org>
Cc: "David S. Miller" <davem@davemloft.net>
LKML-Reference: <20090802140809.7ec4bb6b.akpm@linux-foundation.org>
Signed-off-by: Ingo Molnar <mingo@elte.hu>
		
	
			
		
			
				
	
	
		
			51 lines
		
	
	
		
			1.1 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			51 lines
		
	
	
		
			1.1 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
| /*
 | |
|  *  linux/include/linux/nmi.h
 | |
|  */
 | |
| #ifndef LINUX_NMI_H
 | |
| #define LINUX_NMI_H
 | |
| 
 | |
| #include <linux/sched.h>
 | |
| #include <asm/irq.h>
 | |
| 
 | |
| /**
 | |
|  * touch_nmi_watchdog - restart NMI watchdog timeout.
 | |
|  * 
 | |
|  * If the architecture supports the NMI watchdog, touch_nmi_watchdog()
 | |
|  * may be used to reset the timeout - for code which intentionally
 | |
|  * disables interrupts for a long time. This call is stateless.
 | |
|  */
 | |
| #ifdef ARCH_HAS_NMI_WATCHDOG
 | |
| #include <asm/nmi.h>
 | |
| extern void touch_nmi_watchdog(void);
 | |
| extern void acpi_nmi_disable(void);
 | |
| extern void acpi_nmi_enable(void);
 | |
| #else
 | |
| static inline void touch_nmi_watchdog(void)
 | |
| {
 | |
| 	touch_softlockup_watchdog();
 | |
| }
 | |
| static inline void acpi_nmi_disable(void) { }
 | |
| static inline void acpi_nmi_enable(void) { }
 | |
| #endif
 | |
| 
 | |
| /*
 | |
|  * Create trigger_all_cpu_backtrace() out of the arch-provided
 | |
|  * base function. Return whether such support was available,
 | |
|  * to allow calling code to fall back to some other mechanism:
 | |
|  */
 | |
| #ifdef arch_trigger_all_cpu_backtrace
 | |
| static inline bool trigger_all_cpu_backtrace(void)
 | |
| {
 | |
| 	arch_trigger_all_cpu_backtrace();
 | |
| 
 | |
| 	return true;
 | |
| }
 | |
| #else
 | |
| static inline bool trigger_all_cpu_backtrace(void)
 | |
| {
 | |
| 	return false;
 | |
| }
 | |
| #endif
 | |
| 
 | |
| #endif
 |