diff options
author | Eric W. Biederman <ebiederm@xmission.com> | 2018-04-16 15:18:26 -0400 |
---|---|---|
committer | Eric W. Biederman <ebiederm@xmission.com> | 2018-09-19 09:45:42 -0400 |
commit | efc463adbccf709c5dbaf6cfbf84b7e94b62810a (patch) | |
tree | eee1ff080fa28324033a7400a0ad64c36ceea517 /include/linux/ptrace.h | |
parent | fb50f5a4011c499bc1b1fae77299cfcb3945e51b (diff) |
signal: Simplify tracehook_report_syscall_exit
Replace user_single_step_siginfo with user_single_step_report
that allocates siginfo structure on the stack and sends it.
This allows tracehook_report_syscall_exit to become a simple
if statement that calls user_single_step_report or ptrace_report_syscall
depending on the value of step.
Update the default helper function now called user_single_step_report
to explicitly set si_code to SI_USER and to set si_uid and si_pid to 0.
The default helper has always been doing this (using memset) but it
was far from obvious.
The powerpc helper can now just call force_sig_fault.
The x86 helper can now just call send_sigtrap.
Unfortunately the default implementation of user_single_step_report
can not use force_sig_fault as it does not use a SIGTRAP si_code.
So it has to carefully setup the siginfo and use use force_sig_info.
The net result is code that is easier to understand and simpler
to maintain.
Ref: 85ec7fd9f8e5 ("ptrace: introduce user_single_step_siginfo() helper")
Reviewed-by: Thomas Gleixner <tglx@linutronix.de>
Signed-off-by: "Eric W. Biederman" <ebiederm@xmission.com>
Diffstat (limited to 'include/linux/ptrace.h')
-rw-r--r-- | include/linux/ptrace.h | 17 |
1 files changed, 11 insertions, 6 deletions
diff --git a/include/linux/ptrace.h b/include/linux/ptrace.h index 4f36431c380b..1de2235511c8 100644 --- a/include/linux/ptrace.h +++ b/include/linux/ptrace.h | |||
@@ -336,14 +336,19 @@ static inline void user_enable_block_step(struct task_struct *task) | |||
336 | extern void user_enable_block_step(struct task_struct *); | 336 | extern void user_enable_block_step(struct task_struct *); |
337 | #endif /* arch_has_block_step */ | 337 | #endif /* arch_has_block_step */ |
338 | 338 | ||
339 | #ifdef ARCH_HAS_USER_SINGLE_STEP_INFO | 339 | #ifdef ARCH_HAS_USER_SINGLE_STEP_REPORT |
340 | extern void user_single_step_siginfo(struct task_struct *tsk, | 340 | extern void user_single_step_report(struct pt_regs *regs); |
341 | struct pt_regs *regs, siginfo_t *info); | ||
342 | #else | 341 | #else |
343 | static inline void user_single_step_siginfo(struct task_struct *tsk, | 342 | static inline void user_single_step_report(struct pt_regs *regs) |
344 | struct pt_regs *regs, siginfo_t *info) | ||
345 | { | 343 | { |
346 | info->si_signo = SIGTRAP; | 344 | siginfo_t info; |
345 | clear_siginfo(&info); | ||
346 | info.si_signo = SIGTRAP; | ||
347 | info.si_errno = 0; | ||
348 | info.si_code = SI_USER; | ||
349 | info.si_pid = 0; | ||
350 | info.si_uid = 0; | ||
351 | force_sig_info(info.si_signo, &info, current); | ||
347 | } | 352 | } |
348 | #endif | 353 | #endif |
349 | 354 | ||