本文参考了马维华老师的《微机原理与接口技术》一书
指令格式:
MUL REG/MEM ;REG寄存器,MEM存储器
IMUL REG/MEM
MUL和IMUL指令分别用于实现无符号数的乘法和有符号数的乘法运算。都只有一个源操作数,可以使寄存器或存储器,而且目标操作数隐含规定在累加器中。
1)MUL指令
(a)、字节乘法,则AL×REG8/MEM8,乘积存于AX中。
(b)、字乘法,则AX×REG16/MEM16,乘积的高16位存放在DX中,低16位存放在AX中。
(c)、32位乘法,则EAX×REG32/MEM32,乘积的高32位存放在EDX中,低32位存放在EAX中。
(d)、64位乘法,则RAX×REG64/MEM64,乘积的高64位存放在RDX中,低64位存放在RAX中。
当乘积的高半部分(AH、DX、EDX、RDX)中存有结果的有效数字,则CF=OF=1,否则CF=OF=0。
2)IMUL指令
IMUL指令除了是完成两个有符号数的相乘以外,其他与MUL完全类似。
注:由于乘法指令为乘积保留了两倍于原来操作数的存储空间,因而不会出现溢出。

本文详细介绍了微处理器中的MUL和IMUL指令,这两种指令分别用于执行无符号数和有符号数的乘法运算。文章解释了不同位宽下的乘法运算过程,包括字节、字及更长位宽的乘法,并讨论了乘法结果如何存储以及条件标志的变化。
1万+

被折叠的 条评论
为什么被折叠?



