Received: by 2002:ad5:474a:0:0:0:0:0 with SMTP id i10csp509578imu; Wed, 2 Jan 2019 10:50:09 -0800 (PST) X-Google-Smtp-Source: AFSGD/U/FtWzo4hmfmU+ojxUidT7lrt+te9pKGtSvusQEYGaogeB4C8FNgIZHj8uczzLikJYMNoa X-Received: by 2002:a62:2044:: with SMTP id g65mr45238921pfg.127.1546455009117; Wed, 02 Jan 2019 10:50:09 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1546455009; cv=none; d=google.com; s=arc-20160816; b=iC0vhcZMw9VuPiKJgcL4h0SQVvOQkrPqsJnDnAJy4mOJYmgzfZi5nD23A7N1nQIHUM dof5uab9o61E7/M0exV3e0DzSUuWJX9M/cQKQivvjiHDQsnhQPIAmUuhNJh8B9fzlzn/ 0HPA/457lRrpJw6V1IkE0Q7bWVhWitTjR9LItn9RihHi5Zi4n8mR0HKj/nue0oPiF266 yNLh3tYnyjKVZ1tQaO9PwY2pAgt/4c6lPNoud7v/yVh4x24w/TNc4vAMfw3Yh0h8y1mK tYZKARud9OGpQuAiS+JbgPW3gG4uC/2Or5SJcKQFMruA9pOucSpUiL9G2F8dsCKnJftf kRdQ== 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 :content-language:in-reply-to:mime-version:user-agent:date :message-id:from:references:cc:to:subject; bh=vQJb/M2/rgHuNuY/nuHj7po4tpQTpqGsfXgZAsNPEKI=; b=zxCWV3DwKx6TLmSSgle0L3Pz1XJwHGA1p8lFe+e6r63OOBLmViLwHUJcqOXo/6wcZ8 gyaFxB//3UW607yHLRHLcQQajI7Q65RTC5j0FiM247UX0UHuhmht617RB36JqlpBxn7v IqdimtcXhcLEA04AA728Lh835kFa2rzdEd1ZA26qbeiA4GjqtgcnFK3l+ETKPlW0YoBY 6h3z4+KM0BBvQS7DWstIcdvmAtROnaYpHdUmbOp0RHljrekf/gOXF39nzyzldsfpqm7Q vZWFTJSZWRG2mwIfpEiFwBPwAu3QXkk6S34TzWEp/oHfFQZ6hslek60t8/4hYrFp9It8 ckWg== ARC-Authentication-Results: i=1; mx.google.com; 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=fail (p=NONE sp=NONE dis=NONE) header.from=intel.com Return-Path: Received: from vger.kernel.org (vger.kernel.org. [209.132.180.67]) by mx.google.com with ESMTP id n13si50873655pgp.307.2019.01.02.10.49.53; Wed, 02 Jan 2019 10:50:09 -0800 (PST) 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; 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=fail (p=NONE sp=NONE dis=NONE) header.from=intel.com Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1730418AbfABQdN (ORCPT + 99 others); Wed, 2 Jan 2019 11:33:13 -0500 Received: from mga05.intel.com ([192.55.52.43]:21804 "EHLO mga05.intel.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1729365AbfABQdN (ORCPT ); Wed, 2 Jan 2019 11:33:13 -0500 X-Amp-Result: SKIPPED(no attachment in message) X-Amp-File-Uploaded: False Received: from orsmga005.jf.intel.com ([10.7.209.41]) by fmsmga105.fm.intel.com with ESMTP/TLS/DHE-RSA-AES256-GCM-SHA384; 02 Jan 2019 08:33:12 -0800 X-ExtLoop1: 1 X-IronPort-AV: E=Sophos;i="5.56,431,1539673200"; d="scan'208";a="288320204" Received: from linux.intel.com ([10.54.29.200]) by orsmga005.jf.intel.com with ESMTP; 02 Jan 2019 08:33:12 -0800 Received: from [10.251.9.84] (kliang2-mobl1.ccr.corp.intel.com [10.251.9.84]) (using TLSv1.2 with cipher ECDHE-RSA-AES128-GCM-SHA256 (128/128 bits)) (No client certificate requested) by linux.intel.com (Postfix) with ESMTPS id 724ED58056E; Wed, 2 Jan 2019 08:33:11 -0800 (PST) Subject: Re: [PATCH v4 04/10] KVM/x86: intel_pmu_lbr_enable To: Wei Wang , linux-kernel@vger.kernel.org, kvm@vger.kernel.org, pbonzini@redhat.com, ak@linux.intel.com, peterz@infradead.org Cc: kan.liang@intel.com, mingo@redhat.com, rkrcmar@redhat.com, like.xu@intel.com, jannh@google.com, arei.gonglei@huawei.com References: <1545816338-1171-1-git-send-email-wei.w.wang@intel.com> <1545816338-1171-5-git-send-email-wei.w.wang@intel.com> From: "Liang, Kan" Message-ID: <5a04d8ea-b788-6018-8b34-ebd528578916@linux.intel.com> Date: Wed, 2 Jan 2019 11:33:06 -0500 User-Agent: Mozilla/5.0 (Windows NT 10.0; WOW64; rv:52.0) Gecko/20100101 Thunderbird/52.9.1 MIME-Version: 1.0 In-Reply-To: <1545816338-1171-5-git-send-email-wei.w.wang@intel.com> Content-Type: text/plain; charset=utf-8; format=flowed Content-Language: en-US Content-Transfer-Encoding: 7bit Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On 12/26/2018 4:25 AM, Wei Wang wrote: > + > + /* > + * It could be possible that people have vcpus of old model run on > + * physcal cpus of newer model, for example a BDW guest on a SKX > + * machine (but not possible to be the other way around). > + * The BDW guest may not get accurate results on a SKX machine as it > + * only reads 16 entries of the lbr stack while there are 32 entries > + * of recordings. So we currently forbid the lbr enabling when the > + * vcpu and physical cpu see different lbr stack entries. I think it's not enough to only check number of entries. The LBR from/to MSRs may be different even the number of entries is the same, e.g SLM and KNL. > + */ > + switch (vcpu_model) { That's a duplicate of intel_pmu_init(). I think it's better to factor out the common part if you want to check LBR MSRs and entries. Then we don't need to add the same codes in two different places when enabling new platforms. Actually, I think we may just support LBR for guest if it has the identical CPU model as host. It should be good enough for now. Thanks, Kan > + case INTEL_FAM6_CORE2_MEROM: > + case INTEL_FAM6_CORE2_MEROM_L: