问题描述
首先,我使用mprotect函数使内存区域不可写。
if (mprotect(mem_vadrs,offset,PROT_READ) == 0)
{
return 1;
}
else
{
perror("mprotect Failed\n");
return 0;
}
然后,我将在此存储区中执行相关的写入命令并触发段错误。 在信号处理程序函数内部,我将该区域恢复为可写状态并记录该区域的地址(逻辑地址)。在此步骤之后,我还需要在信号处理函数内部执行哪些其他操作?作为学习者,我不知道关于Linux内核在处理SIGSEGV信号时所做的工作。这是SIGSEGV信号处理程序的代码。
printf("Got SIGSEGV at address: %p\n",(long) si->si_addr);
unsigned long pagenum = (unsigned long)si->si_addr / 4096;
unsigned long pageaddr = pagenum * 4096;//mprotect requires that the parameter be the page starting address
unsigned long phyaddr = 0x0;//Not yet
mprotect(pageaddr,4096,PROT_WRITE);
printf("pageaddr:%p\n",pageaddr);
如所示的代码。在信号处理程序功能中,我使设置为不可写的页面再次可写,这样我可以捕获每个页面写的内容,并且程序可以正常运行。 我的目标是计算在一个进程中写入特定内存区域的物理页面的数量,在这里我只获得逻辑页面地址。我知道我可以读取文件“ pagemap”来获取页面映射,但是它没有将这些操作写入信号处理程序似乎是线程安全的,而我这样做确实会触发很多错误。 你有什么建议吗?
解决方法
暂无找到可以解决该程序问题的有效方法,小编努力寻找整理中!
如果你已经找到好的解决方法,欢迎将解决方案带上本链接一起发送给小编。
小编邮箱:dio#foxmail.com (将#修改为@)