The ID_AA64MMFR3_EL1 characteristics are:
Provides information about the implemented memory model and memory management support in AArch64 state.
Prior to the introduction of the features described by this register, this register was unnamed and reserved, RES0 from EL1, EL2, and EL3.
ID_AA64MMFR3_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 |
Spec_FPACC | ADERR | SDERR | RES0 | ANERR | SNERR | D128_2 | D128 | ||||||||||||||||||||||||
MEC | AIE | S2POE | S1POE | S2PIE | S1PIE | SCTLRX | TCRX |
Speculative behavior in the event of a PAC authentication failure in an implementation that includes FEAT_FPACCOMBINE.
The value of this field is an IMPLEMENTATION DEFINED choice of:
Spec_FPACC | Meaning |
---|---|
0b0000 |
The implementation does not disclose whether the speculative use of pointers processed by a PAC Authentication is materially different in terms of the impact on cached microarchitectural state between passing and failing of the PAC Authentication. |
0b0001 |
The speculative use of pointers processed by a PAC Authentication is not materially different in terms of the impact on cached microarchitectural state between passing and failing of the PAC Authentication. |
All other values are reserved.
For the purpose of this definition, cached microarchitecture state is the state of caching agents such as instruction caches, data caches and TLBs which can be altered as a result of speculation caused by a mispredicted execution, but is not restored to the state prior to the speculation when the misprediction is corrected.
Access to this field is RO.
Reserved, RES0.
Asynchronous Device error exceptions. With ID_AA64MMFR3_EL1.SDERR, describes the PE behavior for External aborts signaled on Device memory loads.
The value of this field is an IMPLEMENTATION DEFINED choice of:
ADERR | Meaning |
---|---|
0b0000 |
If FEAT_RASv2 is not implemented and ID_AA64MMFR3_EL1.SDERR is 0b0000, then the behavior is not described. Otherwise, the behavior is described by ID_AA64MMFR3_EL1.SDERR. |
0b0001 |
All External aborts on Device memory loads are handled asynchronously. |
0b0010 | FEAT_ADERR is implemented. SCTLR2_ELx.EnADERR and HCRX_EL2.EnSDERR are implemented. If FEAT_ANERR is also implemented, then all the following apply: |
0b0011 | FEAT_ADERR is implemented. SCTLR2_ELx.EnADERR and HCRX_EL2.EnSDERR are implemented. If FEAT_ANERR is also implemented, then SCTLR2_ELx.EnADERR and HCRX_EL2.EnSDERR operate independently of SCTLR2_ELx.EnANERR and HCRX_EL2.EnSNERR. |
All other values are reserved.
Handled asynchronously means that the External abort generates an asynchronous SError exception. If FEAT_SVE is implemented and the access generating the External abort is due to any Active element of an SVE Non-fault vector load instruction or an Active element that is not the first Active element of an SVE First-fault vector load instruction, then the External abort is not reported in the FFR.
It is implementation-specific whether this field applies to memory reads generated by each of the following:
When FEAT_RASv2 is implemented and ID_AA64MMFR3_EL1.SDERR is 0b0000, the value of this field is 0b0001.
When ID_AA64MMFR3_EL1.SDERR is 0b0001, the value of this field is 0b0000.
When ID_AA64MMFR3_EL1.SDERR is 0b0010, the value of this field is 0b0010.
When ID_AA64MMFR3_EL1.SDERR is 0b0011, the value of this field is 0b0011.
FEAT_ADERR implements the functionality described by the value 0b0010.
Access to this field is RO.
Synchronous Device error exceptions. With ID_AA64MMFR3_EL1.ADERR, describes the PE behavior for External aborts signaled on Device memory loads.
The value of this field is an IMPLEMENTATION DEFINED choice of:
SDERR | Meaning |
---|---|
0b0000 |
If FEAT_RASv2 is not implemented and ID_AA64MMFR3_EL1.ADERR is 0b0000, then the behavior is not described. Otherwise, the behavior is described by ID_AA64MMFR3_EL1.ADERR. |
0b0001 |
All External aborts on Device memory loads are handled synchronously. |
0b0010 | FEAT_ADERR is implemented. SCTLR2_ELx.EnADERR and HCRX_EL2.EnSDERR are implemented. If FEAT_ANERR is also implemented, then all the following apply: |
0b0011 | FEAT_ADERR is implemented. SCTLR2_ELx.EnADERR and HCRX_EL2.EnSDERR are implemented. If FEAT_ANERR is also implemented, then SCTLR2_ELx.EnADERR and HCRX_EL2.EnSDERR operate independently of SCTLR2_ELx.EnANERR and HCRX_EL2.EnSNERR. |
All other values are reserved.
Handled synchronously means that, if FEAT_SVE is implemented and the access generating the External abort is due to any Active element of an SVE Non-fault vector load instruction or an Active element that is not the first Active element of an SVE First-fault vector load instruction, then no exception is generated and the External abort is reported in the FFR. Otherwise, the External abort generates a precise synchronous Data Abort exception.
It is implementation-specific whether this field applies to memory reads generated by each of the following:
When FEAT_RASv2 is implemented and ID_AA64MMFR3_EL1.ADERR is 0b0000, the value of this field is 0b0001.
When ID_AA64MMFR3_EL1.ADERR is 0b0001, the value of this field is 0b0000.
When ID_AA64MMFR3_EL1.ADERR is 0b0010, the value of this field is 0b0010.
When ID_AA64MMFR3_EL1.ADERR is 0b0011, the value of this field is 0b0011.
FEAT_ADERR implements the functionality described by the value 0b0010.
Access to this field is RO.
Reserved, RES0.
Asynchronous Normal error exceptions. With ID_AA64MMFR3_EL1.SNERR, describes the PE behavior for External aborts signaled on Normal memory loads.
The value of this field is an IMPLEMENTATION DEFINED choice of:
ANERR | Meaning |
---|---|
0b0000 |
If FEAT_RASv2 is not implemented and ID_AA64MMFR3_EL1.SNERR is 0b0000, then the behavior is not described. Otherwise, the behavior is described by ID_AA64MMFR3_EL1.SNERR. |
0b0001 |
All External aborts on Normal memory loads are handled asynchronously. |
0b0010 | FEAT_ANERR is implemented. SCTLR2_ELx.EnANERR and HCRX_EL2.EnSNERR are implemented. If FEAT_ADERR is also implemented, then all the following apply: |
0b0011 | FEAT_ANERR is implemented. SCTLR2_ELx.EnANERR and HCRX_EL2.EnSNERR are implemented. If FEAT_ADERR is also implemented, then SCTLR2_ELx.EnANERR and HCRX_EL2.EnSNERR operate independently of SCTLR2_ELx.EnADERR and HCRX_EL2.EnSDERR. |
All other values are reserved.
Handled asynchronously means that the External abort generates an asynchronous SError exception. If FEAT_SVE is implemented and the access generating the External abort is due to any Active element of an SVE Non-fault vector load instruction or an Active element that is not the first Active element of an SVE First-fault vector load instruction, then the External abort is not reported in the FFR.
It is implementation-specific whether this field applies to memory reads generated by each of the following:
When FEAT_RASv2 is implemented and ID_AA64MMFR3_EL1.SNERR is 0b0000, the value of this field is 0b0001.
When ID_AA64MMFR3_EL1.SNERR is 0b0001, the value of this field is 0b0000.
When ID_AA64MMFR3_EL1.SNERR is 0b0010, the value of this field is 0b0010.
When ID_AA64MMFR3_EL1.SNERR is 0b0011, the value of this field is 0b0011.
FEAT_ANERR implements the functionality described by the value 0b0010.
Access to this field is RO.
Synchronous Normal error exceptions. With ID_AA64MMFR3_EL1.ANERR, describes the PE behavior for External aborts signaled on Normal memory loads.
The value of this field is an IMPLEMENTATION DEFINED choice of:
SNERR | Meaning |
---|---|
0b0000 |
If FEAT_RASv2 is not implemented and ID_AA64MMFR3_EL1.ANERR is 0b0000, then the behavior is not described. Otherwise, the behavior is described by ID_AA64MMFR3_EL1.ANERR. |
0b0001 |
All External aborts on Normal memory loads are handled synchronously. |
0b0010 | FEAT_ANERR is implemented. SCTLR2_ELx.EnANERR and HCRX_EL2.EnSNERR are implemented. If FEAT_ADERR is also implemented, then all the following apply: |
0b0011 | FEAT_ANERR is implemented. SCTLR2_ELx.EnANERR and HCRX_EL2.EnSNERR are implemented. If FEAT_ADERR is also implemented, then SCTLR2_ELx.EnANERR and HCRX_EL2.EnSNERR operate independently of SCTLR2_ELx.EnADERR and HCRX_EL2.EnSDERR. |
All other values are reserved.
Handled synchronously means that, if FEAT_SVE is implemented and the access generating the External abort is due to any Active element of an SVE Non-fault vector load instruction or an Active element that is not the first Active element of an SVE First-fault vector load instruction, then no exception is generated and the External abort is reported in the FFR. Otherwise, the External abort generates a precise synchronous Data Abort exception.
It is implementation-specific whether this field applies to memory reads generated by each of the following:
When FEAT_RASv2 is implemented and ID_AA64MMFR3_EL1.ANERR is 0b0000, the value of this field is 0b0001.
When ID_AA64MMFR3_EL1.ANERR is 0b0001, the value of this field is 0b0000.
When ID_AA64MMFR3_EL1.ANERR is 0b0010, the value of this field is 0b0010.
When ID_AA64MMFR3_EL1.ANERR is 0b0011, the value of this field is 0b0011.
FEAT_ANERR implements the functionality described by the value 0b0010.
Access to this field is RO.
128-bit translation table descriptor at stage 2. Indicates support for 128-bit translation table descriptor at stage 2.
The value of this field is an IMPLEMENTATION DEFINED choice of:
D128_2 | Meaning |
---|---|
0b0000 |
128-bit translation table descriptor Extension at stage 2 is not supported. |
0b0001 |
128-bit translation table descriptor Extension at stage 2 is supported. |
All other values are reserved.
Access to this field is RO.
128-bit translation table descriptor. Indicates support for 128-bit translation table descriptor.
The value of this field is an IMPLEMENTATION DEFINED choice of:
D128 | Meaning |
---|---|
0b0000 |
128-bit translation table descriptor Extension is not supported. |
0b0001 |
128-bit translation table descriptor Extension is supported. |
All other values are reserved.
Access to this field is RO.
Indicates support for Memory Encryption Contexts.
The value of this field is an IMPLEMENTATION DEFINED choice of:
MEC | Meaning |
---|---|
0b0000 |
Memory Encryption Contexts is not supported. |
0b0001 |
Memory Encryption Contexts is supported, with multiple contexts in the Realm physical address space. |
All other values are reserved.
FEAT_MEC implements the functionality identified by the value 0b0001.
Access to this field is RO.
Attribute Indexing. Indicates support for the Attribute Index Enhancement.
The value of this field is an IMPLEMENTATION DEFINED choice of:
AIE | Meaning |
---|---|
0b0000 |
The Attribute Index Enhancement is not supported. |
0b0001 |
The Attribute Index Enhancement at stage 1 is supported. |
All other values are reserved.
FEAT_AIE implements the functionality identified by the value 0b0001.
Access to this field is RO.
Stage 2 Permission Overlay. Indicates support for Permission Overlay at stage 2.
The value of this field is an IMPLEMENTATION DEFINED choice of:
S2POE | Meaning |
---|---|
0b0000 |
Permission Overlay at stage 2 is not supported. |
0b0001 |
Permission Overlay at stage 2 is supported. |
All other values are reserved.
FEAT_S2POE implements the functionality identified by the value 0b0001.
Access to this field is RO.
Stage 1 Permission Overlay. Indicates support for Permission Overlay at stage 1.
The value of this field is an IMPLEMENTATION DEFINED choice of:
S1POE | Meaning |
---|---|
0b0000 |
Permission Overlay at stage 1 is not supported. |
0b0001 |
Permission Overlay at stage 1 is supported. |
All other values are reserved.
FEAT_S1POE implements the functionality identified by the value 0b0001.
Access to this field is RO.
Stage 2 Permission Indirection. Indicates support for Permission Indirection at stage 2.
The value of this field is an IMPLEMENTATION DEFINED choice of:
S2PIE | Meaning |
---|---|
0b0000 |
Permission Indirection at stage 2 is not supported. |
0b0001 |
Permission Indirection at stage 2 is supported. |
All other values are reserved.
FEAT_S2PIE implements the functionality identified by the value 0b0001.
Access to this field is RO.
Stage 1 Permission Indirection. Indicates support for Permission Indirection at stage 1.
The value of this field is an IMPLEMENTATION DEFINED choice of:
S1PIE | Meaning |
---|---|
0b0000 |
Permission Indirection at stage 1 is not supported. |
0b0001 |
Permission Indirection at stage 1 is supported. |
All other values are reserved.
FEAT_S1PIE implements the functionality identified by the value 0b0001.
Access to this field is RO.
SCTLR Extension. Indicates support for extension of SCTLR_ELx.
The value of this field is an IMPLEMENTATION DEFINED choice of:
SCTLRX | Meaning |
---|---|
0b0000 |
SCTLR2_EL1, SCTLR2_EL2, SCTLR2_EL3 registers, and their associated trap controls are not implemented. |
0b0001 |
SCTLR2_EL1, SCTLR2_EL2, SCTLR2_EL3 resisters, and their associated trap controls are implemented. |
All other values are reserved.
From Armv8.9, the value 0b0000 is not permitted.
Access to this field is RO.
TCR Extension. Indicates support for extension of TCR_ELx.
The value of this field is an IMPLEMENTATION DEFINED choice of:
TCRX | Meaning |
---|---|
0b0000 |
TCR2_EL1, TCR2_EL2, and their associated trap controls are not implemented. |
0b0001 |
TCR2_EL1, TCR2_EL2, and their associated trap controls are implemented. |
All other values are reserved.
From Armv8.9, the value 0b0000 is not permitted.
Access to this field is RO.
Accesses to this register use the following encodings in the System register encoding space:
op0 | op1 | CRn | CRm | op2 |
---|---|---|---|---|
0b11 | 0b000 | 0b0000 | 0b0111 | 0b011 |
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_AA64MMFR3_EL1) || boolean IMPLEMENTATION_DEFINED "ID_AA64MMFR3_EL1 trapped by HCR_EL2.TID3") && HCR_EL2.TID3 == '1' then AArch64.SystemAccessTrap(EL2, 0x18); else X[t, 64] = ID_AA64MMFR3_EL1; elsif PSTATE.EL == EL2 then X[t, 64] = ID_AA64MMFR3_EL1; elsif PSTATE.EL == EL3 then X[t, 64] = ID_AA64MMFR3_EL1;
26/03/2024 09:49; 67c0ae5282a7629ba0ea0ba7267b43cd4f7939f6
Copyright © 2010-2024 Arm Limited or its affiliates. All rights reserved. This document is Non-Confidential.