Received: by 2002:a25:c205:0:0:0:0:0 with SMTP id s5csp142619ybf; Thu, 27 Feb 2020 17:51:49 -0800 (PST) X-Google-Smtp-Source: APXvYqx05aaCI92omNBZv/qbJfCF187XyfRYdjAWaApYpBrg68pKzXdvBitJR5/trk6v9gBz0zL/ X-Received: by 2002:a9d:6457:: with SMTP id m23mr1503525otl.162.1582854708977; Thu, 27 Feb 2020 17:51:48 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1582854708; cv=none; d=google.com; s=arc-20160816; b=KPLQCt/p/LCCk4QQAHUETXIK/JsxvsZdoio+ty6vZ+s4N+5xDwG7TiUQHedPI6AN1z ZZX8sio/hcZiNsQxFus4wILtq63ruOPAyoHRNmbJId19z5hLrNBv5+3gkub4k1MqrDQg NUWiv+N74sAAH08xpma9DmI1ltTP5+nS4hHWq0QafPRBKEJh98NfskakE/0UwDxRtog7 mHD+7kncVzB4iL2J4hU4sIofgpZCeYdhSP3xBUXJm3M8AqMXVQiZlVc1OmTIFvUMFi4o 6rwqulUGreurOUjjQE7qMXcAxuFw1WAaDvKCtxzkv89EawDmo9VxrlgSK+72wkf8mzB7 QuuQ== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:mime-version:content-transfer-encoding :content-language:accept-language:message-id:date:thread-index :thread-topic:subject:cc:to:from; bh=jXVm1UUIPb8spAKqFRCQQKdSSLIVXhXfEx+Jna1+XSs=; b=T5EujiEQO/v1x4KzKJAqJ+HN4YhK7mB+Mi25S3a8OH14//pODCTZ3yy7GONxq103Sw Q7R57x01D2tBEeAQ2RIy3hbUoNuVV101ttokUl7KO+zpHX+H8s7KI0LHCnbt0ZELe9eY 9/E4JoKyI3tUYsNxrxs4CxRvBElJ2rnkC4bFnUCa4eSwOoyLxY7Y29XriKZoC5pYDGpQ 3eDV5mRMgTfMKJzkDVxmLIoO1uycNdqHA6x8qmQQOHsUbsO5uCQu14PbSvi/QGWN7Nq/ eDGmal+D5RUiDvCvk+q0CfhYWYFRTXQuFmv/sSwUqwVAF+oBo3FtQK6z/Jk2OWAYE1aU MH/g== 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 Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id f18si672781otf.166.2020.02.27.17.51.33; Thu, 27 Feb 2020 17:51:48 -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 Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1730493AbgB1Buu convert rfc822-to-8bit (ORCPT + 99 others); Thu, 27 Feb 2020 20:50:50 -0500 Received: from szxga02-in.huawei.com ([45.249.212.188]:3028 "EHLO huawei.com" rhost-flags-OK-OK-OK-FAIL) by vger.kernel.org with ESMTP id S1730343AbgB1Buu (ORCPT ); Thu, 27 Feb 2020 20:50:50 -0500 Received: from DGGEMM401-HUB.china.huawei.com (unknown [172.30.72.56]) by Forcepoint Email with ESMTP id B289FC0E010F0FE6498C; Fri, 28 Feb 2020 09:50:44 +0800 (CST) Received: from dggeme702-chm.china.huawei.com (10.1.199.98) by DGGEMM401-HUB.china.huawei.com (10.3.20.209) with Microsoft SMTP Server (TLS) id 14.3.439.0; Fri, 28 Feb 2020 09:50:44 +0800 Received: from dggeme753-chm.china.huawei.com (10.3.19.99) by dggeme702-chm.china.huawei.com (10.1.199.98) with Microsoft SMTP Server (version=TLS1_2, cipher=TLS_ECDHE_RSA_WITH_AES_128_CBC_SHA256_P256) id 15.1.1713.5; Fri, 28 Feb 2020 09:50:43 +0800 Received: from dggeme753-chm.china.huawei.com ([10.7.64.70]) by dggeme753-chm.china.huawei.com ([10.7.64.70]) with mapi id 15.01.1713.004; Fri, 28 Feb 2020 09:50:44 +0800 From: linmiaohe To: Sean Christopherson CC: Paolo Bonzini , Vitaly Kuznetsov , Wanpeng Li , Jim Mattson , Joerg Roedel , "kvm@vger.kernel.org" , "linux-kernel@vger.kernel.org" , Xiaoyao Li Subject: Re: [PATCH] KVM: nVMX: Consult only the "basic" exit reason when routing nested exit Thread-Topic: [PATCH] KVM: nVMX: Consult only the "basic" exit reason when routing nested exit Thread-Index: AdXt2LzqeRxPdhtitkuPjSs9pAY5dw== Date: Fri, 28 Feb 2020 01:50:44 +0000 Message-ID: <22e24adec35f4a519070e1dbd0fcf858@huawei.com> Accept-Language: en-US Content-Language: zh-CN X-MS-Has-Attach: X-MS-TNEF-Correlator: x-originating-ip: [10.173.221.158] Content-Type: text/plain; charset="us-ascii" Content-Transfer-Encoding: 8BIT MIME-Version: 1.0 X-CFilter-Loop: Reflected Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org Sean Christopherson writes: >Consult only the basic exit reason, i.e. bits 15:0 of vmcs.EXIT_REASON, when determining whether a nested VM-Exit should be reflected into L1 or handled by KVM in L0. > >For better or worse, the switch statement in nested_vmx_exit_reflected() currently defaults to "true", i.e. reflects any nested VM-Exit without dedicated logic. Because the case statements only contain the basic exit reason, any VM-Exit with modifier bits set will be reflected to L1, even if KVM intended to handle it in L0. > >Practically speaking, this only affects EXIT_REASON_MCE_DURING_VMENTRY, i.e. a #MC that occurs on nested VM-Enter would be incorrectly routed to L1, as "failed VM-Entry" is the only modifier that KVM can currently encounter. The SMM modifiers will never be generated as KVM doesn't support/employ a SMI Transfer Monitor. Ditto for "exit from enclave", as KVM doesn't yet support virtualizing SGX, i.e. it's impossible to enter an enclave in a KVM guest (L1 or L2). > Nice catch! There are similar patch catching this exit reson error. Reviewed-by: Miaohe Lin >Fixes: 644d711aa0e1 ("KVM: nVMX: Deciding if L0 or L1 should handle an L2 exit") >Cc: Jim Mattson >Cc: Xiaoyao Li >Cc: stable@vger.kernel.org >Signed-off-by: Sean Christopherson >---