软件调试笔记15 - 用户态调试过程:调试会话

调试会话有两种建立方式:从调试器启动被调试程序,附件到被调试程序。


从调试器启动:就是在调用创建进程的API比如CreateProcess时指定DEBUG_PROCESS或者DEBUG_ONLY_THIS_PROCESS。前者是调试正在创建的进程以及子进程,后者不包括子进程。系统在创建进程的时候,如果发现包括这俩标志,则会把新创建的进程当作被调试程序,把调用进程当作调试器进程。并在创建过程中设置DebugPort, BeingDebugged。


第一批调试事件

当创建好后,调试器与被调试进程的对话就建立起来了,调试器线程接下来进入调试事件循环来接收调试事件。



初始断点

当新进程的初始线程在自己的上下文初始化时,NTDLL中的函数会检查正在初始化的进程是否处于被调试状态,如果是,则会触发一个断点异常,中断到调试器。相当于系统在新进程中设置的一个断点,称为初始断点。当这个断点发生的时候,被调试程序的主函数还没执行,因此对于调试在程序初始化阶段发生的问题非常有意义


自动启动调试器




附加到已经启动的进程

主要是通过DebugActiveProcess API来完成的。只需要将一个进程ID传给它,系统就会将这个API的进程跟传递进来的进程建立调试关系。







  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 2
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值