zoukankan      html  css  js  c++  java
  • linux下打印用户态段错误信息的一种方法

    引自:韦东山嵌入式视频第二期 “第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即可

  • 相关阅读:
    07组 Beta冲刺 (2/5)
    第07组 Beta冲刺 (1/5)
    第07组 Alpha冲刺 总结
    ES相关
    集群与分布式
    idea使用总结
    Tomcat配置与启动与访问
    Web基础
    B/S与C/S架构
    一周视频学习总结
  • 原文地址:https://www.cnblogs.com/yinsua/p/4429766.html
Copyright © 2011-2022 走看看