Controls the tracing options.
AArch64 System register TRCCONFIGR bits [31:0] are architecturally mapped to External register TRCCONFIGR[31:0].
This register is present only when FEAT_ETE is implemented and System register access to the trace unit registers is implemented. Otherwise, direct accesses to TRCCONFIGR are UNDEFINED.
TRCCONFIGR 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 | ITO | RES0 | VMIDOPT | QE | RS | TS | RES0 | VMID | CID | RES0 | CCI | BB | RES0 | RES1 |
Reserved, RES0.
Instrumentation Trace Override.
ITO | Meaning |
---|---|
0b0 |
Instrumentation Trace Override disabled. |
0b1 |
Instrumentation Trace Override enabled. |
This field is ignored when SelfHostedTraceEnabled() returns TRUE.
The reset behavior of this field is:
Reserved, RES0.
Reserved, RES0.
Virtual context identifier selection control.
VMIDOPT | Meaning |
---|---|
0b0 |
VTTBR_EL2.VMID is used as the Virtual context identifier. |
0b1 |
CONTEXTIDR_EL2.PROCID is used as the Virtual context identifier. |
Reserved, RES0.
Virtual context identifier selection control.
VTTBR_EL2.VMID is used as the Virtual context identifier.
Reserved, RES1.
Virtual context identifier selection control.
CONTEXTIDR_EL2.PROCID is used as the Virtual context identifier.
Reserved, RES0.
Q element generation control.
QE | Meaning |
---|---|
0b00 |
Q elements are disabled. |
0b01 | Q elements with instruction counts are enabled. Q elements without instruction counts are disabled. |
All other values are reserved.
Q element generation control.
QE | Meaning |
---|---|
0b00 |
Q elements are disabled. |
0b11 | Q elements with instruction counts are enabled. Q elements without instruction counts are enabled. |
All other values are reserved.
Q element generation control.
QE | Meaning |
---|---|
0b00 |
Q elements are disabled. |
0b01 | Q elements with instruction counts are enabled. Q elements without instruction counts are disabled. |
0b11 | Q elements with instruction counts are enabled. Q elements without instruction counts are enabled. |
All other values are reserved.
Reserved, RES0.
Return stack control.
RS | Meaning |
---|---|
0b0 |
Return stack is disabled. |
0b1 |
Return stack is enabled. |
The reset behavior of this field is:
Reserved, RES0.
Global timestamp tracing control.
TS | Meaning |
---|---|
0b0 |
Global timestamp tracing is disabled. |
0b1 |
Global timestamp tracing is enabled. |
The reset behavior of this field is:
Reserved, RES0.
Reserved, RES0.
Virtual context identifier tracing control.
VMID | Meaning |
---|---|
0b0 |
Virtual context identifier tracing is disabled. |
0b1 |
Virtual context identifier tracing is enabled. |
The reset behavior of this field is:
Reserved, RES0.
Context identifier tracing control.
CID | Meaning |
---|---|
0b0 |
Context identifier tracing is disabled. |
0b1 |
Context identifier tracing is enabled. |
The reset behavior of this field is:
Reserved, RES0.
Reserved, RES0.
Cycle counting instruction tracing control.
CCI | Meaning |
---|---|
0b0 |
Cycle counting instruction tracing is disabled. |
0b1 |
Cycle counting instruction tracing is enabled. |
The reset behavior of this field is:
Reserved, RES0.
Branch broadcasting control.
BB | Meaning |
---|---|
0b0 |
Branch broadcasting is disabled. |
0b1 |
Branch broadcasting is enabled. |
The reset behavior of this field is:
Reserved, RES0.
Reserved, RES0.
Reserved, RES1.
Must always be programmed.
TRCCONFIGR.QE must be set to 0b00 if TRCCONFIGR.BB is not 0.
Writes are CONSTRAINED UNPREDICTABLE if the trace unit is not in the Idle state.
Accesses to this register use the following encodings in the System register encoding space:
MRS <Xt>, TRCCONFIGR
op0 | op1 | CRn | CRm | op2 |
---|---|---|---|---|
0b10 | 0b001 | 0b0000 | 0b0100 | 0b000 |
if PSTATE.EL == EL0 then UNDEFINED; elsif PSTATE.EL == EL1 then if HaveEL(EL3) && EL3SDDUndefPriority() && CPTR_EL3.TTA == '1' then UNDEFINED; elsif CPACR_EL1.TTA == '1' then AArch64.SystemAccessTrap(EL1, 0x18); elsif EL2Enabled() && CPTR_EL2.TTA == '1' then AArch64.SystemAccessTrap(EL2, 0x18); elsif EL2Enabled() && IsFeatureImplemented(FEAT_FGT) && (!HaveEL(EL3) || SCR_EL3.FGTEn == '1') && HDFGRTR_EL2.TRC == '1' then AArch64.SystemAccessTrap(EL2, 0x18); elsif HaveEL(EL3) && CPTR_EL3.TTA == '1' then if EL3SDDUndef() then UNDEFINED; else AArch64.SystemAccessTrap(EL3, 0x18); elsif IsFeatureImplemented(FEAT_TRBE_EXT) && OSLSR_EL1.OSLK == '0' && HaltingAllowed() && EDSCR2.TTA == '1' then Halt(DebugHalt_SoftwareAccess); else X[t, 64] = TRCCONFIGR; elsif PSTATE.EL == EL2 then if HaveEL(EL3) && EL3SDDUndefPriority() && CPTR_EL3.TTA == '1' then UNDEFINED; elsif CPTR_EL2.TTA == '1' then AArch64.SystemAccessTrap(EL2, 0x18); elsif HaveEL(EL3) && CPTR_EL3.TTA == '1' then if EL3SDDUndef() then UNDEFINED; else AArch64.SystemAccessTrap(EL3, 0x18); elsif !ELUsingAArch32(EL1) && IsFeatureImplemented(FEAT_TRBE_EXT) && OSLSR_EL1.OSLK == '0' && HaltingAllowed() && EDSCR2.TTA == '1' then Halt(DebugHalt_SoftwareAccess); else X[t, 64] = TRCCONFIGR; elsif PSTATE.EL == EL3 then if CPTR_EL3.TTA == '1' then AArch64.SystemAccessTrap(EL3, 0x18); elsif !ELUsingAArch32(EL1) && IsFeatureImplemented(FEAT_TRBE_EXT) && OSLSR_EL1.OSLK == '0' && HaltingAllowed() && EDSCR2.TTA == '1' then Halt(DebugHalt_SoftwareAccess); else X[t, 64] = TRCCONFIGR;
MSR TRCCONFIGR, <Xt>
op0 | op1 | CRn | CRm | op2 |
---|---|---|---|---|
0b10 | 0b001 | 0b0000 | 0b0100 | 0b000 |
if PSTATE.EL == EL0 then UNDEFINED; elsif PSTATE.EL == EL1 then if HaveEL(EL3) && EL3SDDUndefPriority() && CPTR_EL3.TTA == '1' then UNDEFINED; elsif CPACR_EL1.TTA == '1' then AArch64.SystemAccessTrap(EL1, 0x18); elsif EL2Enabled() && CPTR_EL2.TTA == '1' then AArch64.SystemAccessTrap(EL2, 0x18); elsif EL2Enabled() && IsFeatureImplemented(FEAT_FGT) && (!HaveEL(EL3) || SCR_EL3.FGTEn == '1') && HDFGWTR_EL2.TRC == '1' then AArch64.SystemAccessTrap(EL2, 0x18); elsif HaveEL(EL3) && CPTR_EL3.TTA == '1' then if EL3SDDUndef() then UNDEFINED; else AArch64.SystemAccessTrap(EL3, 0x18); elsif IsFeatureImplemented(FEAT_TRBE_EXT) && OSLSR_EL1.OSLK == '0' && HaltingAllowed() && EDSCR2.TTA == '1' then Halt(DebugHalt_SoftwareAccess); else TRCCONFIGR = X[t, 64]; elsif PSTATE.EL == EL2 then if HaveEL(EL3) && EL3SDDUndefPriority() && CPTR_EL3.TTA == '1' then UNDEFINED; elsif CPTR_EL2.TTA == '1' then AArch64.SystemAccessTrap(EL2, 0x18); elsif HaveEL(EL3) && CPTR_EL3.TTA == '1' then if EL3SDDUndef() then UNDEFINED; else AArch64.SystemAccessTrap(EL3, 0x18); elsif !ELUsingAArch32(EL1) && IsFeatureImplemented(FEAT_TRBE_EXT) && OSLSR_EL1.OSLK == '0' && HaltingAllowed() && EDSCR2.TTA == '1' then Halt(DebugHalt_SoftwareAccess); else TRCCONFIGR = X[t, 64]; elsif PSTATE.EL == EL3 then if CPTR_EL3.TTA == '1' then AArch64.SystemAccessTrap(EL3, 0x18); elsif !ELUsingAArch32(EL1) && IsFeatureImplemented(FEAT_TRBE_EXT) && OSLSR_EL1.OSLK == '0' && HaltingAllowed() && EDSCR2.TTA == '1' then Halt(DebugHalt_SoftwareAccess); else TRCCONFIGR = X[t, 64];