Received: by 2002:a05:6358:4e97:b0:b3:742d:4702 with SMTP id ce23csp3021884rwb; Mon, 15 Aug 2022 16:19:16 -0700 (PDT) X-Google-Smtp-Source: AA6agR4Hv0d0/LWJnxY4huPklyNcELlqOPYLRLgHbkvTGCaIWay6LLWaQQChPT/HVMUD1enVlzHQ X-Received: by 2002:a17:906:ef8f:b0:731:4a01:7781 with SMTP id ze15-20020a170906ef8f00b007314a017781mr12062299ejb.268.1660605474545; Mon, 15 Aug 2022 16:17:54 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1660605474; cv=none; d=google.com; s=arc-20160816; b=Od5csJEsVB/xiwn6nHl4B79iJ8LE5eauEaAdF/lBYHt98hmZL/QJpQ6OhT+lV8ii9b JqzE51V/OGMt3by65XZmQm7Qjln4eWcWE9F9L/A5JQiZQIRl4A4pZ2EHtn161h6eSS4h XcD99ebD19NXy2TBG4aNvvJBLaxqyaUA8LiAD6FwLuuZogHpw3oyWUZvkBO2rjdlWGau 9owfqKNezXKVfhmGHMjIDLmmsCiQTJMTvhEvO7dNXvjWv9LKDJJ5puuy55K/6g5nzwee qtk6Jbf7ntA7YK6CTyEFcBiJVKCGQIGGrSZpbGUPeyiSjsMJODX52Ed35L6rRsqLwytL sBfw== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:content-transfer-encoding:mime-version :user-agent:references:in-reply-to:message-id:date:subject:cc:to :from:dkim-signature; bh=CHbPj2xcLJ6Chkj6/3OBUnXgQjBEAAEwVt3E6DPOcLw=; b=mxvBfRngZE/4gy2wNkU9tZ/eWC3nPAWIPKXJwFiWzzWnD0NQchEkUeBgn/LrzepYWK ShpE/jO2JPq1h8udcoFg++Hi8QfQRyHPgpU0i6NxrBlL0DZSf7Wk9lz8we0mldciaYtt B0bRNHzg3oxYzj/AglecuSRJPKq6YgIOGFjnNch+wX/WszyrcPC4OX4biJVzKIAT9a7x qJo9TOS2ZYUQ1tDDZp+GN/iU53gEJ3XAVAq+vET1TnyibYURUMcP1toF+WdHXwcJg4kJ 3Upg6aCZw9HGGcoE5eRK1y41PiLYi2Du1o+0Abq3f4qQ2t+CwqV6nLsh97fPNVgqLsl0 64nA== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@linuxfoundation.org header.s=korg header.b=WuMKpeeW; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=linuxfoundation.org Return-Path: Received: from out1.vger.email (out1.vger.email. [2620:137:e000::1:20]) by mx.google.com with ESMTP id f18-20020a056402161200b0043d01fe042dsi7705743edv.518.2022.08.15.16.17.28; Mon, 15 Aug 2022 16:17:54 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) client-ip=2620:137:e000::1:20; Authentication-Results: mx.google.com; dkim=pass header.i=@linuxfoundation.org header.s=korg header.b=WuMKpeeW; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 2620:137:e000::1:20 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=linuxfoundation.org Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1347880AbiHOVxt (ORCPT + 99 others); Mon, 15 Aug 2022 17:53:49 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:44090 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1350406AbiHOVvN (ORCPT ); Mon, 15 Aug 2022 17:51:13 -0400 Received: from dfw.source.kernel.org (dfw.source.kernel.org [139.178.84.217]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 4927E105206; Mon, 15 Aug 2022 12:32:33 -0700 (PDT) Received: from smtp.kernel.org (relay.kernel.org [52.25.139.140]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by dfw.source.kernel.org (Postfix) with ESMTPS id 22AA86111E; Mon, 15 Aug 2022 19:32:32 +0000 (UTC) Received: by smtp.kernel.org (Postfix) with ESMTPSA id 10542C433C1; Mon, 15 Aug 2022 19:32:30 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=linuxfoundation.org; s=korg; t=1660591951; bh=mySok1vOxZ8AobUEstS65nGK91a8yPiksYjee/UxkvA=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=WuMKpeeWDUilIaNGALrxiDSYuOmmLK1vR6N9Y7U0Xa4gcghG/lmvRTXu43JqNy40j F6SfgCfn4QkEy6ZrhaAWhj684DqRLT6WG2KJSGfzMWZXseW9bz//6IjXbf7A6u3YYC sN5vUz9zhEF9owkdTdqdubvTYd3hybxdBHM7bIM8= From: Greg Kroah-Hartman To: linux-kernel@vger.kernel.org Cc: Greg Kroah-Hartman , stable@vger.kernel.org, Eric Li , Sean Christopherson , Paolo Bonzini Subject: [PATCH 5.19 0035/1157] KVM: nVMX: Inject #UD if VMXON is attempted with incompatible CR0/CR4 Date: Mon, 15 Aug 2022 19:49:51 +0200 Message-Id: <20220815180440.842609098@linuxfoundation.org> X-Mailer: git-send-email 2.37.2 In-Reply-To: <20220815180439.416659447@linuxfoundation.org> References: <20220815180439.416659447@linuxfoundation.org> User-Agent: quilt/0.67 MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit X-Spam-Status: No, score=-7.1 required=5.0 tests=BAYES_00,DKIMWL_WL_HIGH, DKIM_SIGNED,DKIM_VALID,DKIM_VALID_AU,DKIM_VALID_EF,RCVD_IN_DNSWL_HI, SPF_HELO_NONE,SPF_PASS,T_SCC_BODY_TEXT_LINE autolearn=ham autolearn_force=no version=3.4.6 X-Spam-Checker-Version: SpamAssassin 3.4.6 (2021-04-09) on lindbergh.monkeyblade.net Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org From: Sean Christopherson commit c7d855c2aff2d511fd60ee2e356134c4fb394799 upstream. Inject a #UD if L1 attempts VMXON with a CR0 or CR4 that is disallowed per the associated nested VMX MSRs' fixed0/1 settings. KVM cannot rely on hardware to perform the checks, even for the few checks that have higher priority than VM-Exit, as (a) KVM may have forced CR0/CR4 bits in hardware while running the guest, (b) there may incompatible CR0/CR4 bits that have lower priority than VM-Exit, e.g. CR0.NE, and (c) userspace may have further restricted the allowed CR0/CR4 values by manipulating the guest's nested VMX MSRs. Note, despite a very strong desire to throw shade at Jim, commit 70f3aac964ae ("kvm: nVMX: Remove superfluous VMX instruction fault checks") is not to blame for the buggy behavior (though the comment...). That commit only removed the CR0.PE, EFLAGS.VM, and COMPATIBILITY mode checks (though it did erroneously drop the CPL check, but that has already been remedied). KVM may force CR0.PE=1, but will do so only when also forcing EFLAGS.VM=1 to emulate Real Mode, i.e. hardware will still #UD. Link: https://bugzilla.kernel.org/show_bug.cgi?id=216033 Fixes: ec378aeef9df ("KVM: nVMX: Implement VMXON and VMXOFF") Reported-by: Eric Li Cc: stable@vger.kernel.org Signed-off-by: Sean Christopherson Message-Id: <20220607213604.3346000-4-seanjc@google.com> Signed-off-by: Paolo Bonzini Signed-off-by: Greg Kroah-Hartman --- arch/x86/kvm/vmx/nested.c | 23 ++++++++++++++--------- 1 file changed, 14 insertions(+), 9 deletions(-) --- a/arch/x86/kvm/vmx/nested.c +++ b/arch/x86/kvm/vmx/nested.c @@ -4968,20 +4968,25 @@ static int handle_vmon(struct kvm_vcpu * | FEAT_CTL_VMX_ENABLED_OUTSIDE_SMX; /* - * The Intel VMX Instruction Reference lists a bunch of bits that are - * prerequisite to running VMXON, most notably cr4.VMXE must be set to - * 1 (see vmx_is_valid_cr4() for when we allow the guest to set this). - * Otherwise, we should fail with #UD. But most faulting conditions - * have already been checked by hardware, prior to the VM-exit for - * VMXON. We do test guest cr4.VMXE because processor CR4 always has - * that bit set to 1 in non-root mode. + * Note, KVM cannot rely on hardware to perform the CR0/CR4 #UD checks + * that have higher priority than VM-Exit (see Intel SDM's pseudocode + * for VMXON), as KVM must load valid CR0/CR4 values into hardware while + * running the guest, i.e. KVM needs to check the _guest_ values. + * + * Rely on hardware for the other two pre-VM-Exit checks, !VM86 and + * !COMPATIBILITY modes. KVM may run the guest in VM86 to emulate Real + * Mode, but KVM will never take the guest out of those modes. */ - if (!kvm_read_cr4_bits(vcpu, X86_CR4_VMXE)) { + if (!nested_host_cr0_valid(vcpu, kvm_read_cr0(vcpu)) || + !nested_host_cr4_valid(vcpu, kvm_read_cr4(vcpu))) { kvm_queue_exception(vcpu, UD_VECTOR); return 1; } - /* CPL=0 must be checked manually. */ + /* + * CPL=0 and all other checks that are lower priority than VM-Exit must + * be checked manually. + */ if (vmx_get_cpl(vcpu)) { kvm_inject_gp(vcpu, 0); return 1;