diff options
author | Glauber de Oliveira Costa <gcosta@redhat.com> | 2008-01-30 07:31:31 -0500 |
---|---|---|
committer | Ingo Molnar <mingo@elte.hu> | 2008-01-30 07:31:31 -0500 |
commit | 7818a1e0294debee02d5135e17b89f28b8871887 (patch) | |
tree | 251473910cddc3c2889407cde8f6f962dc14e88f /include/asm-x86/processor.h | |
parent | ca241c75037b32e0216a68e39ad2801d04fa1f87 (diff) |
x86: provide 64-bit with a load_sp0 function.
Paravirt guests need to inform the underlying hypervisor whenever the sp0
tss field changes. i386 already has such a function, and we use it for
x86_64 too. There's an unnecessary (for 64-bit) msr handling part in the original
version, and it is placed around an ifdef. Making no more sense in
processor_32.h, it is moved to the common header
Signed-off-by: Glauber de Oliveira Costa <gcosta@redhat.com>
Signed-off-by: Ingo Molnar <mingo@elte.hu>
Signed-off-by: Thomas Gleixner <tglx@linutronix.de>
Diffstat (limited to 'include/asm-x86/processor.h')
-rw-r--r-- | include/asm-x86/processor.h | 22 |
1 files changed, 21 insertions, 1 deletions
diff --git a/include/asm-x86/processor.h b/include/asm-x86/processor.h index cede9ad3dc6e..b1ea52156362 100644 --- a/include/asm-x86/processor.h +++ b/include/asm-x86/processor.h | |||
@@ -193,8 +193,22 @@ static inline void native_set_iopl_mask(unsigned mask) | |||
193 | #endif | 193 | #endif |
194 | } | 194 | } |
195 | 195 | ||
196 | static inline void native_load_sp0(struct tss_struct *tss, | ||
197 | struct thread_struct *thread) | ||
198 | { | ||
199 | tss->x86_tss.sp0 = thread->sp0; | ||
200 | #ifdef CONFIG_X86_32 | ||
201 | /* Only happens when SEP is enabled, no need to test "SEP"arately */ | ||
202 | if (unlikely(tss->x86_tss.ss1 != thread->sysenter_cs)) { | ||
203 | tss->x86_tss.ss1 = thread->sysenter_cs; | ||
204 | wrmsr(MSR_IA32_SYSENTER_CS, thread->sysenter_cs, 0); | ||
205 | } | ||
206 | #endif | ||
207 | } | ||
196 | 208 | ||
197 | #ifndef CONFIG_PARAVIRT | 209 | #ifdef CONFIG_PARAVIRT |
210 | #include <asm/paravirt.h> | ||
211 | #else | ||
198 | #define __cpuid native_cpuid | 212 | #define __cpuid native_cpuid |
199 | #define paravirt_enabled() 0 | 213 | #define paravirt_enabled() 0 |
200 | 214 | ||
@@ -206,6 +220,12 @@ static inline void native_set_iopl_mask(unsigned mask) | |||
206 | #define set_debugreg(value, register) \ | 220 | #define set_debugreg(value, register) \ |
207 | native_set_debugreg(register, value) | 221 | native_set_debugreg(register, value) |
208 | 222 | ||
223 | static inline void load_sp0(struct tss_struct *tss, | ||
224 | struct thread_struct *thread) | ||
225 | { | ||
226 | native_load_sp0(tss, thread); | ||
227 | } | ||
228 | |||
209 | #define set_iopl_mask native_set_iopl_mask | 229 | #define set_iopl_mask native_set_iopl_mask |
210 | #endif /* CONFIG_PARAVIRT */ | 230 | #endif /* CONFIG_PARAVIRT */ |
211 | 231 | ||