- 1、本文档共48页,可阅读全部内容。
- 2、有哪些信誉好的足球投注网站(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
(2)UMLAL UMLAL{cond}{S} RdLo, RdHi, Rm, Rs UMLAL指令将两个32位无符号数的64位乘积结果与由(RdHi: RdLo)表示的64位无符号数相加,加法结果的高32位存放到寄存器RdHi中,乘积结果的低32位存放到寄存器RdLo中;如果指令包含后缀“S”,则根据操作结果更新CPSR中的相应条件标志位。 (3)SMULL SMULL{cond}{S} RdLo, RdHi, Rm, Rs SMULL指令实现两个32位有符号数的乘积,乘积结果的高32位存放到一个32位的寄存器的RdHi,乘积结果的低32位存放到另一个32位的寄存器的RdLo;如果指令包含后缀“S”,则根据操作结果更新CPSR中的相应条件标志位。 (4)SMLAL SMLAL{cond}{S} RdLo, RdHi, Rm, Rs SMLAL指令将两个32位有符号数的64位乘积结果与由(RdHi: RdLo)表示的64位无符号数相加,加法结果的高32位存放到寄存器RdHi中,乘积结果的低32位存放到寄存器RdLo中;如果指令包含后缀“S”,则根据操作结果更新CPSR中的相应条件标志位。 4.2 ARM分支指令 分支指令用于实现程序流程的跳转,在ARM程序中有两种方法可以实现程序流程的跳转: 使用专门的分支指令。 直接向程序计数器PC写入跳转地址值。 通过向程序计数器PC写入跳转地址值,可以实现在4GB的地址空间中的任意跳转,在跳转之前结合使用MOV?? LR,PC等类似指令,能够保存程序的返回地址值,从而实现在4GB连续地址空间的子程序调用。 分支指令B 分支指令B可以实现跳转到指定的地址执行程序。 指令的汇编语法格式如下: B{cond} target_address 在指令的汇编语法中target_address这个目标地址的计算方法是:将指令中的24位带符号的补码立即数扩展为32位;将此32位数左移两位将得到的值写入到程序计数器PC中,即跳转到目标地址。能够实现跳转的范围为-32MB~+32MB。 带链接的分支指令BL 带链接的分支指令BL可以实现跳转到指定的地址执行程序,同时BL指令还将程序计数器PC的值保存到LR寄存器中。 指令的汇编语法格式如下: BL{cond} target_address L决定是否保存返回地址。当有L时,指令将下一条指令地址保存到LR寄存器中;当无L时同B指令仅执行跳转,当前PC寄存器的值将不会保存到LR寄存器中。从指令的编码可以看出,B与BL指令的唯一区别是bit[24],当bit[24]=0是B指令,当bit[24]=1是BL指令。 BL跳转指令编码中signed_immed_24的含义同B指令。 带状态切换的跳转指令 BX BX指令跳转到指令中所指定的目标地址,目标地址处的指令既可以是ARM指令,也可以是Thumb指令。 指令的汇编语法格式如下: B{cond} Rm BX指令跳转到Rm指定的地址执行程序,如果Rm的bit[0]为1,则跳转时自动将CPSR中的标志位T置位,目标地址的代码为Thumb代码;如果Rm的bit[0]为0,则跳转时自动将CPSR中的T标志位清0,目标地址的代码为ARM代码。 带链接和状态切换的跳转指令 BLX BLX指令从ARM指令集跳转到指令中所指定的目标地址,并将处理器的工作状态由ARM状态切换到Thumb状态,该指令同时将程序计数器PC的当前内容保存到链接寄存器R14中。 (1)由程序标号给出目标地址 这种形式的BLX指令汇编语法格式如下: BLX target_address 目标地址target_address的计算方法:先对指令中定义的有符号24位偏移量用符号位扩展为32位,并将该32位数左移2位,然后将其加到程序计数器PC中,H位(bit[24])加到目标地址的第1位(bit[1]),目标地址总是Thumb指令。跳转的范围为-32MB~+32MB。 (2)寄存器的内容作为目标地址 这种形式的BLX指令汇编语法格式如下: BLX{cond} Rm BLX指令跳转到Rm指定的地址执行程序,如果Rm的bit[0]为1,则跳转时自动将CPSR中的标志位T置位,目标地址的代码为Thumb代码;如果Rm的bit[0]为0,则跳转时自动将CPSR中的T标志位清0,目标地址的代码为ARM代码。 第4章 ARM指令集系统 上半部 完 下半部内容提要 4.3 加载/存储指令 4.4 批量加载/存储指令 4.5 交换指令 4.6 程序状态寄存器PSR访问指令 4.7 协处理器操作指令 4.8 异常产生指令 * TM * * TM 大连理工大学软件学院 邱铁 办
文档评论(0)