# DBGDTRTX\_ELO, Debug Data Transfer Register, Transmit

The DBGDTRTX EL0 characteristics are:

### **Purpose**

Transfers data from the PE to an external debugger. For example, it is used by a debug target to transfer data to the debugger. See <a href="DBGDTR\_EL0">DBGDTR\_EL0</a> for additional architectural mappings. It is a component of the Debug Communication Channel.

## **Configuration**

External register DBGDTRTX\_EL0 bits [31:0] are architecturally mapped to AArch64 System register DBGDTRTX\_EL0[31:0].

External register DBGDTRTX\_EL0 bits [31:0] are architecturally mapped to AArch32 System register DBGDTRTXint[31:0].

DBGDTRTX EL0 is in the Core power domain.

#### **Attributes**

DBGDTRTX EL0 is a 32-bit register.

### Field descriptions

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

Return DTRTX

#### Bits [31:0]

Return DTRTX.

Reads of this register:

- If TXfull is set to 1, return the last value written to DTRTX.
- If TXfull is set to 0, return an unknown value.

After the read, TXfull is cleared to 0.

Writes to this register:

• If TXfull is set to 1, set DTRTX to unknown.

If TXfull is set to 0, update the value in DTRTX.

After the write, TXfull remains unchanged.

For the full behavior of the Debug Communications Channel, see 'The Debug Communication Channel and Instruction Transfer Register'.

The reset behavior of this field is:

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

# **Accessing DBGDTRTX\_EL0**

If <u>EDSCR</u>.ITE == 0 when the PE exits Debug state on receiving a Restart request trigger event, the behavior of any operation issued by a DTR access in memory access mode that has not completed execution is constrained unpredictable, and must do one of the following:

- It must complete execution in Debug state before the PE executes the restart sequence.
- It must complete execution in Non-debug state before the PE executes the restart sequence.
- It must be abandoned. This means that the instruction does not execute. Any registers or memory accessed by the instruction are left in an unknown state.

#### **DBGDTRTX\_EL0** can be accessed through the external debug interface:

| Component | Offset | Instance     |
|-----------|--------|--------------|
| Debug     | 0x08C  | DBGDTRTX_EL0 |

This interface is accessible as follows:

- When IsCorePowered(), !DoubleLockStatus(), !OSLockStatus() and SoftwareLockStatus(), accesses to this register are **RO**.
- When IsCorePowered(), !DoubleLockStatus(), !OSLockStatus() and ! SoftwareLockStatus(), accesses to this register are **RW**.
- Otherwise, accesses to this register generate an error response.

AArch32AArch64AArch32AArch64Index byExternalRegistersRegistersInstructionsInstructionsEncodingRegisters

28/03/2023 16:02; 72747e43966d6b97dcbd230a1b3f0421d1ea3d94

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