arm64: rseq: Implement backend rseq calls and select HAVE_RSEQ
authorWill Deacon <will.deacon@arm.com>
Wed, 20 Jun 2018 13:46:50 +0000 (14:46 +0100)
committerWill Deacon <will.deacon@arm.com>
Wed, 11 Jul 2018 12:29:34 +0000 (13:29 +0100)
Implement calls to rseq_signal_deliver, rseq_handle_notify_resume
and rseq_syscall so that we can select HAVE_RSEQ on arm64.

Acked-by: Mathieu Desnoyers <mathieu.desnoyers@efficios.com>
Acked-by: Mark Rutland <mark.rutland@arm.com>
Signed-off-by: Will Deacon <will.deacon@arm.com>
arch/arm64/Kconfig
arch/arm64/include/asm/unistd.h
arch/arm64/include/asm/unistd32.h
arch/arm64/kernel/entry.S
arch/arm64/kernel/ptrace.c
arch/arm64/kernel/signal.c

index 2e7609e4d08a76859076def51030b9dc3754806b..f4157d4a0289e683b23fc423f023d7b5f50c3268 100644 (file)
@@ -138,6 +138,7 @@ config ARM64
        select HAVE_PERF_USER_STACK_DUMP
        select HAVE_REGS_AND_STACK_ACCESS_API
        select HAVE_RCU_TABLE_FREE
+       select HAVE_RSEQ
        select HAVE_STACKPROTECTOR
        select HAVE_SYSCALL_TRACEPOINTS
        select HAVE_KPROBES
index a0baa9af54878b5ea4dc95f21701eca55e65c4f0..e0d0f5b856e74589404de44c8ca4323e454973ec 100644 (file)
@@ -43,7 +43,7 @@
 #define __ARM_NR_compat_cacheflush     (__ARM_NR_COMPAT_BASE+2)
 #define __ARM_NR_compat_set_tls                (__ARM_NR_COMPAT_BASE+5)
 
-#define __NR_compat_syscalls           398
+#define __NR_compat_syscalls           399
 #endif
 
 #define __ARCH_WANT_SYS_CLONE
index ef292160748c82869505c2ba4f58dbde496269de..0fdc7ef8a776cc92ada6310ccccaf53bfae40db8 100644 (file)
@@ -817,6 +817,8 @@ __SYSCALL(__NR_pkey_alloc, sys_pkey_alloc)
 __SYSCALL(__NR_pkey_free, sys_pkey_free)
 #define __NR_statx 397
 __SYSCALL(__NR_statx, sys_statx)
+#define __NR_rseq 398
+__SYSCALL(__NR_rseq, sys_rseq)
 
 /*
  * Please add new compat syscalls above this comment and update
index 28ad8799406ffdf6d6e11c336305f1f1ad9ea303..1eda9e1a1f4a5820b557717cb804fda6022a9fec 100644 (file)
@@ -904,6 +904,7 @@ ENDPROC(el0_error)
 ret_fast_syscall:
        disable_daif
        str     x0, [sp, #S_X0]                 // returned x0
+#ifndef CONFIG_DEBUG_RSEQ
        ldr     x1, [tsk, #TSK_TI_FLAGS]        // re-check for syscall tracing
        and     x2, x1, #_TIF_SYSCALL_WORK
        cbnz    x2, ret_fast_syscall_trace
@@ -911,6 +912,7 @@ ret_fast_syscall:
        cbnz    x2, work_pending
        enable_step_tsk x1, x2
        kernel_exit 0
+#endif
 ret_fast_syscall_trace:
        enable_daif
        b       __sys_trace_return_skipped      // we already saved x0
index 42ff28aa5a0009addbcae4f3343964a8330e9b7a..489db362460691339c8ad20755f14e7b7859e616 100644 (file)
@@ -1658,6 +1658,8 @@ asmlinkage void syscall_trace_exit(struct pt_regs *regs)
 
        if (test_thread_flag(TIF_SYSCALL_TRACE))
                tracehook_report_syscall(regs, PTRACE_SYSCALL_EXIT);
+
+       rseq_syscall(regs);
 }
 
 /*
index 511af13e8d8fe2a8d921ff4cd35402b92977501d..e3b1d1b0aee88a0359af7f590b1ed7be5d7ca6b0 100644 (file)
@@ -802,6 +802,8 @@ static void handle_signal(struct ksignal *ksig, struct pt_regs *regs)
        int usig = ksig->sig;
        int ret;
 
+       rseq_signal_deliver(ksig, regs);
+
        /*
         * Set up the stack frame
         */
@@ -940,6 +942,7 @@ asmlinkage void do_notify_resume(struct pt_regs *regs,
                        if (thread_flags & _TIF_NOTIFY_RESUME) {
                                clear_thread_flag(TIF_NOTIFY_RESUME);
                                tracehook_notify_resume(regs);
+                               rseq_handle_notify_resume(NULL, regs);
                        }
 
                        if (thread_flags & _TIF_FOREIGN_FPSTATE)