]> git.ipfire.org Git - thirdparty/kernel/linux.git/commitdiff
entry: Move syscall_enter_from_user_mode() to header file
authorSven Schnelle <svens@linux.ibm.com>
Mon, 18 Dec 2023 07:45:20 +0000 (08:45 +0100)
committerThomas Gleixner <tglx@linutronix.de>
Thu, 21 Dec 2023 22:12:18 +0000 (23:12 +0100)
To allow inlining of syscall_enter_from_user_mode(), move it
to entry-common.h.

Signed-off-by: Sven Schnelle <svens@linux.ibm.com>
Signed-off-by: Thomas Gleixner <tglx@linutronix.de>
Link: https://lore.kernel.org/r/20231218074520.1998026-4-svens@linux.ibm.com
include/linux/entry-common.h
kernel/entry/common.c

index c4205390448eee6be9036257dff105a4545196b7..b0fb775a600d9844aa6dbd7c6db70b1c7261829d 100644 (file)
@@ -134,6 +134,9 @@ static __always_inline void enter_from_user_mode(struct pt_regs *regs)
  */
 void syscall_enter_from_user_mode_prepare(struct pt_regs *regs);
 
+long syscall_trace_enter(struct pt_regs *regs, long syscall,
+                        unsigned long work);
+
 /**
  * syscall_enter_from_user_mode_work - Check and handle work before invoking
  *                                    a syscall
@@ -157,7 +160,15 @@ void syscall_enter_from_user_mode_prepare(struct pt_regs *regs);
  *     ptrace_report_syscall_entry(), __secure_computing(), trace_sys_enter()
  *  2) Invocation of audit_syscall_entry()
  */
-long syscall_enter_from_user_mode_work(struct pt_regs *regs, long syscall);
+static __always_inline long syscall_enter_from_user_mode_work(struct pt_regs *regs, long syscall)
+{
+       unsigned long work = READ_ONCE(current_thread_info()->syscall_work);
+
+       if (work & SYSCALL_WORK_ENTER)
+               syscall = syscall_trace_enter(regs, syscall, work);
+
+       return syscall;
+}
 
 /**
  * syscall_enter_from_user_mode - Establish state and check and handle work
@@ -176,7 +187,19 @@ long syscall_enter_from_user_mode_work(struct pt_regs *regs, long syscall);
  * Returns: The original or a modified syscall number. See
  * syscall_enter_from_user_mode_work() for further explanation.
  */
-long syscall_enter_from_user_mode(struct pt_regs *regs, long syscall);
+static __always_inline long syscall_enter_from_user_mode(struct pt_regs *regs, long syscall)
+{
+       long ret;
+
+       enter_from_user_mode(regs);
+
+       instrumentation_begin();
+       local_irq_enable();
+       ret = syscall_enter_from_user_mode_work(regs, syscall);
+       instrumentation_end();
+
+       return ret;
+}
 
 /**
  * local_irq_enable_exit_to_user - Exit to user variant of local_irq_enable()
index 0616f239da4b2244e7f317684f8e44d78d55a172..88cb3c88aaa5c6c1ca271c1cc95dcd60cdd8ca9c 100644 (file)
@@ -25,7 +25,7 @@ static inline void syscall_enter_audit(struct pt_regs *regs, long syscall)
        }
 }
 
-static long syscall_trace_enter(struct pt_regs *regs, long syscall,
+long syscall_trace_enter(struct pt_regs *regs, long syscall,
                                unsigned long work)
 {
        long ret = 0;
@@ -65,36 +65,6 @@ static long syscall_trace_enter(struct pt_regs *regs, long syscall,
        return ret ? : syscall;
 }
 
-static __always_inline long
-__syscall_enter_from_user_work(struct pt_regs *regs, long syscall)
-{
-       unsigned long work = READ_ONCE(current_thread_info()->syscall_work);
-
-       if (work & SYSCALL_WORK_ENTER)
-               syscall = syscall_trace_enter(regs, syscall, work);
-
-       return syscall;
-}
-
-long syscall_enter_from_user_mode_work(struct pt_regs *regs, long syscall)
-{
-       return __syscall_enter_from_user_work(regs, syscall);
-}
-
-noinstr long syscall_enter_from_user_mode(struct pt_regs *regs, long syscall)
-{
-       long ret;
-
-       enter_from_user_mode(regs);
-
-       instrumentation_begin();
-       local_irq_enable();
-       ret = __syscall_enter_from_user_work(regs, syscall);
-       instrumentation_end();
-
-       return ret;
-}
-
 noinstr void syscall_enter_from_user_mode_prepare(struct pt_regs *regs)
 {
        enter_from_user_mode(regs);