Return-Path: Received: (majordomo@vger.kernel.org) by vger.kernel.org via listexpand id S1755726AbaJHLHq (ORCPT ); Wed, 8 Oct 2014 07:07:46 -0400 Received: from casper.infradead.org ([85.118.1.10]:60808 "EHLO casper.infradead.org" rhost-flags-OK-OK-OK-OK) by vger.kernel.org with ESMTP id S1754805AbaJHLHp (ORCPT ); Wed, 8 Oct 2014 07:07:45 -0400 Date: Wed, 8 Oct 2014 13:07:43 +0200 From: Peter Zijlstra To: Matt Fleming Cc: Ingo Molnar , Jiri Olsa , Arnaldo Carvalho de Melo , Thomas Gleixner , linux-kernel@vger.kernel.org, "H. Peter Anvin" , Matt Fleming , Arnaldo Carvalho de Melo Subject: Re: [PATCH 10/11] perf/x86/intel: Support task events with Intel CQM Message-ID: <20141008110743.GF4750@worktop.programming.kicks-ass.net> References: <1411567455-31264-1-git-send-email-matt@console-pimps.org> <1411567455-31264-11-git-send-email-matt@console-pimps.org> MIME-Version: 1.0 Content-Type: text/plain; charset=us-ascii Content-Disposition: inline In-Reply-To: <1411567455-31264-11-git-send-email-matt@console-pimps.org> User-Agent: Mutt/1.5.22.1 (2013-10-16) Sender: linux-kernel-owner@vger.kernel.org List-ID: X-Mailing-List: linux-kernel@vger.kernel.org On Wed, Sep 24, 2014 at 03:04:14PM +0100, Matt Fleming wrote: > From: Matt Fleming > > Add support for task events as well as system-wide events. This change > has a big impact on the way that we gather LLC occupancy values in > intel_cqm_event_read(). > > Currently, for system-wide (per-cpu) events we defer processing to > userspace which knows how to discard all but one cpu result per package. > > Things aren't so simple for task events because we need to do the value > aggregation ourselves. To do this, we defer updating the LLC occupancy > value in event->count from intel_cqm_event_read() and do an SMP > cross-call to read values for all packages in intel_cqm_event_count(). > We need to ensure that we only do this for one task event per cache > group, otherwise we'll report duplicate values. > > If we're a system-wide event we want to fallback to the default > perf_event_count() implementation. Refactor this into a common function > so that we don't duplicate the code. So it looks like these events will be classified as regular HW events, this means they'll be mixed with the other HW events, and we'll stop scheduling the moment either one returns a fail. There are two alternatives; 1) create an extra task context to keep them in 2) pretend to be a software event and do the scheduling yourself I think my initial proposal was 2, can you clarify why you've changed that? Lemme go read the next patch though, maybe that'll clarify things further. -- To unsubscribe from this list: send the line "unsubscribe linux-kernel" in the body of a message to majordomo@vger.kernel.org More majordomo info at http://vger.kernel.org/majordomo-info.html Please read the FAQ at http://www.tux.org/lkml/