Why “DIV EDX” in MASM always generates processor exception?

后端 未结 1 1162
再見小時候
再見小時候 2021-01-18 22:42

I\'ve got that question on my Computer Architecture Exam on Informatics last semester : \"Why \'DIV EDX\' in MASM always generates processor exception?\"
What i

1条回答
  •  慢半拍i
    慢半拍i (楼主)
    2021-01-18 23:06

    When you do 1-operand division on x86 CPUs, EDX:EAX (64 bit) is divided by the 1st operand (32 bit). The result is stored in EAX (32 bit).

    So when you divide by EDX:EAX by EDX, what you essentially get is (EDX * 0x100000000 + EAX) / EDX, which result is always above 0x100000000 and does not fit into the target register or the divisor is zero. In both cases a divide exception occurs.

    See also this page (from the Intel developer manuals).

    Note that this is not specific to the assembler (MASM), but to the platform in this case.

    0 讨论(0)
提交回复
热议问题