KVM: x86: Disable posted interrupts for non-standard IRQs delivery modes
authorAlexander Graf <graf@amazon.com>
Thu, 5 Sep 2019 12:58:18 +0000 (14:58 +0200)
committerPaolo Bonzini <pbonzini@redhat.com>
Tue, 10 Sep 2019 14:39:34 +0000 (16:39 +0200)
commitfdcf756213756c23b533ca4974d1f48c6a4d4281
treed59bf57056591970bb766196249a7575248ddbe9
parentb6852ae75d4be5d3398a4a501443de221151fa9b
KVM: x86: Disable posted interrupts for non-standard IRQs delivery modes

We can easily route hardware interrupts directly into VM context when
they target the "Fixed" or "LowPriority" delivery modes.

However, on modes such as "SMI" or "Init", we need to go via KVM code
to actually put the vCPU into a different mode of operation, so we can
not post the interrupt

Add code in the VMX and SVM PI logic to explicitly refuse to establish
posted mappings for advanced IRQ deliver modes. This reflects the logic
in __apic_accept_irq() which also only ever passes Fixed and LowPriority
interrupts as posted interrupts into the guest.

This fixes a bug I have with code which configures real hardware to
inject virtual SMIs into my guest.

Signed-off-by: Alexander Graf <graf@amazon.com>
Reviewed-by: Liran Alon <liran.alon@oracle.com>
Reviewed-by: Sean Christopherson <sean.j.christopherson@intel.com>
Reviewed-by: Wanpeng Li <wanpengli@tencent.com>
Cc: stable@vger.kernel.org
Signed-off-by: Paolo Bonzini <pbonzini@redhat.com>
arch/x86/include/asm/kvm_host.h
arch/x86/kvm/svm.c
arch/x86/kvm/vmx/vmx.c