On Tue, Jan 14, 2020 at 10:28 AM Sean Christopherson <sean.j.christopherson@xxxxxxxxx> wrote: > > On Tue, Jan 14, 2020 at 09:58:22AM -0800, Jim Mattson wrote: > > On Mon, Jan 13, 2020 at 4:05 PM Sean Christopherson > > <sean.j.christopherson@xxxxxxxxx> wrote: > > > > > Another case, which may or may not be possible, is if INIT is recognized > > > on the same instruction, in which case it takes priority over MTF. SMI > > > might also be an issue. > > > > Don't we already have a priority inversion today when INIT or SMI are > > coincident with a debug trap on the previous instruction (e.g. > > single-step trap on an emulated instruction)? > > Liran fixed the INIT issue in commit 4b9852f4f389 ("KVM: x86: Fix INIT > signal handling in various CPU states"). > > SMI still appears to be inverted. I find the callgraph for vmx_check_nested_events very confusing. It's called as many as three times per call to vcpu_enter_guest(): 1. From kvm_vcpu_running(), before the call to vcpu_enter_guest(). 2. From inject_pending_event(), in vcpu_enter_guest(), after all of the calls to kvm_check_request(). 3. From inject_pending_event(), after injecting (but not reinjecting) an event, but not if we've processed an SMI or an NMI. Can this possibly respect the architected priorities? I'm skeptical. Within the body of vmx_check_nested_events(), the following priorities are imposed: 1. INIT 2. Intercepted fault or trap on previous instruction 3. VMX preemption timer 4. NMI 5. External interrupt (2) is appropriately placed for "traps on the previous instruction," but it looks like there is a priority inversion between INIT and an intercepted fault on the previous instruction. In fact, because of the first two calls to vmx_check_nested_events() listed above, there is a priority inversion between an *unintercepted* fault on the previous instruction and any of {INIT, VMX preemption timer, NMI, external interrupt}. Or is there some subtlety here that I'm missing?