Commit 079ec41b authored by Thomas Gleixner's avatar Thomas Gleixner Committed by Borislav Petkov

x86/fpu: Provide a proper function for ex_handler_fprestore()

To make upcoming changes for support of dynamically enabled features
simpler, provide a proper function for the exception handler which removes
exposure of FPU internals.
Signed-off-by: default avatarThomas Gleixner <tglx@linutronix.de>
Signed-off-by: default avatarBorislav Petkov <bp@suse.de>
Link: https://lkml.kernel.org/r/20211015011540.053515012@linutronix.de
parent b56d2795
...@@ -113,6 +113,7 @@ static inline void update_pasid(void) { } ...@@ -113,6 +113,7 @@ static inline void update_pasid(void) { }
/* Trap handling */ /* Trap handling */
extern int fpu__exception_code(struct fpu *fpu, int trap_nr); extern int fpu__exception_code(struct fpu *fpu, int trap_nr);
extern void fpu_sync_fpstate(struct fpu *fpu); extern void fpu_sync_fpstate(struct fpu *fpu);
extern void fpu_reset_from_exception_fixup(void);
/* Boot, hotplug and resume */ /* Boot, hotplug and resume */
extern void fpu__init_cpu(void); extern void fpu__init_cpu(void);
...@@ -129,9 +130,6 @@ static inline void fpstate_init_soft(struct swregs_state *soft) {} ...@@ -129,9 +130,6 @@ static inline void fpstate_init_soft(struct swregs_state *soft) {}
/* State tracking */ /* State tracking */
DECLARE_PER_CPU(struct fpu *, fpu_fpregs_owner_ctx); DECLARE_PER_CPU(struct fpu *, fpu_fpregs_owner_ctx);
/* fpstate */
extern union fpregs_state init_fpstate;
/* fpstate-related functions which are exported to KVM */ /* fpstate-related functions which are exported to KVM */
extern void fpu_init_fpstate_user(struct fpu *fpu); extern void fpu_init_fpstate_user(struct fpu *fpu);
......
...@@ -155,6 +155,11 @@ void restore_fpregs_from_fpstate(union fpregs_state *fpstate, u64 mask) ...@@ -155,6 +155,11 @@ void restore_fpregs_from_fpstate(union fpregs_state *fpstate, u64 mask)
} }
} }
void fpu_reset_from_exception_fixup(void)
{
restore_fpregs_from_fpstate(&init_fpstate, xfeatures_mask_fpstate());
}
#if IS_ENABLED(CONFIG_KVM) #if IS_ENABLED(CONFIG_KVM)
void fpu_swap_kvm_fpu(struct fpu *save, struct fpu *rstor, u64 restore_mask) void fpu_swap_kvm_fpu(struct fpu *save, struct fpu *rstor, u64 restore_mask)
{ {
......
...@@ -2,6 +2,8 @@ ...@@ -2,6 +2,8 @@
#ifndef __X86_KERNEL_FPU_INTERNAL_H #ifndef __X86_KERNEL_FPU_INTERNAL_H
#define __X86_KERNEL_FPU_INTERNAL_H #define __X86_KERNEL_FPU_INTERNAL_H
extern union fpregs_state init_fpstate;
/* CPU feature check wrappers */ /* CPU feature check wrappers */
static __always_inline __pure bool use_xsave(void) static __always_inline __pure bool use_xsave(void)
{ {
......
...@@ -4,8 +4,7 @@ ...@@ -4,8 +4,7 @@
#include <linux/sched/debug.h> #include <linux/sched/debug.h>
#include <xen/xen.h> #include <xen/xen.h>
#include <asm/fpu/signal.h> #include <asm/fpu/api.h>
#include <asm/fpu/xstate.h>
#include <asm/sev.h> #include <asm/sev.h>
#include <asm/traps.h> #include <asm/traps.h>
#include <asm/kdebug.h> #include <asm/kdebug.h>
...@@ -48,7 +47,7 @@ static bool ex_handler_fprestore(const struct exception_table_entry *fixup, ...@@ -48,7 +47,7 @@ static bool ex_handler_fprestore(const struct exception_table_entry *fixup,
WARN_ONCE(1, "Bad FPU state detected at %pB, reinitializing FPU registers.", WARN_ONCE(1, "Bad FPU state detected at %pB, reinitializing FPU registers.",
(void *)instruction_pointer(regs)); (void *)instruction_pointer(regs));
restore_fpregs_from_fpstate(&init_fpstate, xfeatures_mask_fpstate()); fpu_reset_from_exception_fixup();
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