ARM64 ELF hwcaps

本文档描述了 arm64 ELF hwcaps 的用法和语义。

1. 简介

某些硬件或软件特性仅在某些 CPU 实现上可用,或者仅在具有特定内核配置的情况下可用,但在 EL0 处没有架构化的发现机制可供用户空间代码使用。内核通过一组称为 hwcaps 的标志将这些特性的存在暴露给用户空间,这些标志在辅助向量中暴露。

用户空间软件可以通过获取辅助向量的 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;
}

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

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

2. hwcaps 的解释

大多数 hwcaps 旨在指示架构 ID 寄存器描述的特性的存在,这些寄存器在 EL0 处对用户空间代码不可访问。这些 hwcaps 是根据 ID 寄存器字段定义的,应参考 ARM 架构参考手册 (ARM ARM) 中这些字段的定义进行解释。

此类 hwcaps 在下面以以下形式描述:

Functionality implied by idreg.field == val.

此类 hwcaps 指示 ARM ARM 定义为当 idreg.field 的值为 val 时存在的功能的可用性,但不指示 idreg.field 完全等于 val,也不指示 idreg.field 的其他值所暗示的功能的缺失。

其他 hwcaps 可能指示仅通过 ID 寄存器无法描述的特性的存在。 这些描述可能不参考 ID 寄存器,并且可能引用其他文档。

3. AT_HWCAP 中公开的 hwcaps

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 的受保护控制栈支持 中所述。

HWCAP_CMPBR

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

HWCAP_FPRCVT

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

HWCAP_F8MM8

ID_AA64FPFR0_EL1.F8MM8 == 0b0001 所暗示的功能。

HWCAP_F8MM4

ID_AA64FPFR0_EL1.F8MM4 == 0b0001 所暗示的功能。

HWCAP_SVE_F16MM

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

HWCAP_SVE_ELTPERM

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

HWCAP_SVE_AES2

ID_AA64PFR0_EL1.SVE == 0b0001 和 ID_AA64ZFR0_EL1.AES == 0b0011 所暗示的功能。

HWCAP_SVE_BFSCALE

ID_AA64PFR0_EL1.SVE == 0b0001 和 ID_AA64ZFR0_EL1.B16B16 == 0b0010 所暗示的功能。

HWCAP_SVE2P2

ID_AA64PFR0_EL1.SVE == 0b0001 和 ID_AA64ZFR0_EL1.SVEver == 0b0011 所暗示的功能。

HWCAP_SME2P2

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

HWCAP_SME_SBITPERM

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

HWCAP_SME_AES

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

HWCAP_SME_SFEXPA

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

HWCAP_SME_STMOP

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

HWCAP_SME_SMOP4

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

HWCAP2_DCPODP

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

HWCAP2_SVE2

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

HWCAP2_SVEAES

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

HWCAP2_SVEPMULL

ID_AA64PFR0_EL1.SVE == 0b0001 和 ID_AA64ZFR0_EL1.AES == 0b0010 所暗示的功能。

HWCAP2_SVEBITPERM

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

HWCAP2_SVESHA3

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

HWCAP2_SVESM4

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

HWCAP2_FLAGM2

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

HWCAP2_FRINT

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

HWCAP2_SVEI8MM

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

HWCAP2_SVEF32MM

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

HWCAP2_SVEF64MM

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

HWCAP2_SVEBF16

ID_AA64PFR0_EL1.SVE == 0b0001 和 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_AA64PFR0_EL1.SVE == 0b0001 和 ID_AA64ZFR0_EL1.BF16 == 0b0010 所暗示的功能。

HWCAP2_CSSC

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

HWCAP2_RPRFM

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

HWCAP2_SVE2P1

ID_AA64PFR0_EL1.SVE == 0b0001 和 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_AA64PFR0_EL1.SVE == 0b0001 和 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。