xref: /kvm-unit-tests/lib/arm64/asm/esr.h (revision 7ee966e98ee6e326b4149ed28330a71d6e96b10d)
1*7ee966e9SAndrew Jones /*
2*7ee966e9SAndrew Jones  * From Linux kernel arch/arm64/include/asm/esr.h
3*7ee966e9SAndrew Jones  */
4*7ee966e9SAndrew Jones #ifndef _ASMARM64_ESR_H_
5*7ee966e9SAndrew Jones #define _ASMARM64_ESR_H_
6*7ee966e9SAndrew Jones 
7*7ee966e9SAndrew Jones #define ESR_EL1_WRITE		(1 << 6)
8*7ee966e9SAndrew Jones #define ESR_EL1_CM		(1 << 8)
9*7ee966e9SAndrew Jones #define ESR_EL1_IL		(1 << 25)
10*7ee966e9SAndrew Jones 
11*7ee966e9SAndrew Jones #define ESR_EL1_EC_SHIFT	(26)
12*7ee966e9SAndrew Jones #define ESR_EL1_EC_UNKNOWN	(0x00)
13*7ee966e9SAndrew Jones #define ESR_EL1_EC_WFI		(0x01)
14*7ee966e9SAndrew Jones #define ESR_EL1_EC_CP15_32	(0x03)
15*7ee966e9SAndrew Jones #define ESR_EL1_EC_CP15_64	(0x04)
16*7ee966e9SAndrew Jones #define ESR_EL1_EC_CP14_MR	(0x05)
17*7ee966e9SAndrew Jones #define ESR_EL1_EC_CP14_LS	(0x06)
18*7ee966e9SAndrew Jones #define ESR_EL1_EC_FP_ASIMD	(0x07)
19*7ee966e9SAndrew Jones #define ESR_EL1_EC_CP10_ID	(0x08)
20*7ee966e9SAndrew Jones #define ESR_EL1_EC_CP14_64	(0x0C)
21*7ee966e9SAndrew Jones #define ESR_EL1_EC_ILL_ISS	(0x0E)
22*7ee966e9SAndrew Jones #define ESR_EL1_EC_SVC32	(0x11)
23*7ee966e9SAndrew Jones #define ESR_EL1_EC_SVC64	(0x15)
24*7ee966e9SAndrew Jones #define ESR_EL1_EC_SYS64	(0x18)
25*7ee966e9SAndrew Jones #define ESR_EL1_EC_IABT_EL0	(0x20)
26*7ee966e9SAndrew Jones #define ESR_EL1_EC_IABT_EL1	(0x21)
27*7ee966e9SAndrew Jones #define ESR_EL1_EC_PC_ALIGN	(0x22)
28*7ee966e9SAndrew Jones #define ESR_EL1_EC_DABT_EL0	(0x24)
29*7ee966e9SAndrew Jones #define ESR_EL1_EC_DABT_EL1	(0x25)
30*7ee966e9SAndrew Jones #define ESR_EL1_EC_SP_ALIGN	(0x26)
31*7ee966e9SAndrew Jones #define ESR_EL1_EC_FP_EXC32	(0x28)
32*7ee966e9SAndrew Jones #define ESR_EL1_EC_FP_EXC64	(0x2C)
33*7ee966e9SAndrew Jones #define ESR_EL1_EC_SERROR	(0x2F)
34*7ee966e9SAndrew Jones #define ESR_EL1_EC_BREAKPT_EL0	(0x30)
35*7ee966e9SAndrew Jones #define ESR_EL1_EC_BREAKPT_EL1	(0x31)
36*7ee966e9SAndrew Jones #define ESR_EL1_EC_SOFTSTP_EL0	(0x32)
37*7ee966e9SAndrew Jones #define ESR_EL1_EC_SOFTSTP_EL1	(0x33)
38*7ee966e9SAndrew Jones #define ESR_EL1_EC_WATCHPT_EL0	(0x34)
39*7ee966e9SAndrew Jones #define ESR_EL1_EC_WATCHPT_EL1	(0x35)
40*7ee966e9SAndrew Jones #define ESR_EL1_EC_BKPT32	(0x38)
41*7ee966e9SAndrew Jones #define ESR_EL1_EC_BRK64	(0x3C)
42*7ee966e9SAndrew Jones 
43*7ee966e9SAndrew Jones #endif /* _ASMARM64_ESR_H_ */
44