Commit 4164a482 authored by Thomas Gleixner's avatar Thomas Gleixner Committed by Borislav Petkov

x86/fpu/signal: Move header zeroing out of xsave_to_user_sigframe()

There is no reason to have the header zeroing in the pagefault disabled
region. Do it upfront once.
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.621674721@linutronix.de
parent 4339d0c6
...@@ -318,9 +318,12 @@ static inline void os_xrstor(struct xregs_state *xstate, u64 mask) ...@@ -318,9 +318,12 @@ static inline void os_xrstor(struct xregs_state *xstate, u64 mask)
* We don't use modified optimization because xrstor/xrstors might track * We don't use modified optimization because xrstor/xrstors might track
* a different application. * a different application.
* *
* We don't use compacted format xsave area for * We don't use compacted format xsave area for backward compatibility for
* backward compatibility for old applications which don't understand * old applications which don't understand the compacted format of the
* compacted format of xsave area. * xsave area.
*
* The caller has to zero buf::header before calling this because XSAVE*
* does not touch the reserved fields in the header.
*/ */
static inline int xsave_to_user_sigframe(struct xregs_state __user *buf) static inline int xsave_to_user_sigframe(struct xregs_state __user *buf)
{ {
...@@ -334,14 +337,6 @@ static inline int xsave_to_user_sigframe(struct xregs_state __user *buf) ...@@ -334,14 +337,6 @@ static inline int xsave_to_user_sigframe(struct xregs_state __user *buf)
u32 hmask = mask >> 32; u32 hmask = mask >> 32;
int err; int err;
/*
* Clear the xsave header first, so that reserved fields are
* initialized to zero.
*/
err = __clear_user(&buf->header, sizeof(buf->header));
if (unlikely(err))
return -EFAULT;
stac(); stac();
XSTATE_OP(XSAVE, buf, lmask, hmask, err); XSTATE_OP(XSAVE, buf, lmask, hmask, err);
clac(); clac();
......
...@@ -189,6 +189,18 @@ int copy_fpstate_to_sigframe(void __user *buf, void __user *buf_fx, int size) ...@@ -189,6 +189,18 @@ int copy_fpstate_to_sigframe(void __user *buf, void __user *buf_fx, int size)
if (!access_ok(buf, size)) if (!access_ok(buf, size))
return -EACCES; return -EACCES;
if (use_xsave()) {
struct xregs_state __user *xbuf = buf_fx;
/*
* 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;
}
retry: retry:
/* /*
* Load the FPU registers if they are not valid for the current task. * Load the FPU registers if they are not valid for the current task.
......
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