diff options
| -rw-r--r-- | arch/x86/kernel/traps_32.c | 21 | ||||
| -rw-r--r-- | arch/x86/kernel/traps_64.c | 22 | ||||
| -rw-r--r-- | include/asm-x86/traps.h | 66 |
3 files changed, 68 insertions, 41 deletions
diff --git a/arch/x86/kernel/traps_32.c b/arch/x86/kernel/traps_32.c index c971dce3847b..03df8e45e5a1 100644 --- a/arch/x86/kernel/traps_32.c +++ b/arch/x86/kernel/traps_32.c | |||
| @@ -58,6 +58,7 @@ | |||
| 58 | #include <asm/nmi.h> | 58 | #include <asm/nmi.h> |
| 59 | #include <asm/smp.h> | 59 | #include <asm/smp.h> |
| 60 | #include <asm/io.h> | 60 | #include <asm/io.h> |
| 61 | #include <asm/traps.h> | ||
| 61 | 62 | ||
| 62 | #include "mach_traps.h" | 63 | #include "mach_traps.h" |
| 63 | 64 | ||
| @@ -77,26 +78,6 @@ char ignore_fpu_irq; | |||
| 77 | gate_desc idt_table[256] | 78 | gate_desc idt_table[256] |
| 78 | __attribute__((__section__(".data.idt"))) = { { { { 0, 0 } } }, }; | 79 | __attribute__((__section__(".data.idt"))) = { { { { 0, 0 } } }, }; |
| 79 | 80 | ||
| 80 | asmlinkage void divide_error(void); | ||
| 81 | asmlinkage void debug(void); | ||
| 82 | asmlinkage void nmi(void); | ||
| 83 | asmlinkage void int3(void); | ||
| 84 | asmlinkage void overflow(void); | ||
| 85 | asmlinkage void bounds(void); | ||
| 86 | asmlinkage void invalid_op(void); | ||
| 87 | asmlinkage void device_not_available(void); | ||
| 88 | asmlinkage void coprocessor_segment_overrun(void); | ||
| 89 | asmlinkage void invalid_TSS(void); | ||
| 90 | asmlinkage void segment_not_present(void); | ||
| 91 | asmlinkage void stack_segment(void); | ||
| 92 | asmlinkage void general_protection(void); | ||
| 93 | asmlinkage void page_fault(void); | ||
| 94 | asmlinkage void coprocessor_error(void); | ||
| 95 | asmlinkage void simd_coprocessor_error(void); | ||
| 96 | asmlinkage void alignment_check(void); | ||
| 97 | asmlinkage void spurious_interrupt_bug(void); | ||
| 98 | asmlinkage void machine_check(void); | ||
| 99 | |||
| 100 | int panic_on_unrecovered_nmi; | 81 | int panic_on_unrecovered_nmi; |
| 101 | int kstack_depth_to_print = 24; | 82 | int kstack_depth_to_print = 24; |
| 102 | static unsigned int code_bytes = 64; | 83 | static unsigned int code_bytes = 64; |
diff --git a/arch/x86/kernel/traps_64.c b/arch/x86/kernel/traps_64.c index c664e6962009..3f18d73f420c 100644 --- a/arch/x86/kernel/traps_64.c +++ b/arch/x86/kernel/traps_64.c | |||
| @@ -51,30 +51,10 @@ | |||
| 51 | #include <asm/pgalloc.h> | 51 | #include <asm/pgalloc.h> |
| 52 | #include <asm/proto.h> | 52 | #include <asm/proto.h> |
| 53 | #include <asm/pda.h> | 53 | #include <asm/pda.h> |
| 54 | #include <asm/traps.h> | ||
| 54 | 55 | ||
| 55 | #include <mach_traps.h> | 56 | #include <mach_traps.h> |
| 56 | 57 | ||
| 57 | asmlinkage void divide_error(void); | ||
| 58 | asmlinkage void debug(void); | ||
| 59 | asmlinkage void nmi(void); | ||
| 60 | asmlinkage void int3(void); | ||
| 61 | asmlinkage void overflow(void); | ||
| 62 | asmlinkage void bounds(void); | ||
| 63 | asmlinkage void invalid_op(void); | ||
| 64 | asmlinkage void device_not_available(void); | ||
| 65 | asmlinkage void double_fault(void); | ||
| 66 | asmlinkage void coprocessor_segment_overrun(void); | ||
| 67 | asmlinkage void invalid_TSS(void); | ||
| 68 | asmlinkage void segment_not_present(void); | ||
| 69 | asmlinkage void stack_segment(void); | ||
| 70 | asmlinkage void general_protection(void); | ||
| 71 | asmlinkage void page_fault(void); | ||
| 72 | asmlinkage void coprocessor_error(void); | ||
| 73 | asmlinkage void simd_coprocessor_error(void); | ||
| 74 | asmlinkage void alignment_check(void); | ||
| 75 | asmlinkage void spurious_interrupt_bug(void); | ||
| 76 | asmlinkage void machine_check(void); | ||
| 77 | |||
| 78 | int panic_on_unrecovered_nmi; | 58 | int panic_on_unrecovered_nmi; |
| 79 | int kstack_depth_to_print = 12; | 59 | int kstack_depth_to_print = 12; |
| 80 | static unsigned int code_bytes = 64; | 60 | static unsigned int code_bytes = 64; |
diff --git a/include/asm-x86/traps.h b/include/asm-x86/traps.h new file mode 100644 index 000000000000..a4b65a71bd66 --- /dev/null +++ b/include/asm-x86/traps.h | |||
| @@ -0,0 +1,66 @@ | |||
| 1 | #ifndef _ASM_X86_TRAPS_H | ||
| 2 | #define _ASM_X86_TRAPS_H | ||
| 3 | |||
| 4 | /* Common in X86_32 and X86_64 */ | ||
| 5 | asmlinkage void divide_error(void); | ||
| 6 | asmlinkage void debug(void); | ||
| 7 | asmlinkage void nmi(void); | ||
| 8 | asmlinkage void int3(void); | ||
| 9 | asmlinkage void overflow(void); | ||
| 10 | asmlinkage void bounds(void); | ||
| 11 | asmlinkage void invalid_op(void); | ||
| 12 | asmlinkage void device_not_available(void); | ||
| 13 | asmlinkage void coprocessor_segment_overrun(void); | ||
| 14 | asmlinkage void invalid_TSS(void); | ||
| 15 | asmlinkage void segment_not_present(void); | ||
| 16 | asmlinkage void stack_segment(void); | ||
| 17 | asmlinkage void general_protection(void); | ||
| 18 | asmlinkage void page_fault(void); | ||
| 19 | asmlinkage void coprocessor_error(void); | ||
| 20 | asmlinkage void simd_coprocessor_error(void); | ||
| 21 | asmlinkage void alignment_check(void); | ||
| 22 | asmlinkage void spurious_interrupt_bug(void); | ||
| 23 | #ifdef CONFIG_X86_MCE | ||
| 24 | asmlinkage void machine_check(void); | ||
| 25 | #endif /* CONFIG_X86_MCE */ | ||
| 26 | |||
| 27 | void do_divide_error(struct pt_regs *, long); | ||
| 28 | void do_overflow(struct pt_regs *, long); | ||
| 29 | void do_bounds(struct pt_regs *, long); | ||
| 30 | void do_coprocessor_segment_overrun(struct pt_regs *, long); | ||
| 31 | void do_invalid_TSS(struct pt_regs *, long); | ||
| 32 | void do_segment_not_present(struct pt_regs *, long); | ||
| 33 | void do_stack_segment(struct pt_regs *, long); | ||
| 34 | void do_alignment_check(struct pt_regs *, long); | ||
| 35 | void do_invalid_op(struct pt_regs *, long); | ||
| 36 | void do_general_protection(struct pt_regs *, long); | ||
| 37 | void do_nmi(struct pt_regs *, long); | ||
| 38 | |||
| 39 | extern int panic_on_unrecovered_nmi; | ||
| 40 | extern int kstack_depth_to_print; | ||
| 41 | |||
| 42 | #ifdef CONFIG_X86_32 | ||
| 43 | |||
| 44 | void do_iret_error(struct pt_regs *, long); | ||
| 45 | void do_int3(struct pt_regs *, long); | ||
| 46 | void do_debug(struct pt_regs *, long); | ||
| 47 | void math_error(void __user *); | ||
| 48 | void do_coprocessor_error(struct pt_regs *, long); | ||
| 49 | void do_simd_coprocessor_error(struct pt_regs *, long); | ||
| 50 | void do_spurious_interrupt_bug(struct pt_regs *, long); | ||
| 51 | unsigned long patch_espfix_desc(unsigned long, unsigned long); | ||
| 52 | asmlinkage void math_emulate(long); | ||
| 53 | |||
| 54 | #else /* CONFIG_X86_32 */ | ||
| 55 | |||
| 56 | asmlinkage void double_fault(void); | ||
| 57 | |||
| 58 | asmlinkage void do_int3(struct pt_regs *, long); | ||
| 59 | asmlinkage void do_stack_segment(struct pt_regs *, long); | ||
| 60 | asmlinkage void do_debug(struct pt_regs *, unsigned long); | ||
| 61 | asmlinkage void do_coprocessor_error(struct pt_regs *); | ||
| 62 | asmlinkage void do_simd_coprocessor_error(struct pt_regs *); | ||
| 63 | asmlinkage void do_spurious_interrupt_bug(struct pt_regs *); | ||
| 64 | |||
| 65 | #endif /* CONFIG_X86_32 */ | ||
| 66 | #endif /* _ASM_X86_TRAPS_H */ | ||
