首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >是否检测ARM指令集版本?

是否检测ARM指令集版本?
EN

Stack Overflow用户
提问于 2021-08-11 11:43:23
回答 1查看 160关注 0票数 0

我正在写一段代码,根据不同供应商实现的指令集的不同版本,可能会有不同的行为。这些是不同版本的ARMv8指令集,如ARM v8.1、v8.2、v8.6。

是否有任何寄存器可以在运行时告知ARM cpu上实现的ARM指令集(ARMv8)的版本?

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2021-08-17 15:19:26

首先,没有寄存器直接提供所实现的Arm指令集版本。其次,您可以使用以ID_*开头的寄存器来查询实现的特性。例如,ID_AA64ISAR0_EL1有AES字段,它告诉AES=1/2,那么AES指令被实现,ID_AA64PFR0_EL1.FP告诉是否实现浮点运算。

可以说,如果实现符合或实现了ARMV8.2,那么需要实现一组强制特性。在Arm参考手册的A2章中对此进行了说明。例如,如果您想知道V8.6是否存在,那么Fine Grain Trap和Enhanced Counter Virtualization是必须实现的功能。ID_AA64MMFR0_EL1。{FGT,ECV }字段将告知这些功能的存在,如果存在,则可以说Arm V8.6指令集已实现

MIDR_EL1寄存器具有字段“架构”,该字段可能会设置为0x1111,表示可以使用ID_*寄存器了解所实现的功能。该寄存器中的其他字段为IMPLEMENTATION_DEFINED值,可以设置为零。可能苹果已经选择将"Architecuture“字段设置为零,因此您会看到MIDR_EL1的值为零。

票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/68741344

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档