Received: by 2002:a05:6358:4e97:b0:b3:742d:4702 with SMTP id ce23csp2889813rwb; Mon, 15 Aug 2022 13:23:47 -0700 (PDT) X-Google-Smtp-Source: AA6agR4IyZ8u8bt/9lafDOH3VyL4KnU9WvxKd6Hwo0ZCctm+4vgTZjgaNu/PRuZMP2hD8iZEp5cK X-Received: by 2002:a17:907:94ca:b0:731:8395:d526 with SMTP id dn10-20020a17090794ca00b007318395d526mr11095021ejc.389.1660595027629; Mon, 15 Aug 2022 13:23:47 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1660595027; cv=none; d=google.com; s=arc-20160816; b=fOHyPBJN7cD0rPKnxsEoAlEYpdWMCd60ndsxGlzwN24j5p/plvbjqfkrQ/9LQVbhg/ yVpyIManmZ4guR1JTPC0B/tnIzZK8kQps/hE7hUU3jtre140ezoulLau8Zet6zsSVF2A KXdjF7ZXHiy+ZFcNJuUtH3vkA/D68S1Fypbz78eoPzC5wp/05nkDnXobmlrgMuyq9FKJ eiDM/BwJUEeKa0OvVhx2uDc4evnYxlYqxHu+7Pz9UyzS7BsI5Eu9R/rn+pTGwKz4SSNT l+2wgFwvFOTtBVbA2MBJtVrntjiq7PhSPeYgTy9xYnjz2n+SeLEnsYDUyWNqP69opihr /0ZA== 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=JNwgf+MZH/2Um8ttPYx+B4n58O8Bip3Q6EeNiOhnUrY=; b=b+6f34CUEOX2CPee30gbWOMFJrFV7pkeV6rcREDfrArLHR12quo+XFoIlgJAe+yxNw ruOMP9hTXc7CXm9A4Iwy+QZ+oJ4161GeVQihY320ELSE5ss5BLvIOTnmHcDvPTuS9wJ0 qGBG/vc9AqS5/iW6kLxlOUUfHt77KdgbQDOqpXIguE8drJTeEhG7SFwGR3qp9+RqUuAH 8S6C4gyz43aEC7wb4cRmcGHfZCHXLd+h47i47n+yTKbO6Tevm4cmCYisFoIM47Je/7AL AOXDp0G0KAGh3H4zSgdN4hJRxK4yI1CdF/KZfSnGbn5ADpnDlY8NnZ5Uu38Fb2jczELF 7fLQ== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@linuxfoundation.org header.s=korg header.b=CvCVoxss; 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 qa7-20020a170907868700b0073092b8be95si9341320ejc.705.2022.08.15.13.23.18; Mon, 15 Aug 2022 13:23:47 -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=CvCVoxss; 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 S232662AbiHOUPe (ORCPT + 99 others); Mon, 15 Aug 2022 16:15:34 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:52762 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S242663AbiHOUJd (ORCPT ); Mon, 15 Aug 2022 16:09:33 -0400 Received: from ams.source.kernel.org (ams.source.kernel.org [145.40.68.75]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 169DB83F25; Mon, 15 Aug 2022 11:56:03 -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 7A286B81082; Mon, 15 Aug 2022 18:56:01 +0000 (UTC) Received: by smtp.kernel.org (Postfix) with ESMTPSA id 7508BC433C1; Mon, 15 Aug 2022 18:55:59 +0000 (UTC) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/simple; d=linuxfoundation.org; s=korg; t=1660589759; bh=ii10Fs2g9tmcQoujzfpb1e/bISm5/ymiR4b6QYyeZEo=; h=From:To:Cc:Subject:Date:In-Reply-To:References:From; b=CvCVoxssRdoRGe+8pq7PZo7pRe59BE7zxg1VHZh8i7ois8r6oosgSbPW0rjfQNvry b0WTeUeL6/EDzgr3KvyE5iYPhijpfPTjeYEkc9xEPb33876ivClECJbZQfOwWmYXFV 5VuhnyxJi6FkPLX4MIJCVQMN+RgRL+CdSS6E20cg= From: Greg Kroah-Hartman To: linux-kernel@vger.kernel.org Cc: Greg Kroah-Hartman , stable@vger.kernel.org, David Woodhouse , Paolo Bonzini Subject: [PATCH 5.18 0040/1095] KVM: x86: do not report preemption if the steal time cache is stale Date: Mon, 15 Aug 2022 19:50:39 +0200 Message-Id: <20220815180431.074751502@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: Paolo Bonzini commit c3c28d24d910a746b02f496d190e0e8c6560224b upstream. Commit 7e2175ebd695 ("KVM: x86: Fix recording of guest steal time / preempted status", 2021-11-11) open coded the previous call to kvm_map_gfn, but in doing so it dropped the comparison between the cached guest physical address and the one in the MSR. This cause an incorrect cache hit if the guest modifies the steal time address while the memslots remain the same. This can happen with kexec, in which case the preempted bit is written at the address used by the old kernel instead of the old one. Cc: David Woodhouse Cc: stable@vger.kernel.org Fixes: 7e2175ebd695 ("KVM: x86: Fix recording of guest steal time / preempted status") Signed-off-by: Paolo Bonzini Signed-off-by: Greg Kroah-Hartman --- arch/x86/kvm/x86.c | 2 ++ 1 file changed, 2 insertions(+) --- a/arch/x86/kvm/x86.c +++ b/arch/x86/kvm/x86.c @@ -4614,6 +4614,7 @@ static void kvm_steal_time_set_preempted struct kvm_steal_time __user *st; struct kvm_memslots *slots; static const u8 preempted = KVM_VCPU_PREEMPTED; + gpa_t gpa = vcpu->arch.st.msr_val & KVM_STEAL_VALID_BITS; /* * The vCPU can be marked preempted if and only if the VM-Exit was on @@ -4641,6 +4642,7 @@ static void kvm_steal_time_set_preempted slots = kvm_memslots(vcpu->kvm); if (unlikely(slots->generation != ghc->generation || + gpa != ghc->gpa || kvm_is_error_hva(ghc->hva) || !ghc->memslot)) return;