aboutsummaryrefslogtreecommitdiffstats
path: root/include/asm-x86/processor.h
diff options
context:
space:
mode:
authorGlauber de Oliveira Costa <gcosta@redhat.com>2008-01-30 07:31:31 -0500
committerIngo Molnar <mingo@elte.hu>2008-01-30 07:31:31 -0500
commit7818a1e0294debee02d5135e17b89f28b8871887 (patch)
tree251473910cddc3c2889407cde8f6f962dc14e88f /include/asm-x86/processor.h
parentca241c75037b32e0216a68e39ad2801d04fa1f87 (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.h22
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
196static 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
223static 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