diff options
author | He, Qing <qing.he@intel.com> | 2007-09-03 10:01:36 -0400 |
---|---|---|
committer | Avi Kivity <avi@qumranet.com> | 2007-10-13 04:18:26 -0400 |
commit | 932f72adbe76f098922c746737cb0bd75fc21e27 (patch) | |
tree | 55a98bd0692094289d4bea4f5b2c58835f8b59df | |
parent | 40487c680d5855459dfdce340df13d40071bb774 (diff) |
KVM: round robin for APIC lowest priority delivery mode
Signed-off-by: Qing He <qing.he@intel.com>
Signed-off-by: Avi Kivity <avi@qumranet.com>
-rw-r--r-- | drivers/kvm/kvm.h | 1 | ||||
-rw-r--r-- | drivers/kvm/lapic.c | 33 |
2 files changed, 29 insertions, 5 deletions
diff --git a/drivers/kvm/kvm.h b/drivers/kvm/kvm.h index f8fe87d3ddbd..dbb929d8a31e 100644 --- a/drivers/kvm/kvm.h +++ b/drivers/kvm/kvm.h | |||
@@ -413,6 +413,7 @@ struct kvm { | |||
413 | struct kvm_io_bus pio_bus; | 413 | struct kvm_io_bus pio_bus; |
414 | struct kvm_pic *vpic; | 414 | struct kvm_pic *vpic; |
415 | struct kvm_ioapic *vioapic; | 415 | struct kvm_ioapic *vioapic; |
416 | int round_robin_prev_vcpu; | ||
416 | }; | 417 | }; |
417 | 418 | ||
418 | static inline struct kvm_pic *pic_irqchip(struct kvm *kvm) | 419 | static inline struct kvm_pic *pic_irqchip(struct kvm *kvm) |
diff --git a/drivers/kvm/lapic.c b/drivers/kvm/lapic.c index 01e769672dcc..ca1db3852ace 100644 --- a/drivers/kvm/lapic.c +++ b/drivers/kvm/lapic.c | |||
@@ -371,12 +371,35 @@ struct kvm_lapic *kvm_apic_round_robin(struct kvm *kvm, u8 vector, | |||
371 | unsigned long bitmap) | 371 | unsigned long bitmap) |
372 | { | 372 | { |
373 | int vcpu_id; | 373 | int vcpu_id; |
374 | int last; | ||
375 | int next; | ||
376 | struct kvm_lapic *apic; | ||
377 | |||
378 | last = kvm->round_robin_prev_vcpu; | ||
379 | next = last; | ||
380 | |||
381 | do { | ||
382 | if (++next == KVM_MAX_VCPUS) | ||
383 | next = 0; | ||
384 | if (kvm->vcpus[next] == NULL || !test_bit(next, &bitmap)) | ||
385 | continue; | ||
386 | apic = kvm->vcpus[next]->apic; | ||
387 | if (apic && apic_enabled(apic)) | ||
388 | break; | ||
389 | apic = NULL; | ||
390 | } while (next != last); | ||
391 | kvm->round_robin_prev_vcpu = next; | ||
392 | |||
393 | if (!apic) { | ||
394 | vcpu_id = ffs(bitmap) - 1; | ||
395 | if (vcpu_id < 0) { | ||
396 | vcpu_id = 0; | ||
397 | printk(KERN_DEBUG "vcpu not ready for apic_round_robin\n"); | ||
398 | } | ||
399 | apic = kvm->vcpus[vcpu_id]->apic; | ||
400 | } | ||
374 | 401 | ||
375 | /* TODO for real round robin */ | 402 | return apic; |
376 | vcpu_id = fls(bitmap) - 1; | ||
377 | if (vcpu_id < 0) | ||
378 | printk(KERN_DEBUG "vcpu not ready for apic_round_robin\n"); | ||
379 | return kvm->vcpus[vcpu_id]->apic; | ||
380 | } | 403 | } |
381 | 404 | ||
382 | static void apic_set_eoi(struct kvm_lapic *apic) | 405 | static void apic_set_eoi(struct kvm_lapic *apic) |