|
@@ -25,6 +25,9 @@
|
|
|
#include <asm/traps.h>
|
|
|
#include <arch/chip.h>
|
|
|
|
|
|
+#define CREATE_TRACE_POINTS
|
|
|
+#include <trace/events/syscalls.h>
|
|
|
+
|
|
|
void user_enable_single_step(struct task_struct *child)
|
|
|
{
|
|
|
set_tsk_thread_flag(child, TIF_SINGLESTEP);
|
|
@@ -249,16 +252,24 @@ long compat_arch_ptrace(struct task_struct *child, compat_long_t request,
|
|
|
|
|
|
int do_syscall_trace_enter(struct pt_regs *regs)
|
|
|
{
|
|
|
- if (tracehook_report_syscall_entry(regs)) {
|
|
|
- regs->regs[TREG_SYSCALL_NR] = -1;
|
|
|
+ if (test_thread_flag(TIF_SYSCALL_TRACE)) {
|
|
|
+ if (tracehook_report_syscall_entry(regs))
|
|
|
+ regs->regs[TREG_SYSCALL_NR] = -1;
|
|
|
}
|
|
|
|
|
|
+ if (test_thread_flag(TIF_SYSCALL_TRACEPOINT))
|
|
|
+ trace_sys_enter(regs, regs->regs[TREG_SYSCALL_NR]);
|
|
|
+
|
|
|
return regs->regs[TREG_SYSCALL_NR];
|
|
|
}
|
|
|
|
|
|
void do_syscall_trace_exit(struct pt_regs *regs)
|
|
|
{
|
|
|
- tracehook_report_syscall_exit(regs, 0);
|
|
|
+ if (test_thread_flag(TIF_SYSCALL_TRACE))
|
|
|
+ tracehook_report_syscall_exit(regs, 0);
|
|
|
+
|
|
|
+ if (test_thread_flag(TIF_SYSCALL_TRACEPOINT))
|
|
|
+ trace_sys_exit(regs, regs->regs[TREG_SYSCALL_NR]);
|
|
|
}
|
|
|
|
|
|
void send_sigtrap(struct task_struct *tsk, struct pt_regs *regs, int error_code)
|