mirror of
https://mirrors.bfsu.edu.cn/git/linux.git
synced 2024-11-17 09:14:19 +08:00
ptrace: introduce user_single_step_siginfo() helper
Suggested by Roland. Currently there is no way to synthesize a single-stepping trap in the arch-independent manner. This patch adds the default helper which fills siginfo_t, arch/ can can override it. Architetures which implement user_enable_single_step() should add user_single_step_siginfo() also. Signed-off-by: Oleg Nesterov <oleg@redhat.com> Acked-by: Roland McGrath <roland@redhat.com> Cc: <linux-arch@vger.kernel.org> Cc: Ingo Molnar <mingo@elte.hu> Cc: Thomas Gleixner <tglx@linutronix.de> Cc: "H. Peter Anvin" <hpa@zytor.com> Signed-off-by: Andrew Morton <akpm@linux-foundation.org> Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org>
This commit is contained in:
parent
6580807da1
commit
85ec7fd9f8
@ -273,6 +273,18 @@ static inline void user_enable_block_step(struct task_struct *task)
|
||||
}
|
||||
#endif /* arch_has_block_step */
|
||||
|
||||
#ifdef ARCH_HAS_USER_SINGLE_STEP_INFO
|
||||
extern void user_single_step_siginfo(struct task_struct *tsk,
|
||||
struct pt_regs *regs, siginfo_t *info);
|
||||
#else
|
||||
static inline void user_single_step_siginfo(struct task_struct *tsk,
|
||||
struct pt_regs *regs, siginfo_t *info)
|
||||
{
|
||||
memset(info, 0, sizeof(*info));
|
||||
info->si_signo = SIGTRAP;
|
||||
}
|
||||
#endif
|
||||
|
||||
#ifndef arch_ptrace_stop_needed
|
||||
/**
|
||||
* arch_ptrace_stop_needed - Decide whether arch_ptrace_stop() should be called
|
||||
|
Loading…
Reference in New Issue
Block a user