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

2024-03-26 14:52

本文主要是介绍【ARM64 常见汇编指令学习 22 -- ARMv8/v9 入栈寄存器介绍】,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

文章目录

    • 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 表示后索引递增堆栈指针。

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

这篇关于【ARM64 常见汇编指令学习 22 -- ARMv8/v9 入栈寄存器介绍】的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/848869

相关文章

Java汇编源码如何查看环境搭建

《Java汇编源码如何查看环境搭建》:本文主要介绍如何在IntelliJIDEA开发环境中搭建字节码和汇编环境,以便更好地进行代码调优和JVM学习,首先,介绍了如何配置IntelliJIDEA以方... 目录一、简介二、在IDEA开发环境中搭建汇编环境2.1 在IDEA中搭建字节码查看环境2.1.1 搭建步

C语言线程池的常见实现方式详解

《C语言线程池的常见实现方式详解》本文介绍了如何使用C语言实现一个基本的线程池,线程池的实现包括工作线程、任务队列、任务调度、线程池的初始化、任务添加、销毁等步骤,感兴趣的朋友跟随小编一起看看吧... 目录1. 线程池的基本结构2. 线程池的实现步骤3. 线程池的核心数据结构4. 线程池的详细实现4.1 初

HarmonyOS学习(七)——UI(五)常用布局总结

自适应布局 1.1、线性布局(LinearLayout) 通过线性容器Row和Column实现线性布局。Column容器内的子组件按照垂直方向排列,Row组件中的子组件按照水平方向排列。 属性说明space通过space参数设置主轴上子组件的间距,达到各子组件在排列上的等间距效果alignItems设置子组件在交叉轴上的对齐方式,且在各类尺寸屏幕上表现一致,其中交叉轴为垂直时,取值为Vert

Ilya-AI分享的他在OpenAI学习到的15个提示工程技巧

Ilya(不是本人,claude AI)在社交媒体上分享了他在OpenAI学习到的15个Prompt撰写技巧。 以下是详细的内容: 提示精确化:在编写提示时,力求表达清晰准确。清楚地阐述任务需求和概念定义至关重要。例:不用"分析文本",而用"判断这段话的情感倾向:积极、消极还是中性"。 快速迭代:善于快速连续调整提示。熟练的提示工程师能够灵活地进行多轮优化。例:从"总结文章"到"用

这15个Vue指令,让你的项目开发爽到爆

1. V-Hotkey 仓库地址: github.com/Dafrok/v-ho… Demo: 戳这里 https://dafrok.github.io/v-hotkey 安装: npm install --save v-hotkey 这个指令可以给组件绑定一个或多个快捷键。你想要通过按下 Escape 键后隐藏某个组件,按住 Control 和回车键再显示它吗?小菜一碟: <template

性能测试介绍

性能测试是一种测试方法,旨在评估系统、应用程序或组件在现实场景中的性能表现和可靠性。它通常用于衡量系统在不同负载条件下的响应时间、吞吐量、资源利用率、稳定性和可扩展性等关键指标。 为什么要进行性能测试 通过性能测试,可以确定系统是否能够满足预期的性能要求,找出性能瓶颈和潜在的问题,并进行优化和调整。 发现性能瓶颈:性能测试可以帮助发现系统的性能瓶颈,即系统在高负载或高并发情况下可能出现的问题

水位雨量在线监测系统概述及应用介绍

在当今社会,随着科技的飞速发展,各种智能监测系统已成为保障公共安全、促进资源管理和环境保护的重要工具。其中,水位雨量在线监测系统作为自然灾害预警、水资源管理及水利工程运行的关键技术,其重要性不言而喻。 一、水位雨量在线监测系统的基本原理 水位雨量在线监测系统主要由数据采集单元、数据传输网络、数据处理中心及用户终端四大部分构成,形成了一个完整的闭环系统。 数据采集单元:这是系统的“眼睛”,

Hadoop数据压缩使用介绍

一、压缩原则 (1)运算密集型的Job,少用压缩 (2)IO密集型的Job,多用压缩 二、压缩算法比较 三、压缩位置选择 四、压缩参数配置 1)为了支持多种压缩/解压缩算法,Hadoop引入了编码/解码器 2)要在Hadoop中启用压缩,可以配置如下参数

【前端学习】AntV G6-08 深入图形与图形分组、自定义节点、节点动画(下)

【课程链接】 AntV G6:深入图形与图形分组、自定义节点、节点动画(下)_哔哩哔哩_bilibili 本章十吾老师讲解了一个复杂的自定义节点中,应该怎样去计算和绘制图形,如何给一个图形制作不间断的动画,以及在鼠标事件之后产生动画。(有点难,需要好好理解) <!DOCTYPE html><html><head><meta charset="UTF-8"><title>06

学习hash总结

2014/1/29/   最近刚开始学hash,名字很陌生,但是hash的思想却很熟悉,以前早就做过此类的题,但是不知道这就是hash思想而已,说白了hash就是一个映射,往往灵活利用数组的下标来实现算法,hash的作用:1、判重;2、统计次数;