The ID_ISAR6 characteristics are:
Provides information about the instruction sets implemented by the PE in AArch32 state.
Must be interpreted with ID_ISAR0, ID_ISAR1, ID_ISAR2, ID_ISAR3, ID_ISAR4 and ID_ISAR5.
For general information about the interpretation of the ID registers see 'Principles of the ID scheme for fields in ID registers' in the Arm® Architecture Reference Manual, Armv8, for Armv8-A architecture profile, section G7.1.3.
AArch32 System register ID_ISAR6 bits [31:0] are architecturally mapped to AArch64 System register ID_ISAR6_EL1[31:0] .
ID_ISAR6 is a 32-bit register.
The ID_ISAR6 bit assignments are:
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 |
0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | SPECRES | SB | FHM | DP | JSCVT |
Reserved, RES0.
Speculation invalidation instruction support in AArch32 state. Defined values are:
SPECRES | Meaning |
---|---|
0b0000 |
CFPRCTX, DVPRCTX, and CPPRCTX instructions are not implemented. |
0b0001 |
CFPRCTX, DVPRCTX, and CPPRCTX instructions are implemented. |
All other values are reserved.
From Armv8.5, the only permitted value is 0b0001.
SB instruction support in AArch32 state. Defined values are:
SB | Meaning |
---|---|
0b0000 |
SB instruction is not implemented. |
0b0001 |
SB instruction is implemented. |
All other values are reserved.
From Armv8.5, the only permitted value is 0b0001.
Indicates whether VFMAL and VFMSL instructions are implemented.
FHM | Meaning |
---|---|
0b0000 |
VFMAL and VMFSL instructions not implemented. |
0b0001 |
VFMAL and VMFSL instructions implemented. |
ARMv8.2-FHM implements the functionality identified by the value 0b0001.
Reserved, RES0.
Indicates the support for dot product instructions in AArch32 state.
DP | Meaning |
---|---|
0b0000 |
No dot product instructions implemented. |
0b0001 |
VUDOT and VSDOT instructions implemented. |
All other values are reserved.
ARMv8.2-DotProd implements the functionality identified by the value 0b0001.
Reserved, RES0.
Indicates whether the Javascript conversion instruction is implemented in AArch32 state. Defined values are:
JSCVT | Meaning |
---|---|
0b0000 |
The VJCVT instruction is not implemented. |
0b0001 |
The VJCVT instruction is implemented. |
All other values are reserved.
In Armv8.0, Armv8.1 and Armv8.2 the only permitted value is 0b0000.
From Armv8.3 the only permitted value is 0b0001. This feature is identified as ARMv8.3.JSConv.
Reserved, RES0.
Accesses to this register use the following encodings:
opc1 | opc2 | CRn | coproc | CRm |
---|---|---|---|---|
0b000 | 0b111 | 0b0000 | 0b1111 | 0b0010 |
if PSTATE.EL == EL0 then UNDEFINED; elsif PSTATE.EL == EL1 then if EL2Enabled() && !ELUsingAArch32(EL2) && HSTR_EL2.T0 == '1' then AArch64.AArch32SystemAccessTrap(EL2, 0x03); elsif EL2Enabled() && ELUsingAArch32(EL2) && HSTR.T0 == '1' then AArch32.TakeHypTrapException(0x03); elsif EL2Enabled() && !ELUsingAArch32(EL2) && HCR_EL2.TID3 == '1' then AArch64.AArch32SystemAccessTrap(EL2, 0x03); elsif EL2Enabled() && ELUsingAArch32(EL2) && HCR.TID3 == '1' then AArch32.TakeHypTrapException(0x03); else return ID_ISAR6; elsif PSTATE.EL == EL2 then return ID_ISAR6; elsif PSTATE.EL == EL3 then return ID_ISAR6;
13/12/2018 16:42; 6379d01c197f1d40720d32d0f84c419c9187c009
Copyright © 2010-2018 Arm Limited or its affiliates. All rights reserved. This document is Non-Confidential.