aboutsummaryrefslogtreecommitdiffstats
path: root/tools
diff options
context:
space:
mode:
authorAndi Kleen <ak@linux.intel.com>2014-11-12 21:05:24 -0500
committerArnaldo Carvalho de Melo <acme@redhat.com>2014-11-24 16:03:46 -0500
commit23f0981bbd89fcc1496d0490ec39ca7c91599e32 (patch)
tree4ab315a987915d7f46a54c8d00b5bb1824e843fb /tools
parenta7444af69b2898bb9b3a847d3599e1fc98356ce5 (diff)
perf callchain: Enable printing the srcline in the history
For lbr-as-callgraph we need to see the line number in the history, because many LBR entries can be in a single function, and just showing the same function name many times is not useful. When the history code is configured to sort by address, also try to resolve the address to a file:srcline and display this in the browser. If that doesn't work still display the address. This can be also useful without LBRs for understanding which call in a large function (or in which inlined function) called something else. Contains fixes from Namhyung Kim v2: Refactor code into common function v3: Fix GTK build v4: Rebase Signed-off-by: Andi Kleen <ak@linux.intel.com> Cc: Jiri Olsa <jolsa@redhat.com> Cc: Namhyung Kim <namhyung@kernel.org> Link: http://lkml.kernel.org/r/1415844328-4884-7-git-send-email-andi@firstfloor.org Signed-off-by: Arnaldo Carvalho de Melo <acme@redhat.com>
Diffstat (limited to 'tools')
-rw-r--r--tools/perf/util/callchain.c11
-rw-r--r--tools/perf/util/callchain.h1
-rw-r--r--tools/perf/util/srcline.c6
3 files changed, 15 insertions, 3 deletions
diff --git a/tools/perf/util/callchain.c b/tools/perf/util/callchain.c
index 38da69c8c1ff..b6624aeaaca9 100644
--- a/tools/perf/util/callchain.c
+++ b/tools/perf/util/callchain.c
@@ -815,7 +815,16 @@ char *callchain_list__sym_name(struct callchain_list *cl,
815 int printed; 815 int printed;
816 816
817 if (cl->ms.sym) { 817 if (cl->ms.sym) {
818 printed = scnprintf(bf, bfsize, "%s", cl->ms.sym->name); 818 if (callchain_param.key == CCKEY_ADDRESS &&
819 cl->ms.map && !cl->srcline)
820 cl->srcline = get_srcline(cl->ms.map->dso,
821 map__rip_2objdump(cl->ms.map,
822 cl->ip));
823 if (cl->srcline)
824 printed = scnprintf(bf, bfsize, "%s %s",
825 cl->ms.sym->name, cl->srcline);
826 else
827 printed = scnprintf(bf, bfsize, "%s", cl->ms.sym->name);
819 } else 828 } else
820 printed = scnprintf(bf, bfsize, "%#" PRIx64, cl->ip); 829 printed = scnprintf(bf, bfsize, "%#" PRIx64, cl->ip);
821 830
diff --git a/tools/perf/util/callchain.h b/tools/perf/util/callchain.h
index 3e1ed15d11f1..3f158474c892 100644
--- a/tools/perf/util/callchain.h
+++ b/tools/perf/util/callchain.h
@@ -70,6 +70,7 @@ extern struct callchain_param callchain_param;
70struct callchain_list { 70struct callchain_list {
71 u64 ip; 71 u64 ip;
72 struct map_symbol ms; 72 struct map_symbol ms;
73 char *srcline;
73 struct list_head list; 74 struct list_head list;
74}; 75};
75 76
diff --git a/tools/perf/util/srcline.c b/tools/perf/util/srcline.c
index 77c180637138..ac877f96fed7 100644
--- a/tools/perf/util/srcline.c
+++ b/tools/perf/util/srcline.c
@@ -258,7 +258,7 @@ char *get_srcline(struct dso *dso, unsigned long addr)
258 const char *dso_name; 258 const char *dso_name;
259 259
260 if (!dso->has_srcline) 260 if (!dso->has_srcline)
261 return SRCLINE_UNKNOWN; 261 goto out;
262 262
263 if (dso->symsrc_filename) 263 if (dso->symsrc_filename)
264 dso_name = dso->symsrc_filename; 264 dso_name = dso->symsrc_filename;
@@ -289,7 +289,9 @@ out:
289 dso->has_srcline = 0; 289 dso->has_srcline = 0;
290 dso__free_a2l(dso); 290 dso__free_a2l(dso);
291 } 291 }
292 return SRCLINE_UNKNOWN; 292 if (asprintf(&srcline, "%s[%lx]", dso->short_name, addr) < 0)
293 return SRCLINE_UNKNOWN;
294 return srcline;
293} 295}
294 296
295void free_srcline(char *srcline) 297void free_srcline(char *srcline)