我目前正在调查GDB的消息来源。我试图找出从GDB到BFD的转换是在哪里与内存“应用”一个断点的交互。因此,代码中的位置就是为了设置断点而对内存进行操作的位置。
有人能指引我吗?
发布于 2022-01-07 13:35:11
BFD不涉及插入断点。
GDB有许多可以插入断点的机制。但是,如果我们只查看内存断点,那么您应该开始查看gdb/mem-ACK.c。
当插入内存断点时,您将进入memory_insert_breakpoint,对于大多数体系结构来说,后者将调用default_memory_insert_breakpoint。
这个函数然后利用target_read_memory和target_write_raw_memory来读写内存。
根据您的目标是什么,这些目标函数将执行不同的任务,本地Linux目标将使用ptrace命令戳取内存,远程目标将向gdbserver发送数据包。
您还必须考虑远程目标可以支持硬件断点,也可以使用z/Z远程协议包插入/远程数据包,这些都可以在gdb/remote.c中找到,但是当您专门询问内存断点时,我将不详细介绍这些情况。
https://stackoverflow.com/questions/70619023
复制相似问题