断点设置原理

原创 2007年09月26日 08:27:00

调试寄存器:

在寄存器中, 有一些调试寄存器专门用于调试的作用. 人们经常把它们称为调试寄存器, 调试寄存器共有 8 个,
分别是 Dr0-Dr7. 这 8 调试寄存器常被简称为 Drx.

Dr0-Dr3: 这 4 个调试寄存器的作用是存放中断的地址, 例如: 0x400000。 这 4 个调试寄存器共同时可以存放 4 个断点.(这指的是硬件断点).
Dr4-Dr5 这两个寄存器我们已使用他们, 保留
Dr6-Dr7 这2 各寄存器的作用是来记录你在 Dr0-Dr3 中下断点的属性, 比如: 对于这个 0x400000 是硬件读还是写, 或者是执行; 是对字节还是对字或者是双字.

上面对调试器的介绍可以解决下面的疑惑:
(1) 硬件断点职能设置 4 个.
(2) 为什么硬件断点有 byte, word, dword 之分.
(3) 为什么下硬件断点有 读, 写, 执行之分.


OllyDbg 中

F4 功能是: 运行到光标位置
实现方法是:
在指定的光标位置处设置硬件断点. 如图:我把程序入口函数处的指令全部改为了 nop,并改了 0x0040228B 处的指令为 JMP 指令, 相当于 JMP $。然后我们使光标指向 0x0040228F 按下 F4, 此时程序执行. 我们查看右侧的寄存器窗口:
Dr0 为 0x0040228F. 这就说明当执行到这条指令时暂停.

F8 单步步过:
单步步过是在 call 指令的返回地址处设置断点


F7 单步步入:
F7 是利用 TF 陷阱标志来使指令一条一条的执行.
F7 使TF=1, 当程序执行后只能执行一条指令然后就停住, 此时 TF=0; 再按 F7 TF=1, 执行一条指令后程序暂停 TF=0 ,这就达到了步入的效果.


F2 设置断点:

实现方法是在程序执行后, 把指定地址的指令替换为 int 3, 当程序运行到该地址处的指令时中断,然后替换回原先的指令.


 

iOS-断点设置(调试程序)

编码不能没调试,调试不能没断点(Break Point)。XCode的断点功能也是越来越强大。 基本断点 如下图,这种是最常用的断点,也是最容易设置。左键点击一下就可以设置。 ...

gdb break 断点设置(一)

http://sourceware.org/gdb/current/onlinedocs/gdb 二、断点设置 gdb断点分类: 以设置断点的命令分类: breakpoint 可以根据行号、...

Chrome 中的 JavaScript 断点设置和调试技巧

你是怎么调试 JavaScript 程序的?最原始的方法是用 alert() 在页面上打印内容,稍微改进一点的方法是用 console.log() 在 JavaScript 控制台上输出内容。嗯~,用...

eclipse中各种断点设置方法

大家肯定都用过Eclipse的调试的功能,在调试的过程中自然也无法避免要使用断点(breakpoint),但不知是否对Eclipse中各类断点都有所了解 1. 示例程序 BreakpointDem...

使用Chrome调试JavaScript的断点设置和调试技巧

使用Chrome调试JavaScript的断点设置和调试技巧  分类: javascript 你是怎么调试 JavaScript 程序的?...

gdb调试(二)断点设置(英文板)

Breakpoints are set with the break command (abbreviatedb). The debugger convenience variable `$bpnum...

Chrome 中的 JavaScript 断点设置和调试技巧

你是怎么调试 JavaScript 程序的?最原始的方法是用 alert() 在页面上打印内容,稍微改进一点的方法是用 console.log() 在 JavaScript 控制台上输出内容。嗯~,用...

[转]VS2005调试器 1,断点设置有技巧

VS2005调试器 1,断点设置有技巧: 1)设置条件断点,比如i==10,变量改变时断点; 2)如何让断点在指定的命中次数或者大于某个次数时触发呢?方法是设定几个断点的HitCount,右键单击...

Chrome 中的 JavaScript 断点设置和调试技巧

http://han.guokai.blog.163.com/blog/static/136718271201321402514114/ 你是怎么调试 JavaScript 程序的?最原始的方法是用...

VCDebug、Ollydbg、WinDbg字符串条件断点设置方法总结

无聊的时候浏览看雪,总是会有些收获。碰到好的文章就转载过来了,再次对原作者表示感谢! 原文:http://bbs.pediy.com/showthread.php?t=173334   大牛直接...
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:断点设置原理
举报原因:
原因补充:

(最多只允许输入30个字)