diff options
author | Arnd Bergmann <arnd@arndb.de> | 2009-05-13 18:56:33 -0400 |
---|---|---|
committer | Arnd Bergmann <arnd@klappe2.(none)> | 2009-06-11 15:02:37 -0400 |
commit | aafe4dbed0bf6cbdb2e9f03e1d42f8a540d8541d (patch) | |
tree | 5cc3e500ebb234ad82928de0ed680373c616dc44 /include/asm-generic/irqflags.h | |
parent | 9858c60cc2d33b18367b2bc6947e3ea23db26ccb (diff) |
asm-generic: add generic versions of common headers
These are all kernel internal interfaces that get copied
around a lot. In most cases, architectures can provide
their own optimized versions, but these generic versions
can work as well.
I have tried to use the most common contents of each
header to allow existing architectures to migrate easily.
Thanks to Remis for suggesting a number of cleanups.
Signed-off-by: Remis Lima Baima <remis.developer@googlemail.com>
Signed-off-by: Arnd Bergmann <arnd@arndb.de>
Diffstat (limited to 'include/asm-generic/irqflags.h')
-rw-r--r-- | include/asm-generic/irqflags.h | 72 |
1 files changed, 72 insertions, 0 deletions
diff --git a/include/asm-generic/irqflags.h b/include/asm-generic/irqflags.h new file mode 100644 index 000000000000..9aebf618275a --- /dev/null +++ b/include/asm-generic/irqflags.h | |||
@@ -0,0 +1,72 @@ | |||
1 | #ifndef __ASM_GENERIC_IRQFLAGS_H | ||
2 | #define __ASM_GENERIC_IRQFLAGS_H | ||
3 | |||
4 | /* | ||
5 | * All architectures should implement at least the first two functions, | ||
6 | * usually inline assembly will be the best way. | ||
7 | */ | ||
8 | #ifndef RAW_IRQ_DISABLED | ||
9 | #define RAW_IRQ_DISABLED 0 | ||
10 | #define RAW_IRQ_ENABLED 1 | ||
11 | #endif | ||
12 | |||
13 | /* read interrupt enabled status */ | ||
14 | #ifndef __raw_local_save_flags | ||
15 | unsigned long __raw_local_save_flags(void); | ||
16 | #endif | ||
17 | |||
18 | /* set interrupt enabled status */ | ||
19 | #ifndef raw_local_irq_restore | ||
20 | void raw_local_irq_restore(unsigned long flags); | ||
21 | #endif | ||
22 | |||
23 | /* get status and disable interrupts */ | ||
24 | #ifndef __raw_local_irq_save | ||
25 | static inline unsigned long __raw_local_irq_save(void) | ||
26 | { | ||
27 | unsigned long flags; | ||
28 | flags = __raw_local_save_flags(); | ||
29 | raw_local_irq_restore(RAW_IRQ_DISABLED); | ||
30 | return flags; | ||
31 | } | ||
32 | #endif | ||
33 | |||
34 | /* test flags */ | ||
35 | #ifndef raw_irqs_disabled_flags | ||
36 | static inline int raw_irqs_disabled_flags(unsigned long flags) | ||
37 | { | ||
38 | return flags == RAW_IRQ_DISABLED; | ||
39 | } | ||
40 | #endif | ||
41 | |||
42 | /* unconditionally enable interrupts */ | ||
43 | #ifndef raw_local_irq_enable | ||
44 | static inline void raw_local_irq_enable(void) | ||
45 | { | ||
46 | raw_local_irq_restore(RAW_IRQ_ENABLED); | ||
47 | } | ||
48 | #endif | ||
49 | |||
50 | /* unconditionally disable interrupts */ | ||
51 | #ifndef raw_local_irq_disable | ||
52 | static inline void raw_local_irq_disable(void) | ||
53 | { | ||
54 | raw_local_irq_restore(RAW_IRQ_DISABLED); | ||
55 | } | ||
56 | #endif | ||
57 | |||
58 | /* test hardware interrupt enable bit */ | ||
59 | #ifndef raw_irqs_disabled | ||
60 | static inline int raw_irqs_disabled(void) | ||
61 | { | ||
62 | return raw_irqs_disabled_flags(__raw_local_save_flags()); | ||
63 | } | ||
64 | #endif | ||
65 | |||
66 | #define raw_local_save_flags(flags) \ | ||
67 | do { (flags) = __raw_local_save_flags(); } while (0) | ||
68 | |||
69 | #define raw_local_irq_save(flags) \ | ||
70 | do { (flags) = __raw_local_irq_save(); } while (0) | ||
71 | |||
72 | #endif /* __ASM_GENERIC_IRQFLAGS_H */ | ||