diff options
Diffstat (limited to 'arch/x86/kernel/cpu/common.c')
-rw-r--r-- | arch/x86/kernel/cpu/common.c | 33 |
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 */ | ||
959 | static 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 | ||
972 | void 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 | ||
958 | void __init identify_boot_cpu(void) | 991 | void __init identify_boot_cpu(void) |