| /* SPDX-License-Identifier: GPL-2.0-only */ | 
| /* | 
|  * arch/arm/include/asm/probes.h | 
|  * | 
|  * Original contents copied from arch/arm/include/asm/kprobes.h | 
|  * which contains the following notice... | 
|  * | 
|  * Copyright (C) 2006, 2007 Motorola Inc. | 
|  */ | 
|   | 
| #ifndef _ASM_PROBES_H | 
| #define _ASM_PROBES_H | 
|   | 
| #ifndef __ASSEMBLY__ | 
|   | 
| typedef u32 probes_opcode_t; | 
|   | 
| struct arch_probes_insn; | 
| typedef void (probes_insn_handler_t)(probes_opcode_t, | 
|                      struct arch_probes_insn *, | 
|                      struct pt_regs *); | 
| typedef unsigned long (probes_check_cc)(unsigned long); | 
| typedef void (probes_insn_singlestep_t)(probes_opcode_t, | 
|                     struct arch_probes_insn *, | 
|                     struct pt_regs *); | 
| typedef void (probes_insn_fn_t)(void); | 
|   | 
| /* Architecture specific copy of original instruction. */ | 
| struct arch_probes_insn { | 
|     probes_opcode_t            *insn; | 
|     probes_insn_handler_t        *insn_handler; | 
|     probes_check_cc            *insn_check_cc; | 
|     probes_insn_singlestep_t    *insn_singlestep; | 
|     probes_insn_fn_t        *insn_fn; | 
|     int                stack_space; | 
|     unsigned long            register_usage_flags; | 
|     bool                kprobe_direct_exec; | 
| }; | 
|   | 
| #endif /* __ASSEMBLY__ */ | 
|   | 
| /* | 
|  * We assume one instruction can consume at most 64 bytes stack, which is | 
|  * 'push {r0-r15}'. Instructions consume more or unknown stack space like | 
|  * 'str r0, [sp, #-80]' and 'str r0, [sp, r1]' should be prohibit to probe. | 
|  */ | 
| #define MAX_STACK_SIZE            64 | 
|   | 
| #endif |