Skip to content

Commit

Permalink
perf evlist: Introduce perf_evlist__parse_sample
Browse files Browse the repository at this point in the history
That is a more compact form of perf_session__parse_sample and to support
multiple evlists per perf_session is the way to go anyway.

Cc: David Ahern <[email protected]>
Cc: Frederic Weisbecker <[email protected]>
Cc: Jiri Olsa <[email protected]>
Cc: Mike Galbraith <[email protected]>
Cc: Namhyung Kim <[email protected]>
Cc: Paul Mackerras <[email protected]>
Cc: Peter Zijlstra <[email protected]>
Cc: Stephane Eranian <[email protected]>
Link: http://lkml.kernel.org/n/[email protected]
Signed-off-by: Arnaldo Carvalho de Melo <[email protected]>
  • Loading branch information
acmel committed Aug 2, 2012
1 parent 7b56cce commit cb0b29e
Show file tree
Hide file tree
Showing 7 changed files with 21 additions and 31 deletions.
8 changes: 2 additions & 6 deletions tools/perf/builtin-test.c
Original file line number Diff line number Diff line change
Expand Up @@ -562,9 +562,7 @@ static int test__basic_mmap(void)
goto out_munmap;
}

err = perf_event__parse_sample(event, attr.sample_type,
evsels[0]->sample_size,
false, &sample, false);
err = perf_evlist__parse_sample(evlist, event, &sample, false);
if (err) {
pr_err("Can't parse sample, err = %d\n", err);
goto out_munmap;
Expand Down Expand Up @@ -781,9 +779,7 @@ static int test__PERF_RECORD(void)
if (type < PERF_RECORD_MAX)
nr_events[type]++;

err = perf_event__parse_sample(event, evsel->attr.sample_type,
evsel->sample_size, true,
&sample, false);
err = perf_evlist__parse_sample(evlist, event, &sample, false);
if (err < 0) {
if (verbose)
perf_event__fprintf(event, stderr);
Expand Down
2 changes: 1 addition & 1 deletion tools/perf/builtin-top.c
Original file line number Diff line number Diff line change
Expand Up @@ -811,7 +811,7 @@ static void perf_top__mmap_read_idx(struct perf_top *top, int idx)
int ret;

while ((event = perf_evlist__mmap_read(top->evlist, idx)) != NULL) {
ret = perf_session__parse_sample(session, event, &sample);
ret = perf_evlist__parse_sample(top->evlist, event, &sample, false);
if (ret) {
pr_err("Can't parse sample, err = %d\n", ret);
continue;
Expand Down
9 changes: 9 additions & 0 deletions tools/perf/util/evlist.c
Original file line number Diff line number Diff line change
Expand Up @@ -881,3 +881,12 @@ int perf_evlist__start_workload(struct perf_evlist *evlist)

return 0;
}

int perf_evlist__parse_sample(struct perf_evlist *evlist,
const union perf_event *event,
struct perf_sample *sample, bool swapped)
{
struct perf_evsel *e = list_entry(evlist->entries.next, struct perf_evsel, node);
return perf_event__parse_sample(event, e->attr.sample_type, e->sample_size,
e->attr.sample_id_all, sample, swapped);
}
4 changes: 4 additions & 0 deletions tools/perf/util/evlist.h
Original file line number Diff line number Diff line change
Expand Up @@ -122,6 +122,10 @@ u64 perf_evlist__sample_type(const struct perf_evlist *evlist);
bool perf_evlist__sample_id_all(const const struct perf_evlist *evlist);
u16 perf_evlist__id_hdr_size(const struct perf_evlist *evlist);

int perf_evlist__parse_sample(struct perf_evlist *evlist,
const union perf_event *event,
struct perf_sample *sample, bool swapped);

bool perf_evlist__valid_sample_type(const struct perf_evlist *evlist);
bool perf_evlist__valid_sample_id_all(const struct perf_evlist *evlist);

Expand Down
6 changes: 1 addition & 5 deletions tools/perf/util/python.c
Original file line number Diff line number Diff line change
Expand Up @@ -797,17 +797,13 @@ static PyObject *pyrf_evlist__read_on_cpu(struct pyrf_evlist *pevlist,

event = perf_evlist__mmap_read(evlist, cpu);
if (event != NULL) {
struct perf_evsel *first;
PyObject *pyevent = pyrf_event__new(event);
struct pyrf_event *pevent = (struct pyrf_event *)pyevent;

if (pyevent == NULL)
return PyErr_NoMemory();

first = list_entry(evlist->entries.next, struct perf_evsel, node);
err = perf_event__parse_sample(event, first->attr.sample_type,
first->sample_size,
sample_id_all, &pevent->sample, false);
err = perf_evlist__parse_sample(evlist, event, &pevent->sample, false);
if (err)
return PyErr_Format(PyExc_OSError,
"perf: can't parse sample, err=%d", err);
Expand Down
19 changes: 4 additions & 15 deletions tools/perf/util/session.c
Original file line number Diff line number Diff line change
Expand Up @@ -16,19 +16,6 @@
#include "cpumap.h"
#include "event-parse.h"

int perf_session__parse_sample(struct perf_session *session,
const union perf_event *event,
struct perf_sample *sample)
{
struct perf_evsel *first;
first = list_entry(session->evlist->entries.next, struct perf_evsel, node);

return perf_event__parse_sample(event, first->attr.sample_type,
first->sample_size,
first->attr.sample_id_all, sample,
session->header.needs_swap);
}

int perf_session__synthesize_sample(struct perf_session *session,
union perf_event *event,
const struct perf_sample *sample)
Expand Down Expand Up @@ -692,7 +679,8 @@ static void flush_sample_queue(struct perf_session *s,
if (iter->timestamp > limit)
break;

ret = perf_session__parse_sample(s, iter->event, &sample);
ret = perf_evlist__parse_sample(s->evlist, iter->event, &sample,
s->header.needs_swap);
if (ret)
pr_err("Can't parse sample, err = %d\n", ret);
else
Expand Down Expand Up @@ -1103,7 +1091,8 @@ static int perf_session__process_event(struct perf_session *session,
/*
* For all kernel events we get the sample data
*/
ret = perf_session__parse_sample(session, event, &sample);
ret = perf_evlist__parse_sample(session->evlist, event, &sample,
session->header.needs_swap);
if (ret)
return ret;

Expand Down
4 changes: 0 additions & 4 deletions tools/perf/util/session.h
Original file line number Diff line number Diff line change
Expand Up @@ -126,10 +126,6 @@ size_t perf_session__fprintf_dsos_buildid(struct perf_session *self,

size_t perf_session__fprintf_nr_events(struct perf_session *session, FILE *fp);

int perf_session__parse_sample(struct perf_session *session,
const union perf_event *event,
struct perf_sample *sample);

int perf_session__synthesize_sample(struct perf_session *session,
union perf_event *event,
const struct perf_sample *sample);
Expand Down

0 comments on commit cb0b29e

Please sign in to comment.