diff options
Diffstat (limited to 'include/asm-i386')
-rw-r--r-- | include/asm-i386/irqflags.h | 56 | ||||
-rw-r--r-- | include/asm-i386/spinlock.h | 5 | ||||
-rw-r--r-- | include/asm-i386/system.h | 20 |
3 files changed, 62 insertions, 19 deletions
diff --git a/include/asm-i386/irqflags.h b/include/asm-i386/irqflags.h new file mode 100644 index 000000000000..ca777e894c92 --- /dev/null +++ b/include/asm-i386/irqflags.h | |||
@@ -0,0 +1,56 @@ | |||
1 | /* | ||
2 | * include/asm-i386/irqflags.h | ||
3 | * | ||
4 | * IRQ flags handling | ||
5 | * | ||
6 | * This file gets included from lowlevel asm headers too, to provide | ||
7 | * wrapped versions of the local_irq_*() APIs, based on the | ||
8 | * raw_local_irq_*() macros from the lowlevel headers. | ||
9 | */ | ||
10 | #ifndef _ASM_IRQFLAGS_H | ||
11 | #define _ASM_IRQFLAGS_H | ||
12 | |||
13 | #define raw_local_save_flags(x) do { typecheck(unsigned long,x); __asm__ __volatile__("pushfl ; popl %0":"=g" (x): /* no input */); } while (0) | ||
14 | #define raw_local_irq_restore(x) do { typecheck(unsigned long,x); __asm__ __volatile__("pushl %0 ; popfl": /* no output */ :"g" (x):"memory", "cc"); } while (0) | ||
15 | #define raw_local_irq_disable() __asm__ __volatile__("cli": : :"memory") | ||
16 | #define raw_local_irq_enable() __asm__ __volatile__("sti": : :"memory") | ||
17 | /* used in the idle loop; sti takes one instruction cycle to complete */ | ||
18 | #define raw_safe_halt() __asm__ __volatile__("sti; hlt": : :"memory") | ||
19 | /* used when interrupts are already enabled or to shutdown the processor */ | ||
20 | #define halt() __asm__ __volatile__("hlt": : :"memory") | ||
21 | |||
22 | #define raw_irqs_disabled_flags(flags) (!((flags) & (1<<9))) | ||
23 | |||
24 | /* For spinlocks etc */ | ||
25 | #define raw_local_irq_save(x) __asm__ __volatile__("pushfl ; popl %0 ; cli":"=g" (x): /* no input */ :"memory") | ||
26 | |||
27 | /* | ||
28 | * Do the CPU's IRQ-state tracing from assembly code. We call a | ||
29 | * C function, so save all the C-clobbered registers: | ||
30 | */ | ||
31 | #ifdef CONFIG_TRACE_IRQFLAGS | ||
32 | |||
33 | # define TRACE_IRQS_ON \ | ||
34 | pushl %eax; \ | ||
35 | pushl %ecx; \ | ||
36 | pushl %edx; \ | ||
37 | call trace_hardirqs_on; \ | ||
38 | popl %edx; \ | ||
39 | popl %ecx; \ | ||
40 | popl %eax; | ||
41 | |||
42 | # define TRACE_IRQS_OFF \ | ||
43 | pushl %eax; \ | ||
44 | pushl %ecx; \ | ||
45 | pushl %edx; \ | ||
46 | call trace_hardirqs_off; \ | ||
47 | popl %edx; \ | ||
48 | popl %ecx; \ | ||
49 | popl %eax; | ||
50 | |||
51 | #else | ||
52 | # define TRACE_IRQS_ON | ||
53 | # define TRACE_IRQS_OFF | ||
54 | #endif | ||
55 | |||
56 | #endif | ||
diff --git a/include/asm-i386/spinlock.h b/include/asm-i386/spinlock.h index 04ba30234c48..7e29b51bcaa0 100644 --- a/include/asm-i386/spinlock.h +++ b/include/asm-i386/spinlock.h | |||
@@ -31,6 +31,11 @@ | |||
31 | "jmp 1b\n" \ | 31 | "jmp 1b\n" \ |
32 | "3:\n\t" | 32 | "3:\n\t" |
33 | 33 | ||
34 | /* | ||
35 | * NOTE: there's an irqs-on section here, which normally would have to be | ||
36 | * irq-traced, but on CONFIG_TRACE_IRQFLAGS we never use | ||
37 | * __raw_spin_lock_string_flags(). | ||
38 | */ | ||
34 | #define __raw_spin_lock_string_flags \ | 39 | #define __raw_spin_lock_string_flags \ |
35 | "\n1:\t" \ | 40 | "\n1:\t" \ |
36 | "lock ; decb %0\n\t" \ | 41 | "lock ; decb %0\n\t" \ |
diff --git a/include/asm-i386/system.h b/include/asm-i386/system.h index cab0180567f9..db398d88b1d9 100644 --- a/include/asm-i386/system.h +++ b/include/asm-i386/system.h | |||
@@ -456,25 +456,7 @@ static inline unsigned long long __cmpxchg64(volatile void *ptr, unsigned long l | |||
456 | 456 | ||
457 | #define set_wmb(var, value) do { var = value; wmb(); } while (0) | 457 | #define set_wmb(var, value) do { var = value; wmb(); } while (0) |
458 | 458 | ||
459 | /* interrupt control.. */ | 459 | #include <linux/irqflags.h> |
460 | #define local_save_flags(x) do { typecheck(unsigned long,x); __asm__ __volatile__("pushfl ; popl %0":"=g" (x): /* no input */); } while (0) | ||
461 | #define local_irq_restore(x) do { typecheck(unsigned long,x); __asm__ __volatile__("pushl %0 ; popfl": /* no output */ :"g" (x):"memory", "cc"); } while (0) | ||
462 | #define local_irq_disable() __asm__ __volatile__("cli": : :"memory") | ||
463 | #define local_irq_enable() __asm__ __volatile__("sti": : :"memory") | ||
464 | /* used in the idle loop; sti takes one instruction cycle to complete */ | ||
465 | #define safe_halt() __asm__ __volatile__("sti; hlt": : :"memory") | ||
466 | /* used when interrupts are already enabled or to shutdown the processor */ | ||
467 | #define halt() __asm__ __volatile__("hlt": : :"memory") | ||
468 | |||
469 | #define irqs_disabled() \ | ||
470 | ({ \ | ||
471 | unsigned long flags; \ | ||
472 | local_save_flags(flags); \ | ||
473 | !(flags & (1<<9)); \ | ||
474 | }) | ||
475 | |||
476 | /* For spinlocks etc */ | ||
477 | #define local_irq_save(x) __asm__ __volatile__("pushfl ; popl %0 ; cli":"=g" (x): /* no input */ :"memory") | ||
478 | 460 | ||
479 | /* | 461 | /* |
480 | * disable hlt during certain critical i/o operations | 462 | * disable hlt during certain critical i/o operations |