-
-
[分享]F2与F7原理的理解
-
发表于: 2012-3-29 16:44 2841
-
看过坛子里好多大牛关于断点原理的介绍。可是F2与F7的原理始终有点模糊,于是今天用了一些时间,并经过一些实验,总结了一下。应该不算什么成果。只是为了那些跟我一样搞不懂F2与F7区别的人写的~·~
F2是将所选行的第一个字节替换成CC(int 3),F7是将当前的TF标志置为1(会执行int 1)。
int 3与将TF标志置1在调试器中的区别:
int 3:程序将断在int 3处。
将TF置1:程序将断在下一条原子操作处,并将TF位清零。原子操作是指不会被线程调度机制打断的操作;这种操作一旦开始,就一直运行倒结束,中间不会有任何 context switch (切换到另一个线程)。call指令是原子操作,它的作用是:将返回地址压栈,并跳转。所以,在调用call的时候,如果我们将TF置1,那么程序将在call指令的功能完成以后(即将返回地址压栈并跳转)断下来。而执行call内的语句则仅仅是call的逻辑功能(我们理解的功能),并非实际的功能(CPU理解的功能)。
搞清楚call的实际作用,再来理解F2与F7原理的不同应该就没什么问题了。
有什么不对的地方欢迎大家指正~_~
F2是将所选行的第一个字节替换成CC(int 3),F7是将当前的TF标志置为1(会执行int 1)。
int 3与将TF标志置1在调试器中的区别:
int 3:程序将断在int 3处。
将TF置1:程序将断在下一条原子操作处,并将TF位清零。原子操作是指不会被线程调度机制打断的操作;这种操作一旦开始,就一直运行倒结束,中间不会有任何 context switch (切换到另一个线程)。call指令是原子操作,它的作用是:将返回地址压栈,并跳转。所以,在调用call的时候,如果我们将TF置1,那么程序将在call指令的功能完成以后(即将返回地址压栈并跳转)断下来。而执行call内的语句则仅仅是call的逻辑功能(我们理解的功能),并非实际的功能(CPU理解的功能)。
搞清楚call的实际作用,再来理解F2与F7原理的不同应该就没什么问题了。
有什么不对的地方欢迎大家指正~_~
赞赏
他的文章
- [求助]metasploit安装不了啊~~~~~~~~~~ 6209
- [讨论]一个面试官的问题 26864
- [求助]如何设置寄存器有关断点 3776
- [求助]PE启动时,操作系统不会加载PE文件哪些部分 3969
看原图
赞赏
雪币:
留言: