引自:韦东山嵌入式视频第二期 “第31课第3节_应用调试之配置修改内核打印用户态段错误信息_P” 第6分钟起。
1.配置内核支持DEBUG_USER (勾选 Kernel hacking -> Verbose user fault messages[*] 即可)(视频第8:23)
2.设置bootargs,添加参数 user_debug = 0xFF 即可。 user_debug的每一位代表设置不同的模式,具体模式可参考文件:include/asm-arm/System.h下的UDBG_XXX。
如果执行有段错误的程序时会有详细错误信息打印出来。
你可以根据PC值和各个寄存器值来定位错误位置。
首先对问题应用程序进行反汇编: arm-linux-objdump -D FileName > AnotherFile
然后打开AnotherFile查看反汇编,定位PC值处的指令即可。
附:
查看系统调用函数的地址范围:查看文件system.map即可。
查看当前系统某个函数所在地址:查看/proc/kallsyms文件(文件较大,最好重定位到文件后再查看)
查看函数调用顺序: strace -o xxxFile ./xxx 然后查看xxxFile即可
时间: 2024-12-29 11:54:57