## TRCIDR6, ID Register 6

The TRCIDR6 characteristics are:

### **Purpose**

Returns the tracing capabilities of the trace unit.

### Configuration

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

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

### **Attributes**

TRCIDR6 is a 64-bit register.

### Field descriptions

6362616059585756555453525150494847464544434241403938373635 34 33

| RES0                                                       |                |       |           |       |      |
|------------------------------------------------------------|----------------|-------|-----------|-------|------|
| RES0                                                       | <b>EXLEVEL</b> | RL_EL | 2EXLEVEL_ | RL_EL | 1EXL |
| 21202020272625242222212010101716151412121110 0 0 7 6 5 4 2 | 7              |       | 1         |       |      |

31302928272625242322212019181716151413121110 9 8 7 6 5 4 3

#### Bits [63:3]

Reserved, res0.

#### **EXLEVEL RL EL2, bit [2]**

Indicates if Realm EL2 is implemented.

| EXLEVEL_RL_EL2 | Meaning          |  |  |
|----------------|------------------|--|--|
| 0b0            | Realm EL2 is not |  |  |
|                | implemented.     |  |  |
| 0b1            | Realm EL2 is     |  |  |
|                | implemented.     |  |  |

#### EXLEVEL\_RL\_EL1, bit [1]

Indicates if Realm EL1 is implemented.

| EXLEVEL_RL_EL1 | Meaning          |  |  |
|----------------|------------------|--|--|
| 0b0            | Realm EL1 is not |  |  |
|                | implemented.     |  |  |
| 0b1            | Realm EL1 is     |  |  |
|                | implemented.     |  |  |

#### EXLEVEL\_RL\_ELO, bit [0]

Indicates if Realm EL0 is implemented.

| EXLEVEL_RL_EL0 | Meaning          |  |  |
|----------------|------------------|--|--|
| 0b0            | Realm EL0 is not |  |  |
|                | implemented.     |  |  |
| 0b1            | Realm EL0 is     |  |  |
|                | implemented.     |  |  |

### **Accessing TRCIDR6**

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

# MRS <Xt>, TRCIDR6

| op0  | op1   | CRn    | CRm    | op2   |
|------|-------|--------|--------|-------|
| 0b10 | 0b001 | 0b0000 | 0b1110 | 0b111 |

```
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.TRCID == '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] = TRCIDR6;
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] = TRCIDR6;
elsif PSTATE.EL == EL3 then
    if CPTR_EL3.TTA == '1' then
        AArch64.SystemAccessTrap(EL3, 0x18);
    else
        X[t, 64] = TRCIDR6;
```

AArch32 Registers AArch64 Registers AArch32 Instructions AArch64 Instructions Index by Encoding

External Registers

28/03/2023 16:02; 72747e43966d6b97dcbd230a1b3f0421d1ea3d94

Copyright © 2010-2023 Arm Limited or its affiliates. All rights reserved. This document is Non-Confidential.