微处理器指令系统

微处理器指令系统

ID:39405552

大小:541.00 KB

页数:58页

时间:2019-07-02

微处理器指令系统_第1页
微处理器指令系统_第2页
微处理器指令系统_第3页
微处理器指令系统_第4页
微处理器指令系统_第5页
资源描述:

《微处理器指令系统》由会员上传分享,免费在线阅读,更多相关内容在教育资源-天天文库

1、第二章微处理器指令系统华北电力大学计算机系刘丽12.6控制转移类指令8088CPU中,程序代码放在代码段,由CS:IP获得物理地址程序顺序执行时,CPU自动增量IP值当程序遇到分支、循环、子程序调用时,采用控制转移类指令修改CS和IP寄存器的值改变程序的执行顺序控制转移类指令重点掌握:JMP/Jcc/LOOP/JCXZCALL/RETINTn/IRET常用系统功能调用2目标地址的寻址方式用于改变CS和IP,使程序跳转到目标地址相对寻址方式指令代码中提供目的地址相对于当前IP的位移量,转移到的目的地址(转移后的

2、IP值)就是当前IP值加上位移量直接寻址方式指令代码中提供目的逻辑地址,转移后的CS和IP值直接来自指令操作码后的目的地址操作数间接寻址方式指令代码中指示寄存器或存储单元,目的地址从寄存器或存储单元中间接获得用标号表达用标号表达用寄存器或存储器操作数表达3目标地址的寻址范围:段内寻址段内转移——近转移(nearjump)在当前代码段64KB范围内转移(±32KB范围)不需要更改CS段地址,只要改变IP偏移地址段内转移——短转移(shortjump)转移范围可以用一个字节表达,在段内-128~+127范围的转移

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

4、行指令操作数label是要转移到的目标地址(目的地址、转移地址)JMP指令分成4种类型:⑴段内转移、相对寻址⑵段内转移、间接寻址⑶段间转移、直接寻址⑷段间转移、间接寻址JMPlabel;程序转向label标号指定的地址6无条件转移指令JMP(jump)JMPlabel;段内转移、相对寻址;IP←IP+位移量JMPr16/m16;段内转移、间接寻址;IP←r16/m16JMPfarptrlabel;段间转移、直接寻址;IP←偏移地址,CS←段地址JMPfarptrmem;段间转移,间接寻址;IP←[mem],C

5、S←[mem+2]演示演示演示演示演示72.6.2条件转移指令条件转移指令Jcc根据指定的条件确定程序是否发生转移。其通用格式为:Jcclabel;条件满足,发生转移;IP←IP+8位位移量;;否则,顺序执行label是一个标号、一个8位位移量,表示Jcc指令后的那条指令的偏移地址,到目标指令的偏移地址的地址位移Jcc只支持短转移的相对寻址方式,因而只能实现段内-128~127的跳转8Jcc指令的分类Jcc指令不影响标志,但要利用标志(表2-3)在Jcc之前,通常有CMP、TEST、加减运算、逻辑运算等指令根

6、据利用的标志位不同,分成三种情况:⑴判断单个标志位状态⑵比较无符号数高低⑶比较有符号数大小Jcc指令实际虽然只有16条,但却有30个助记符采用多个助记符,目的是为了方便记忆和使用91.判断单个标志位状态⑴JZ/JE和JNZ/JNE利用零标志ZF,判断结果是否为零(或相等)⑵JS和JNS利用符号标志SF,判断结果是正是负⑶JO和JNO利用溢出标志OF,判断结果是否产生溢出⑷JP/JPE和JNP/JPO利用奇偶标志PF,判断结果中“1”的个数是偶是奇⑸JC/JB/JNAE和JNC/JNB/JAE利用进位标志CF,

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

8、测试AX的最低位D0(不用AND指令,以免改变AX)jzeven;标志ZF=1,即D0=0:AX内是偶数,程序转移addax,1;标志ZF=0,即D0=1:AX内的奇数,加1even:shrax,1;AX←AX÷2用右移一位的方法实现除以2本例中用RCR指令比SHR指令更好(AX=FFFFH)Inc→add?12解答2用JNC指令实现movbx,axshrbx,1;将AX的最低位D0移进CFjnce

当前文档最多预览五页,下载文档查看全文

此文档下载收益归作者所有

当前文档最多预览五页,下载文档查看全文
温馨提示:
1. 部分包含数学公式或PPT动画的文件,查看预览时可能会显示错乱或异常,文件下载后无此问题,请放心下载。
2. 本文档由用户上传,版权归属用户,天天文库负责整理代发布。如果您对本文档版权有争议请及时联系客服。
3. 下载前请仔细阅读文档内容,确认文档内容符合您的需求后进行下载,若出现内容与标题不符可向本站投诉处理。
4. 下载文档时可能由于网络波动等原因无法下载或下载错误,付费完成后未能成功下载的用户请联系客服处理。