Advanced Debugging
About AdvDbg Consult Train Services Products Tools Community Contact  
欢迎光临 高端调试 登录 | 注册 | FAQ
 
  ACPI调试
Linux内核调试
Windows内核调试
 
  调试战役
调试原理
新工具观察
 
  Linux
Windows Vista
Windows
 
  Linux驱动
WDF
WDM
 
  PCI Express
PCI/PCI-X
USB
无线通信协议
 
  64位CPU
ARM
IA-32
  CPU Info Center
 
  ACPI标准
系统认证
Desktop
服务器
 
  Embedded Linux
嵌入式开发工具
VxWorks
WinCE
嵌入式Windows
 
  格蠹调试套件(GDK)
  格蠹学院
  小朱书店
  老雷的微博
  《软件调试》
  《格蠹汇编》
  《软件调试(第二版)》
沪ICP备11027180号-1

WinDbg

帖子发起人: nigel   发起时间: 2009-12-18 15:35 下午   回复: 3

Print Search
帖子排序:    
   2009-12-18, 15:35 下午
yicaolove 离线,最后访问时间: 2011/2/17 6:15:38 nigel

发帖数前50位
注册: 2009-05-20
发 贴: 18
windbg break point
Reply Quote
当我们用windbg时,用bp bu等命令设置好断点,然后命中断点进入到调试器,那么此时我们设置的断点位置的指令是已经执行了的,还是将要执行的呢?
IP 地址: 已记录   报告
   2009-12-18, 16:24 下午
pch 离线,最后访问时间: 2009/12/1 15:36:26 pch

发帖数前25位
注册: 2008-08-26
发 贴: 28
Re: windbg break point
Reply Quote
将要执行啊……
IP 地址: 已记录   报告
   2009-12-21, 22:03 下午
uglyangel 离线,最后访问时间: 2016/5/21 11:16:32 uglyangel

发帖数前100位
男
注册: 2009-11-14
天津
发 贴: 11
Re: windbg break point
Reply Quote
和在代码下断点一样吧.
IP 地址: 已记录   报告
   2009-12-28, 12:49 下午
Raymond 离线,最后访问时间: 2020/7/3 3:40:25 格蠹老雷

发帖数前10位
注册: 2005-12-19
发 贴: 1,303
Re: windbg break point
Reply Quote
这个问题挺好的,说明楼主的思考已经精确到指令一级。
因为bp, bu都是基于断点指令(x86上即INT 3)工作的,设置断点时,断点位置是被换成断点指令的,所以断点命中时,准确说,那里的INT 3已经执行过了,但是那条本来的指令还没执行呢,因为本来的指令已经被替换掉了。
对于使用ba设置的数据监视断点,中断下来时,访问数据的指令已经执行过了,程序指针指向的是下一条指令。

要完全理解其中的原因,应该知道IA-32把异常分成了三类,根据异常的类型不同,CPU的EIP指针可能指向导致异常的,也可能指向下一条指令,如果有《软件调试》,那么可以看一下表3-1和表4-2。

IP 地址: 已记录   报告
高端调试 » 软件调试 » WinDbg » windbg break point

 
Legal Notice Privacy Statement Corporate Governance Corporate Governance
(C)2004-2020 ADVDBG.ORG All Rights Reserved.