From: Peter Zijlstra Date: Thu, 6 Aug 2009 18:57:41 +0000 (+0200) Subject: perf tools: Fix multi-counter stat bug caused by incorrect reading of perf.data file... X-Git-Tag: v2.6.31-rc6~19^2~20 X-Git-Url: https://www.infradead.org/git/?a=commitdiff_plain;h=1c222bce7dd0cb9578b4c5cd3874a74f1db497c3;p=users%2Fwilly%2Flinux.git perf tools: Fix multi-counter stat bug caused by incorrect reading of perf.data file header Brice Goglin reported that only the first result from a multi-counter perf record --stat run is accurate, the rest looks bogus. A silly mistake made us re-read the first attribute for every recorded attribute. Reported-by: Brice Goglin Signed-off-by: Peter Zijlstra Tested-by: Brice Goglin Cc: paulus@samba.org Signed-off-by: Ingo Molnar --- diff --git a/tools/perf/util/header.c b/tools/perf/util/header.c index 450384b3bbe5..95a44bcfc2dc 100644 --- a/tools/perf/util/header.c +++ b/tools/perf/util/header.c @@ -213,9 +213,10 @@ struct perf_header *perf_header__read(int fd) for (i = 0; i < nr_attrs; i++) { struct perf_header_attr *attr; - off_t tmp = lseek(fd, 0, SEEK_CUR); + off_t tmp; do_read(fd, &f_attr, sizeof(f_attr)); + tmp = lseek(fd, 0, SEEK_CUR); attr = perf_header_attr__new(&f_attr.attr);