The ID_AA64ZFR0_EL1 characteristics are:
Provides additional information about the implemented features of the AArch64 Scalable Vector Extension instruction set, when either or both of ID_AA64PFR0_EL1.SVE and ID_AA64PFR1_EL1.SME are not zero.
For general information about the interpretation of the ID registers see 'Principles of the ID scheme for fields in ID registers'.
Prior to the introduction of the features described by this register, this register was unnamed and reserved, RES0 from EL1, EL2, and EL3.
ID_AA64ZFR0_EL1 is a 64-bit register.
63 | 62 | 61 | 60 | 59 | 58 | 57 | 56 | 55 | 54 | 53 | 52 | 51 | 50 | 49 | 48 | 47 | 46 | 45 | 44 | 43 | 42 | 41 | 40 | 39 | 38 | 37 | 36 | 35 | 34 | 33 | 32 |
31 | 30 | 29 | 28 | 27 | 26 | 25 | 24 | 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16 | 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
RES0 | F64MM | F32MM | RES0 | I8MM | SM4 | RES0 | SHA3 | ||||||||||||||||||||||||
RES0 | BF16 | BitPerm | RES0 | AES | SVEver |
Reserved, RES0.
Indicates support for SVE FP64 double-precision floating-point matrix multiplication instructions. Defined values are:
F64MM | Meaning |
---|---|
0b0000 |
FP64 matrix multiplication and related instructions are not implemented. |
0b0001 |
FP64 variant of the FMMLA instruction, and LD1RO* instructions are implemented. The 128-bit element variations of TRN1, TRN2, UZP1, UZP2, ZIP1, and ZIP2 are also implemented. |
All other values are reserved.
When the PE is in Streaming SVE mode, software should ignore and treat as zero the value in this field.
FEAT_F64MM implements the functionality identified by 0b0001.
From Armv8.2, the permitted values are 0b0000 and 0b0001.
Indicates support for the SVE FP32 single-precision floating-point matrix multiplication instruction. Defined values are:
F32MM | Meaning |
---|---|
0b0000 |
FP32 matrix multiplication instruction is not implemented. |
0b0001 |
FP32 variant of the FMMLA instruction is implemented. |
All other values are reserved.
When the PE is in Streaming SVE mode, software should ignore and treat as zero the value in this field.
FEAT_F32MM implements the functionality identified by 0b0001.
From Arm v8.2, the permitted values are 0b0000 and 0b0001.
Reserved, RES0.
Indicates support for SVE Int8 matrix multiplication instructions. Defined values are:
I8MM | Meaning |
---|---|
0b0000 |
Int8 matrix multiplication instructions are not implemented. |
0b0001 |
SMMLA, SUDOT, UMMLA, USMMLA, and USDOT instructions are implemented. |
All other values are reserved.
When the PE is in Streaming SVE mode, software should ignore and treat as zero the value in this field.
FEAT_I8MM implements the functionality identified by 0b0001.
When Advanced SIMD and SVE are both implemented, this field must return the same value as ID_AA64ISAR1_EL1.I8MM.
From Armv8.6, if FEAT_SVE is implemented, then the only permitted value is 0b0001. Otherwise, the value can be 0b0000 or 0b0001.
Indicates support for SVE SM4 instructions. Defined values are:
SM4 | Meaning |
---|---|
0b0000 |
SVE SM4 instructions are not implemented. |
0b0001 |
SVE SM4E and SM4EKEY instructions are implemented. |
All other values are reserved.
When the PE is in Streaming SVE mode, software should ignore and treat as zero the value in this field.
FEAT_SVE_SM4 implements the functionality identified by 0b0001.
Reserved, RES0.
Indicates support for the SVE SHA3 instructions. Defined values are:
SHA3 | Meaning |
---|---|
0b0000 |
SVE SHA3 instructions are not implemented. |
0b0001 |
SVE RAX1 instruction is implemented. |
All other values are reserved.
When the PE is in Streaming SVE mode, software should ignore and treat as zero the value in this field.
FEAT_SVE_SHA3 implements the functionality identified by 0b0001.
Reserved, RES0.
Indicates support for SVE BFloat16 instructions. Defined values are:
BF16 | Meaning |
---|---|
0b0000 |
BFloat16 instructions are not implemented. |
0b0001 |
BFCVT, BFCVTNT, BFDOT, BFMLALB, BFMLALT, and BFMMLA instructions are implemented. |
0b0010 |
As 0b0001, but the FPCR.EBF field is also supported. |
All other values are reserved.
FEAT_BF16 implements the functionality identified by 0b0001.
FEAT_EBF16 implements the functionality identified by 0b0010.
When Advanced SIMD and SVE are both implemented, this field must return the same value as ID_AA64ISAR1_EL1.BF16.
From Armv8.6, if FEAT_SME is implemented, the permitted values are 0b0001 and 0b0010.
From Armv8.6, if FEAT_SME is not implemented, the only permitted value is 0b0001.
Indicates support for SVE bit permute instructions. Defined values are:
BitPerm | Meaning |
---|---|
0b0000 |
SVE bit permute instructions are not implemented. |
0b0001 |
SVE BDEP, BEXT, and BGRP instructions are implemented. |
All other values are reserved.
When the PE is in Streaming SVE mode, software should ignore and treat as zero the value in this field.
FEAT_SVE_BitPerm implements the functionality identified by 0b0001.
Reserved, RES0.
Indicates support for SVE AES instructions. Defined values are:
AES | Meaning |
---|---|
0b0000 |
SVE AES instructions are not implemented. |
0b0001 |
SVE AESE, AESD, AESMC, and AESIMC instructions are implemented. |
0b0010 |
As 0b0001, plus SVE PMULLB and PMULLT instructions with 64-bit source. |
All other values are reserved.
When the PE is in Streaming SVE mode, software should ignore and treat as zero the value in this field.
FEAT_SVE_AES implements the functionality identified by the value 0b0001.
FEAT_SVE_PMULL128 implements the functionality identified by the value 0b0010.
The permitted values are 0b0000 and 0b0010.
Indicates support for SVE. Defined values are:
SVEver | Meaning |
---|---|
0b0000 |
SVE instructions are implemented. |
0b0001 |
The SVE and non-optional SVE2 instructions are implemented. |
All other values are reserved.
FEAT_SVE2 and FEAT_SME implement the functionality identified by the value 0b0001.
From Armv9, if FEAT_SME is implemented, the only permitted value is 0b0001. This value indicates that SVE and SVE2 instructions are implemented when the PE is in Streaming SVE mode.
Irrespective of the value of ID_AA64ZFR0_EL1.SVEver, when the PE is in Streaming SVE mode, software should not attempt to execute any of the SVE and SVE2 instructions that are illegal in Streaming SVE mode.
Accesses to this register use the following encodings in the System register encoding space:
op0 | op1 | CRn | CRm | op2 |
---|---|---|---|---|
0b11 | 0b000 | 0b0000 | 0b0100 | 0b100 |
if PSTATE.EL == EL0 then if IsFeatureImplemented(FEAT_IDST) then if EL2Enabled() && HCR_EL2.TGE == '1' then AArch64.SystemAccessTrap(EL2, 0x18); else AArch64.SystemAccessTrap(EL1, 0x18); else UNDEFINED; elsif PSTATE.EL == EL1 then if EL2Enabled() && (!IsZero(ID_AA64ZFR0_EL1) || boolean IMPLEMENTATION_DEFINED "ID_AA64ZFR0_EL1 trapped by HCR_EL2.TID3") && HCR_EL2.TID3 == '1' then AArch64.SystemAccessTrap(EL2, 0x18); else return ID_AA64ZFR0_EL1; elsif PSTATE.EL == EL2 then return ID_AA64ZFR0_EL1; elsif PSTATE.EL == EL3 then return ID_AA64ZFR0_EL1;
30/09/2021 14:53; 092b4e1bbfbb45a293b198f9330c5f529ead2b0f
Copyright © 2010-2021 Arm Limited or its affiliates. All rights reserved. This document is Non-Confidential.