mirror of
				git://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git
				synced 2025-09-04 20:19:47 +08:00 
			
		
		
		
	 b7a584598a
			
		
	
	
		b7a584598a
		
	
	
	
	
		
			
			On Xen PV, regs->flags doesn't reliably reflect IOPL and the exit-to-userspace code doesn't change IOPL. We need to context switch it manually. I'm doing this without going through paravirt because this is specific to Xen PV. After the dust settles, we can merge this with the 32-bit code, tidy up the iopl syscall implementation, and remove the set_iopl pvop entirely. Fixes XSA-171. Reviewewd-by: Jan Beulich <JBeulich@suse.com> Signed-off-by: Andy Lutomirski <luto@kernel.org> Cc: Andrew Cooper <andrew.cooper3@citrix.com> Cc: Andy Lutomirski <luto@amacapital.net> Cc: Boris Ostrovsky <boris.ostrovsky@oracle.com> Cc: Borislav Petkov <bp@alien8.de> Cc: Brian Gerst <brgerst@gmail.com> Cc: David Vrabel <david.vrabel@citrix.com> Cc: Denys Vlasenko <dvlasenk@redhat.com> Cc: H. Peter Anvin <hpa@zytor.com> Cc: Jan Beulich <JBeulich@suse.com> Cc: Linus Torvalds <torvalds@linux-foundation.org> Cc: Peter Zijlstra <peterz@infradead.org> Cc: Thomas Gleixner <tglx@linutronix.de> Cc: stable@vger.kernel.org Link: http://lkml.kernel.org/r/693c3bd7aeb4d3c27c92c622b7d0f554a458173c.1458162709.git.luto@kernel.org Signed-off-by: Ingo Molnar <mingo@kernel.org>
		
			
				
	
	
		
			68 lines
		
	
	
		
			2.2 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			68 lines
		
	
	
		
			2.2 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
| /******************************************************************************
 | |
|  * hypervisor.h
 | |
|  *
 | |
|  * Linux-specific hypervisor handling.
 | |
|  *
 | |
|  * Copyright (c) 2002-2004, K A Fraser
 | |
|  *
 | |
|  * This program is free software; you can redistribute it and/or
 | |
|  * modify it under the terms of the GNU General Public License version 2
 | |
|  * as published by the Free Software Foundation; or, when distributed
 | |
|  * separately from the Linux kernel or incorporated into other
 | |
|  * software packages, subject to the following license:
 | |
|  *
 | |
|  * Permission is hereby granted, free of charge, to any person obtaining a copy
 | |
|  * of this source file (the "Software"), to deal in the Software without
 | |
|  * restriction, including without limitation the rights to use, copy, modify,
 | |
|  * merge, publish, distribute, sublicense, and/or sell copies of the Software,
 | |
|  * and to permit persons to whom the Software is furnished to do so, subject to
 | |
|  * the following conditions:
 | |
|  *
 | |
|  * The above copyright notice and this permission notice shall be included in
 | |
|  * all copies or substantial portions of the Software.
 | |
|  *
 | |
|  * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
 | |
|  * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
 | |
|  * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
 | |
|  * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
 | |
|  * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
 | |
|  * FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS
 | |
|  * IN THE SOFTWARE.
 | |
|  */
 | |
| 
 | |
| #ifndef _ASM_X86_XEN_HYPERVISOR_H
 | |
| #define _ASM_X86_XEN_HYPERVISOR_H
 | |
| 
 | |
| extern struct shared_info *HYPERVISOR_shared_info;
 | |
| extern struct start_info *xen_start_info;
 | |
| 
 | |
| #include <asm/processor.h>
 | |
| 
 | |
| static inline uint32_t xen_cpuid_base(void)
 | |
| {
 | |
| 	return hypervisor_cpuid_base("XenVMMXenVMM", 2);
 | |
| }
 | |
| 
 | |
| #ifdef CONFIG_XEN
 | |
| extern bool xen_hvm_need_lapic(void);
 | |
| 
 | |
| static inline bool xen_x2apic_para_available(void)
 | |
| {
 | |
| 	return xen_hvm_need_lapic();
 | |
| }
 | |
| #else
 | |
| static inline bool xen_x2apic_para_available(void)
 | |
| {
 | |
| 	return (xen_cpuid_base() != 0);
 | |
| }
 | |
| #endif
 | |
| 
 | |
| #ifdef CONFIG_HOTPLUG_CPU
 | |
| void xen_arch_register_cpu(int num);
 | |
| void xen_arch_unregister_cpu(int num);
 | |
| #endif
 | |
| 
 | |
| extern void xen_set_iopl_mask(unsigned mask);
 | |
| 
 | |
| #endif /* _ASM_X86_XEN_HYPERVISOR_H */
 |