Received: by 10.223.185.116 with SMTP id b49csp3714025wrg; Tue, 13 Feb 2018 06:41:16 -0800 (PST) X-Google-Smtp-Source: AH8x225f53Vi3FlLbrUD9INIPo+llLWdSW/8Qzxykkbo2ZVUZKx10jAJ9ag9vMzrScAbjVxdNnWS X-Received: by 10.101.80.130 with SMTP id r2mr1147871pgp.107.1518532876225; Tue, 13 Feb 2018 06:41:16 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1518532876; cv=none; d=google.com; s=arc-20160816; b=R65AIMnJbxd4byQVbocj6Jt2fYfgizUxhNPNjRxxG4rcgKLFrka8sdtu78ekW8tph+ rUZcf6cS1SHSVazLQHFXDph64RBTxFrBLoO4VmTwbe/7HWxyaf8Lg+tv3Vh1FSHUm9pg ui3UnVnai/uj+dyu2OBYWGz/JBQGBn8BzXIVxUBHMbKfdsNTFbFmCpxxRX4Hbt4XK5iF 0e5guV534Nx1INfrT9SywSppd2goGWbXnxjUeOg+GMkgFH/ILDf6C2/oAMqXaLltxULE jo+XOrll0Ym9bP4gaGh/ODF7jvRZ9lwuF+fBiy2D7eJbroX3Tt0SCD9qyO+pCYNRPiVA wIzA== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:content-transfer-encoding :content-language:in-reply-to:mime-version:user-agent:date :message-id:from:references:cc:to:subject:arc-authentication-results; bh=Squf3XtWVOjm76Qrjb0ZouZKzp+QDymFs67VhzYoYEw=; b=DFl4GfX6fAt3e/98aQXoJxBLiQzyUGScI9DEcojjIFhnY8gW2nPhq7d8+zoTAQB2mU QzCehlicFr3C3WYUGYXVQXNAgCag1miL4LVj1nFmVmC6hg9GB1M5RMxNRDxJYJzGRj7Y xkjrAKCmZKifPijV8EZ+J5xV/LmkcOHEK2bYGsg0U9GTe6Nl/AydzWHih7fOjp6t//gx 3eXcOlTaicyBWWIH+V+0UR0nuG8QpJKn08mfHGpyuo2/zG8wqSG5NqDUHdOlZE1AFAxP jFnWTvJku/1Pqn75fk6MHR3E9i/zHnk9hsEYM5wnb50DOKOZMzQSGoA3T6zKbZ+bbKI/ V+QA== ARC-Authentication-Results: i=1; mx.google.com; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=redhat.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id y12si855018pgq.380.2018.02.13.06.41.01; Tue, 13 Feb 2018 06:41:16 -0800 (PST) Received-SPF: pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) client-ip=209.132.180.67; Authentication-Results: mx.google.com; spf=pass (google.com: best guess record for domain of linux-kernel-owner@vger.kernel.org designates 209.132.180.67 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=fail (p=NONE sp=NONE dis=NONE) header.from=redhat.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S935478AbeBMOil (ORCPT + 99 others); Tue, 13 Feb 2018 09:38:41 -0500 Received: from mx3-rdu2.redhat.com ([66.187.233.73]:48114 "EHLO mx1.redhat.com" rhost-flags-OK-OK-OK-FAIL) by vger.kernel.org with ESMTP id S935246AbeBMOik (ORCPT ); Tue, 13 Feb 2018 09:38:40 -0500 Received: from smtp.corp.redhat.com (int-mx04.intmail.prod.int.rdu2.redhat.com [10.11.54.4]) (using TLSv1.2 with cipher AECDH-AES256-SHA (256/256 bits)) (No client certificate requested) by mx1.redhat.com (Postfix) with ESMTPS id 8006D8182D32; Tue, 13 Feb 2018 14:38:39 +0000 (UTC) Received: from [10.36.116.223] (ovpn-116-223.ams2.redhat.com [10.36.116.223]) by smtp.corp.redhat.com (Postfix) with ESMTPS id 815F3202699A; Tue, 13 Feb 2018 14:38:37 +0000 (UTC) Subject: Re: [PATCH v3] KVM: VMX: Don't halt vcpu when L1 is injecting events to L2 To: Chao Gao , kvm@vger.kernel.org Cc: linux-kernel@vger.kernel.org, x86@kernel.org, "H. Peter Anvin" , Ingo Molnar , Thomas Gleixner , =?UTF-8?B?UmFkaW0gS3LEjW3DocWZ?= , Liran Alon References: <1518314790-31774-1-git-send-email-chao.gao@intel.com> From: Paolo Bonzini Message-ID: <6164ecd6-cf6e-dfc9-812a-b99706468f8b@redhat.com> Date: Tue, 13 Feb 2018 15:38:35 +0100 User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:52.0) Gecko/20100101 Thunderbird/52.5.2 MIME-Version: 1.0 In-Reply-To: <1518314790-31774-1-git-send-email-chao.gao@intel.com> Content-Type: text/plain; charset=utf-8 Content-Language: en-US Content-Transfer-Encoding: 7bit X-Scanned-By: MIMEDefang 2.78 on 10.11.54.4 X-Greylist: Sender IP whitelisted, not delayed by milter-greylist-4.5.16 (mx1.redhat.com [10.11.55.8]); Tue, 13 Feb 2018 14:38:39 +0000 (UTC) X-Greylist: inspected by milter-greylist-4.5.16 (mx1.redhat.com [10.11.55.8]); Tue, 13 Feb 2018 14:38:39 +0000 (UTC) for IP:'10.11.54.4' DOMAIN:'int-mx04.intmail.prod.int.rdu2.redhat.com' HELO:'smtp.corp.redhat.com' FROM:'pbonzini@redhat.com' RCPT:'' Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On 11/02/2018 03:06, Chao Gao wrote: > Although L2 is in halt state, it will be in the active state after > VM entry if the VM entry is vectoring according to SDM 26.6.2 Activity > State. Halting the vcpu here means the event won't be injected to L2 > and this decision isn't reported to L1. Thus L0 drops an event that > should be injected to L2. > > Cc: Liran Alon > Signed-off-by: Chao Gao > --- > changes in v3: > - s/VECTORING_INFO_VALID_MASK/INTR_INFO_VALID_MASK > - Changes of subject, comments. > > Changes in v2: > - Remove VID stuff. Only handle event injection in this patch. > > Signed-off-by: Chao Gao > --- > arch/x86/kvm/vmx.c | 7 ++++++- > 1 file changed, 6 insertions(+), 1 deletion(-) > > diff --git a/arch/x86/kvm/vmx.c b/arch/x86/kvm/vmx.c > index bb5b488..cf7c2fc 100644 > --- a/arch/x86/kvm/vmx.c > +++ b/arch/x86/kvm/vmx.c > @@ -10985,7 +10985,12 @@ static int nested_vmx_run(struct kvm_vcpu *vcpu, bool launch) > if (ret) > return ret; > > - if (vmcs12->guest_activity_state == GUEST_ACTIVITY_HLT) > + /* > + * If we're entering a halted L2 vcpu and the L2 vcpu won't be woken > + * by event injection, halt vcpu. > + */ > + if ((vmcs12->guest_activity_state == GUEST_ACTIVITY_HLT) && > + !(vmcs12->vm_entry_intr_info_field & INTR_INFO_VALID_MASK)) > return kvm_vcpu_halt(vcpu); > > vmx->nested.nested_run_pending = 1; > Queued, thanks (haven't yet tried the new test). Paolo