mirror of
git://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git
synced 2025-08-05 16:54:27 +00:00

Currently a SIGTRAP can denote any one of below reasons. - Breakpoint hit - H/W debug register hit - Single step - Signal sent through kill() or rasie() Architectures like powerpc/parisc provides infrastructure to demultiplex SIGTRAP signal by passing down the information for receiving SIGTRAP through si_code of siginfot_t structure. Here is an attempt is generalise this infrastructure by extending it to x86 and x86_64 archs. Signed-off-by: Srinivasa DS <srinivasa@in.ibm.com> Cc: Roland McGrath <roland@redhat.com> Cc: akpm@linux-foundation.org Cc: paulus@samba.org Cc: linuxppc-dev@ozlabs.org Signed-off-by: Ingo Molnar <mingo@elte.hu>
80 lines
2.6 KiB
C
80 lines
2.6 KiB
C
#ifndef ASM_X86__TRAPS_H
|
|
#define ASM_X86__TRAPS_H
|
|
|
|
/* Common in X86_32 and X86_64 */
|
|
asmlinkage void divide_error(void);
|
|
asmlinkage void debug(void);
|
|
asmlinkage void nmi(void);
|
|
asmlinkage void int3(void);
|
|
asmlinkage void overflow(void);
|
|
asmlinkage void bounds(void);
|
|
asmlinkage void invalid_op(void);
|
|
asmlinkage void device_not_available(void);
|
|
asmlinkage void coprocessor_segment_overrun(void);
|
|
asmlinkage void invalid_TSS(void);
|
|
asmlinkage void segment_not_present(void);
|
|
asmlinkage void stack_segment(void);
|
|
asmlinkage void general_protection(void);
|
|
asmlinkage void page_fault(void);
|
|
asmlinkage void coprocessor_error(void);
|
|
asmlinkage void simd_coprocessor_error(void);
|
|
asmlinkage void alignment_check(void);
|
|
asmlinkage void spurious_interrupt_bug(void);
|
|
#ifdef CONFIG_X86_MCE
|
|
asmlinkage void machine_check(void);
|
|
#endif /* CONFIG_X86_MCE */
|
|
|
|
void do_divide_error(struct pt_regs *, long);
|
|
void do_overflow(struct pt_regs *, long);
|
|
void do_bounds(struct pt_regs *, long);
|
|
void do_coprocessor_segment_overrun(struct pt_regs *, long);
|
|
void do_invalid_TSS(struct pt_regs *, long);
|
|
void do_segment_not_present(struct pt_regs *, long);
|
|
void do_stack_segment(struct pt_regs *, long);
|
|
void do_alignment_check(struct pt_regs *, long);
|
|
void do_invalid_op(struct pt_regs *, long);
|
|
void do_general_protection(struct pt_regs *, long);
|
|
void do_nmi(struct pt_regs *, long);
|
|
|
|
static inline int get_si_code(unsigned long condition)
|
|
{
|
|
if (condition & DR_STEP)
|
|
return TRAP_TRACE;
|
|
else if (condition & (DR_TRAP0|DR_TRAP1|DR_TRAP2|DR_TRAP3))
|
|
return TRAP_HWBKPT;
|
|
else
|
|
return TRAP_BRKPT;
|
|
}
|
|
|
|
extern int panic_on_unrecovered_nmi;
|
|
extern int kstack_depth_to_print;
|
|
|
|
#ifdef CONFIG_X86_32
|
|
|
|
void do_iret_error(struct pt_regs *, long);
|
|
void do_int3(struct pt_regs *, long);
|
|
void do_debug(struct pt_regs *, long);
|
|
void math_error(void __user *);
|
|
void do_coprocessor_error(struct pt_regs *, long);
|
|
void do_simd_coprocessor_error(struct pt_regs *, long);
|
|
void do_spurious_interrupt_bug(struct pt_regs *, long);
|
|
unsigned long patch_espfix_desc(unsigned long, unsigned long);
|
|
asmlinkage void math_emulate(long);
|
|
|
|
void do_page_fault(struct pt_regs *regs, unsigned long error_code);
|
|
|
|
#else /* CONFIG_X86_32 */
|
|
|
|
asmlinkage void double_fault(void);
|
|
|
|
asmlinkage void do_int3(struct pt_regs *, long);
|
|
asmlinkage void do_stack_segment(struct pt_regs *, long);
|
|
asmlinkage void do_debug(struct pt_regs *, unsigned long);
|
|
asmlinkage void do_coprocessor_error(struct pt_regs *);
|
|
asmlinkage void do_simd_coprocessor_error(struct pt_regs *);
|
|
asmlinkage void do_spurious_interrupt_bug(struct pt_regs *);
|
|
|
|
asmlinkage void do_page_fault(struct pt_regs *regs, unsigned long error_code);
|
|
|
|
#endif /* CONFIG_X86_32 */
|
|
#endif /* ASM_X86__TRAPS_H */
|