linux c内存检测,Linux C调试库检测内存损坏

有时以前在带有简单MMU的嵌入式系统上工作时,我曾经动态编程这个MMU以检测内存损坏.

例如,在运行时的某个时刻,foo变量被一些意外数据覆盖(可能是通过悬空指针或其他任何东西).所以我添加了额外的调试代码:

>在init时,foo使用的内存被指示为MMU的禁区;

>每当foo被故意访问时,就可以在之前禁止访问该区域;

>添加了MMU irq处理程序以转储主服务器和负责违规的地址.

这实际上是某种观察点,但直接由代码本身自行处理.

现在,我想重用相同的技巧,但在x86平台上.问题是我很难理解在这个平台上如何使用MMU,以及Linux如何使用它,但我想知道是否已经存在任何库/工具/系统调用来处理这个问题.

请注意,我知道存在各种工具,如Valgrind或GDB来管理内存问题,但据我所知,这些工具都不会被调试代码动态重新配置.

我主要对Linux下的用户空间感兴趣,但也欢迎任何关于内核模式或Windows下的信息!

解决方法:

您可以使用mmap(MAP_ANONYMOUS)和mprotect函数来操作虚拟内存系统并使用相应的保护标志.当然,您的变量需要约束到系统页面大小的倍数.许多小变量将带来巨大的开销.

当然,在管理内存区域的访问权限时,您的应用程序需要正常工作.您还需要使用mmap()而不是malloc作为受保护区域.

这是MMU的用户空间接口层,以相对便携的方式.

标签:c-3,linux,debugging,memory-management,watchpoint

来源: https://codeday.me/bug/20190724/1518701.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值