forked from mirrors/linux
		
	 5b404fdaba
			
		
	
	
		5b404fdaba
		
	
	
	
	
		
			
			It is sometimes helpful to have a way for the subsystem causing the stall to dump its state when an RCU CPU stall occurs. This commit therefore bases rcu_stall_chain_notifier_register() and rcu_stall_chain_notifier_unregister() on atomic notifiers in order to provide this functionality. Signed-off-by: Paul E. McKenney <paulmck@kernel.org> Cc: Steven Rostedt <rostedt@goodmis.org> Signed-off-by: Frederic Weisbecker <frederic@kernel.org>
		
			
				
	
	
		
			32 lines
		
	
	
	
		
			969 B
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			32 lines
		
	
	
	
		
			969 B
		
	
	
	
		
			C
		
	
	
	
	
	
| /* SPDX-License-Identifier: GPL-2.0+ */
 | |
| /*
 | |
|  * Read-Copy Update notifiers, initially RCU CPU stall notifier.
 | |
|  * Separate from rcupdate.h to avoid #include loops.
 | |
|  *
 | |
|  * Copyright (C) 2023 Paul E. McKenney.
 | |
|  */
 | |
| 
 | |
| #ifndef __LINUX_RCU_NOTIFIER_H
 | |
| #define __LINUX_RCU_NOTIFIER_H
 | |
| 
 | |
| // Actions for RCU CPU stall notifier calls.
 | |
| #define RCU_STALL_NOTIFY_NORM	1
 | |
| #define RCU_STALL_NOTIFY_EXP	2
 | |
| 
 | |
| #ifdef CONFIG_RCU_STALL_COMMON
 | |
| 
 | |
| #include <linux/notifier.h>
 | |
| #include <linux/types.h>
 | |
| 
 | |
| int rcu_stall_chain_notifier_register(struct notifier_block *n);
 | |
| int rcu_stall_chain_notifier_unregister(struct notifier_block *n);
 | |
| 
 | |
| #else // #ifdef CONFIG_RCU_STALL_COMMON
 | |
| 
 | |
| // No RCU CPU stall warnings in Tiny RCU.
 | |
| static inline int rcu_stall_chain_notifier_register(struct notifier_block *n) { return -EEXIST; }
 | |
| static inline int rcu_stall_chain_notifier_unregister(struct notifier_block *n) { return -ENOENT; }
 | |
| 
 | |
| #endif // #else // #ifdef CONFIG_RCU_STALL_COMMON
 | |
| 
 | |
| #endif /* __LINUX_RCU_NOTIFIER_H */
 |