网站大量收购独家精品文档,联系QQ:2885784924

微处理器指令系统.pptxVIP

  1. 1、本文档共10页,可阅读全部内容。
  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文档。上传文档
查看更多

1第二章微处理器指令系统

华北电力大学计算机系刘丽

2.6控制转移类指令2程序顺序执行时,CPU自动增量IP值当程序遇到分支、循环、子程序调用时,采用控制转移类指令修改CS和IP寄存器的值改变程序的执行顺序8088CPU中,程序代码放在代码段,由CS:IP获得物理地址01JMP/Jcc/LOOP/JCXZCALL/RETINTn/IRET常用系统功能调用控制转移类指令重点掌握:02

目标地址的寻址方式3用标号表达间接寻址方式03指令代码中指示寄存器或存储单元,目的地址从寄存器或存储单元中间接获得用于改变CS和IP,使程序跳转到目标地址用标号表达用寄存器或存储器操作数表达直接寻址方式02指令代码中提供目的逻辑地址,转移后的CS和IP值直接来自指令操作码后的目的地址操作数相对寻址方式01指令代码中提供目的地址相对于当前IP的位移量,转移到的目的地址(转移后的IP值)就是当前IP值加上位移量

目标地址的寻址范围:段内寻址4段内转移——近转移(nearjump)在当前代码段64KB范围内转移(±32KB范围)不需要更改CS段地址,只要改变IP偏移地址段内转移——短转移(shortjump)转移范围可以用一个字节表达,在段内-128~+127范围的转移代码段代码段

目标地址的寻址范围:段间寻址5段间转移——远转移(farjump)从当前代码段跳转到另一个代码段,8088支持在1MB范围内跳转需要更改CS段地址和IP偏移地址目标地址必须用一个32位数表达,叫做32位远指针,它就是逻辑地址(CS:IP)代码段代码段实际编程时,汇编程序根据目标地址的属性,自动处理成短转移、近转移或远转移程序员可用操作符short、nearptr或farptr强制成为需要的转移类型

2.6.1无条件转移指令6只要执行无条件转移指令JMP,就使程序转到指定的目标地址,从目标地址处开始执行指令操作数label是要转移到的目标地址(目的地址、转移地址)JMP指令分成4种类型:段内转移、相对寻址段内转移、间接寻址段间转移、直接寻址段间转移、间接寻址JMPlabel ;程序转向label标号指定的地址

无条件转移指令JMP(jump)7JMPlabel ;段内转移、相对寻址;IP←IP+位移量JMPr16/m16 ;段内转移、间接寻址;IP←r16/m16JMPfarptrlabel ;段间转移、直接寻址;IP←偏移地址,CS←段地址JMPfarptrmem ;段间转移,间接寻址;IP←[mem],CS←[mem+2]1演示2演示3演示4演示5演示6

2.6.2条件转移指令8条件转移指令Jcc根据指定的条件确定程序是否发生转移。其通用格式为:Jcclabel ;条件满足,发生转移;IP←IP+8位位移量;;否则,顺序执行label是一个标号、一个8位位移量,表示Jcc指令后的那条指令的偏移地址,到目标指令的偏移地址的地址位移Jcc只支持短转移的相对寻址方式,因而只能实现段内-128~127的跳转

Jcc指令的分类9Jcc指令不影响标志,但要利用标志(表2-3)在Jcc之前,通常有CMP、TEST、加减运算、逻辑运算等指令根据利用的标志位不同,分成三种情况:判断单个标志位状态比较无符号数高低比较有符号数大小Jcc指令实际虽然只有16条,但却有30个助记符采用多个助记符,目的是为了方便记忆和使用

1.判断单个标志位状态10JZ/JE和JNZ/JNE1利用零标志ZF,判断结果是否为零(或相等)2JS和JNS3利用符号标志SF,判断结果是正是负4JO和JNO5利用溢出标志OF,判断结果是否产生溢出6JP/JPE和JNP/JPO7利用奇偶标志PF,判断结果中“1”的个数是偶是奇8JC/JB/JNAE和JNC/JNB/JAE9利用进位标志CF,判断结果是否进位或借位10

例2.19将AX中存放的无符号数除以2,如果是奇数则加1后除以2问题:如何判断AX中的数据是奇数还是偶数?解答:判断AX最低位是“0”(偶数),还是“1”(奇数)。可以用位操作类指令用逻辑与指令将除最低位外的其他位变成0,保留最低位不变。判断这个数据是0,AX就是偶数;否则,为奇数将最低位用移位指令移至进位标志,判断进位标志是0,AX就是偶数;否则,为奇数将最低位用移位指令移至最高位(符号位),判断符号标志是0,AX就是偶数;否则,为奇数

解答1用JZ指令实现12testax,01h1;测试AX的最低位D0(不用AND指令,以免改变AX)2jzeven3;标志ZF=1,即D0=0:AX内是偶数,程序转移4addax

文档评论(0)

SYWL2019 + 关注
官方认证
文档贡献者

权威、专业、丰富

认证主体四川尚阅网络信息科技有限公司
IP属地四川
统一社会信用代码/组织机构代码
91510100MA6716HC2Y

1亿VIP精品文档

相关文档