Received: by 2002:a5b:505:0:0:0:0:0 with SMTP id o5csp168997ybp; Thu, 3 Oct 2019 11:46:41 -0700 (PDT) X-Google-Smtp-Source: APXvYqyOMdf570MaxD6YjmbfR+cdAs5kFFv0nJBMyHP7kE23v6ceDFGE58Q4eElHYyYl8AfvCFmW X-Received: by 2002:a17:907:441d:: with SMTP id om21mr9278162ejb.188.1570128401355; Thu, 03 Oct 2019 11:46:41 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1570128401; cv=none; d=google.com; s=arc-20160816; b=uGWc1nMAw7Ew2KydhhhI3/POnHFIXaOQA6UvnLLhAEHx3954ABuSr7UW+bPUe4Gzn3 K3VGFxf85IqzHVevYkq88jwdJTHDWELXKRWVcJM9E8zw5ks0ed/JTLgyguxsdKQjvfgu WZWPMzkEdT7G9KBkiRRrNLP3ECV5CKRpNRHLM2vd/fWmaFwskB9iVqVfNlDSNK3arBjk 5xfhboYSqsDbO4+JNOTPfJILSs62s6QAWV6CWYUwJv9Baz6ZYDpR48ZdtGzvmSn1koV3 w3SSCQFuywwmAjyD5YqlzyhuEMcJMlgXuo48U7IIpjGiOQatICxUyko97N6HqEZdgiBZ MkCQ== 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:mime-version :user-agent:references:in-reply-to:message-id:date:subject:cc:to :from:dkim-signature; bh=p+rZYjZSOYAsiuF44xh4ITE1TuSm5IelMPhYbc0xdTE=; b=DFprRF93wMr2gANo95BAbb/a6ViDenDrRuGoHftF4MZoiGhQjgE0AqjopJzxYxMuOI gKMXHKBUci88URPG+nAyjoQhMs3n70F0qMzhS0+FRY2KEaNBvSXhbiTyPwwF90bNZJLZ tYCimRlf0g/1VcDlIZ0FSzBWaRYFMDRmWsbiFSSkZJp/R8uQoXEygXLVe4sc5OEEKlIp wmsJBtHMwbwyESvCEayiC9nT+vyhYESE/rLo9dXq+5DqdG+fRVayskP7ztugWP6aL7Zz DftTMDnO9xAfYZadQI8xCBrLES+nC6mQiNSpb1tLZ/MbE/4rqcl91UCDlOEMUB573Qsy 2Z9A== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@kernel.org header.s=default header.b=x+SPhiLv; 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 c8si2260223edb.82.2019.10.03.11.46.17; Thu, 03 Oct 2019 11:46:41 -0700 (PDT) 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; dkim=pass header.i=@kernel.org header.s=default header.b=x+SPhiLv; 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 S1731395AbfJCP7o (ORCPT + 99 others); Thu, 3 Oct 2019 11:59:44 -0400 Received: from mail.kernel.org ([198.145.29.99]:42842 "EHLO mail.kernel.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1731378AbfJCP7m (ORCPT ); Thu, 3 Oct 2019 11:59:42 -0400 Received: from localhost (83-86-89-107.cable.dynamic.v4.ziggo.nl [83.86.89.107]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by mail.kernel.org (Postfix) with ESMTPSA id 5AF5A21D81; Thu, 3 Oct 2019 15:59:40 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=kernel.org; s=default; t=1570118380; bh=h0rsyqVWWEVXXs6hc1a5kbfGdU7JSDnYzCi6ysQNAjw=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=x+SPhiLvgXVdkNPsxvVftd7DhjHEL8V3/5iMHwnNktOh6Cx3BLr/nS2Zo2tjK51gP fWkWINAqEqyI4/wME2g4k6mHz/obFZZPgBPqcQXHyb0gtq9OF2KwNWEUsIK/TPj/ko VNgBO+Hqswpk2hwSqj9TTIJVF2IGqknsrISBZ5BA= From: Greg Kroah-Hartman To: linux-kernel@vger.kernel.org Cc: Greg Kroah-Hartman , stable@vger.kernel.org, Nadav Amit , Doug Reiland , Sean Christopherson , Peter Xu , Paolo Bonzini Subject: [PATCH 4.4 83/99] KVM: x86: Manually calculate reserved bits when loading PDPTRS Date: Thu, 3 Oct 2019 17:53:46 +0200 Message-Id: <20191003154336.641144460@linuxfoundation.org> X-Mailer: git-send-email 2.23.0 In-Reply-To: <20191003154252.297991283@linuxfoundation.org> References: <20191003154252.297991283@linuxfoundation.org> User-Agent: quilt/0.66 MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org From: Sean Christopherson commit 16cfacc8085782dab8e365979356ce1ca87fd6cc upstream. Manually generate the PDPTR reserved bit mask when explicitly loading PDPTRs. The reserved bits that are being tracked by the MMU reflect the current paging mode, which is unlikely to be PAE paging in the vast majority of flows that use load_pdptrs(), e.g. CR0 and CR4 emulation, __set_sregs(), etc... This can cause KVM to incorrectly signal a bad PDPTR, or more likely, miss a reserved bit check and subsequently fail a VM-Enter due to a bad VMCS.GUEST_PDPTR. Add a one off helper to generate the reserved bits instead of sharing code across the MMU's calculations and the PDPTR emulation. The PDPTR reserved bits are basically set in stone, and pushing a helper into the MMU's calculation adds unnecessary complexity without improving readability. Oppurtunistically fix/update the comment for load_pdptrs(). Note, the buggy commit also introduced a deliberate functional change, "Also remove bit 5-6 from rsvd_bits_mask per latest SDM.", which was effectively (and correctly) reverted by commit cd9ae5fe47df ("KVM: x86: Fix page-tables reserved bits"). A bit of SDM archaeology shows that the SDM from late 2008 had a bug (likely a copy+paste error) where it listed bits 6:5 as AVL and A for PDPTEs used for 4k entries but reserved for 2mb entries. I.e. the SDM contradicted itself, and bits 6:5 are and always have been reserved. Fixes: 20c466b56168d ("KVM: Use rsvd_bits_mask in load_pdptrs()") Cc: stable@vger.kernel.org Cc: Nadav Amit Reported-by: Doug Reiland Signed-off-by: Sean Christopherson Reviewed-by: Peter Xu Signed-off-by: Paolo Bonzini Signed-off-by: Greg Kroah-Hartman --- arch/x86/kvm/x86.c | 11 ++++++++--- 1 file changed, 8 insertions(+), 3 deletions(-) --- a/arch/x86/kvm/x86.c +++ b/arch/x86/kvm/x86.c @@ -523,8 +523,14 @@ static int kvm_read_nested_guest_page(st data, offset, len, access); } +static inline u64 pdptr_rsvd_bits(struct kvm_vcpu *vcpu) +{ + return rsvd_bits(cpuid_maxphyaddr(vcpu), 63) | rsvd_bits(5, 8) | + rsvd_bits(1, 2); +} + /* - * Load the pae pdptrs. Return true is they are all valid. + * Load the pae pdptrs. Return 1 if they are all valid, 0 otherwise. */ int load_pdptrs(struct kvm_vcpu *vcpu, struct kvm_mmu *mmu, unsigned long cr3) { @@ -543,8 +549,7 @@ int load_pdptrs(struct kvm_vcpu *vcpu, s } for (i = 0; i < ARRAY_SIZE(pdpte); ++i) { if (is_present_gpte(pdpte[i]) && - (pdpte[i] & - vcpu->arch.mmu.guest_rsvd_check.rsvd_bits_mask[0][2])) { + (pdpte[i] & pdptr_rsvd_bits(vcpu))) { ret = 0; goto out; }