当前位置:首页 > 嵌入式 > 嵌入式教程
[导读]带连接和状态切换的跳转指令BLX(Branch with Link Exchange)使用一个寄存器中的绝对地址,用于使程序跳转到Thumb状态或从Thumb状态返回。该指令用分支寄存器的最低位来更新CPSR中的T位,将返回地址写入到连接寄存器LR中。

8.4带状态切换的连接跳转指令BLX(2)1.指令编码格式

带连接和状态切换的跳转指令BLX(BranchwithLinkExchange)使用一个寄存器中的绝对地址,用于使程序跳转到Thumb状态或从Thumb状态返回。该指令用分支寄存器的最低位来更新CPSR中的T位,将返回地址写入到连接寄存器LR中。

指令编码格式如图8.4所示。

图8.4BLX(2)指令编码格式

2.语法格式

BLX{<cond>}<Rm>

①<cond>

为指令编码中的条件域。它指示指令在什么条件下执行。当<cond>忽略时,指令为无条件执行(cond=AL(Alway))。

②<Rm>

寄存器Rm指定转移目标,Rm的第0位拷贝到CPSR中的T位,bit[31∶0]移入PC。

·如果Rm的bit[0]=1,则跳转时自动将CPSR中的标志位T置位,即把目标地址的代码解释为Thumb代码。

·如果Rm的bit[0]=0,则跳转时自动将CPSR中的标志位T复位,即把目标地址代码解释为ARM代码。

3.指令操作的伪代码

指令操作的伪代码如下面程序段所示。

IfConditionPass{cond}then

LR=addressoftheinstructionafterthebranchinstruction

TFlag=Rm[0]

PC=RmAND0xfffffffe

注意

在这种情况下,如果Rm的bit[1∶0]=0b10,指令的执行结果不可预知,因为这将导致在ARM状态下非对齐的字访问。

4.指令举例

调用Thumb子程序。

CODE32 ;ARM代码

……

BLXTSUB ;调用Thumb子程序

……

CODE16 ;Thumb代码开始

TSUB

……

BXr14 ;返回ARM状态

注意

(1)一些不支持Thumb指令集的ARM处理器将捕获这些指令,允许软件仿真Thumb指令。

(2)只有实现ARMv5版本以上的处理器支持BLX指令的两种格式。

本站声明: 本文章由作者或相关机构授权发布,目的在于传递更多信息,并不代表本站赞同其观点,本站亦不保证或承诺内容真实性等。需要转载请联系该专栏作者,如若文章内容侵犯您的权益,请及时联系本站删除( 邮箱:macysun@21ic.com )。
换一批
延伸阅读
关闭