]> git.ipfire.org Git - thirdparty/kernel/stable.git/commitdiff
KVM: x86: Explicitly treat routing entry type changes as changes
authorSean Christopherson <seanjc@google.com>
Fri, 4 Apr 2025 19:38:18 +0000 (12:38 -0700)
committerGreg Kroah-Hartman <gregkh@linuxfoundation.org>
Fri, 2 May 2025 05:46:57 +0000 (07:46 +0200)
commit bcda70c56f3e718465cab2aad260cf34183ce1ce upstream.

Explicitly treat type differences as GSI routing changes, as comparing MSI
data between two entries could get a false negative, e.g. if userspace
changed the type but left the type-specific data as-is.

Fixes: 515a0c79e796 ("kvm: irqfd: avoid update unmodified entries of the routing")
Cc: stable@vger.kernel.org
Signed-off-by: Sean Christopherson <seanjc@google.com>
Message-ID: <20250404193923.1413163-4-seanjc@google.com>
Signed-off-by: Paolo Bonzini <pbonzini@redhat.com>
Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
arch/x86/kvm/x86.c

index 4d5be4956c4839a7bf2db89d9528c9a12ec8c163..580730b1e589355ee326f96dfd070ca6d5aba31d 100644 (file)
@@ -13426,7 +13426,8 @@ int kvm_arch_update_irqfd_routing(struct kvm *kvm, unsigned int host_irq,
 bool kvm_arch_irqfd_route_changed(struct kvm_kernel_irq_routing_entry *old,
                                  struct kvm_kernel_irq_routing_entry *new)
 {
-       if (new->type != KVM_IRQ_ROUTING_MSI)
+       if (old->type != KVM_IRQ_ROUTING_MSI ||
+           new->type != KVM_IRQ_ROUTING_MSI)
                return true;
 
        return !!memcmp(&old->msi, &new->msi, sizeof(new->msi));