

### 58.4.3.1 Software Controlled Ownership Ending

The ROI bits will be automatically cleared when the master that owns the PRR access right clears (write) the RAR bits ([Table 2](#)).

It will then end the ownership of the PRR.

### 58.4.4 The Un-owned State

During the time when the peripheral is un-owned (i.e the ROI field contains all 0's), all masters have full access to it (RAR bits can then be modified by a master if ROI[1:0] = 2'b0).

In such cases it is necessary for software to ensure any necessary coherency in the resource, there is no hardware protection.

## 58.5 SPBA Memory Map/Register Definition

The SPBA control registers (Peripheral Right Registers) are mapped as a virtual shared peripheral.

SPBA can support up to 31 shared peripherals. Each of them has its own Peripheral Right Register (PRR) accessible within the SPBA memory-mapped registers, and consists of the Requesting Master Owner, the Resource Owner ID and the Resource Access Right fields.

**SPBA memory map**

| Absolute address (hex) | Register name                          | Width (in bits) | Access | Reset value | Section/ page               |
|------------------------|----------------------------------------|-----------------|--------|-------------|-----------------------------|
| 203_C000               | Peripheral Rights Register (SPBA_PRR0) | 32              | R/W    | 0000_0007h  | <a href="#">58.5.1/5017</a> |
| 203_C004               | Peripheral Rights Register (SPBA_PRR1) | 32              | R/W    | 0000_0007h  | <a href="#">58.5.1/5017</a> |
| 203_C008               | Peripheral Rights Register (SPBA_PRR2) | 32              | R/W    | 0000_0007h  | <a href="#">58.5.1/5017</a> |
| 203_C00C               | Peripheral Rights Register (SPBA_PRR3) | 32              | R/W    | 0000_0007h  | <a href="#">58.5.1/5017</a> |
| 203_C010               | Peripheral Rights Register (SPBA_PRR4) | 32              | R/W    | 0000_0007h  | <a href="#">58.5.1/5017</a> |
| 203_C014               | Peripheral Rights Register (SPBA_PRR5) | 32              | R/W    | 0000_0007h  | <a href="#">58.5.1/5017</a> |
| 203_C018               | Peripheral Rights Register (SPBA_PRR6) | 32              | R/W    | 0000_0007h  | <a href="#">58.5.1/5017</a> |
| 203_C01C               | Peripheral Rights Register (SPBA_PRR7) | 32              | R/W    | 0000_0007h  | <a href="#">58.5.1/5017</a> |
| 203_C020               | Peripheral Rights Register (SPBA_PRR8) | 32              | R/W    | 0000_0007h  | <a href="#">58.5.1/5017</a> |

*Table continues on the next page...*

## SPBA memory map (continued)

| Absolute address (hex) | Register name                           | Width (in bits) | Access | Reset value | Section/page |
|------------------------|-----------------------------------------|-----------------|--------|-------------|--------------|
| 203_C024               | Peripheral Rights Register (SPBA_PRR9)  | 32              | R/W    | 0000_0007h  | 58.5.1/5017  |
| 203_C028               | Peripheral Rights Register (SPBA_PRR10) | 32              | R/W    | 0000_0007h  | 58.5.1/5017  |
| 203_C02C               | Peripheral Rights Register (SPBA_PRR11) | 32              | R/W    | 0000_0007h  | 58.5.1/5017  |
| 203_C030               | Peripheral Rights Register (SPBA_PRR12) | 32              | R/W    | 0000_0007h  | 58.5.1/5017  |
| 203_C034               | Peripheral Rights Register (SPBA_PRR13) | 32              | R/W    | 0000_0007h  | 58.5.1/5017  |
| 203_C038               | Peripheral Rights Register (SPBA_PRR14) | 32              | R/W    | 0000_0007h  | 58.5.1/5017  |
| 203_C03C               | Peripheral Rights Register (SPBA_PRR15) | 32              | R/W    | 0000_0007h  | 58.5.1/5017  |
| 203_C040               | Peripheral Rights Register (SPBA_PRR16) | 32              | R/W    | 0000_0007h  | 58.5.1/5017  |
| 203_C044               | Peripheral Rights Register (SPBA_PRR17) | 32              | R/W    | 0000_0007h  | 58.5.1/5017  |
| 203_C048               | Peripheral Rights Register (SPBA_PRR18) | 32              | R/W    | 0000_0007h  | 58.5.1/5017  |
| 203_C04C               | Peripheral Rights Register (SPBA_PRR19) | 32              | R/W    | 0000_0007h  | 58.5.1/5017  |
| 203_C050               | Peripheral Rights Register (SPBA_PRR20) | 32              | R/W    | 0000_0007h  | 58.5.1/5017  |
| 203_C054               | Peripheral Rights Register (SPBA_PRR21) | 32              | R/W    | 0000_0007h  | 58.5.1/5017  |
| 203_C058               | Peripheral Rights Register (SPBA_PRR22) | 32              | R/W    | 0000_0007h  | 58.5.1/5017  |
| 203_C05C               | Peripheral Rights Register (SPBA_PRR23) | 32              | R/W    | 0000_0007h  | 58.5.1/5017  |
| 203_C060               | Peripheral Rights Register (SPBA_PRR24) | 32              | R/W    | 0000_0007h  | 58.5.1/5017  |
| 203_C064               | Peripheral Rights Register (SPBA_PRR25) | 32              | R/W    | 0000_0007h  | 58.5.1/5017  |
| 203_C068               | Peripheral Rights Register (SPBA_PRR26) | 32              | R/W    | 0000_0007h  | 58.5.1/5017  |
| 203_C06C               | Peripheral Rights Register (SPBA_PRR27) | 32              | R/W    | 0000_0007h  | 58.5.1/5017  |
| 203_C070               | Peripheral Rights Register (SPBA_PRR28) | 32              | R/W    | 0000_0007h  | 58.5.1/5017  |
| 203_C074               | Peripheral Rights Register (SPBA_PRR29) | 32              | R/W    | 0000_0007h  | 58.5.1/5017  |
| 203_C078               | Peripheral Rights Register (SPBA_PRR30) | 32              | R/W    | 0000_0007h  | 58.5.1/5017  |
| 203_C07C               | Peripheral Rights Register (SPBA_PRR31) | 32              | R/W    | 0000_0007h  | 58.5.1/5017  |

### 58.5.1 Peripheral Rights Register (SPBA\_PRRn)

This register controls master ownership and access for a peripheral.

Address: 203\_C000h base + 0h offset + (4d × i), where i=0d to 31d



#### SPBA\_PRRn field descriptions

| Field        | Description                                                                                                                                                                                                                                                                                                                                                                                                    |
|--------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31–30<br>RMO | Requesting Master Owner. This 2-bit register field indicates if the corresponding resource is owned by the requesting master or not. This register is reset to 2'b0 if ROI = 2'b0.<br><br>00 <b>UNOWNED</b> — The resource is unowned.<br>01 Reserved.<br>10 <b>ANOTHER_MASTER</b> — The resource is owned by another master.<br>11 <b>REQUESTING_MASTER</b> — The resource is owned by the requesting master. |
| 29–18<br>-   | This field is reserved.<br>Reserved                                                                                                                                                                                                                                                                                                                                                                            |
| 17–16<br>ROI | Resource Owner ID. This field indicates which master (one at a time) can access to the PRR for rights modification. This is a read-only register.<br><br>After reset, ROI bits are cleared ("00" -> un-owned resource).                                                                                                                                                                                        |

Table continues on the next page...

## SPBA\_PRRn field descriptions (continued)

| Field     | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|-----------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|           | <p>A master performing a write access to the an un-owned PRR will get its ID automatically written into ROI, while modifying RARx bits. It can then read back the RMO, RAR, ROI bits to make sure RMO returns the right value, ROI bits contain its ID and RARx bits are correctly asserted. Then no other master (whom ID is different from the one stored in ROI) will be able to modify RAR fields.</p> <p>Owner master of a peripheral can assert its dead_owner signal, or write 1'b0 in the RARx to release the ownership (ROI[1:0] reset to 2'b0).</p> <p>00 <b>UNOWNED</b> — Unowned resource.<br/>     01 <b>MASTER_A</b> — The resource is owned by master A port.<br/>     10 <b>MASTER_B</b> — The resource is owned by master B port.<br/>     11 <b>MASTER_C</b> — The resource is owned by master C port.</p> |
| 15–3<br>- | This field is reserved.<br>Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| 2<br>RARC | <p>Resource Access Right. Control and Status bit for master C.</p> <p>This field indicates whether master C can access the peripheral. From 0 up to 3 masters can have permission to access a resource (all the master can be granted on a peripheral, but only one access at a time will be granted by SPBA).</p> <p>0 <b>PROHIBITED</b> — Access to peripheral is not allowed.<br/>     1 <b>ALLOWED</b> — Access to peripheral is granted.</p>                                                                                                                                                                                                                                                                                                                                                                            |
| 1<br>RARB | <p>Resource Access Right. Control and Status bit for master B.</p> <p>This field indicates whether master B can access the peripheral. From 0 up to 3 masters can have permission to access a resource (all the master can be granted on a peripheral, but only one access at a time will be granted by SPBA).</p> <p>0 <b>PROHIBITED</b> — Access to peripheral is not allowed.<br/>     1 <b>ALLOWED</b> — Access to peripheral is granted.</p>                                                                                                                                                                                                                                                                                                                                                                            |
| 0<br>RARA | <p>Resource Access Right. Control and Status bit for master A.</p> <p>This field indicates whether master A can access the peripheral. From 0 up to 3 masters can have permission to access a resource (all the master can be granted on a peripheral, but only one access at a time will be granted by SPBA).</p> <p>0 <b>PROHIBITED</b> — Access to peripheral is not allowed.<br/>     1 <b>ALLOWED</b> — Access to peripheral is granted.</p>                                                                                                                                                                                                                                                                                                                                                                            |