[<prev] [next>] [<thread-prev] [day] [month] [year] [list]
Message-ID: <20160810140026.GF4249@kernel.org>
Date: Wed, 10 Aug 2016 11:00:26 -0300
From: Arnaldo Carvalho de Melo <acme@...nel.org>
To: Rabin Vincent <rabin.vincent@...s.com>
Cc: linux-kernel@...r.kernel.org, Rabin Vincent <rabinv@...s.com>,
Jiri Olsa <jolsa@...nel.org>, He Kuang <hekuang@...wei.com>
Subject: Re: [PATCH] perf unwind: check symsrc ELF for .debug_frame
Em Wed, Aug 10, 2016 at 03:36:16PM +0200, Rabin Vincent escreveu:
> From: Rabin Vincent <rabinv@...s.com>
>
> When using split debug info, the file without debug info may not have a
> .debug_frame section, so we need to check the symsrc ELF also, since
> that's the file we actually read the unwind information from.
Thanks for your work, next time please also copy the persons that did
work on this file recently, like:
He Kuang <hekuang@...wei.com>
And people who acked or reviewed their patches, like:
Jiri Olsa <jolsa@...nel.org>
Guys, are you ok with these changes? 2/2 seems trivial enough.
- Arnaldo
> Signed-off-by: Rabin Vincent <rabinv@...s.com>
> ---
> tools/perf/util/unwind-libunwind-local.c | 14 ++++++++++++++
> 1 file changed, 14 insertions(+)
>
> diff --git a/tools/perf/util/unwind-libunwind-local.c b/tools/perf/util/unwind-libunwind-local.c
> index 97c0f8f..d492192 100644
> --- a/tools/perf/util/unwind-libunwind-local.c
> +++ b/tools/perf/util/unwind-libunwind-local.c
> @@ -308,6 +308,20 @@ static int read_unwind_spec_debug_frame(struct dso *dso,
> dso__data_put_fd(dso);
> }
>
> + /*
> + * With split debug info, the file without debug info may not have a
> + * .debug_frame, so check the symsrc too.
> + */
> + if (ofs == 0 && dso->symsrc_filename) {
> + fd = open(dso->symsrc_filename, O_RDONLY);
> + if (fd < 0)
> + return -EINVAL;
> +
> + ofs = elf_section_offset(fd, ".debug_frame");
> + dso->data.debug_frame_offset = ofs;
> + close(fd);
> + }
> +
> *offset = ofs;
> if (*offset)
> return 0;
> --
> 2.1.4
Powered by blists - more mailing lists