Blame view

include/linux/irqflags.h 3.89 KB
de30a2b35   Ingo Molnar   [PATCH] lockdep: ...
1
2
3
4
5
6
7
8
9
10
11
12
  /*
   * include/linux/irqflags.h
   *
   * IRQ flags tracing: follow the state of the hardirq and softirq flags and
   * provide callbacks for transitions between ON and OFF states.
   *
   * This file gets included from lowlevel asm headers too, to provide
   * wrapped versions of the local_irq_*() APIs, based on the
   * raw_local_irq_*() macros from the lowlevel headers.
   */
  #ifndef _LINUX_TRACE_IRQFLAGS_H
  #define _LINUX_TRACE_IRQFLAGS_H
3f307891c   Steven Rostedt   locking: add type...
13
  #include <linux/typecheck.h>
de30a2b35   Ingo Molnar   [PATCH] lockdep: ...
14
  #ifdef CONFIG_TRACE_IRQFLAGS
de30a2b35   Ingo Molnar   [PATCH] lockdep: ...
15
16
    extern void trace_softirqs_on(unsigned long ip);
    extern void trace_softirqs_off(unsigned long ip);
81d68a96a   Steven Rostedt   ftrace: trace irq...
17
18
    extern void trace_hardirqs_on(void);
    extern void trace_hardirqs_off(void);
de30a2b35   Ingo Molnar   [PATCH] lockdep: ...
19
20
21
22
23
24
  # define trace_hardirq_context(p)	((p)->hardirq_context)
  # define trace_softirq_context(p)	((p)->softirq_context)
  # define trace_hardirqs_enabled(p)	((p)->hardirqs_enabled)
  # define trace_softirqs_enabled(p)	((p)->softirqs_enabled)
  # define trace_hardirq_enter()	do { current->hardirq_context++; } while (0)
  # define trace_hardirq_exit()	do { current->hardirq_context--; } while (0)
d820ac4c2   Ingo Molnar   locking: rename t...
25
26
  # define lockdep_softirq_enter()	do { current->softirq_context++; } while (0)
  # define lockdep_softirq_exit()	do { current->softirq_context--; } while (0)
de30a2b35   Ingo Molnar   [PATCH] lockdep: ...
27
28
29
30
31
32
33
34
35
36
37
38
  # define INIT_TRACE_IRQFLAGS	.softirqs_enabled = 1,
  #else
  # define trace_hardirqs_on()		do { } while (0)
  # define trace_hardirqs_off()		do { } while (0)
  # define trace_softirqs_on(ip)		do { } while (0)
  # define trace_softirqs_off(ip)		do { } while (0)
  # define trace_hardirq_context(p)	0
  # define trace_softirq_context(p)	0
  # define trace_hardirqs_enabled(p)	0
  # define trace_softirqs_enabled(p)	0
  # define trace_hardirq_enter()		do { } while (0)
  # define trace_hardirq_exit()		do { } while (0)
d820ac4c2   Ingo Molnar   locking: rename t...
39
40
  # define lockdep_softirq_enter()	do { } while (0)
  # define lockdep_softirq_exit()		do { } while (0)
de30a2b35   Ingo Molnar   [PATCH] lockdep: ...
41
42
  # define INIT_TRACE_IRQFLAGS
  #endif
6cd8a4bb2   Steven Rostedt   ftrace: trace pre...
43
44
  #if defined(CONFIG_IRQSOFF_TRACER) || \
  	defined(CONFIG_PREEMPT_TRACER)
81d68a96a   Steven Rostedt   ftrace: trace irq...
45
46
47
48
49
50
   extern void stop_critical_timings(void);
   extern void start_critical_timings(void);
  #else
  # define stop_critical_timings() do { } while (0)
  # define start_critical_timings() do { } while (0)
  #endif
de30a2b35   Ingo Molnar   [PATCH] lockdep: ...
51
52
53
54
55
56
57
58
  #ifdef CONFIG_TRACE_IRQFLAGS_SUPPORT
  
  #include <asm/irqflags.h>
  
  #define local_irq_enable() \
  	do { trace_hardirqs_on(); raw_local_irq_enable(); } while (0)
  #define local_irq_disable() \
  	do { raw_local_irq_disable(); trace_hardirqs_off(); } while (0)
3f307891c   Steven Rostedt   locking: add type...
59
60
61
62
63
64
  #define local_irq_save(flags)				\
  	do {						\
  		typecheck(unsigned long, flags);	\
  		raw_local_irq_save(flags);		\
  		trace_hardirqs_off();			\
  	} while (0)
de30a2b35   Ingo Molnar   [PATCH] lockdep: ...
65

3f307891c   Steven Rostedt   locking: add type...
66
67
68
69
70
71
72
73
74
75
76
  
  #define local_irq_restore(flags)			\
  	do {						\
  		typecheck(unsigned long, flags);	\
  		if (raw_irqs_disabled_flags(flags)) {	\
  			raw_local_irq_restore(flags);	\
  			trace_hardirqs_off();		\
  		} else {				\
  			trace_hardirqs_on();		\
  			raw_local_irq_restore(flags);	\
  		}					\
de30a2b35   Ingo Molnar   [PATCH] lockdep: ...
77
78
79
80
81
82
83
84
  	} while (0)
  #else /* !CONFIG_TRACE_IRQFLAGS_SUPPORT */
  /*
   * The local_irq_*() APIs are equal to the raw_local_irq*()
   * if !TRACE_IRQFLAGS.
   */
  # define raw_local_irq_disable()	local_irq_disable()
  # define raw_local_irq_enable()		local_irq_enable()
3f307891c   Steven Rostedt   locking: add type...
85
86
87
88
89
90
91
92
93
94
  # define raw_local_irq_save(flags)			\
  	do {						\
  		typecheck(unsigned long, flags);	\
  		local_irq_save(flags);			\
  	} while (0)
  # define raw_local_irq_restore(flags)			\
  	do {						\
  		typecheck(unsigned long, flags);	\
  		local_irq_restore(flags);		\
  	} while (0)
de30a2b35   Ingo Molnar   [PATCH] lockdep: ...
95
96
97
98
99
100
101
102
  #endif /* CONFIG_TRACE_IRQFLAGS_SUPPORT */
  
  #ifdef CONFIG_TRACE_IRQFLAGS_SUPPORT
  #define safe_halt()						\
  	do {							\
  		trace_hardirqs_on();				\
  		raw_safe_halt();				\
  	} while (0)
3f307891c   Steven Rostedt   locking: add type...
103
104
105
106
107
  #define local_save_flags(flags)				\
  	do {						\
  		typecheck(unsigned long, flags);	\
  		raw_local_save_flags(flags);		\
  	} while (0)
de30a2b35   Ingo Molnar   [PATCH] lockdep: ...
108
109
110
  
  #define irqs_disabled()						\
  ({								\
a7d5ac87b   Harvey Harrison   x86: pageattr.c f...
111
  	unsigned long _flags;					\
de30a2b35   Ingo Molnar   [PATCH] lockdep: ...
112
  								\
a7d5ac87b   Harvey Harrison   x86: pageattr.c f...
113
114
  	raw_local_save_flags(_flags);				\
  	raw_irqs_disabled_flags(_flags);			\
de30a2b35   Ingo Molnar   [PATCH] lockdep: ...
115
  })
3f307891c   Steven Rostedt   locking: add type...
116
117
118
119
120
  #define irqs_disabled_flags(flags)		\
  ({						\
  	typecheck(unsigned long, flags);	\
  	raw_irqs_disabled_flags(flags);		\
  })
40b1f4e51   Michael Neuling   irq: trivial: Fix...
121
  #endif /* CONFIG_TRACE_IRQFLAGS_SUPPORT */
de30a2b35   Ingo Molnar   [PATCH] lockdep: ...
122
123
  
  #endif