跳转指令用于实现程序流程的跳转,在 ARM (同样在TI C66x DSP)程序中有两种方法可以实现程序流程的跳转:
—使用专门的跳转指令(如B指令)。
—直接向程序计数器 PC写入跳转地址值。
通过向程序计数器 PC写入跳转地址值,可以实现在 4GB的地址空间中的任意跳转,在跳转之前结合使用MOV LR,PC等类似指令,可以保存将来的返回地址值,从而实现在 4GB连续的线性地址空间的子程序调用。
ARM指令集中的跳转指令可以完成从当前指令向前或向后的 32MB的地址空间的跳转,包括以下4条指令:
— B 跳转指令(TI C66x DSP指令集也有该指令)
B 指令的格式为:
B 目标地址; //程序跳转到目标地址处执行
B Label //程序无条件跳转到标号Label处执行
B指令是最简单的跳转指令。一旦遇到一个 B指令,ARM处理器将立即跳转到给定的目标地址,从那里继续执行,并需要重新装入PC(程序计数器),使执行流水线中断。注意存储在跳转指令中的实际值是相对当前 PC 值的一个偏移量,而不是一个绝对地址,它的值由汇编器来计算(参考寻址方式中的相对寻址)。它是24位有符号数,左移两位后有符号扩展为 32 位,表示的有效偏移为 26位(前后 32MB的地址空间)。