Commit c42103b2 authored by Ingo Molnar's avatar Ingo Molnar

x86/fpu: Remove xsave_init()

Expand fpu__init_system_xstate() and fpu__init_cpu_xstate() calls
into xsave_init() calls.

(This will allow us to call the proper versions in higher level FPU init code
later on.)

No change in functionality.
Reviewed-by: default avatarBorislav Petkov <bp@alien8.de>
Cc: Andy Lutomirski <luto@amacapital.net>
Cc: Dave Hansen <dave.hansen@linux.intel.com>
Cc: Fenghua Yu <fenghua.yu@intel.com>
Cc: H. Peter Anvin <hpa@zytor.com>
Cc: Linus Torvalds <torvalds@linux-foundation.org>
Cc: Oleg Nesterov <oleg@redhat.com>
Cc: Peter Zijlstra <peterz@infradead.org>
Cc: Thomas Gleixner <tglx@linutronix.de>
Signed-off-by: default avatarIngo Molnar <mingo@kernel.org>
parent 62db6871
...@@ -52,7 +52,6 @@ extern u64 xfeatures_mask; ...@@ -52,7 +52,6 @@ extern u64 xfeatures_mask;
extern u64 xstate_fx_sw_bytes[USER_XSTATE_FX_SW_WORDS]; extern u64 xstate_fx_sw_bytes[USER_XSTATE_FX_SW_WORDS];
extern struct xsave_struct init_xstate_ctx; extern struct xsave_struct init_xstate_ctx;
extern void xsave_init(void);
extern void update_regset_xstate_info(unsigned int size, u64 xstate_mask); extern void update_regset_xstate_info(unsigned int size, u64 xstate_mask);
/* These macros all use (%edi)/(%rdi) as the single memory argument. */ /* These macros all use (%edi)/(%rdi) as the single memory argument. */
......
...@@ -98,7 +98,7 @@ static void fpstate_xstate_init_size(void) ...@@ -98,7 +98,7 @@ static void fpstate_xstate_init_size(void)
{ {
/* /*
* Note that xstate_size might be overwriten later during * Note that xstate_size might be overwriten later during
* xsave_init(). * fpu__init_system_xstate().
*/ */
if (!cpu_has_fpu) { if (!cpu_has_fpu) {
...@@ -146,7 +146,8 @@ void fpu__init_cpu(void) ...@@ -146,7 +146,8 @@ void fpu__init_cpu(void)
cr0 |= X86_CR0_EM; cr0 |= X86_CR0_EM;
write_cr0(cr0); write_cr0(cr0);
xsave_init(); fpu__init_system_xstate();
fpu__init_cpu_xstate();
} }
/* /*
...@@ -159,7 +160,8 @@ void fpu__init_system(void) ...@@ -159,7 +160,8 @@ void fpu__init_system(void)
fpu__init_cpu(); fpu__init_cpu();
mxcsr_feature_mask_init(); mxcsr_feature_mask_init();
xsave_init(); fpu__init_system_xstate();
fpu__init_cpu_xstate();
eager_fpu_init(); eager_fpu_init();
} }
......
...@@ -646,8 +646,7 @@ static void __init init_xstate_size(void) ...@@ -646,8 +646,7 @@ static void __init init_xstate_size(void)
* Enable and initialize the xsave feature. * Enable and initialize the xsave feature.
* Called once per system bootup. * Called once per system bootup.
* *
* ( Not marked __init because of false positive section warnings * ( Not marked __init because of false positive section warnings. )
* generated by xsave_init(). )
*/ */
void fpu__init_system_xstate(void) void fpu__init_system_xstate(void)
{ {
...@@ -713,16 +712,6 @@ void fpu__init_system_xstate(void) ...@@ -713,16 +712,6 @@ void fpu__init_system_xstate(void)
cpu_has_xsaves ? "compacted" : "standard"); cpu_has_xsaves ? "compacted" : "standard");
} }
/*
* For the very first instance, this calls fpu__init_system_xstate();
* for all subsequent instances, this calls fpu__init_cpu_xstate().
*/
void xsave_init(void)
{
fpu__init_system_xstate();
fpu__init_cpu_xstate();
}
/* /*
* setup_init_fpu_buf() is __init and it is OK to call it here because * setup_init_fpu_buf() is __init and it is OK to call it here because
* init_xstate_ctx will be unset only once during boot. * init_xstate_ctx will be unset only once during boot.
......
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