第5章指令系统.pptVIP

  1. 1、本文档共70页,可阅读全部内容。
  2. 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  5. 5、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  6. 6、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  7. 7、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  8. 8、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多

在数据对准边界的计算机中,当以二进制来表示地址时,半字地址的最低位恒为零,如xxxxxxxx0;字地址的最低两位为零,如xxxxxxxx00;双字地址的最低三位为零,如xxxxxxx000。以下为按字节编址的双字数据的两种字节次序;(1)低字节为低地址,图(a)所示;(2)高字节为低地址,如图(b)所示。字地址04字节次序32107654字地址04字节次序01234567(a)(b)5.4寻址方式寻找指令或操作数有效地址的方式指令寻址顺序寻址跳跃寻址操作数寻址62.操作数的寻址方式立即寻址直接寻址间接寻址寄存器寻址寄存器间接寻址相对寻址变址寻址复合寻址立即寻址地址码字段是操作数本身S=D例:MOVAX,2038H(2038H→AX)MOV38202038内存AX寄存器寻址(RegisterAddressing)操作数在CPU的内部寄存器中.AX,BX,CX,DXMOVAX,BXE=R0x20000x4FFFBXAX0x2000直接寻址(DirectAddressing)地址码字段直接给出操作数在内存的地址.E=DMOVAX,[200]77OPXD200200内存间接寻址(IndirectAddressing)D单元的内容是操作数地址,D是操作数地址的地址E=(D)400788300300400需要访问两次内存,速度慢已被淘汰OPXD内存寄存器间接寻址(RegisterIndirectAddressing)D单元的内容是操作数的地址,D是操作数地址的地址E=(R)MOVAX,[BX]300ROPXR300400400788内存相对寻址(RelativeAddressing)指令中的D加上PC的内容作为操作数的地址.E=D+(PC)2000PC2100程序指令计数器OPX100XXX2100内存变址寻址(IndexAddressing)指定一个寄存器R,其存放基址,R被称为变址寄存器。它与本指令的地址无关,R的内容可以随要求填入。E=D+(R)MOVAX,200[SI]SI,DI都称为变址寄存器3000操作数R3200OPX200内存复合寻址(CompositeAddressing)将间址,相对,变址,基值等寻址方式组合.变址间址先变址,后间址.E=((R)+D)30005000操作数OPXD=1003100段寻址Intel8086/8088微机中,ALU16位运算,但其寻址范围可到1M,即地址有20位。实质是基值寻址。4位16位逻辑地址16位段寄存器20位物理地址ALU堆栈寻址方式堆栈------一组能存取数据的暂时存储单元。串联堆栈一组专门的寄存器,一个R保存一个数据。数据的传送在栈顶和通用寄存器之间进行。快速:在CPU内部实现串行:进栈和出栈涉及到栈内所有其它数据的移动;破坏性读出:读数据的同时也离开了堆栈;栈容量有限:取决于CPU内堆栈专用寄存器的数量;栈顶不动,数据移动。堆栈寻址方式AXAXBXBXAXCXCXBXAXPUSHAXPUSHBXPUSHCXCXBXAXPOPCX堆栈顶存储器堆栈用一部分主存空间作堆栈称为存储器堆栈。堆栈的数目、长度可随意指定SP---堆栈指示器(栈指针),CPU中一个专门寄存器,SP内容是栈顶单元地址。改变SP内容即可移动栈顶的位置。堆栈操作期间,堆栈中数据不动,栈顶移动非破坏性读出进栈进栈--------累加器中的数送堆栈保存.(AC)→堆栈MSP堆栈指针(sp)-1→spaPUSHaPUSHb100999897SPabbAC出栈出栈--------将堆栈中的数取出送累加器堆栈指针(sp)+1→sp(堆栈MSP)→AC100999897SPabbACa例一种二地址RS型指令的结构如下所示:?OP—通用寄存器IX偏移量D6位4位1位2位

文档评论(0)

趁早学习 + 关注
实名认证
文档贡献者

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

1亿VIP精品文档

相关文档