diff options
author | Amit Daniel Kachhap <amit.kachhap@arm.com> | 2022-11-17 06:42:07 +0100 |
---|---|---|
committer | Russell King (Oracle) <rmk+kernel@armlinux.org.uk> | 2022-11-28 12:57:33 +0100 |
commit | 23b6d4ad6e7a3028dd88aff7e2b0e5a81da8565e (patch) | |
tree | cf85dff234f31626a5d44cd4220e3fc5c2b4f35e /arch/arm/vfp | |
parent | ARM: 9270/1: vfp: Add hwcap for FEAT_FHM (diff) | |
download | linux-23b6d4ad6e7a3028dd88aff7e2b0e5a81da8565e.tar.xz linux-23b6d4ad6e7a3028dd88aff7e2b0e5a81da8565e.zip |
ARM: 9271/1: vfp: Add hwcap for FEAT_AA32BF16
Advanced SIMD BFloat16 (FEAT_AA32BF16) is a feature present in AArch32
state for Armv8 and is represented by ISAR6.BF16 identification
register.
This feature denotes the presence of VCVT, VCVTB, VCVTT, VDOT, VFMAB,
VFMAT and VMMLA instructions and hence adding a hwcap will enable the
userspace to check it before trying to use those instructions.
Reviewed-by: Linus Walleij <linus.walleij@linaro.org>
Signed-off-by: Amit Daniel Kachhap <amit.kachhap@arm.com>
Signed-off-by: Russell King (Oracle) <rmk+kernel@armlinux.org.uk>
Diffstat (limited to 'arch/arm/vfp')
-rw-r--r-- | arch/arm/vfp/vfpmodule.c | 6 |
1 files changed, 6 insertions, 0 deletions
diff --git a/arch/arm/vfp/vfpmodule.c b/arch/arm/vfp/vfpmodule.c index 404c4f901132..ff574cb8a0b9 100644 --- a/arch/arm/vfp/vfpmodule.c +++ b/arch/arm/vfp/vfpmodule.c @@ -851,6 +851,12 @@ static int __init vfp_init(void) */ if (cpuid_feature_extract_field(isar6, 8) == 0x1) elf_hwcap |= HWCAP_ASIMDFHM; + /* + * Check for the presence of Advanced SIMD Bfloat16 + * floating point instructions. + */ + if (cpuid_feature_extract_field(isar6, 20) == 0x1) + elf_hwcap |= HWCAP_ASIMDBF16; /* Extract the architecture version on pre-cpuid scheme */ } else { |