Re: 除0异常

Windows内核调试

除0异常


saga 2011-01-10, 22:57 下午

<<软件调试>> 的P71除0异常程序,我在vs2008中运行了,出现死循环,不停输出

In __except block: nDividend=22, nDivisor=1, nResult=100.
Divide Zeroexception detected:nDividend=22, nDivisor=1, nResult=100.

 

查看反汇编代码发现

    11:   nResult=nDividend / nDivisor;
00411451 8B 45 E0         mov         eax,dword ptr [ebp-20h]
00411454 99               cdq             
00411455 F7 F9            idiv        eax,ecx
00411457 89 45 C8         mov         dword ptr [ebp-38h],eax

原来nDivisor值取到ecx中了,因此无论如何修改nDivisor值,也不会影响ecx的值。

如何产生和书上相同的代码呢?

 

第二个问题,调试器如何确认硬件断点中读命中的呢?

Re: 除0异常


格蠹老雷 2011-01-11, 11:48 上午
这是个已知的问题,请参考下面的讨论:

http://advdbg.org/forums/3693/ShowPost.aspx

Re: 除0异常


格蠹老雷 2011-01-11, 11:49 上午
第二个问题: 调试器通过察看DR6知道哪个硬件断点命中.
因为硬件的限制,x86上不可以只有读时命中,之可以设置为读写都命中(ba r),或者只有写时命中(ba w)。

你说的是何调试器?

Re: 除0异常


saga 2011-01-11, 12:04 下午
谢谢,我以为ba r只管读呢?

Powered by Community Server Powered by CnForums.Net