From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S933792AbcK2SLd (ORCPT ); Tue, 29 Nov 2016 13:11:33 -0500 Received: from mail-yw0-f179.google.com ([209.85.161.179]:33811 "EHLO mail-yw0-f179.google.com" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S933745AbcK2SLZ (ORCPT ); Tue, 29 Nov 2016 13:11:25 -0500 MIME-Version: 1.0 In-Reply-To: <20161129173055.GP3092@twins.programming.kicks-ass.net> References: <1480361206-1702-1-git-send-email-kan.liang@intel.com> <20161129092520.GB3092@twins.programming.kicks-ass.net> <20161129173055.GP3092@twins.programming.kicks-ass.net> From: Stephane Eranian Date: Tue, 29 Nov 2016 10:11:23 -0800 Message-ID: Subject: Re: [PATCH] perf/x86: fix event counter update issue To: Peter Zijlstra Cc: "Liang, Kan" , "mingo@redhat.com" , LKML , Alexander Shishkin , "ak@linux.intel.com" , "Odzioba, Lukasz" Content-Type: text/plain; charset=UTF-8 Sender: linux-kernel-owner@vger.kernel.org List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Tue, Nov 29, 2016 at 9:30 AM, Peter Zijlstra wrote: > On Tue, Nov 29, 2016 at 09:20:10AM -0800, Stephane Eranian wrote: >> Max period is limited by the number of bits the kernel can write to an MSR. >> Used to be 31, now it is 47 for core PMU as per patch pointed to by Kan. > > No, I think it sets it to 48 now, which is the problem. It should be 1 > bit less than the total width. > > So something like so. > > diff --git a/arch/x86/events/intel/core.c b/arch/x86/events/intel/core.c > index a74a2dbc0180..cb8522290e6a 100644 > --- a/arch/x86/events/intel/core.c > +++ b/arch/x86/events/intel/core.c > @@ -4034,7 +4034,7 @@ __init int intel_pmu_init(void) > > /* Support full width counters using alternative MSR range */ > if (x86_pmu.intel_cap.full_width_write) { > - x86_pmu.max_period = x86_pmu.cntval_mask; > + x86_pmu.max_period = x86_pmu.cntval_mask >> 1; > x86_pmu.perfctr = MSR_IA32_PMC0; > pr_cont("full-width counters, "); > } Ah, yes! That would make it consistent with the other Intel PMU settings I see in intel/core.c such as for intel_core_pmu.max_period = (1<<31) -1 which is 0x7ffffff whereas now I see max_period of 0x0000ffffffffffff instead of 0x7fffffffffff. So I think Peter's patch is required no matter what.