perf probe: Fix get_real_path to free allocated memory in error path
authorMasami Hiramatsu <masami.hiramatsu.pt@hitachi.com>
Thu, 26 Feb 2015 08:25:04 +0000 (17:25 +0900)
committerArnaldo Carvalho de Melo <acme@redhat.com>
Thu, 26 Feb 2015 14:59:05 +0000 (11:59 -0300)
Fix get_real_path to free allocated memory when comp_dir is used for
complementing path and getting an error.

Signed-off-by: Masami Hiramatsu <masami.hiramatsu.pt@hitachi.com>
Cc: Namhyung Kim <namhyung@kernel.org>
Cc: Naohiro Aota <naota@elisp.net>
Cc: Peter Zijlstra <peterz@infradead.org>
Link: http://lkml.kernel.org/r/20150226082504.28125.74506.stgit@localhost.localdomain
Signed-off-by: Arnaldo Carvalho de Melo <acme@redhat.com>
tools/perf/util/probe-event.c

index 662d454cb667afb545305ca4b3b5b7c0208ad7ac..4a93bf433344d60cf2dc3f7b34e2b12cf3a1befb 100644 (file)
@@ -549,9 +549,11 @@ static int get_real_path(const char *raw_path, const char *comp_dir,
                if (access(*new_path, R_OK) == 0)
                        return 0;
 
-               if (!symbol_conf.source_prefix)
+               if (!symbol_conf.source_prefix) {
                        /* In case of searching comp_dir, don't retry */
+                       zfree(new_path);
                        return -errno;
+               }
 
                switch (errno) {
                case ENAMETOOLONG: