TRCSTALLCTLR, Stall Control Register
The TRCSTALLCTLR characteristics are:
Purpose
Enables trace unit functionality that prevents trace unit buffer overflows.
Configuration
External register TRCSTALLCTLR bits [31:0] are architecturally mapped to AArch64 System register TRCSTALLCTLR[31:0] .
This register is present only when ETE is implemented and TRCIDR3.STALLCTL == 0b1. Otherwise, direct accesses to TRCSTALLCTLR are RES0.
Attributes
TRCSTALLCTLR is a 32-bit register.
Field descriptions
The TRCSTALLCTLR bit assignments are:
Bits [31:14]
Reserved, RES0.
NOOVERFLOW, bit [13]
When TRCIDR3.NOOVERFLOW == 0b1:
When TRCIDR3.NOOVERFLOW == 0b1:
Trace overflow prevention.
NOOVERFLOW | Meaning |
---|---|
0b0 |
Trace unit buffer overflow prevention is disabled. |
0b1 |
Trace unit buffer overflow prevention is enabled. |
Note that enabling this feature might cause a significant performance impact.
On a Trace unit reset, this field resets to an architecturally UNKNOWN value.
Otherwise:
Otherwise:
Reserved, RES0.
Bits [12:9]
Reserved, RES0.
ISTALL, bit [8]
Instruction stall control. Controls if a trace unit can stall the PE when the trace buffer space is less than LEVEL.
ISTALL | Meaning |
---|---|
0b0 |
The trace unit must not stall the PE. |
0b1 |
The trace unit can stall the PE. |
On a Trace unit reset, this field resets to an architecturally UNKNOWN value.
Bits [7:4]
Reserved, RES0.
LEVEL, bits [3:0]
Threshold level field. The field can support 16 monotonic levels from 0b0000 to 0b1111.
LEVEL | Meaning |
---|---|
0b0000 |
Minimal invasion. This setting has a greater risk of a trace unit buffer overflow. |
0b1111 |
Maximum invasion. Reduced risk of a trace unit buffer overflow. |
Note that for some implementations, invasion might occur at the minimal invasion level.
It is IMPLEMENTATION DEFINED whether some of the least significant bits are supported. Arm recommends that bits[3:2] are supported.
On a Trace unit reset, this field resets to an architecturally UNKNOWN value.
Accessing the TRCSTALLCTLR
Must be programmed if implemented.
Writes are CONSTRAINED UNPREDICTABLE if the trace unit is not in the Idle state.
TRCSTALLCTLR can be accessed through the external debug interface:
Component | Offset |
---|---|
ETE | 0x02C |
This interface is accessible as follows:
- When OSLockStatus(), or !AllowExternalTraceAccess() or !IsTraceCorePowered() accesses to this register generate an error response.
- Otherwise accesses to this register are RW.