Re: disabling group leader perf_event

From: Steven Rostedt
Date: Mon Sep 06 2010 - 09:17:31 EST


Sorry for top post, sending via my android phone. Today's a US holiday.


We can filter before the work, if we expose the parameters. Currently we filter what goes into the buffer and there are several cases where we don't know the result before the work.

If we also expose the parameters of a TRACE_EVENT, then we can filter on them before the work.

-- Steve

"Ingo Molnar" <mingo@xxxxxxx> wrote:

>
>* Peter Zijlstra <peterz@xxxxxxxxxxxxx> wrote:
>
>> On Mon, 2010-09-06 at 14:58 +0300, Avi Kivity wrote:
>> > On 09/06/2010 02:54 PM, Peter Zijlstra wrote:
>> > >
>> > >> Basically, to read() all events in one go. I have many of them.
>> > >>
>> > >> My current problem is that I have an event (kvm_exit) which I want to
>> > >> drill down by looking at a field (exit_reason). So I create lots of
>> > >> separate perf_events with a filter for each reason:
>> > >> kvm_exit(exit_reason==0), kvm_exit(exit_reason==1), etc. But filters
>> > >> are fairly slow (can have ~60 such events on AMD), so I want to make
>> > >> this drill-down optional.
>> > > Yeah, filters suck.
>> >
>> > Any idea why? I saw nothing obvious in the code, except that there
>> > is lots of it.
>>
>> It filters after it does all the hard work of creating the trace
>> event, instead of before.
>
>Btw., that's an implementational property of filters that would be nice
>to fix.
>
>If it's not doable within CPP then outside of it.
>
> Ingo

--
Sent from my Android phone with K-9 Mail. Please excuse my brevity.
--
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/