当前位置:   article > 正文

用mprotect来定位Linux踩内存的问题_踩内存怎么定位

踩内存怎么定位
    最恶心的Bug莫过于踩内存,定位了内核问题的朋友都知道。这类问题一直没有很套路的方法解决,都需要走读大量的代码,做大量调试来解决。解这类问题最关键的两点就是,1,找到被踩的内存地址,2,抓住被踩的时序。

    想要找到被踩的内存地址,这里很多时候可以通过堆栈反汇编,和调试,查找出来,虽然很多时候被踩的地方不固定,这就糟糕了。就要想方法发现共同规律,比如是否在同一个全局变量里面,或者都是同一个业务场景里面?

    这里介绍一个好方法,如果知道了1,找到被踩的内存地址,2,抓住被踩的时序。可以用mprotect 来帮助定位问题。

  1. #include <sys/mman.h>
  2. int mprotect(const void *addr, size_t len, int prot);
  3. 此函数把自addr开始的、长度为len的内存区的保护属性修改为prot指定的值,prot值如下:
  4. prot标签值  描述
  5. PROT_NONE The memory cannot be accessed at all.
  6. PROT_READ The memory can be read.
  7. PROT_WRITE The memory can be written to.
  8. PROT_EXEC The memory can contain executing code.

在代码用这个函数把被踩的地址保护起来,如果其他模块或者代码尝试写操作,就会挂死,然后就会有堆栈,就顺着堆栈反汇编查出什么地方踩了内存了。


声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/花生_TL007/article/detail/152488
推荐阅读
相关标签
  

闽ICP备14008679号