linux – gdb暂时是否允许页面写入权限?
我正在调试一个
Linux应用程序中的seg错误,该错误是由程序试图更改静态常量数组结构引起的(因此数据位于ELF的只读部分,随后加载到一个页面中,然后读取 – 唯一的许可).
在GDB中,我在汇编程序中放置了一个断点,它执行了坏存储,当它停在那里时,我使用GDB手动执行了等效的写操作. GDB在没有任何投诉的情况下做到了这一点,并且阅读价值证明它确实已经写好了.我查看了/ proc / thepid / maps,并且该特定页面仍被标记为“不可写”. 所以我的问题是:GDB是否暂时在只读页面上设置写权限,执行写操作,然后重置权限?谢谢. 解决方法
没有. 在Linux / * 86上,ptrace()(这是GDB用来读取和编写下级(正在调试的)进程内存)允许读取和写入不可读/不可读的页面,这导致了你的困惑已经描述过. 这可以被认为是内核中的错误. 应该注意的是,内核必须允许ptrace写入通常不可写的.text段,以便调试器能够设置断点(通过使用断点/陷阱指令覆盖原始指令 – 通过PTRACE_POKETEXT请求int3来完成) ). 内核不必为POKE_DATA做同样的事情,但man ptrace说: PTRACE_POKETEXT,PTRACE_POKEDATA Copies the word data to location addr in the child's memory. As above,the two requests are currently equivalent. 我相信这是导致当前行为的等效性. (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |