## TRCIDR2, ID Register 2

The TRCIDR2 characteristics are:

### **Purpose**

Returns the tracing capabilities of the trace unit.

## **Configuration**

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

This register is present only when FEAT\_ETE is implemented and FEAT\_TRC\_EXT is implemented. Otherwise, direct accesses to TRCIDR2 are res0.

### **Attributes**

TRCIDR2 is a 32-bit register.

## Field descriptions

| 31      | 3029 | 28272 | 2625 | 2423 | 3 2 2 | 2120 | 19 | 181 | L7 16 | 5 1 5 | 141 | L3 12 | 2 1 1 | . 10 | 9 8 | 7   | 6  | 5 | 4 | 3   | 2 1 | 0 |
|---------|------|-------|------|------|-------|------|----|-----|-------|-------|-----|-------|-------|------|-----|-----|----|---|---|-----|-----|---|
| WFXMODI | EVMI | ores  | IZE  | D    | VSI   | ZE   |    | DA: | SIZI  |       | V   | MID   | SIZ   | Ξ    | CI  | DSI | ZE |   |   | IAS | IZE |   |

### WFXMODE, bit [31]

Indicates whether WFI, WFIT, WFE, and WFET instructions are classified as PO instructions:

| WFXMODE | Meaning                                                                  |
|---------|--------------------------------------------------------------------------|
| 0b0     | WFI, WFIT, WFE, and WFET                                                 |
|         | instructions are not classified as P0 instructions.                      |
| 0b1     | WFI, WFIT, WFE, and WFET instructions are classified as P0 instructions. |

### **VMIDOPT, bits [30:29]**

Indicates the options for Virtual context identifier selection.

| 00d0 | Virtual context identifier selection not supported.  TRCCONFIGR.VMIDOPT is res0.                                 |
|------|------------------------------------------------------------------------------------------------------------------|
| 0b01 | Virtual context identifier selection supported.  TRCCONFIGR.VMIDOPT is implemented.                              |
| 0b10 | Virtual context identifier selection not supported. <a href="mailto:TRCCONFIGR">TRCCONFIGR</a> .VMIDOPT is res1. |

All other values are reserved.

If TRCIDR2.VMIDSIZE == 0b00000 then this field is 0b00.

If TRCIDR2.VMIDSIZE != 0b00000 then this field is 0b10.

# CCSIZE, bits [28:25] When TRCIDR0.TRCCCI == 1:

Indicates the size of the cycle counter.

| CCSIZE | Meaning                                 |
|--------|-----------------------------------------|
| 000000 | The cycle counter is 12 bits in length. |
| 0b0001 | The cycle counter is 13 bits in length. |
| 0b0010 | The cycle counter is 14 bits in length. |
| 0b0011 | The cycle counter is 15 bits in length. |
| 0b0100 | The cycle counter is 16 bits in length. |
| 0b0101 | The cycle counter is 17 bits in length. |
| 0b0110 | The cycle counter is 18 bits in length. |
| 0b0111 | The cycle counter is 19 bits in length. |
| 0b1000 | The cycle counter is 20 bits in length. |

All other values are reserved.

### Otherwise:

Reserved, res0.

# DVSIZE, bits [24:20] When TRCIDR0.TRCDATA != 0b00:

Indicates the data value size in bytes. Data tracing is not implemented in ETE and this field is reserved for other trace architectures. Allocated in other trace architectures.

| DVSIZE  | Meaning                                                 |
|---------|---------------------------------------------------------|
| 0000000 | Data value tracing not implemented.                     |
| 0b00100 | Data value tracing has a maximum of 32-bit data values. |
| 0b01000 | Data value tracing has a maximum of 64-bit data values. |

All other values are reserved.

#### Otherwise:

Reserved, res0.

## DASIZE, bits [19:15] When TRCIDRO.TRCDATA != 0b00:

Indicates the data address size in bytes. Data tracing is not implemented in ETE and this field is reserved for other trace architectures. Allocated in other trace architectures.

| DASIZE  | Meaning                                                      |
|---------|--------------------------------------------------------------|
| 00000d0 | Data address tracing not implemented.                        |
| 0b00100 | Data address tracing has a maximum of 32-bit data addresses. |
| 0b01000 | Data address tracing has a maximum of 64-bit data addresses. |

All other values are reserved.

#### Otherwise:

Reserved, res0.

### VMIDSIZE, bits [14:10]

Indicates the trace unit Virtual context identifier size.

| VMIDSIZE | Meaning                    |
|----------|----------------------------|
| 0000000  | Virtual context identifier |
|          | tracing is not supported.  |
| 0b00001  | 8-bit Virtual context      |
|          | identifier size.           |
| 0b00010  | 16-bit Virtual context     |
|          | identifier size.           |
| 0b00100  | 32-bit Virtual context     |
|          | identifier size.           |

All other values are reserved.

If the PE does not implement EL2 then this field is 0b00000.

If the PE implements EL2 then this field is 0b00100.

### CIDSIZE, bits [9:5]

Indicates the Context identifier size.

| CIDSIZE | Meaning                         |  |  |  |
|---------|---------------------------------|--|--|--|
| 0000000 | Context identifier tracing is   |  |  |  |
|         | not supported.                  |  |  |  |
| 0b00100 | 32-bit Context identifier size. |  |  |  |

All other values are reserved.

This field reads as 0b00100.

### IASIZE, bits [4:0]

Virtual instruction address size.

| IASIZE  | Meaning                       |
|---------|-------------------------------|
| 0b00100 | Maximum of 32-bit instruction |
|         | address size.                 |
| 0b01000 | Maximum of 64-bit instruction |
|         | address size.                 |

All other values are reserved.

This field reads as 0b01000.

## **Accessing TRCIDR2**

### TRCIDR2 can be accessed through the external debug interface:

| Component | Offset | Instance |
|-----------|--------|----------|
| ETE       | 0x1E8  | TRCIDR2  |

This interface is accessible as follows:

- When OSLockStatus() or !IsTraceCorePowered(), accesses to this register generate an error response.
- Otherwise, accesses to this register are **RO**.

AArch32AArch64AArch32AArch64Index byExternalRegistersRegistersInstructionsInstructionsEncodingRegisters

28/03/2023 16:02; 72747e43966d6b97dcbd230a1b3f0421d1ea3d94

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