perf unwind: Unwind with libdw doesn't take symfs into account
Path passed to libdw for unwinding doesn't include symfs path if specified, so unwinding fails because ELF file is not found. Similar to unwinding with libunwind, pass symsrc_filename instead of long_name. If there is no symsrc_filename, fallback to long_name. Signed-off-by: Martin Vuille <jpmv27@aim.com> Cc: Adrian Hunter <adrian.hunter@intel.com> Cc: David Ahern <dsahern@gmail.com> Cc: Jiri Olsa <jolsa@kernel.org> Cc: Namhyung Kim <namhyung@kernel.org> Cc: Wang Nan <wangnan0@huawei.com> Link: http://lkml.kernel.org/r/20180211212420.18388-1-jpmv27@aim.com Signed-off-by: Arnaldo Carvalho de Melo <acme@redhat.com>
This commit is contained in:
parent
a8685f0888
commit
3d20c62466
@ -50,7 +50,7 @@ static int __report_module(struct addr_location *al, u64 ip,
|
|||||||
|
|
||||||
if (!mod)
|
if (!mod)
|
||||||
mod = dwfl_report_elf(ui->dwfl, dso->short_name,
|
mod = dwfl_report_elf(ui->dwfl, dso->short_name,
|
||||||
dso->long_name, -1, al->map->start,
|
(dso->symsrc_filename ? dso->symsrc_filename : dso->long_name), -1, al->map->start,
|
||||||
false);
|
false);
|
||||||
|
|
||||||
return mod && dwfl_addrmodule(ui->dwfl, ip) == mod ? 0 : -1;
|
return mod && dwfl_addrmodule(ui->dwfl, ip) == mod ? 0 : -1;
|
||||||
|
Loading…
Reference in New Issue
Block a user