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 /arch/x86/kernel | |
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 'arch/x86/kernel')
-rw-r--r-- | arch/x86/kernel/ptrace.c | 11 |
1 files changed, 5 insertions, 6 deletions
diff --git a/arch/x86/kernel/ptrace.c b/arch/x86/kernel/ptrace.c index e2ee403865eb..94bd6e89129a 100644 --- a/arch/x86/kernel/ptrace.c +++ b/arch/x86/kernel/ptrace.c | |||
@@ -1382,12 +1382,6 @@ static void fill_sigtrap_info(struct task_struct *tsk, | |||
1382 | info->si_addr = user_mode(regs) ? (void __user *)regs->ip : NULL; | 1382 | info->si_addr = user_mode(regs) ? (void __user *)regs->ip : NULL; |
1383 | } | 1383 | } |
1384 | 1384 | ||
1385 | void user_single_step_siginfo(struct task_struct *tsk, | ||
1386 | struct pt_regs *regs, | ||
1387 | struct siginfo *info) | ||
1388 | { | ||
1389 | fill_sigtrap_info(tsk, regs, 0, TRAP_BRKPT, info); | ||
1390 | } | ||
1391 | 1385 | ||
1392 | void send_sigtrap(struct task_struct *tsk, struct pt_regs *regs, | 1386 | void send_sigtrap(struct task_struct *tsk, struct pt_regs *regs, |
1393 | int error_code, int si_code) | 1387 | int error_code, int si_code) |
@@ -1399,3 +1393,8 @@ void send_sigtrap(struct task_struct *tsk, struct pt_regs *regs, | |||
1399 | /* Send us the fake SIGTRAP */ | 1393 | /* Send us the fake SIGTRAP */ |
1400 | force_sig_info(SIGTRAP, &info, tsk); | 1394 | force_sig_info(SIGTRAP, &info, tsk); |
1401 | } | 1395 | } |
1396 | |||
1397 | void user_single_step_report(struct pt_regs *regs) | ||
1398 | { | ||
1399 | send_sigtrap(current, regs, 0, TRAP_BRKPT); | ||
1400 | } | ||