第五章 86系列微型计算机的指令系统.ppt

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

(二). 86系列 CPU的寻址方式——数据寻址方式 1. 立即数寻址 8086 CPU指令系统中,有一部分指令所用的8位或16位操作数就在指令中提供,这种方式叫立即数寻址方式。 例如: MOV AL,80H;将十六进制数80H送入AL MOV AX,1090H;将1090H送AX,AH中为10H,AL中为90H 采用立即数寻址方式的指令主要用来对寄存器赋值。因为操作数可以从指令中直接取得,不需要运行总线周期,所以,立即数寻址方式的显著特点就是速度快。 立即数可以为8位,也可以为16位;规定立即数只能是整数,不能是小数、变量或者其他类型的数据; 另外还要注意,立即数只能作为源操作数。 如果操作数就在CPU的内部寄存器中,那么寄存器名可在指令中指出。这种寻址方式就叫寄存器寻址方式。 对16位操作数来说,寄存器可以为AX,BX,CX,DX,SI,DI,SP或者BP,而对8位操作数来说,寄存器可为AH,AL,BH,BL,CH,CL,DH,DL。 例如:  INC CX ;将CX的内容加1    ROL AH,1 ;将AH中的内容循环左移一位   采用寄存器间接寻址方式时,操作数一定在存储器中,存储单元的有效地址由寄存器指出,这些寄存器可以为BX,BP,SI和DI之一,即有效地址等于其中某一个寄存器的值: [BX]       [BP] 8位位移量    EA= [SI] + 16位位移量 [DI]  MOV AX,[BX] 设DS=5000H,BX=3000H,则本指令在执行时,将53000H和53001H两单元的内容送AX。 如果要对其它段寄存器所指的区域进行寻址,则必须在指令前用前缀指出段寄存器名。 例如: ES∶MOV CX,[BX] 设ES=3000H,BX=4000H,则本指令在执行时,将34000H和34001H两单元的内容送CX。 (3) 以SI和DI寄存器进行间接寻址——变址寻址。SI和DI寄存器分别称为源变址寄存器和目的变址寄存器,所以用这两个寄存器来进行间接寻址也叫变址寻址。 变址寻址通常用于对数组元素进行操作,另外,在“5.4串操作指令中还将讲到有些串操作指令要求用固定的变址寄存器对操作数进行寻址,操作过程中,指令会自动修改变址寄存器中的地址,以指向下一个操作数。   (4) 将BX,BP和SI,DI寄存器组合起来进行间接寻址——基址加变址的寻址。通常将BX和BP称为基址寄存器,将SI和DI称为变址寄存器。8086指令系统允许把基址寄存器和变址寄存器组成起来构成一种新的寻址方式,叫基址加变址的寻址。用这种寻址方式时,操作数的有效地址是1个基址寄存器(BX或BP)的内容加上一个变址寄存器(SI或DI)的内容。即:    EA=[BX] [SI]       [BP]+[DI] 例如: MOV AX,[BX+SI] 设DS=1000H,BX=5000H,SI=2000H,则上面指令在执行时,有效地址为7000H,本指令将17000H和17001H两单元的内容取到AX中。 图5.2对堆栈中数组的访问在基址加变址的寻址方式中,只要用上BP寄存器,那么默认的段寄存器就是SS;在其它情况下,默认的段寄存器均为DS。如果操作数不在默认段,则要用前缀指出相应的段寄存器名。用基址加变址的寻址方式时,与变址寻址、基址寻址的情况类似,也允许带一个8位或16位的位移量。带位移量的基址加变址的寻址,在有些资料中也称为相对的基址加变址寻址。 例如:MOV AX,[BX+SI+0050];将BX和SI中的内容与0050相加作为有效地址. 由于基址加变址的寻址方式中,允许两个地址分量分别改变,而且有一个对段寄存器的约定规则——即如果基址寄存器用BX,则默认的段寄存器为DS;   如果基址寄存器用BP,则默认的段寄存器为SS——这种寻址方式使用起来很灵活,特别是为堆栈中数组的访问过程提供了极大的方便。 图5.3对8086有关操作数的各种寻址方式进行了总结。图中不仅指出了每种寻址方式下操作数的来源,还表明了有效地址的计算方法。 【例5.1】设BX=0158H,DI=10A5H, 位移量=1B57H,DS=2100H,并假定没有使用段前缀,即把DS作为操作数对应的段寄存器。 在各种寻址方式下,这些寄存器和位移量所产生的有效地址和物理地址为: ①直接寻址: 有效地址=1B57H 物理地址=21000H+1B57H=22B57H ②寄存器间

文档评论(0)

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

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

1亿VIP精品文档

相关文档