我正在写一段代码,根据不同供应商实现的指令集的不同版本,可能会有不同的行为。这些是不同版本的ARMv8指令集,如ARM v8.1、v8.2、v8.6。
是否有任何寄存器可以在运行时告知ARM cpu上实现的ARM指令集(ARMv8)的版本?
发布于 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的值为零。
https://stackoverflow.com/questions/68741344
复制相似问题