diff options
| author | Linus Torvalds <torvalds@linux-foundation.org> | 2008-11-12 13:38:42 -0500 |
|---|---|---|
| committer | Linus Torvalds <torvalds@linux-foundation.org> | 2008-11-12 13:38:42 -0500 |
| commit | 5d2007ebc278525cbe8d2e3ef559a4b191ee4ded (patch) | |
| tree | 04287151da2ecbd8055703d34b0b572709651137 | |
| parent | 1c1271850494f06b63ae6b485e2e1b9c27ffb2d1 (diff) | |
| parent | e17d1dc0863767bab8fde4ba9be92c7f79e7fe50 (diff) | |
Merge branch 'kvm-updates/2.6.28' of git://git.kernel.org/pub/scm/linux/kernel/git/avi/kvm
* 'kvm-updates/2.6.28' of git://git.kernel.org/pub/scm/linux/kernel/git/avi/kvm:
KVM: Fix pit memory leak if unable to allocate irq source id
KVM: ia64: fix vmm_spin_{un}lock for !CONFIG_SMP
KVM: VMX: Set IGMT bit in EPT entry
KVM: Require the PCI subsystem
x86: KVM guest: fix section mismatch warning in kvmclock.c
KVM: ia64: Use guest signal mask when blocking
KVM: MMU: increase per-vcpu rmap cache alloc size
| -rw-r--r-- | arch/ia64/kvm/Kconfig | 2 | ||||
| -rw-r--r-- | arch/ia64/kvm/kvm-ia64.c | 12 | ||||
| -rw-r--r-- | arch/ia64/kvm/vcpu.h | 5 | ||||
| -rw-r--r-- | arch/x86/kernel/kvmclock.c | 2 | ||||
| -rw-r--r-- | arch/x86/kvm/Kconfig | 2 | ||||
| -rw-r--r-- | arch/x86/kvm/i8254.c | 4 | ||||
| -rw-r--r-- | arch/x86/kvm/mmu.c | 2 | ||||
| -rw-r--r-- | arch/x86/kvm/vmx.c | 3 | ||||
| -rw-r--r-- | arch/x86/kvm/vmx.h | 1 |
9 files changed, 23 insertions, 10 deletions
diff --git a/arch/ia64/kvm/Kconfig b/arch/ia64/kvm/Kconfig index 8e99fed6b3fd..f833a0b4188d 100644 --- a/arch/ia64/kvm/Kconfig +++ b/arch/ia64/kvm/Kconfig | |||
| @@ -20,6 +20,8 @@ if VIRTUALIZATION | |||
| 20 | config KVM | 20 | config KVM |
| 21 | tristate "Kernel-based Virtual Machine (KVM) support" | 21 | tristate "Kernel-based Virtual Machine (KVM) support" |
| 22 | depends on HAVE_KVM && EXPERIMENTAL | 22 | depends on HAVE_KVM && EXPERIMENTAL |
| 23 | # for device assignment: | ||
| 24 | depends on PCI | ||
| 23 | select PREEMPT_NOTIFIERS | 25 | select PREEMPT_NOTIFIERS |
| 24 | select ANON_INODES | 26 | select ANON_INODES |
| 25 | ---help--- | 27 | ---help--- |
diff --git a/arch/ia64/kvm/kvm-ia64.c b/arch/ia64/kvm/kvm-ia64.c index 3caac477de9e..af1464f7a6ad 100644 --- a/arch/ia64/kvm/kvm-ia64.c +++ b/arch/ia64/kvm/kvm-ia64.c | |||
| @@ -673,16 +673,16 @@ int kvm_arch_vcpu_ioctl_run(struct kvm_vcpu *vcpu, struct kvm_run *kvm_run) | |||
| 673 | 673 | ||
| 674 | vcpu_load(vcpu); | 674 | vcpu_load(vcpu); |
| 675 | 675 | ||
| 676 | if (vcpu->sigset_active) | ||
| 677 | sigprocmask(SIG_SETMASK, &vcpu->sigset, &sigsaved); | ||
| 678 | |||
| 676 | if (unlikely(vcpu->arch.mp_state == KVM_MP_STATE_UNINITIALIZED)) { | 679 | if (unlikely(vcpu->arch.mp_state == KVM_MP_STATE_UNINITIALIZED)) { |
| 677 | kvm_vcpu_block(vcpu); | 680 | kvm_vcpu_block(vcpu); |
| 678 | clear_bit(KVM_REQ_UNHALT, &vcpu->requests); | 681 | clear_bit(KVM_REQ_UNHALT, &vcpu->requests); |
| 679 | vcpu_put(vcpu); | 682 | r = -EAGAIN; |
| 680 | return -EAGAIN; | 683 | goto out; |
| 681 | } | 684 | } |
| 682 | 685 | ||
| 683 | if (vcpu->sigset_active) | ||
| 684 | sigprocmask(SIG_SETMASK, &vcpu->sigset, &sigsaved); | ||
| 685 | |||
| 686 | if (vcpu->mmio_needed) { | 686 | if (vcpu->mmio_needed) { |
| 687 | memcpy(vcpu->mmio_data, kvm_run->mmio.data, 8); | 687 | memcpy(vcpu->mmio_data, kvm_run->mmio.data, 8); |
| 688 | kvm_set_mmio_data(vcpu); | 688 | kvm_set_mmio_data(vcpu); |
| @@ -690,7 +690,7 @@ int kvm_arch_vcpu_ioctl_run(struct kvm_vcpu *vcpu, struct kvm_run *kvm_run) | |||
| 690 | vcpu->mmio_needed = 0; | 690 | vcpu->mmio_needed = 0; |
| 691 | } | 691 | } |
| 692 | r = __vcpu_run(vcpu, kvm_run); | 692 | r = __vcpu_run(vcpu, kvm_run); |
| 693 | 693 | out: | |
| 694 | if (vcpu->sigset_active) | 694 | if (vcpu->sigset_active) |
| 695 | sigprocmask(SIG_SETMASK, &sigsaved, NULL); | 695 | sigprocmask(SIG_SETMASK, &sigsaved, NULL); |
| 696 | 696 | ||
diff --git a/arch/ia64/kvm/vcpu.h b/arch/ia64/kvm/vcpu.h index 341e3fee280c..e9b2a4e121c0 100644 --- a/arch/ia64/kvm/vcpu.h +++ b/arch/ia64/kvm/vcpu.h | |||
| @@ -384,6 +384,10 @@ static inline u64 __gpfn_is_io(u64 gpfn) | |||
| 384 | #define MODE_IND(psr) \ | 384 | #define MODE_IND(psr) \ |
| 385 | (((psr).it << 2) + ((psr).dt << 1) + (psr).rt) | 385 | (((psr).it << 2) + ((psr).dt << 1) + (psr).rt) |
| 386 | 386 | ||
| 387 | #ifndef CONFIG_SMP | ||
| 388 | #define _vmm_raw_spin_lock(x) do {}while(0) | ||
| 389 | #define _vmm_raw_spin_unlock(x) do {}while(0) | ||
| 390 | #else | ||
| 387 | #define _vmm_raw_spin_lock(x) \ | 391 | #define _vmm_raw_spin_lock(x) \ |
| 388 | do { \ | 392 | do { \ |
| 389 | __u32 *ia64_spinlock_ptr = (__u32 *) (x); \ | 393 | __u32 *ia64_spinlock_ptr = (__u32 *) (x); \ |
| @@ -403,6 +407,7 @@ static inline u64 __gpfn_is_io(u64 gpfn) | |||
| 403 | do { barrier(); \ | 407 | do { barrier(); \ |
| 404 | ((spinlock_t *)x)->raw_lock.lock = 0; } \ | 408 | ((spinlock_t *)x)->raw_lock.lock = 0; } \ |
| 405 | while (0) | 409 | while (0) |
| 410 | #endif | ||
| 406 | 411 | ||
| 407 | void vmm_spin_lock(spinlock_t *lock); | 412 | void vmm_spin_lock(spinlock_t *lock); |
| 408 | void vmm_spin_unlock(spinlock_t *lock); | 413 | void vmm_spin_unlock(spinlock_t *lock); |
diff --git a/arch/x86/kernel/kvmclock.c b/arch/x86/kernel/kvmclock.c index 774ac4991568..1c9cc431ea4f 100644 --- a/arch/x86/kernel/kvmclock.c +++ b/arch/x86/kernel/kvmclock.c | |||
| @@ -128,7 +128,7 @@ static int kvm_register_clock(char *txt) | |||
| 128 | } | 128 | } |
| 129 | 129 | ||
| 130 | #ifdef CONFIG_X86_LOCAL_APIC | 130 | #ifdef CONFIG_X86_LOCAL_APIC |
| 131 | static void kvm_setup_secondary_clock(void) | 131 | static void __devinit kvm_setup_secondary_clock(void) |
| 132 | { | 132 | { |
| 133 | /* | 133 | /* |
| 134 | * Now that the first cpu already had this clocksource initialized, | 134 | * Now that the first cpu already had this clocksource initialized, |
diff --git a/arch/x86/kvm/Kconfig b/arch/x86/kvm/Kconfig index ce3251ce5504..b81125f0bdee 100644 --- a/arch/x86/kvm/Kconfig +++ b/arch/x86/kvm/Kconfig | |||
| @@ -20,6 +20,8 @@ if VIRTUALIZATION | |||
| 20 | config KVM | 20 | config KVM |
| 21 | tristate "Kernel-based Virtual Machine (KVM) support" | 21 | tristate "Kernel-based Virtual Machine (KVM) support" |
| 22 | depends on HAVE_KVM | 22 | depends on HAVE_KVM |
| 23 | # for device assignment: | ||
| 24 | depends on PCI | ||
| 23 | select PREEMPT_NOTIFIERS | 25 | select PREEMPT_NOTIFIERS |
| 24 | select MMU_NOTIFIER | 26 | select MMU_NOTIFIER |
| 25 | select ANON_INODES | 27 | select ANON_INODES |
diff --git a/arch/x86/kvm/i8254.c b/arch/x86/kvm/i8254.c index 8772dc946823..59ebd37ad79e 100644 --- a/arch/x86/kvm/i8254.c +++ b/arch/x86/kvm/i8254.c | |||
| @@ -548,8 +548,10 @@ struct kvm_pit *kvm_create_pit(struct kvm *kvm) | |||
| 548 | mutex_lock(&kvm->lock); | 548 | mutex_lock(&kvm->lock); |
| 549 | pit->irq_source_id = kvm_request_irq_source_id(kvm); | 549 | pit->irq_source_id = kvm_request_irq_source_id(kvm); |
| 550 | mutex_unlock(&kvm->lock); | 550 | mutex_unlock(&kvm->lock); |
| 551 | if (pit->irq_source_id < 0) | 551 | if (pit->irq_source_id < 0) { |
| 552 | kfree(pit); | ||
| 552 | return NULL; | 553 | return NULL; |
| 554 | } | ||
| 553 | 555 | ||
| 554 | mutex_init(&pit->pit_state.lock); | 556 | mutex_init(&pit->pit_state.lock); |
| 555 | mutex_lock(&pit->pit_state.lock); | 557 | mutex_lock(&pit->pit_state.lock); |
diff --git a/arch/x86/kvm/mmu.c b/arch/x86/kvm/mmu.c index 2a5e64881d9b..f1983d9477cd 100644 --- a/arch/x86/kvm/mmu.c +++ b/arch/x86/kvm/mmu.c | |||
| @@ -314,7 +314,7 @@ static int mmu_topup_memory_caches(struct kvm_vcpu *vcpu) | |||
| 314 | if (r) | 314 | if (r) |
| 315 | goto out; | 315 | goto out; |
| 316 | r = mmu_topup_memory_cache(&vcpu->arch.mmu_rmap_desc_cache, | 316 | r = mmu_topup_memory_cache(&vcpu->arch.mmu_rmap_desc_cache, |
| 317 | rmap_desc_cache, 1); | 317 | rmap_desc_cache, 4); |
| 318 | if (r) | 318 | if (r) |
| 319 | goto out; | 319 | goto out; |
| 320 | r = mmu_topup_memory_cache_page(&vcpu->arch.mmu_page_cache, 8); | 320 | r = mmu_topup_memory_cache_page(&vcpu->arch.mmu_page_cache, 8); |
diff --git a/arch/x86/kvm/vmx.c b/arch/x86/kvm/vmx.c index 2643b430d83a..d06b4dc0e2ea 100644 --- a/arch/x86/kvm/vmx.c +++ b/arch/x86/kvm/vmx.c | |||
| @@ -3564,7 +3564,8 @@ static int __init vmx_init(void) | |||
| 3564 | bypass_guest_pf = 0; | 3564 | bypass_guest_pf = 0; |
| 3565 | kvm_mmu_set_base_ptes(VMX_EPT_READABLE_MASK | | 3565 | kvm_mmu_set_base_ptes(VMX_EPT_READABLE_MASK | |
| 3566 | VMX_EPT_WRITABLE_MASK | | 3566 | VMX_EPT_WRITABLE_MASK | |
| 3567 | VMX_EPT_DEFAULT_MT << VMX_EPT_MT_EPTE_SHIFT); | 3567 | VMX_EPT_DEFAULT_MT << VMX_EPT_MT_EPTE_SHIFT | |
| 3568 | VMX_EPT_IGMT_BIT); | ||
| 3568 | kvm_mmu_set_mask_ptes(0ull, 0ull, 0ull, 0ull, | 3569 | kvm_mmu_set_mask_ptes(0ull, 0ull, 0ull, 0ull, |
| 3569 | VMX_EPT_EXECUTABLE_MASK); | 3570 | VMX_EPT_EXECUTABLE_MASK); |
| 3570 | kvm_enable_tdp(); | 3571 | kvm_enable_tdp(); |
diff --git a/arch/x86/kvm/vmx.h b/arch/x86/kvm/vmx.h index 3e010d21fdd7..ec5edc339da6 100644 --- a/arch/x86/kvm/vmx.h +++ b/arch/x86/kvm/vmx.h | |||
| @@ -352,6 +352,7 @@ enum vmcs_field { | |||
| 352 | #define VMX_EPT_READABLE_MASK 0x1ull | 352 | #define VMX_EPT_READABLE_MASK 0x1ull |
| 353 | #define VMX_EPT_WRITABLE_MASK 0x2ull | 353 | #define VMX_EPT_WRITABLE_MASK 0x2ull |
| 354 | #define VMX_EPT_EXECUTABLE_MASK 0x4ull | 354 | #define VMX_EPT_EXECUTABLE_MASK 0x4ull |
| 355 | #define VMX_EPT_IGMT_BIT (1ull << 6) | ||
| 355 | 356 | ||
| 356 | #define VMX_EPT_IDENTITY_PAGETABLE_ADDR 0xfffbc000ul | 357 | #define VMX_EPT_IDENTITY_PAGETABLE_ADDR 0xfffbc000ul |
| 357 | 358 | ||
