1 /* SPDX-License-Identifier: GPL-2.0-only */
3 * Copyright (C) 2004, 2007-2010, 2011-2012 Synopsys, Inc. (www.synopsys.com)
9 #include <asm-generic/kprobes.h>
13 typedef u16 kprobe_opcode_t
;
15 #define UNIMP_S_INSTRUCTION 0x79e0
16 #define TRAP_S_2_INSTRUCTION 0x785e
18 #define MAX_INSN_SIZE 8
19 #define MAX_STACK_SIZE 64
21 struct arch_specific_insn
{
23 kprobe_opcode_t
*t1_addr
, *t2_addr
;
24 kprobe_opcode_t t1_opcode
, t2_opcode
;
27 #define flush_insn_slot(p) do { } while (0)
29 #define kretprobe_blacklist_size 0
33 void arch_remove_kprobe(struct kprobe
*p
);
35 int kprobe_exceptions_notify(struct notifier_block
*self
,
36 unsigned long val
, void *data
);
43 struct kprobe_ctlblk
{
44 unsigned int kprobe_status
;
45 struct prev_kprobe prev_kprobe
;
48 int kprobe_fault_handler(struct pt_regs
*regs
, unsigned long cause
);
49 void kretprobe_trampoline(void);
50 void trap_is_kprobe(unsigned long address
, struct pt_regs
*regs
);
52 #define trap_is_kprobe(address, regs)
53 #endif /* CONFIG_KPROBES */
55 #endif /* _ARC_KPROBES_H */