查看完整版本: 跳转指令之:带状态切换的跳转指令BX

admin 发表于 2014-10-10 07:29:11

跳转指令之:带状态切换的跳转指令BX

        8.2带状态切换的跳转指令BX

        1.指令编码格式

        带状态切换的跳转指令BX使程序跳转到指令中指定的参数Rm指定的地址执行程序,Rm的第0位拷贝到CPSR中T位,位移入PC。若Rm的bit为1,则跳转时自动将CPSR中的标志位T置位,即把目标地址的代码解释为Thumb代码;若Rm的位bit为0,则跳转时自动将CPSR中的标志位T复位,即把目标地址代码解释为ARM代码。
       
        指令的编码格式如图8.2所示。
       
        图8.2BX指令编码格式
       
        2.指令的语法格式

        BX{<cond>}<Rm>
       
        ① <cond>
        为指令编码中的条件域。它指示指令在什么条件下执行。当<cond>忽略时,指令为无条件执行(cond=AL(Alway))。
       
        ② <Rm>
        包含跳转指令的目标地址。如果Rm的bit=0,目标地址处指令为ARM指令;如果Rm的bit=1,目标地址处指令为Thumb指令。
       
        3.指令操作的伪代码

        指令操作的伪代码如下面程序段所示。
       
        IfconditionPassed{cond}then
             TFlag=Rm
             PC = Rm AND 0xfffffffe
       
        4.指令的使用

        ·当Rm=0b10时,指令的执行结果不可预知。因为在ARM状态下,指令是4字节对齐的。
        ·PC可以作为Rm寄存器使用,但这种用法不推荐使用。当PC作为<Rm>使用时,指令“BXPC”将程序跳转到当前指令下面第二条指令处执行。虽然这样跳转可以实现,但最好使用下面的指令完成这种跳转。
       
        MOV   PC, PC
       
        或,
       
        ADD   PC, PC, #0
       
        5.指令举例

        (1)转移到r0中的地址,如果r0=1,则进入Thumb状态。
       
        BX   r0;
       
        (2)跳转到r0指定的地址,并根据r0的最低位来切换处理器状态。
       
        ADRL   r0,ThumbFun+1 ;
        BX   r0;
页: [1]
查看完整版本: 跳转指令之:带状态切换的跳转指令BX