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
相关推荐
真实的菜5 小时前
微服务注册配置中心终极选型:2026指南
微服务·云原生·架构
拼搏的小浣熊5 小时前
香橙派Zero3的奇幻之旅【【持续更新】香橙派zero3从入门到玩转 各种工具+笔记】
arm开发·物联网·香橙派
HavenlonLabs7 小时前
硬件 + SaaS 产品的工程化路径:从系统架构、PCB 设计到工程样机
网络·安全·架构·系统架构·安全架构
SamDeepThinking8 小时前
我们当年是如何真实落地BFF的?
java·后端·架构
宜昌未来智慧谷9 小时前
WWDC 2026开发者视角解读:Siri独立App的技术架构与第三方AI模型接入机制
人工智能·架构·apple·wwdc·gemini
协享科技9 小时前
Spring Boot 与 Go 双服务架构实践:从单体拆分到通信设计
java·人工智能·spring boot·后端·架构·golang·ai编程
这个DBA有点耶9 小时前
索引优化深潜(下):索引合并、ICP 与索引设计的实战法则
数据库·mysql·架构
行者-全栈开发10 小时前
深度解析 WWDC 2026:苹果 AI 全栈技术架构与落地实现路径
人工智能·架构·wwdc
我是一颗柠檬10 小时前
【Java项目技术亮点】分库分表+数据路由策略:单表5000万后的架构升级方案
java·开发语言·分布式·架构
小短腿的代码世界11 小时前
QtitanRibbon 深度解析:工业级Ribbon界面框架的架构设计与自定义扩展
qt·3d·架构