Provides information about the instruction sets implemented by the PE in AArch32 state.
Must be interpreted with ID_ISAR0_EL1, ID_ISAR1_EL1, ID_ISAR2_EL1, ID_ISAR3_EL1, ID_ISAR4_EL1 and ID_ISAR5_EL1.
For general information about the interpretation of the ID registers see 'Principles of the ID scheme for fields in ID registers'.
AArch64 System register ID_ISAR6_EL1 bits [31:0] are architecturally mapped to AArch32 System register ID_ISAR6[31:0].
Prior to the introduction of the features described by this register, this register was unnamed and reserved, RES0 from EL1, EL2, and EL3.
ID_ISAR6_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 | |||||||||||||||||||||||||||||||
CLRBHB | I8MM | BF16 | SPECRES | SB | FHM | DP | JSCVT |
Reserved, RES0.
Indicates support for the CLRBHB instruction in AArch32 state.
The value of this field is an IMPLEMENTATION DEFINED choice of:
CLRBHB | Meaning |
---|---|
0b0000 |
CLRBHB instruction is not implemented. |
0b0001 |
CLRBHB instruction is implemented. |
All other values are reserved.
FEAT_CLRBHB implements the functionality identified by 0b0001.
From Armv8.9, the value 0b0000 is not permitted.
Access to this field is RO.
Indicates support for Advanced SIMD and floating-point Int8 matrix multiplication instructions in AArch32 state.
The value of this field is an IMPLEMENTATION DEFINED choice of:
I8MM | Meaning |
---|---|
0b0000 |
Int8 matrix multiplication instructions are not implemented. |
0b0001 |
VSMMLA, VSUDOT, VUMMLA, VUSMMLA, and VUSDOT instructions are implemented. |
All other values are reserved.
FEAT_AA32I8MM implements the functionality identified by 0b0001.
Access to this field is RO.
Indicates support for Advanced SIMD and floating-point BFloat16 instructions in AArch32 state.
The value of this field is an IMPLEMENTATION DEFINED choice of:
BF16 | Meaning |
---|---|
0b0000 |
BFloat16 instructions are not implemented. |
0b0001 |
VCVT, VCVTB, VCVTT, VDOT, VFMAB, VFMAT, and VMMLA instructions with BF16 operand or result types are implemented. |
All other values are reserved.
FEAT_AA32BF16 implements the functionality identified by 0b0001.
Access to this field is RO.
Indicates support for prediction invalidation instructions in AArch32 state.
The value of this field is an IMPLEMENTATION DEFINED choice of:
SPECRES | Meaning |
---|---|
0b0000 |
Prediction invalidation instructions are not implemented. |
0b0001 | |
0b0010 |
As 0b0001, and COSPRCTX instruction is implemented. |
All other values are reserved.
FEAT_SPECRES implements the functionality identified by 0b0001.
FEAT_SPECRES2 implements the functionality identified by 0b0010.
From Armv8.5, the value 0b0000 is not permitted.
From Armv8.9, the value 0b0001 is not permitted.
Access to this field is RO.
Indicates support for the SB instruction in AArch32 state.
The value of this field is an IMPLEMENTATION DEFINED choice of:
SB | Meaning |
---|---|
0b0000 |
SB instruction is not implemented. |
0b0001 |
SB instruction is implemented. |
All other values are reserved.
FEAT_SB implements the functionality identified by 0b0001.
From Armv8.5, the only permitted value is 0b0001.
Access to this field is RO.
Indicates support for Advanced SIMD and floating-point VFMAL and VFMSL instructions in AArch32 state.
The value of this field is an IMPLEMENTATION DEFINED choice of:
FHM | Meaning |
---|---|
0b0000 |
VFMAL and VMFSL instructions are not implemented. |
0b0001 |
VFMAL and VMFSL instructions are implemented. |
All other values are reserved.
FEAT_FHM implements the functionality identified by 0b0001.
From Armv8.2, the permitted values are 0b0000 and 0b0001.
Access to this field is RO.
Indicates support for dot product instructions in AArch32 state.
The value of this field is an IMPLEMENTATION DEFINED choice of:
DP | Meaning |
---|---|
0b0000 |
Dot product instructions are not implemented. |
0b0001 |
VUDOT and VSDOT instructions are implemented. |
All other values are reserved.
FEAT_DotProd implements the functionality identified by 0b0001.
In Armv8.2, the permitted values are 0b0000 and 0b0001.
From Armv8.4, the only permitted value is 0b0001.
Access to this field is RO.
Indicates support for the VJCVT instruction in AArch32 state.
The value of this field is an IMPLEMENTATION DEFINED choice of:
JSCVT | Meaning |
---|---|
0b0000 |
The VJCVT instruction is not implemented. |
0b0001 |
The VJCVT instruction is implemented. |
All other values are reserved.
FEAT_JSCVT implements the functionality identified by 0b0001.
In Armv8.0, Armv8.1, and Armv8.2, the only permitted value is 0b0000.
From Armv8.3, if Advanced SIMD or Floating-point is implemented, the only permitted value is 0b0001.
From Armv8.3, if Advanced SIMD or Floating-point is not implemented, the only permitted value is 0b0000.
Access to this field is RO.
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 |
UNKNOWN | |||||||||||||||||||||||||||||||
UNKNOWN |
Reserved, UNKNOWN.
Accesses to this register use the following encodings in the System register encoding space:
MRS <Xt>, ID_ISAR6_EL1
op0 | op1 | CRn | CRm | op2 |
---|---|---|---|---|
0b11 | 0b000 | 0b0000 | 0b0010 | 0b111 |
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() && (IsFeatureImplemented(FEAT_FGT) || !IsZero(ID_ISAR6_EL1) || boolean IMPLEMENTATION_DEFINED "ID_ISAR6_EL1 trapped by HCR_EL2.TID3") && HCR_EL2.TID3 == '1' then AArch64.SystemAccessTrap(EL2, 0x18); else X[t, 64] = ID_ISAR6_EL1; elsif PSTATE.EL == EL2 then X[t, 64] = ID_ISAR6_EL1; elsif PSTATE.EL == EL3 then X[t, 64] = ID_ISAR6_EL1;