这里介绍如何用Coredump文件查找崩溃的位置,使用的工具是gdb。另外一种调试Coredump问题的方便的办法,是使用backtrace()等相关函数。
1. 生成Debug版本软件包
使用选项CMAKE_BUILD_TYPE编译工程生成程序和库。
$ cmake -DCMAKE_BUILD_TYPE=Debug .
用cpack工具生成软件包mypkg.tar.gz。
$ cpack -c CPackConfig.cmake
2. 设置Linux生成Core
core文件的名称格式是core - <程序名> - <pid>。
$ ulimit -c unlimited
$ echo core-%e-%p > /proc/sys/kernel/core_pattern
3. 生成Core文件
- 在目标板上解开pos发布包:
/opt/mypkg/bin
/opt/mypkg/lib
- 运行软件包,得到core文件,并复制回宿主机。如:
/home/ronzheng/core.myapp.1234
5. 调试
- 在宿主机中解开mypkg.tar.gz,解开的位置应该包含目标板上位置的全路径,这里是/opt/mypkg。
/home/ronzheng/opt/mypkg
- 加载app和core。
$ arm-linux-gnueabi-gdb /home/ronzheng/opt/mypkg/bin/myapp /home/ronzheng/core.myapp.1234
- 加载动态库的符号
设置sysroot:
(gdb) set sysroot /home/ronzheng
查看动态库是否加载成功。
(gdb) info sharedlibrary
- 查看coredump的位置
(gdb) bt
相关链接
GDB 常用法
GDB 调试Coredump问题
嵌入式开发中GDB调试Coredump问题
嵌入式开发中GDB串口远程调试
用backtrace()调试coredump问题
Valgrind memcheck 用法
Address Sanitizer 用法
网友评论