ARM64 ELF 硬件能力

本文档描述了 arm64 ELF 硬件能力的使用和语义。

1. 简介

某些硬件或软件功能仅在某些 CPU 实现上可用,或者仅在某些内核配置下可用,但在 EL0 处没有架构化的发现机制可供用户空间代码使用。内核通过一组称为硬件能力的标志,在辅助向量中公开这些功能的存在。

用户空间软件可以通过获取辅助向量的 AT_HWCAP、AT_HWCAP2 或 AT_HWCAP3 条目,并测试是否设置了相关标志来测试功能,例如:

bool floating_point_is_present(void)
{
        unsigned long hwcaps = getauxval(AT_HWCAP);
        if (hwcaps & HWCAP_FP)
                return true;

        return false;
}

如果软件依赖于硬件能力描述的功能,则应检查相关的硬件能力标志,以验证该功能是否存在,然后再尝试使用该功能。

无法通过其他方式可靠地探测功能。当某个功能不可用时,尝试使用它可能会导致不可预测的行为,并且不能保证会产生任何可靠的指示,例如 SIGILL,来表明该功能不可用。

2. 硬件能力的解释

大多数硬件能力旨在指示 EL0 处的用户空间代码无法访问的架构化 ID 寄存器描述的功能的存在。这些硬件能力根据 ID 寄存器字段定义,应参考 ARM 架构参考手册 (ARM ARM) 中这些字段的定义进行解释。

此类硬件能力在下面以以下形式描述

Functionality implied by idreg.field == val.

此类硬件能力表示 ARM ARM 定义的当 idreg.field 的值为 val 时存在的功能的可用性,但不表示 idreg.field 精确等于 val,也不表示 idreg.field 的其他值所暗示的功能不存在。

其他硬件能力可能表示无法仅通过 ID 寄存器描述的功能的存在。这些可能在不参考 ID 寄存器的情况下进行描述,并且可能参考其他文档。

3. AT_HWCAP 中公开的硬件能力

HWCAP_FP

ID_AA64PFR0_EL1.FP == 0b0000 所暗示的功能。

HWCAP_ASIMD

ID_AA64PFR0_EL1.AdvSIMD == 0b0000 所暗示的功能。

HWCAP_EVTSTRM

通用定时器配置为以大约 10KHz 的频率生成事件。

HWCAP_AES

ID_AA64ISAR0_EL1.AES == 0b0001 所暗示的功能。

HWCAP_PMULL

ID_AA64ISAR0_EL1.AES == 0b0010 所暗示的功能。

HWCAP_SHA1

ID_AA64ISAR0_EL1.SHA1 == 0b0001 所暗示的功能。

HWCAP_SHA2

ID_AA64ISAR0_EL1.SHA2 == 0b0001 所暗示的功能。

HWCAP_CRC32

ID_AA64ISAR0_EL1.CRC32 == 0b0001 所暗示的功能。

HWCAP_ATOMICS

ID_AA64ISAR0_EL1.Atomic == 0b0010 所暗示的功能。

HWCAP_FPHP

ID_AA64PFR0_EL1.FP == 0b0001 所暗示的功能。

HWCAP_ASIMDHP

ID_AA64PFR0_EL1.AdvSIMD == 0b0001 所暗示的功能。

HWCAP_CPUID

EL0 可以访问某些 ID 寄存器,访问程度由 ARM64 CPU 功能寄存器 描述。

这些 ID 寄存器可能暗示功能的可用性。

HWCAP_ASIMDRDM

ID_AA64ISAR0_EL1.RDM == 0b0001 所暗示的功能。

HWCAP_JSCVT

ID_AA64ISAR1_EL1.JSCVT == 0b0001 所暗示的功能。

HWCAP_FCMA

ID_AA64ISAR1_EL1.FCMA == 0b0001 所暗示的功能。

HWCAP_LRCPC

ID_AA64ISAR1_EL1.LRCPC == 0b0001 所暗示的功能。

HWCAP_DCPOP

ID_AA64ISAR1_EL1.DPB == 0b0001 所暗示的功能。

HWCAP_SHA3

ID_AA64ISAR0_EL1.SHA3 == 0b0001 所暗示的功能。

HWCAP_SM3

ID_AA64ISAR0_EL1.SM3 == 0b0001 所暗示的功能。

HWCAP_SM4

ID_AA64ISAR0_EL1.SM4 == 0b0001 所暗示的功能。

HWCAP_ASIMDDP

ID_AA64ISAR0_EL1.DP == 0b0001 所暗示的功能。

HWCAP_SHA512

ID_AA64ISAR0_EL1.SHA2 == 0b0010 所暗示的功能。

HWCAP_SVE

ID_AA64PFR0_EL1.SVE == 0b0001 所暗示的功能。

HWCAP_ASIMDFHM

ID_AA64ISAR0_EL1.FHM == 0b0001 所暗示的功能。

HWCAP_DIT

ID_AA64PFR0_EL1.DIT == 0b0001 所暗示的功能。

HWCAP_USCAT

ID_AA64MMFR2_EL1.AT == 0b0001 所暗示的功能。

HWCAP_ILRCPC

ID_AA64ISAR1_EL1.LRCPC == 0b0010 所暗示的功能。

HWCAP_FLAGM

ID_AA64ISAR0_EL1.TS == 0b0001 所暗示的功能。

HWCAP_SSBS

ID_AA64PFR1_EL1.SSBS == 0b0010 所暗示的功能。

HWCAP_SB

ID_AA64ISAR1_EL1.SB == 0b0001 所暗示的功能。

HWCAP_PACA

ID_AA64ISAR1_EL1.APA == 0b0001 或 ID_AA64ISAR1_EL1.API == 0b0001 所暗示的功能,如 AArch64 Linux 中的指针身份验证 所述。

HWCAP_PACG

ID_AA64ISAR1_EL1.GPA == 0b0001 或 ID_AA64ISAR1_EL1.GPI == 0b0001 所暗示的功能,如 AArch64 Linux 中的指针身份验证 所述。

HWCAP_GCS

ID_AA64PFR1_EL1.GCS == 0b1 所暗示的功能,如 AArch64 Linux 的受保护控制堆栈支持 所述。

HWCAP2_DCPODP

ID_AA64ISAR1_EL1.DPB == 0b0010 所暗示的功能。

HWCAP2_SVE2

ID_AA64ZFR0_EL1.SVEver == 0b0001 所暗示的功能。

HWCAP2_SVEAES

ID_AA64ZFR0_EL1.AES == 0b0001 所暗示的功能。

HWCAP2_SVEPMULL

ID_AA64ZFR0_EL1.AES == 0b0010 所暗示的功能。

HWCAP2_SVEBITPERM

ID_AA64ZFR0_EL1.BitPerm == 0b0001 所暗示的功能。

HWCAP2_SVESHA3

ID_AA64ZFR0_EL1.SHA3 == 0b0001 所暗示的功能。

HWCAP2_SVESM4

ID_AA64ZFR0_EL1.SM4 == 0b0001 所暗示的功能。

HWCAP2_FLAGM2

ID_AA64ISAR0_EL1.TS == 0b0010 所暗示的功能。

HWCAP2_FRINT

ID_AA64ISAR1_EL1.FRINTTS == 0b0001 所暗示的功能。

HWCAP2_SVEI8MM

ID_AA64ZFR0_EL1.I8MM == 0b0001 所暗示的功能。

HWCAP2_SVEF32MM

ID_AA64ZFR0_EL1.F32MM == 0b0001 所暗示的功能。

HWCAP2_SVEF64MM

ID_AA64ZFR0_EL1.F64MM == 0b0001 所暗示的功能。

HWCAP2_SVEBF16

ID_AA64ZFR0_EL1.BF16 == 0b0001 所暗示的功能。

HWCAP2_I8MM

ID_AA64ISAR1_EL1.I8MM == 0b0001 所暗示的功能。

HWCAP2_BF16

ID_AA64ISAR1_EL1.BF16 == 0b0001 所暗示的功能。

HWCAP2_DGH

ID_AA64ISAR1_EL1.DGH == 0b0001 所暗示的功能。

HWCAP2_RNG

ID_AA64ISAR0_EL1.RNDR == 0b0001 所暗示的功能。

HWCAP2_BTI

ID_AA64PFR1_EL1.BT == 0b0001 所暗示的功能。

HWCAP2_MTE

ID_AA64PFR1_EL1.MTE == 0b0010 所暗示的功能,如 AArch64 Linux 中的内存标记扩展 (MTE) 所述。

HWCAP2_ECV

ID_AA64MMFR0_EL1.ECV == 0b0001 所暗示的功能。

HWCAP2_AFP

ID_AA64MMFR1_EL1.AFP == 0b0001 所暗示的功能。

HWCAP2_RPRES

ID_AA64ISAR2_EL1.RPRES == 0b0001 所暗示的功能。

HWCAP2_MTE3

ID_AA64PFR1_EL1.MTE == 0b0011 所暗示的功能,如 AArch64 Linux 中的内存标记扩展 (MTE) 所述。

HWCAP2_SME

ID_AA64PFR1_EL1.SME == 0b0001 所暗示的功能,如 AArch64 Linux 的可扩展矩阵扩展支持 所述。

HWCAP2_SME_I16I64

ID_AA64SMFR0_EL1.I16I64 == 0b1111 所暗示的功能。

HWCAP2_SME_F64F64

ID_AA64SMFR0_EL1.F64F64 == 0b1 所暗示的功能。

HWCAP2_SME_I8I32

ID_AA64SMFR0_EL1.I8I32 == 0b1111 所暗示的功能。

HWCAP2_SME_F16F32

ID_AA64SMFR0_EL1.F16F32 == 0b1 所暗示的功能。

HWCAP2_SME_B16F32

ID_AA64SMFR0_EL1.B16F32 == 0b1 所暗示的功能。

HWCAP2_SME_F32F32

ID_AA64SMFR0_EL1.F32F32 == 0b1 所暗示的功能。

HWCAP2_SME_FA64

ID_AA64SMFR0_EL1.FA64 == 0b1 所暗示的功能。

HWCAP2_WFXT

ID_AA64ISAR2_EL1.WFXT == 0b0010 所暗示的功能。

HWCAP2_EBF16

ID_AA64ISAR1_EL1.BF16 == 0b0010 所暗示的功能。

HWCAP2_SVE_EBF16

ID_AA64ZFR0_EL1.BF16 == 0b0010 所暗示的功能。

HWCAP2_CSSC

ID_AA64ISAR2_EL1.CSSC == 0b0001 所暗示的功能。

HWCAP2_RPRFM

ID_AA64ISAR2_EL1.RPRFM == 0b0001 所暗示的功能。

HWCAP2_SVE2P1

ID_AA64ZFR0_EL1.SVEver == 0b0010 所暗示的功能。

HWCAP2_SME2

ID_AA64SMFR0_EL1.SMEver == 0b0001 所暗示的功能。

HWCAP2_SME2P1

ID_AA64SMFR0_EL1.SMEver == 0b0010 所暗示的功能。

HWCAP2_SMEI16I32

ID_AA64SMFR0_EL1.I16I32 == 0b0101 所暗示的功能

HWCAP2_SMEBI32I32

ID_AA64SMFR0_EL1.BI32I32 == 0b1 所暗示的功能

HWCAP2_SMEB16B16

ID_AA64SMFR0_EL1.B16B16 == 0b1 所暗示的功能

HWCAP2_SMEF16F16

ID_AA64SMFR0_EL1.F16F16 == 0b1 所暗示的功能

HWCAP2_MOPS

ID_AA64ISAR2_EL1.MOPS == 0b0001 所暗示的功能。

HWCAP2_HBC

ID_AA64ISAR2_EL1.BC == 0b0001 所暗示的功能。

HWCAP2_SVE_B16B16

ID_AA64ZFR0_EL1.B16B16 == 0b0001 所暗示的功能。

HWCAP2_LRCPC3

ID_AA64ISAR1_EL1.LRCPC == 0b0011 所暗示的功能。

HWCAP2_LSE128

ID_AA64ISAR0_EL1.Atomic == 0b0011 所暗示的功能。

HWCAP2_FPMR

ID_AA64PFR2_EL1.FMR == 0b0001 所暗示的功能。

HWCAP2_LUT

ID_AA64ISAR2_EL1.LUT == 0b0001 所暗示的功能。

HWCAP2_FAMINMAX

ID_AA64ISAR3_EL1.FAMINMAX == 0b0001 所暗示的功能。

HWCAP2_F8CVT

ID_AA64FPFR0_EL1.F8CVT == 0b1 所暗示的功能。

HWCAP2_F8FMA

ID_AA64FPFR0_EL1.F8FMA == 0b1 所暗示的功能。

HWCAP2_F8DP4

ID_AA64FPFR0_EL1.F8DP4 == 0b1 所暗示的功能。

HWCAP2_F8DP2

ID_AA64FPFR0_EL1.F8DP2 == 0b1 所暗示的功能。

HWCAP2_F8E4M3

ID_AA64FPFR0_EL1.F8E4M3 == 0b1 所暗示的功能。

HWCAP2_F8E5M2

ID_AA64FPFR0_EL1.F8E5M2 == 0b1 所暗示的功能。

HWCAP2_SME_LUTV2

ID_AA64SMFR0_EL1.LUTv2 == 0b1 所暗示的功能。

HWCAP2_SME_F8F16

ID_AA64SMFR0_EL1.F8F16 == 0b1 所暗示的功能。

HWCAP2_SME_F8F32

ID_AA64SMFR0_EL1.F8F32 == 0b1 所暗示的功能。

HWCAP2_SME_SF8FMA

ID_AA64SMFR0_EL1.SF8FMA == 0b1 所暗示的功能。

HWCAP2_SME_SF8DP4

ID_AA64SMFR0_EL1.SF8DP4 == 0b1 所暗示的功能。

HWCAP2_SME_SF8DP2

ID_AA64SMFR0_EL1.SF8DP2 == 0b1 所暗示的功能。

HWCAP2_SME_SF8DP4

ID_AA64SMFR0_EL1.SF8DP4 == 0b1 所暗示的功能。

HWCAP2_POE

ID_AA64MMFR3_EL1.S1POE == 0b0001 所暗示的功能。

4. 未使用的 AT_HWCAP 位

为了与用户空间互操作,内核保证 AT_HWCAP 的第 62 位和第 63 位始终返回为 0。