|
From: tip-bot f. M. H. <mhi...@re...> - 2010-02-22 11:05:14
|
Commit-ID: 388c3aab5d4f1b0bbfe2d5f47e7cd681866bc573 Gitweb: http://git.kernel.org/tip/388c3aab5d4f1b0bbfe2d5f47e7cd681866bc573 Author: Masami Hiramatsu <mhi...@re...> AuthorDate: Thu, 18 Feb 2010 13:16:52 -0500 Committer: Ingo Molnar <mi...@el...> CommitDate: Mon, 22 Feb 2010 11:42:27 +0100 perf probe: Init struct probe_point and set counter correctly Clear struct probe_point before using it in show_perf_probe_events(), and set pp->found counter correctly in synthesize_perf_probe_point(). Without this initialization, clear_probe_point() will free random addresses. Signed-off-by: Masami Hiramatsu <mhi...@re...> Cc: Peter Zijlstra <a.p...@ch...> Cc: Mike Galbraith <ef...@gm...> Cc: Paul Mackerras <pa...@sa...> Cc: Arnaldo Carvalho de Melo <ac...@re...> Cc: Frederic Weisbecker <fwe...@gm...> Cc: systemtap <sys...@so...> Cc: DLE <dle...@li...> LKML-Reference: <201...@dh...> Signed-off-by: Ingo Molnar <mi...@el...> --- tools/perf/util/probe-event.c | 3 +++ 1 files changed, 3 insertions(+), 0 deletions(-) diff --git a/tools/perf/util/probe-event.c b/tools/perf/util/probe-event.c index 29465d4..fde17b0 100644 --- a/tools/perf/util/probe-event.c +++ b/tools/perf/util/probe-event.c @@ -272,6 +272,7 @@ int synthesize_perf_probe_point(struct probe_point *pp) int ret; pp->probes[0] = buf = zalloc(MAX_CMDLEN); + pp->found = 1; if (!buf) die("Failed to allocate memory by zalloc."); if (pp->offset) { @@ -294,6 +295,7 @@ int synthesize_perf_probe_point(struct probe_point *pp) error: free(pp->probes[0]); pp->probes[0] = NULL; + pp->found = 0; } return ret; } @@ -455,6 +457,7 @@ void show_perf_probe_events(void) struct strlist *rawlist; struct str_node *ent; + memset(&pp, 0, sizeof(pp)); fd = open_kprobe_events(O_RDONLY, 0); rawlist = get_trace_kprobe_event_rawlist(fd); close(fd); |