Prev: Staging: wlags49_h2: fixed C99 comments style issues in wl_profile.c
Next: [tip:sched/core] sched: Remove a stale comment
From: tip-bot for Tom Zanussi on 10 May 2010 03:30 Commit-ID: 794e43b56c18b95fc9776c914a2659e7d558a352 Gitweb: http://git.kernel.org/tip/794e43b56c18b95fc9776c914a2659e7d558a352 Author: Tom Zanussi <tzanussi(a)gmail.com> AuthorDate: Wed, 5 May 2010 00:27:40 -0500 Committer: Frederic Weisbecker <fweisbec(a)gmail.com> CommitDate: Sun, 9 May 2010 13:49:52 +0200 perf/live-mode: Handle payload-less events Some events, such as the PERF_RECORD_FINISHED_ROUND event consist of only an event header and no data. In this case, a 0-length payload will be read, and the 0 return value will be wrongly interpreted as an 'unexpected end of event stream'. This patch allows for proper handling of data-less events by skipping 0-length reads. Signed-off-by: Tom Zanussi <tzanussi(a)gmail.com> Cc: Arnaldo Carvalho de Melo <acme(a)redhat.com> Cc: Ingo Molnar <mingo(a)elte.hu> Cc: Peter Zijlstra <a.p.zijlstra(a)chello.nl> Cc: Paul Mackerras <paulus(a)samba.org> Cc: Masami Hiramatsu <mhiramat(a)redhat.com> LKML-Reference: <1273038527.6383.51.camel(a)tropicana> Signed-off-by: Frederic Weisbecker <fweisbec(a)gmail.com> --- tools/perf/util/session.c | 19 +++++++++++-------- 1 files changed, 11 insertions(+), 8 deletions(-) diff --git a/tools/perf/util/session.c b/tools/perf/util/session.c index 9401909..00ab298 100644 --- a/tools/perf/util/session.c +++ b/tools/perf/util/session.c @@ -696,15 +696,18 @@ more: p = &event; p += sizeof(struct perf_event_header); - err = do_read(self->fd, p, size - sizeof(struct perf_event_header)); - if (err <= 0) { - if (err == 0) { - pr_err("unexpected end of event stream\n"); - goto done; - } + if (size - sizeof(struct perf_event_header)) { + err = do_read(self->fd, p, + size - sizeof(struct perf_event_header)); + if (err <= 0) { + if (err == 0) { + pr_err("unexpected end of event stream\n"); + goto done; + } - pr_err("failed to read event data\n"); - goto out_err; + pr_err("failed to read event data\n"); + goto out_err; + } } if (size == 0 || -- To unsubscribe from this list: send the line "unsubscribe linux-kernel" in the body of a message to majordomo(a)vger.kernel.org More majordomo info at http://vger.kernel.org/majordomo-info.html Please read the FAQ at http://www.tux.org/lkml/ |