Received: by 2002:a05:6a10:d5a5:0:0:0:0 with SMTP id gn37csp3118058pxb; Sat, 9 Oct 2021 02:11:26 -0700 (PDT) X-Google-Smtp-Source: ABdhPJx0ltT2wPApDAALJ++MrtJQhydjf+53EqxTwSspNIj0V9Hrcwjxf0LezBHhsaiH4Sey9fvm X-Received: by 2002:a17:906:1755:: with SMTP id d21mr10583753eje.257.1633770685715; Sat, 09 Oct 2021 02:11:25 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1633770685; cv=none; d=google.com; s=arc-20160816; b=ZAfUcRT01s3+GzAy09CH1dSdzZU91GqG7GguPtTE9MjTuieop8t54W+4kBT5fH0R/h x0/qVz6FRCGqNDcFkCBOtM6AKxIWHm/YdU2Kd62Ed5zEhAndWpM2cmOIv8kcssMei3ox uyOFB9o4mc0TtHYB1ETKZVbWs2W8G+KbHocENgUhyYDCofPffVTuS8SR7vwBJ8MsVDXh fN336Lzz17yRrMPo2c/xLM5JB790vMvnifO4J2tvPH8aVKjFPsD6koNdN0s/D9wjofsh fCgQMJHLhJb9TLcgTXf3ZJ2ilNfxBsfqvPiOfw+eFIyoBL55ZqfK8fYtuh2xmSUPjIfr A+bw== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:message-id:date:subject:cc:to:from :dkim-signature; bh=M1+1Yip8GFzyYIhL8WE/3+73lyzOVhHwNfK4uPgNVUA=; b=edGaQA+8Xw/C3v0Kf5JQRY5TiLvi9tbo26Br7Qv7xUXu5SVJH8FKdC+o/y00uou/Sb 9VdlciJ2GX6Md9CyISLiOjxpJAYjsEqjRmNRs2GXj+VwkCFsg4BsFlh4BglmpVtbrmxf 7zxlyJLUMO/B3x314TdQd9gxlOPRr2Djo/kQ7zRO2eS9TO3ewcyg6V3ZdssJSQX1rXCu Vsi1Q21rDYrupWblmUW9O3W5FQGbPOeX4agi5v5FPXPDaBpW3Eep1masUc5BqHRLVXK3 Ex8PkzdZreGRfByQ/7HXsGHc941yhGNqZEL6NSRy9ykCuQhdhUeqMRqlZV4f8GBQ6Y7B GzYw== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@gmail.com header.s=20210112 header.b=TxSfJMqv; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=QUARANTINE dis=NONE) header.from=gmail.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [23.128.96.18]) by mx.google.com with ESMTP id n10si3856722edx.552.2021.10.09.02.11.02; Sat, 09 Oct 2021 02:11:25 -0700 (PDT) Received-SPF: pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) client-ip=23.128.96.18; Authentication-Results: mx.google.com; dkim=pass header.i=@gmail.com header.s=20210112 header.b=TxSfJMqv; spf=pass (google.com: domain of linux-kernel-owner@vger.kernel.org designates 23.128.96.18 as permitted sender) smtp.mailfrom=linux-kernel-owner@vger.kernel.org; dmarc=pass (p=NONE sp=QUARANTINE dis=NONE) header.from=gmail.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S231529AbhJIJLm (ORCPT + 99 others); Sat, 9 Oct 2021 05:11:42 -0400 Received: from lindbergh.monkeyblade.net ([23.128.96.19]:44632 "EHLO lindbergh.monkeyblade.net" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S229995AbhJIJLk (ORCPT ); Sat, 9 Oct 2021 05:11:40 -0400 Received: from mail-pl1-x631.google.com (mail-pl1-x631.google.com [IPv6:2607:f8b0:4864:20::631]) by lindbergh.monkeyblade.net (Postfix) with ESMTPS id 18D6DC061570; Sat, 9 Oct 2021 02:09:44 -0700 (PDT) Received: by mail-pl1-x631.google.com with SMTP id 21so1515973plo.13; Sat, 09 Oct 2021 02:09:44 -0700 (PDT) DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=gmail.com; s=20210112; h=from:to:cc:subject:date:message-id; bh=M1+1Yip8GFzyYIhL8WE/3+73lyzOVhHwNfK4uPgNVUA=; b=TxSfJMqva34WyinV6SrFZjI5WJv0mm07cxZh6lItXh62PrHp4Bkd98w8qgxkp+rjbG HYRbyRgaJhwbNknvStXuWi1LiAzfeCL79jsYMS8idExfOSZuGhCWBgzxK2fEqJi3WLmS uwr9/WTrtCwB6tszb4RsLpi9Wq+4pwkGY9pASkRbGJiKbwMBkmT2VWa7UYSouOXDvBo4 5wLAy4i7jN0q315/BmUWl07SWi6OO7VmVAOmuk8Mr/CmTZExrQFAulRzxCZiLvAa2xyr W57aXDUYj/9q3b1QXDaRGNGj1iLHftBuwujKOLkzzJP66QLIKc18VBGqlUT35xtQut3y 0LoQ== X-Google-DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=1e100.net; s=20210112; h=x-gm-message-state:from:to:cc:subject:date:message-id; bh=M1+1Yip8GFzyYIhL8WE/3+73lyzOVhHwNfK4uPgNVUA=; b=cdxnXG2dFEVZ3y0hlNh/tqOzB/DEGZ/HlBGUefEPkDMQnV8H35FKw07Nxs1N+OH+xR xj70oe8RzzOn4jrskWM/fJ8HuTRdsVGHS3XzdqWer6qa6RAiqrOI7PhE0UTnTqoY0lFC OFp3y1NtYBwIZB8e4fJFQIw+RzJHTYC7zXMtKnRRH2K1kJVgpnK8LiiYcQCfKAE436N+ 0WGZfYQH2TruvJJFhnCzLtrpqLkZr5RZhnYKRDcR6AUbnmBhXVtW1Cd1d3ZmFjzPlq+R hjFI8w+B0mnbGQHYbyyflgTZ68P/S8dsBfnNfXGmfAZjdRtLn0GHxwGSADowZWaTHlY5 aFkg== X-Gm-Message-State: AOAM530g0/smLwdSuO5PNrpUyZWVzJa4v41L/kvQwwFyEnPFY2QjLGsv 3bNazWc4h4vhMRDQ8gnxD+sqtOG5xKe7hg== X-Received: by 2002:a17:90a:1a06:: with SMTP id 6mr17862330pjk.150.1633770583346; Sat, 09 Oct 2021 02:09:43 -0700 (PDT) Received: from localhost.localdomain ([203.205.141.112]) by smtp.googlemail.com with ESMTPSA id u2sm13607217pji.30.2021.10.09.02.09.40 (version=TLS1_2 cipher=ECDHE-ECDSA-AES128-GCM-SHA256 bits=128/128); Sat, 09 Oct 2021 02:09:43 -0700 (PDT) From: Wanpeng Li X-Google-Original-From: Wanpeng Li To: linux-kernel@vger.kernel.org, kvm@vger.kernel.org Cc: Paolo Bonzini , Sean Christopherson , Vitaly Kuznetsov , Wanpeng Li , Jim Mattson , Joerg Roedel Subject: [PATCH v2 1/3] KVM: emulate: Don't inject #GP when emulating RDMPC if CR0.PE=0 Date: Sat, 9 Oct 2021 02:08:50 -0700 Message-Id: <1633770532-23664-1-git-send-email-wanpengli@tencent.com> X-Mailer: git-send-email 2.7.4 Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org From: Wanpeng Li DM mentioned that, RDPMC: IF (((CR4.PCE = 1) or (CPL = 0) or (CR0.PE = 0)) and (ECX indicates a supported counter)) THEN EAX := counter[31:0]; EDX := ZeroExtend(counter[MSCB:32]); ELSE (* ECX is not valid or CR4.PCE is 0 and CPL is 1, 2, or 3 and CR0.PE is 1 *) #GP(0); FI; Let's add the CR0.PE is 1 checking to rdpmc emulate, though this isn't strictly necessary since it's impossible for CPL to be >0 if CR0.PE=0. Signed-off-by: Wanpeng Li --- v1 -> v2: * update patch description arch/x86/kvm/emulate.c | 3 ++- 1 file changed, 2 insertions(+), 1 deletion(-) diff --git a/arch/x86/kvm/emulate.c b/arch/x86/kvm/emulate.c index 9a144ca8e146..ab7ec569e8c9 100644 --- a/arch/x86/kvm/emulate.c +++ b/arch/x86/kvm/emulate.c @@ -4213,6 +4213,7 @@ static int check_rdtsc(struct x86_emulate_ctxt *ctxt) static int check_rdpmc(struct x86_emulate_ctxt *ctxt) { u64 cr4 = ctxt->ops->get_cr(ctxt, 4); + u64 cr0 = ctxt->ops->get_cr(ctxt, 0); u64 rcx = reg_read(ctxt, VCPU_REGS_RCX); /* @@ -4222,7 +4223,7 @@ static int check_rdpmc(struct x86_emulate_ctxt *ctxt) if (enable_vmware_backdoor && is_vmware_backdoor_pmc(rcx)) return X86EMUL_CONTINUE; - if ((!(cr4 & X86_CR4_PCE) && ctxt->ops->cpl(ctxt)) || + if ((!(cr4 & X86_CR4_PCE) && ctxt->ops->cpl(ctxt) && (cr0 & X86_CR0_PE)) || ctxt->ops->check_pmc(ctxt, rcx)) return emulate_gp(ctxt, 0); -- 2.25.1