• Paul Mackerras's avatar
    KVM: PPC: Book3S HV: Don't sleep if XIVE interrupt pending on POWER9 · ee3308a2
    Paul Mackerras authored
    On a POWER9 system, it is possible for an interrupt to become pending
    for a VCPU when that VCPU is about to cede (execute a H_CEDE hypercall)
    and has already disabled interrupts, or in the H_CEDE processing up
    to the point where the XIVE context is pulled from the hardware.  In
    such a case, the H_CEDE should not sleep, but should return immediately
    to the guest.  However, the conditions tested in kvmppc_vcpu_woken()
    don't include the condition that a XIVE interrupt is pending, so the
    VCPU could sleep until the next decrementer interrupt.
    
    To fix this, we add a new xive_interrupt_pending() helper which looks
    in the XIVE context that was pulled from the hardware to see if the
    priority of any pending interrupt is higher (numerically lower than)
    the CPU priority.  If so then kvmppc_vcpu_woken() will return true.
    If the XIVE context has never been used, then both the pipr and the
    cppr fields will be zero and the test will indicate that no interrupt
    is pending.
    Signed-off-by: default avatarPaul Mackerras <paulus@ozlabs.org>
    ee3308a2
book3s_hv.c 109 KB