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 * 0x55xx: Undefined Behavior Sanitizer traps ('U' << 8) 21 * 0x8xxx: Control-Flow Integrity traps 22 */ 23 #define KPROBES_BRK_IMM 0x004 24 #define UPROBES_BRK_IMM 0x005 25 #define KPROBES_BRK_SS_IMM 0x006 26 #define FAULT_BRK_IMM 0x100 27 #define KGDB_DYN_DBG_BRK_IMM 0x400 28 #define KGDB_COMPILED_DBG_BRK_IMM 0x401 29 #define BUG_BRK_IMM 0x800 30 #define KASAN_BRK_IMM 0x900 31 #define KASAN_BRK_MASK 0x0ff 32 #define UBSAN_BRK_IMM 0x5500 33 #define UBSAN_BRK_MASK 0x00ff 34 35 #define CFI_BRK_IMM_TARGET GENMASK(4, 0) 36 #define CFI_BRK_IMM_TYPE GENMASK(9, 5) 37 #define CFI_BRK_IMM_BASE 0x8000 38 #define CFI_BRK_IMM_MASK (CFI_BRK_IMM_TARGET | CFI_BRK_IMM_TYPE) 39 40 #endif 41