第2章 指令系统.ppt

  1. 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
  2. 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  3. 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
第2章 指令系统

第2章 8086指令系统 2.1 指令的基本概念和基本格式 2.2 指令的寻址方式 2.3 8086指令系统 2.4 DEBUG调试程序 2.1 指令的基本概念及格式 1、机器指令 CPU指挥计算机完成某种操作的二进制代码。 从计算机组成的层次结构来说,计算机指令有机器指令、伪指令和宏指令之分。 但CPU真正能够执行的是机器指令。 2、指令的一般格式 操作符 OPD, OPS OPD:目的操作数 OPS:源操作数 操作符:指明了具体的操作 操作数:指明待处理的数据存放位置和结果存放位 置。 2.2 指令寻址方式 1、寻址方式的基本概念 所谓寻址方式就是在指令中指明操作数地址(偏移地址、有效地址、EA)的方法。 操作数存放的位置: 操作数包含在指令中 在CPU的寄存器中 在存储器中 在I/O接口中 2、寻址方式 (1)立即寻址 立即寻址方式中,指令操作码和操作数都在存储器代码段中。 操作数存放在存储器中,指令操作码下一单元的内容为立即操作数n。 例:MOV AX, 10 执行:10→AX (2)寄存器寻址 寄存器寻址方式的操作数在指令指明的寄存器中。 (3)直接寻址方式 在指令中直接指明了操作数的偏移地址(EA)。 偏移地址EA存放在指令操作码的下一单元。 直接偏移地址在指令的表现形式: ①16位偏移地址 ②含有变量的地址表达式。 ③段寄存器名:[EA] 。 (4)寄存器间接寻址 寄存器间接寻址方式中,寄存器的内容为操作数的偏移地址EA,操作数在存储器中。 例: MOV AX,[BX] 若(DS)=2000H,(BX)=1000H,物理地址=20000H+1000H=21000H。 指令执行前,(AX)=2030H,(21000H)=0A0H,(21001H)=50H。 指令执行后,(AX)=50A0H,(21000H)=0A0H,(21001H)=50H。 指令执行情况如下: (5)寄存器相对寻址 寄存器相对寻址方式是在指令中给定一个基址寄存器(或变址寄存器)名和一个8位或16位的相对偏移量,两者之和作为操作数的有效地址。 对BX、SI、DI这三个间址寄存器,指示的是数据段中的数据,而用BP作间址寄存器,则指示的是堆栈段中的数据。 指令中的相对寻址应用格式:X[R]、[R+X] 。 相对寻址偏移地址:EA=R+X 例:MOV AL,[DX+1000H] MOV AL,1000H[DX] 例:设执行前: (AX)=0040H,(BX)=0030H,(DS)=2000H,(20036H)=0050H 执行指令:ADD 6[BX],AX 执行后:(AX)=?,(BX)=?,(DS)=?,(20036H)=? 图形表示如下: (6)基址变址寻址 基址变址寻址方式是在指令中给出一个基址寄存器名和一个变址寄存器名,两者内容之和作为操作数的有效地址。 基址寄存器为BX或BP,变址寄存器为SI或DI,但指令中不能同时出现两个基址寄存器或两个变址寄存器。如果基址寄存器为BX,则段寄存器使用DS;如果基址寄存器用BP,则段寄存器用SS。 基址变址寻址偏移地址: 例: MOV AL,[BX+SI](或者MOV AL,[BX][SI]) 若指令执行前,(DS)=1000H,(BX)=0010H,(SI)=0002H,(10012H)=45H 则EA=(BX)+(SI)=0012H,PA=(DS)×10H+EA=10012H 指令执行后(AL)=45H。 (7)I/O端口寻址方式 8086CPU采用独立编址的I/O端口,可以最多访问64K个字节端口或32K个字端口,用专门的IN指令和OUT指令访问。I/O端口寻址只用于这两种指令中。寻址方式有如下两种。 直接端口寻址 在指令中直接给出端口地址,端口地址一般采用2位十六进制数,也可以用符号表示,这种寻址方式为直接端口寻址。因此,直接端口寻址可访问的端口数为0~255个。 例如:IN AL,25H 寄存器间接端口寻址 如果访问的端口地址值大于255,则必须用I/O端口的间接寻址方式。所谓间接寻址,是指把I/O端口的地址先送到DX中,用DX作间接寻址寄存器,而且只能用DX寄存器。 例如:MOV DX,378H OUT DX,AL 3、跨段问题

文档评论(0)

82393aa + 关注
实名认证
内容提供者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档