最近调试的C代码出现不知名的内存问题,只要涉及到内存申请和释放,就会出现SIGSEGV问题。
valgrind -tool=memcheck xxx args
AddressSanitizer
-fsanitize=address -fno-omit-frame-pointer
但是在QEMU上编译后,QEMU会退出,无法使用。
gcc 4.8以后加入这个功能,但是gcc4.9以前,打印的信息有限,是代码的偏移量,需要通过
addr2line -e xxx 0xXXX打印出所在的行。编译中需要有-g选项。
mtrace类似,需要增加头文件,增加一个函数调用。如果是动态链接库,需要
cat /proc/xxx/maps获取加载的基址,再用出问题的地址减去基址,然后用addr2line获取具体信息。
这里面感觉address sanitizer最好用