123456789101112131415161718192021222324252627282930313233343536373839404142 |
- /* SPDX-License-Identifier: GPL-2.0-only */
- /*
- * Copyright (C) 2012 Rabin Vincent <rabin at rab.in>
- */
- #ifndef _ASM_UPROBES_H
- #define _ASM_UPROBES_H
- #include <asm/probes.h>
- #include <asm/opcodes.h>
- typedef u32 uprobe_opcode_t;
- #define MAX_UINSN_BYTES 4
- #define UPROBE_XOL_SLOT_BYTES 64
- #define UPROBE_SWBP_ARM_INSN 0xe7f001f9
- #define UPROBE_SS_ARM_INSN 0xe7f001fa
- #define UPROBE_SWBP_INSN __opcode_to_mem_arm(UPROBE_SWBP_ARM_INSN)
- #define UPROBE_SWBP_INSN_SIZE 4
- struct arch_uprobe_task {
- u32 backup;
- unsigned long saved_trap_no;
- };
- struct arch_uprobe {
- u8 insn[MAX_UINSN_BYTES];
- unsigned long ixol[2];
- uprobe_opcode_t bpinsn;
- bool simulate;
- u32 pcreg;
- void (*prehandler)(struct arch_uprobe *auprobe,
- struct arch_uprobe_task *autask,
- struct pt_regs *regs);
- void (*posthandler)(struct arch_uprobe *auprobe,
- struct arch_uprobe_task *autask,
- struct pt_regs *regs);
- struct arch_probes_insn asi;
- };
- #endif
|