mirror of
https://github.com/Fishwaldo/Star64_linux.git
synced 2025-07-22 23:04:43 +00:00
perf session: Pass evsel in event_ops->sample()
Resolving the sample->id to an evsel since the most advanced tools, report and annotate, and the others will too when they evolve to properly support multi-event perf.data files. Good also because it does an extra validation, checking that the ID is valid when present. When that is not the case, the overhead is just a branch + function call (perf_evlist__id2evsel). Cc: Frederic Weisbecker <fweisbec@gmail.com> Cc: Ingo Molnar <mingo@elte.hu> Cc: Mike Galbraith <efault@gmx.de> Cc: Paul Mackerras <paulus@samba.org> Cc: Peter Zijlstra <peterz@infradead.org> Cc: Stephane Eranian <eranian@google.com> Cc: Tom Zanussi <tzanussi@gmail.com> LKML-Reference: <new-submission> Signed-off-by: Arnaldo Carvalho de Melo <acme@redhat.com>
This commit is contained in:
parent
880f573184
commit
9e69c21082
17 changed files with 73 additions and 46 deletions
|
@ -42,9 +42,9 @@ static const char *sym_hist_filter;
|
|||
|
||||
static int perf_evlist__add_sample(struct perf_evlist *evlist,
|
||||
struct perf_sample *sample,
|
||||
struct perf_evsel *evsel,
|
||||
struct addr_location *al)
|
||||
{
|
||||
struct perf_evsel *evsel;
|
||||
struct hist_entry *he;
|
||||
int ret;
|
||||
|
||||
|
@ -59,18 +59,6 @@ static int perf_evlist__add_sample(struct perf_evlist *evlist,
|
|||
return 0;
|
||||
}
|
||||
|
||||
evsel = perf_evlist__id2evsel(evlist, sample->id);
|
||||
if (evsel == NULL) {
|
||||
/*
|
||||
* FIXME: Propagate this back, but at least we're in a builtin,
|
||||
* where exit() is allowed. ;-)
|
||||
*/
|
||||
ui__warning("Invalid %s file, contains samples with id not in "
|
||||
"its header!\n", input_name);
|
||||
exit_browser(0);
|
||||
exit(1);
|
||||
}
|
||||
|
||||
he = __hists__add_entry(&evsel->hists, al, NULL, 1);
|
||||
if (he == NULL)
|
||||
return -ENOMEM;
|
||||
|
@ -92,6 +80,7 @@ static int perf_evlist__add_sample(struct perf_evlist *evlist,
|
|||
|
||||
static int process_sample_event(union perf_event *event,
|
||||
struct perf_sample *sample,
|
||||
struct perf_evsel *evsel,
|
||||
struct perf_session *session)
|
||||
{
|
||||
struct addr_location al;
|
||||
|
@ -103,7 +92,8 @@ static int process_sample_event(union perf_event *event,
|
|||
return -1;
|
||||
}
|
||||
|
||||
if (!al.filtered && perf_evlist__add_sample(session->evlist, sample, &al)) {
|
||||
if (!al.filtered &&
|
||||
perf_evlist__add_sample(session->evlist, sample, evsel, &al)) {
|
||||
pr_warning("problem incrementing symbol count, "
|
||||
"skipping event\n");
|
||||
return -1;
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue