【ARM64 常见汇编指令学习 22 -- ARMv8/v9 入栈寄存器介绍】


请阅读【嵌入式开发学习必备专栏 】


ARMv8/v9 入栈寄存器介绍

在 ARMv8 架构中,函数调用遵循一组称为 AAPCS64 (ARMv8 64-bit Procedure Call Standard)的规则。这个调用约定定义了哪些寄存器是可用于传递函数参数的、哪些需要由调用者保存(caller-saved),以及哪些需要由被调用者保存(callee-saved)。

可以不入栈的寄存器

  • 参数寄存器:X0X7 用于传递整数和指针参数,以及返回值。
  • 临时寄存器:X8X15 是临时寄存器,被调用者(callee)不需要保存它们。
  • 浮点参数寄存器:V0V7 用于浮点参数的传递。

函数调用时,以上寄存器的值通常不需要入栈,除非调用者(caller)希望在函数调用返回后还能再次使用这些寄存器中的值。

需要入栈的寄存器(被调用者保存的寄存器)

  • 寄存器 X19X29 是被调用者保存寄存器,也称为 Callee-saved 寄存器。如果在函数中使用这些寄存器,你必须在函数入口处将它们推入栈中(保存它们的状态),并在函数退出之前从栈中恢复它们。
  • 链接寄存器 LRX30)通常也需要保存,以便在返回时使用。
  • 堆栈指针 SPX31SP_ELx)用于堆栈操作。 - 浮点/向量寄存器 V8V15 如果被使用,也需要被保存。

入栈顺序

当一个函数需要保存这些寄存器时,它通常会按照从低寄存器号到高寄存器号的顺序将它们压栈。例如,先保存 X19,然后是 X20,一直到 X29LR

出栈顺序

在函数返回前,需要从栈中恢复这些寄存器的值。这通常是按照入栈的相反顺序完成的,即从高寄存器号到低寄存器号。例如,先恢复 LRX29,然后是 X28,一直到 X19

示例汇编代码

// 函数入口 
func: 
	STP X29, X30, [SP, #-16]! // 保存帧指针和链接寄存器 
	STP X19, X20, [SP, #-16]! // 如果需要,保存 callee-saved 寄存器 
	
	// 函数体 ... 

// 函数退出 
   LDP X19, X20, [SP], #16 // 恢复 callee-saved 寄存器 
   LDP X29, X30, [SP], #16 // 恢复帧指针和链接寄存器 
   RET // 返回到调用者 

在此示例中,STP(Store Pair of Registers)和 LDP(Load Pair of Registers)指令用于同时保存和恢复两个寄存器,[SP, #-16]! 表示预索引递减堆栈指针,而 [SP], #16 表示后索引递增堆栈指针。

请注意,实际的保存操作可能会根据函数的需要来调整哪些寄存器被保存以及它们是否需要被保存。

  • 3
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

主公CodingCos

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值