mirror of
git://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git
synced 2025-08-31 23:27:20 +00:00

LoongArch defines UPROBE_SWBP_INSN as a function call and this breaks
arch_uprobe_trampoline() which uses it to initialize a static variable.
Add the new "__builtin_constant_p" helper, __emit_break(), and redefine
the current users of larch_insn_gen_break() to use it.
Fixes: ff474a78ce
("uprobe: Add uretprobe syscall to speed up return probe")
Reported-by: Nathan Chancellor <nathan@kernel.org>
Closes: https://lore.kernel.org/all/20240614174822.GA1185149@thelio-3990X/
Suggested-by: Andrii Nakryiko <andrii@kernel.org>
Tested-by: Tiezhu Yang <yangtiezhu@loongson.cn>
Signed-off-by: Oleg Nesterov <oleg@redhat.com>
Signed-off-by: Huacai Chen <chenhuacai@loongson.cn>
36 lines
954 B
C
36 lines
954 B
C
/* SPDX-License-Identifier: GPL-2.0-only */
|
|
#ifndef __ASM_LOONGARCH_UPROBES_H
|
|
#define __ASM_LOONGARCH_UPROBES_H
|
|
|
|
#include <asm/inst.h>
|
|
|
|
typedef u32 uprobe_opcode_t;
|
|
|
|
#define MAX_UINSN_BYTES 8
|
|
#define UPROBE_XOL_SLOT_BYTES MAX_UINSN_BYTES
|
|
|
|
#define UPROBE_SWBP_INSN __emit_break(BRK_UPROBE_BP)
|
|
#define UPROBE_SWBP_INSN_SIZE LOONGARCH_INSN_SIZE
|
|
|
|
#define UPROBE_XOLBP_INSN __emit_break(BRK_UPROBE_XOLBP)
|
|
|
|
struct arch_uprobe {
|
|
unsigned long resume_era;
|
|
u32 insn[2];
|
|
u32 ixol[2];
|
|
bool simulate;
|
|
};
|
|
|
|
struct arch_uprobe_task {
|
|
unsigned long saved_trap_nr;
|
|
};
|
|
|
|
#ifdef CONFIG_UPROBES
|
|
bool uprobe_breakpoint_handler(struct pt_regs *regs);
|
|
bool uprobe_singlestep_handler(struct pt_regs *regs);
|
|
#else /* !CONFIG_UPROBES */
|
|
static inline bool uprobe_breakpoint_handler(struct pt_regs *regs) { return false; }
|
|
static inline bool uprobe_singlestep_handler(struct pt_regs *regs) { return false; }
|
|
#endif /* CONFIG_UPROBES */
|
|
|
|
#endif /* __ASM_LOONGARCH_UPROBES_H */
|