指令系统-.pptVIP

  1. 1、本文档共42页,可阅读全部内容。
  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文档。上传文档
查看更多
3.3 80x86指令系统 可分成如下6类: 数据传送指令 算术运算指令 逻辑运算和移位指令 串操作指令 程序控制指令 处理器控制指令 一、 数据传送指令 可实现 存储器 寄存器 I/O 数据传送指令又可分为如下四种: 通用传送 目标地址传送 标志传送 输入输出 通用数据传送指令 1、 MOV dest,src ;(dest)←(src) 传送的是字节还是字取决于指令中涉及的寄 存器是8位还是16位。 具体来说可实现: ① MOV mem/reg1,mem/reg2 指令中两操作数中至少有一个为寄存器 例: MOV CL,DL MOV AX,BX MOV [SI],CX MOV CL,[BX+5] ② MOV reg,data ;立即数送寄存器 ③ MOV mem,data ;立即数送存储单元 ④ MOV acc,mem ;存储单元送累加器 ⑤ MOV mem,acc ;累加器送存储单元 ⑥ MOV segreg,mem/reg ;存储单元/寄存器送 段寄存器 ⑦ MOV mem/reg,segreg ;段寄存器送存储单 元/寄存器 例:MOV AX, DATA_SEG MOV DS, AX 段地址必须通过寄存器送到DS寄存器。 MOV EAX,[EBX+ECX*4] 把DS段中有效地址为(EBX)+(ECX)*4存储单元的内容送给EAX寄存器。 MOV指令使用规则: 1) IP不能作目的寄存器 2) 不允许mem←mem 3) 不允许segreg←segreg 4)目的操作数不允许是立即数,也不允许是CS寄存器 5) 不允许segreg←立即数 6) 源操作数与目的操作数类型要一致 几个不能传送的解决办法:用AX作桥梁 存储器←存储器: MOV AX,MEM1 MOV MEM2,AX 段寄存器←段寄存器: MOV AX,DS MOV ES,AX 段寄存器←立即数: MOV AX,DATA MOV DS,AX 2、 MOVSX带符号扩展传送指令 格式:MOVSX dest,src; 操作:(dest)←符号扩展(src) 两种格式: MOVSX reg1,reg2 MOVSX reg,mem 注意:源操作数可以是8位或16位,而目的操作数必须是16或32位。 例: MOVSX EAX,CL 把CL寄存器中的8位数,符号扩展成32位数,送到EDX寄存器。 MOVSX EDX,[EDI] 把DS段中由EDI指定地址的16位数符号扩展成32位数,送到EDX寄存器。 3、 MOVZX带零扩展传送指令 格式:MOVZX dest,src; 操作:(dest)←零扩展(src) 两种格式: MOVZX reg1,reg2 MOVZX reg,mem 例: MOVZX DX,AL 把AL寄存器中的8位数,零扩展成16位数,送到DX寄存器。 MOVZX EDX,DATA 把DATA单元的16位数零扩展成32位数,送到EDX寄存器。 4、 PUSH进栈指令 格式:PUSH SRC 执行操作: 16位指令: (SP) ←(SP)-2 ((SP)+1,(SP)) ←(SRC) 32位指令: (ESP) ←(ESP)-4 ((ESP)+3, (ESP)+2, (ESP)+1,(ESP)) ←(SRC) 几种用法: PUSH reg PUSH mem PUSH data ; 8086不允许使用立即数寻址方式 PUSH segreg 5、 POP出栈指令 格式:POP DST 执行操作: 16位指令: (DST) ← ((SP)+1,(SP)) (SP) ←(SP)+2 32位指令: (DST) ←((ESP)+3, (ESP)+2, (ESP)+

文档评论(0)

panguoxiang + 关注
实名认证
文档贡献者

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

1亿VIP精品文档

相关文档