1 | /* SPDX-License-Identifier: GPL-2.0 */ |
2 | #ifndef _ASM_X86_TRAPNR_H |
3 | #define _ASM_X86_TRAPNR_H |
4 | |
5 | /* |
6 | * Event type codes used by FRED, Intel VT-x and AMD SVM |
7 | */ |
8 | #define EVENT_TYPE_EXTINT 0 // External interrupt |
9 | #define EVENT_TYPE_RESERVED 1 |
10 | #define EVENT_TYPE_NMI 2 // NMI |
11 | #define EVENT_TYPE_HWEXC 3 // Hardware originated traps, exceptions |
12 | #define EVENT_TYPE_SWINT 4 // INT n |
13 | #define EVENT_TYPE_PRIV_SWEXC 5 // INT1 |
14 | #define EVENT_TYPE_SWEXC 6 // INTO, INT3 |
15 | #define EVENT_TYPE_OTHER 7 // FRED SYSCALL/SYSENTER, VT-x MTF |
16 | |
17 | /* Interrupts/Exceptions */ |
18 | |
19 | #define X86_TRAP_DE 0 /* Divide-by-zero */ |
20 | #define X86_TRAP_DB 1 /* Debug */ |
21 | #define X86_TRAP_NMI 2 /* Non-maskable Interrupt */ |
22 | #define X86_TRAP_BP 3 /* Breakpoint */ |
23 | #define X86_TRAP_OF 4 /* Overflow */ |
24 | #define X86_TRAP_BR 5 /* Bound Range Exceeded */ |
25 | #define X86_TRAP_UD 6 /* Invalid Opcode */ |
26 | #define X86_TRAP_NM 7 /* Device Not Available */ |
27 | #define X86_TRAP_DF 8 /* Double Fault */ |
28 | #define X86_TRAP_OLD_MF 9 /* Coprocessor Segment Overrun */ |
29 | #define X86_TRAP_TS 10 /* Invalid TSS */ |
30 | #define X86_TRAP_NP 11 /* Segment Not Present */ |
31 | #define X86_TRAP_SS 12 /* Stack Segment Fault */ |
32 | #define X86_TRAP_GP 13 /* General Protection Fault */ |
33 | #define X86_TRAP_PF 14 /* Page Fault */ |
34 | #define X86_TRAP_SPURIOUS 15 /* Spurious Interrupt */ |
35 | #define X86_TRAP_MF 16 /* x87 Floating-Point Exception */ |
36 | #define X86_TRAP_AC 17 /* Alignment Check */ |
37 | #define X86_TRAP_MC 18 /* Machine Check */ |
38 | #define X86_TRAP_XF 19 /* SIMD Floating-Point Exception */ |
39 | #define X86_TRAP_VE 20 /* Virtualization Exception */ |
40 | #define X86_TRAP_CP 21 /* Control Protection Exception */ |
41 | #define X86_TRAP_VC 29 /* VMM Communication Exception */ |
42 | #define X86_TRAP_IRET 32 /* IRET Exception */ |
43 | |
44 | #endif |
45 | |