Re: [PATCH 1/2] ftrace: Add separate handler for ftrace:function event

From: Jiri Olsa
Date: Wed Nov 25 2015 - 11:51:07 EST


On Wed, Nov 25, 2015 at 11:19:56AM -0500, Steven Rostedt wrote:
> On Wed, 25 Nov 2015 16:45:32 +0100
> Jiri Olsa <jolsa@xxxxxxxxxx> wrote:
>
> > Having following commands running concurently:
> >
> > # perf record -e ftrace:function -a -o krava.data sleep 10
> > # perf record -e ftrace:function --filter 'ip == SyS_read' ls
> >
> > will endup in the latter one failing on the filter
> > rules and store all functions (in perf.data) as
> > instructed by the first record instead of just
> > SyS_read records.
> >
> > The reason is that we don't check the ftrace_ops that
> > triggered the event with event's ftrace_ops. Hence
> > once running together the event from latter perf will
> > get all the data of the event from the first one.
> >
> > Fixing this by having separate handler for ftrace:function
> > event that actualy checks ftrace_ops against event.
>
> This seems redundant. I never understood the control_ops that perf uses
> in the function tracing infrastructure. Why can't you just register the
> event->ops and have that ops set the filtering? Then the ftrace
> infrastructure will only call that event handler for the functions its
> filtered on. Then you don't need to do it again. Right now ftrace
> already does that with the generic "control_ops" that perf uses, but
> now you are doing it again. Seems rather pointless.

well thats exactly what we are doing.. but as all ops
share single callback we need to find the proper event
this callback was triggered for

currently we use tracepoint callback (perf_tp_event)
where the proper event is found based on the event->filter

however this is not the case for ftrace:function because
filter will not change the event->filter, but the ops filter

> I may need to spend some time looking at how perf uses the function
> tracing, and perhaps we can remove a lot of this redundancy.

that'd be cool

thanks,
jirka
--
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/