# TRCRSR, Resources Status Register

The TRCRSR characteristics are:

## **Purpose**

Use this to set, or read, the status of the resources.

# **Configuration**

AArch64 System register TRCRSR bits [31:0] are architecturally mapped to External register TRCRSR[31:0].

This register is present only when FEAT\_ETE is implemented and FEAT\_TRC\_SR is implemented. Otherwise, direct accesses to TRCRSR are undefined.

#### **Attributes**

TRCRSR is a 64-bit register.

## Field descriptions

| 636261605958575655545352515049484746454 | 14 4    | .3     | 42      | 41       | 40       | <u>39383736</u> | 35       |
|-----------------------------------------|---------|--------|---------|----------|----------|-----------------|----------|
| RES0                                    |         |        |         |          |          |                 |          |
| RES0 T                                  | TA EVEI | NT[3]E | VENT[2] | EVENT[1] | EVENT[0] | RES0            | EXTIN[3] |
| 313029282726252423222120191817161514131 | 12 1    | 1      | 10      | 9        | 8        | 7 6 5 4         | 3        |

#### Bits [63:13]

Reserved, res0.

#### **TA**, bit [12]

Tracing active.

| TA  | Meaning                |
|-----|------------------------|
| 0b0 | Tracing is not active. |
| 0b1 | Tracing is active.     |

The reset behavior of this field is:

• On a Trace unit reset, this field resets to an architecturally unknown value.

#### EVENT[< m>], bit [m+8], for m=3 to 0

Untraced status of ETEEvents.

| EVENT[ <m>]</m> | Meaning                 |
|-----------------|-------------------------|
| 0b0             | An ETEEvent <m> has</m> |
|                 | not occurred.           |
| 0b1             | An ETEEvent <m> has</m> |
|                 | occurred while the      |
|                 | resources were in the   |
|                 | Paused state.           |

This bit is res0 if  $\underline{\text{TRCIDR4}}$ . NUMRSPAIR == 0 || m >  $\underline{\text{TRCIDR0}}$ . NUMEVENT.

The reset behavior of this field is:

• On a Trace unit reset, this field resets to an architecturally unknown value.

#### Bits [7:4]

Reserved, res0.

#### EXTIN[<m>], bit [m], for m = 3 to 0

The sticky status of the External Input Selectors.

| EXTIN[ <m>]</m> | Meaning                    |
|-----------------|----------------------------|
| 0b0             | An event selected by       |
|                 | External Input Selector    |
|                 | <m> has not occurred.</m>  |
| 0b1             | At least one event         |
|                 | selected by External       |
|                 | Input Selector <m> has</m> |
|                 | occurred while the         |
|                 | resources were in the      |
|                 | Paused state.              |

This bit is res0 if  $m \ge TRCIDR5.NUMEXTINSEL$ .

The reset behavior of this field is:

• On a Trace unit reset, this field resets to an architecturally unknown value.

# **Accessing TRCRSR**

Must always be programmed.

Writes are constrained unpredictable if the trace unit is not in the Idle state.

Reads from this register might return an unknown value if the trace unit is not in either of the Idle or Stable states.

Accesses to this register use the following encodings in the System register encoding space:

# MRS <Xt>, TRCRSR

| op0  | op1   | CRn    | CRm    | op2   |
|------|-------|--------|--------|-------|
| 0b10 | 0b001 | 0b0000 | 0b1010 | 0b000 |

```
if PSTATE.EL == ELO 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() &&
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 Halted() && EDSCR.SDD == '1' then
            UNDEFINED;
        else
            AArch64.SystemAccessTrap(EL3, 0x18);
        X[t, 64] = TRCRSR;
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
        X[t, 64] = TRCRSR;
elsif PSTATE.EL == EL3 then
    if CPTR_EL3.TTA == '1' then
        AArch64.SystemAccessTrap(EL3, 0x18);
    else
        X[t, 64] = TRCRSR;
```

## MSR TRCRSR, <Xt>

| op0  | op1   | CRn    | CRm    | op2   |
|------|-------|--------|--------|-------|
| 0b10 | 0b001 | 0b0000 | 0b1010 | 0b000 |

```
if PSTATE.EL == ELO 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() &&
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 Halted() && EDSCR.SDD == '1' then
            UNDEFINED;
        else
            AArch64.SystemAccessTrap(EL3, 0x18);
    else
        TRCRSR = X[t, 64];
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
        TRCRSR = X[t, 64];
elsif PSTATE.EL == EL3 then
    if CPTR EL3.TTA == '1' then
        AArch64.SystemAccessTrap(EL3, 0x18);
    else
        TRCRSR = X[t, 64];
```

|   | 28/03/2023 16:02; 72747e43966d6b97dcbd230a1b3f0421d1ea3d9                                                  |     |
|---|------------------------------------------------------------------------------------------------------------|-----|
| С | opyright © 2010-2023 Arm Limited or its affiliates. All rights reserved. Th<br>document is Non-Confidentia | is  |
|   | document is ivon-confidentic                                                                               | 11. |
|   |                                                                                                            |     |
|   |                                                                                                            |     |
|   |                                                                                                            |     |
|   |                                                                                                            |     |
|   |                                                                                                            |     |
|   |                                                                                                            |     |
|   |                                                                                                            |     |
|   |                                                                                                            |     |
|   |                                                                                                            |     |
|   |                                                                                                            |     |
|   |                                                                                                            |     |
|   |                                                                                                            |     |
|   |                                                                                                            |     |
|   |                                                                                                            |     |
|   |                                                                                                            |     |
|   |                                                                                                            |     |
|   |                                                                                                            |     |
|   |                                                                                                            |     |
|   |                                                                                                            |     |
|   |                                                                                                            |     |
|   |                                                                                                            |     |
|   |                                                                                                            |     |
|   |                                                                                                            |     |
|   |                                                                                                            |     |
|   |                                                                                                            |     |
|   |                                                                                                            |     |
|   |                                                                                                            |     |
|   |                                                                                                            |     |
|   |                                                                                                            |     |
|   |                                                                                                            |     |
|   |                                                                                                            |     |
|   |                                                                                                            |     |