Provides controls for traps of MRS and MRC reads of debug, trace, PMU, and Statistical Profiling System registers.
This register is present only when FEAT_FGT2 is implemented. Otherwise, direct accesses to HDFGRTR2_EL2 are UNDEFINED.
If EL2 is not implemented, this register is RES0 from EL3.
HDFGRTR2_EL2 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 | |||||||||||||||||||||||||||||||
RES0 | nMDSTEPOP_EL1 | nTRBMPAM_EL1 | RES0 | nTRCITECR_EL1 | nPMSDSFR_EL1 | nSPMDEVAFF_EL1 | nSPMID | nSPMSCR_EL1 | nSPMACCESSR_EL1 | nSPMCR_EL0 | nSPMOVS | nSPMINTEN | nSPMCNTEN | nSPMSELR_EL0 | nSPMEVTYPERn_EL0 | nSPMEVCNTRn_EL0 | nPMSSCR_EL1 | nPMSSDATA | nMDSELR_EL1 | nPMUACR_EL1 | nPMICFILTR_EL0 | nPMICNTR_EL0 | nPMIAR_EL1 | nPMECR_EL1 |
Reserved, RES0.
Trap MRS reads of MDSTEPOP_EL1 at EL1 using AArch64 to EL2.
nMDSTEPOP_EL1 | Meaning |
---|---|
0b0 |
If EL2 is implemented and enabled in the current Security state, then MRS reads of MDSTEPOP_EL1 at EL1 using AArch64 are trapped to EL2 and reported with EC syndrome value 0x18, unless the read generates a higher priority exception. |
0b1 |
MRS reads of MDSTEPOP_EL1 are not trapped by this mechanism. |
This field is ignored by the PE and treated as zero when all of the following are true:
The reset behavior of this field is:
Reserved, RES0.
Trap MRS reads of TRBMPAM_EL1 at EL1 using AArch64 to EL2.
nTRBMPAM_EL1 | Meaning |
---|---|
0b0 |
If EL2 is implemented and enabled in the current Security state, then MRS reads of TRBMPAM_EL1 at EL1 using AArch64 are trapped to EL2 and reported with EC syndrome value 0x18, unless the read generates a higher priority exception. |
0b1 |
MRS reads of TRBMPAM_EL1 are not trapped by this mechanism. |
This field is ignored by the PE and treated as zero when all of the following are true:
The reset behavior of this field is:
Reserved, RES0.
Reserved, RES0.
Trap MRS reads of TRCITECR_EL1 at EL1 using AArch64 to EL2.
nTRCITECR_EL1 | Meaning |
---|---|
0b0 |
If EL2 is implemented and enabled in the current Security state, then MRS reads of TRCITECR_EL1 at EL1 using AArch64 are trapped to EL2 and reported with EC syndrome value 0x18, unless the read generates a higher priority exception. |
0b1 |
MRS reads of TRCITECR_EL1 are not trapped by this mechanism. |
This field is ignored by the PE and treated as zero when all of the following are true:
The reset behavior of this field is:
Reserved, RES0.
Trap MRS reads of PMSDSFR_EL1 at EL1 using AArch64 to EL2.
nPMSDSFR_EL1 | Meaning |
---|---|
0b0 |
If EL2 is implemented and enabled in the current Security state, then MRS reads of PMSDSFR_EL1 at EL1 using AArch64 are trapped to EL2 and reported with EC syndrome value 0x18, unless the read generates a higher priority exception. |
0b1 |
MRS reads of PMSDSFR_EL1 are not trapped by this mechanism. |
This field is ignored by the PE and treated as zero when all of the following are true:
The reset behavior of this field is:
Reserved, RES0.
Trap MRS reads of SPMDEVAFF_EL1 at EL1 using AArch64 to EL2.
nSPMDEVAFF_EL1 | Meaning |
---|---|
0b0 |
If EL2 is implemented and enabled in the current Security state, then MRS reads of SPMDEVAFF_EL1 at EL1 using AArch64 are trapped to EL2 and reported with EC syndrome value 0x18, unless the read generates a higher priority exception. |
0b1 |
MRS reads of SPMDEVAFF_EL1 are not trapped by this mechanism. |
This field is ignored by the PE and treated as zero when all of the following are true:
The reset behavior of this field is:
Reserved, RES0.
Trap MRS reads of multiple System registers. Enables a trap on MRS reads at EL1 using AArch64 of any of the following AArch64 System registers to EL2:
nSPMID | Meaning |
---|---|
0b0 |
If EL2 is implemented and enabled in the current Security state, then MRS reads at EL1 using AArch64 of any of the specified System registers are trapped to EL2 and reported with EC syndrome value 0x18, unless the read generates a higher priority exception. |
0b1 |
MRS reads of the specified System registers are not trapped by this mechanism. |
This field is ignored by the PE and treated as zero when all of the following are true:
The reset behavior of this field is:
Reserved, RES0.
Trap MRS reads of SPMSCR_EL1 at EL1 using AArch64 to EL2.
nSPMSCR_EL1 | Meaning |
---|---|
0b0 |
If EL2 is implemented and enabled in the current Security state, then MRS reads of SPMSCR_EL1 at EL1 using AArch64 are trapped to EL2 and reported with EC syndrome value 0x18, unless the read generates a higher priority exception. |
0b1 |
MRS reads of SPMSCR_EL1 are not trapped by this mechanism. |
This field is ignored by the PE and treated as zero when all of the following are true:
The reset behavior of this field is:
Reserved, RES0.
Trap MRS reads of SPMACCESSR_EL1 at EL1 using AArch64 to EL2.
nSPMACCESSR_EL1 | Meaning |
---|---|
0b0 |
If EL2 is implemented and enabled in the current Security state, then MRS reads of SPMACCESSR_EL1 at EL1 using AArch64 are trapped to EL2 and reported with EC syndrome value 0x18, unless the read generates a higher priority exception. |
0b1 |
MRS reads of SPMACCESSR_EL1 are not trapped by this mechanism. |
This field is ignored by the PE and treated as zero when all of the following are true:
The reset behavior of this field is:
Reserved, RES0.
Trap MRS reads of SPMCR_EL0 at EL1 and EL0 using AArch64 to EL2.
nSPMCR_EL0 | Meaning |
---|---|
0b0 |
If EL2 is implemented and enabled in the current Security state, and the Effective value of HCR_EL2.{E2H, TGE} is not {1, 1}, then MRS reads of SPMCR_EL0 at EL1 and EL0 using AArch64 are trapped to EL2 and reported with EC syndrome value 0x18, unless the read generates a higher priority exception. |
0b1 |
MRS reads of SPMCR_EL0 are not trapped by this mechanism. |
This field is ignored by the PE and treated as zero when all of the following are true:
The reset behavior of this field is:
Reserved, RES0.
Trap MRS reads of multiple System registers. Enables a trap on MRS reads at EL1 and EL0 using AArch64 of any of the following AArch64 System registers to EL2:
nSPMOVS | Meaning |
---|---|
0b0 |
If EL2 is implemented and enabled in the current Security state, and the Effective value of HCR_EL2.{E2H, TGE} is not {1, 1}, then MRS reads at EL1 and EL0 using AArch64 of any of the specified System registers are trapped to EL2 and reported with EC syndrome value 0x18, unless the read generates a higher priority exception. |
0b1 |
MRS reads of the specified System registers are not trapped by this mechanism. |
This field is ignored by the PE and treated as zero when all of the following are true:
The reset behavior of this field is:
Reserved, RES0.
Trap MRS reads of multiple System registers. Enables a trap on MRS reads at EL1 using AArch64 of any of the following AArch64 System registers to EL2:
nSPMINTEN | Meaning |
---|---|
0b0 |
If EL2 is implemented and enabled in the current Security state, then MRS reads at EL1 using AArch64 of any of the specified System registers are trapped to EL2 and reported with EC syndrome value 0x18, unless the read generates a higher priority exception. |
0b1 |
MRS reads of the specified System registers are not trapped by this mechanism. |
This field is ignored by the PE and treated as zero when all of the following are true:
The reset behavior of this field is:
Reserved, RES0.
Trap MRS reads of multiple System registers. Enables a trap on MRS reads at EL1 and EL0 using AArch64 of any of the following AArch64 System registers to EL2:
nSPMCNTEN | Meaning |
---|---|
0b0 |
If EL2 is implemented and enabled in the current Security state, and the Effective value of HCR_EL2.{E2H, TGE} is not {1, 1}, then MRS reads at EL1 and EL0 using AArch64 of any of the specified System registers are trapped to EL2 and reported with EC syndrome value 0x18, unless the read generates a higher priority exception. |
0b1 |
MRS reads of the specified System registers are not trapped by this mechanism. |
This field is ignored by the PE and treated as zero when all of the following are true:
The reset behavior of this field is:
Reserved, RES0.
Trap MRS reads of SPMSELR_EL0 at EL1 and EL0 using AArch64 to EL2.
nSPMSELR_EL0 | Meaning |
---|---|
0b0 |
If EL2 is implemented and enabled in the current Security state, and the Effective value of HCR_EL2.{E2H, TGE} is not {1, 1}, then MRS reads of SPMSELR_EL0 at EL1 and EL0 using AArch64 are trapped to EL2 and reported with EC syndrome value 0x18, unless the read generates a higher priority exception. |
0b1 |
MRS reads of SPMSELR_EL0 are not trapped by this mechanism. |
This field is ignored by the PE and treated as zero when all of the following are true:
The reset behavior of this field is:
Reserved, RES0.
Trap MRS reads of multiple System registers. Enables a trap on MRS reads at EL1 and EL0 using AArch64 of any of the following AArch64 System registers to EL2:
nSPMEVTYPERn_EL0 | Meaning |
---|---|
0b0 |
If EL2 is implemented and enabled in the current Security state, and the Effective value of HCR_EL2.{E2H, TGE} is not {1, 1}, then MRS reads at EL1 and EL0 using AArch64 of any of the specified System registers are trapped to EL2 and reported with EC syndrome value 0x18, unless the read generates a higher priority exception. |
0b1 |
MRS reads of the specified System registers are not trapped by this mechanism. |
This field is ignored by the PE and treated as zero when all of the following are true:
The reset behavior of this field is:
Reserved, RES0.
Trap MRS reads of SPMEVCNTR<n>_EL0 at EL1 and EL0 using AArch64 to EL2.
nSPMEVCNTRn_EL0 | Meaning |
---|---|
0b0 |
If EL2 is implemented and enabled in the current Security state, and the Effective value of HCR_EL2.{E2H, TGE} is not {1, 1}, then MRS reads of SPMEVCNTR<n>_EL0 at EL1 and EL0 using AArch64 are trapped to EL2 and reported with EC syndrome value 0x18, unless the read generates a higher priority exception. |
0b1 |
MRS reads of SPMEVCNTR<n>_EL0 are not trapped by this mechanism. |
This field is ignored by the PE and treated as zero when all of the following are true:
The reset behavior of this field is:
Reserved, RES0.
Trap MRS reads of PMSSCR_EL1 at EL1 using AArch64 to EL2.
nPMSSCR_EL1 | Meaning |
---|---|
0b0 |
If EL2 is implemented and enabled in the current Security state, then MRS reads of PMSSCR_EL1 at EL1 using AArch64 are trapped to EL2 and reported with EC syndrome value 0x18, unless the read generates a higher priority exception. |
0b1 |
MRS reads of PMSSCR_EL1 are not trapped by this mechanism. |
This field is ignored by the PE and treated as zero when all of the following are true:
The reset behavior of this field is:
Reserved, RES0.
Trap MRS reads of multiple System registers. Enables a trap on MRS reads at EL1 using AArch64 of any of the following AArch64 System registers to EL2:
nPMSSDATA | Meaning |
---|---|
0b0 |
If EL2 is implemented and enabled in the current Security state, then MRS reads at EL1 using AArch64 of any of the specified System registers are trapped to EL2 and reported with EC syndrome value 0x18, unless the read generates a higher priority exception. |
0b1 |
MRS reads of the specified System registers are not trapped by this mechanism. |
This field is ignored by the PE and treated as zero when all of the following are true:
The reset behavior of this field is:
Reserved, RES0.
Trap MRS reads of MDSELR_EL1 at EL1 using AArch64 to EL2.
nMDSELR_EL1 | Meaning |
---|---|
0b0 |
If EL2 is implemented and enabled in the current Security state, then MRS reads of MDSELR_EL1 at EL1 using AArch64 are trapped to EL2 and reported with EC syndrome value 0x18, unless the read generates a higher priority exception. |
0b1 |
MRS reads of MDSELR_EL1 are not trapped by this mechanism. |
It is IMPLEMENTATION DEFINED whether this field is implemented or is RES0 when 16 or fewer breakpoints are implemented, 16 or fewer watchpoints are implemented, and MDSELR_EL1 is implemented as RAZ/WI.
This field is ignored by the PE and treated as zero when all of the following are true:
The reset behavior of this field is:
Reserved, RES0.
Trap MRS reads of PMUACR_EL1 at EL1 using AArch64 to EL2.
nPMUACR_EL1 | Meaning |
---|---|
0b0 |
If EL2 is implemented and enabled in the current Security state, then MRS reads of PMUACR_EL1 at EL1 using AArch64 are trapped to EL2 and reported with EC syndrome value 0x18, unless the read generates a higher priority exception. |
0b1 |
MRS reads of PMUACR_EL1 are not trapped by this mechanism. |
This field is ignored by the PE and treated as zero when all of the following are true:
The reset behavior of this field is:
Reserved, RES0.
Trap MRS reads of PMICFILTR_EL0 at EL1 and EL0 using AArch64 to EL2.
nPMICFILTR_EL0 | Meaning |
---|---|
0b0 | If EL2 is implemented and enabled in the current Security state, and the Effective value of HCR_EL2.{E2H, TGE} is not {1, 1}, then:
|
0b1 |
MRS reads of PMICFILTR_EL0 are not trapped by this mechanism. |
This field is ignored by the PE and treated as zero when all of the following are true:
The reset behavior of this field is:
Reserved, RES0.
Trap MRS reads of PMICNTR_EL0 at EL1 and EL0 using AArch64 to EL2.
nPMICNTR_EL0 | Meaning |
---|---|
0b0 |
If EL2 is implemented and enabled in the current Security state, and the Effective value of HCR_EL2.{E2H, TGE} is not {1, 1}, then MRS reads of PMICNTR_EL0 at EL1 and EL0 using AArch64 are trapped to EL2 and reported with EC syndrome value 0x18, unless the read generates a higher priority exception. |
0b1 |
MRS reads of PMICNTR_EL0 are not trapped by this mechanism. |
This field is ignored by the PE and treated as zero when all of the following are true:
The reset behavior of this field is:
Reserved, RES0.
Trap MRS reads of PMIAR_EL1 at EL1 using AArch64 to EL2.
nPMIAR_EL1 | Meaning |
---|---|
0b0 |
If EL2 is implemented and enabled in the current Security state, then MRS reads of PMIAR_EL1 at EL1 using AArch64 are trapped to EL2 and reported with EC syndrome value 0x18, unless the read generates a higher priority exception. |
0b1 |
MRS reads of PMIAR_EL1 are not trapped by this mechanism. |
This field is ignored by the PE and treated as zero when all of the following are true:
The reset behavior of this field is:
Reserved, RES0.
Trap MRS reads of PMECR_EL1 at EL1 using AArch64 to EL2.
nPMECR_EL1 | Meaning |
---|---|
0b0 |
If EL2 is implemented and enabled in the current Security state, then MRS reads of PMECR_EL1 at EL1 using AArch64 are trapped to EL2 and reported with EC syndrome value 0x18, unless the read generates a higher priority exception. |
0b1 |
MRS reads of PMECR_EL1 are not trapped by this mechanism. |
This field is ignored by the PE and treated as zero when all of the following are true:
The reset behavior of this field is:
Reserved, RES0.
Accesses to this register use the following encodings in the System register encoding space:
MRS <Xt>, HDFGRTR2_EL2
op0 | op1 | CRn | CRm | op2 |
---|---|---|---|---|
0b11 | 0b100 | 0b0011 | 0b0001 | 0b000 |
if PSTATE.EL == EL0 then UNDEFINED; elsif PSTATE.EL == EL1 then if EffectiveHCR_EL2_NVx() IN {'1x1'} then X[t, 64] = NVMem[0x1A0]; elsif EffectiveHCR_EL2_NVx() IN {'xx1'} then AArch64.SystemAccessTrap(EL2, 0x18); else UNDEFINED; elsif PSTATE.EL == EL2 then if HaveEL(EL3) && EL3SDDUndefPriority() && SCR_EL3.FGTEn2 == '0' then UNDEFINED; elsif HaveEL(EL3) && SCR_EL3.FGTEn2 == '0' then if EL3SDDUndef() then UNDEFINED; else AArch64.SystemAccessTrap(EL3, 0x18); else X[t, 64] = HDFGRTR2_EL2; elsif PSTATE.EL == EL3 then X[t, 64] = HDFGRTR2_EL2;
MSR HDFGRTR2_EL2, <Xt>
op0 | op1 | CRn | CRm | op2 |
---|---|---|---|---|
0b11 | 0b100 | 0b0011 | 0b0001 | 0b000 |
if PSTATE.EL == EL0 then UNDEFINED; elsif PSTATE.EL == EL1 then if EffectiveHCR_EL2_NVx() IN {'1x1'} then NVMem[0x1A0] = X[t, 64]; elsif EffectiveHCR_EL2_NVx() IN {'xx1'} then AArch64.SystemAccessTrap(EL2, 0x18); else UNDEFINED; elsif PSTATE.EL == EL2 then if HaveEL(EL3) && EL3SDDUndefPriority() && SCR_EL3.FGTEn2 == '0' then UNDEFINED; elsif HaveEL(EL3) && SCR_EL3.FGTEn2 == '0' then if EL3SDDUndef() then UNDEFINED; else AArch64.SystemAccessTrap(EL3, 0x18); else HDFGRTR2_EL2 = X[t, 64]; elsif PSTATE.EL == EL3 then HDFGRTR2_EL2 = X[t, 64];