- 1、本文档共31页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
gdb的基本工作原理 刘东 雨丝风片@chinaunix msn: yanbohuachuan@ 2007.12.15 gdb简介 gdb - GNU debugger。 gdb的主要功能 – 救死扶伤。 gdb的主要用途 – 修复bug;分析程序结构。 gdb官方网址 - /software/gdb/gdb.html gdb下载地址 - /gnu/gdb/ gdb调试的组成架构 gdb调试的工具 – ptrace系统调用 (1) ptrace系统调用的原型 long ptrace(enum __ptrace_request request, pid_t pid, void *addr, void *data); ptrace系统调用的简要说明 ptrace系统调用提供了一种方法来让父进程可以观察和控制其它进程的执行,检查和改变其核心映像以及寄存器。 gdb调试的工具 – ptrace系统调用 (2) ptrace系统调用的主要选项 PTRACE_TRACEME 表示本进程将被其父进程跟踪,交付给这个进程的所有信号(除SIGKILL之外),都将使其停止,父进程将通过wait()获知这一情况。 PTRACE_ATTACH attach到一个指定的进程,使其成为当前进程跟踪的子进程,子进程的行为等同于它进行了一次PTRACE_TRACEME操作。 PTRACE_CONT 继续运行之前停止的子进程。可同时向子进程交付指定的信号。 gdb的三种调试方式 (1) attach并调试一个已经运行的进程 调试关系的建立过程: 用户确定需要进行调试的进程id; 运行gdb,输入attach pid,gdb对指定进程执行下述操作: ptrace(PTRACE_ATTACH, pid, 0, 0); gdb的三种调试方式 (2) attach并调试一个已经运行的进程 gdb的三种调试方式 (3) 运行并调试一个新的进程 调试关系的建立过程: 运行gdb,通过命令行参数或file命令指定目标程序。 输入run命令,gdb执行下述操作: 通过fork()系统调用创建一个新进程; 在新创建的子进程中执行下述操作:ptrace(PTRACE_TRACEME, 0, 0, 0); 在子进程中通过execv()系统调用加载用户指定的可执行文件。 gdb的三种调试方式 (4) 运行并调试一个新的进程 gdb的三种调试方式 (5) 远程调试目标机上新创建的进程 gdb运行在调试机上,gdbserver运行在目标机上,两者之间的通信数据格式由gdb远程串行协议(Remote Serial Protocol)定义。 RSP协议数据的基本格式为:“$..........#xx”。 gdbserver的启动方式相当于运行并调试一个新创建的进程。 gdb的三种调试方式 (6) 远程调试目标机上新创建的进程 gdb调试的基础 – 信号 (1) 在使用参数为PTRACE_TRACEME或PTRACE_ATTACH的ptrace系统调用建立调试关系之后,交付给目标程序的任何信号(除SIGKILL之外)都将被gdb先行截获,或在远程调试中被gdbserver截获并通知gdb。 gdb因此有机会对信号进行相应处理,并根据信号的属性决定在继续目标程序运行时是否将之前截获的信号实际交付给目标程序。 gdb调试的基础 – 信号 (2) 信号是实现断点功能的基础。以x86为例,向某个地址打入断点,实际上就是往该地址写入断点指令INT 3,即0xCC。目标程序运行到这条指令之后就会触发SIGTRAP信号,gdb捕获到这个信号,根据目标程序当前停止位置查询gdb维护的断点链表,若发现在该地址确实存在断点,则可判定为断点命中。 gdb暂停目标程序运行的方法是向其发送SIGSTOP信号。 kill_lwp(process-head.id, SIGSTOP); gdb的同步模式和异步模式 同步模式 – gdb将以同步方式等待目标程序发生停止事件,可称之为“死等”。因此,在目标程序运行期间,gdb不再扫描标准输入,用户也无法输入任何调试命令,要么等待目标程序发生调试事件而停止,要么通过“Ctrl c”来暂停目标程序的运行。 异步模式 – gdb不会同步等待目标程序发生停止事件,此类事件将通过异步上报的方式告知gdb。在目标程序运行期间,gdb仍将扫描标准输入,用户可以输入调试命令。 使用同步模式还是异步模式由调试目标决定,在启动gdb之后通过target命令的参数给出。比如远程同步目标为target remote …,而远程异步目标为target async …。 gdb远程异步模式中的事件循环 (1) g
您可能关注的文档
最近下载
- 【高中英语】读后续写人物情绪描写.pptx
- 《思想政治教育方法论》PPT课件 2.第三章 课件 (有修改)第三章《思想政治教育方法的继承与改革》.ppt VIP
- 建筑施工行业安全风险辨识和管控指导清单分析.pdf VIP
- 2024年计算机二级《Python语言程序设计》考前冲刺备考题库资料200题(含答案).pdf
- 肾病科运用PDCA循环降低腹膜透析相关性腹膜炎发生率品管圈成果汇报.pptx
- 儿科临床常见微生物的检验方法及应用进展-2025年华医网继续教育答案.docx VIP
- 北京市2024-2025学年高一上学期9月月考地理试题含答案.docx VIP
- 新人教版英语七年级上册unit4课件.ppt
- 《麻醉科工作总结》课件.pptx VIP
- 活动单导学课程 一轮总复习 高中物理讲解详答.pdf VIP
文档评论(0)