diff options
author | Andrey Smetanin <asmetanin@virtuozzo.com> | 2015-10-16 03:07:45 -0400 |
---|---|---|
committer | Paolo Bonzini <pbonzini@redhat.com> | 2015-10-16 04:34:28 -0400 |
commit | 351dc6477cd35136ce4668401b1b1332a62908a8 (patch) | |
tree | 909d643640eeb91f7312572074681d915138febc /virt/kvm/eventfd.c | |
parent | 7cae2bedcbd4680b155999655e49c27b9cf020fa (diff) |
kvm/eventfd: avoid loop inside irqfd_update()
The loop(for) inside irqfd_update() is unnecessary
because any other value for irq_entry.type will just trigger
schedule_work(&irqfd->inject) in irqfd_wakeup.
Signed-off-by: Andrey Smetanin <asmetanin@virtuozzo.com>
Reviewed-by: Roman Kagan <rkagan@virtuozzo.com>
Signed-off-by: Denis V. Lunev <den@openvz.org>
CC: Vitaly Kuznetsov <vkuznets@redhat.com>
CC: "K. Y. Srinivasan" <kys@microsoft.com>
CC: Gleb Natapov <gleb@kernel.org>
CC: Paolo Bonzini <pbonzini@redhat.com>
Signed-off-by: Paolo Bonzini <pbonzini@redhat.com>
Diffstat (limited to 'virt/kvm/eventfd.c')
-rw-r--r-- | virt/kvm/eventfd.c | 13 |
1 files changed, 5 insertions, 8 deletions
diff --git a/virt/kvm/eventfd.c b/virt/kvm/eventfd.c index b637965746bb..518421e65b0d 100644 --- a/virt/kvm/eventfd.c +++ b/virt/kvm/eventfd.c | |||
@@ -238,20 +238,17 @@ static void irqfd_update(struct kvm *kvm, struct kvm_kernel_irqfd *irqfd) | |||
238 | { | 238 | { |
239 | struct kvm_kernel_irq_routing_entry *e; | 239 | struct kvm_kernel_irq_routing_entry *e; |
240 | struct kvm_kernel_irq_routing_entry entries[KVM_NR_IRQCHIPS]; | 240 | struct kvm_kernel_irq_routing_entry entries[KVM_NR_IRQCHIPS]; |
241 | int i, n_entries; | 241 | int n_entries; |
242 | 242 | ||
243 | n_entries = kvm_irq_map_gsi(kvm, entries, irqfd->gsi); | 243 | n_entries = kvm_irq_map_gsi(kvm, entries, irqfd->gsi); |
244 | 244 | ||
245 | write_seqcount_begin(&irqfd->irq_entry_sc); | 245 | write_seqcount_begin(&irqfd->irq_entry_sc); |
246 | 246 | ||
247 | irqfd->irq_entry.type = 0; | ||
248 | |||
249 | e = entries; | 247 | e = entries; |
250 | for (i = 0; i < n_entries; ++i, ++e) { | 248 | if (n_entries == 1) |
251 | /* Only fast-path MSI. */ | 249 | irqfd->irq_entry = *e; |
252 | if (e->type == KVM_IRQ_ROUTING_MSI) | 250 | else |
253 | irqfd->irq_entry = *e; | 251 | irqfd->irq_entry.type = 0; |
254 | } | ||
255 | 252 | ||
256 | write_seqcount_end(&irqfd->irq_entry_sc); | 253 | write_seqcount_end(&irqfd->irq_entry_sc); |
257 | } | 254 | } |