diff options
Diffstat (limited to 'virt/kvm/kvm_main.c')
-rw-r--r-- | virt/kvm/kvm_main.c | 12 |
1 files changed, 12 insertions, 0 deletions
diff --git a/virt/kvm/kvm_main.c b/virt/kvm/kvm_main.c index 2884baf1d5f9..dee321e58894 100644 --- a/virt/kvm/kvm_main.c +++ b/virt/kvm/kvm_main.c | |||
@@ -986,6 +986,7 @@ static struct kvm *kvm_create_vm(void) | |||
986 | spin_lock_init(&kvm->mmu_lock); | 986 | spin_lock_init(&kvm->mmu_lock); |
987 | spin_lock_init(&kvm->requests_lock); | 987 | spin_lock_init(&kvm->requests_lock); |
988 | kvm_io_bus_init(&kvm->pio_bus); | 988 | kvm_io_bus_init(&kvm->pio_bus); |
989 | kvm_irqfd_init(kvm); | ||
989 | mutex_init(&kvm->lock); | 990 | mutex_init(&kvm->lock); |
990 | kvm_io_bus_init(&kvm->mmio_bus); | 991 | kvm_io_bus_init(&kvm->mmio_bus); |
991 | init_rwsem(&kvm->slots_lock); | 992 | init_rwsem(&kvm->slots_lock); |
@@ -1071,6 +1072,8 @@ static int kvm_vm_release(struct inode *inode, struct file *filp) | |||
1071 | { | 1072 | { |
1072 | struct kvm *kvm = filp->private_data; | 1073 | struct kvm *kvm = filp->private_data; |
1073 | 1074 | ||
1075 | kvm_irqfd_release(kvm); | ||
1076 | |||
1074 | kvm_put_kvm(kvm); | 1077 | kvm_put_kvm(kvm); |
1075 | return 0; | 1078 | return 0; |
1076 | } | 1079 | } |
@@ -2222,6 +2225,15 @@ static long kvm_vm_ioctl(struct file *filp, | |||
2222 | } | 2225 | } |
2223 | #endif | 2226 | #endif |
2224 | #endif /* KVM_CAP_IRQ_ROUTING */ | 2227 | #endif /* KVM_CAP_IRQ_ROUTING */ |
2228 | case KVM_IRQFD: { | ||
2229 | struct kvm_irqfd data; | ||
2230 | |||
2231 | r = -EFAULT; | ||
2232 | if (copy_from_user(&data, argp, sizeof data)) | ||
2233 | goto out; | ||
2234 | r = kvm_irqfd(kvm, data.fd, data.gsi, data.flags); | ||
2235 | break; | ||
2236 | } | ||
2225 | default: | 2237 | default: |
2226 | r = kvm_arch_vm_ioctl(filp, ioctl, arg); | 2238 | r = kvm_arch_vm_ioctl(filp, ioctl, arg); |
2227 | } | 2239 | } |