准备跟一下iostat(包含在sysstat软件包中)的源码。在Eclipse中新建一个Makefile工程,导入sysstat 9.1.3的源代码。代码可以通过编译,编译出来的iostat也可以正常运行。然而,在Eclipse调试运行却提示"function 'main' not defined",代码中的断点也都不起作用。

在命令行下用gdb调试,在main函数上设置断点时也会提示"function 'main' not defined"。

将iostat用objdump反汇编,在汇编代码中看到一处"call __libc_start_main"。于是在gdb中在__libc_start_main函数上设断点,成功,单步跟踪,然而跟到libc-start.c中的"result = main (argc, argv, __environ MAIN_AUXVEC_PARAM)"这一行就再也跟不进去了。

在Eclipse中建一个对比C工程,编译,然后用objdump反汇编,发现该反汇编结果中的"Symbol table '.symtab'"含有符号"main",然而前面反汇编的iostat中却没有。

于是考虑是不是两个工程的gcc编译参数不一样,于是进行比较:

iostat:
编译:
gcc -o iostat.o -c -g3 -O0 -Wall -Wstrict-prototypes -pipe -O0 -DSA_DIR=/"/var/log/sa/" -DSADC_PATH=/"/usr/local/lib/sa/sadc/" -DUSE_NLS -DPACKAGE=/"sysstat/" -DLOCALEDIR=/"/usr/local/share/locale/" iostat.c
链接:
gcc -o iostat -g3 -O0 -Wall -Wstrict-prototypes -pipe -O0 iostat.o librdstats.a libsyscom.a -s

对比C工程:
编译:
gcc -O0 -g3 -Wall -c -fmessage-length=0 -MMD -MP -MF"ttt.d" -MT"ttt.d" -o"ttt.o" "../ttt.c"
链接:
gcc -o"testtest" ./ttt.o

参数相差的还不少,经过一番查阅资料,发现问题出在iostat链接参数中的"-s"上,gcc手册上写"-s"的作用是"Remove all symbol table and relocation information from the executable"。

于是进入sysstat工程的Makefile,将"LFLAGS"里的"-s"删掉。这样再编译的iostat就可以正常调试了。自己对gcc了解不多,这个小问题就折腾了半天,也让我学到不少。

 

 

Logo

更多推荐