| #! /bin/sh |
| # Copyright (C) 2013 Red Hat, Inc. |
| # This file is part of elfutils. |
| # |
| # This file is free software; you can redistribute it and/or modify |
| # it under the terms of the GNU General Public License as published by |
| # the Free Software Foundation; either version 3 of the License, or |
| # (at your option) any later version. |
| # |
| # elfutils is distributed in the hope that it will be useful, but |
| # WITHOUT ANY WARRANTY; without even the implied warranty of |
| # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the |
| # GNU General Public License for more details. |
| # |
| # You should have received a copy of the GNU General Public License |
| # along with this program. If not, see <http://www.gnu.org/licenses/>. |
| |
| . $srcdir/test-subr.sh |
| |
| # // g++ x.cpp -g -fPIC -olibx.so -shared -O3 -fvisibility=hidden |
| # |
| # void foobar() |
| # { |
| # __asm__ ( "nop" ::: ); |
| # } |
| # |
| # void fubar() |
| # { |
| # __asm__ ( "nop" ::: ); |
| # } |
| # |
| # void bar() |
| # { |
| # foobar(); |
| # } |
| # |
| # void baz() |
| # { |
| # fubar(); |
| # } |
| # |
| # void foo() |
| # { |
| # bar(); |
| # baz(); |
| # } |
| # |
| # void fu() |
| # { |
| # __asm__ ( "nop" ::: ); |
| # fubar(); |
| # foobar(); |
| # } |
| |
| testfiles testfile-inlines |
| |
| testrun_compare ${abs_top_builddir}/src/addr2line -i -e testfile-inlines 0x00000000000005a0 <<\EOF |
| /tmp/x.cpp:5 |
| EOF |
| |
| testrun_compare ${abs_top_builddir}/src/addr2line -i -e testfile-inlines 0x00000000000005a1 <<\EOF |
| /tmp/x.cpp:6 |
| EOF |
| |
| testrun_compare ${abs_top_builddir}/src/addr2line -i -e testfile-inlines 0x00000000000005b0 <<\EOF |
| /tmp/x.cpp:10 |
| EOF |
| |
| testrun_compare ${abs_top_builddir}/src/addr2line -i -e testfile-inlines 0x00000000000005b1 <<\EOF |
| /tmp/x.cpp:11 |
| EOF |
| |
| testrun_compare ${abs_top_builddir}/src/addr2line -i -e testfile-inlines 0x00000000000005c0 <<\EOF |
| /tmp/x.cpp:5 |
| /tmp/x.cpp:15 |
| EOF |
| |
| testrun_compare ${abs_top_builddir}/src/addr2line -i -e testfile-inlines 0x00000000000005d0 <<\EOF |
| /tmp/x.cpp:10 |
| /tmp/x.cpp:20 |
| EOF |
| |
| testrun_compare ${abs_top_builddir}/src/addr2line -i -e testfile-inlines 0x00000000000005e0 <<\EOF |
| /tmp/x.cpp:5 |
| /tmp/x.cpp:15 |
| /tmp/x.cpp:25 |
| EOF |
| |
| testrun_compare ${abs_top_builddir}/src/addr2line -i -e testfile-inlines 0x00000000000005e1 <<\EOF |
| /tmp/x.cpp:10 |
| /tmp/x.cpp:20 |
| /tmp/x.cpp:26 |
| EOF |
| |
| testrun_compare ${abs_top_builddir}/src/addr2line -i -e testfile-inlines 0x00000000000005f1 <<\EOF |
| /tmp/x.cpp:10 |
| /tmp/x.cpp:32 |
| EOF |
| |
| testrun_compare ${abs_top_builddir}/src/addr2line -i -e testfile-inlines 0x00000000000005f2 <<\EOF |
| /tmp/x.cpp:5 |
| /tmp/x.cpp:33 |
| EOF |
| |
| # All together now (plus function names). |
| testrun_compare ${abs_top_builddir}/src/addr2line -f -i -e testfile-inlines 0x00000000000005a0 0x00000000000005a1 0x00000000000005b0 0x00000000000005b1 0x00000000000005c0 0x00000000000005d0 0x00000000000005e0 0x00000000000005e1 0x00000000000005f0 0x00000000000005f1 0x00000000000005f2 <<\EOF |
| foobar |
| /tmp/x.cpp:5 |
| foobar |
| /tmp/x.cpp:6 |
| fubar |
| /tmp/x.cpp:10 |
| fubar |
| /tmp/x.cpp:11 |
| foobar inlined at /tmp/x.cpp:15 in _Z3barv |
| /tmp/x.cpp:5 |
| bar |
| /tmp/x.cpp:15 |
| fubar inlined at /tmp/x.cpp:20 in _Z3bazv |
| /tmp/x.cpp:10 |
| baz |
| /tmp/x.cpp:20 |
| foobar inlined at /tmp/x.cpp:15 in _Z3foov |
| /tmp/x.cpp:5 |
| bar |
| /tmp/x.cpp:15 |
| _Z3foov |
| /tmp/x.cpp:25 |
| fubar inlined at /tmp/x.cpp:20 in _Z3foov |
| /tmp/x.cpp:10 |
| baz |
| /tmp/x.cpp:20 |
| _Z3foov |
| /tmp/x.cpp:26 |
| _Z2fuv |
| /tmp/x.cpp:31 |
| fubar inlined at /tmp/x.cpp:32 in _Z2fuv |
| /tmp/x.cpp:10 |
| _Z2fuv |
| /tmp/x.cpp:32 |
| foobar inlined at /tmp/x.cpp:33 in _Z2fuv |
| /tmp/x.cpp:5 |
| _Z2fuv |
| /tmp/x.cpp:33 |
| EOF |
| |
| # All together now (plus function names plus addresses). |
| testrun_compare ${abs_top_builddir}/src/addr2line -a -f -i -e testfile-inlines 0x00000000000005a0 0x00000000000005a1 0x00000000000005b0 0x00000000000005b1 0x00000000000005c0 0x00000000000005d0 0x00000000000005e0 0x00000000000005e1 0x00000000000005f0 0x00000000000005f1 0x00000000000005f2 <<\EOF |
| 0x00000000000005a0 |
| foobar |
| /tmp/x.cpp:5 |
| 0x00000000000005a1 |
| foobar |
| /tmp/x.cpp:6 |
| 0x00000000000005b0 |
| fubar |
| /tmp/x.cpp:10 |
| 0x00000000000005b1 |
| fubar |
| /tmp/x.cpp:11 |
| 0x00000000000005c0 |
| foobar inlined at /tmp/x.cpp:15 in _Z3barv |
| /tmp/x.cpp:5 |
| bar |
| /tmp/x.cpp:15 |
| 0x00000000000005d0 |
| fubar inlined at /tmp/x.cpp:20 in _Z3bazv |
| /tmp/x.cpp:10 |
| baz |
| /tmp/x.cpp:20 |
| 0x00000000000005e0 |
| foobar inlined at /tmp/x.cpp:15 in _Z3foov |
| /tmp/x.cpp:5 |
| bar |
| /tmp/x.cpp:15 |
| _Z3foov |
| /tmp/x.cpp:25 |
| 0x00000000000005e1 |
| fubar inlined at /tmp/x.cpp:20 in _Z3foov |
| /tmp/x.cpp:10 |
| baz |
| /tmp/x.cpp:20 |
| _Z3foov |
| /tmp/x.cpp:26 |
| 0x00000000000005f0 |
| _Z2fuv |
| /tmp/x.cpp:31 |
| 0x00000000000005f1 |
| fubar inlined at /tmp/x.cpp:32 in _Z2fuv |
| /tmp/x.cpp:10 |
| _Z2fuv |
| /tmp/x.cpp:32 |
| 0x00000000000005f2 |
| foobar inlined at /tmp/x.cpp:33 in _Z2fuv |
| /tmp/x.cpp:5 |
| _Z2fuv |
| /tmp/x.cpp:33 |
| EOF |
| |
| # All together now (plus function names and addresses and pretty) |
| testrun_compare ${abs_top_builddir}/src/addr2line --pretty-print -a -f -i -e testfile-inlines 0x00000000000005a0 0x00000000000005a1 0x00000000000005b0 0x00000000000005b1 0x00000000000005c0 0x00000000000005d0 0x00000000000005e0 0x00000000000005e1 0x00000000000005f0 0x00000000000005f1 0x00000000000005f2 <<\EOF |
| 0x00000000000005a0: foobar at /tmp/x.cpp:5 |
| 0x00000000000005a1: foobar at /tmp/x.cpp:6 |
| 0x00000000000005b0: fubar at /tmp/x.cpp:10 |
| 0x00000000000005b1: fubar at /tmp/x.cpp:11 |
| 0x00000000000005c0: foobar at /tmp/x.cpp:5 |
| (inlined by) bar at /tmp/x.cpp:15 |
| 0x00000000000005d0: fubar at /tmp/x.cpp:10 |
| (inlined by) baz at /tmp/x.cpp:20 |
| 0x00000000000005e0: foobar at /tmp/x.cpp:5 |
| (inlined by) bar at /tmp/x.cpp:15 |
| (inlined by) _Z3foov at /tmp/x.cpp:25 |
| 0x00000000000005e1: fubar at /tmp/x.cpp:10 |
| (inlined by) baz at /tmp/x.cpp:20 |
| (inlined by) _Z3foov at /tmp/x.cpp:26 |
| 0x00000000000005f0: _Z2fuv at /tmp/x.cpp:31 |
| 0x00000000000005f1: fubar at /tmp/x.cpp:10 |
| (inlined by) _Z2fuv at /tmp/x.cpp:32 |
| 0x00000000000005f2: foobar at /tmp/x.cpp:5 |
| (inlined by) _Z2fuv at /tmp/x.cpp:33 |
| EOF |
| |
| exit 0 |