文档详情

第2章4微处理器指令系统.ppt

发布:2017-05-03约7.27千字共47页下载文档
文本预览下载声明
第二章 微处理器指令系统 华北电力大学 计算机系 刘丽 2.4 算术运算类指令 用来执行二进制的算术运算:加减乘除 会根据运算结果影响状态标志,有时要利用某些标志才能得到正确的结果;使用他们时请留心有关状态标志 重点掌握 加法指令:ADD、ADC、INC 减法指令:SUB 、SBB、DEC、CMP、NEG 2.4.1 加法和减法指令 加法指令:ADD, ADC和INC 减法指令:SUB, SBB, DEC, NEG和CMP 它们分别执行字或字节的加法和减法运算,除INC和DEC不影响CF标志外,其他按定义影响全部状态标志位 操作数组合: 运算指令助记符 reg, imm/reg/mem 运算指令助记符 mem, imm/reg 1. 加和减指令 ADD dest,src ;加法:dest←dest+src ;ADD指令使目的操作数加上源操作数,和的结果送到目的操作数 SUB dest,src ;减法:dest←dest-src ;SUB指令使目的操作数减去源操作数,差的结果送到目的操作数 例2.7 加法 mov ax,7348h ;AX=7348H add al,27h ;AL=48H+27H=6FH,AX=736FH ;OF?=0,SF=0,ZF=0,PF=1,CF=0 add ax,3fffh ;AX=736FH+3FFFH=B36EH ;OF?=1,SF=1,ZF=0,PF=0,CF=0 sub ah,0f0h ;AH=B3H-F0H=C3H,AX=C36EH ;OF?=0,SF=1,ZF=0,PF=1,CF=1 mov word ptr[200h],0ef00h ;[200H]=EF00H,标志不变 sub [200h],ax ;[200H]=EF00H-C36EH=2B92H ;OF?=0,SF=0,ZF=0,PF=0,CF=0 sub si,si ;SI=0 ;OF=0,SF=0,ZF=1,PF=1,CF=0 2. 带进位加和减指令 ADC dest,src ;加法:dest←dest+src+CF ;ADC指令除完成ADD加法运算外,还要加上进位CF,结果送到目的操作数 SBB dest,src ;减法:dest←dest-src-CF ;SBB指令除完成SUB减法运算外,还要减去借位CF,结果送到目的操作数 例2.8:无符号双字加法和减法 mov ax,7856h ;AX=7856H mov dx,8234h ;DX=8234H add ax,8998h ;AX=01EEH,CF=1 adc dx,1234h ;DX=9469H,CF=0 sub ax,4491h ;AX=BD5DH,CF=1 sbb dx,8000h ;DX=1468H,CF=0 3. 比较指令CMP(compare) CMP dest,src ;做减法运算:dest-src ;CMP指令将目的操作数减去源操作数,但差值不回送目的操作数 比较指令通过减法运算影响状态标志,用于比较两个操作数的大小关系 4. 增量和减量指令 INC reg/mem ;增量(加1):reg/mem←reg/mem+1 DEC reg/mem ;减量(减1):reg/mem←reg/mem-1 INC指令和DEC指令是单操作数指令 与加法和减法指令实现的加1和减1不同的是:INC和DEC不影响CF标志 5. 求补指令NEG(negtive) NEG reg/mem ;reg/mem←0-reg/mem NEG指令对操作数执行求补运算,即用零减去操作数,然后结果返回操作数 求补运算也可以表达成:将操作数按位取反后加1 NEG指令对标志的影响与用零作减法的SUB指令一样 NEG指令也是一个单操作数指令 例2.9 求补运算 mov ax,0ff64h neg al ;AL=0-64H=9CH,AX=FF9CH ;OF=0,SF=1,ZF=0,PF=1,CF=1 sub al,9dh ;AL=9CH-9DH=FFH,AX=FFFFH ;OF?=0,SF=1,ZF=0,PF=1,CF=1 neg ax ;AX=0-FFFFH=0001H ;OF?=0,SF=0,ZF=0,PF=0,CF=1 dec al ;AL=01H-1=0,AX=0000H ;OF?=0,SF=0,ZF=1,PF=1,CF=1 neg ax ;AX=0-0=0 ;OF?=0,SF=0,
显示全部
相似文档