首页
/ ARM-software/abi-aa项目2025Q1版本更新解析

ARM-software/abi-aa项目2025Q1版本更新解析

2025-07-05 04:09:45作者:史锋燃Gardner

项目概述

ARM-software/abi-aa项目是ARM架构的应用二进制接口(ABI)规范集合,为基于ARM架构的软件开发提供了标准化的接口定义和调用约定。该项目涵盖了32位(ARM)和64位(AArch64)架构的多个ABI规范,包括过程调用标准、ELF文件格式、DWARF调试信息格式等核心内容,以及针对特定扩展功能(如Morello、PAuth、MemTag等)的补充规范。

2025Q1版本核心更新内容

1. FPMR寄存器与FP8类型支持

在AArch64过程调用标准(AAPCS64)中,本次更新正式描述了FPMR(Floating-point Mode Register)寄存器以及FP8(8位浮点)数据类型。FPMR寄存器用于控制浮点运算的行为模式,而FP8数据类型则针对机器学习等场景提供了更高效的浮点计算支持。值得注意的是,FP8类型的ABI状态已从Alpha升级至Beta,表明其成熟度有所提升。

2. BTI工具链要求明确化

系统V ABI规范中新增了对BTI(Branch Target Identification)的工具链要求说明。BTI是ARMv8.5引入的控制流完整性保护机制,本次更新明确了工具链在生成和处理BTI相关代码时的具体要求,有助于开发者更好地实现控制流保护。

3. SME扩展增强

Scalable Matrix Extension(SME)是ARMv9引入的重要扩展,本次更新增加了agnostic-ZA接口以及保存/恢复SME状态的例程。ZA(ZE+ZA)是SME中的矩阵寄存器组,这些新增内容为开发者提供了更完善的SME编程接口支持。

4. PAuth扩展改进

指针认证(PAuth)扩展在本次更新中获得了多项增强:

  • 新增了支持认证的TLSDESC GOT重定位类型
  • 将PAuth相关的GOT重定位从私有空间移出 这些改进使得PAuth能更好地与线程本地存储(TLS)机制协同工作,并提高了重定位信息的标准化程度。

5. Morello扩展完善

针对Morello能力架构的扩展规范,本次更新补充了R_MORELLO_JUMP_SLOT重定位类型的详细文档,解决了之前文档不完整的问题。Morello是ARM推出的支持硬件能力的安全架构,这些更新有助于开发者更好地利用其安全特性。

6. 系统V ABI硬浮点要求

系统V ABI规范现在明确要求必须支持硬浮点(hard-float),这反映了现代ARM系统对浮点性能的普遍需求,也简化了ABI兼容性要求。

7. 纯代码段标志引入

ELF规范新增了SHF_AARCH64_PURECODE段标志,用于标识仅包含代码的段。这有助于工具链和运行时系统更好地识别和处理纯代码段,为代码完整性保护等安全特性提供支持。

8. 函数指针与代码指针区分

通过引入额外的重定位类型,本次更新明确区分了函数指针和代码指针。这种区分对于支持能力架构(如Morello)的系统尤为重要,因为它允许更精确地描述不同类型的代码引用。

9. 原子操作扩展

LSFE(Linux Standard Function Environment)规范更新了fetch_add操作,增加了对原子浮点操作的支持。这使得开发者能够在多线程环境中安全地进行浮点数的原子操作。

技术影响与开发者建议

本次ABI更新反映了ARM架构在安全、性能和功能扩展方面的持续演进。对于开发者而言,建议关注以下几点:

  1. 浮点支持方面:FP8类型的成熟意味着开发者可以考虑在机器学习等场景中使用这种高效的浮点格式,但需要注意其Beta状态可能带来的兼容性考虑。

  2. 安全特性:BTI和PAuth相关的更新强调了ARM在控制流完整性和指针安全方面的持续投入,开发者应评估这些特性在自身项目中的应用价值。

  3. SME支持:随着SME规范的完善,涉及矩阵运算的应用可以开始考虑利用这一扩展带来的性能优势。

  4. 工具链适配:新增的ELF段标志和重定位类型可能需要工具链更新,开发者应确保使用支持这些新特性的工具链版本。

  5. 兼容性考虑:系统V ABI对硬浮点的强制要求意味着针对不支持浮点的旧系统可能需要特殊的兼容性处理。

ARM架构的ABI规范持续演进,既反映了硬件特性的发展,也为软件开发提供了更强大的基础。开发者应当定期关注ABI更新,以确保充分利用新特性并保持兼容性。

登录后查看全文
热门项目推荐

项目优选

收起
openHiTLS-examplesopenHiTLS-examples
本仓将为广大高校开发者提供开源实践和创新开发平台,收集和展示openHiTLS示例代码及创新应用,欢迎大家投稿,让全世界看到您的精巧密码实现设计,也让更多人通过您的优秀成果,理解、喜爱上密码技术。
C
53
465
kernelkernel
deepin linux kernel
C
22
5
openHiTLSopenHiTLS
旨在打造算法先进、性能卓越、高效敏捷、安全可靠的密码套件,通过轻量级、可剪裁的软件技术架构满足各行业不同场景的多样化要求,让密码技术应用更简单,同时探索后量子等先进算法创新实践,构建密码前沿技术底座!
C
349
381
nop-entropynop-entropy
Nop Platform 2.0是基于可逆计算理论实现的采用面向语言编程范式的新一代低代码开发平台,包含基于全新原理从零开始研发的GraphQL引擎、ORM引擎、工作流引擎、报表引擎、规则引擎、批处理引引擎等完整设计。nop-entropy是它的后端部分,采用java语言实现,可选择集成Spring框架或者Quarkus框架。中小企业可以免费商用
Java
7
0
openGauss-serveropenGauss-server
openGauss kernel ~ openGauss is an open source relational database management system
C++
132
185
RuoYi-Vue3RuoYi-Vue3
🎉 (RuoYi)官方仓库 基于SpringBoot,Spring Security,JWT,Vue3 & Vite、Element Plus 的前后端分离权限管理系统
Vue
876
517
Cangjie-ExamplesCangjie-Examples
本仓将收集和展示高质量的仓颉示例代码,欢迎大家投稿,让全世界看到您的妙趣设计,也让更多人通过您的编码理解和喜爱仓颉语言。
Cangjie
336
1.1 K
ohos_react_nativeohos_react_native
React Native鸿蒙化仓库
C++
179
264
cherry-studiocherry-studio
🍒 Cherry Studio 是一款支持多个 LLM 提供商的桌面客户端
TypeScript
610
59
note-gennote-gen
一款跨平台的 Markdown AI 笔记软件,致力于使用 AI 建立记录和写作的桥梁。
TSX
83
4