From mboxrd@z Thu Jan 1 00:00:00 1970 Return-Path: X-Spam-Checker-Version: SpamAssassin 3.4.0 (2014-02-07) on aws-us-west-2-korg-lkml-1.web.codeaurora.org X-Spam-Level: X-Spam-Status: No, score=-8.3 required=3.0 tests=DKIMWL_WL_HIGH,DKIM_SIGNED, DKIM_VALID,HEADER_FROM_DIFFERENT_DOMAINS,INCLUDES_PATCH,MAILING_LIST_MULTI, SIGNED_OFF_BY,SPF_HELO_NONE,SPF_PASS,USER_AGENT_SANE_1 autolearn=unavailable autolearn_force=no version=3.4.0 Received: from mail.kernel.org (mail.kernel.org [198.145.29.99]) by smtp.lore.kernel.org (Postfix) with ESMTP id 79C0EC43603 for ; Wed, 18 Dec 2019 11:05:44 +0000 (UTC) Received: from bombadil.infradead.org (bombadil.infradead.org [198.137.202.133]) (using TLSv1.2 with cipher ECDHE-RSA-AES256-GCM-SHA384 (256/256 bits)) (No client certificate requested) by mail.kernel.org (Postfix) with ESMTPS id 42D4921D7D for ; Wed, 18 Dec 2019 11:05:44 +0000 (UTC) Authentication-Results: mail.kernel.org; dkim=pass (2048-bit key) header.d=lists.infradead.org header.i=@lists.infradead.org header.b="RmWCN5bf" DMARC-Filter: OpenDMARC Filter v1.3.2 mail.kernel.org 42D4921D7D Authentication-Results: mail.kernel.org; dmarc=none (p=none dis=none) header.from=arm.com Authentication-Results: mail.kernel.org; spf=none smtp.mailfrom=linux-arm-kernel-bounces+infradead-linux-arm-kernel=archiver.kernel.org@lists.infradead.org DKIM-Signature: v=1; a=rsa-sha256; q=dns/txt; c=relaxed/relaxed; d=lists.infradead.org; s=bombadil.20170209; h=Sender: Content-Transfer-Encoding:Content-Type:Cc:List-Subscribe:List-Help:List-Post: List-Archive:List-Unsubscribe:List-Id:In-Reply-To:MIME-Version:Date: Message-ID:From:References:To:Subject:Reply-To:Content-ID:Content-Description :Resent-Date:Resent-From:Resent-Sender:Resent-To:Resent-Cc:Resent-Message-ID: List-Owner; bh=0j4OFmr8NyJfFH58WJZKYMu8eskVHu537/n4AXD/AaM=; b=RmWCN5bfC9UA0O Zf5GXqyxlsrCJ8vFkPuHIJUv4OYfBdW1yPwsmFTQHIFfHrFW9aoDcjxMvOGXvBKDZRKt2mBL3UFbl yQhkdTp1oIL8BEQnkyJTVlmgszWlEJeY3tqQvhC/vYNA9mcqyFstylpOdWpWYGhrGWeS8LclLkbCd szPeq3FhlEqT7sgOYZsbpA9Aiwhfsc1WyTYj+vDY8hQLjxNH/tbM/j0oDOoR/Zn2hmpVeY19CCk/B dHtIu8G0Vh0c4r7L20MGhCHeGHba7EXHLBiPV6+ihKNnkQ07tL3rhEhjRqDoJlAA68xFqGzBDFXax y9yjiBARGP4qePePmkMA==; Received: from localhost ([127.0.0.1] helo=bombadil.infradead.org) by bombadil.infradead.org with esmtp (Exim 4.92.3 #3 (Red Hat Linux)) id 1ihX9A-0007Al-V6; Wed, 18 Dec 2019 11:05:40 +0000 Received: from foss.arm.com ([217.140.110.172]) by bombadil.infradead.org with esmtp (Exim 4.92.3 #3 (Red Hat Linux)) id 1ihX97-0007A6-HF for linux-arm-kernel@lists.infradead.org; Wed, 18 Dec 2019 11:05:39 +0000 Received: from usa-sjc-imap-foss1.foss.arm.com (unknown [10.121.207.14]) by usa-sjc-mx-foss1.foss.arm.com (Postfix) with ESMTP id B7A9630E; Wed, 18 Dec 2019 03:05:36 -0800 (PST) Received: from [10.1.196.56] (e112269-lin.cambridge.arm.com [10.1.196.56]) by usa-sjc-imap-foss1.foss.arm.com (Postfix) with ESMTPSA id B6C053F6CF; Wed, 18 Dec 2019 03:05:35 -0800 (PST) Subject: Re: [PATCH v2] arm64: cpufeature: Export matrix and other features to userspace To: Will Deacon References: <20191216113337.13882-1-steven.price@arm.com> From: Steven Price Message-ID: <3fb4b181-76f3-4bad-c645-888b69bab758@arm.com> Date: Wed, 18 Dec 2019 11:05:34 +0000 User-Agent: Mozilla/5.0 (X11; Linux x86_64; rv:68.0) Gecko/20100101 Thunderbird/68.3.0 MIME-Version: 1.0 In-Reply-To: <20191216113337.13882-1-steven.price@arm.com> Content-Language: en-US X-CRM114-Version: 20100106-BlameMichelson ( TRE 0.8.0 (BSD) ) MR-646709E3 X-CRM114-CacheID: sfid-20191218_030537_664967_0AE31130 X-CRM114-Status: GOOD ( 19.81 ) X-BeenThere: linux-arm-kernel@lists.infradead.org X-Mailman-Version: 2.1.29 Precedence: list List-Id: List-Unsubscribe: , List-Archive: List-Post: List-Help: List-Subscribe: , Cc: julien@xen.org, Suzuki K Poulose , Catalin Marinas , Anshuman Khandual , linux-kernel@vger.kernel.org, linux-arm-kernel@lists.infradead.org Content-Type: text/plain; charset="us-ascii" Content-Transfer-Encoding: 7bit Sender: "linux-arm-kernel" Errors-To: linux-arm-kernel-bounces+infradead-linux-arm-kernel=archiver.kernel.org@lists.infradead.org Hi Will, It was pointed out to me that this patch conflicts with Anshuman's patch[1] adding the BFloat16 support. I'd like your opinion on the best way of handling this. I originally extended the scope of Julien's original patch based on your comment[2] on his patch: So we probably want a patch bringing all of this up to speed, rather than randomly advertising some features and not others. So which outcome do you prefer: * Splitting up the features into multiple patches, i.e. Anshuman's BF16, followed by a version of Julien's Matrix, followed by the remaining features SPECRES/DGH. * A single patch adding everything in one go (i.e. this patch). * Something else I haven't thought of. Thanks, Steve [1] https://lore.kernel.org/linux-arm-kernel/1576145232-8311-1-git-send-email-anshuman.khandual@arm.com/ [2] http://lists.infradead.org/pipermail/linux-arm-kernel/2019-October/690350.html On 16/12/2019 11:33, Steven Price wrote: > Export the features introduced as part of ARMv8.6 exposed in the > ID_AA64ISAR1_EL1 and ID_AA64ZFR0_EL1 registers. This introduces the > Matrix features (ARMv8.2-I8MM, ARMv8.2-F64MM and ARMv8.2-F32MM) along > with BFloat16 (Armv8.2-BF16), speculation invalidation (SPECRES) and > Data Gathering Hint (ARMv8.0-DGH). > > Signed-off-by: Julien Grall > [Added other features in those registers] > Signed-off-by: Steven Price > --- > This is a v2 of Julien's patch[1] extended to export all the new > features contained within the ID_AA64ISAR1_EL1 and ID_AA64ZFR0_EL1 > registers. > > [1] https://lore.kernel.org/linux-arm-kernel/20191025171056.30641-1-julien.grall@arm.com/ > > Documentation/arm64/cpu-feature-registers.rst | 16 ++++++++++ > Documentation/arm64/elf_hwcaps.rst | 31 +++++++++++++++++++ > arch/arm64/include/asm/hwcap.h | 8 +++++ > arch/arm64/include/asm/sysreg.h | 12 +++++++ > arch/arm64/include/uapi/asm/hwcap.h | 8 +++++ > arch/arm64/kernel/cpufeature.c | 20 ++++++++++++ > arch/arm64/kernel/cpuinfo.c | 8 +++++ > 7 files changed, 103 insertions(+) > > diff --git a/Documentation/arm64/cpu-feature-registers.rst b/Documentation/arm64/cpu-feature-registers.rst > index b6e44884e3ad..5382981533f8 100644 > --- a/Documentation/arm64/cpu-feature-registers.rst > +++ b/Documentation/arm64/cpu-feature-registers.rst > @@ -200,6 +200,14 @@ infrastructure: > +------------------------------+---------+---------+ > | Name | bits | visible | > +------------------------------+---------+---------+ > + | I8MM | [55-52] | y | > + +------------------------------+---------+---------+ > + | DGH | [51-48] | y | > + +------------------------------+---------+---------+ > + | BF16 | [47-44] | y | > + +------------------------------+---------+---------+ > + | SPECRES | [43-40] | y | > + +------------------------------+---------+---------+ > | SB | [39-36] | y | > +------------------------------+---------+---------+ > | FRINTTS | [35-32] | y | > @@ -234,10 +242,18 @@ infrastructure: > +------------------------------+---------+---------+ > | Name | bits | visible | > +------------------------------+---------+---------+ > + | F64MM | [59-56] | y | > + +------------------------------+---------+---------+ > + | F32MM | [55-52] | y | > + +------------------------------+---------+---------+ > + | I8MM | [47-44] | y | > + +------------------------------+---------+---------+ > | SM4 | [43-40] | y | > +------------------------------+---------+---------+ > | SHA3 | [35-32] | y | > +------------------------------+---------+---------+ > + | BF16 | [23-20] | y | > + +------------------------------+---------+---------+ > | BitPerm | [19-16] | y | > +------------------------------+---------+---------+ > | AES | [7-4] | y | > diff --git a/Documentation/arm64/elf_hwcaps.rst b/Documentation/arm64/elf_hwcaps.rst > index 7fa3d215ae6a..183ba86ad46e 100644 > --- a/Documentation/arm64/elf_hwcaps.rst > +++ b/Documentation/arm64/elf_hwcaps.rst > @@ -204,6 +204,37 @@ HWCAP2_FRINT > > Functionality implied by ID_AA64ISAR1_EL1.FRINTTS == 0b0001. > > +HWCAP2_SVEI8MM > + > + Functionality implied by ID_AA64ZFR0_EL1.I8MM == 0b0001. > + > +HWCAP2_SVEF32MM > + > + Functionality implied by ID_AA64ZFR0_EL1.F32MM == 0b0001. > + > +HWCAP2_SVEF64MM > + > + Functionality implied by ID_AA64ZFR0_EL1.F64MM == 0b0001. > + > +HWCAP2_SVEBF16 > + > + Functionality implied by ID_AA64ZFR0_EL1.BF16 == 0b0001. > + > +HWCAP2_I8MM > + > + Functionality implied by ID_AA64ISAR1_EL1.I8MM == 0b0001. > + > +HWCAP2_BF16 > + > + Functionality implied by ID_AA64ISAR1_EL1.BF16 == 0b0001. > + > +HWCAP2_DGH > + > + Functionality implied by ID_AA64ISAR1_EL1.DGH == 0b0001. > + > +HWCAP2_SPECRES > + > + Functionality implied by ID_AA64ISAR1_EL1.SPECRES == 0b0001. > > 4. Unused AT_HWCAP bits > ----------------------- > diff --git a/arch/arm64/include/asm/hwcap.h b/arch/arm64/include/asm/hwcap.h > index 3d2f2472a36c..ac7180b2c20b 100644 > --- a/arch/arm64/include/asm/hwcap.h > +++ b/arch/arm64/include/asm/hwcap.h > @@ -86,6 +86,14 @@ > #define KERNEL_HWCAP_SVESM4 __khwcap2_feature(SVESM4) > #define KERNEL_HWCAP_FLAGM2 __khwcap2_feature(FLAGM2) > #define KERNEL_HWCAP_FRINT __khwcap2_feature(FRINT) > +#define KERNEL_HWCAP_SVEI8MM __khwcap2_feature(SVEI8MM) > +#define KERNEL_HWCAP_SVEF32MM __khwcap2_feature(SVEF32MM) > +#define KERNEL_HWCAP_SVEF64MM __khwcap2_feature(SVEF64MM) > +#define KERNEL_HWCAP_SVEBF16 __khwcap2_feature(SVEBF16) > +#define KERNEL_HWCAP_I8MM __khwcap2_feature(I8MM) > +#define KERNEL_HWCAP_DGH __khwcap2_feature(DGH) > +#define KERNEL_HWCAP_BF16 __khwcap2_feature(BF16) > +#define KERNEL_HWCAP_SPECRES __khwcap2_feature(SPECRES) > > /* > * This yields a mask that user programs can use to figure out what > diff --git a/arch/arm64/include/asm/sysreg.h b/arch/arm64/include/asm/sysreg.h > index 6e919fafb43d..f56c4a02a127 100644 > --- a/arch/arm64/include/asm/sysreg.h > +++ b/arch/arm64/include/asm/sysreg.h > @@ -553,6 +553,10 @@ > #define ID_AA64ISAR0_AES_SHIFT 4 > > /* id_aa64isar1 */ > +#define ID_AA64ISAR1_I8MM_SHIFT 52 > +#define ID_AA64ISAR1_DGH_SHIFT 48 > +#define ID_AA64ISAR1_BF16_SHIFT 44 > +#define ID_AA64ISAR1_SPECRES_SHIFT 40 > #define ID_AA64ISAR1_SB_SHIFT 36 > #define ID_AA64ISAR1_FRINTTS_SHIFT 32 > #define ID_AA64ISAR1_GPI_SHIFT 28 > @@ -605,12 +609,20 @@ > #define ID_AA64PFR1_SSBS_PSTATE_INSNS 2 > > /* id_aa64zfr0 */ > +#define ID_AA64ZFR0_F64MM_SHIFT 56 > +#define ID_AA64ZFR0_F32MM_SHIFT 52 > +#define ID_AA64ZFR0_I8MM_SHIFT 44 > #define ID_AA64ZFR0_SM4_SHIFT 40 > #define ID_AA64ZFR0_SHA3_SHIFT 32 > +#define ID_AA64ZFR0_BF16_SHIFT 20 > #define ID_AA64ZFR0_BITPERM_SHIFT 16 > #define ID_AA64ZFR0_AES_SHIFT 4 > #define ID_AA64ZFR0_SVEVER_SHIFT 0 > > +#define ID_AA64ZFR0_F64MM 0x1 > +#define ID_AA64ZFR0_F32MM 0x1 > +#define ID_AA64ZFR0_I8MM 0x1 > +#define ID_AA64ZFR0_BF16 0x1 > #define ID_AA64ZFR0_SM4 0x1 > #define ID_AA64ZFR0_SHA3 0x1 > #define ID_AA64ZFR0_BITPERM 0x1 > diff --git a/arch/arm64/include/uapi/asm/hwcap.h b/arch/arm64/include/uapi/asm/hwcap.h > index a1e72886b30c..8f3f1b66f7b2 100644 > --- a/arch/arm64/include/uapi/asm/hwcap.h > +++ b/arch/arm64/include/uapi/asm/hwcap.h > @@ -65,5 +65,13 @@ > #define HWCAP2_SVESM4 (1 << 6) > #define HWCAP2_FLAGM2 (1 << 7) > #define HWCAP2_FRINT (1 << 8) > +#define HWCAP2_SVEI8MM (1 << 9) > +#define HWCAP2_SVEF32MM (1 << 10) > +#define HWCAP2_SVEF64MM (1 << 11) > +#define HWCAP2_SVEBF16 (1 << 12) > +#define HWCAP2_I8MM (1 << 13) > +#define HWCAP2_BF16 (1 << 14) > +#define HWCAP2_DGH (1 << 15) > +#define HWCAP2_SPECRES (1 << 16) > > #endif /* _UAPI__ASM_HWCAP_H */ > diff --git a/arch/arm64/kernel/cpufeature.c b/arch/arm64/kernel/cpufeature.c > index 04cf64e9f0c9..bf9e9e09da0d 100644 > --- a/arch/arm64/kernel/cpufeature.c > +++ b/arch/arm64/kernel/cpufeature.c > @@ -135,6 +135,10 @@ static const struct arm64_ftr_bits ftr_id_aa64isar0[] = { > }; > > static const struct arm64_ftr_bits ftr_id_aa64isar1[] = { > + ARM64_FTR_BITS(FTR_VISIBLE, FTR_STRICT, FTR_LOWER_SAFE, ID_AA64ISAR1_I8MM_SHIFT, 4, 0), > + ARM64_FTR_BITS(FTR_VISIBLE, FTR_STRICT, FTR_LOWER_SAFE, ID_AA64ISAR1_DGH_SHIFT, 4, 0), > + ARM64_FTR_BITS(FTR_VISIBLE, FTR_STRICT, FTR_LOWER_SAFE, ID_AA64ISAR1_BF16_SHIFT, 4, 0), > + ARM64_FTR_BITS(FTR_VISIBLE, FTR_STRICT, FTR_LOWER_SAFE, ID_AA64ISAR1_SPECRES_SHIFT, 4, 0), > ARM64_FTR_BITS(FTR_VISIBLE, FTR_STRICT, FTR_LOWER_SAFE, ID_AA64ISAR1_SB_SHIFT, 4, 0), > ARM64_FTR_BITS(FTR_VISIBLE, FTR_STRICT, FTR_LOWER_SAFE, ID_AA64ISAR1_FRINTTS_SHIFT, 4, 0), > ARM64_FTR_BITS(FTR_VISIBLE_IF_IS_ENABLED(CONFIG_ARM64_PTR_AUTH), > @@ -176,10 +180,18 @@ static const struct arm64_ftr_bits ftr_id_aa64pfr1[] = { > }; > > static const struct arm64_ftr_bits ftr_id_aa64zfr0[] = { > + ARM64_FTR_BITS(FTR_VISIBLE_IF_IS_ENABLED(CONFIG_ARM64_SVE), > + FTR_STRICT, FTR_LOWER_SAFE, ID_AA64ZFR0_F64MM_SHIFT, 4, 0), > + ARM64_FTR_BITS(FTR_VISIBLE_IF_IS_ENABLED(CONFIG_ARM64_SVE), > + FTR_STRICT, FTR_LOWER_SAFE, ID_AA64ZFR0_F32MM_SHIFT, 4, 0), > + ARM64_FTR_BITS(FTR_VISIBLE_IF_IS_ENABLED(CONFIG_ARM64_SVE), > + FTR_STRICT, FTR_LOWER_SAFE, ID_AA64ZFR0_I8MM_SHIFT, 4, 0), > ARM64_FTR_BITS(FTR_VISIBLE_IF_IS_ENABLED(CONFIG_ARM64_SVE), > FTR_STRICT, FTR_LOWER_SAFE, ID_AA64ZFR0_SM4_SHIFT, 4, 0), > ARM64_FTR_BITS(FTR_VISIBLE_IF_IS_ENABLED(CONFIG_ARM64_SVE), > FTR_STRICT, FTR_LOWER_SAFE, ID_AA64ZFR0_SHA3_SHIFT, 4, 0), > + ARM64_FTR_BITS(FTR_VISIBLE_IF_IS_ENABLED(CONFIG_ARM64_SVE), > + FTR_STRICT, FTR_LOWER_SAFE, ID_AA64ZFR0_BF16_SHIFT, 4, 0), > ARM64_FTR_BITS(FTR_VISIBLE_IF_IS_ENABLED(CONFIG_ARM64_SVE), > FTR_STRICT, FTR_LOWER_SAFE, ID_AA64ZFR0_BITPERM_SHIFT, 4, 0), > ARM64_FTR_BITS(FTR_VISIBLE_IF_IS_ENABLED(CONFIG_ARM64_SVE), > @@ -1651,6 +1663,10 @@ static const struct arm64_cpu_capabilities arm64_elf_hwcaps[] = { > HWCAP_CAP(SYS_ID_AA64ISAR1_EL1, ID_AA64ISAR1_LRCPC_SHIFT, FTR_UNSIGNED, 2, CAP_HWCAP, KERNEL_HWCAP_ILRCPC), > HWCAP_CAP(SYS_ID_AA64ISAR1_EL1, ID_AA64ISAR1_FRINTTS_SHIFT, FTR_UNSIGNED, 1, CAP_HWCAP, KERNEL_HWCAP_FRINT), > HWCAP_CAP(SYS_ID_AA64ISAR1_EL1, ID_AA64ISAR1_SB_SHIFT, FTR_UNSIGNED, 1, CAP_HWCAP, KERNEL_HWCAP_SB), > + HWCAP_CAP(SYS_ID_AA64ISAR1_EL1, ID_AA64ISAR1_SPECRES_SHIFT, FTR_UNSIGNED, 1, CAP_HWCAP, KERNEL_HWCAP_SPECRES), > + HWCAP_CAP(SYS_ID_AA64ISAR1_EL1, ID_AA64ISAR1_BF16_SHIFT, FTR_UNSIGNED, 1, CAP_HWCAP, KERNEL_HWCAP_BF16), > + HWCAP_CAP(SYS_ID_AA64ISAR1_EL1, ID_AA64ISAR1_DGH_SHIFT, FTR_UNSIGNED, 1, CAP_HWCAP, KERNEL_HWCAP_DGH), > + HWCAP_CAP(SYS_ID_AA64ISAR1_EL1, ID_AA64ISAR1_I8MM_SHIFT, FTR_UNSIGNED, 1, CAP_HWCAP, KERNEL_HWCAP_I8MM), > HWCAP_CAP(SYS_ID_AA64MMFR2_EL1, ID_AA64MMFR2_AT_SHIFT, FTR_UNSIGNED, 1, CAP_HWCAP, KERNEL_HWCAP_USCAT), > #ifdef CONFIG_ARM64_SVE > HWCAP_CAP(SYS_ID_AA64PFR0_EL1, ID_AA64PFR0_SVE_SHIFT, FTR_UNSIGNED, ID_AA64PFR0_SVE, CAP_HWCAP, KERNEL_HWCAP_SVE), > @@ -1658,8 +1674,12 @@ static const struct arm64_cpu_capabilities arm64_elf_hwcaps[] = { > HWCAP_CAP(SYS_ID_AA64ZFR0_EL1, ID_AA64ZFR0_AES_SHIFT, FTR_UNSIGNED, ID_AA64ZFR0_AES, CAP_HWCAP, KERNEL_HWCAP_SVEAES), > HWCAP_CAP(SYS_ID_AA64ZFR0_EL1, ID_AA64ZFR0_AES_SHIFT, FTR_UNSIGNED, ID_AA64ZFR0_AES_PMULL, CAP_HWCAP, KERNEL_HWCAP_SVEPMULL), > HWCAP_CAP(SYS_ID_AA64ZFR0_EL1, ID_AA64ZFR0_BITPERM_SHIFT, FTR_UNSIGNED, ID_AA64ZFR0_BITPERM, CAP_HWCAP, KERNEL_HWCAP_SVEBITPERM), > + HWCAP_CAP(SYS_ID_AA64ZFR0_EL1, ID_AA64ZFR0_BF16_SHIFT, FTR_UNSIGNED, ID_AA64ZFR0_BF16, CAP_HWCAP, KERNEL_HWCAP_SVEBF16), > HWCAP_CAP(SYS_ID_AA64ZFR0_EL1, ID_AA64ZFR0_SHA3_SHIFT, FTR_UNSIGNED, ID_AA64ZFR0_SHA3, CAP_HWCAP, KERNEL_HWCAP_SVESHA3), > HWCAP_CAP(SYS_ID_AA64ZFR0_EL1, ID_AA64ZFR0_SM4_SHIFT, FTR_UNSIGNED, ID_AA64ZFR0_SM4, CAP_HWCAP, KERNEL_HWCAP_SVESM4), > + HWCAP_CAP(SYS_ID_AA64ZFR0_EL1, ID_AA64ZFR0_I8MM_SHIFT, FTR_UNSIGNED, ID_AA64ZFR0_I8MM, CAP_HWCAP, KERNEL_HWCAP_SVEI8MM), > + HWCAP_CAP(SYS_ID_AA64ZFR0_EL1, ID_AA64ZFR0_F32MM_SHIFT, FTR_UNSIGNED, ID_AA64ZFR0_F32MM, CAP_HWCAP, KERNEL_HWCAP_SVEF32MM), > + HWCAP_CAP(SYS_ID_AA64ZFR0_EL1, ID_AA64ZFR0_F64MM_SHIFT, FTR_UNSIGNED, ID_AA64ZFR0_F64MM, CAP_HWCAP, KERNEL_HWCAP_SVEF64MM), > #endif > HWCAP_CAP(SYS_ID_AA64PFR1_EL1, ID_AA64PFR1_SSBS_SHIFT, FTR_UNSIGNED, ID_AA64PFR1_SSBS_PSTATE_INSNS, CAP_HWCAP, KERNEL_HWCAP_SSBS), > #ifdef CONFIG_ARM64_PTR_AUTH > diff --git a/arch/arm64/kernel/cpuinfo.c b/arch/arm64/kernel/cpuinfo.c > index 56bba746da1c..1eaf4dc0c5a0 100644 > --- a/arch/arm64/kernel/cpuinfo.c > +++ b/arch/arm64/kernel/cpuinfo.c > @@ -84,6 +84,14 @@ static const char *const hwcap_str[] = { > "svesm4", > "flagm2", > "frint", > + "svei8mm", > + "svef32mm", > + "svef64mm", > + "svebf16", > + "i8mm", > + "bf16", > + "dgh", > + "specres", > NULL > }; > > _______________________________________________ linux-arm-kernel mailing list linux-arm-kernel@lists.infradead.org http://lists.infradead.org/mailman/listinfo/linux-arm-kernel