diff options
author | Yang Zhang <yang.z.zhang@Intel.com> | 2013-04-11 07:25:14 -0400 |
---|---|---|
committer | Marcelo Tosatti <mtosatti@redhat.com> | 2013-04-16 15:32:40 -0400 |
commit | cf9e65b773394c5ad8fa7455c43268bc8ec2109f (patch) | |
tree | dea4e116da3ecc13c8b6383ec2145a73480d66f0 /arch/x86 | |
parent | 3d81bc7e96d6bca0b8f8b7d1bf6ea72caa3aac57 (diff) |
KVM: Set TMR when programming ioapic entry
We already know the trigger mode of a given interrupt when programming
the ioapice entry. So it's not necessary to set it in each interrupt
delivery.
Signed-off-by: Yang Zhang <yang.z.zhang@Intel.com>
Reviewed-by: Gleb Natapov <gleb@redhat.com>
Signed-off-by: Marcelo Tosatti <mtosatti@redhat.com>
Diffstat (limited to 'arch/x86')
-rw-r--r-- | arch/x86/kvm/lapic.c | 15 | ||||
-rw-r--r-- | arch/x86/kvm/lapic.h | 1 | ||||
-rw-r--r-- | arch/x86/kvm/x86.c | 5 |
3 files changed, 14 insertions, 7 deletions
diff --git a/arch/x86/kvm/lapic.c b/arch/x86/kvm/lapic.c index 34a8ca845280..d197579435d0 100644 --- a/arch/x86/kvm/lapic.c +++ b/arch/x86/kvm/lapic.c | |||
@@ -468,6 +468,15 @@ static inline int apic_find_highest_isr(struct kvm_lapic *apic) | |||
468 | return result; | 468 | return result; |
469 | } | 469 | } |
470 | 470 | ||
471 | void kvm_apic_update_tmr(struct kvm_vcpu *vcpu, u32 *tmr) | ||
472 | { | ||
473 | struct kvm_lapic *apic = vcpu->arch.apic; | ||
474 | int i; | ||
475 | |||
476 | for (i = 0; i < 8; i++) | ||
477 | apic_set_reg(apic, APIC_TMR + 0x10 * i, tmr[i]); | ||
478 | } | ||
479 | |||
471 | static void apic_update_ppr(struct kvm_lapic *apic) | 480 | static void apic_update_ppr(struct kvm_lapic *apic) |
472 | { | 481 | { |
473 | u32 tpr, isrv, ppr, old_ppr; | 482 | u32 tpr, isrv, ppr, old_ppr; |
@@ -661,12 +670,6 @@ static int __apic_accept_irq(struct kvm_lapic *apic, int delivery_mode, | |||
661 | if (dest_map) | 670 | if (dest_map) |
662 | __set_bit(vcpu->vcpu_id, dest_map); | 671 | __set_bit(vcpu->vcpu_id, dest_map); |
663 | 672 | ||
664 | if (trig_mode) { | ||
665 | apic_debug("level trig mode for vector %d", vector); | ||
666 | apic_set_vector(vector, apic->regs + APIC_TMR); | ||
667 | } else | ||
668 | apic_clear_vector(vector, apic->regs + APIC_TMR); | ||
669 | |||
670 | result = !apic_test_and_set_irr(vector, apic); | 673 | result = !apic_test_and_set_irr(vector, apic); |
671 | trace_kvm_apic_accept_irq(vcpu->vcpu_id, delivery_mode, | 674 | trace_kvm_apic_accept_irq(vcpu->vcpu_id, delivery_mode, |
672 | trig_mode, vector, !result); | 675 | trig_mode, vector, !result); |
diff --git a/arch/x86/kvm/lapic.h b/arch/x86/kvm/lapic.h index 16304b1a8cba..7fe0c9180ea1 100644 --- a/arch/x86/kvm/lapic.h +++ b/arch/x86/kvm/lapic.h | |||
@@ -53,6 +53,7 @@ void kvm_lapic_set_base(struct kvm_vcpu *vcpu, u64 value); | |||
53 | u64 kvm_lapic_get_base(struct kvm_vcpu *vcpu); | 53 | u64 kvm_lapic_get_base(struct kvm_vcpu *vcpu); |
54 | void kvm_apic_set_version(struct kvm_vcpu *vcpu); | 54 | void kvm_apic_set_version(struct kvm_vcpu *vcpu); |
55 | 55 | ||
56 | void kvm_apic_update_tmr(struct kvm_vcpu *vcpu, u32 *tmr); | ||
56 | int kvm_apic_match_physical_addr(struct kvm_lapic *apic, u16 dest); | 57 | int kvm_apic_match_physical_addr(struct kvm_lapic *apic, u16 dest); |
57 | int kvm_apic_match_logical_addr(struct kvm_lapic *apic, u8 mda); | 58 | int kvm_apic_match_logical_addr(struct kvm_lapic *apic, u8 mda); |
58 | int kvm_apic_set_irq(struct kvm_vcpu *vcpu, struct kvm_lapic_irq *irq, | 59 | int kvm_apic_set_irq(struct kvm_vcpu *vcpu, struct kvm_lapic_irq *irq, |
diff --git a/arch/x86/kvm/x86.c b/arch/x86/kvm/x86.c index 87a05df3eae4..276b4a9a5605 100644 --- a/arch/x86/kvm/x86.c +++ b/arch/x86/kvm/x86.c | |||
@@ -5664,14 +5664,17 @@ static void kvm_gen_update_masterclock(struct kvm *kvm) | |||
5664 | static void vcpu_scan_ioapic(struct kvm_vcpu *vcpu) | 5664 | static void vcpu_scan_ioapic(struct kvm_vcpu *vcpu) |
5665 | { | 5665 | { |
5666 | u64 eoi_exit_bitmap[4]; | 5666 | u64 eoi_exit_bitmap[4]; |
5667 | u32 tmr[8]; | ||
5667 | 5668 | ||
5668 | if (!kvm_apic_hw_enabled(vcpu->arch.apic)) | 5669 | if (!kvm_apic_hw_enabled(vcpu->arch.apic)) |
5669 | return; | 5670 | return; |
5670 | 5671 | ||
5671 | memset(eoi_exit_bitmap, 0, 32); | 5672 | memset(eoi_exit_bitmap, 0, 32); |
5673 | memset(tmr, 0, 32); | ||
5672 | 5674 | ||
5673 | kvm_ioapic_scan_entry(vcpu, eoi_exit_bitmap); | 5675 | kvm_ioapic_scan_entry(vcpu, eoi_exit_bitmap, tmr); |
5674 | kvm_x86_ops->load_eoi_exitmap(vcpu, eoi_exit_bitmap); | 5676 | kvm_x86_ops->load_eoi_exitmap(vcpu, eoi_exit_bitmap); |
5677 | kvm_apic_update_tmr(vcpu, tmr); | ||
5675 | } | 5678 | } |
5676 | 5679 | ||
5677 | static int vcpu_enter_guest(struct kvm_vcpu *vcpu) | 5680 | static int vcpu_enter_guest(struct kvm_vcpu *vcpu) |