Linux segfault错误排查

17 篇文章 0 订阅

Linux下一般情况程序出现段错误异常崩溃时,并不会产生core文件,此时可借助/var/log/messages中打印的错误信息进行排查。如下错误信息:

segfault at 7f30beffe000 ip 00007f30c6eebda9 sp 00007f30a7ffc4a0 error 4 in libc-2.17.so[7f30c6e56000+1c3000]

其中,异常在libc-2.17.so库中,00007f30beffe000为出错地址,7f30c6eebda9为指令地址,00007f30a7ffc4a0为栈变指寄存器。error 4代表用户态读取内存越界  7f30c6e56000为libc-2.17.so映射到程序内存的基地址。

偏移地址   =   指令地址   -   基地址         --------------->      95DA9 =  7f30c6eebda9  -  7f30c6e56000

通过偏移地址查找所在的函数,

[root@localhost ~]# objdump -tT /lib64/libc-2.17.so | grep 095a
0000000000095a70 l     F .text  0000000000000415              __GI_memmem
0000000000095a70 g     F .text  0000000000000415              memmem
0000000000095a70 g    DF .text  0000000000000415  GLIBC_2.2.5 memmem

由此可判断是出错memmem函数中,此时我们再反汇编libc-2.17.so,找到对应函数的汇编代码,查到对应偏移地址

 

关于error错误码:

/*
 * Page fault error code bits:
 *
 *   bit 0 ==     0: no page found    1: protection fault
 *   bit 1 ==     0: read access        1: write access
 *   bit 2 ==     0: kernel-mode access    1: user-mode access
 *   bit 3 ==                1: use of reserved bit detected
 *   bit 4 ==                1: fault was an instruction fetch
 */
enum x86_pf_error_code {
 
    PF_PROT        =        1 << 0,
    PF_WRITE    =        1 << 1,
    PF_USER        =        1 << 2,
    PF_RSVD        =        1 << 3,
    PF_INSTR    =        1 << 4,
};

 

 

  • 1
    点赞
  • 19
    收藏
    觉得还不错? 一键收藏
  • 6
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 6
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值