Re: [PATCH 1/1] rasd: Use perf_evlist__open() instead of open coded
From: Arnaldo Carvalho de Melo
Date: Tue Oct 07 2014 - 09:32:49 EST
Em Tue, Oct 07, 2014 at 10:45:14AM +0200, Jean Pihet escreveu:
> > --- a/src/rasd.c
> > - evlist__for_each(evlist, c) {
> > - /* On all online cpus by default, system wide tracing */
> > - if (perf_evsel__open(c, evlist->cpus, NULL) < 0)
> > - err("opening tracepoint, are you root?");
> > - }
> > - perf_evlist__set_id_pos(evlist);
> > + /* On all online cpus by default, system wide tracing */
> > + if (perf_evlist__open(evlist) < 0)
> > + err("opening tracepoint, are you root?");
> That way the system wide tracing does not work. perf_evlist__open uses
> a non-NULL thread mapping and so it only traces the events generated
> by the daemon itself.
> perf top uses a similar approach but uses a lot of code in machine.c
> (machine__synthesize_threads) and util/event.c
> (perf_event__synthesize_threads) to synthesize the threads etc., which
> we want to avoid in the minimalistic approach of rasd.
Humm, I will look into making it support this usecase, the point of
evsel/evlist is to try to abstract away as much as possible, leaving
just a few methods to be used by tools.
I think the default for perf_evlist__open() should be the most useful
for the majority of tools, which I thought would serve rasd well. It is
not the case, so I'll into how the tools that currently use
perf_evlist__open() behave and try to get a sane default in place.
Hopefully we will completely remove the need to set up any thread or cpu
map, as what you want is syswide tracing, right?
- Arnaldo
> Maybe I missed something about the system wide tracing, any suggestion
> is welcome.
>
> Thanks for looking!
>
> Jean
>
> >
> > /* mmap buffers */
> > if (perf_evlist__mmap(evlist, 4 /* opts->mmap_pages */, false) < 0)
> > --
> > 1.9.3
> >
--
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/