HFGITR_EL2, Hypervisor Fine-Grained Instruction Trap Register
The HFGITR_EL2 characteristics are:
Purpose
Provides instruction trap controls.
Configuration
This register is present only when FEAT_FGT is implemented. Otherwise, direct accesses to HFGITR_EL2 are UNDEFINED.
Attributes
HFGITR_EL2 is a 64-bit register.
Field descriptions
The HFGITR_EL2 bit assignments are:
Bits [63:57]
Reserved, RES0.
nBRBIALL, bit [56]
When FEAT_BRBE is implemented:
When FEAT_BRBE is implemented:
Trap execution of BRB IALL at EL1 using AArch64 to EL2.
nBRBIALL | Meaning |
---|---|
0b0 |
If EL2 is implemented and enabled in the current Security state then execution of BRB IALL at EL1 using AArch64 is trapped to EL2 and reported with EC syndrome value 0x18, unless the instruction generates a higher priority exception. |
0b1 |
Execution of BRB IALL is not affected by this bit. |
This bit is ignored by the PE and treated as zero when EL3 is implemented and SCR_EL3.FGTEn == 0b0.
On a Warm reset, in a system where the PE resets into EL2, this field resets to 0.
Otherwise:
Otherwise:
Reserved, RES0.
nBRBINJ, bit [55]
When FEAT_BRBE is implemented:
When FEAT_BRBE is implemented:
Trap execution of BRB INJ at EL1 using AArch64 to EL2.
nBRBINJ | Meaning |
---|---|
0b0 |
If EL2 is implemented and enabled in the current Security state then execution of BRB INJ at EL1 using AArch64 is trapped to EL2 and reported with EC syndrome value 0x18, unless the instruction generates a higher priority exception. |
0b1 |
Execution of BRB INJ is not affected by this bit. |
This bit is ignored by the PE and treated as zero when EL3 is implemented and SCR_EL3.FGTEn == 0b0.
On a Warm reset, in a system where the PE resets into EL2, this field resets to 0.
Otherwise:
Otherwise:
Reserved, RES0.
DCCVAC, bit [54]
Trap execution of multiple instructions. Enables a trap on execution at EL1 and EL0 using AArch64 of any of the following AArch64 instructions to EL2:
DCCVAC | Meaning |
---|---|
0b0 |
Execution of the instructions listed above is not affected by this bit. |
0b1 |
If EL2 is implemented and enabled in the current Security state, HCR_EL2.{E2H,TGE} != {1,1}, and either EL3 is not implemented or SCR_EL3.FGTEn == 0b1, then execution at EL1 and EL0 using AArch64 of any of the instructions listed above is trapped to EL2 and reported with EC syndrome value 0x18, unless the instruction generates a higher priority exception. |
On a Warm reset, in a system where the PE resets into EL2, this field resets to 0.
SVC_EL1, bit [53]
Trap execution of SVC at EL1 using AArch64 to EL2.
SVC_EL1 | Meaning |
---|---|
0b0 |
Execution of SVC is not affected by this bit. |
0b1 |
If EL2 is implemented and enabled in the current Security state and either EL3 is not implemented or SCR_EL3.FGTEn == 0b1, then execution of SVC at EL1 using AArch64 is trapped to EL2 and reported with EC syndrome value 0x15, unless the instruction generates a higher priority exception. |
On a Warm reset, in a system where the PE resets into EL2, this field resets to 0.
SVC_EL0, bit [52]
Trap execution of SVC at EL0 using AArch64 and execution of SVC at EL0 using AArch32 when EL1 is using AArch64 to EL2.
SVC_EL0 | Meaning |
---|---|
0b0 |
Execution of SVC at EL0 using AArch64 and execution of SVC at EL0 using AArch32 is not affected by this bit. |
0b1 | If EL2 is implemented and enabled in the current Security state, HCR_EL2.{E2H,TGE} != {1,1}, EL1 is using AArch64, and either EL3 is not implemented or SCR_EL3.FGTEn == 0b1, then, unless the instruction generates a higher priority exception:
|
On a Warm reset, in a system where the PE resets into EL2, this field resets to 0.
ERET, bit [51]
Trap execution of multiple instructions. Enables a trap on execution at EL1 using AArch64 of any of the following AArch64 instructions to EL2:
- ERET.
- ERETAA, if FEAT_PAuth is implemented.
- ERETAB, if FEAT_PAuth is implemented.
ERET | Meaning |
---|---|
0b0 |
Execution of the instructions listed above is not affected by this bit. |
0b1 |
If EL2 is implemented and enabled in the current Security state and either EL3 is not implemented or SCR_EL3.FGTEn == 0b1, then execution at EL1 using AArch64 of any of the instructions listed above is trapped to EL2 and reported with EC syndrome value 0x1A, unless the instruction generates a higher priority exception. |
If EL2 is implemented and enabled in the current Security state, HCR_EL2.API == 0b0, and this bit enables a fine-grained trap on the instruction, then execution at EL1 using AArch64 of ERETAA or ERETAB instructions is trapped to EL2 and reported with EC syndrome value 0x1A with its associated ISS field, as the fine-grained trap has higher priority than the trap enabled by HCR_EL2.API == 0.
On a Warm reset, in a system where the PE resets into EL2, this field resets to 0.
CPPRCTX, bit [50]
When FEAT_SPECRES is implemented:
When FEAT_SPECRES is implemented:
Trap execution of CPP RCTX at EL1 and EL0 using AArch64 and execution of CPPRCTX at EL0 using AArch32 when EL1 is using AArch64 to EL2.
CPPRCTX | Meaning |
---|---|
0b0 |
Execution of CPP RCTX at EL1 and EL0 using AArch64 and execution of CPPRCTX at EL0 using AArch32 is not affected by this bit. |
0b1 | If EL2 is implemented and enabled in the current Security state, HCR_EL2.{E2H,TGE} != {1,1}, EL1 is using AArch64, and either EL3 is not implemented or SCR_EL3.FGTEn == 0b1, then, unless the instruction generates a higher priority exception: |
On a Warm reset, in a system where the PE resets into EL2, this field resets to 0.
Otherwise:
Otherwise:
Reserved, RES0.
DVPRCTX, bit [49]
When FEAT_SPECRES is implemented:
When FEAT_SPECRES is implemented:
Trap execution of DVP RCTX at EL1 and EL0 using AArch64 and execution of DVPRCTX at EL0 using AArch32 when EL1 is using AArch64 to EL2.
DVPRCTX | Meaning |
---|---|
0b0 |
Execution of DVP RCTX at EL1 and EL0 using AArch64 and execution of DVPRCTX at EL0 using AArch32 is not affected by this bit. |
0b1 | If EL2 is implemented and enabled in the current Security state, HCR_EL2.{E2H,TGE} != {1,1}, EL1 is using AArch64, and either EL3 is not implemented or SCR_EL3.FGTEn == 0b1, then, unless the instruction generates a higher priority exception: |
On a Warm reset, in a system where the PE resets into EL2, this field resets to 0.
Otherwise:
Otherwise:
Reserved, RES0.
CFPRCTX, bit [48]
When FEAT_SPECRES is implemented:
When FEAT_SPECRES is implemented:
Trap execution of CFP RCTX at EL1 and EL0 using AArch64 and execution of CFPRCTX at EL0 using AArch32 when EL1 is using AArch64 to EL2.
CFPRCTX | Meaning |
---|---|
0b0 |
Execution of CFP RCTX at EL1 and EL0 using AArch64 and execution of CFPRCTX at EL0 using AArch32 is not affected by this bit. |
0b1 | If EL2 is implemented and enabled in the current Security state, HCR_EL2.{E2H,TGE} != {1,1}, EL1 is using AArch64, and either EL3 is not implemented or SCR_EL3.FGTEn == 0b1, then, unless the instruction generates a higher priority exception: |
On a Warm reset, in a system where the PE resets into EL2, this field resets to 0.
Otherwise:
Otherwise:
Reserved, RES0.
TLBIVAALE1, bit [47]
Trap execution of TLBI VAALE1 at EL1 using AArch64 to EL2.
If FEAT_XS is implemented and HCRX_EL2.FGTnXS == 0b0, this field also traps execution of TLBI VAALE1NXS.
TLBIVAALE1 | Meaning |
---|---|
0b0 |
Execution of TLBI VAALE1 is not affected by this bit. |
0b1 |
If EL2 is implemented and enabled in the current Security state and either EL3 is not implemented or SCR_EL3.FGTEn == 0b1, then execution of TLBI VAALE1 at EL1 using AArch64 is trapped to EL2 and reported with EC syndrome value 0x18, unless the instruction generates a higher priority exception. |
On a Warm reset, in a system where the PE resets into EL2, this field resets to 0.
TLBIVALE1, bit [46]
Trap execution of TLBI VALE1 at EL1 using AArch64 to EL2.
If FEAT_XS is implemented and HCRX_EL2.FGTnXS == 0b0, this field also traps execution of TLBI VALE1NXS.
TLBIVALE1 | Meaning |
---|---|
0b0 |
Execution of TLBI VALE1 is not affected by this bit. |
0b1 |
If EL2 is implemented and enabled in the current Security state and either EL3 is not implemented or SCR_EL3.FGTEn == 0b1, then execution of TLBI VALE1 at EL1 using AArch64 is trapped to EL2 and reported with EC syndrome value 0x18, unless the instruction generates a higher priority exception. |
On a Warm reset, in a system where the PE resets into EL2, this field resets to 0.
TLBIVAAE1, bit [45]
Trap execution of TLBI VAAE1 at EL1 using AArch64 to EL2.
If FEAT_XS is implemented and HCRX_EL2.FGTnXS == 0b0, this field also traps execution of TLBI VAAE1NXS.
TLBIVAAE1 | Meaning |
---|---|
0b0 |
Execution of TLBI VAAE1 is not affected by this bit. |
0b1 |
If EL2 is implemented and enabled in the current Security state and either EL3 is not implemented or SCR_EL3.FGTEn == 0b1, then execution of TLBI VAAE1 at EL1 using AArch64 is trapped to EL2 and reported with EC syndrome value 0x18, unless the instruction generates a higher priority exception. |
On a Warm reset, in a system where the PE resets into EL2, this field resets to 0.
TLBIASIDE1, bit [44]
Trap execution of TLBI ASIDE1 at EL1 using AArch64 to EL2.
If FEAT_XS is implemented and HCRX_EL2.FGTnXS == 0b0, this field also traps execution of TLBI ASIDE1NXS.
TLBIASIDE1 | Meaning |
---|---|
0b0 |
Execution of TLBI ASIDE1 is not affected by this bit. |
0b1 |
If EL2 is implemented and enabled in the current Security state and either EL3 is not implemented or SCR_EL3.FGTEn == 0b1, then execution of TLBI ASIDE1 at EL1 using AArch64 is trapped to EL2 and reported with EC syndrome value 0x18, unless the instruction generates a higher priority exception. |
On a Warm reset, in a system where the PE resets into EL2, this field resets to 0.
TLBIVAE1, bit [43]
Trap execution of TLBI VAE1 at EL1 using AArch64 to EL2.
If FEAT_XS is implemented and HCRX_EL2.FGTnXS == 0b0, this field also traps execution of TLBI VAE1NXS.
TLBIVAE1 | Meaning |
---|---|
0b0 |
Execution of TLBI VAE1 is not affected by this bit. |
0b1 |
If EL2 is implemented and enabled in the current Security state and either EL3 is not implemented or SCR_EL3.FGTEn == 0b1, then execution of TLBI VAE1 at EL1 using AArch64 is trapped to EL2 and reported with EC syndrome value 0x18, unless the instruction generates a higher priority exception. |
On a Warm reset, in a system where the PE resets into EL2, this field resets to 0.
TLBIVMALLE1, bit [42]
Trap execution of TLBI VMALLE1 at EL1 using AArch64 to EL2.
If FEAT_XS is implemented and HCRX_EL2.FGTnXS == 0b0, this field also traps execution of TLBI VMALLE1NXS.
TLBIVMALLE1 | Meaning |
---|---|
0b0 |
Execution of TLBI VMALLE1 is not affected by this bit. |
0b1 |
If EL2 is implemented and enabled in the current Security state and either EL3 is not implemented or SCR_EL3.FGTEn == 0b1, then execution of TLBI VMALLE1 at EL1 using AArch64 is trapped to EL2 and reported with EC syndrome value 0x18, unless the instruction generates a higher priority exception. |
On a Warm reset, in a system where the PE resets into EL2, this field resets to 0.
TLBIRVAALE1, bit [41]
When FEAT_TLBIRANGE is implemented:
When FEAT_TLBIRANGE is implemented:
Trap execution of TLBI RVAALE1 at EL1 using AArch64 to EL2.
If FEAT_XS is implemented and HCRX_EL2.FGTnXS == 0b0, this field also traps execution of TLBI RVAALE1NXS.
TLBIRVAALE1 | Meaning |
---|---|
0b0 |
Execution of TLBI RVAALE1 is not affected by this bit. |
0b1 |
If EL2 is implemented and enabled in the current Security state and either EL3 is not implemented or SCR_EL3.FGTEn == 0b1, then execution of TLBI RVAALE1 at EL1 using AArch64 is trapped to EL2 and reported with EC syndrome value 0x18, unless the instruction generates a higher priority exception. |
On a Warm reset, in a system where the PE resets into EL2, this field resets to 0.
Otherwise:
Otherwise:
Reserved, RES0.
TLBIRVALE1, bit [40]
When FEAT_TLBIRANGE is implemented:
When FEAT_TLBIRANGE is implemented:
Trap execution of TLBI RVALE1 at EL1 using AArch64 to EL2.
If FEAT_XS is implemented and HCRX_EL2.FGTnXS == 0b0, this field also traps execution of TLBI RVALE1NXS.
TLBIRVALE1 | Meaning |
---|---|
0b0 |
Execution of TLBI RVALE1 is not affected by this bit. |
0b1 |
If EL2 is implemented and enabled in the current Security state and either EL3 is not implemented or SCR_EL3.FGTEn == 0b1, then execution of TLBI RVALE1 at EL1 using AArch64 is trapped to EL2 and reported with EC syndrome value 0x18, unless the instruction generates a higher priority exception. |
On a Warm reset, in a system where the PE resets into EL2, this field resets to 0.
Otherwise:
Otherwise:
Reserved, RES0.
TLBIRVAAE1, bit [39]
When FEAT_TLBIRANGE is implemented:
When FEAT_TLBIRANGE is implemented:
Trap execution of TLBI RVAAE1 at EL1 using AArch64 to EL2.
If FEAT_XS is implemented and HCRX_EL2.FGTnXS == 0b0, this field also traps execution of TLBI RVAAE1NXS.
TLBIRVAAE1 | Meaning |
---|---|
0b0 |
Execution of TLBI RVAAE1 is not affected by this bit. |
0b1 |
If EL2 is implemented and enabled in the current Security state and either EL3 is not implemented or SCR_EL3.FGTEn == 0b1, then execution of TLBI RVAAE1 at EL1 using AArch64 is trapped to EL2 and reported with EC syndrome value 0x18, unless the instruction generates a higher priority exception. |
On a Warm reset, in a system where the PE resets into EL2, this field resets to 0.
Otherwise:
Otherwise:
Reserved, RES0.
TLBIRVAE1, bit [38]
When FEAT_TLBIRANGE is implemented:
When FEAT_TLBIRANGE is implemented:
Trap execution of TLBI RVAE1 at EL1 using AArch64 to EL2.
If FEAT_XS is implemented and HCRX_EL2.FGTnXS == 0b0, this field also traps execution of TLBI RVAE1NXS.
TLBIRVAE1 | Meaning |
---|---|
0b0 |
Execution of TLBI RVAE1 is not affected by this bit. |
0b1 |
If EL2 is implemented and enabled in the current Security state and either EL3 is not implemented or SCR_EL3.FGTEn == 0b1, then execution of TLBI RVAE1 at EL1 using AArch64 is trapped to EL2 and reported with EC syndrome value 0x18, unless the instruction generates a higher priority exception. |
On a Warm reset, in a system where the PE resets into EL2, this field resets to 0.
Otherwise:
Otherwise:
Reserved, RES0.
TLBIRVAALE1IS, bit [37]
When FEAT_TLBIRANGE is implemented:
When FEAT_TLBIRANGE is implemented:
Trap execution of TLBI RVAALE1IS at EL1 using AArch64 to EL2.
If FEAT_XS is implemented and HCRX_EL2.FGTnXS == 0b0, this field also traps execution of TLBI RVAALE1ISNXS.
TLBIRVAALE1IS | Meaning |
---|---|
0b0 |
Execution of TLBI RVAALE1IS is not affected by this bit. |
0b1 |
If EL2 is implemented and enabled in the current Security state and either EL3 is not implemented or SCR_EL3.FGTEn == 0b1, then execution of TLBI RVAALE1IS at EL1 using AArch64 is trapped to EL2 and reported with EC syndrome value 0x18, unless the instruction generates a higher priority exception. |
On a Warm reset, in a system where the PE resets into EL2, this field resets to 0.
Otherwise:
Otherwise:
Reserved, RES0.
TLBIRVALE1IS, bit [36]
When FEAT_TLBIRANGE is implemented:
When FEAT_TLBIRANGE is implemented:
Trap execution of TLBI RVALE1IS at EL1 using AArch64 to EL2.
If FEAT_XS is implemented and HCRX_EL2.FGTnXS == 0b0, this field also traps execution of TLBI RVALE1ISNXS.
TLBIRVALE1IS | Meaning |
---|---|
0b0 |
Execution of TLBI RVALE1IS is not affected by this bit. |
0b1 |
If EL2 is implemented and enabled in the current Security state and either EL3 is not implemented or SCR_EL3.FGTEn == 0b1, then execution of TLBI RVALE1IS at EL1 using AArch64 is trapped to EL2 and reported with EC syndrome value 0x18, unless the instruction generates a higher priority exception. |
On a Warm reset, in a system where the PE resets into EL2, this field resets to 0.
Otherwise:
Otherwise:
Reserved, RES0.
TLBIRVAAE1IS, bit [35]
When FEAT_TLBIRANGE is implemented:
When FEAT_TLBIRANGE is implemented:
Trap execution of TLBI RVAAE1IS at EL1 using AArch64 to EL2.
If FEAT_XS is implemented and HCRX_EL2.FGTnXS == 0b0, this field also traps execution of TLBI RVAAE1ISNXS.
TLBIRVAAE1IS | Meaning |
---|---|
0b0 |
Execution of TLBI RVAAE1IS is not affected by this bit. |
0b1 |
If EL2 is implemented and enabled in the current Security state and either EL3 is not implemented or SCR_EL3.FGTEn == 0b1, then execution of TLBI RVAAE1IS at EL1 using AArch64 is trapped to EL2 and reported with EC syndrome value 0x18, unless the instruction generates a higher priority exception. |
On a Warm reset, in a system where the PE resets into EL2, this field resets to 0.
Otherwise:
Otherwise:
Reserved, RES0.
TLBIRVAE1IS, bit [34]
When FEAT_TLBIRANGE is implemented:
When FEAT_TLBIRANGE is implemented:
Trap execution of TLBI RVAE1IS at EL1 using AArch64 to EL2.
If FEAT_XS is implemented and HCRX_EL2.FGTnXS == 0b0, this field also traps execution of TLBI RVAE1ISNXS.
TLBIRVAE1IS | Meaning |
---|---|
0b0 |
Execution of TLBI RVAE1IS is not affected by this bit. |
0b1 |
If EL2 is implemented and enabled in the current Security state and either EL3 is not implemented or SCR_EL3.FGTEn == 0b1, then execution of TLBI RVAE1IS at EL1 using AArch64 is trapped to EL2 and reported with EC syndrome value 0x18, unless the instruction generates a higher priority exception. |
On a Warm reset, in a system where the PE resets into EL2, this field resets to 0.
Otherwise:
Otherwise:
Reserved, RES0.
TLBIVAALE1IS, bit [33]
Trap execution of TLBI VAALE1IS at EL1 using AArch64 to EL2.
If FEAT_XS is implemented and HCRX_EL2.FGTnXS == 0b0, this field also traps execution of TLBI VAALE1ISNXS.
TLBIVAALE1IS | Meaning |
---|---|
0b0 |
Execution of TLBI VAALE1IS is not affected by this bit. |
0b1 |
If EL2 is implemented and enabled in the current Security state and either EL3 is not implemented or SCR_EL3.FGTEn == 0b1, then execution of TLBI VAALE1IS at EL1 using AArch64 is trapped to EL2 and reported with EC syndrome value 0x18, unless the instruction generates a higher priority exception. |
On a Warm reset, in a system where the PE resets into EL2, this field resets to 0.
TLBIVALE1IS, bit [32]
Trap execution of TLBI VALE1IS at EL1 using AArch64 to EL2.
If FEAT_XS is implemented and HCRX_EL2.FGTnXS == 0b0, this field also traps execution of TLBI VALE1ISNXS.
TLBIVALE1IS | Meaning |
---|---|
0b0 |
Execution of TLBI VALE1IS is not affected by this bit. |
0b1 |
If EL2 is implemented and enabled in the current Security state and either EL3 is not implemented or SCR_EL3.FGTEn == 0b1, then execution of TLBI VALE1IS at EL1 using AArch64 is trapped to EL2 and reported with EC syndrome value 0x18, unless the instruction generates a higher priority exception. |
On a Warm reset, in a system where the PE resets into EL2, this field resets to 0.
TLBIVAAE1IS, bit [31]
Trap execution of TLBI VAAE1IS at EL1 using AArch64 to EL2.
If FEAT_XS is implemented and HCRX_EL2.FGTnXS == 0b0, this field also traps execution of TLBI VAAE1ISNXS.
TLBIVAAE1IS | Meaning |
---|---|
0b0 |
Execution of TLBI VAAE1IS is not affected by this bit. |
0b1 |
If EL2 is implemented and enabled in the current Security state and either EL3 is not implemented or SCR_EL3.FGTEn == 0b1, then execution of TLBI VAAE1IS at EL1 using AArch64 is trapped to EL2 and reported with EC syndrome value 0x18, unless the instruction generates a higher priority exception. |
On a Warm reset, in a system where the PE resets into EL2, this field resets to 0.
TLBIASIDE1IS, bit [30]
Trap execution of TLBI ASIDE1IS at EL1 using AArch64 to EL2.
If FEAT_XS is implemented and HCRX_EL2.FGTnXS == 0b0, this field also traps execution of TLBI ASIDE1ISNXS.
TLBIASIDE1IS | Meaning |
---|---|
0b0 |
Execution of TLBI ASIDE1IS is not affected by this bit. |
0b1 |
If EL2 is implemented and enabled in the current Security state and either EL3 is not implemented or SCR_EL3.FGTEn == 0b1, then execution of TLBI ASIDE1IS at EL1 using AArch64 is trapped to EL2 and reported with EC syndrome value 0x18, unless the instruction generates a higher priority exception. |
On a Warm reset, in a system where the PE resets into EL2, this field resets to 0.
TLBIVAE1IS, bit [29]
Trap execution of TLBI VAE1IS at EL1 using AArch64 to EL2.
If FEAT_XS is implemented and HCRX_EL2.FGTnXS == 0b0, this field also traps execution of TLBI VAE1ISNXS.
TLBIVAE1IS | Meaning |
---|---|
0b0 |
Execution of TLBI VAE1IS is not affected by this bit. |
0b1 |
If EL2 is implemented and enabled in the current Security state and either EL3 is not implemented or SCR_EL3.FGTEn == 0b1, then execution of TLBI VAE1IS at EL1 using AArch64 is trapped to EL2 and reported with EC syndrome value 0x18, unless the instruction generates a higher priority exception. |
On a Warm reset, in a system where the PE resets into EL2, this field resets to 0.
TLBIVMALLE1IS, bit [28]
Trap execution of TLBI VMALLE1IS at EL1 using AArch64 to EL2.
If FEAT_XS is implemented and HCRX_EL2.FGTnXS == 0b0, this field also traps execution of TLBI VMALLE1ISNXS.
TLBIVMALLE1IS | Meaning |
---|---|
0b0 |
Execution of TLBI VMALLE1IS is not affected by this bit. |
0b1 |
If EL2 is implemented and enabled in the current Security state and either EL3 is not implemented or SCR_EL3.FGTEn == 0b1, then execution of TLBI VMALLE1IS at EL1 using AArch64 is trapped to EL2 and reported with EC syndrome value 0x18, unless the instruction generates a higher priority exception. |
On a Warm reset, in a system where the PE resets into EL2, this field resets to 0.
TLBIRVAALE1OS, bit [27]
When FEAT_TLBIRANGE is implemented and FEAT_TLBIOS is implemented:
When FEAT_TLBIRANGE is implemented and FEAT_TLBIOS is implemented:
Trap execution of TLBI RVAALE1OS at EL1 using AArch64 to EL2.
If FEAT_XS is implemented and HCRX_EL2.FGTnXS == 0b0, this field also traps execution of TLBI RVAALE1OSNXS.
TLBIRVAALE1OS | Meaning |
---|---|
0b0 |
Execution of TLBI RVAALE1OS is not affected by this bit. |
0b1 |
If EL2 is implemented and enabled in the current Security state and either EL3 is not implemented or SCR_EL3.FGTEn == 0b1, then execution of TLBI RVAALE1OS at EL1 using AArch64 is trapped to EL2 and reported with EC syndrome value 0x18, unless the instruction generates a higher priority exception. |
On a Warm reset, in a system where the PE resets into EL2, this field resets to 0.
Otherwise:
Otherwise:
Reserved, RES0.
TLBIRVALE1OS, bit [26]
When FEAT_TLBIRANGE is implemented and FEAT_TLBIOS is implemented:
When FEAT_TLBIRANGE is implemented and FEAT_TLBIOS is implemented:
Trap execution of TLBI RVALE1OS at EL1 using AArch64 to EL2.
If FEAT_XS is implemented and HCRX_EL2.FGTnXS == 0b0, this field also traps execution of TLBI RVALE1OSNXS.
TLBIRVALE1OS | Meaning |
---|---|
0b0 |
Execution of TLBI RVALE1OS is not affected by this bit. |
0b1 |
If EL2 is implemented and enabled in the current Security state and either EL3 is not implemented or SCR_EL3.FGTEn == 0b1, then execution of TLBI RVALE1OS at EL1 using AArch64 is trapped to EL2 and reported with EC syndrome value 0x18, unless the instruction generates a higher priority exception. |
On a Warm reset, in a system where the PE resets into EL2, this field resets to 0.
Otherwise:
Otherwise:
Reserved, RES0.
TLBIRVAAE1OS, bit [25]
When FEAT_TLBIRANGE is implemented and FEAT_TLBIOS is implemented:
When FEAT_TLBIRANGE is implemented and FEAT_TLBIOS is implemented:
Trap execution of TLBI RVAAE1OS at EL1 using AArch64 to EL2.
If FEAT_XS is implemented and HCRX_EL2.FGTnXS == 0b0, this field also traps execution of TLBI RVAAE1OSNXS.
TLBIRVAAE1OS | Meaning |
---|---|
0b0 |
Execution of TLBI RVAAE1OS is not affected by this bit. |
0b1 |
If EL2 is implemented and enabled in the current Security state and either EL3 is not implemented or SCR_EL3.FGTEn == 0b1, then execution of TLBI RVAAE1OS at EL1 using AArch64 is trapped to EL2 and reported with EC syndrome value 0x18, unless the instruction generates a higher priority exception. |
On a Warm reset, in a system where the PE resets into EL2, this field resets to 0.
Otherwise:
Otherwise:
Reserved, RES0.
TLBIRVAE1OS, bit [24]
When FEAT_TLBIRANGE is implemented and FEAT_TLBIOS is implemented:
When FEAT_TLBIRANGE is implemented and FEAT_TLBIOS is implemented:
Trap execution of TLBI RVAE1OS at EL1 using AArch64 to EL2.
If FEAT_XS is implemented and HCRX_EL2.FGTnXS == 0b0, this field also traps execution of TLBI RVAE1OSNXS.
TLBIRVAE1OS | Meaning |
---|---|
0b0 |
Execution of TLBI RVAE1OS is not affected by this bit. |
0b1 |
If EL2 is implemented and enabled in the current Security state and either EL3 is not implemented or SCR_EL3.FGTEn == 0b1, then execution of TLBI RVAE1OS at EL1 using AArch64 is trapped to EL2 and reported with EC syndrome value 0x18, unless the instruction generates a higher priority exception. |
On a Warm reset, in a system where the PE resets into EL2, this field resets to 0.
Otherwise:
Otherwise:
Reserved, RES0.
TLBIVAALE1OS, bit [23]
When FEAT_TLBIOS is implemented:
When FEAT_TLBIOS is implemented:
Trap execution of TLBI VAALE1OS at EL1 using AArch64 to EL2.
If FEAT_XS is implemented and HCRX_EL2.FGTnXS == 0b0, this field also traps execution of TLBI VAALE1OSNXS.
TLBIVAALE1OS | Meaning |
---|---|
0b0 |
Execution of TLBI VAALE1OS is not affected by this bit. |
0b1 |
If EL2 is implemented and enabled in the current Security state and either EL3 is not implemented or SCR_EL3.FGTEn == 0b1, then execution of TLBI VAALE1OS at EL1 using AArch64 is trapped to EL2 and reported with EC syndrome value 0x18, unless the instruction generates a higher priority exception. |
On a Warm reset, in a system where the PE resets into EL2, this field resets to 0.
Otherwise:
Otherwise:
Reserved, RES0.
TLBIVALE1OS, bit [22]
When FEAT_TLBIOS is implemented:
When FEAT_TLBIOS is implemented:
Trap execution of TLBI VALE1OS at EL1 using AArch64 to EL2.
If FEAT_XS is implemented and HCRX_EL2.FGTnXS == 0b0, this field also traps execution of TLBI VALE1OSNXS.
TLBIVALE1OS | Meaning |
---|---|
0b0 |
Execution of TLBI VALE1OS is not affected by this bit. |
0b1 |
If EL2 is implemented and enabled in the current Security state and either EL3 is not implemented or SCR_EL3.FGTEn == 0b1, then execution of TLBI VALE1OS at EL1 using AArch64 is trapped to EL2 and reported with EC syndrome value 0x18, unless the instruction generates a higher priority exception. |
On a Warm reset, in a system where the PE resets into EL2, this field resets to 0.
Otherwise:
Otherwise:
Reserved, RES0.
TLBIVAAE1OS, bit [21]
When FEAT_TLBIOS is implemented:
When FEAT_TLBIOS is implemented:
Trap execution of TLBI VAAE1OS at EL1 using AArch64 to EL2.
If FEAT_XS is implemented and HCRX_EL2.FGTnXS == 0b0, this field also traps execution of TLBI VAAE1OSNXS.
TLBIVAAE1OS | Meaning |
---|---|
0b0 |
Execution of TLBI VAAE1OS is not affected by this bit. |
0b1 |
If EL2 is implemented and enabled in the current Security state and either EL3 is not implemented or SCR_EL3.FGTEn == 0b1, then execution of TLBI VAAE1OS at EL1 using AArch64 is trapped to EL2 and reported with EC syndrome value 0x18, unless the instruction generates a higher priority exception. |
On a Warm reset, in a system where the PE resets into EL2, this field resets to 0.
Otherwise:
Otherwise:
Reserved, RES0.
TLBIASIDE1OS, bit [20]
When FEAT_TLBIOS is implemented:
When FEAT_TLBIOS is implemented:
Trap execution of TLBI ASIDE1OS at EL1 using AArch64 to EL2.
If FEAT_XS is implemented and HCRX_EL2.FGTnXS == 0b0, this field also traps execution of TLBI ASIDE1OSNXS.
TLBIASIDE1OS | Meaning |
---|---|
0b0 |
Execution of TLBI ASIDE1OS is not affected by this bit. |
0b1 |
If EL2 is implemented and enabled in the current Security state and either EL3 is not implemented or SCR_EL3.FGTEn == 0b1, then execution of TLBI ASIDE1OS at EL1 using AArch64 is trapped to EL2 and reported with EC syndrome value 0x18, unless the instruction generates a higher priority exception. |
On a Warm reset, in a system where the PE resets into EL2, this field resets to 0.
Otherwise:
Otherwise:
Reserved, RES0.
TLBIVAE1OS, bit [19]
When FEAT_TLBIOS is implemented:
When FEAT_TLBIOS is implemented:
Trap execution of TLBI VAE1OS at EL1 using AArch64 to EL2.
If FEAT_XS is implemented and HCRX_EL2.FGTnXS == 0b0, this field also traps execution of TLBI VAE1OSNXS.
TLBIVAE1OS | Meaning |
---|---|
0b0 |
Execution of TLBI VAE1OS is not affected by this bit. |
0b1 |
If EL2 is implemented and enabled in the current Security state and either EL3 is not implemented or SCR_EL3.FGTEn == 0b1, then execution of TLBI VAE1OS at EL1 using AArch64 is trapped to EL2 and reported with EC syndrome value 0x18, unless the instruction generates a higher priority exception. |
On a Warm reset, in a system where the PE resets into EL2, this field resets to 0.
Otherwise:
Otherwise:
Reserved, RES0.
TLBIVMALLE1OS, bit [18]
When FEAT_TLBIOS is implemented:
When FEAT_TLBIOS is implemented:
Trap execution of TLBI VMALLE1OS at EL1 using AArch64 to EL2.
If FEAT_XS is implemented and HCRX_EL2.FGTnXS == 0b0, this field also traps execution of TLBI VMALLE1OSNXS.
TLBIVMALLE1OS | Meaning |
---|---|
0b0 |
Execution of TLBI VMALLE1OS is not affected by this bit. |
0b1 |
If EL2 is implemented and enabled in the current Security state and either EL3 is not implemented or SCR_EL3.FGTEn == 0b1, then execution of TLBI VMALLE1OS at EL1 using AArch64 is trapped to EL2 and reported with EC syndrome value 0x18, unless the instruction generates a higher priority exception. |
On a Warm reset, in a system where the PE resets into EL2, this field resets to 0.
Otherwise:
Otherwise:
Reserved, RES0.
ATS1E1WP, bit [17]
When FEAT_PAN2 is implemented:
When FEAT_PAN2 is implemented:
Trap execution of AT S1E1WP at EL1 using AArch64 to EL2.
ATS1E1WP | Meaning |
---|---|
0b0 |
Execution of AT S1E1WP is not affected by this bit. |
0b1 |
If EL2 is implemented and enabled in the current Security state and either EL3 is not implemented or SCR_EL3.FGTEn == 0b1, then execution of AT S1E1WP at EL1 using AArch64 is trapped to EL2 and reported with EC syndrome value 0x18, unless the instruction generates a higher priority exception. |
On a Warm reset, in a system where the PE resets into EL2, this field resets to 0.
Otherwise:
Otherwise:
Reserved, RES0.
ATS1E1RP, bit [16]
When FEAT_PAN2 is implemented:
When FEAT_PAN2 is implemented:
Trap execution of AT S1E1RP at EL1 using AArch64 to EL2.
ATS1E1RP | Meaning |
---|---|
0b0 |
Execution of AT S1E1RP is not affected by this bit. |
0b1 |
If EL2 is implemented and enabled in the current Security state and either EL3 is not implemented or SCR_EL3.FGTEn == 0b1, then execution of AT S1E1RP at EL1 using AArch64 is trapped to EL2 and reported with EC syndrome value 0x18, unless the instruction generates a higher priority exception. |
On a Warm reset, in a system where the PE resets into EL2, this field resets to 0.
Otherwise:
Otherwise:
Reserved, RES0.
ATS1E0W, bit [15]
Trap execution of AT S1E0W at EL1 using AArch64 to EL2.
ATS1E0W | Meaning |
---|---|
0b0 |
Execution of AT S1E0W is not affected by this bit. |
0b1 |
If EL2 is implemented and enabled in the current Security state and either EL3 is not implemented or SCR_EL3.FGTEn == 0b1, then execution of AT S1E0W at EL1 using AArch64 is trapped to EL2 and reported with EC syndrome value 0x18, unless the instruction generates a higher priority exception. |
On a Warm reset, in a system where the PE resets into EL2, this field resets to 0.
ATS1E0R, bit [14]
Trap execution of AT S1E0R at EL1 using AArch64 to EL2.
ATS1E0R | Meaning |
---|---|
0b0 |
Execution of AT S1E0R is not affected by this bit. |
0b1 |
If EL2 is implemented and enabled in the current Security state and either EL3 is not implemented or SCR_EL3.FGTEn == 0b1, then execution of AT S1E0R at EL1 using AArch64 is trapped to EL2 and reported with EC syndrome value 0x18, unless the instruction generates a higher priority exception. |
On a Warm reset, in a system where the PE resets into EL2, this field resets to 0.
ATS1E1W, bit [13]
Trap execution of AT S1E1W at EL1 using AArch64 to EL2.
ATS1E1W | Meaning |
---|---|
0b0 |
Execution of AT S1E1W is not affected by this bit. |
0b1 |
If EL2 is implemented and enabled in the current Security state and either EL3 is not implemented or SCR_EL3.FGTEn == 0b1, then execution of AT S1E1W at EL1 using AArch64 is trapped to EL2 and reported with EC syndrome value 0x18, unless the instruction generates a higher priority exception. |
On a Warm reset, in a system where the PE resets into EL2, this field resets to 0.
ATS1E1R, bit [12]
Trap execution of AT S1E1R at EL1 using AArch64 to EL2.
ATS1E1R | Meaning |
---|---|
0b0 |
Execution of AT S1E1R is not affected by this bit. |
0b1 |
If EL2 is implemented and enabled in the current Security state and either EL3 is not implemented or SCR_EL3.FGTEn == 0b1, then execution of AT S1E1R at EL1 using AArch64 is trapped to EL2 and reported with EC syndrome value 0x18, unless the instruction generates a higher priority exception. |
On a Warm reset, in a system where the PE resets into EL2, this field resets to 0.
DCZVA, bit [11]
Trap execution of multiple instructions. Enables a trap on execution at EL1 and EL0 using AArch64 of any of the following AArch64 instructions to EL2:
DCZVA | Meaning |
---|---|
0b0 |
Execution of the instructions listed above is not affected by this bit. |
0b1 |
If EL2 is implemented and enabled in the current Security state, HCR_EL2.{E2H,TGE} != {1,1}, and either EL3 is not implemented or SCR_EL3.FGTEn == 0b1, then execution at EL1 and EL0 using AArch64 of any of the instructions listed above is trapped to EL2 and reported with EC syndrome value 0x18, unless the instruction generates a higher priority exception. |
On a Warm reset, in a system where the PE resets into EL2, this field resets to 0.
DCCIVAC, bit [10]
Trap execution of multiple instructions. Enables a trap on execution at EL1 and EL0 using AArch64 of any of the following AArch64 instructions to EL2:
- DC CIVAC.
- DC CIGVAC, if FEAT_MTE is implemented.
- DC CIGDVAC, if FEAT_MTE is implemented.
DCCIVAC | Meaning |
---|---|
0b0 |
Execution of the instructions listed above is not affected by this bit. |
0b1 |
If EL2 is implemented and enabled in the current Security state, HCR_EL2.{E2H,TGE} != {1,1}, and either EL3 is not implemented or SCR_EL3.FGTEn == 0b1, then execution at EL1 and EL0 using AArch64 of any of the instructions listed above is trapped to EL2 and reported with EC syndrome value 0x18, unless the instruction generates a higher priority exception. |
On a Warm reset, in a system where the PE resets into EL2, this field resets to 0.
DCCVADP, bit [9]
When FEAT_DPB2 is implemented:
When FEAT_DPB2 is implemented:
Trap execution of multiple instructions. Enables a trap on execution at EL1 and EL0 using AArch64 of any of the following AArch64 instructions to EL2:
- DC CVADP.
- DC CGVADP, if FEAT_MTE is implemented.
- DC CGDVADP, if FEAT_MTE is implemented.
DCCVADP | Meaning |
---|---|
0b0 |
Execution of the instructions listed above is not affected by this bit. |
0b1 |
If EL2 is implemented and enabled in the current Security state, HCR_EL2.{E2H,TGE} != {1,1}, and either EL3 is not implemented or SCR_EL3.FGTEn == 0b1, then execution at EL1 and EL0 using AArch64 of any of the instructions listed above is trapped to EL2 and reported with EC syndrome value 0x18, unless the instruction generates a higher priority exception. |
On a Warm reset, in a system where the PE resets into EL2, this field resets to 0.
Otherwise:
Otherwise:
Reserved, RES0.
DCCVAP, bit [8]
Trap execution of multiple instructions. Enables a trap on execution at EL1 and EL0 using AArch64 of any of the following AArch64 instructions to EL2:
DCCVAP | Meaning |
---|---|
0b0 |
Execution of the instructions listed above is not affected by this bit. |
0b1 |
If EL2 is implemented and enabled in the current Security state, HCR_EL2.{E2H,TGE} != {1,1}, and either EL3 is not implemented or SCR_EL3.FGTEn == 0b1, then execution at EL1 and EL0 using AArch64 of any of the instructions listed above is trapped to EL2 and reported with EC syndrome value 0x18, unless the instruction generates a higher priority exception. |
On a Warm reset, in a system where the PE resets into EL2, this field resets to 0.
DCCVAU, bit [7]
Trap execution of DC CVAU at EL1 and EL0 using AArch64 to EL2.
DCCVAU | Meaning |
---|---|
0b0 |
Execution of DC CVAU is not affected by this bit. |
0b1 |
If EL2 is implemented and enabled in the current Security state, HCR_EL2.{E2H,TGE} != {1,1}, and either EL3 is not implemented or SCR_EL3.FGTEn == 0b1, then execution of DC CVAU at EL1 and EL0 using AArch64 is trapped to EL2 and reported with EC syndrome value 0x18, unless the instruction generates a higher priority exception. |
On a Warm reset, in a system where the PE resets into EL2, this field resets to 0.
DCCISW, bit [6]
Trap execution of multiple instructions. Enables a trap on execution at EL1 using AArch64 of any of the following AArch64 instructions to EL2:
DCCISW | Meaning |
---|---|
0b0 |
Execution of the instructions listed above is not affected by this bit. |
0b1 |
If EL2 is implemented and enabled in the current Security state and either EL3 is not implemented or SCR_EL3.FGTEn == 0b1, then execution at EL1 using AArch64 of any of the instructions listed above is trapped to EL2 and reported with EC syndrome value 0x18, unless the instruction generates a higher priority exception. |
On a Warm reset, in a system where the PE resets into EL2, this field resets to 0.
DCCSW, bit [5]
Trap execution of multiple instructions. Enables a trap on execution at EL1 using AArch64 of any of the following AArch64 instructions to EL2:
DCCSW | Meaning |
---|---|
0b0 |
Execution of the instructions listed above is not affected by this bit. |
0b1 |
If EL2 is implemented and enabled in the current Security state and either EL3 is not implemented or SCR_EL3.FGTEn == 0b1, then execution at EL1 using AArch64 of any of the instructions listed above is trapped to EL2 and reported with EC syndrome value 0x18, unless the instruction generates a higher priority exception. |
On a Warm reset, in a system where the PE resets into EL2, this field resets to 0.
DCISW, bit [4]
Trap execution of multiple instructions. Enables a trap on execution at EL1 using AArch64 of any of the following AArch64 instructions to EL2:
DCISW | Meaning |
---|---|
0b0 |
Execution of the instructions listed above is not affected by this bit. |
0b1 |
If EL2 is implemented and enabled in the current Security state and either EL3 is not implemented or SCR_EL3.FGTEn == 0b1, then execution at EL1 using AArch64 of any of the instructions listed above is trapped to EL2 and reported with EC syndrome value 0x18, unless the instruction generates a higher priority exception. |
On a Warm reset, in a system where the PE resets into EL2, this field resets to 0.
DCIVAC, bit [3]
Trap execution of multiple instructions. Enables a trap on execution at EL1 using AArch64 of any of the following AArch64 instructions to EL2:
DCIVAC | Meaning |
---|---|
0b0 |
Execution of the instructions listed above is not affected by this bit. |
0b1 |
If EL2 is implemented and enabled in the current Security state and either EL3 is not implemented or SCR_EL3.FGTEn == 0b1, then execution at EL1 using AArch64 of any of the instructions listed above is trapped to EL2 and reported with EC syndrome value 0x18, unless the instruction generates a higher priority exception. |
On a Warm reset, in a system where the PE resets into EL2, this field resets to 0.
ICIVAU, bit [2]
Trap execution of IC IVAU at EL1 and EL0 using AArch64 to EL2.
ICIVAU | Meaning |
---|---|
0b0 |
Execution of IC IVAU is not affected by this bit. |
0b1 |
If EL2 is implemented and enabled in the current Security state, HCR_EL2.{E2H,TGE} != {1,1}, and either EL3 is not implemented or SCR_EL3.FGTEn == 0b1, then execution of IC IVAU at EL1 and EL0 using AArch64 is trapped to EL2 and reported with EC syndrome value 0x18, unless the instruction generates a higher priority exception. |
On a Warm reset, in a system where the PE resets into EL2, this field resets to 0.
ICIALLU, bit [1]
Trap execution of IC IALLU at EL1 using AArch64 to EL2.
ICIALLU | Meaning |
---|---|
0b0 |
Execution of IC IALLU is not affected by this bit. |
0b1 |
If EL2 is implemented and enabled in the current Security state and either EL3 is not implemented or SCR_EL3.FGTEn == 0b1, then execution of IC IALLU at EL1 using AArch64 is trapped to EL2 and reported with EC syndrome value 0x18, unless the instruction generates a higher priority exception. |
On a Warm reset, in a system where the PE resets into EL2, this field resets to 0.
ICIALLUIS, bit [0]
Trap execution of IC IALLUIS at EL1 using AArch64 to EL2.
ICIALLUIS | Meaning |
---|---|
0b0 |
Execution of IC IALLUIS is not affected by this bit. |
0b1 |
If EL2 is implemented and enabled in the current Security state and either EL3 is not implemented or SCR_EL3.FGTEn == 0b1, then execution of IC IALLUIS at EL1 using AArch64 is trapped to EL2 and reported with EC syndrome value 0x18, unless the instruction generates a higher priority exception. |
On a Warm reset, in a system where the PE resets into EL2, this field resets to 0.
Accessing the HFGITR_EL2
Accesses to this register use the following encodings:
MRS <Xt>, HFGITR_EL2
op0 | op1 | CRn | CRm | op2 |
---|---|---|---|---|
0b11 | 0b100 | 0b0001 | 0b0001 | 0b110 |
if PSTATE.EL == EL0 then UNDEFINED; elsif PSTATE.EL == EL1 then if EL2Enabled() && HCR_EL2.<NV2,NV> == '11' then return NVMem[0x1C8]; elsif EL2Enabled() && HCR_EL2.NV == '1' then AArch64.SystemAccessTrap(EL2, 0x18); else UNDEFINED; elsif PSTATE.EL == EL2 then if Halted() && HaveEL(EL3) && EDSCR.SDD == '1' && boolean IMPLEMENTATION_DEFINED "EL3 trap priority when SDD == '1'" && SCR_EL3.FGTEn == '0' then UNDEFINED; elsif HaveEL(EL3) && SCR_EL3.FGTEn == '0' then if Halted() && EDSCR.SDD == '1' then UNDEFINED; else AArch64.SystemAccessTrap(EL3, 0x18); else return HFGITR_EL2; elsif PSTATE.EL == EL3 then return HFGITR_EL2;
MSR HFGITR_EL2, <Xt>
op0 | op1 | CRn | CRm | op2 |
---|---|---|---|---|
0b11 | 0b100 | 0b0001 | 0b0001 | 0b110 |
if PSTATE.EL == EL0 then UNDEFINED; elsif PSTATE.EL == EL1 then if EL2Enabled() && HCR_EL2.<NV2,NV> == '11' then NVMem[0x1C8] = X[t]; elsif EL2Enabled() && HCR_EL2.NV == '1' then AArch64.SystemAccessTrap(EL2, 0x18); else UNDEFINED; elsif PSTATE.EL == EL2 then if Halted() && HaveEL(EL3) && EDSCR.SDD == '1' && boolean IMPLEMENTATION_DEFINED "EL3 trap priority when SDD == '1'" && SCR_EL3.FGTEn == '0' then UNDEFINED; elsif HaveEL(EL3) && SCR_EL3.FGTEn == '0' then if Halted() && EDSCR.SDD == '1' then UNDEFINED; else AArch64.SystemAccessTrap(EL3, 0x18); else HFGITR_EL2 = X[t]; elsif PSTATE.EL == EL3 then HFGITR_EL2 = X[t];