- 1、本文档共143页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
微机原理与汇编语言及接口技术04
微机原理与接口技术--基于IA-32处理器和32位汇编语言·第4版 第4章 汇编语言程序设计 第 4 章汇编语言程序设计 4.1 分支程序结构 4.2 循环程序结构 4.3 子程序结构 4.4 Windows应用程序编程 4.5 与C++语言的混合编程 4.1 分支程序结构 改变程序执行顺序、形成分支、循环、调用等程序结构是很常见的程序设计问题 高级语言采用IF等语句表达条件,并根据条件是否成立转向不同的程序分支 汇编语言需要 首先利用比较CMP、测试TEST、加减 运算、逻辑运算等影响状态标志的 指令形成条件 然后利用条件转移指令判断由标志 表达的条件,并根据标志状态控制程序 转移到不同的程序段 4.1.1 无条件转移指令 程序代码在代码段 CS:指明代码段在主存中的段基地址 EIP:给出将要执行指令的偏移地址 程序顺序执行,处理器自动增量EIP 程序控制转移,EIP随之改变 程序转移到另外的代码段,EIP和CS都改变 控制转移类指令:改变EIP(有些也改变CS),即改变程序执行顺序(实现程序控制转移)的指令 1. 转移范围 段内转移 在当前代码段范围内的程序转移 不需更改CS,只要改变EIP(偏移地址) 近转移(Near):32位近转移NEAR32,16位近转移NEAR16 短转移(Short):转移范围在127~-128字节 段间转移 从当前代码段跳转到另一个代码段 需要更改CS(段地址)和EIP(偏移地址) 远转移(Far): 48位远转移FAR32,32位远转移FAR16 2. 指令寻址方式 相对寻址方式 提供目标地址相对于当前指令指针EIP的位移量 目标地址(转移后的EIP)=当前EIP+位移量 相对寻址都是段内转移,最常用、最灵活 直接寻址方式 直接提供目标地址 目标地址(转移后的CS和EIP)=指令操作数 间接寻址方式 指示寄存器或存储单元 目标地址来自寄存器或存储单元、间接获得 寄存器间接寻址:用寄存器保存目标地址 存储器间接寻址:用存储单元保存目标地址 3. JMP指令 无条件转移:程序无条件改变执行顺序 JMP指令相当于高级语言的goto语句 JMP label ;程序转向label标号指定的地址 ;段内相对寻址,段间直接寻址 JMP reg32/reg16 ;程序转向寄存器指定的地址 ;寄存器间接寻址 JMP mem32/mem16 ;程序转向存储单元指定的地址 ;存储器间接寻址 JMP指令的4种类型 1. 段内转移、相对寻址 标号指明目标地址,指令代码包含位移量 2. 段内转移、间接寻址 通用寄存器或主存单元包含目标指令偏移地址 3. 段间转移、直接寻址 标号包含目标指令的段地址和偏移地址 4. 段间转移、间接寻址 32位段用3字存储单元包含目标地址 16位段用双字存储单元包含目标地址 〔例4-1〕无条件转移程序-1 ; 数据段00000000 nvar dword ? ; 代码段EB 01 jmp labl1 ; 相对寻址90 nopE9labl1: jmp near ptr labl2 ; 相对近转移90 nopB8R labl2: mov eax,offset labl3 〔例4-1〕无条件转移程序-2 0000000E FF E0 jmp eax ; 寄存器间接寻址90 nopB8R labl3: mov eax,offset labl4A3R mov nvar,eax 0000001B FF 25R jmp nvar ; 存储器间接寻址90 nop labl4: 4.1.2 条件转移指令 根据指定的条件确定程序是否发生转移 Jcc label ;条件满足,发生转移;否则,顺序执行下条指令 LABEL表示目标地址,采用段内相对寻址 32位IA-32处理器:达到32位的全偏移量 16位80x86处理器:-128~+127间的短转移 条件转移指令不影响标志,但要利用标志 cc表示利用标志判断的条件,16种、两类 单个标志状态作为条件 两数大小关系作为条件 转移条件cc:单个标志状态 JZ/JE ZF=1 Jump if Zero/Equal JNZ/JNE ZF=0 Jump if Not Zero/Not Equal JS SF=1 Jump if Sign JNS SF=0 Jump if Not Sign JP/JPE PF=1 Jum
文档评论(0)