On Tue, Nov 02, 2010 at 05:09:42PM +0800, Xiao Guangrong wrote: > On 11/02/2010 03:45 PM, Gleb Natapov wrote: > > > kvm_event_needs_reinjection() checks for nmi/interrupts that > > need reinjection (not injection). Those are nmi/interrupts that > > was injected but injection failed for some reason. For nmi, for > > instance, kvm_arch_vcpu_runnable() checks vcpu->arch.nmi_pending, > > but kvm_event_needs_reinjection() checks for vcpu->arch.nmi_injected. > > NMI moves from nmi_pending to nmi_injected when it is injected into vcpu > > for the first time. CPU cannot be halted in this state. > > > > Yeah, nmi is handled like this way, but for interrupt: > If interruption controller is in userspace (!irqchip_in_kernel(v->kvm)), > kvm_arch_vcpu_runnable() checks vcpu->arch.interrupt.pending and > kvm_event_needs_reinjection() also checks vcpu->arch.interrupt.pending. > > Consider this case: > > - Guest vcpu executes 'HLT' > - wakeup the vcpu and inject interrupt and apfs is completed at this time > - then the vcpu can't handle apf completion and .done list keeps nonempty. > > Can this case happen? Sorry if i missed it again. > If irqchip is in userspace apf is disabled (see mmu.c:can_do_async_pf()). The reason for this is that when irqchip_in_kernel(v->kvm) cpu sleeps in userspace during halt, so all event that can cause it to be unhalted should be generated in userspace too. This is also the reason you can't have pit in kernel and irqchip in userpsace. -- Gleb. -- To unsubscribe from this list: send the line "unsubscribe kvm" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html