# 28. Debug Unit (DBGU)

# 28.1 Description

The Debug Unit provides a single entry point from the processor for access to all the debug capabilities of Atmel's ARM-based systems.

The Debug Unit features a two-pin UART that can be used for several debug and trace purposes and offers an ideal medium for in-situ programming solutions and debug monitor communications. Moreover, the association with two peripheral data controller channels permits packet handling for these tasks with processor time reduced to a minimum.

The Debug Unit also makes the Debug Communication Channel (DCC) signals provided by the In-circuit Emulator of the ARM processor visible to the software. These signals indicate the status of the DCC read and write registers and generate an interrupt to the ARM processor, making possible the handling of the DCC under interrupt control.

Chip Identifier registers permit recognition of the device and its revision. These registers inform as to the sizes and types of the on-chip memories, as well as the set of embedded peripherals.

Finally, the Debug Unit features a Force NTRST capability that enables the software to decide whether to prevent access to the system via the In-circuit Emulator. This permits protection of the code, stored in ROM.





# 28.2 Block Diagram



Figure 28-1. Debug Unit Functional Block Diagram

# Table 28-1. Debug Unit Pin Description

| Pin Name | Description         | Туре   |
|----------|---------------------|--------|
| DRXD     | Debug Receive Data  | Input  |
| DTXD     | Debug Transmit Data | Output |

Figure 28-2. Debug Unit Application Example



# 28.3 **Product Dependencies**

#### 28.3.1 I/O Lines

Depending on product integration, the Debug Unit pins may be multiplexed with PIO lines. In this case, the programmer must first configure the corresponding PIO Controller to enable I/O lines operations of the Debug Unit.

#### 28.3.2 Power Management

Depending on product integration, the Debug Unit clock may be controllable through the Power Management Controller. In this case, the programmer must first configure the PMC to enable the Debug Unit clock. Usually, the peripheral identifier used for this purpose is 1.

### 28.3.3 Interrupt Source

Depending on product integration, the Debug Unit interrupt line is connected to one of the interrupt sources of the Advanced Interrupt Controller. Interrupt handling requires programming of the AIC before configuring the Debug Unit. Usually, the Debug Unit interrupt line connects to the interrupt source 1 of the AIC, which may be shared with the real-time clock, the system timer interrupt lines and other system peripheral interrupts, as shown in Figure 28-1. This sharing requires the programmer to determine the source of the interrupt when the source 1 is triggered.

# 28.4 UART Operations

The Debug Unit operates as a UART, (asynchronous mode only) and supports only 8-bit character handling (with parity). It has no clock pin.

The Debug Unit's UART is made up of a receiver and a transmitter that operate independently, and a common baud rate generator. Receiver timeout and transmitter time guard are not implemented. However, all the implemented features are compatible with those of a standard USART.

#### 28.4.1 Baud Rate Generator

The baud rate generator provides the bit period clock named baud rate clock to both the receiver and the transmitter.

The baud rate clock is the master clock divided by 16 times the value (CD) written in DBGU\_BRGR (Baud Rate Generator Register). If DBGU\_BRGR is set to 0, the baud rate clock is disabled and the Debug Unit's UART remains inactive. The maximum allowable baud rate is Master Clock divided by 16. The minimum allowable baud rate is Master Clock divided by (16 x 65536).

Baud Rate = 
$$\frac{MCK}{16 \times CD}$$



#### Figure 28-3. Baud Rate Generator



#### 28.4.2 Receiver

28.4.2.1 Receiver Reset, Enable and Disable

After device reset, the Debug Unit receiver is disabled and must be enabled before being used. The receiver can be enabled by writing the control register DBGU\_CR with the bit RXEN at 1. At this command, the receiver starts looking for a start bit.

The programmer can disable the receiver by writing DBGU\_CR with the bit RXDIS at 1. If the receiver is waiting for a start bit, it is immediately stopped. However, if the receiver has already detected a start bit and is receiving the data, it waits for the stop bit before actually stopping its operation.

The programmer can also put the receiver in its reset state by writing DBGU\_CR with the bit RSTRX at 1. In doing so, the receiver immediately stops its current operations and is disabled, whatever its current state. If RSTRX is applied when data is being processed, this data is lost.

#### 28.4.2.2 Start Detection and Data Sampling

The Debug Unit only supports asynchronous operations, and this affects only its receiver. The Debug Unit receiver detects the start of a received character by sampling the DRXD signal until it detects a valid start bit. A low level (space) on DRXD is interpreted as a valid start bit if it is detected for more than 7 cycles of the sampling clock, which is 16 times the baud rate. Hence, a space that is longer than 7/16 of the bit period is detected as a valid start bit. A space which is 7/16 of a bit period or shorter is ignored and the receiver continues to wait for a valid start bit.

When a valid start bit has been detected, the receiver samples the DRXD at the theoretical midpoint of each bit. It is assumed that each bit lasts 16 cycles of the sampling clock (1-bit period) so the bit sampling point is eight cycles (0.5-bit period) after the start of the bit. The first sampling point is therefore 24 cycles (1.5-bit periods) after the falling edge of the start bit was detected.

Each subsequent bit is sampled 16 cycles (1-bit period) after the previous one.



#### Figure 28-4. Start Bit Detection



#### Figure 28-5. Character Reception

Example: 8-bit, parity enabled 1 stop



#### 28.4.2.3 Receiver Ready

When a complete character is received, it is transferred to the DBGU\_RHR and the RXRDY status bit in DBGU\_SR (Status Register) is set. The bit RXRDY is automatically cleared when the receive holding register DBGU\_RHR is read.

#### Figure 28-6. Receiver Ready



#### 28.4.2.4 Receiver Overrun

If DBGU\_RHR has not been read by the software (or the Peripheral Data Controller) since the last transfer, the RXRDY bit is still set and a new character is received, the OVRE status bit in DBGU\_SR is set. OVRE is cleared when the software writes the control register DBGU\_CR with the bit RSTSTA (Reset Status) at 1.

#### Figure 28-7. Receiver Overrun



28.4.2.5 Parity Error

Each time a character is received, the receiver calculates the parity of the received data bits, in accordance with the field PAR in DBGU\_MR. It then compares the result with the received parity



# AT91SAM9260

bit. If different, the parity error bit PARE in DBGU\_SR is set at the same time the RXRDY is set. The parity bit is cleared when the control register DBGU\_CR is written with the bit RSTSTA (Reset Status) at 1. If a new character is received before the reset status command is written, the PARE bit remains at 1.

#### Figure 28-8. Parity Error



#### 28.4.2.6 Receiver Framing Error

When a start bit is detected, it generates a character reception when all the data bits have been sampled. The stop bit is also sampled and when it is detected at 0, the FRAME (Framing Error) bit in DBGU\_SR is set at the same time the RXRDY bit is set. The bit FRAME remains high until the control register DBGU\_CR is written with the bit RSTSTA at 1.

#### Figure 28-9. Receiver Framing Error



#### 28.4.3 Transmitter

#### 28.4.3.1 Transmitter Reset, Enable and Disable

After device reset, the Debug Unit transmitter is disabled and it must be enabled before being used. The transmitter is enabled by writing the control register DBGU\_CR with the bit TXEN at 1. From this command, the transmitter waits for a character to be written in the Transmit Holding Register DBGU\_THR before actually starting the transmission.

The programmer can disable the transmitter by writing DBGU\_CR with the bit TXDIS at 1. If the transmitter is not operating, it is immediately stopped. However, if a character is being processed into the Shift Register and/or a character has been written in the Transmit Holding Register, the characters are completed before the transmitter is actually stopped.

The programmer can also put the transmitter in its reset state by writing the DBGU\_CR with the bit RSTTX at 1. This immediately stops the transmitter, whether or not it is processing characters.

#### 28.4.3.2 Transmit Format

The Debug Unit transmitter drives the pin DTXD at the baud rate clock speed. The line is driven depending on the format defined in the Mode Register and the data stored in the Shift Register. One start bit at level 0, then the 8 data bits, from the lowest to the highest bit, one optional parity bit and one stop bit at 1 are consecutively shifted out as shown on the following figure. The field



PARE in the mode register DBGU\_MR defines whether or not a parity bit is shifted out. When a parity bit is enabled, it can be selected between an odd parity, an even parity, or a fixed space or mark bit.

#### Figure 28-10. Character Transmission



#### 28.4.3.3 Transmitter Control

When the transmitter is enabled, the bit TXRDY (Transmitter Ready) is set in the status register DBGU\_SR. The transmission starts when the programmer writes in the Transmit Holding Register DBGU\_THR, and after the written character is transferred from DBGU\_THR to the Shift Register. The bit TXRDY remains high until a second character is written in DBGU\_THR. As soon as the first character is completed, the last character written in DBGU\_THR is transferred into the shift register and TXRDY rises again, showing that the holding register is empty.

When both the Shift Register and the DBGU\_THR are empty, i.e., all the characters written in DBGU\_THR have been processed, the bit TXEMPTY rises after the last stop bit has been completed.



#### Figure 28-11. Transmitter Control

28.4.4 Peripheral Data Controller

Both the receiver and the transmitter of the Debug Unit's UART are generally connected to a Peripheral Data Controller (PDC) channel.

The peripheral data controller channels are programmed via registers that are mapped within the Debug Unit user interface from the offset 0x100. The status bits are reported in the Debug Unit status register DBGU\_SR and can generate an interrupt.



The RXRDY bit triggers the PDC channel data transfer of the receiver. This results in a read of the data in DBGU\_RHR. The TXRDY bit triggers the PDC channel data transfer of the transmitter. This results in a write of a data in DBGU\_THR.

#### 28.4.5 Test Modes

The Debug Unit supports three tests modes. These modes of operation are programmed by using the field CHMODE (Channel Mode) in the mode register DBGU\_MR.

The Automatic Echo mode allows bit-by-bit retransmission. When a bit is received on the DRXD line, it is sent to the DTXD line. The transmitter operates normally, but has no effect on the DTXD line.

The Local Loopback mode allows the transmitted characters to be received. DTXD and DRXD pins are not used and the output of the transmitter is internally connected to the input of the receiver. The DRXD pin level has no effect and the DTXD line is held high, as in idle state.

The Remote Loopback mode directly connects the DRXD pin to the DTXD line. The transmitter and the receiver are disabled and have no effect. This mode allows a bit-by-bit retransmission.





### 28.4.6 Debug Communication Channel Support

The Debug Unit handles the signals COMMRX and COMMTX that come from the Debug Communication Channel of the ARM Processor and are driven by the In-circuit Emulator.



The Debug Communication Channel contains two registers that are accessible through the ICE Breaker on the JTAG side and through the coprocessor 0 on the ARM Processor side.

As a reminder, the following instructions are used to read and write the Debug Communication Channel:

MRC p14, 0, Rd, c1, c0, 0

Returns the debug communication data read register into Rd

MCR p14, 0, Rd, c1, c0, 0

Writes the value in Rd to the debug communication data write register.

The bits COMMRX and COMMTX, which indicate, respectively, that the read register has been written by the debugger but not yet read by the processor, and that the write register has been written by the processor and not yet read by the debugger, are wired on the two highest bits of the status register DBGU\_SR. These bits can generate an interrupt. This feature permits handling under interrupt a debug link between a debug monitor running on the target system and a debugger.

#### 28.4.7 Chip Identifier

The Debug Unit features two chip identifier registers, DBGU\_CIDR (Chip ID Register) and DBGU\_EXID (Extension ID). Both registers contain a hard-wired value that is read-only. The first register contains the following fields:

- EXT shows the use of the extension identifier register
- NVPTYP and NVPSIZ identifies the type of embedded non-volatile memory and its size
- · ARCH identifies the set of embedded peripherals
- SRAMSIZ indicates the size of the embedded SRAM
- EPROC indicates the embedded ARM processor
- VERSION gives the revision of the silicon

The second register is device-dependent and reads 0 if the bit EXT is 0.

#### 28.4.8 ICE Access Prevention

The Debug Unit allows blockage of access to the system through the ARM processor's ICE interface. This feature is implemented via the register Force NTRST (DBGU\_FNR), that allows assertion of the NTRST signal of the ICE Interface. Writing the bit FNTRST (Force NTRST) to 1 in this register prevents any activity on the TAP controller.

On standard devices, the bit FNTRST resets to 0 and thus does not prevent ICE access.

This feature is especially useful on custom ROM devices for customers who do not want their on-chip code to be visible.



# 28.5 Debug Unit (DBGU) User Interface

| Offset          | Register                     | Name      | Access     | Reset |
|-----------------|------------------------------|-----------|------------|-------|
| 0x0000          | Control Register             | DBGU_CR   | Write-only | _     |
| 0x0004          | Mode Register                | DBGU_MR   | Read-write | 0x0   |
| 0x0008          | Interrupt Enable Register    | DBGU_IER  | Write-only | _     |
| 0x000C          | Interrupt Disable Register   | DBGU_IDR  | Write-only | _     |
| 0x0010          | Interrupt Mask Register      | DBGU_IMR  | Read-only  | 0x0   |
| 0x0014          | Status Register              | DBGU_SR   | Read-only  | -     |
| 0x0018          | Receive Holding Register     | DBGU_RHR  | Read-only  | 0x0   |
| 0x001C          | Transmit Holding Register    | DBGU_THR  | Write-only | -     |
| 0x0020          | Baud Rate Generator Register | DBGU_BRGR | Read-write | 0x0   |
| 0x0024 - 0x003C | Reserved                     | -         | _          | -     |
| 0x0040          | Chip ID Register             | DBGU_CIDR | Read-only  | -     |
| 0x0044          | Chip ID Extension Register   | DBGU_EXID | Read-only  | -     |
| 0x0048          | Force NTRST Register         | DBGU_FNR  | Read-write | 0x0   |
| 0x004C - 0x00FC | Reserved                     | -         | _          | -     |
| 0x0100 - 0x0124 | PDC Area                     | -         | _          | _     |

# Table 28-2. Register Mapping



# 28.5.1 Debug Unit Control Register

| Namo  |  |
|-------|--|
| name. |  |

DBGU CR

| Write-only |
|------------|
|            |

| 31    | 30   | 29    | 28   | 27    | 26    | 25 | 24     |
|-------|------|-------|------|-------|-------|----|--------|
| -     | -    | -     | -    | -     |       | Ι  | —      |
| 23    | 22   | 21    | 20   | 19    | 18    | 17 | 16     |
| -     | -    | -     | -    | -     |       | Ι  | —      |
| 15    | 14   | 13    | 12   | 11    | 10    | 9  | 8      |
| -     | -    | -     | -    | —     | -     | Ι  | RSTSTA |
| 7     | 6    | 5     | 4    | 3     | 2     | 1  | 0      |
| TXDIS | TXEN | RXDIS | RXEN | RSTTX | RSTRX | -  | _      |

#### • RSTRX: Reset Receiver

0 = No effect.

1 = The receiver logic is reset and disabled. If a character is being received, the reception is aborted.

### • RSTTX: Reset Transmitter

0 = No effect.

1 = The transmitter logic is reset and disabled. If a character is being transmitted, the transmission is aborted.

### • RXEN: Receiver Enable

0 = No effect.

1 = The receiver is enabled if RXDIS is 0.

### • RXDIS: Receiver Disable

0 = No effect.

1 = The receiver is disabled. If a character is being processed and RSTRX is not set, the character is completed before the receiver is stopped.

### • TXEN: Transmitter Enable

0 = No effect.

1 = The transmitter is enabled if TXDIS is 0.

### • TXDIS: Transmitter Disable

0 = No effect.

1 = The transmitter is disabled. If a character is being processed and a character has been written the DBGU\_THR and RSTTX is not set, both characters are completed before the transmitter is stopped.

### • RSTSTA: Reset Status Bits

0 = No effect.

1 = Resets the status bits PARE, FRAME and OVRE in the DBGU\_SR.



# 28.5.2 Debug Unit Mode Register

Name:

DBGU\_MR

Access Type: Read-write

| 31  | 30   | 29 | 28 | 27 | 26  | 25 | 24 |
|-----|------|----|----|----|-----|----|----|
| -   | —    | Ι  | -  | -  | -   | Ι  | —  |
| 23  | 22   | 21 | 20 | 19 | 18  | 17 | 16 |
| -   | —    | -  | -  | -  | -   | -  | -  |
| 15  | 14   | 13 | 12 | 11 | 10  | 9  | 8  |
| CHM | IODE | Ι  | -  |    | PAR |    | _  |
| 7   | 6    | 5  | 4  | 3  | 2   | 1  | 0  |
| —   | —    | _  | _  | _  | _   | _  | —  |

### • PAR: Parity Type

| PAR |   |   | Parity Type               |
|-----|---|---|---------------------------|
| 0   | 0 | 0 | Even parity               |
| 0   | 0 | 1 | Odd parity                |
| 0   | 1 | 0 | Space: parity forced to 0 |
| 0   | 1 | 1 | Mark: parity forced to 1  |
| 1   | x | x | No parity                 |

# • CHMODE: Channel Mode

| CHMODE |   | Mode Description |
|--------|---|------------------|
| 0      | 0 | Normal Mode      |
| 0      | 1 | Automatic Echo   |
| 1      | 0 | Local Loopback   |
| 1      | 1 | Remote Loopback  |



## 28.5.3 Debug Unit Interrupt Enable Register

| Na  | mo    |
|-----|-------|
| 110 | IIIC. |

DBGU\_IER

| Access Type: | Write-or | nly  |        |        |    |         |       |
|--------------|----------|------|--------|--------|----|---------|-------|
| 31           | 30       | 29   | 28     | 27     | 26 | 25      | 24    |
| COMMRX       | COMMTX   | _    | -      | -      | —  | -       | —     |
| 23           | 22       | 21   | 20     | 19     | 18 | 17      | 16    |
| -            | -        | _    | -      | -      | —  | -       | -     |
| 15           | 14       | 13   | 12     | 11     | 10 | 9       | 8     |
| —            | -        | -    | RXBUFF | TXBUFE | —  | TXEMPTY | _     |
| 7            | 6        | 5    | 4      | 3      | 2  | 1       | 0     |
| PARE         | FRAME    | OVRE | ENDTX  | ENDRX  | _  | TXRDY   | RXRDY |

- RXRDY: Enable RXRDY Interrupt
- TXRDY: Enable TXRDY Interrupt
- ENDRX: Enable End of Receive Transfer Interrupt
- ENDTX: Enable End of Transmit Interrupt
- OVRE: Enable Overrun Error Interrupt
- FRAME: Enable Framing Error Interrupt
- PARE: Enable Parity Error Interrupt
- TXEMPTY: Enable TXEMPTY Interrupt
- TXBUFE: Enable Buffer Empty Interrupt
- RXBUFF: Enable Buffer Full Interrupt
- COMMTX: Enable COMMTX (from ARM) Interrupt
- COMMRX: Enable COMMRX (from ARM) Interrupt
- 0 = No effect.

1 = Enables the corresponding interrupt.



## 28.5.4 Debug Unit Interrupt Disable Register

| Na  | m | Δ. |
|-----|---|----|
| 110 |   | с. |

DBGU\_IDR

| Access Type: | Write-o | nly  |        |        |    |         |       |
|--------------|---------|------|--------|--------|----|---------|-------|
| 31           | 30      | 29   | 28     | 27     | 26 | 25      | 24    |
| COMMRX       | COMMTX  | -    | -      | -      | -  | -       | -     |
| 23           | 22      | 21   | 20     | 19     | 18 | 17      | 16    |
| -            | —       | -    | -      | -      | -  | -       | -     |
| 15           | 14      | 13   | 12     | 11     | 10 | 9       | 8     |
| -            | _       | Ι    | RXBUFF | TXBUFE | Ι  | TXEMPTY | —     |
| 7            | 6       | 5    | 4      | 3      | 2  | 1       | 0     |
| PARE         | FRAME   | OVRE | ENDTX  | ENDRX  | -  | TXRDY   | RXRDY |

- RXRDY: Disable RXRDY Interrupt
- TXRDY: Disable TXRDY Interrupt
- ENDRX: Disable End of Receive Transfer Interrupt
- ENDTX: Disable End of Transmit Interrupt
- OVRE: Disable Overrun Error Interrupt
- FRAME: Disable Framing Error Interrupt
- PARE: Disable Parity Error Interrupt
- TXEMPTY: Disable TXEMPTY Interrupt
- TXBUFE: Disable Buffer Empty Interrupt
- RXBUFF: Disable Buffer Full Interrupt
- COMMTX: Disable COMMTX (from ARM) Interrupt
- COMMRX: Disable COMMRX (from ARM) Interrupt
- 0 = No effect.

1 = Disables the corresponding interrupt.



## 28.5.5 Debug Unit Interrupt Mask Register

Name:

DBGU\_IMR

| Access Type: | Read-or | nly  |        |        |    |         |       |
|--------------|---------|------|--------|--------|----|---------|-------|
| 31           | 30      | 29   | 28     | 27     | 26 | 25      | 24    |
| COMMRX       | COMMTX  | -    | -      | -      | -  | -       | -     |
| 23           | 22      | 21   | 20     | 19     | 18 | 17      | 16    |
| _            | -       | -    | -      | -      | -  | -       | -     |
| 15           | 14      | 13   | 12     | 11     | 10 | 9       | 8     |
| -            | -       | -    | RXBUFF | TXBUFE | -  | TXEMPTY | _     |
| 7            | 6       | 5    | 4      | 3      | 2  | 1       | 0     |
| PARE         | FRAME   | OVRE | ENDTX  | ENDRX  | _  | TXRDY   | RXRDY |

- RXRDY: Mask RXRDY Interrupt
- TXRDY: Disable TXRDY Interrupt
- ENDRX: Mask End of Receive Transfer Interrupt
- ENDTX: Mask End of Transmit Interrupt
- OVRE: Mask Overrun Error Interrupt
- FRAME: Mask Framing Error Interrupt
- PARE: Mask Parity Error Interrupt
- TXEMPTY: Mask TXEMPTY Interrupt
- TXBUFE: Mask TXBUFE Interrupt
- RXBUFF: Mask RXBUFF Interrupt
- COMMTX: Mask COMMTX Interrupt
- COMMRX: Mask COMMRX Interrupt
- 0 = The corresponding interrupt is disabled.

1 = The corresponding interrupt is enabled.



# 28.5.6 Debug Unit Status Register

Name:

DBGU SR

Access Type: Read-only

| 31     | 30     | 29   | 28     | 27     | 26 | 25      | 24    |
|--------|--------|------|--------|--------|----|---------|-------|
| COMMRX | COMMTX | -    | -      | -      | -  | -       | -     |
| 23     | 22     | 21   | 20     | 19     | 18 | 17      | 16    |
| _      | -      |      | -      | -      | -  | -       | -     |
| 15     | 14     | 13   | 12     | 11     | 10 | 9       | 8     |
| _      | -      | _    | RXBUFF | TXBUFE | -  | TXEMPTY | -     |
| 7      | 6      | 5    | 4      | 3      | 2  | 1       | 0     |
| PARE   | FRAME  | OVRE | ENDTX  | ENDRX  | _  | TXRDY   | RXRDY |

### • RXRDY: Receiver Ready

0 = No character has been received since the last read of the DBGU\_RHR or the receiver is disabled.

1 = At least one complete character has been received, transferred to DBGU\_RHR and not yet read.

### • TXRDY: Transmitter Ready

0 = A character has been written to DBGU\_THR and not yet transferred to the Shift Register, or the transmitter is disabled.

1 = There is no character written to DBGU\_THR not yet transferred to the Shift Register.

# • ENDRX: End of Receiver Transfer

0 = The End of Transfer signal from the receiver Peripheral Data Controller channel is inactive.

1 = The End of Transfer signal from the receiver Peripheral Data Controller channel is active.

### • ENDTX: End of Transmitter Transfer

0 = The End of Transfer signal from the transmitter Peripheral Data Controller channel is inactive.

1 = The End of Transfer signal from the transmitter Peripheral Data Controller channel is active.

### OVRE: Overrun Error

0 = No overrun error has occurred since the last RSTSTA.

1 = At least one overrun error has occurred since the last RSTSTA.

### • FRAME: Framing Error

0 = No framing error has occurred since the last RSTSTA.

1 = At least one framing error has occurred since the last RSTSTA.

### • PARE: Parity Error

0 = No parity error has occurred since the last RSTSTA.

1 = At least one parity error has occurred since the last RSTSTA.

### • TXEMPTY: Transmitter Empty

0 = There are characters in DBGU\_THR, or characters being processed by the transmitter, or the transmitter is disabled.

1 = There are no characters in DBGU\_THR and there are no characters being processed by the transmitter.



# AT91SAM9260

#### • TXBUFE: Transmission Buffer Empty

0 = The buffer empty signal from the transmitter PDC channel is inactive.

1 = The buffer empty signal from the transmitter PDC channel is active.

#### • RXBUFF: Receive Buffer Full

0 = The buffer full signal from the receiver PDC channel is inactive.

1 = The buffer full signal from the receiver PDC channel is active.

# • COMMTX: Debug Communication Channel Write Status

- 0 = COMMTX from the ARM processor is inactive.
- 1 = COMMTX from the ARM processor is active.

#### • COMMRX: Debug Communication Channel Read Status

0 = COMMRX from the ARM processor is inactive.

1 = COMMRX from the ARM processor is active.



# 28.5.7 Debug Unit Receiver Holding Register

| Access Type:       Read-only         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 | Name:        | DBGU_RHR |      |    |     |    |    |    |  |  |
|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------|----------|------|----|-----|----|----|----|--|--|
| 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                                                                                                                                                                  | Access Type: | Read-o   | only |    |     |    |    |    |  |  |
| -     -     -     -     -     -       23     22     21     20     19     18     17     16       -     -     -     -     -     -     -     -       15     14     13     12     11     10     9     8       -     -     -     -     -     -     -       7     6     5     4     3     2     1     0                                                                                                                                                                                                                                        | 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                                                                                                                                                                                                                                                                              | _            | _        | _    | -  | _   | _  | _  | -  |  |  |
| -     -     -     -     -     -       15     14     13     12     11     10     9     8       -     -     -     -     -     -     -       7     6     5     4     3     2     1     0                                                                                                                                                                                                                                                                                                                                                    | 23           | 22       | 21   | 20 | 19  | 18 | 17 | 16 |  |  |
| 15     14     13     12     11     10     9     8       -     -     -     -     -     -     -     -       7     6     5     4     3     2     1     0       BXCHB                                                                                                                                                                                                                                                                                                                                                                        | -            | —        | _    | -  | -   | —  | -  | -  |  |  |
| -     -     -     -     -     -       7     6     5     4     3     2     1     0                                                                                                                                                                                                                                                                                                                                                                                                                                                        | 15           | 14       | 13   | 12 | 11  | 10 | 9  | 8  |  |  |
| 7 6 5 4 3 2 1 0<br>BXCHR                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | _            | —        | _    | -  | _   | —  | Ι  | -  |  |  |
| BXCHB                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | 7            | 6        | 5    | 4  | 3   | 2  | 1  | 0  |  |  |
| •••••                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |              |          |      | RX | CHR |    |    |    |  |  |

### • RXCHR: Received Character

Last received character if RXRDY is set.

# 28.5.8 Debug Unit Transmit Holding Register

| Name:        | DBGU_THR |      |    |      |    |    |    |  |  |
|--------------|----------|------|----|------|----|----|----|--|--|
| Access Type: | Write-o  | only |    |      |    |    |    |  |  |
| 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  |  |  |
|              |          |      | TX | CHR  |    |    |    |  |  |

# • TXCHR: Character to be Transmitted

Next character to be transmitted after the current character if TXRDY is not set.



# 28.5.9 Debug Unit Baud Rate Generator Register

| Name:        | DBGU_BRGR |       |    |    |    |    |    |  |  |
|--------------|-----------|-------|----|----|----|----|----|--|--|
| Access Type: | Read-w    | vrite |    |    |    |    |    |  |  |
| 31           | 30        | 29    | 28 | 27 | 26 | 25 | 24 |  |  |
| _            | _         | _     | -  | _  | _  | _  | -  |  |  |
| 23           | 22        | 21    | 20 | 19 | 18 | 17 | 16 |  |  |
| -            | —         | -     | -  | -  | —  | _  | -  |  |  |
| 15           | 14        | 13    | 12 | 11 | 10 | 9  | 8  |  |  |
|              |           |       | С  | D  |    |    |    |  |  |
| 7            | 6         | 5     | 4  | 3  | 2  | 1  | 0  |  |  |
|              |           |       | C  | D  |    |    |    |  |  |
|              |           |       |    |    |    |    |    |  |  |

# • CD: Clock Divisor

| CD         | Baud Rate Clock |
|------------|-----------------|
| 0          | Disabled        |
| 1          | MCK             |
| 2 to 65535 | MCK / (CD x 16) |



# 28.5.10 Debug Unit Chip ID Register

| Name:        | DBGU_   | DBGU_CIDR |    |         |     |      |    |  |
|--------------|---------|-----------|----|---------|-----|------|----|--|
| Access Type: | Read-or | nly       |    |         |     |      |    |  |
| 31           | 30      | 29        | 28 | 27      | 26  | 25   | 24 |  |
| EXT          |         | NVPTYP    |    |         | AR  | CH   |    |  |
| 23           | 22      | 21        | 20 | 19      | 18  | 17   | 16 |  |
|              | AF      | RCH       |    | SRAMSIZ |     |      |    |  |
| 15           | 14      | 13        | 12 | 11      | 10  | 9    | 8  |  |
|              | NVPSIZ2 |           |    |         | NVF | PSIZ |    |  |
| 7            | 6       | 5         | 4  | 3       | 2   | 1    | 0  |  |
| EPROC        |         |           |    | VERSION |     |      |    |  |
|              |         |           |    |         |     |      |    |  |

### • VERSION: Version of the Device

Current version of the device.

### • EPROC: Embedded Processor

| EPROC |   |   | Processor |
|-------|---|---|-----------|
| 0     | 0 | 1 | ARM946ES  |
| 0     | 1 | 0 | ARM7TDMI  |
| 1     | 0 | 0 | ARM920T   |
| 1     | 0 | 1 | ARM926EJS |

# • NVPSIZ: Nonvolatile Program Memory Size

|   | NVF | PSIZ | Size |             |
|---|-----|------|------|-------------|
| 0 | 0   | 0    | 0    | None        |
| 0 | 0   | 0    | 1    | 8K bytes    |
| 0 | 0   | 1    | 0    | 16K bytes   |
| 0 | 0   | 1    | 1    | 32K bytes   |
| 0 | 1   | 0    | 0    | Reserved    |
| 0 | 1   | 0    | 1    | 64K bytes   |
| 0 | 1   | 1    | 0    | Reserved    |
| 0 | 1   | 1    | 1    | 128K bytes  |
| 1 | 0   | 0    | 0    | Reserved    |
| 1 | 0   | 0    | 1    | 256K bytes  |
| 1 | 0   | 1    | 0    | 512K bytes  |
| 1 | 0   | 1    | 1    | Reserved    |
| 1 | 1   | 0    | 0    | 1024K bytes |
| 1 | 1   | 0    | 1    | Reserved    |
| 1 | 1   | 1    | 0    | 2048K bytes |
| 1 | 1   | 1    | 1    | Reserved    |



# AT91SAM9260

# NVPSIZ2 Second Nonvolatile Program Memory Size

|   | NVP | SIZ2 | Size |             |
|---|-----|------|------|-------------|
| 0 | 0   | 0    | 0    | None        |
| 0 | 0   | 0    | 1    | 8K bytes    |
| 0 | 0   | 1    | 0    | 16K bytes   |
| 0 | 0   | 1    | 1    | 32K bytes   |
| 0 | 1   | 0    | 0    | Reserved    |
| 0 | 1   | 0    | 1    | 64K bytes   |
| 0 | 1   | 1    | 0    | Reserved    |
| 0 | 1   | 1    | 1    | 128K bytes  |
| 1 | 0   | 0    | 0    | Reserved    |
| 1 | 0   | 0    | 1    | 256K bytes  |
| 1 | 0   | 1    | 0    | 512K bytes  |
| 1 | 0   | 1    | 1    | Reserved    |
| 1 | 1   | 0    | 0    | 1024K bytes |
| 1 | 1   | 0    | 1    | Reserved    |
| 1 | 1   | 1    | 0    | 2048K bytes |
| 1 | 1   | 1    | 1    | Reserved    |

### • SRAMSIZ: Internal SRAM Size

|   | SRA | MSIZ | Size |            |
|---|-----|------|------|------------|
| 0 | 0   | 0    | 0    | Reserved   |
| 0 | 0   | 0    | 1    | 1K bytes   |
| 0 | 0   | 1    | 0    | 2K bytes   |
| 0 | 0   | 1    | 1    | 6K bytes   |
| 0 | 1   | 0    | 0    | 112K bytes |
| 0 | 1   | 0    | 1    | 4K bytes   |
| 0 | 1   | 1    | 0    | 80K bytes  |
| 0 | 1   | 1    | 1    | 160K bytes |
| 1 | 0   | 0    | 0    | 8K bytes   |
| 1 | 0   | 0    | 1    | 16K bytes  |
| 1 | 0   | 1    | 0    | 32K bytes  |
| 1 | 0   | 1    | 1    | 64K bytes  |
| 1 | 1   | 0    | 0    | 128K bytes |
| 1 | 1   | 0    | 1    | 256K bytes |
| 1 | 1   | 1    | 0    | 96K bytes  |
| 1 | 1   | 1    | 1    | 512K bytes |



### • ARCH: Architecture Identifier

| AR   | СН        |                     |
|------|-----------|---------------------|
| Hex  | Bin       | Architecture        |
| 0x19 | 0001 1001 | AT91SAM9xx Series   |
| 0x29 | 0010 1001 | AT91SAM9XExx Series |
| 0x34 | 0011 0100 | AT91x34 Series      |
| 0x37 | 0011 0111 | CAP7 Series         |
| 0x39 | 0011 1001 | CAP9 Series         |
| 0x3B | 0011 1011 | CAP11 Series        |
| 0x40 | 0100 0000 | AT91x40 Series      |
| 0x42 | 0100 0010 | AT91x42 Series      |
| 0x55 | 0101 0101 | AT91x55 Series      |
| 0x60 | 0110 0000 | AT91SAM7Axx Series  |
| 0x61 | 0110 0001 | AT91SAM7AQxx Series |
| 0x63 | 0110 0011 | AT91x63 Series      |
| 0x70 | 0111 0000 | AT91SAM7Sxx Series  |
| 0x71 | 0111 0001 | AT91SAM7XCxx Series |
| 0x72 | 0111 0010 | AT91SAM7SExx Series |
| 0x73 | 0111 0011 | AT91SAM7Lxx Series  |
| 0x75 | 0111 0101 | AT91SAM7Xxx Series  |
| 0x92 | 1001 0010 | AT91x92 Series      |
| 0xF0 | 1111 0000 | AT75Cxx Series      |

# • NVPTYP: Nonvolatile Program Memory Type

| NVPTYP |   |   | Memory                                                                       |  |
|--------|---|---|------------------------------------------------------------------------------|--|
| 0      | 0 | 0 | ROM                                                                          |  |
| 0      | 0 | 1 | ROMIess or on-chip Flash                                                     |  |
| 1      | 0 | 0 | SRAM emulating ROM                                                           |  |
| 0      | 1 | 0 | Embedded Flash Memory                                                        |  |
| 0      | 1 | 1 | ROM and Embedded Flash Memory<br>NVPSIZ is ROM size<br>NVPSIZ2 is Flash size |  |

# • EXT: Extension Flag

0 = Chip ID has a single register definition without extension

1 = An extended Chip ID exists.



# 28.5.11 Debug Unit Chip ID Extension Register

| Name:        | DBGU_EXID |     |    |     |    |    |    |  |
|--------------|-----------|-----|----|-----|----|----|----|--|
| Access Type: | Read-o    | nly |    |     |    |    |    |  |
| 31           | 30        | 29  | 28 | 27  | 26 | 25 | 24 |  |
| EXID         |           |     |    |     |    |    |    |  |
| 23           | 22        | 21  | 20 | 19  | 18 | 17 | 16 |  |
|              |           |     | Ε> | (ID |    |    |    |  |
| 15           | 14        | 13  | 12 | 11  | 10 | 9  | 8  |  |
|              |           |     | Ε> | (ID |    |    |    |  |
| 7            | 6         | 5   | 4  | 3   | 2  | 1  | 0  |  |
|              |           |     | Ε> | (ID |    |    |    |  |

### • EXID: Chip ID Extension

Reads 0 if the bit EXT in DBGU\_CIDR is 0.

# 28.5.12 Debug Unit Force NTRST Register

| Name | DBGU  | FNR        |
|------|-------|------------|
|      | DDGO_ | _1 1 1 1 1 |

Access Type: Read-write

| 31 | 30 | 29 | 28 | 27 | 26 | 25 | 24     |
|----|----|----|----|----|----|----|--------|
| -  | —  | -  | Ι  | Ι  | _  | Ι  | _      |
| 23 | 22 | 21 | 20 | 19 | 18 | 17 | 16     |
| -  | -  | -  | -  | -  | -  | -  | -      |
| 15 | 14 | 13 | 12 | 11 | 10 | 9  | 8      |
| -  | —  | 1  |    | Ι  | —  | Ι  | —      |
| 7  | 6  | 5  | 4  | 3  | 2  | 1  | 0      |
| -  | -  | -  | -  | -  | _  | -  | FNTRST |

# • FNTRST: Force NTRST

0 = NTRST of the ARM processor's TAP controller is driven by the power\_on\_reset signal.

1 = NTRST of the ARM processor's TAP controller is held low.





# 332 AT91SAM9260