我正在检查ELF二进制文件是否包含以下代码。我在Virtual Box的Ubuntu x86_64系统上的gcc 7.4.0上将其编译为:
gcc -g scratch1.c -o scratch1.out
#include <stdio.h>
void do_stuff(int my_arg){
int my_local = my_arg + 2;
int i;
for (i = 0; i < my_local; ++i) printf("i = %d\n", i);
}
int main(){
do_stuff(2);
return 0;
}
但是,当我尝试引用.debug_loc部分时,它为空。
objdump --dwarf=loc scratch1.out
scratch1.out: file format elf64-x86-64
尽管,我确实看到了其他的debug_部分
[26] .debug_aranges PROGBITS 0000000000000000 0000103b
0000000000000030 0000000000000000 0 0 1
[27] .debug_info PROGBITS 0000000000000000 0000106b
000000000000035f 0000000000000000 0 0 1
[28] .debug_abbrev PROGBITS 0000000000000000 000013ca
0000000000000125 0000000000000000 0 0 1
[29] .debug_line PROGBITS 0000000000000000 000014ef
00000000000000e6 0000000000000000 0 0 1
[30] .debug_str PROGBITS 0000000000000000 000015d5
00000000000002b5 0000000000000001 MS 0 0 1
需要您的帮助,为什么缺少此部分。
需要您的帮助,为什么缺少此部分。
.debug_loc
部分包含DW_AT_location
列表,通常为优化代码而发出only。
由于您已编译without优化,因此编译器未发出此部分。尝试使用:
gcc -g -O3 scratch1.c -o scratch1.out
这是我在gcc 8.3.0中看到的内容:
$ gcc -g scratch.c && readelf -WS a.out | grep debug_loc
# no output
$ gcc -g scratch.c -O3 && readelf -WS a.out | grep debug_loc
[32] .debug_loc PROGBITS 0000000000000000 0039db 000230 00 0 0 1