From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1753521AbbLIXhc (ORCPT ); Wed, 9 Dec 2015 18:37:32 -0500 Received: from bombadil.infradead.org ([198.137.202.9]:57040 "EHLO bombadil.infradead.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1751297AbbLIXhb (ORCPT ); Wed, 9 Dec 2015 18:37:31 -0500 Date: Thu, 10 Dec 2015 00:37:27 +0100 From: Peter Zijlstra To: Harish Chegondi Cc: linux-kernel@vger.kernel.org, mingo@redhat.com, Harish Chegondi , Andi Kleen , Kan Liang , Lukasz Anaczkowski Subject: Re: [PATCH 1/1] perf/x86/intel: Add perf core PMU support for Intel Knights Landing Message-ID: <20151209233727.GS6356@twins.programming.kicks-ass.net> References: <20151208083757.GD6356@twins.programming.kicks-ass.net> <5668B7B4.9070102@intel.com> MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline In-Reply-To: <5668B7B4.9070102@intel.com> User-Agent: Mutt/1.5.21 (2012-12-30) Sender: linux-kernel-owner@vger.kernel.org List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Wed, Dec 09, 2015 at 03:22:29PM -0800, Harish Chegondi wrote: > On 12/08/2015 12:37 AM, Peter Zijlstra wrote: > > On Mon, Dec 07, 2015 at 02:28:18PM -0800, Harish Chegondi wrote: > >> Knights Landing core is based on Silvermont core with several differences. > >> Like Silvermont, Knights Landing has 8 pairs of LBR MSRs. However, the > >> LBR MSRs addresses match those of the Xeon cores' first 8 pairs of LBR MSRs > > > >> +/* Knights Landing */ > >> +void intel_pmu_lbr_init_knl(void) > >> +{ > >> + x86_pmu.lbr_nr = 8; > >> + x86_pmu.lbr_tos = MSR_LBR_TOS; > >> + x86_pmu.lbr_from = MSR_LBR_NHM_FROM; > >> + x86_pmu.lbr_to = MSR_LBR_NHM_TO; > >> + > >> + x86_pmu.lbr_sel_mask = LBR_SEL_MASK; > >> + x86_pmu.lbr_sel_map = snb_lbr_sel_map; > > Also, unlike Silvermont, this thing seems to have hardware LBR filters. > > So would it not be more accurate to say the KNL has a big core LBR > > instead? (Note that this LBR setup isn't specific to Xeon's, all of the > > Core chips have this, including the client parts). > We cannot say that KNL has a big core LBR. This is because > architectural MSR IA32_PERF_CAPABILITIES[5:0] which indicates the > format of the address that is stored in the LBR stack is different for > KNL (IA32_PERF_CAPABILITIES[5:0] = 0x1) and big core (for example, > Haswell IA32_PERF_CAPABILITIES[5:0]=0x4). Haswell LBR stack has TSX > info which KNL LBR stack doesn't have. Fair enough I suppose. Applied the patch.