xref: /openbmc/linux/arch/arm64/include/asm/brk-imm.h (revision fadbafc1)
1 /* SPDX-License-Identifier: GPL-2.0-only */
2 /*
3  * Copyright (C) 2012 ARM Ltd.
4  */
5 
6 #ifndef __ASM_BRK_IMM_H
7 #define __ASM_BRK_IMM_H
8 
9 /*
10  * #imm16 values used for BRK instruction generation
11  * 0x004: for installing kprobes
12  * 0x005: for installing uprobes
13  * 0x006: for kprobe software single-step
14  * Allowed values for kgdb are 0x400 - 0x7ff
15  * 0x100: for triggering a fault on purpose (reserved)
16  * 0x400: for dynamic BRK instruction
17  * 0x401: for compile time BRK instruction
18  * 0x800: kernel-mode BUG() and WARN() traps
19  * 0x9xx: tag-based KASAN trap (allowed values 0x900 - 0x9ff)
20  * 0x8xxx: Control-Flow Integrity traps
21  */
22 #define KPROBES_BRK_IMM			0x004
23 #define UPROBES_BRK_IMM			0x005
24 #define KPROBES_BRK_SS_IMM		0x006
25 #define FAULT_BRK_IMM			0x100
26 #define KGDB_DYN_DBG_BRK_IMM		0x400
27 #define KGDB_COMPILED_DBG_BRK_IMM	0x401
28 #define BUG_BRK_IMM			0x800
29 #define KASAN_BRK_IMM			0x900
30 #define KASAN_BRK_MASK			0x0ff
31 
32 #define CFI_BRK_IMM_TARGET		GENMASK(4, 0)
33 #define CFI_BRK_IMM_TYPE		GENMASK(9, 5)
34 #define CFI_BRK_IMM_BASE		0x8000
35 #define CFI_BRK_IMM_MASK		(CFI_BRK_IMM_TARGET | CFI_BRK_IMM_TYPE)
36 
37 #endif
38