Received: by 2002:a25:ad19:0:0:0:0:0 with SMTP id y25csp10419363ybi; Wed, 24 Jul 2019 22:53:41 -0700 (PDT) X-Google-Smtp-Source: APXvYqwhTHUT1DF7Pj6NejeIsDSgMYMmGOukFqgUNIHGw4W3weA7sY/x/hyjemK4ts7Cqo+Q01IR X-Received: by 2002:a17:902:61:: with SMTP id 88mr85172503pla.50.1564034021128; Wed, 24 Jul 2019 22:53:41 -0700 (PDT) ARC-Seal: i=1; a=rsa-sha256; t=1564034021; cv=none; d=google.com; s=arc-20160816; b=poqC1gAp1aHMreZCGnPOdQzpYVXijisSAPb6YPrG0HkkBcmfrxpKJX5s7w8ylQlckW VC7zVyZTrKSs7BZPni/ckcGJbVx7Ai8SV+vwwLBKDx4UL9Gs/ri1lOL4vt/Kqa2zKs8h OduI4yfszXtmXrAd/LwAm6AbZV+4pU/fR++ZnlePm+5/rwzPtNb4eWGKv4Zo79uqGVCq kjRCrv+Apx/cfW6QRSenUx/iXr2nJF3kcPI3IsseT0e9yRmq6ErAaJllHKqSt6PGq9MU ifZvJ6SDeFdFbKXixo3qXQb+CE17EbkLGX5wDVH6hOjguoubpGbzYS33knJMmoAZmErl Jz7w== ARC-Message-Signature: i=1; a=rsa-sha256; c=relaxed/relaxed; d=google.com; s=arc-20160816; h=list-id:precedence:sender:message-id:date:subject:cc:to:from :dkim-signature; bh=X4pW0WBzhMJy4dgkexPh9ckOKMeErig/SG1EBztU1FM=; b=OJGlnSISq2dSE1WTekpc9/PXUrbciyHa8UpW9xRVjdgS0jRNE6367/ZngE/6XRPMLW 3yMJb0VaHoOR/+M+Zczj7GtvzZ1On498TTbjbuW5fPIGQ8Txqj9C8tE2BcVpFQfq6pvv zo64PM7LjtoFHYPX9YVHup0GhM0ab9MlkTJ/mMfxst9A6pTwwyl4vj/q6200dqasl9NE p8rjutSotVuJIH/J9XLTsbPjQZb/jR4t8JUzsnmTJAQorHYMHFYSZ5Oncw4qu5hKLOYl fpVF8fiqs7wA17FRIS1UfNi10CAPQ/0IWcrIUWmL1fesirmrp6QusExiH73Dw1IHMRuJ mKVQ== ARC-Authentication-Results: i=1; mx.google.com; dkim=pass header.i=@oracle.com header.s=corp-2018-07-02 header.b="b/vgNDFH"; 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; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=oracle.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id r12si15749114pgm.473.2019.07.24.22.53.25; Wed, 24 Jul 2019 22:53: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=@oracle.com header.s=corp-2018-07-02 header.b="b/vgNDFH"; 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; dmarc=pass (p=NONE sp=NONE dis=NONE) header.from=oracle.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S2389259AbfGYCkO (ORCPT + 99 others); Wed, 24 Jul 2019 22:40:14 -0400 Received: from userp2120.oracle.com ([156.151.31.85]:44706 "EHLO userp2120.oracle.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S2389231AbfGYCkN (ORCPT ); Wed, 24 Jul 2019 22:40:13 -0400 Received: from pps.filterd (userp2120.oracle.com [127.0.0.1]) by userp2120.oracle.com (8.16.0.27/8.16.0.27) with SMTP id x6P2dANN060256; Thu, 25 Jul 2019 02:39:38 GMT DKIM-Signature: v=1; a=rsa-sha256; c=relaxed/relaxed; d=oracle.com; h=from : to : cc : subject : date : message-id; s=corp-2018-07-02; bh=X4pW0WBzhMJy4dgkexPh9ckOKMeErig/SG1EBztU1FM=; b=b/vgNDFH29B2+JKpLyhJ9tvs3j3Py6ijhmWHFh5NHDuKd9Ho0Cycv/uPDbakmuJUKTFr YTjckC8wVE9Hc7MosV7oDL+tDd6DsGy5Jck+ARTohaYa08PC2+aQljQSVAC73lPE/Bdq M5d2/ZGPRgSwDFZ0Tl1dV4xoTUvINiN5deMqOePUfFppgJCeaKfbJ7NfZngSKBRWja7B YKaoZ7ZJQ3CGkt+WoED2Gw2wJNmR99dz54Uc2CWt5bHQ1xxZw7FsN1c5ZEJ0wnz0qjRv pYsD2neDBWB4pS9bhkCvaevjC9PL3WtHVI1MylUwTOFrTGGHSSjdvJVrBiEXV0uQwWIF OA== Received: from userp3030.oracle.com (userp3030.oracle.com [156.151.31.80]) by userp2120.oracle.com with ESMTP id 2tx61c0uqn-1 (version=TLSv1.2 cipher=ECDHE-RSA-AES256-GCM-SHA384 bits=256 verify=OK); Thu, 25 Jul 2019 02:39:38 +0000 Received: from pps.filterd (userp3030.oracle.com [127.0.0.1]) by userp3030.oracle.com (8.16.0.27/8.16.0.27) with SMTP id x6P2cA27058177; Thu, 25 Jul 2019 02:39:38 GMT Received: from aserv0121.oracle.com (aserv0121.oracle.com [141.146.126.235]) by userp3030.oracle.com with ESMTP id 2tx60y23k7-1 (version=TLSv1.2 cipher=ECDHE-RSA-AES256-GCM-SHA384 bits=256 verify=OK); Thu, 25 Jul 2019 02:39:38 +0000 Received: from abhmp0010.oracle.com (abhmp0010.oracle.com [141.146.116.16]) by aserv0121.oracle.com (8.14.4/8.13.8) with ESMTP id x6P2dZ1F021491; Thu, 25 Jul 2019 02:39:36 GMT Received: from z2.cn.oracle.com (/10.182.71.205) by default (Oracle Beehive Gateway v4.0) with ESMTP ; Wed, 24 Jul 2019 19:39:35 -0700 From: Zhenzhong Duan To: linux-kernel@vger.kernel.org Cc: x86@kernel.org, Zhenzhong Duan , Peter Zijlstra , Arnaldo Carvalho de Melo , Alexander Shishkin , Jiri Olsa , Namhyung Kim , Thomas Gleixner , Ingo Molnar , Borislav Petkov , Juergen Gross , Boris Ostrovsky Subject: [PATCH] perf/x86: Apply more accurate check on hypervisor platform Date: Thu, 25 Jul 2019 10:39:26 +0800 Message-Id: <1564022366-18293-1-git-send-email-zhenzhong.duan@oracle.com> X-Mailer: git-send-email 1.8.3.1 X-Proofpoint-Virus-Version: vendor=nai engine=6000 definitions=9328 signatures=668685 X-Proofpoint-Spam-Details: rule=notspam policy=default score=0 suspectscore=1 malwarescore=0 phishscore=0 bulkscore=0 spamscore=0 mlxscore=0 mlxlogscore=999 adultscore=0 classifier=spam adjust=0 reason=mlx scancount=1 engine=8.0.1-1906280000 definitions=main-1907250029 X-Proofpoint-Virus-Version: vendor=nai engine=6000 definitions=9328 signatures=668685 X-Proofpoint-Spam-Details: rule=notspam policy=default score=0 priorityscore=1501 malwarescore=0 suspectscore=1 phishscore=0 bulkscore=0 spamscore=0 clxscore=1011 lowpriorityscore=0 mlxscore=0 impostorscore=0 mlxlogscore=999 adultscore=0 classifier=spam adjust=0 reason=mlx scancount=1 engine=8.0.1-1906280000 definitions=main-1907250029 Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org check_msr is used to fix a bug report in guest where KVM doesn't support LBR MSR and cause #GP. The msr check is bypassed on real HW to workaround a false failure, see commit d0e1a507bdc7 ("perf/x86/intel: Disable check_msr for real HW") When running a guest with CONFIG_HYPERVISOR_GUEST not set or "nopv" enabled, current check isn't enough and #GP could trigger. Signed-off-by: Zhenzhong Duan Cc: Peter Zijlstra Cc: Arnaldo Carvalho de Melo Cc: Alexander Shishkin Cc: Jiri Olsa Cc: Namhyung Kim Cc: Thomas Gleixner Cc: Ingo Molnar Cc: Borislav Petkov Cc: Juergen Gross Cc: Boris Ostrovsky --- arch/x86/events/intel/core.c | 3 +-- 1 file changed, 1 insertion(+), 2 deletions(-) diff --git a/arch/x86/events/intel/core.c b/arch/x86/events/intel/core.c index 9e911a9..86f3656 100644 --- a/arch/x86/events/intel/core.c +++ b/arch/x86/events/intel/core.c @@ -20,7 +20,6 @@ #include #include #include -#include #include "../perf_event.h" @@ -4053,7 +4052,7 @@ static bool check_msr(unsigned long msr, u64 mask) * Disable the check for real HW, so we don't * mess with potentionaly enabled registers: */ - if (hypervisor_is_type(X86_HYPER_NATIVE)) + if (!boot_cpu_has(X86_FEATURE_HYPERVISOR)) return true; /* -- 1.8.3.1