汇编--算术运算类指令

加法指令:ADD、ADC、INC

减法指令:SUB、SBB、DEC、NEG、CMP

乘法指令:MUL、IMUL

除法指令:DIV、IDIV

十进制调整指令:DAA、DAS、AAA、AAS、AAM、AAD



加法指令: ADD

带进位加法指令:ADC

加一指令:   INC

注意: 除 INC 指令不影响 CF 标志外,均对条件标志位有影响。



结果为0   ZF=1       结果为负   SF=1

CF 位表示 无符号数 相加的溢出。   和的最高有效位 有 向高位的进位

OF 位表示 带符号数 相加的溢出。

  • 两个操作数符号相同,而结果符号与之相反
  • 两个操作数符号相反,而结果的符号与减数相同


减法指令: SUB(subtract)

带借位减法指令:SBB         SBB指令主要与SUB配合,实现多精度减法运算

减一指令: DEC(decrement)

求补指令: NEG    OPR       求补运算也可以表达成:将操作数按位取反后加1,忘记加1了。

比较指令: CMP    OPR1,OPR2       

INC指令和DEC指令都是单操作数指令, 主要用于对计数器和地址指针的调整

NEG 指令对CF/OF的影响    求补后

  • 操作数为0   CF=0  否则为1
  • 操作数为 -128 (字节运算)或 操作数为 -32768 (字运算)   OF=1  否则为1


CMP指令执行的功能与SUB指令相同,但结果不回送目的操作数



无符号数乘法指令:   MUL

带符号数乘法指令:   IMUL

无符号数乘法指令: MUL SRC 执行操作:

  • 字节操作数 ( AX ) ? ( AL ) * ( SRC )
  • 字操作数 ( DX , AX ) ? ( AX ) * ( SRC )

带符号数乘法指令: IMUL SRC

乘法指令利用OF和CF判断乘积的高一半是否具有有效数值

MUL指令——若乘积的高一半(AH或DX)为0,则OF=CF=0;否则OF=CF=1

IMUL指令——若乘积的高一半是低一半的符号扩展,则OF=CF=0;否则均为1

乘法指令对其他状态标识没有定义

对标志没有定义:指令执行后这些标志是任意的、不可预测(就是谁也不知道是0还是1)

对标志没有影响:指令执行不改变标志状态



除法

DIV是无符号数除法 DIV;完成两个无符号数相除。

IDIV 是有符号数除法指令,完成两个有符号数相除。

无符号数除法指令: DIV SRC 执行操作:

  字节操作:( AL ) ? ( AX ) / ( SRC ) 的商

        ( AH ) ? ( AX ) / ( SRC ) 的余数

  字操作 : ( AX ) ? ( DX , AX ) / ( SRC ) 的商

        ( DX ) ? ( DX , AX ) / ( SRC ) 的余数

带符号数除法指令: IDIV SRC

注意:

  • AX ( DX , AX ) 为隐含的被除数寄存器。
  • AL ( AX ) 为隐含的商寄存器。
  • AH ( DX ) 为隐含的余数寄存器。
  • SRC 不能为立即数。
  • 对所有条件标志位均 无定义。

除法指令对标志没有定义 除法指令会产生结果溢出

除法错中断   被除数远大于除数时候,就会产生编号为0的溢出。



十进制调整指令

十进制数调整指令对二进制运算的结果进行十进制调整,以得到十进制的运算结果

分成压缩BCD码和非压缩BCD码调整

压缩BCD码就是通常的8421码;它用4个二进制位表示一个十进制位,一个字节可以表示两个十进制位,即00~99

非压缩BCD码用8个二进制位表示一个十进制位,只用低4个二进制位表示一个十进制位0~9,高4位任意,通常默认为0   造成浪费

压缩BCD码调整指令: DAA、DAS

非压缩BCD码调整指令: AAA、AAS、 AAM、AAD

DAA ;AL←将AL的加和调整为压缩BCD码

DAS ;AL←将AL的减差调整为压缩BCD码    还会借1呢?

使用DAA或DAS指令前,应先执行以AL为目的操作数的加法或减法指令

DAA和DAS指令对OF标志无定义,按结果影响其他标志,例如CF反映压缩BCD码相加或减的进位或借位状态

add al,bl     ;二进制加法:al=68h+28h=90h

daa            ;十进制调整:al=96h

sub al,bl   ;二进制减法:al=68h-28h=40h

das          ;十进制调整:al=40h

das ;34-12=22,CF=0

das ;12-46=66,CF=1

AAA ;AL←将AL的加和调整为非压缩BCD码 ;AH←AH+调整的进位

AAS ;AL←将AL的减差调整为非压缩BCD码 ;AH←AH-调整的借位

使用AAA或AAS指令前,应先执行以AL为目的操作数的加法或减法指令

AAA和AAS指令在调整中产生了进位或借位,则AH要加上进位或减去借位,同时CF=AF=1,否则CF=AF=0;它们对其他标志无定义

mov ax,0608h ;ax=0608h,非压缩BCD码表示真值68

mov bl,09h ;bl=09h,非压缩BCD码表示真值9

add al,bl ;二进制加法:al=08h+09h=11h

aaa ;十进制调整:ax=0707h;实现非压缩BCD码加法:68+9=77

sub al,bl ;二进制减法:al=08h-09h=ffh

aas ;十进制调整:ax=0509h ;实现非压缩BCD码减法:68-9=59

AAM ;AX←将AX的乘积调整为非压缩BCD码

AAD ;AX←将AX中非压缩BCD码扩展成二进制数

  • AAM指令跟在字节乘MUL之后,将乘积调整为非压缩BCD码
  • AAD指令跟在字节除DIV之前,先将非压缩BCD码的被除数调整为二进制数
  • AAM和AAD指令根据结果设置SF、ZF和PF,但对OF、CF和AF无定义

mul bl ;二进制乘法:al=08h×09h=0048h

aam ;十进制调整:ax=0702h ;实现非压缩BCD码乘法:8×9=72

aam ;二进制扩展:ax=68=0044h

div bl ;除法运算:商al=07h,余数ah=05h ;实现非压缩BCD码初法: 68÷9=7(余5)

时间: 2024-08-10 21:14:11

汇编--算术运算类指令的相关文章

8086算术运算类指令

算术运算指令 ①加法类指令 ②减法类指令 ③乘法指令 ④除法指令 ⑤BCD吗指令 一.加法类指令 首先我么们先看加法类指令三个(add,adc,inc) 1)不带进位位的加法指令ADD add用来执行2个字节或2个字的相加操作,运算时不考虑CF位 ADD DST,SRC   ;DST<--(DST)+(SRC) ADD影响OF,SF,ZF,AF,PF,CF标志 2)带进位位的加法指令ADC ADC在功能上和ADD类似,只是有一点区别,即执行ADC指令时,将进位标志CF的值加进和中. ADC DS

ARM汇编初探---汇编代码中都有哪几类指令---ARM伪指令介绍

要学习一个东西首先要把概念搞清楚,下面只是自己的一些关于汇编的理解. 可执行文件中的01码是机器码,机器码不等于汇编码,虽然机器码可以很容易翻译成汇编码. 汇编码中包含很多汇编指令.伪指令和宏指令等,这些是不可以直接在机器上运行的. 机器指令是ARM指令集和Thumb指令集这些arm硬件支持的指令集组成的. 汇编码中的伪指令和宏指令这些都是汇编语言这个级别的指令,在汇编文件编译的时候汇编编译器as会去处理这些指令,在编译期间也会对宏进行展开,类似于gcc编译的时候对C代码中的宏展开一样.个人感觉

汇编--指令系统 数据传送类指令

(1) 数据传送类指令 通用数据传送指令:MOV .PUSH.POP.XCHG 交换指令 累加器专用传送指令: IN.OUT .XLAT 换码指令 地址传送指令:LEA.LDS.LES 标志寄存器传送指令:LAHF.SAHF.PUSHF.POPF 类型转换指令:CBW.CWD.CDQ.BSWAP MOV指令 对于存储器单元与立即数同时作为操作数的情况,必须显式指明   ;byte ptr 说明是字节操作   ;word ptr 说明是字操作 mov [bx],[si+2]  错误 不允许立即数传

or1200中加载存储类指令说明

以下内容摘自<步步惊芯--软核处理器内部设计分析>一书 OR1200中实现的加载存储类指令有8条,每条指令的作用与说明如表9.1所示. 说明一点:在第2章建立的最小系统没有配置使用MMU,所以有效地址等于物理地址. 加载存储类指令的助记符也很好理解记忆,第一位是's'表示存储指令,'l'表示加载指令:第二位是'b'表示对字节操作,'h'表示对半字操作,'w'表示对字操作:第三位是'z'表示零扩展,'s'表示符号扩展.据此可以对指令进行简称,如:l.sb指令可以简称为存储字节指令.l.lwz指令

or1200中载入存储类指令说明

下面内容摘自<步步惊芯--软核处理器内部设计分析>一书 OR1200中实现的载入存储类指令有8条,每条指令的作用与说明如表9.1所看到的. 说明一点:在第2章建立的最小系统没有配置使用MMU,所以有效地址等于物理地址. 载入存储类指令的助记符也非常好理解记忆.第一位是's'表示存储指令,'l'表示载入指令.第二位是'b'表示对字节操作,'h'表示对半字操作,'w'表示对字操作:第三位是'z'表示零扩展,'s'表示符号扩展.据此能够对指令进行简称,如:l.sb指令能够简称为存储字节指令.l.lw

or1200处理器的异常处理类指令介绍

以下内容摘自<步步惊芯--软核处理器内部设计分析>一书 我们在计算机体系结构的学习中知道:中断实质上包括由外部事件引起的硬中断(又称外中断)和由内部预先安排的特定指令或内部异常引起的软中断(又称内中断或异常)两大类.在OR1200处理器中将中断称之为异常(exception),硬中断是其中的一种异常,当然这只是说法的不同而已.当异常发生时,有关处理器的状态信息被存储到某些寄存器,OR1200处理器转移到事先定义好的一个地址,在那个地址中往往有异常处理例程,在其中进行异常处理,这个地址称为异常处

汇编中的指令对齐

title: 汇编中的指令对齐 tags: ARM date: 2018-10-23 20:50:39 --- 汇编中的指令对齐 搜索下官方文档的索引.align,有如下描述,也就是有两种情况,对于ARM,表示的是末尾几个0,也就是2^x了.具体填充格式可以指定align abs-expr, abs-expr, abs-expr,参考链接 For other systems, including ppc, i386 using a.out format, arm and strongarm, i

汇编跳转指令B、BL、BX、BLX 和 BXJ的区别

跳转指令用于实现程序流程的跳转,在 ARM 程序中有两种方法可以实现程序流程的跳转: (1) 使用专门的跳转指令. (2) 直接向程序计数器 PC 写入跳转地址值. 通过向程序计数器 PC 写入跳转地址值,可以实现在 4GB 的地址空间中的任意跳转,在跳转之前结合使用 MOV LR , PC 等类似指令,可以保存下一条指令地址作为将来的返回地址值,从而实现在 4GB 连续的线性地址空间的子程序调用. 专门的跳转指令 B.BL.BX.BLX 和 BXJ: 跳转.带链接跳转(带返回的跳转).跳转并切

汇编总结:mov指令

mov指令的作用: mov指令可能是汇编里用的最多的指令了,完成c语言里的赋值. mov指令种类: 普通的mov指令 做符号扩展的movs 做零扩展的movz 普通mov的种类有: movb #完成1个字节的复制 movw #完成2个字节的复制 movl #完成4个字节的复制 movq #完成8个字节的复制 movs的种类以及为什么要符号扩展指令? 1.为什么要用符号扩展指令 如果要完成下面的c语言代码 char c = -1; int i = c; 如果翻译成下面的汇编代码,会发现一个问题 用