Skip to content

Commit

Permalink
KVM: arm/arm64: vgic: Trust the LR state for HW IRQs
Browse files Browse the repository at this point in the history
We were probing the physial distributor state for the active state of a
HW virtual IRQ, because we had seen evidence that the LR state was not
cleared when the guest deactivated a virtual interrupted.

However, this issue turned out to be a software bug in the GIC, which
was solved by: 84aab5e68c2a5e1e18d81ae8308c3ce25d501b29
(KVM: arm/arm64: arch_timer: Preserve physical dist. active
state on LR.active, 2015-11-24)

Therefore, get rid of the complexities and just look at the LR.

Reviewed-by: Marc Zyngier <[email protected]>
Signed-off-by: Christoffer Dall <[email protected]>
  • Loading branch information
chazy committed Nov 24, 2015
1 parent 0e3dfda commit 9f958c1
Showing 1 changed file with 2 additions and 14 deletions.
16 changes: 2 additions & 14 deletions virt/kvm/arm/vgic.c
Original file line number Diff line number Diff line change
Expand Up @@ -1417,25 +1417,13 @@ static bool vgic_process_maintenance(struct kvm_vcpu *vcpu)
static bool vgic_sync_hwirq(struct kvm_vcpu *vcpu, int lr, struct vgic_lr vlr)
{
struct vgic_dist *dist = &vcpu->kvm->arch.vgic;
struct irq_phys_map *map;
bool phys_active;
bool level_pending;
int ret;

if (!(vlr.state & LR_HW))
return false;

map = vgic_irq_map_search(vcpu, vlr.irq);
BUG_ON(!map);

ret = irq_get_irqchip_state(map->irq,
IRQCHIP_STATE_ACTIVE,
&phys_active);

WARN_ON(ret);

if (phys_active)
return 0;
if (vlr.state & LR_STATE_ACTIVE)
return false;

spin_lock(&dist->lock);
level_pending = process_queued_irq(vcpu, lr, vlr);
Expand Down

0 comments on commit 9f958c1

Please sign in to comment.