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
相关推荐
Ya-Jun3 小时前
项目实战Now in Android:项目模块说明
android·架构·kotlin
天上的光4 小时前
软件体系结构——基本架构演变
架构
radient5 小时前
Agent的"思考" - 智能体
后端·架构·ai编程
孟祥_成都5 小时前
下一代组件的奥义在此!headless 组件构建思想探索!
前端·设计模式·架构
正在走向自律7 小时前
大数据时代时序数据库选型指南:从技术架构到实战案例
大数据·架构·时序数据库
Amos_Web8 小时前
Rust实战(三):HTTP健康检查引擎 —— 异步Rust与高性能探针
后端·架构·rust
wa的一声哭了9 小时前
Linux服务器配置ssh免密登陆多台服务器、服务器别名配置
linux·运维·服务器·网络·arm开发·python·ssh
蓁蓁啊10 小时前
ARM交叉编译中编译与链接参数不一致导致的问题
开发语言·arm开发·嵌入式硬件
装不满的克莱因瓶11 小时前
【Java架构师体系课 | MySQL篇】③ Explain执行计划详解
java·数据库·mysql·架构·优化·索引·explain
一水鉴天11 小时前
整体设计 全面梳理复盘 之38 3+1 工具套件(思维工具为根)设计共识暨 DevOps 融合落地路径
人工智能·架构·transformer