Donate to e Foundation | Murena handsets with /e/OS | Own a part of Murena! Learn more

Commit 19d25a0e authored by David Hildenbrand's avatar David Hildenbrand Committed by Radim Krčmář
Browse files

KVM: x86: check against irqchip_mode in pic_in_kernel()



Let's avoid checking against kvm->arch.vpic. We have kvm->arch.irqchip_mode
for that now.

KVM_IRQCHIP_KERNEL implies a fully inititalized pic, while kvm->arch.vpic
might temporarily be set but invalidated again if e.g. kvm_ioapic_init()
fails when setting KVM_CREATE_IRQCHIP. Although current users seem to be
fine, this avoids future bugs.

Signed-off-by: default avatarDavid Hildenbrand <david@redhat.com>
Signed-off-by: default avatarRadim Krčmář <rkrcmar@redhat.com>
parent 8bf463f3
Loading
Loading
Loading
Loading
+4 −3
Original line number Diff line number Diff line
@@ -85,10 +85,11 @@ static inline struct kvm_pic *pic_irqchip(struct kvm *kvm)

static inline int pic_in_kernel(struct kvm *kvm)
{
	int ret;
	int mode = kvm->arch.irqchip_mode;

	ret = (pic_irqchip(kvm) != NULL);
	return ret;
	/* Matches smp_wmb() when setting irqchip_mode */
	smp_rmb();
	return mode == KVM_IRQCHIP_KERNEL;
}

static inline int irqchip_split(struct kvm *kvm)