第三章的指令系统.ppt

上传人:sccc 文档编号:5285761 上传时间:2023-06-22 格式:PPT 页数:65 大小:746.52KB
返回 下载 相关 举报
第三章的指令系统.ppt_第1页
第1页 / 共65页
第三章的指令系统.ppt_第2页
第2页 / 共65页
第三章的指令系统.ppt_第3页
第3页 / 共65页
第三章的指令系统.ppt_第4页
第4页 / 共65页
第三章的指令系统.ppt_第5页
第5页 / 共65页
点击查看更多>>
资源描述

《第三章的指令系统.ppt》由会员分享,可在线阅读,更多相关《第三章的指令系统.ppt(65页珍藏版)》请在三一办公上搜索。

1、第三章 8086的指令系统,8086指令特点8086的寻址方式8086的指令格式及数据类型8086的指令集,3.1 8086指令特点,18086具有灵活的指令格式28086有较强的运算指令38086指令有极强的寻址能力48086指令有处理多种数据能力,32 8086的寻址方式 寻址方式就是指令中用于说明操作数所在地址的方法MOV AX,1234H;B8 34 12MOV AX,1234H;A1 34 12,一、8086的寻址方式说明,1有效地址EA(Effective Address)当操作数在内存中时,指令的地址码(操作码)给出所访问的内存单元的逻辑地址。在寻址方式中,逻辑地址的形成是由多个

2、分量组合而成,该组合地址又叫有效地址。,2、MOV数据传送指令 其格式为:MOV 目的操作数,源操作数目的操作数和源操作数均可采用不同的寻址方式,两个操作数的类型必需一致。,二、寻址方式介绍,1立即寻址(Immediate addressing)操作数就在指令中,紧跟在操作码后面,作为指令一部分存放在内存的代码段中,这种操作数称为立即数。例:MOV AX,34EAH B8 EA 34 MOV BL,20HB3 20,2、寄存器寻址(Register addressing)操作数在寄存器中,指令中源操作数和目的操作数都可用这种寻址方式。例:MOV AL,BL 88 D8MOV AX,1234HB

3、8 34 12MOV AL,AH88 E0,3、直接寻址(Direct addressing)当指令中的源操作数或目的操作数,采用直接给出被访问内存单元的逻辑地址时,这种寻址方式称直接寻址。例:MOV AX,3E4CHA1 4C 3EMOV 1234H,ALA2 34 12,4、寄存器间接寻址(Register indirect addressing)内存单元的逻辑偏移地址通过寄存器间接给出。例:MOV SI,61A8H MOV DX,SI,5、基址/变址寻址(Based/Indexed addressing)这种寻址方式中提出位移量的概念,即在寄存器间接寻址给出的偏移地址上,加一相对位移量。

4、位移量是一带符号的16位16进制数。当使用BX或BP寄存器时,称基址寻址;使用SI或DI寄存器时,称变址寻址。例:MOV CX,36HBX MOV 20BP,AL,6、基址加变址寻址(Based Indexed addressing)它的EA是由三部分组成的,基址寄存器BX或BP的内容加上变址寄存器的内容再加位移量。物理地址由基址寄存器按规则选择段寄存器,也可以使用段超越。例:MOV AX,8AHBXSI该例中EA8AHBXSI物理地址DS10H8AHBXSI,7、其他A、隐含寻址 在指令中没有明显的标出,而指定寄存器参加操作,称之为“隐含寻址”。DAAMUL BL,B、串寻址(String

5、addressing)串寻址方式仅在8086的串指令中使用。规定源操作数的逻辑地址为DS:SI;目的操作数的逻辑地址为ES:DI。当执行串指令的重复操作时,根据设定的方向标志DF,SI和DI会自动调整。,c、I/O(输入/输出)端口寻址(I/O port addressing)当操作数在外部设备时,使用I/O指令。此时有两种不同的寻址方式访问I/O端口。(1)直接端口寻址方式。(2)采用DX寄存器间接寻址方式(3)输入指令中目的操作数可为AL或 AX;输出指令中源操作数可为AL或AX。例:IN AL,25HE5 25HMOV DX,3E4H OUT DX,ALEE,33 8086的指令格式及数

6、据类型,指令由操作码和操作数(地址码)组成。8086的指令长度是可变的,一条指令一般由16个字节组成。,一、指令中的操作数,1、单操作数指令 指令助记符 指令的16进制代码 INC AX 40H INC BX 43H,2、双操作数指令 指令助记符 指令的16进制代码 MOV AL,04 B004H MOV AX,04 B80400,3、三个操作数指令 8086指令系统中,大多数指令中只有12个操作数,但也有少数指令中有3个操作数,不过有一操作数隐含在操作码中。例:ADC AX,BX 该指令完成操作数AX、BX和CF位相加。,二、指令中的数据类型,无符号数 带符号数 ASCII码 BCD数(压缩

7、BCD和非压缩BCD),34 8086的指令集,8086指令系统按功能可分为6大类型:1、数据传输类2、算术运算类3、逻辑运算类4、串操作类5、程序控制类6、处理机控制类,一、数据传送指令,数据传送指令又可以分成4种:l 通用数据传送l累加器专用传送(输入/输出数据传送)l目的地址传送l 标志寄存器转送,指令的共同特点是:,1、除POP和SAHF指令外,这类指令的操作结果不会影响FR寄存器中的标志。2、指令中有两个操作数,目的操作数和源操作数,其执行过程为:目的操作数 源操作数,当指令中仅列出一个操作数时,另一操作数为隐含。,常用的符号,累加器 a ax,al寄存器 r:ax,bx,cx,dx

8、,si,di,sp,bp,al,ah,cl,ch,bl,bhdl,dh段寄存器seg:ds,es,ss,cs内存 mem:nn,bx,si,di,bpbx/bp+count,si/di+countbx+si/di+count,bp+si/di+count立即数 im,1、通用数据传送指令,1)、MOV 传送指令 指令格式为:MOV 目的,源 功能:目的 源,mov r,oprdOprd:r,mem,seg,immov mem,oprdOprd:r,seg,immov seg,oprdOped:r,mem注意:1、mem不能到mem 2、seg做目的操作数时,不包括cs。3、类型匹配,2)PUS

9、H 进栈指令 指令格式为:PUSH oprdOprd:r,mem,seg其操作过程是:a、SP2,指示堆栈中可以存放数据的位置b、存源操作数,完成进栈操作。,3)POP 出栈指令 指令格式为:POP opedOped:r,mem,seg(不包括 CS!)其操作过程是:a、将SS:SP所指示的栈顶处的两个字 节的数据,弹到目的操作数中;b、SP2,指示当前栈顶位置,完成出栈操作。,4)XCHG 交换指令 指令格式为:XCHG 目的操作数,源操作数XCHG R,OPRDOPRD:R,MEM 操作数不能为立即数;源和目的不能同时为存储单元;段寄存器不能作为操作数。,举例:把2000H单元的字和300

10、0H单元互换,2、累加器专用传送指令,1)IN 输入指令指令格式为:IN AL,n IN AX,n IN AL,DX IN AX,DX2)OUT 输出指令 指令格式为:OUT n,AL OUT n,AX OUT DX,AL OUT DX,AX,3)XLAT 换码指令指令格式为:XLAT 功能bxalal例:查表求n的平方。n:0-91、将09的平方表建立在偏移地址为2000H的内存中,如图。2、查表,完成求5的平方指令序列为:MOV BX,2000H;指向平方表的首地址MOV AL,5;将5换码成5的平方值XLAT;查表,平方值在AL中,3、目标地址传送指令 这类指令有:1)LEA 有效地址传

11、送到寄存器2)LDS 装入一个新的物理地址3)LES 装入一个新的物理地址,4、标志寄存器传送指令1)LAHF AH 送 FR寄存器的低8位2)SAHF FR寄存器的低8位送AH3)PUSHF FR寄存器推入堆栈4)POPF 从栈顶中弹出存入FR寄存器,举例:1、把FR各位清零2、把TF置1,其他位不变,二、算术运算指令,1、算术加法指令 1)ADD 算术加法指令功能:目的地目的操作数源操作数格式ADD R,OPRDOPRD:R,MEM,IMADD MEM,OPRDOPRD:R算术指令影响标志位,二、算术运算指令,1、算术加法指令 2)ADC 带进位算术加法指令功能:目的地目的操作数源操作数C

12、F3)INC 加1指令指令功能:目的地目的操作数14)DAA 对压缩BCD数加法操作的结果进行校正指令功能:对AL寄存器的内容进行十进制调整5)AAA 对非压缩BCD数加法操作的结果进行校正指令功能:对AL寄存器的内容进行十进制调整举例:多位的加法,2、算术减法指令 1)SUB 算术减法指令功能:目的地目的操作数源操作数2)SBB 带进位算术减法指令功能:目的地目的操作数源操作数CF3)DEC 减1指令指令功能:目的地目的操作数14)DAS 对压缩BCD数减法操作的结果进行校正指令功能:对AL寄存器的内容进行十进制调整5)AAS 对非压缩BCD数减法操作的结果进行校正指令功能:对AL寄存器的内

13、容进行十进制调整6)CMP 比较指令指令功能:两个操作数相减,不产生运算结果仅影响标志7)NEG 取补指令指令功能:0目的操作数,3、算术乘法指令 1)MUL 无符号数乘法指令功能:完成两个操作数相乘 MUL OPRD;AL*OPRD-AXAX*OPRD-DX AXOPRD:R,MEM2)IMUL 带符号数乘法指令功能:完成两个操作数相乘3)AAM 非压缩BCD数乘法操作结果校正指令功能:完成两个非压缩BCD数乘法结果的十进制数调整举例:把扩展BCD转二进制数,4、算术除法指令DIV 无符号数除法 指令功能:完成两个操作数相除 DIV OPRD AX/OPRDAL:商,AH:余数 DXAX/O

14、PRD AX:商,DX:余数IDIV 带符号数除法 指令功能:完成两个操作数相除 另外还有:CBW 带符号数字节扩展、CWD 带符号数字扩展、AAD 非压缩BCD数除法校正 举例:把AL二进制数转为扩展BCD数,三、位操作指令指令的共同点是:(1)可以按二进制位进行操作;(2)逻辑运算指令按逻辑门电路的运算规则,(3)逻辑移位指令有左移和右移,移出的位都 进入CF标志(4)因移空位的补充方式不同有多种指令形 式(5)逻辑移位指令中,移动超过1次则用CL寄 存器做计数器(6)执行逻辑操作指令,CF均被清0,1、逻辑运算指令,1)NOT 逻辑求反 指令功能:将8位、16位寄存器或存储器内容求反 2

15、)AND 逻辑与操作 指令功能:将8位、16位寄存器或存储器内容和源操作数“与”3)OR 逻辑或操作指令功能:将8位、16位寄存器或存储器内容和源操作数“或”4)XOR 逻辑异或操作 指令功能:将8位、16位寄存器或存储器内容和源操作数“异或”5)TEST 测试指令 指令功能:将8位、16位寄存器或存储器内容和源操作数“与”,不产生运算结果,仅影响状态标志,AND 可以使指定位为0OR 可以使指定位为1XOR 可以使指定位为非,2、逻辑移位指令,1)SHL 逻辑左移指令功能:将8位、16位寄存器或存储器内容左移,移空的位补0 SHL OPRD,1 OR SHL OPRD,CL 2)SAL 算术

16、左移 指令功能:将8位、16位寄存器或存储器内容左移,移空的位补0 举例:扩展BCD码BCD 码,2、逻辑移位指令,3)SHR 逻辑右移 指令功能:将8位、16位寄存器或存储器内容右移,移空的位补0 4)SAR 算术右移指令功能:将8位、16位寄存器或存储器内容右移,移空的位由最高位补充。举例:BCD 码扩展BCD码,5)ROL 不带进位循环左移指令功能:将8位、16位寄存器或存储器内容左移,移空的位由移出位补充。6)ROR 不带进位循环右移指令功能:将8位、16位寄存器或存储器内容右移,移空的位由移出位补充。,7)RCL 带进位循环左移指令功能:将8位、16位寄存器或存储器内容左移,移空的位

17、由CF位补充。8)RCR 带进位循环右移 指令功能:将8位、16位寄存器或存储器内容右移,移空的位由CF位补充。举例:倒序程序,四、串处理指令,源操作数指针 DS:SI,目的操作数指针 ES:DI 每操作一次SI,DI修改一次,方向由DF控制重复操作的退出cx控制条件控制(ZF标志),四、串处理指令,1、串传送指令 MOVSB/MOVSW2、串比较指令 CMPSB/COMPSW3、串搜索指令 SCASB/SCASW4、串装入指令 LODSB/LODSW5、串存储指令 STOSB/STOSB6、指令前缀 REP、REPZ/REPE、REPNZ/REPNE,五、程序控制转移指令,1、无条件转移指令

18、JMP 目标地址 1)、段内直接转移 JMP LABELIP+位移量IP位移量LABEL指令地址JMP地址32)、段内间接转移JMP OPRD;OPRD:R,MEMoprd IPJMP WORD PTR SI,3)、段间直接转移 JMP far LABEL offest LABEL IP seg LABEL cs4)、段间间接转移 JMP OPRD;OPRD:MEM offest OPRD IP seg OPRD cs JMP DWORD PTR SI 5)、短转移指令 IP+CBW(位移量)IP 位移量(8bit)LABEL指令地址JMP地址2,2、条件转移指令,1)单条件转移指令 JC;C

19、F标志为1,则转移 JNC;CF标志为0,则转移 JE/JZ;ZF标志为1,则转移 JNE/JNZ;ZF标志为0,则转移 JS;SF标志为1,则转移 JNS;SF标志为0,则转移 JO;OF标志为1,则转移 JNO;OF标志为0,则转移 JP/JPE;PF标志为1,则转移 JNP/JPO;PF标志为0,则转移,条件A处理,条件A判断,条件B处理,条件B判断,N,Y,Y,N,2)用于无符号数的条件转移指令 JA/JNBE;高于/不低于等于转移,CFZF0 JNA/JBE;不高于/低于等于转移,CFZF1 JB/JNAE;低于/不高于等于转移,CF1 JNB/JAE;不低于/高于等于转移,CF0,

20、3)用于带符号数的条件转移指令 JG/JNLE;大于/不小于等于转移,(SF OF)ZF0 JGE/JNL;大于等于/不小于转移,(SF OF)0 JL/JNGE;小于/不大于等于转移,(SF OF)1 JLE/JNG;小于等于/不大于转移,(SF OF)ZF1,3、循环控制指令,1)LOOP指令 指令格式:LOOP 目标地址执行该指令,CX1,若CX0,转移到目标地址,即:IPIP8位位移量(带符号扩展到16位)。由于指令自动对CX寄存器做减1操作,故使用LOOP指令前,需将循环操作次数值赋给CX寄存器。2)另外还有:LOOPZ/LOOPE指令、LOOPNZ/LOOPNE指令、JCXZ指令。

21、,4、子程序调用和返回指令,1)CALL指令段内直接调用例:CALL LABLEa、IP栈 b、IP+位移量IP段内间接调用例:CALL WORD PTR SI 段间直接调用 例:CALL FAR 目标地址 段间间接调用 例:CALL DWORD PTR SI,2)、RET 子程序返回指令 和调用指令CALL 相对应的是返回指令RET。返回指令通常作为一个子程序或过程的最后一条指令,它用以返回到调用这个子程序的断点处。关于RET n 指令,这条指令称为带参数返回指令。,5、中断指令和中断返回指令,1)INT n 中断指令 2)INTO 溢出中断指令3)IRET 中断返回指令,六、处理器控制指令,1、标志控制指令 STC;使CF 置1CLC;使CF 清0CMC;使CF 取反STD;使DF 置1CLD;使DF 清0STI;使IF置1CLI;使IF 清0,2、外同步指令 HLT 处理器暂停指令WAIT 等待指令ESC 换码指令/交权指令LOCK 总线封锁指令NOP 空操作指令,

展开阅读全文
相关资源
猜你喜欢
相关搜索

当前位置:首页 > 建筑/施工/环境 > 农业报告


备案号:宁ICP备20000045号-2

经营许可证:宁B2-20210002

宁公网安备 64010402000987号