ARM汇编编程(AArch64架构)课程 - 第5章函数调用规范

目录

AAPCS64调用约定

ARM Architecture Procedure Call Standard for 64-bit (AAPCS64)

参数传递规则

参数位置 寄存器分配 特殊规则
参数1-8 X0-X7 (64-bit) / W0-W7 (32-bit) 浮点数使用 V0-V7
参数>8 栈传递(按顺序右→左压栈) 要求8字节对齐
可变参数 所有浮点参数必须通过寄存器传递 需预留相应寄存器空间

示例代码:

assembly 复制代码
// 函数调用示例
mov x0, #1       // 第一个整型参数
mov x1, #2       // 第二个整型参数
fmov d0, 3.14    // 第一个浮点参数
bl my_function

返回值规则

  • 整型返回值:X0(64-bit)/W0(32-bit)
  • 浮点返回值:V0(128-bit)/D0(64-bit)/S0(32-bit)
  • 大结构体:通过X8间接返回(调用者分配内存)

栈帧管理

SP寄存器

  • Stack Pointer:始终指向栈顶
  • 操作要求
    • 必须保持16字节对齐
    • 函数退出时必须恢复原始值

FP寄存器 (X29)

  • Frame Pointer:指向当前栈帧基址

  • 典型布局

    复制代码
    High Address
    +---------------+
    |  Caller's FP  | ← FP
    +---------------+
    |   LR (X30)    |
    +---------------+
    |  Local Vars   |
    +---------------+
    |  Callee-save  |
    +---------------+
    | 参数区域(>8)   | ← SP
    Low Address

栈帧布局示例

assembly 复制代码
my_function:
    // 序言
    stp x29, x30, [sp, #-32]!  // 保存FP/LR并分配栈空间
    mov x29, sp                 // 建立新栈帧

    // 函数体
    str x0, [x29, #16]          // 保存参数到栈

    // 尾声
    ldp x29, x30, [sp], #32     // 恢复FP/LR并释放栈空间
    ret
相关推荐
hdsoft_huge2 小时前
SpringBoot 与 JPA 整合全解析:架构优势、应用场景、集成指南与最佳实践
java·spring boot·架构
DoraBigHead5 小时前
你写前端按钮,他们扛服务器压力:搞懂后端那些“黑话”!
前端·javascript·架构
isNotNullX6 小时前
数据中台架构解析:湖仓一体的实战设计
java·大数据·数据库·架构·spark
Kookoos7 小时前
ABP VNext + .NET Minimal API:极简微服务快速开发
后端·微服务·架构·.net·abp vnext
码字的字节7 小时前
深入理解Transformer架构:从理论到实践
深度学习·架构·transformer
wzj_what_why_how7 小时前
Android网络层架构:统一错误处理的问题分析到解决方案与设计实现
android·架构
bug攻城狮7 小时前
Alloy VS Promtail:基于 Loki 的日志采集架构对比与选型指南
运维·架构·grafana·数据可视化
芯岭技术8 小时前
MS32C001-C单片机,32位ARM M0+内核,宽电压、低功耗、小封装。
c语言·arm开发·单片机