aboutsummaryrefslogtreecommitdiffstats
path: root/tools/perf/util/evsel.c
diff options
context:
space:
mode:
authorArnaldo Carvalho de Melo <acme@redhat.com>2012-09-26 11:48:18 -0400
committerArnaldo Carvalho de Melo <acme@redhat.com>2012-09-26 11:48:18 -0400
commit0807d2d8a381f4fc600ad481c3e77e5cdb624eed (patch)
tree3cd46552cea3e1a9c7c872250f790cb180f6cccf /tools/perf/util/evsel.c
parenta14bb7a6fd4a3d563ca971daf462ba4dc294a7a6 (diff)
perf evsel: Know if byte swap is needed
Instead of passing it around for parsing as an explicit parameter, will help with reading tracepoint fields when not using a perf session or pevent structure, i.e. for non perf.data centered workflows. Cc: David Ahern <dsahern@gmail.com> Cc: Frederic Weisbecker <fweisbec@gmail.com> Cc: Jiri Olsa <jolsa@redhat.com> Cc: Mike Galbraith <efault@gmx.de> Cc: Namhyung Kim <namhyung@gmail.com> Cc: Paul Mackerras <paulus@samba.org> Cc: Peter Zijlstra <peterz@infradead.org> Cc: Stephane Eranian <eranian@google.com> Link: http://lkml.kernel.org/n/tip-qa67ikv2sm49cwa7dyjhhp6g@git.kernel.org Signed-off-by: Arnaldo Carvalho de Melo <acme@redhat.com>
Diffstat (limited to 'tools/perf/util/evsel.c')
-rw-r--r--tools/perf/util/evsel.c13
1 files changed, 8 insertions, 5 deletions
diff --git a/tools/perf/util/evsel.c b/tools/perf/util/evsel.c
index 2467eaf2968f..fe9581b0323c 100644
--- a/tools/perf/util/evsel.c
+++ b/tools/perf/util/evsel.c
@@ -767,11 +767,13 @@ int perf_evsel__open_per_thread(struct perf_evsel *evsel,
767 return __perf_evsel__open(evsel, &empty_cpu_map.map, threads); 767 return __perf_evsel__open(evsel, &empty_cpu_map.map, threads);
768} 768}
769 769
770static int perf_event__parse_id_sample(const union perf_event *event, u64 type, 770static int perf_evsel__parse_id_sample(const struct perf_evsel *evsel,
771 struct perf_sample *sample, 771 const union perf_event *event,
772 bool swapped) 772 struct perf_sample *sample)
773{ 773{
774 u64 type = evsel->attr.sample_type;
774 const u64 *array = event->sample.array; 775 const u64 *array = event->sample.array;
776 bool swapped = evsel->needs_swap;
775 union u64_swap u; 777 union u64_swap u;
776 778
777 array += ((event->header.size - 779 array += ((event->header.size -
@@ -832,10 +834,11 @@ static bool sample_overlap(const union perf_event *event,
832} 834}
833 835
834int perf_evsel__parse_sample(struct perf_evsel *evsel, union perf_event *event, 836int perf_evsel__parse_sample(struct perf_evsel *evsel, union perf_event *event,
835 struct perf_sample *data, bool swapped) 837 struct perf_sample *data)
836{ 838{
837 u64 type = evsel->attr.sample_type; 839 u64 type = evsel->attr.sample_type;
838 u64 regs_user = evsel->attr.sample_regs_user; 840 u64 regs_user = evsel->attr.sample_regs_user;
841 bool swapped = evsel->needs_swap;
839 const u64 *array; 842 const u64 *array;
840 843
841 /* 844 /*
@@ -852,7 +855,7 @@ int perf_evsel__parse_sample(struct perf_evsel *evsel, union perf_event *event,
852 if (event->header.type != PERF_RECORD_SAMPLE) { 855 if (event->header.type != PERF_RECORD_SAMPLE) {
853 if (!evsel->attr.sample_id_all) 856 if (!evsel->attr.sample_id_all)
854 return 0; 857 return 0;
855 return perf_event__parse_id_sample(event, type, data, swapped); 858 return perf_evsel__parse_id_sample(evsel, event, data);
856 } 859 }
857 860
858 array = event->sample.array; 861 array = event->sample.array;