我正在写一个程序来练习一些逆向工程技术。以下是英特尔( x86 )汇编代码的相关行:
mov, eax [ebp - 20]
cdq
idiv ecx通过我的输入(一个网络套接字),我可以控制在执行这些汇编代码行之前进入eax和ecx的字节数。
我的问题是:为了引起除法溢出,我可以使用的最小值(正数或负数)是多少(除法溢出不是“除以零”错误,但返回的结果大于32位,因此不适合eax (返回寄存器)。
提前感谢您的帮助!
发布于 2016-10-12 01:07:14
因为你的被除数是32位的,并且它被cdq符号扩展到64位,所以获得溢出的唯一方法是由于二的补码的不对称性,即它可以表示-2^31,但不能表示+2^31。因此,您可以使用-2^31 / -1。
https://stackoverflow.com/questions/39982609
复制相似问题