diff options
author | Arnaldo Carvalho de Melo <acme@redhat.com> | 2012-09-26 11:48:18 -0400 |
---|---|---|
committer | Arnaldo Carvalho de Melo <acme@redhat.com> | 2012-09-26 11:48:18 -0400 |
commit | 0807d2d8a381f4fc600ad481c3e77e5cdb624eed (patch) | |
tree | 3cd46552cea3e1a9c7c872250f790cb180f6cccf /tools/perf/util/evsel.c | |
parent | a14bb7a6fd4a3d563ca971daf462ba4dc294a7a6 (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.c | 13 |
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 | ||
770 | static int perf_event__parse_id_sample(const union perf_event *event, u64 type, | 770 | static 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 | ||
834 | int perf_evsel__parse_sample(struct perf_evsel *evsel, union perf_event *event, | 836 | int 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; |