Commit 2af07f3a authored by Thomas Gleixner's avatar Thomas Gleixner Committed by Borislav Petkov

x86/fpu/signal: Change return type of copy_fpregs_to_sigframe() helpers to boolean

Now that copy_fpregs_to_sigframe() returns boolean the individual return
codes in the related helper functions do not make sense anymore. Change
them to return boolean success/fail.
Signed-off-by: default avatarThomas Gleixner <tglx@linutronix.de>
Signed-off-by: default avatarBorislav Petkov <bp@suse.de>
Link: https://lkml.kernel.org/r/20210908132525.794334915@linutronix.de
parent 052adee6
...@@ -65,7 +65,7 @@ static inline int check_xstate_in_sigframe(struct fxregs_state __user *fxbuf, ...@@ -65,7 +65,7 @@ static inline int check_xstate_in_sigframe(struct fxregs_state __user *fxbuf,
/* /*
* Signal frame handlers. * Signal frame handlers.
*/ */
static inline int save_fsave_header(struct task_struct *tsk, void __user *buf) static inline bool save_fsave_header(struct task_struct *tsk, void __user *buf)
{ {
if (use_fxsr()) { if (use_fxsr()) {
struct xregs_state *xsave = &tsk->thread.fpu.state.xsave; struct xregs_state *xsave = &tsk->thread.fpu.state.xsave;
...@@ -82,18 +82,19 @@ static inline int save_fsave_header(struct task_struct *tsk, void __user *buf) ...@@ -82,18 +82,19 @@ static inline int save_fsave_header(struct task_struct *tsk, void __user *buf)
if (__copy_to_user(buf, &env, sizeof(env)) || if (__copy_to_user(buf, &env, sizeof(env)) ||
__put_user(xsave->i387.swd, &fp->status) || __put_user(xsave->i387.swd, &fp->status) ||
__put_user(X86_FXSR_MAGIC, &fp->magic)) __put_user(X86_FXSR_MAGIC, &fp->magic))
return -1; return false;
} else { } else {
struct fregs_state __user *fp = buf; struct fregs_state __user *fp = buf;
u32 swd; u32 swd;
if (__get_user(swd, &fp->swd) || __put_user(swd, &fp->status)) if (__get_user(swd, &fp->swd) || __put_user(swd, &fp->status))
return -1; return false;
} }
return 0; return true;
} }
static inline int save_xstate_epilog(void __user *buf, int ia32_frame) static inline bool save_xstate_epilog(void __user *buf, int ia32_frame)
{ {
struct xregs_state __user *x = buf; struct xregs_state __user *x = buf;
struct _fpx_sw_bytes *sw_bytes; struct _fpx_sw_bytes *sw_bytes;
...@@ -131,7 +132,7 @@ static inline int save_xstate_epilog(void __user *buf, int ia32_frame) ...@@ -131,7 +132,7 @@ static inline int save_xstate_epilog(void __user *buf, int ia32_frame)
err |= __put_user(xfeatures, (__u32 __user *)&x->header.xfeatures); err |= __put_user(xfeatures, (__u32 __user *)&x->header.xfeatures);
return err; return !err;
} }
static inline int copy_fpregs_to_sigframe(struct xregs_state __user *buf) static inline int copy_fpregs_to_sigframe(struct xregs_state __user *buf)
...@@ -218,10 +219,10 @@ bool copy_fpstate_to_sigframe(void __user *buf, void __user *buf_fx, int size) ...@@ -218,10 +219,10 @@ bool copy_fpstate_to_sigframe(void __user *buf, void __user *buf_fx, int size)
} }
/* Save the fsave header for the 32-bit frames. */ /* Save the fsave header for the 32-bit frames. */
if ((ia32_fxstate || !use_fxsr()) && save_fsave_header(tsk, buf)) if ((ia32_fxstate || !use_fxsr()) && !save_fsave_header(tsk, buf))
return false; return false;
if (use_fxsr() && save_xstate_epilog(buf_fx, ia32_fxstate)) if (use_fxsr() && !save_xstate_epilog(buf_fx, ia32_fxstate))
return false; return false;
return true; return true;
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment