The TRCCONFIGR characteristics are:
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. Otherwise, direct accesses to TRCCONFIGR are UNDEFINED.
TRCCONFIGR is a 64-bit register.
The TRCCONFIGR bit assignments are:
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 | VMIDOPT | QE | RS | TS | RES0 | VMID | CID | RES0 | CCI | BB | RES0 | RES1 |
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. |
On a Trace unit reset, this field resets to an architecturally UNKNOWN value.
Reserved, RES0.
Global timestamp tracing control.
TS | Meaning |
---|---|
0b0 |
Global timestamp tracing is disabled. |
0b1 |
Global timestamp tracing is enabled. |
On a Trace unit reset, this field resets to an architecturally UNKNOWN value.
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. |
On a Trace unit reset, this field resets to an architecturally UNKNOWN value.
Reserved, RES0.
Context identifier tracing control.
CID | Meaning |
---|---|
0b0 |
Context identifier tracing is disabled. |
0b1 |
Context identifier tracing is enabled. |
On a Trace unit reset, this field resets to an architecturally UNKNOWN value.
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. |
On a Trace unit reset, this field resets to an architecturally UNKNOWN value.
Reserved, RES0.
Branch broadcasting control.
BB | Meaning |
---|---|
0b0 |
Branch broadcasting is disabled. |
0b1 |
Branch broadcasting is enabled. |
On a Trace unit reset, this field resets to an architecturally UNKNOWN value.
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:
op0 | op1 | CRn | CRm | op2 |
---|---|---|---|---|
0b10 | 0b001 | 0b0000 | 0b0100 | 0b000 |
if PSTATE.EL == EL0 then UNDEFINED; elsif PSTATE.EL == EL1 then if Halted() && HaveEL(EL3) && EDSCR.SDD == '1' && boolean IMPLEMENTATION_DEFINED "EL3 trap priority when SDD == '1'" && 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() && (!HaveEL(EL3) || SCR_EL3.FGTEn == '1') && HDFGRTR_EL2.TRC == '1' then AArch64.SystemAccessTrap(EL2, 0x18); elsif HaveEL(EL3) && CPTR_EL3.TTA == '1' then if Halted() && EDSCR.SDD == '1' then UNDEFINED; else AArch64.SystemAccessTrap(EL3, 0x18); else return TRCCONFIGR; elsif PSTATE.EL == EL2 then if Halted() && HaveEL(EL3) && EDSCR.SDD == '1' && boolean IMPLEMENTATION_DEFINED "EL3 trap priority when SDD == '1'" && 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 Halted() && EDSCR.SDD == '1' then UNDEFINED; else AArch64.SystemAccessTrap(EL3, 0x18); else return TRCCONFIGR; elsif PSTATE.EL == EL3 then if CPTR_EL3.TTA == '1' then AArch64.SystemAccessTrap(EL3, 0x18); else return TRCCONFIGR;
op0 | op1 | CRn | CRm | op2 |
---|---|---|---|---|
0b10 | 0b001 | 0b0000 | 0b0100 | 0b000 |
if PSTATE.EL == EL0 then UNDEFINED; elsif PSTATE.EL == EL1 then if Halted() && HaveEL(EL3) && EDSCR.SDD == '1' && boolean IMPLEMENTATION_DEFINED "EL3 trap priority when SDD == '1'" && 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() && (!HaveEL(EL3) || SCR_EL3.FGTEn == '1') && HDFGWTR_EL2.TRC == '1' then AArch64.SystemAccessTrap(EL2, 0x18); elsif HaveEL(EL3) && CPTR_EL3.TTA == '1' then if Halted() && EDSCR.SDD == '1' then UNDEFINED; else AArch64.SystemAccessTrap(EL3, 0x18); else TRCCONFIGR = X[t]; elsif PSTATE.EL == EL2 then if Halted() && HaveEL(EL3) && EDSCR.SDD == '1' && boolean IMPLEMENTATION_DEFINED "EL3 trap priority when SDD == '1'" && 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 Halted() && EDSCR.SDD == '1' then UNDEFINED; else AArch64.SystemAccessTrap(EL3, 0x18); else TRCCONFIGR = X[t]; elsif PSTATE.EL == EL3 then if CPTR_EL3.TTA == '1' then AArch64.SystemAccessTrap(EL3, 0x18); else TRCCONFIGR = X[t];
30/03/2021 20:51; e3551d56dc294a4d55296a6c10544191ada08a8e
Copyright © 2010-2021 Arm Limited or its affiliates. All rights reserved. This document is Non-Confidential.