From e93ebe98e6588a2176f15989d1188ce2facacc9f Mon Sep 17 00:00:00 2001 From: Masami Hiramatsu Date: Tue, 3 Aug 2010 11:11:40 +0900 Subject: [PATCH] --- yaml --- r: 209253 b: refs/heads/master c: 449e5b247ca7c9dc9fc3391b7eebfefdeb2ce1fc h: refs/heads/master i: 209251: b91ab6eda5fbb6903ac951d3db0c4576fbcda4ee v: v3 --- [refs] | 2 +- trunk/tools/perf/util/probe-event.c | 11 ++++++++--- 2 files changed, 9 insertions(+), 4 deletions(-) diff --git a/[refs] b/[refs] index 58584e64f064..578399f09cea 100644 --- a/[refs] +++ b/[refs] @@ -1,2 +1,2 @@ --- -refs/heads/master: 58432e1f3625ef22b347ec8f9487e1852aa9ad67 +refs/heads/master: 449e5b247ca7c9dc9fc3391b7eebfefdeb2ce1fc diff --git a/trunk/tools/perf/util/probe-event.c b/trunk/tools/perf/util/probe-event.c index 2e665cb84055..e72f05c3bef0 100644 --- a/trunk/tools/perf/util/probe-event.c +++ b/trunk/tools/perf/util/probe-event.c @@ -1606,8 +1606,10 @@ int add_perf_probe_events(struct perf_probe_event *pevs, int npevs, /* Init vmlinux path */ ret = init_vmlinux(); - if (ret < 0) + if (ret < 0) { + free(pkgs); return ret; + } /* Loop 1: convert all events */ for (i = 0; i < npevs; i++) { @@ -1625,10 +1627,13 @@ int add_perf_probe_events(struct perf_probe_event *pevs, int npevs, ret = __add_probe_trace_events(pkgs[i].pev, pkgs[i].tevs, pkgs[i].ntevs, force_add); end: - /* Loop 3: cleanup trace events */ - for (i = 0; i < npevs; i++) + /* Loop 3: cleanup and free trace events */ + for (i = 0; i < npevs; i++) { for (j = 0; j < pkgs[i].ntevs; j++) clear_probe_trace_event(&pkgs[i].tevs[j]); + free(pkgs[i].tevs); + } + free(pkgs); return ret; }