4.8.1. B、BL、BX、BLX 和 BXJ

跳转、带链接跳转、跳转并切换指令集、带链接跳转并切换指令集、跳转并转换到 Jazelle 状态。

语法

op1{cond}{.W} label
op2{cond} Rm

其中:

op1

是下列项之一:

B

跳转。

BL

带链接跳转

BLX

带链接跳转并切换指令集。

op2

是下列项之一:

BX

跳转并切换指令集。

BLX

带链接跳转并切换指令集。

BXJ

跳转并转换为 Jazelle 执行。

cond

是一个可选的条件代码(请参阅条件执行)。 cond 不能用于此指令的所有形式,请参阅指令可用性和跳转范围

.W

是一个可选的指令宽度说明符,用于强制要求在 Thumb-2 中使用 32 位 B 指令。有关详细信息,请参阅Thumb-2 中的 B

label

是一个程序相对的表达式。 有关详细信息,请参阅相对寄存器和程序相对的表达式

Rm

是一个寄存器,包含要跳转到的目标地址。

操作

所有这些指令均会引发跳转,或跳转到 label,或跳转到包含在 Rm 中的地址处。 此外:

  • BLBLX 指令可将下一个指令的地址复制到 lr(r14,链接寄存器)中。

  • BXBLX 指令可将处理器的状态从 ARM 更改为 Thumb,或从 Thumb 更改为 ARM。

    BLX label 无论何种情况,始终会更改处理器的状态。

    BX RmBLX Rm 可从 Rm 的位 [0] 推算出目标状态:

    • 如果 Rm 的位 [0] 为 0,则处理器的状态会更改为(或保持在)ARM 状态

    • 如果 Rm 的位 [0] 为 1,则处理器的状态会更改为(或保持在)Thumb 状态。

  • BXJ 指令会将处理器的状态更改为 Jazelle。

指令可用性和跳转范围

Table 4.7 给出了可在 ARM 和 Thumb 状态下使用的指令。 此表中未列出的指令不可在这两种状态下使用。 括号中的注释给出了第一个可在其中使用指令的体系结构版本。

Table 4.7. 跳转指令的可用性和范围

指令ARM 16 位 Thumb32 位 Thumb
B label±32MB(所有)±2KB(所有 T)±16MB[1](所有 T2)
B{cond} label±32MB(所有)–252 到 +258(所有 T)±1MBa(所有 T2)
BL label±32MB(所有)±4MB [2](所有 T)±16MB(所有 T2)
BL{cond} label±32MB(所有)- --
BX Rm可用(4T,5)可用(所有 T)使用 16 位(所有 T2)
BX{cond} Rm可用(4T,5)- --
BLX label±32MB(5)±4MB [2](5T)±16MB(除 ARMv7-M 之外的所有 T2)
BLX Rm可用(5)可用(5T)使用 16 位(所有 T2)
BLX{cond} Rm可用(5)- --
BXJ Rm可用(5J,6)- 可用(除 ARMv7-M 之外的所有 T2)
BXJ{cond} Rm可用(5J,6)- --

[1] 使用 .W 可指示汇编器使用此 32 位指令。

[2] 这是一个指令对。


扩展跳转范围

机器级指令 BBL 对当前指令有地址范围限制。 但是,即使 label 超出范围,仍可以使用这些指令。 通常您并不知道链接器会将 label 放在何处。 必要时链接器会添加代码,以允许进行更长的跳转。 请参阅《链接器用户指南》第 3 章 使用基本链接器功能。 所添加的代码称为中间代码

Thumb-2 中的 B

您可以使用 .W 宽度说明符强制 B 在 Thumb-2 代码中生成 32 位指令。

B.W 始终生成 32 位指令,即使使用 16 位指令就可访问目标也如此。

对于向前引用,不带 .WB 始终在 Thumb 代码中生成 16 位指令,即使这会导致无法访问可以使用 32 位 Thumb 指令访问的目标。

Thumb-2EE 中的 BX、BLX 和 BXJ

这些指令可在 Thumb-2EE 代码中用作跳转,但不能用于更改状态。 不能在 Thumb-2EE 中使用这些指令的 op{cond} label 格式。在该寄存器格式中,Rm 的位 [0] 必须是 1,执行以 ThumbEE 状态在目标地址继续进行。

条件标记

这些指令不更改标记。

体系结构

有关这些指令在每种体系结构中的可用性的详细信息,请参阅指令可用性和跳转范围

示例

    B       loopA
    BLE     ng+8
    BL      subC
    BLLT    rtX
    BEQ     {pc}+4  ; #0x8004
Copyright © 2002-2008 ARM Limited. All rights reserved.ARM DUI 0204IC
Non-Confidential