提交 970156da 编写于 作者: C Chang S. Bae 提交者: Lin Wang

x86/fpu: Calculate the default sizes independently

mainline inclusion
from mainline-v5.16-rc1
commit 2ae996e0
category: feature
bugzilla: https://gitee.com/openeuler/intel-kernel/issues/I590ZC
CVE: NA

Intel-SIG: commit 2ae996e0 x86/fpu: Calculate the default sizes independently.

--------------------------------

When dynamically enabled states are supported the maximum and default sizes
for the kernel buffers and user space interfaces are not longer identical.

Put the necessary calculations in place which only take the default enabled
features into account.
Signed-off-by: NChang S. Bae <chang.seok.bae@intel.com>
Signed-off-by: NThomas Gleixner <tglx@linutronix.de>
Signed-off-by: NBorislav Petkov <bp@suse.de>
Link: https://lore.kernel.org/r/20211021225527.10184-22-chang.seok.bae@intel.comSigned-off-by: NLin Wang <lin.x.wang@intel.com>
上级 af5963c9
...@@ -781,35 +781,40 @@ static bool __init is_supported_xstate_size(unsigned int test_xstate_size) ...@@ -781,35 +781,40 @@ static bool __init is_supported_xstate_size(unsigned int test_xstate_size)
static int __init init_xstate_size(void) static int __init init_xstate_size(void)
{ {
/* Recompute the context size for enabled features: */ /* Recompute the context size for enabled features: */
unsigned int user_size, kernel_size; unsigned int user_size, kernel_size, kernel_default_size;
bool compacted = cpu_feature_enabled(X86_FEATURE_XSAVES);
/* Uncompacted user space size */ /* Uncompacted user space size */
user_size = get_xsave_size_user(); user_size = get_xsave_size_user();
/* /*
* XSAVES kernel size includes supervisor states and * XSAVES kernel size includes supervisor states and
* uses compacted format. * uses compacted format when available.
* *
* XSAVE does not support supervisor states so * XSAVE does not support supervisor states so
* kernel and user size is identical. * kernel and user size is identical.
*/ */
if (cpu_feature_enabled(X86_FEATURE_XSAVES)) if (compacted)
kernel_size = get_xsaves_size_no_independent(); kernel_size = get_xsaves_size_no_independent();
else else
kernel_size = user_size; kernel_size = user_size;
/* Ensure we have the space to store all enabled features. */ kernel_default_size =
if (!is_supported_xstate_size(kernel_size)) xstate_calculate_size(fpu_kernel_cfg.default_features, compacted);
/* Ensure we have the space to store all default enabled features. */
if (!is_supported_xstate_size(kernel_default_size))
return -EINVAL; return -EINVAL;
if (!paranoid_xstate_size_valid(kernel_size)) if (!paranoid_xstate_size_valid(kernel_size))
return -EINVAL; return -EINVAL;
/* Keep it the same for now */
fpu_kernel_cfg.max_size = kernel_size; fpu_kernel_cfg.max_size = kernel_size;
fpu_kernel_cfg.default_size = kernel_size;
fpu_user_cfg.max_size = user_size; fpu_user_cfg.max_size = user_size;
fpu_user_cfg.default_size = user_size;
fpu_kernel_cfg.default_size = kernel_default_size;
fpu_user_cfg.default_size =
xstate_calculate_size(fpu_user_cfg.default_features, false);
return 0; return 0;
} }
...@@ -894,15 +899,21 @@ void __init fpu__init_system_xstate(unsigned int legacy_size) ...@@ -894,15 +899,21 @@ void __init fpu__init_system_xstate(unsigned int legacy_size)
fpu_kernel_cfg.max_features &= ~BIT_ULL(i); fpu_kernel_cfg.max_features &= ~BIT_ULL(i);
} }
if (!cpu_feature_enabled(X86_FEATURE_XFD))
fpu_kernel_cfg.max_features &= ~XFEATURE_MASK_USER_DYNAMIC;
fpu_kernel_cfg.max_features &= XFEATURE_MASK_USER_SUPPORTED | fpu_kernel_cfg.max_features &= XFEATURE_MASK_USER_SUPPORTED |
XFEATURE_MASK_SUPERVISOR_SUPPORTED; XFEATURE_MASK_SUPERVISOR_SUPPORTED;
fpu_user_cfg.max_features = fpu_kernel_cfg.max_features; fpu_user_cfg.max_features = fpu_kernel_cfg.max_features;
fpu_user_cfg.max_features &= XFEATURE_MASK_USER_SUPPORTED; fpu_user_cfg.max_features &= XFEATURE_MASK_USER_SUPPORTED;
/* Identical for now */ /* Clean out dynamic features from default */
fpu_kernel_cfg.default_features = fpu_kernel_cfg.max_features; fpu_kernel_cfg.default_features = fpu_kernel_cfg.max_features;
fpu_kernel_cfg.default_features &= ~XFEATURE_MASK_USER_DYNAMIC;
fpu_user_cfg.default_features = fpu_user_cfg.max_features; fpu_user_cfg.default_features = fpu_user_cfg.max_features;
fpu_user_cfg.default_features &= ~XFEATURE_MASK_USER_DYNAMIC;
/* Store it for paranoia check at the end */ /* Store it for paranoia check at the end */
xfeatures = fpu_kernel_cfg.max_features; xfeatures = fpu_kernel_cfg.max_features;
...@@ -913,6 +924,7 @@ void __init fpu__init_system_xstate(unsigned int legacy_size) ...@@ -913,6 +924,7 @@ void __init fpu__init_system_xstate(unsigned int legacy_size)
if (err) if (err)
goto out_disable; goto out_disable;
/* Reset the state for the current task */
fpstate_reset(&current->thread.fpu); fpstate_reset(&current->thread.fpu);
/* /*
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册