## **Trigger Routing Unit**

The trigger routing unit (TRU) provides simple sequence control of distributed modules without the penalties assocaiated with core intervention

Base Address: 32'h1000\_0000

Size(bytes): 0x2020

### **Registers List**

| Offset        | Identifier  | Name                        |
|---------------|-------------|-----------------------------|
| 32'h0000_1FFF | -           | -                           |
| 32'h0000_2000 | TRU_SSRN    | Slave Select Register       |
| 32'h0000_2004 | TRU_MTR     | Master Trigger Register     |
| 32'h0000_2008 | -           | -                           |
| 32'h0000_200C | -           | -                           |
| 32'h0000_2010 | TRU_ERRADDR | Error Address Register      |
| 32'h0000_2014 | TRU_STAT    | Status Information Register |
| 32'h0000_2018 | TRU_GCTL    | Global Control Register     |
| 32'h0000_201C | TRU_RXDATA  | Receive Data Register       |

### **Slave Select Register**

The TRU slave select registers (TRU\_SSRn) each provide slave selection and register locking.

Absolute Address: 32'h0000\_2000 Base Offset: 32'h0000\_2000

Access: RW

**Reset**: 32'h0000\_0000 **Size(bytes)**: 0x4

| Bits   | Identifier | Access | Reset      | Name / Description                                                                                                                                                                                                                                                                   |
|--------|------------|--------|------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31]   | LOCK       | RW     | 1'h0       | SSRn Lock If the global lock is enabled (SPU_CTL_GLCK bit =1) and the TRU_ SSRn.LOCK bit is enabled, the TRU_SSRn register is read only.                                                                                                                                             |
| [30:8] | RESERVED1  | RW     | 23'h0_0000 | Reserved1<br>Reserved bits                                                                                                                                                                                                                                                           |
| [7:0]  | SSR        | RW     | 8'h00      | SSRn Slave Select The TRU_SSRn register selects the trigger master ID to which the trigger slave responds. For example, when a TRU_SSRn register is set to respond to trigger master ID n, a trigger that is generated by trigger master ID n results in a trigger out to the slave. |

### Master Trigger Register

The TRU master trigger register (TRU\_MTR) permits trigger generation through software by writing a trigger master ID value to one of the four fields in the TRU\_MTR register. If the global lock is enabled SPU\_CTL\_GLCK bit =1) and the TRU\_GCTL.LOCK bit is set, the TRU\_MTR register is read only.

Absolute Address: 32'h0000\_2004

Base Offset: 32'h0000\_2004

Access: RW

**Reset**: 32'h0000\_0000 **Size(bytes)**: 0x4

| Bits    | Identifier | Access | Reset | Name / Description        |
|---------|------------|--------|-------|---------------------------|
| [31:24] | MTR3       | RW     | 8'h00 | Master Trigger Register 3 |
| [23:16] | MTR2       | RW     | 8'h00 | Master Trigger Register 2 |
| [15:8]  | MTR1       | RW     | 8'h00 | Master Trigger Register 1 |
| [7:0]   | MTR0       | RW     | 8'h00 | Master Trigger Register 0 |

## **Error Address Register**

The TRU error address register (TRU\_ERRADDR) holds the address from the memory mapped register access generating an access error of TRU registers.

Absolute Address: 32'h0000\_2010

Base Offset: 32'h0000\_2010

Access: RW

**Reset**: 32'h0000\_0000 **Size(bytes)**: 0x4

| Bits    | Identifier | Access | Reset      | Name / Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
|---------|------------|--------|------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:12] | RESERVED1  | RW     | 20'h0_0000 | Reserved1<br>Reserved bits                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| [11:0]  | ADDR       | RW     | 12'h000    | Error Address The TRU_ERRADDR.ADDR holds the address from the memory mapped register access generating an access error of TRU registers. These errors occur on access to the TRU_SSRn or TRU_MTR registers when these registers are locked or on access to an invalid address. See the TRU_SSRn and TRU_MTR register descriptions for more information about locking. The TRU_ERRADDR register holds the address of the first error to occur. In the event of multiple errors occurring, the TRU_ERRADDR register contains the address of the first error. To re-enable the TRU_ERRADDR register for update, both status bits (TRU_STAT.LWERR and TRU_STAT.ADDRERR) in the TRU_STAT register must be cleared. |

# **Status Information Register**

The TRU status register (TRU\_STAT) contains the status of TRU\_MTR and TRU\_SSRn register writes and status of bus read/write errors.

Absolute Address: 32'h0000\_2014

Base Offset: 32'h0000\_2014

Access: RW

**Reset**: 32'h0000\_0000 **Size(bytes)**: 0x4

| Bits   | Identifier | Access | Reset       | Name / Description                                                                                                                                                                                                                                                                                                 |
|--------|------------|--------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31:2] | RESERVED1  | RW     | 30'h00_0000 | Reserved1<br>Reserved bits                                                                                                                                                                                                                                                                                         |
| [1]    | ADDRERR    | RW1C   | 1'h0        | Address Error Status The TRU_STAT.ADDRERR bit is set when an invalid address is provided for an MMR access while the TRU is selected. Writing a one to this bit clears the error indication. The TRU_ERRADDR register also is updated when an address error occurs during an MMR access while the TRU is selected. |
| [0]    | LWERR      | RW1C   | 1'h0        | Lock Write Error Status If TRU_STAT.LWERR is set, a lock write error has occurred. Writing a one to this bit clears the error indication.                                                                                                                                                                          |

## **Global Control Register**

The TRU global control register (TRU\_GCTL) provides register locking, TRU reset, and TRU enable.

 $\textbf{Absolute Address}: 32 \text{'}h0000\_2018$ 

Base Offset: 32'h0000\_2018

Access: RW

Reset: 32'h0000\_01BA Size(bytes): 0x4

| Bits   | Identifier | Access | Reset       | Name / Description                                                                                                                                                                                       |
|--------|------------|--------|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [31]   | LOCK       | RW     | 1'h0        | GCTL Lock Bit If the global lock is enabled (SPU_CTL_GLCK bit =1) and the TRU_ GCTL.LOCK bit is enabled, the TRU_GCTL register is read only.                                                             |
| [30:3] | RESERVED1  | RW     | 28'h00_0037 | Reserved1<br>Reserved bits                                                                                                                                                                               |
| [2]    | MTRL       | RW     | 1'h0        | MTR Lock Bit If the global lock is enabled (SPU_CTL_GLCK bit =1) and the TRU_ GCTL.MTRL bit is enabled, the TRU_MTR register is read only.                                                               |
| [1]    | RESET      | RW     | 1'h1        | Soft Reset The TRU_GCTL.RESET bit is write-1-action and triggers a soft reset to all TRU registers.                                                                                                      |
| [0]    | EN         | RW     | 1'h0        | Non-MMR Enable The TRU_GCTL.EN bit is read/write and must be set for the TRU to propagate trigger events. All TRU register read/write operations continue to operate independent of the TRU_GCTL.EN bit. |

### **Receive Data Register**

Used for storing the received data

 $\textbf{Absolute Address}: 32 \text{'}h0000\_201C$ 

Base Offset: 32'h0000\_201C

Access: RO

**Reset**: 32'h0000\_0000 **Size(bytes)**: 0x4

| Bits   | Identifier | Access | Reset             | Name / Description                                                   |
|--------|------------|--------|-------------------|----------------------------------------------------------------------|
| [31:0] | RXDATA     | RO     | 32'h0000_00<br>00 | Receive Data The Trigger block received data is stored in this field |