Received: by 2002:ad5:474a:0:0:0:0:0 with SMTP id i10csp922731imu; Fri, 4 Jan 2019 09:32:58 -0800 (PST) X-Google-Smtp-Source: ALg8bN4HjEe0MjL3xnZJETwzAnx9VR7+ayxxkjmjI15OQkRy/g/PxZPk22d8hDWFzFoTPr3eDJfr X-Received: by 2002:a63:504d:: with SMTP id q13mr2436147pgl.319.1546623178636; Fri, 04 Jan 2019 09:32:58 -0800 (PST) ARC-Seal: i=1; a=rsa-sha256; t=1546623178; cv=none; d=google.com; s=arc-20160816; b=IRG+YNro8oZPbUBxrFDsm2nB8HdIOG5lZKDeW/vRMjPk6qtonwUByrjmcwVPbUeh5b exaOMF2frfkAjAPJ7eWoqVWspcXaB2ZPFTzOalVtj3k8uevhGCtgKcV+B3SM4/PJTRYM zTINkXNyU1t+p3ZUuTde66iLVe+6YYO5/hyLE/rOX2AsU6Y4zooODfrr4so4Ifb46b/V eq8XnBDdGF0SDCZAluizlU88CgAUwodMsKyZEhZBVyAO53ju3V+G789rax/MP1LIkYSF H7aqrFYS7rT2/vIk5WgyT8HP+dUnWYSCBTQG6Iwr2I/vQCvL+DpyuUe2zKzXDlpZoSGS 8Jfw== 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=i/3Qa0tCL69hCWOgDyt92kPIK5oi1eECQlbUtElWYgI=; b=DDRdWUcaA1shW5kvC/oZX9BI5I30x+zoE8SeQMI0x6gLAeQwYP/ykVbDmfZvr/cXBL HApLFr8sqP5l1uF2DZ3dcD9X+ARr+B96P23BxlGkel0pG0cswCd7ELTFc08VFM9enDqs CX0a19Iihw5hRC6sw49Lng1MwRae29w1dics6UzRt2zxUnPDZ3vL23sfSwFkiDU63MBL da2NtAvZC8ko0CUsCVWEdEyB7ktvVnJqB9ejhpILU99YNiHkx0sxDOceRJRyivhIvVPT Iyk2SdDrqIvYlgYAXTV7QurWCXvtmtCk2+W2tWPV1MpgvA0UXeKFfFP3Y20XQuchGdIk QDMQ== 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 ba9si27366544plb.109.2019.01.04.09.32.42; Fri, 04 Jan 2019 09:32:58 -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 S1728294AbfADP53 (ORCPT + 99 others); Fri, 4 Jan 2019 10:57:29 -0500 Received: from mga14.intel.com ([192.55.52.115]:18506 "EHLO mga14.intel.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1727771AbfADP52 (ORCPT ); Fri, 4 Jan 2019 10:57:28 -0500 X-Amp-Result: SKIPPED(no attachment in message) X-Amp-File-Uploaded: False Received: from orsmga004.jf.intel.com ([10.7.209.38]) by fmsmga103.fm.intel.com with ESMTP/TLS/DHE-RSA-AES256-GCM-SHA384; 04 Jan 2019 07:57:28 -0800 X-ExtLoop1: 1 X-IronPort-AV: E=Sophos;i="5.56,439,1539673200"; d="scan'208";a="264427963" Received: from linux.intel.com ([10.54.29.200]) by orsmga004.jf.intel.com with ESMTP; 04 Jan 2019 07:57:28 -0800 Received: from [10.251.13.106] (kliang2-mobl1.ccr.corp.intel.com [10.251.13.106]) (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 084ED58056F; Fri, 4 Jan 2019 07:57:26 -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> <5a04d8ea-b788-6018-8b34-ebd528578916@linux.intel.com> <5C2F2E3E.7020306@intel.com> From: "Liang, Kan" Message-ID: <4e5cd929-8a28-461d-7f8f-79a2f9301b7c@linux.intel.com> Date: Fri, 4 Jan 2019 10:57:24 -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: <5C2F2E3E.7020306@intel.com> Content-Type: text/plain; charset=utf-8; format=flowed Content-Language: en-US Content-Transfer-Encoding: 8bit Sender: linux-kernel-owner@vger.kernel.org Precedence: bulk List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On 1/4/2019 4:58 AM, Wei Wang wrote: > On 01/03/2019 12:33 AM, Liang, Kan wrote: >> >> >> 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. > > Yes, we could add the comparison of the FROM msrs. > >> >>> +     */ >>> +    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. >> > > > Yes, I thought about this, but intel_pmu_init() does a lot more things > in each "Case xx". Any thought about how to factor them out? > I think we may only move the "switch (boot_cpu_data.x86_model) { ... }" to a new function, e.g. __intel_pmu_init(int model, struct x86_pmu *x86_pmu) In __intel_pmu_init, if the model != boot_cpu_data.x86_model, you only need to update x86_pmu.*. Just ignore global settings, e.g hw_cache_event_ids, mem_attr, extra_attr etc. You may also need to introduce another new function to check if the LBR is compatible with guest in lbr.c, e.g. bool is_lbr_compatible_with_guest(int model). bool is_lbr_compatible_with_guest(int model) { struct x86_pmu fake_x86_pmu; if (boot_cpu_data.x86_model == model) return true; __intel_pmu_init(model, &fake_x86_pmu); if ((x86_pmu.lbr_nr == fake_x86_pmu.lbr_nr) && (x86_pmu.lbr_tos == fake_x86_pmu.lbr_tos) && (x86_pmu.lbr_from == fake_x86_pmu.lbr_from)) return true; return false; } > >> 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. >> > > I actually tried this in the first place but it failed to work with the > existing QEMU. > For example, when we specify "Broadwell" cpu from qemu, then qemu uses > Broadwell core model, > but the physical machine I have is Broadwell X. This patch will support > this case. I mean is it good enough if we only support "-cpu host"? Thanks, Kan