x86/fpu/signal: Change return type of copy_fpstate_to_sigframe() to boolean
authorThomas Gleixner <tglx@linutronix.de>
Wed, 8 Sep 2021 13:29:32 +0000 (15:29 +0200)
committerBorislav Petkov <bp@suse.de>
Tue, 14 Sep 2021 19:10:03 +0000 (21:10 +0200)
None of the call sites cares about the actual return code. Change the
return type to boolean and return 'true' on success.

Suggested-by: Al Viro <viro@zeniv.linux.org.uk>
Signed-off-by: Thomas Gleixner <tglx@linutronix.de>
Signed-off-by: Borislav Petkov <bp@suse.de>
Link: https://lkml.kernel.org/r/20210908132525.736773588@linutronix.de
arch/x86/ia32/ia32_signal.c
arch/x86/include/asm/fpu/internal.h
arch/x86/kernel/fpu/signal.c
arch/x86/kernel/signal.c

index 5e3d9b7fd5fb0896ae28e44f71826c072b05a92e..023198edf86356347c27c53d4cd0aa321af637a6 100644 (file)
@@ -220,8 +220,8 @@ static void __user *get_sigframe(struct ksignal *ksig, struct pt_regs *regs,
 
        sp = fpu__alloc_mathframe(sp, 1, &fx_aligned, &math_size);
        *fpstate = (struct _fpstate_32 __user *) sp;
-       if (copy_fpstate_to_sigframe(*fpstate, (void __user *)fx_aligned,
-                                    math_size) < 0)
+       if (!copy_fpstate_to_sigframe(*fpstate, (void __user *)fx_aligned,
+                                     math_size))
                return (void __user *) -1L;
 
        sp -= frame_size;
index c856ca481546724231fac8669afa949b16de3aa2..74aa53eeedf5808972e19347abf9234e525337ed 100644 (file)
@@ -386,7 +386,7 @@ static inline void restore_fpregs_from_fpstate(union fpregs_state *fpstate)
        __restore_fpregs_from_fpstate(fpstate, xfeatures_mask_fpstate());
 }
 
-extern int copy_fpstate_to_sigframe(void __user *buf, void __user *fp, int size);
+extern bool copy_fpstate_to_sigframe(void __user *buf, void __user *fp, int size);
 
 /*
  * FPU context switch related helper methods:
index c4abbd97587b84973c2ba7905aafbfeb757fd33a..7ce396dcc94200d01305ec0ac49c15659635252a 100644 (file)
@@ -165,7 +165,7 @@ static inline int copy_fpregs_to_sigframe(struct xregs_state __user *buf)
  * For [f]xsave state, update the SW reserved fields in the [f]xsave frame
  * indicating the absence/presence of the extended state to the user.
  */
-int copy_fpstate_to_sigframe(void __user *buf, void __user *buf_fx, int size)
+bool copy_fpstate_to_sigframe(void __user *buf, void __user *buf_fx, int size)
 {
        struct task_struct *tsk = current;
        int ia32_fxstate = (buf != buf_fx);
@@ -176,13 +176,14 @@ int copy_fpstate_to_sigframe(void __user *buf, void __user *buf_fx, int size)
 
        if (!static_cpu_has(X86_FEATURE_FPU)) {
                struct user_i387_ia32_struct fp;
+
                fpregs_soft_get(current, NULL, (struct membuf){.p = &fp,
                                                .left = sizeof(fp)});
-               return copy_to_user(buf, &fp, sizeof(fp)) ? -EFAULT : 0;
+               return !copy_to_user(buf, &fp, sizeof(fp));
        }
 
        if (!access_ok(buf, size))
-               return -EACCES;
+               return false;
 
        if (use_xsave()) {
                struct xregs_state __user *xbuf = buf_fx;
@@ -191,9 +192,8 @@ int copy_fpstate_to_sigframe(void __user *buf, void __user *buf_fx, int size)
                 * Clear the xsave header first, so that reserved fields are
                 * initialized to zero.
                 */
-               ret = __clear_user(&xbuf->header, sizeof(xbuf->header));
-               if (unlikely(ret))
-                       return ret;
+               if (__clear_user(&xbuf->header, sizeof(xbuf->header)))
+                       return false;
        }
 retry:
        /*
@@ -214,17 +214,17 @@ retry:
        if (ret) {
                if (!__clear_user(buf_fx, fpu_user_xstate_size))
                        goto retry;
-               return -1;
+               return false;
        }
 
        /* Save the fsave header for the 32-bit frames. */
        if ((ia32_fxstate || !use_fxsr()) && save_fsave_header(tsk, buf))
-               return -1;
+               return false;
 
        if (use_fxsr() && save_xstate_epilog(buf_fx, ia32_fxstate))
-               return -1;
+               return false;
 
-       return 0;
+       return true;
 }
 
 static int __restore_fpregs_from_user(void __user *buf, u64 xrestore,
index f4d21e47008355a11aa81b02b5a94eb2b44c20a4..5f623a1c807508f036eee2f9959755925c69ef57 100644 (file)
@@ -244,7 +244,6 @@ get_sigframe(struct k_sigaction *ka, struct pt_regs *regs, size_t frame_size,
        unsigned long math_size = 0;
        unsigned long sp = regs->sp;
        unsigned long buf_fx = 0;
-       int ret;
 
        /* redzone */
        if (IS_ENABLED(CONFIG_X86_64))
@@ -292,8 +291,7 @@ get_sigframe(struct k_sigaction *ka, struct pt_regs *regs, size_t frame_size,
        }
 
        /* save i387 and extended state */
-       ret = copy_fpstate_to_sigframe(*fpstate, (void __user *)buf_fx, math_size);
-       if (ret < 0)
+       if (!copy_fpstate_to_sigframe(*fpstate, (void __user *)buf_fx, math_size))
                return (void __user *)-1L;
 
        return (void __user *)sp;