lists.openwall.net   lists  /  announce  owl-users  owl-dev  john-users  john-dev  passwdqc-users  yescrypt  popa3d-users  /  oss-security  kernel-hardening  musl  sabotage  tlsify  passwords  /  crypt-dev  xvendor  /  Bugtraq  Full-Disclosure  linux-kernel  linux-netdev  linux-ext4  linux-hardening  linux-cve-announce  PHC 
Open Source and information security mailing list archives
 
Hash Suite: Windows password security audit tool. GUI, reports in PDF.
[<prev] [next>] [<thread-prev] [day] [month] [year] [list]
Message-Id: <20170327123954.44acd4f0f32ef106e27517a4@kernel.org>
Date:   Mon, 27 Mar 2017 12:39:54 +0900
From:   Masami Hiramatsu <mhiramat@...nel.org>
To:     Masami Hiramatsu <mhiramat@...nel.org>
Cc:     Kim Phillips <kim.phillips@....com>,
        Will Deacon <will.deacon@....com>,
        He Kuang <hekuang@...wei.com>, Wang Nan <wangnan0@...wei.com>,
        Arnaldo Carvalho de Melo <acme@...nel.org>,
        Peter Zijlstra <peterz@...radead.org>,
        Mark Rutland <mark.rutland@....com>,
        <linux-kernel@...r.kernel.org>
Subject: [BUG?] perf: dwarf unwind doesn't work correctly with -static

Hello,

On Fri, 24 Mar 2017 22:00:30 +0900
Masami Hiramatsu <mhiramat@...nel.org> wrote:

> On Thu, 23 Mar 2017 22:24:01 -0500
> Kim Phillips <kim.phillips@....com> wrote:
> 
> > On Thu, 23 Feb 2017 16:50:18 +0900
> > Masami Hiramatsu <mhiramat@...nel.org> wrote:
> > 
> > [sorry for the delay, I just saw this]
> > 
> > > perf record -g dwarf (and perf report) doesn't show correct callchain
> > > on aarch64. Here is how to reproduce it.
> > ...
> > > # Samples: 6K of event 'cpu-clock:u'
> > > # Event count (approx.): 1623750000
> > > #
> > > # Children      Self  Command  Shared Object  Symbol                    
> > > # ........  ........  .......  .............  ..........................
> > > #
> > >     17.21%    17.21%  main     main           [.] func2
> > >             |
> > >             ---func2
> > > 
> > >     17.09%    17.09%  main     main           [.] func1
> > >             |
> > >             ---func1
> > > 
> > >     16.67%    16.67%  main     main           [.] main
> > >             |
> > >             ---main
> > > .....
> > > 
> > > So, as you can see, the call graph reported each function has been
> > > called from itself. If I report it with fp as below, perf reported
> > > correct callgraph.
> > ...
> > > I guess there is a bug in libunwind on aarch64 or we missed to pass
> > > the stack data to libunwind. (BTW, it works correctly on arm32)
> > 
> > Trying to replicate this on a debian 9 ("stretch") arm64 box:
> 
> I'm using debian 8 ("jessie"), but I can try debian 9 too.

I've tried debian 9 and found this issue is another reason.

> 2) Build attached program as below
> # gcc -O0 -ggdb3 -funwind-tables -o main main.c

Originally, I reported above, but that is not correct, when I cleaned
up the command line, I missed important piece -- -static.

I've tested several binaries with different gcc, and found that
- Even with linaro-gcc 6.3.1, this issue happened.
- But natively build binary with gcc-6.3 (stretch) I didn't see it.
- Building binary with -static, it happened even with native binary 6.3.
- And I saw this happened even on x86-64 with -static.

So, I think the correct subject is

"perf: dwarf unwind doesn't work correctly with -static"

Thank you,

-- 
Masami Hiramatsu <mhiramat@...nel.org>

Powered by blists - more mailing lists

Powered by Openwall GNU/*/Linux Powered by OpenVZ