Received: by 2002:a05:6358:4e97:b0:b3:742d:4702 with SMTP id ce23csp2889829rwb; Mon, 15 Aug 2022 13:23:49 -0700 (PDT) X-Google-Smtp-Source: AA6agR6xMlLcMW+LFOGkcFCvLZ+vhMVt1e0XYpk3oCq5Epv158K0TyTPeN3kMVoSy1N2LmHkAFf0 X-Received: by 2002:a17:907:720f:b0:731:8a9d:5ade with SMTP id dr15-20020a170907720f00b007318a9d5ademr11128969ejc.768.1660595028766; Mon, 15 Aug 2022 13:23:48 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1660595028; cv=none; d=google.com; s=arc-20160816; b=WbX43i/dJ/nbRcGz0Nqwl+mwSHYPX3df3ClZ5PZRRwyYvi6sypWWP/Zmp8SlZixGyF TGGV8zFC//lr9vGwmfZJ0ce6hutQE6zNbk+WQpF+9kVAaK57fayXKmTiHZjdf3nLVMC7 +YEF8Ndar3qyyGz/2VayE+/J7sHlYT97UuNCfcJ5iTMvLKdVxYfD8A3z9xGwViwqXT/Y W+pWVPI5SaJOJX6/mNdaAQi3oMRKlwICGi+J9mg8TYFG2pY4L4p4oXVwH5oVhbDhAe0L hEu7Le35jLgT+FEvod2CCAEUkYYF1QobbwoCKDu5DTjltTG7hGGIE7BZSOcPiEVUvoR6 PPiA== 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=AHl3gG6xYcIsHA3yxLoSsaEZPGaVP+UOQRw/rQ6LqQk=; b=k7EggPzeLfXANq/+sjwxeoRC/QYl/0cEyVvZ/Sm5neoERUT9dWXiZFv1rlYvtjd5ZT YzsrschFtEPkA7i/1WEZ3cqH/tmgrClilJh8GXeQwuDT6P8KOekMqWcbtKYYwJjPVVJ6 QYDybeXp9VDvKrGhOlv2q7tWctUWw+8EENTYG9xDql0p0u1ULsFzWO9QXOkaIa2Cd0NJ 31AUuYgl0JwrZi5MSYa+vue6+zScC8oAwu2KNRMfA/xY6NCFRGUqLY5UjwsOXlf/forN iOnBoP8rOMgjTEaK32vmcdTTW9X3XjCZE631Qi6nDluRThMmAuQLJjxUav0oJezkZBl3 Nf7g== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@linuxfoundation.org header.s=korg header.b=kqRdFrQF; 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 w20-20020a056402269400b0043c23c5d892si9825972edd.444.2022.08.15.13.23.19; Mon, 15 Aug 2022 13:23:48 -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=kqRdFrQF; 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 S1346535AbiHOUQH (ORCPT + 99 others); Mon, 15 Aug 2022 16:16:07 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:53354 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1346247AbiHOULF (ORCPT ); Mon, 15 Aug 2022 16:11:05 -0400 Received: from ams.source.kernel.org (ams.source.kernel.org [IPv6:2604:1380:4601:e00::1]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 01F082873A; Mon, 15 Aug 2022 11:57:27 -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 ams.source.kernel.org (Postfix) with ESMTPS id 884B7B8109E; Mon, 15 Aug 2022 18:57:26 +0000 (UTC) Received: by smtp.kernel.org (Postfix) with ESMTPSA id BE1A3C43470; Mon, 15 Aug 2022 18:57:24 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=linuxfoundation.org; s=korg; t=1660589845; bh=2CHC3svalq1Gyf9BQX3NmCndAGt4dNGgpMfHUiU2LWA=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=kqRdFrQFyIwV0TVTsVorGSyqsEHMcQN1x7xRewh4LaaPdlatKoYMIMq6MsKiwk/de 1HKIyrw8cZel7kBtR3h8+Eh2+MuF1eAXLivzVlr1kmh7F8pjbBEKKKtwi5BTUc1hpn d5bZF1UA9qBhQ/WdfmRyG5OCJZzcacc4XU+81SVU= 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.18 0035/1095] KVM: nVMX: Inject #UD if VMXON is attempted with incompatible CR0/CR4 Date: Mon, 15 Aug 2022 19:50:34 +0200 Message-Id: <20220815180430.838822104@linuxfoundation.org> X-Mailer: git-send-email 2.37.2 In-Reply-To: <20220815180429.240518113@linuxfoundation.org> References: <20220815180429.240518113@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 @@ -4973,20 +4973,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;