aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--tools/perf/util/annotate.c32
1 files changed, 31 insertions, 1 deletions
diff --git a/tools/perf/util/annotate.c b/tools/perf/util/annotate.c
index 61bf9128e1f2..b72086eca943 100644
--- a/tools/perf/util/annotate.c
+++ b/tools/perf/util/annotate.c
@@ -1008,6 +1008,32 @@ fallback:
1008 } 1008 }
1009 filename = symfs_filename; 1009 filename = symfs_filename;
1010 } 1010 }
1011 } else if (dso__needs_decompress(dso)) {
1012 char tmp[PATH_MAX];
1013 struct kmod_path m;
1014 int fd;
1015 bool ret;
1016
1017 if (kmod_path__parse_ext(&m, symfs_filename))
1018 goto out_free_filename;
1019
1020 snprintf(tmp, PATH_MAX, "/tmp/perf-kmod-XXXXXX");
1021
1022 fd = mkstemp(tmp);
1023 if (fd < 0) {
1024 free(m.ext);
1025 goto out_free_filename;
1026 }
1027
1028 ret = decompress_to_file(m.ext, symfs_filename, fd);
1029
1030 free(m.ext);
1031 close(fd);
1032
1033 if (!ret)
1034 goto out_free_filename;
1035
1036 strcpy(symfs_filename, tmp);
1011 } 1037 }
1012 1038
1013 snprintf(command, sizeof(command), 1039 snprintf(command, sizeof(command),
@@ -1027,7 +1053,7 @@ fallback:
1027 1053
1028 file = popen(command, "r"); 1054 file = popen(command, "r");
1029 if (!file) 1055 if (!file)
1030 goto out_free_filename; 1056 goto out_remove_tmp;
1031 1057
1032 while (!feof(file)) 1058 while (!feof(file))
1033 if (symbol__parse_objdump_line(sym, map, file, privsize, 1059 if (symbol__parse_objdump_line(sym, map, file, privsize,
@@ -1042,6 +1068,10 @@ fallback:
1042 delete_last_nop(sym); 1068 delete_last_nop(sym);
1043 1069
1044 pclose(file); 1070 pclose(file);
1071
1072out_remove_tmp:
1073 if (dso__needs_decompress(dso))
1074 unlink(symfs_filename);
1045out_free_filename: 1075out_free_filename:
1046 if (delete_extract) 1076 if (delete_extract)
1047 kcore_extract__delete(&kce); 1077 kcore_extract__delete(&kce);