Re: [PATCH 08/11] perf/x86/intel: Add Intel Cache QoS Monitoring support
From: Matt Fleming
Date: Wed Oct 08 2014 - 08:15:42 EST
On Wed, 08 Oct, at 11:36:58AM, Matt Fleming wrote:
> On Tue, 07 Oct, at 09:43:10PM, Peter Zijlstra wrote:
> > On Wed, Sep 24, 2014 at 03:04:12PM +0100, Matt Fleming wrote:
> > > +/*
> > > + * Determine if @a and @b measure the same set of tasks.
> > > + */
> > > +static bool __match_event(struct perf_event *a, struct perf_event *b)
> > > +{
> > > + if ((a->attach_state & PERF_ATTACH_TASK) !=
> > > + (b->attach_state & PERF_ATTACH_TASK))
> > > + return false;
> > > +
> > > + /* not task */
> > > +
> > > + return true; /* if not task, we're machine wide */
> > > +}
> >
> > You cut too much out there. That first test checks weather the two
> > events are of the same type; ie. both tasks or both cpu. After that you
> > still need to verify that they are indeed the same target.
>
> This gets fixed in PATCH 10 where we actually implement monitoring of
> task events. At this point in the series, we'll return -EINVAL from
> intel_cqm_event_init() for anything other than a cpu event.
I was having an interesting discussion with one of the teams using this
stuff at Intel and they made the suggestion that when using,
perf stat -p <pid>
we should by default opt for sharing an RMID between all tasks in that
thread group, rather that assigning a new RMID for each task, which is
what we do currently.
Right now, it's like the Oprah Winfrey of RMID assignment, "You get an
RMID, and you get an RMID!"
Which means we'll run out of RMIDs quicker, and enable the rotation code
sooner.
I'm wondering whether we should require that the user specify whether
they want per-thread monitoring if using -p, via some perf tools event
modifier, and make the record-per-thread-data scenario the exceptional
case, rather than the default?
--
Matt Fleming, Intel Open Source Technology Center
--
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at http://vger.kernel.org/majordomo-info.html
Please read the FAQ at http://www.tux.org/lkml/