 89f883372f
			
		
	
	
	89f883372f
	
	
	
		
			
			Pull KVM updates from Marcelo Tosatti: "KVM updates for the 3.9 merge window, including x86 real mode emulation fixes, stronger memory slot interface restrictions, mmu_lock spinlock hold time reduction, improved handling of large page faults on shadow, initial APICv HW acceleration support, s390 channel IO based virtio, amongst others" * tag 'kvm-3.9-1' of git://git.kernel.org/pub/scm/virt/kvm/kvm: (143 commits) Revert "KVM: MMU: lazily drop large spte" x86: pvclock kvm: align allocation size to page size KVM: nVMX: Remove redundant get_vmcs12 from nested_vmx_exit_handled_msr x86 emulator: fix parity calculation for AAD instruction KVM: PPC: BookE: Handle alignment interrupts booke: Added DBCR4 SPR number KVM: PPC: booke: Allow multiple exception types KVM: PPC: booke: use vcpu reference from thread_struct KVM: Remove user_alloc from struct kvm_memory_slot KVM: VMX: disable apicv by default KVM: s390: Fix handling of iscs. KVM: MMU: cleanup __direct_map KVM: MMU: remove pt_access in mmu_set_spte KVM: MMU: cleanup mapping-level KVM: MMU: lazily drop large spte KVM: VMX: cleanup vmx_set_cr0(). KVM: VMX: add missing exit names to VMX_EXIT_REASONS array KVM: VMX: disable SMEP feature when guest is in non-paging mode KVM: Remove duplicate text in api.txt Revert "KVM: MMU: split kvm_mmu_free_page" ...
		
			
				
	
	
		
			136 lines
		
	
	
	
		
			3.2 KiB
			
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			136 lines
		
	
	
	
		
			3.2 KiB
			
		
	
	
	
		
			C
		
	
	
	
	
	
| #ifndef _ASM_X86_KVM_PARA_H
 | |
| #define _ASM_X86_KVM_PARA_H
 | |
| 
 | |
| #include <asm/processor.h>
 | |
| #include <uapi/asm/kvm_para.h>
 | |
| 
 | |
| extern void kvmclock_init(void);
 | |
| extern int kvm_register_clock(char *txt);
 | |
| 
 | |
| #ifdef CONFIG_KVM_GUEST
 | |
| bool kvm_check_and_clear_guest_paused(void);
 | |
| #else
 | |
| static inline bool kvm_check_and_clear_guest_paused(void)
 | |
| {
 | |
| 	return false;
 | |
| }
 | |
| #endif /* CONFIG_KVM_GUEST */
 | |
| 
 | |
| /* This instruction is vmcall.  On non-VT architectures, it will generate a
 | |
|  * trap that we will then rewrite to the appropriate instruction.
 | |
|  */
 | |
| #define KVM_HYPERCALL ".byte 0x0f,0x01,0xc1"
 | |
| 
 | |
| /* For KVM hypercalls, a three-byte sequence of either the vmcall or the vmmcall
 | |
|  * instruction.  The hypervisor may replace it with something else but only the
 | |
|  * instructions are guaranteed to be supported.
 | |
|  *
 | |
|  * Up to four arguments may be passed in rbx, rcx, rdx, and rsi respectively.
 | |
|  * The hypercall number should be placed in rax and the return value will be
 | |
|  * placed in rax.  No other registers will be clobbered unless explicitly
 | |
|  * noted by the particular hypercall.
 | |
|  */
 | |
| 
 | |
| static inline long kvm_hypercall0(unsigned int nr)
 | |
| {
 | |
| 	long ret;
 | |
| 	asm volatile(KVM_HYPERCALL
 | |
| 		     : "=a"(ret)
 | |
| 		     : "a"(nr)
 | |
| 		     : "memory");
 | |
| 	return ret;
 | |
| }
 | |
| 
 | |
| static inline long kvm_hypercall1(unsigned int nr, unsigned long p1)
 | |
| {
 | |
| 	long ret;
 | |
| 	asm volatile(KVM_HYPERCALL
 | |
| 		     : "=a"(ret)
 | |
| 		     : "a"(nr), "b"(p1)
 | |
| 		     : "memory");
 | |
| 	return ret;
 | |
| }
 | |
| 
 | |
| static inline long kvm_hypercall2(unsigned int nr, unsigned long p1,
 | |
| 				  unsigned long p2)
 | |
| {
 | |
| 	long ret;
 | |
| 	asm volatile(KVM_HYPERCALL
 | |
| 		     : "=a"(ret)
 | |
| 		     : "a"(nr), "b"(p1), "c"(p2)
 | |
| 		     : "memory");
 | |
| 	return ret;
 | |
| }
 | |
| 
 | |
| static inline long kvm_hypercall3(unsigned int nr, unsigned long p1,
 | |
| 				  unsigned long p2, unsigned long p3)
 | |
| {
 | |
| 	long ret;
 | |
| 	asm volatile(KVM_HYPERCALL
 | |
| 		     : "=a"(ret)
 | |
| 		     : "a"(nr), "b"(p1), "c"(p2), "d"(p3)
 | |
| 		     : "memory");
 | |
| 	return ret;
 | |
| }
 | |
| 
 | |
| static inline long kvm_hypercall4(unsigned int nr, unsigned long p1,
 | |
| 				  unsigned long p2, unsigned long p3,
 | |
| 				  unsigned long p4)
 | |
| {
 | |
| 	long ret;
 | |
| 	asm volatile(KVM_HYPERCALL
 | |
| 		     : "=a"(ret)
 | |
| 		     : "a"(nr), "b"(p1), "c"(p2), "d"(p3), "S"(p4)
 | |
| 		     : "memory");
 | |
| 	return ret;
 | |
| }
 | |
| 
 | |
| static inline bool kvm_para_available(void)
 | |
| {
 | |
| 	unsigned int eax, ebx, ecx, edx;
 | |
| 	char signature[13];
 | |
| 
 | |
| 	if (boot_cpu_data.cpuid_level < 0)
 | |
| 		return false;	/* So we don't blow up on old processors */
 | |
| 
 | |
| 	if (cpu_has_hypervisor) {
 | |
| 		cpuid(KVM_CPUID_SIGNATURE, &eax, &ebx, &ecx, &edx);
 | |
| 		memcpy(signature + 0, &ebx, 4);
 | |
| 		memcpy(signature + 4, &ecx, 4);
 | |
| 		memcpy(signature + 8, &edx, 4);
 | |
| 		signature[12] = 0;
 | |
| 
 | |
| 		if (strcmp(signature, "KVMKVMKVM") == 0)
 | |
| 			return true;
 | |
| 	}
 | |
| 
 | |
| 	return false;
 | |
| }
 | |
| 
 | |
| static inline unsigned int kvm_arch_para_features(void)
 | |
| {
 | |
| 	return cpuid_eax(KVM_CPUID_FEATURES);
 | |
| }
 | |
| 
 | |
| #ifdef CONFIG_KVM_GUEST
 | |
| void __init kvm_guest_init(void);
 | |
| void kvm_async_pf_task_wait(u32 token);
 | |
| void kvm_async_pf_task_wake(u32 token);
 | |
| u32 kvm_read_and_reset_pf_reason(void);
 | |
| extern void kvm_disable_steal_time(void);
 | |
| #else
 | |
| #define kvm_guest_init() do { } while (0)
 | |
| #define kvm_async_pf_task_wait(T) do {} while(0)
 | |
| #define kvm_async_pf_task_wake(T) do {} while(0)
 | |
| static inline u32 kvm_read_and_reset_pf_reason(void)
 | |
| {
 | |
| 	return 0;
 | |
| }
 | |
| 
 | |
| static inline void kvm_disable_steal_time(void)
 | |
| {
 | |
| 	return;
 | |
| }
 | |
| #endif
 | |
| 
 | |
| #endif /* _ASM_X86_KVM_PARA_H */
 |