1 /* SPDX-License-Identifier: GPL-2.0 */
2 #ifndef _LINUX_BH_H
3 #define _LINUX_BH_H
4 
5 #include <linux/instruction_pointer.h>
6 #include <linux/preempt.h>
7 
8 #if defined(CONFIG_PREEMPT_RT) || defined(CONFIG_TRACE_IRQFLAGS)
9 extern void __local_bh_disable_ip(unsigned long ip, unsigned int cnt);
10 #else
__local_bh_disable_ip(unsigned long ip,unsigned int cnt)11 static __always_inline void __local_bh_disable_ip(unsigned long ip, unsigned int cnt)
12 {
13 	preempt_count_add(cnt);
14 	barrier();
15 }
16 #endif
17 
local_bh_disable(void)18 static inline void local_bh_disable(void)
19 {
20 	__local_bh_disable_ip(_THIS_IP_, SOFTIRQ_DISABLE_OFFSET);
21 }
22 
23 extern void _local_bh_enable(void);
24 extern void __local_bh_enable_ip(unsigned long ip, unsigned int cnt);
25 
local_bh_enable_ip(unsigned long ip)26 static inline void local_bh_enable_ip(unsigned long ip)
27 {
28 	__local_bh_enable_ip(ip, SOFTIRQ_DISABLE_OFFSET);
29 }
30 
local_bh_enable(void)31 static inline void local_bh_enable(void)
32 {
33 	__local_bh_enable_ip(_THIS_IP_, SOFTIRQ_DISABLE_OFFSET);
34 }
35 
36 #ifdef CONFIG_PREEMPT_RT
37 extern bool local_bh_blocked(void);
38 #else
local_bh_blocked(void)39 static inline bool local_bh_blocked(void) { return false; }
40 #endif
41 
42 #endif /* _LINUX_BH_H */
43