[PATCH v6 13/37] arm64/sme: Basic enumeration support
Mark Brown
broonie at kernel.org
Thu Dec 9 11:28:16 PST 2021
On Thu, Dec 09, 2021 at 06:41:26PM +0000, Catalin Marinas wrote:
> On Mon, Nov 15, 2021 at 03:28:11PM +0000, Mark Brown wrote:
> > +#define HWCAP2_SME (1 << 20)
> > +#define HWCAP2_SME_I16I64 (1 << 21)
> > +#define HWCAP2_SME_F64F64 (1 << 22)
> > +#define HWCAP2_SME_I8I32 (1 << 23)
> > +#define HWCAP2_SME_F16F32 (1 << 24)
> > +#define HWCAP2_SME_B16F32 (1 << 25)
> > +#define HWCAP2_SME_F32F32 (1 << 26)
> > +#define HWCAP2_SME_FA64 (1 << 27)
> At this pace we'll need HWCAP3 pretty soon (since we only allocated
> 32-bit in each). I wonder whether we could instead not bother at all and
> just provide user-space emulation for ID_AA64SMFR0_EL1.
I think so if people are willing to go along with just having userspace
check the ID register (IIRC access to it already does the right thing
but I need to confirm). We'll also need to think about how we handle
any new SVE features, that's got a similar thing going on and is most of
the existing usage of HWCAP2.
> > + {
> > + .desc = "FA64",
> > + .type = ARM64_CPUCAP_SYSTEM_FEATURE,
> > + .capability = ARM64_SME_FA64,
> > + .sys_reg = SYS_ID_AA64SMFR0_EL1,
> > + .sign = FTR_UNSIGNED,
> > + .field_pos = ID_AA64SMFR0_FA64_SHIFT,
> > + .min_field_value = ID_AA64SMFR0_FA64,
> > + .matches = has_feature_flag,
> > + .cpu_enable = fa64_kernel_enable,
> > + },
> I'll comment here rather than the patch introducing has_feature_flag():
> an alternative would be to add a .field_width option and in
> feature_matches() use cpuid_feature_extract_field_width() directly. All
> the arm64_ftr_bits entries already have a width, so just generalise it
> for arm64_cpu_capabilities.
Sure, if people are happy with that - it's a more invasive change since
we don't currently set the widths, I wasn't clear if that was a case of
not needing it right now or a design decision.
-------------- next part --------------
A non-text attachment was scrubbed...
Name: signature.asc
Type: application/pgp-signature
Size: 488 bytes
Desc: not available
URL: <http://lists.infradead.org/pipermail/linux-arm-kernel/attachments/20211209/8b5c79fc/attachment.sig>
More information about the linux-arm-kernel
mailing list