summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorLinus Torvalds <torvalds@linux-foundation.org>2011-10-02 02:46:13 +0200
committerLinus Torvalds <torvalds@linux-foundation.org>2011-10-02 02:46:13 +0200
commit2e518181074b4ac67c27768f44a1515c4fc1bff9 (patch)
tree61fd9bdcc9bcbd0d90fead8975b93e359a5b6616
parentMerge branches 'irq-urgent-for-linus', 'x86-urgent-for-linus' and 'sched-urge... (diff)
parentMerge branch 'perf/urgent' of git://github.com/acmel/linux into perf/urgent (diff)
downloadlinux-2e518181074b4ac67c27768f44a1515c4fc1bff9.tar.xz
linux-2e518181074b4ac67c27768f44a1515c4fc1bff9.zip
Merge branch 'perf-urgent-for-linus' of git://tesla.tglx.de/git/linux-2.6-tip
* 'perf-urgent-for-linus' of git://tesla.tglx.de/git/linux-2.6-tip: perf tools: Fix raw sample reading
-rw-r--r--tools/perf/util/evsel.c7
1 files changed, 5 insertions, 2 deletions
diff --git a/tools/perf/util/evsel.c b/tools/perf/util/evsel.c
index c5748c52318f..e389815078d3 100644
--- a/tools/perf/util/evsel.c
+++ b/tools/perf/util/evsel.c
@@ -449,6 +449,8 @@ int perf_event__parse_sample(const union perf_event *event, u64 type,
}
if (type & PERF_SAMPLE_RAW) {
+ const u64 *pdata;
+
u.val64 = *array;
if (WARN_ONCE(swapped,
"Endianness of raw data not corrected!\n")) {
@@ -462,11 +464,12 @@ int perf_event__parse_sample(const union perf_event *event, u64 type,
return -EFAULT;
data->raw_size = u.val32[0];
+ pdata = (void *) array + sizeof(u32);
- if (sample_overlap(event, &u.val32[1], data->raw_size))
+ if (sample_overlap(event, pdata, data->raw_size))
return -EFAULT;
- data->raw_data = &u.val32[1];
+ data->raw_data = (void *) pdata;
}
return 0;