ARMV8 - A64 - 跳转和返回指令

说明

  • C语言等高级语言,根据是否需要返回到触发跳转代码的下一条代码,跳转有两种语句:
  1. 不需要返回,例如:if,goto,switch,while等语句。
  2. 需要返回,例如:函数调用,系统调用,SMC调用等。
  • A64汇编指令跳转也一样。

只跳转,不需要返回

  1. B指令
  • 跳转到某地址执行,无法返回。

  • 一般是函数内跳转,类似于C语言中while循环,if else等语句导致的跳转。

  • 示例:

    int test(int a, int b)
    {
    if (a) {
    return 0;
    }

    复制代码
      return a+b;

    }

    • 对应汇编代码
      test:
      sub sp, sp, #16
      str w0, [sp, 12] //将实参a保存到栈对应地址
      str w1, [sp, 8] //将实参b保存到栈对应地址
      ldr w0, [sp, 12] //从栈中将变量a load到寄存器w0中
      cmp w0, 0 //对应上面的if 判断 w0(变量a)是否为0
      beq .L4 // 为0,跳转到标签 .L4
      mov w0, 0 // 不为0,将w0赋值为0
      b .L5 //不为0,跳转到 .L5,对应return 0
      .L4: //对应 a+b;
      ldr w1, [sp, 12]
      ldr w0, [sp, 8]
      add w0, w1, w0
      .L5: // 对应 return
      add sp, sp, 16
      ret
  1. BR指令
  • 跳转到某寄存器保存的地址处运行,无法返回。

    br x20 //跳转到通用寄存器x20指向地址运行

跳转后,需要返回

  • 跳转和返回是不同的指令,返回时,需要主动调用返回指令。
  • 指令详细动作如下:
  • 跳转指令,先将下一条指令的地址(即返回后执行的起始地址)保存到通用寄存器 lr (x30)中,再跳转目标地址。
  • 返回指令,跳转到x30寄存器所保存的地址执行。

跳转指令

  1. BL指令
  • 跳转到某地址执行,运行完可以返回。

  • 一般用于不同函数的跳转,类似于C语言中的函数调用,如:

  • 语法

    bl 0x100cfa754

  • 示例

    int test()
    {
    return 0;
    }

    int main()
    {
    test();
    return 0;
    }

    • 对应汇编
      test:
      mov w0, 0
      ret // 返回到 bl test 下一条指令执行
      main:
      stp x29, x30, [sp, -16]!
      add x29, sp, 0
      bl test //跳转到 test 函数地址执行
      mov w0, 0
      ldp x29, x30, [sp], 16
      ret
  1. BLR指令
  • 跳转到某寄存器保存的地址处运行,运行完可以返回。

    br x20 //跳转到通用寄存器x20指向地址运行

返回指令

  1. ret
  • 主动调用后,跳转到x30寄存器所保存的地址执行。

  • 语法

    ret

相关推荐
AndyHeee14 天前
【SVC、PendSV(系统异常) 与 外设 IRQ 、NVIC笔记】
arm开发
暮云星影14 天前
瑞芯微rk3588利用Rockchip NPU运行大语言模型(LLM)
arm开发·人工智能·语言模型·自然语言处理
techdashen14 天前
绕过系统 ICMP:用 rawsock、Npcap 和 WMI 找到默认网卡
开发语言·arm开发·rust
ThornArmor14 天前
【工具篇·番外】跨语言生态的主权回收:基于 ISA 说明书的 4-bit 双向汇编系统全线封顶
c语言·开发语言·汇编·c++·重构·架构
振南的单片机世界14 天前
ARM中断比51快在哪?硬件压栈+NVIC集中管理
arm开发·stm32·单片机·嵌入式硬件
墨绿色的摆渡人14 天前
论文笔记(一百三十七)Learning Dual-Arm Push and Grasp Synergy in Dense Clutter
arm开发·论文阅读
暮云星影15 天前
全志linux开发屏幕适配(一)屏幕参数设置说明
linux·arm开发
是星辰吖~15 天前
WIN32_线程(下)
汇编
m0_5474866615 天前
《ARM Cortex-M4嵌入式应用技术——基于STM32F407、STM32CubeMX与Proteus》全套PPT课件
arm开发·stm32·proteus
Lanceli_van15 天前
SQLite 3.45.2(sqlite-autoconf-3450200)ARM 交叉编译完整步骤
arm开发·sqlite