aboutsummaryrefslogtreecommitdiffstats
path: root/arch/x86/kernel/cpu/common.c
diff options
context:
space:
mode:
Diffstat (limited to 'arch/x86/kernel/cpu/common.c')
-rw-r--r--arch/x86/kernel/cpu/common.c33
1 files changed, 33 insertions, 0 deletions
diff --git a/arch/x86/kernel/cpu/common.c b/arch/x86/kernel/cpu/common.c
index a135239badb7..2cbbf88d8f2c 100644
--- a/arch/x86/kernel/cpu/common.c
+++ b/arch/x86/kernel/cpu/common.c
@@ -20,6 +20,7 @@
20#include <asm/processor.h> 20#include <asm/processor.h>
21#include <asm/debugreg.h> 21#include <asm/debugreg.h>
22#include <asm/sections.h> 22#include <asm/sections.h>
23#include <asm/vsyscall.h>
23#include <linux/topology.h> 24#include <linux/topology.h>
24#include <linux/cpumask.h> 25#include <linux/cpumask.h>
25#include <asm/pgtable.h> 26#include <asm/pgtable.h>
@@ -953,6 +954,38 @@ static void vgetcpu_set_mode(void)
953 else 954 else
954 vgetcpu_mode = VGETCPU_LSL; 955 vgetcpu_mode = VGETCPU_LSL;
955} 956}
957
958/* May not be __init: called during resume */
959static void syscall32_cpu_init(void)
960{
961 /* Load these always in case some future AMD CPU supports
962 SYSENTER from compat mode too. */
963 wrmsrl_safe(MSR_IA32_SYSENTER_CS, (u64)__KERNEL_CS);
964 wrmsrl_safe(MSR_IA32_SYSENTER_ESP, 0ULL);
965 wrmsrl_safe(MSR_IA32_SYSENTER_EIP, (u64)ia32_sysenter_target);
966
967 wrmsrl(MSR_CSTAR, ia32_cstar_target);
968}
969#endif
970
971#ifdef CONFIG_X86_32
972void enable_sep_cpu(void)
973{
974 int cpu = get_cpu();
975 struct tss_struct *tss = &per_cpu(init_tss, cpu);
976
977 if (!boot_cpu_has(X86_FEATURE_SEP)) {
978 put_cpu();
979 return;
980 }
981
982 tss->x86_tss.ss1 = __KERNEL_CS;
983 tss->x86_tss.sp1 = sizeof(struct tss_struct) + (unsigned long) tss;
984 wrmsr(MSR_IA32_SYSENTER_CS, __KERNEL_CS, 0);
985 wrmsr(MSR_IA32_SYSENTER_ESP, tss->x86_tss.sp1, 0);
986 wrmsr(MSR_IA32_SYSENTER_EIP, (unsigned long) ia32_sysenter_target, 0);
987 put_cpu();
988}
956#endif 989#endif
957 990
958void __init identify_boot_cpu(void) 991void __init identify_boot_cpu(void)