addr2line not woking on Ubuntu 16.10?

2019-09-12 12:02发布

问题:

#include <stdio.h>
void foo() {}
int main(int argc, char **argv)
{
    printf("%p\n", foo);
    return 0;
}

save as foo.c and compile with gcc -g foo.c

$ ./a.out
0x564e523896a0
$ addr2line 0x564e523896a0 -f -e a.out
??
??:0

I found the address doesn't start at 0x400000, and dumped the elf:

$ readelf -h a.out
ELF Header:
Magic:   7f 45 4c 46 02 01 01 00 00 00 00 00 00 00 00 00 
Class:                             ELF64
Data:                              2's complement, little endian
Version:                           1 (current)
OS/ABI:                            UNIX - System V
ABI Version:                       0
Type:                              DYN (Shared object file)
Machine:                           Advanced Micro Devices X86-64
Version:                           0x1
Entry point address:               0x570
Start of program headers:          64 (bytes into file)
Start of section headers:          8808 (bytes into file)
Flags:                             0x0
Size of this header:               64 (bytes)
Size of program headers:           56 (bytes)
Number of program headers:         9
Size of section headers:           64 (bytes)
Number of section headers:         34
Section header string table index: 31

The entry point doesn't start at 0x400000. Why? But Ubuntu 16.04 is fine.

NOTE: I've found a similar question: Ubuntu 16.10 randomizes function addresses at runtime

回答1:

They changed the default of GCC to emit Position Independent Executables. If you want the old behavior, compile with -fno-pie.



标签: linux ubuntu