



# **Processor Local Bus** (PLB) v4.6 (v1.03a)

DS531 July 28, 2008 **Product Specification** 

### Introduction

The Xilinx 128-bit Processor Local Bus (PLB) v4.6 provides bus infrastructure for connecting an optional number of PLB masters and slaves into an overall PLB system. It consists of a bus control unit, a watchdog timer, and separate address, write, and read data path units. It contains an optional DCR slave interface to provide access to its bus error status registers.

## **Features**

- Arbitration support for a configurable number of PLB master devices
- PLB address and data steering support for all masters
- 128-bit, 64-bit, and 32-bit support for masters and slaves
- PLB address pipelining (supported in shared bus mode or point-to-point configuration)
- Three-cycle arbitration
- Four levels of dynamic master request priority
- Selectable round robin or fixed priority arbitration
- Configurable optimization for point-to-point topology
- PLB watchdog timer
- PLB architecture compatible
- Complete PLB bus structure provided
  - Supports a configurable number of slave devices
  - No external OR gates required for PLB slave input signals

| LogiCORE™ Facts                                              |                                                                                                                                                                                                                                                                              |                                        |  |  |  |  |
|--------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------|--|--|--|--|
| Core Specifics                                               |                                                                                                                                                                                                                                                                              |                                        |  |  |  |  |
| Supported Device<br>Family                                   | Virtex®-II Pro, Virtex-4, QPro<br>Virtex-4 Hi Rel, QPro Virtex-4 Rac<br>Tolerant, Virtex-5, Spartan®-3E,<br>Automotive Spartan-3E,<br>Spartan-3, Automotive Spartan-3,<br>Spartan-3A, Spartan-3AN,<br>Automotive Spartan-3A,<br>Spartan-3A DSP, Automotive<br>Spartan-3A DSP |                                        |  |  |  |  |
| Version of Core                                              | plb_v46                                                                                                                                                                                                                                                                      | v1.03a                                 |  |  |  |  |
| Re                                                           | sources Used                                                                                                                                                                                                                                                                 |                                        |  |  |  |  |
|                                                              | Min                                                                                                                                                                                                                                                                          | Max                                    |  |  |  |  |
| Slices                                                       |                                                                                                                                                                                                                                                                              |                                        |  |  |  |  |
| LUTs                                                         | See Table 14 on page 35.                                                                                                                                                                                                                                                     |                                        |  |  |  |  |
| FFs                                                          |                                                                                                                                                                                                                                                                              |                                        |  |  |  |  |
| Block RAMs                                                   |                                                                                                                                                                                                                                                                              |                                        |  |  |  |  |
| Pro                                                          | vided with Core                                                                                                                                                                                                                                                              |                                        |  |  |  |  |
| Documentation                                                | Product S                                                                                                                                                                                                                                                                    | pecification                           |  |  |  |  |
| Design File Formats                                          | VI                                                                                                                                                                                                                                                                           | HDL                                    |  |  |  |  |
| Constraints File                                             | N                                                                                                                                                                                                                                                                            | I/A                                    |  |  |  |  |
| Verification                                                 | N                                                                                                                                                                                                                                                                            | I/A                                    |  |  |  |  |
| Instantiation Template                                       | N                                                                                                                                                                                                                                                                            | I/A                                    |  |  |  |  |
| Reference Designs                                            | No                                                                                                                                                                                                                                                                           | one                                    |  |  |  |  |
| Design Tool Requirements                                     |                                                                                                                                                                                                                                                                              |                                        |  |  |  |  |
| Design                                                       | Tool Requiremer                                                                                                                                                                                                                                                              | nts                                    |  |  |  |  |
| Design  Xilinx Implementation Tools                          | -                                                                                                                                                                                                                                                                            | ats<br>2i or later                     |  |  |  |  |
| Xilinx Implementation                                        | ISE® 9.                                                                                                                                                                                                                                                                      |                                        |  |  |  |  |
| Xilinx Implementation<br>Tools                               | ISE® 9.                                                                                                                                                                                                                                                                      | 2i or later                            |  |  |  |  |
| Xilinx Implementation<br>Tools<br>Verification               | ISE® 9.  ModelSim SE/                                                                                                                                                                                                                                                        | 2i or later                            |  |  |  |  |
| Xilinx Implementation<br>Tools<br>Verification<br>Simulation | ISE® 9.  ModelSim SE/                                                                                                                                                                                                                                                        | 2i or later<br>I/A<br>EE 6.2c or later |  |  |  |  |

© 2006-2008 Xilinx, Inc. All rights reserved. XILINX, the Xilinx logo, the Brand Window, and other designated brands included herein are trademarks of Xilinx, Inc. All other trademarks are the property of their respective owners.



## Features (contd)

- PLB Reset circuit
  - PLB Reset generated synchronously to the PLB clock
  - PLB Reset generated synchronously from external reset when external reset provided
  - Provides vectorized reset signal to reduce system fanout for improved timing
  - Active state of external reset selectable via a design parameter

## **Functional Description**

The Xilinx PLB consists of a central bus arbiter, the necessary bus control and gating logic, and all necessary bus OR/MUX structures. The Xilinx PLB provides the entire PLB bus structure and allows for direct connection with a configuration number of masters and slaves. Figure 1 provides an example of the PLB connections for a system with three masters and three slaves.



Figure 1: PLB Interconnect Diagram

## **Basic Operation**

The Xilinx PLB has 3-cycle arbitration during the address phase of the transaction as shown in Figure 2. There is a two-cycle delay from Mn\_request to PLB\_PAValid. If the slave can respond combinatorially in the same cycle—the optimistic assumption shown and theoretically possible for a write transaction—the whole transaction takes three cycles.

The two-cycle delay from Mn\_request to PLB\_PAValid holds for the case where there are two or more attached masters and allows one cycle for a priority arbitration to occur and one cycle to route the selected master's



transaction data and qualifiers to the slaves. If there is a single master, arbitration is not necessary and transaction data and qualifiers can be driven to the slaves without multiplexing. This allows PLB\_PAValid to be driven after one clock, saving a cycle of latency.



Figure 2: 3-cycle arbitration (Xilinx Implementation)

During the bus arbitration cycle (in a fixed priority arbitration scheme), the bus arbitration control unit uses two priority bits from each requesting master to determine which master is granted the bus. The two bits **M\_priority[i\*2:i\*2+1]** are the priority bits for master **i**. The two priority bits are interpreted as an integer between 0 and 3—with the bit at the lowest index having the highest weight of two. The value of zero represents the lowest priority. From there, priority increases with increasing numerical value.

In addition, the Xilinx PLB arbitration logic supports the fixed priority scheme to handle "tie" situations (that is, situations when two or more masters request the bus simultaneously while presenting the same level of request priority). Selection of the priority mode during tie situations is shown in Table 1 where  $n = C_PLBV46_NUM_MASTERS$ .

Table 1: Priority Order for Bus Masters

| Highest<br>Priority |                     | Decreasing Priority |                       | Lowest<br>Priority    |
|---------------------|---------------------|---------------------|-----------------------|-----------------------|
| Master <sub>0</sub> | Master <sub>1</sub> |                     | Master <sub>n-2</sub> | Master <sub>n-1</sub> |

In the round robin arbitration scheme, the bus arbitration control unit allows the least recently used master to win arbitration and control the bus. Once a master is granted the bus, it will then become the lowest priority master in the next arbitration cycle. Configuring the PLB in a round robin scheme allows each master in the system an opportunity to be granted the bus. This is critical in system configurations where certain masters can lock out other masters from being granted the bus simply due to connection ordering on the PLB. Round robin arbitration prevents the need of each master to increase the M\_priority bits to the highest level in order for a chance to win arbitration on the bus.

## Address Pipelining

The read and write data buses of the PLB can be concurrently active. Therefore, two *primary transactions*, one read and one write, are launched sequentially and completed in parallel. Beyond this, the PLB protocol allows for additional *secondary transactions* to be acknowledged through the address phase and queued up, waiting to



complete the data transfer when signaled to that the needed data bus is free. The PLB v4.6 protocol allows for such *address pipelining* to be arbitrarily deep, but does not require it.

To make use of address pipelining, the Xilinx PLB must incorporate the implied extra state and book-keeping logic *and* slaves must be designed to accept secondary transactions. If support is missing in either place, all transactions proceed as primary transactions and the expense associated with implementing the unused secondary-transaction capability--whether in the Xilinx PLB or slaves--is wasted.

The Xilinx PLB is introduced into an FPGA embedded computing environment where slaves generally do not support secondary addresses. Therefore, the Xilinx PLB will not support address pipelining by default. However, there is an option to enable address pipelining, in case slaves with secondary address support become needed. The option is enabled by setting C\_ADDR\_PIPELINING\_TYPE = 1, which enables two-deep address pipelining (one primary and one secondary transaction for each of read and write). Deeper address pipelining is not supported. To get the default of no address pipelining, set C\_ADDR\_PIPELINING\_TYPE = 0.

Enabling of the PLB two-deep address pipelining is not limited to the shared bus mode configuration. When the PLB is configured in a point-to-point topology, the two-deep address pipeline can also be enabled. To enable this, both the parameters must be set as C\_P2P = 1 and C\_ADDR\_PIPELINING\_TYPE = 1. The point-to-point configuration with address pipelining allows slave devices to assert the Sl\_addrAck to the asserted PLB\_SAValid, secondary address valid. On read transactions, the slave must monitor the PLB\_rdPrim signal which indicates the primary transaction data phase is complete and the slave can begin to drive Sl\_rdDAck and Sl\_rdComp for the secondary transaction which was previously acknowledged. Figure 3 illustrates this usage case.



Figure 3: Point-to-point Address Pipelining (AddrAck to SAValid)



Figure 4 illustrates an example of a delayed Sl\_addrAck assertion to the secondary address valid indicator. In this case, the PLB\_SAValid will be promoted to the PLB\_PAValid if the primary transaction completes (with the assertion of Sl\_rdComp) prior to the Sl\_addrAck.



Figure 4: Point-to-point Address Pipelining (Secondary to Primary Promotion)

Figure 5 illustrates back to back read requests followed by a subsequent write request of the master. With separate read and write data buses on the PLB, the arbiter is capable of asserting PAValid for a subsequent write operation prior to the previous read operations completing.



Figure 5: Pipelined Read Transactions with Subsequent Write

Slave devices supporting address pipelining must be able to assert either Sl\_reArbitrate or Sl\_addrAck to the PLB\_SAValid transaction. The PLB\_SAValid operation can not timeout by the arbiter, only the primary transaction, indicated by the assertion of PLB\_PAValid. Figure 6 illustrates an example of PLB\_SAValid asserted for more than the primary transaction timeout count value. The arbiter will not timeout the PLB\_SAValid transaction, but will wait for the promotion of PLB\_SAValid to PLB\_PAValid (indicated by Sl\_rdComp), then the



timeout counter will be activated. If during the assertion of PLB\_PAValid neither Sl\_reArbitrate or Sl\_addrAck is asserted, the PLB\_MTimeout will be asserted after 16 clock cycles.



Figure 6: Timeout Only on Promotion of Secondary to Primary Transaction

## **PLB Design Parameters**

To allow for a PLB that is tailored to the target embedded system, certain features can be parameterized in the Xilinx PLB. This allows the user to have a design that only utilizes the resources required by the system and runs at the best possible performance. The features that can be parameterized in the Xilinx PLB are shown in Table 2.

Table 2: PLB Design Parameters

| Generic    | Feature /<br>Description | Parameter Name           | Allowable Values                                                              | Default<br>Value | VHDL<br>Type         |  |  |  |
|------------|--------------------------|--------------------------|-------------------------------------------------------------------------------|------------------|----------------------|--|--|--|
|            | PLB Features             |                          |                                                                               |                  |                      |  |  |  |
| G1         | Number of PLB<br>Masters | C_PLBV46_NUM_<br>MASTERS | 1 - 16 (1)                                                                    | 4                | integer              |  |  |  |
| G2         | Number of PLB<br>Slaves  | C_PLBV46_NUM_<br>SLAVES  | 1 - 16 <sup>(2)</sup>                                                         | 8                | integer              |  |  |  |
| G3         | PLB Address Bus<br>Width | C_PLBV46_AWIDTH          | 32                                                                            | 32               | integer              |  |  |  |
| G4         | PLB Data Bus Width       | C_PLBV46_DWIDTH          | 32, 64, 128                                                                   | 64               | integer              |  |  |  |
| G5         | Include DCR interface    | C_DCR_INTFCE             | 1 = Include DCR slave<br>interface<br>0 = DCR slave interface<br>not included | 0                | integer              |  |  |  |
|            |                          | DCR Interfa              | ce                                                                            | ı                |                      |  |  |  |
| G6         | DCR Base Address         | C_BASEADDR               | Valid DCR address (3)                                                         | None (4)         | std_logic<br>_vector |  |  |  |
| <b>G</b> 7 | DCR High Address         | C_HIGHADDR               | Valid DCR address (3)                                                         | None (4)         | std_logic<br>_vector |  |  |  |
| G8         | DCR Address Bus<br>Width | C_DCR_AWIDTH             | 10                                                                            | 10               | integer              |  |  |  |



Table 2: PLB Design Parameters (Contd)

| Generic | Feature /<br>Description                                             | Parameter Name             | Allowable Values                                                                                                                                                                                             | Default<br>Value | VHDL<br>Type |
|---------|----------------------------------------------------------------------|----------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------|--------------|
| G9      | DCR Data Bus Width                                                   | C_DCR_DWIDTH               | 32                                                                                                                                                                                                           | 32               | integer      |
|         | 1                                                                    | Interrupts                 |                                                                                                                                                                                                              | ll.              | I.           |
| G10     | Active Interrupt State (5)                                           | C_IRQ_ACTIVE               | 0 = interrupt request is<br>driven as a falling edge<br>1 = interrupt request is<br>driven as a rising edge                                                                                                  | 1                | std_logic    |
|         | 1                                                                    | System                     |                                                                                                                                                                                                              | ll.              | II.          |
| G11     | Active level of external reset                                       | C_EXT_RESET_<br>HIGH       | 1 = external reset is<br>active high<br>0=external reset is active<br>low                                                                                                                                    | 1                | integer      |
|         |                                                                      | Auto-calculated par        | ameters <sup>(6)</sup>                                                                                                                                                                                       | +                | <u> </u>     |
| G12     | Number of bits<br>required to encode<br>the number of PLB<br>Masters | C_PLBV46_MID_<br>WIDTH     | 1 -<br>log2(C_PLBV46_NUM_<br>MASTERS)                                                                                                                                                                        | 2                | integer      |
|         |                                                                      | System                     |                                                                                                                                                                                                              | l .              | I            |
| G13     | Target FPGA family                                                   | C_FAMILY                   | virtex2p, qvirtex4,<br>qrvirtex4, virtex4lx,<br>virtex4sx, virtex4fx,<br>virtex5lx, virtex5sx,<br>spartan3a, aspartan3a,<br>spartan3, aspartan3,<br>spartan3e, aspartan3e,<br>spartan3adsp,<br>aspartan3adsp |                  | string       |
| G14     | Address pipelining type supported                                    | C_ADDR_<br>PIPELINING_TYPE | 0 = no address pipelining<br>1 = 2-level address<br>pipelining                                                                                                                                               | 1                | integer      |



Table 2: PLB Design Parameters (Contd)

| Generic | Feature /<br>Description                                                    | Parameter Name | Allowable Values                                                                                                                                      | Default<br>Value | VHDL<br>Type |
|---------|-----------------------------------------------------------------------------|----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------|------------------|--------------|
| G15     | Optimize PLB for point-to-point topology (one master & one slave)           | C_P2P          | 0 = PLB is configured in a<br>shared bus mode<br>topology<br>1 = PLB is configured<br>with one master and one<br>slave for point-to-point<br>topology | 0                | integer      |
| G16     | Selects the arbitration scheme for all master devices connected to the bus. | C_ARB_TYPE     | 0 = Fixed priority<br>1 = Round robin                                                                                                                 | 0                | integer      |

#### Notes:

8

- 1. The supported allowable values for the parameter, C\_PLBV46\_NUM\_MASTERS, are 1 16. Only the values of 1 8 have been tested in a unit-level verification environment.
- 2. The supported allowable values for the parameter, C\_PLBV46\_NUM\_SLAVES, are 1 16. Only the values of 1 8 have been tested in a unit-level verification environment.
- 3. The range specified by C\_BASEADDR and C\_HIGHADDR must comprise a complete, contiguous power of two range such that range = 2<sup>n</sup>, and the n least significant bits of C\_BASEADDR must be zero. To allow for the 8 DCR registers within the PLB, n must be at least 3.
- 4. No default value is specified for C\_BASEADDR or C\_HIGHADDR to insure that the actual value is set, i.e. if the value is not set, a compiler error is generated.
- 5. The interrupt request output is generated as an edge type interrupt. A specific interrupt acknowledge response is not required.
- 6. These parameters are automatically calculated by the system generation tool and are not input by the user.

#### Allowable Parameter Combinations

The address range specified by C\_BASEADDR and C\_HIGHADDR must comprise a complete, contiguous power of two range such that range  $= 2^n$ , and the n least significant bits of C\_BASEADDR must be zero.

To allow for the registers in the PLB design, this range must be at least 7; therefore n must be at least 3. This means that at a minimum, the three least significant bits of C\_BASEADDR must be 0.

The base address and high address parameters determine the number of most significant address bits used to decode the address space. These parameters allow the user to trade-off address space resolution with size and speed of the PLB.

Some parameters can cause other parameters to be irrelevant. See Table 4 for information on the relationship between design parameters.



## **PLB I/O Signals**

Table 3 provides a summary of all Xilinx PLB input/output (I/O) signals, the interfaces under which they are grouped, and a brief description of the signal.

Table 3: PLB Pin Descriptions

| Port        | Signal Name                                              | Interface    | I/O   | Init<br>State | Description                                       |  |  |  |
|-------------|----------------------------------------------------------|--------------|-------|---------------|---------------------------------------------------|--|--|--|
| DCR Signals |                                                          |              |       |               |                                                   |  |  |  |
| P1          | DCR_ABus[0:C_DCR_<br>AWIDTH-1]                           | DCR          | I     |               | CPU DCR address bus                               |  |  |  |
| P2          | DCR_Read                                                 | DCR          | I     |               | CPU read from DCR indicator                       |  |  |  |
| P3          | DCR_Write                                                | DCR          | ı     |               | CPU write to DCR indicator                        |  |  |  |
| P4          | DCR_DBus[0:C_DCR_<br>DWIDTH-1]                           | DCR          | I     |               | DCR write data bus                                |  |  |  |
| P5          | PLB_dcrAck                                               | DCR          | 0     | 0             | PLB DCR data transfer acknowledge                 |  |  |  |
| P6          | PLB_dcrDBus[0:C_DCR_<br>DWIDTH-1]                        | DCR          | 0     | 0             | PLB DCR read data bus                             |  |  |  |
|             |                                                          | PLB Status   | Signa | ls            |                                                   |  |  |  |
| P7          | PLB_rdPendPri[0:1]                                       | Master/Slave | 0     | 0             | PLB pending read request priority                 |  |  |  |
| P8          | PLB_wrPendPri[0:1]                                       | Master/Slave | 0     | 0             | PLB pending write request priority                |  |  |  |
| P9          | PLB_rdPendReq                                            | Master/Slave | 0     | 0             | PLB pending bus read request indicator            |  |  |  |
| P10         | PLB_wrPendReq                                            | Master/Slave | 0     | 0             | PLB pending bus write request indicator           |  |  |  |
| P11         | PLB_reqPri[0:1]                                          | Master/Slave | 0     | 0             | PLB current request priority                      |  |  |  |
|             |                                                          | Master Si    | gnals |               |                                                   |  |  |  |
| P12         | M_abort[0:C_PLBV46_NUM_<br>MASTERS-1]                    | Master       | I     |               | Master abort bus request indicator                |  |  |  |
| P13         | M_ABus[0:C_PLBV46_NUM_<br>MASTERS*32-1]                  | Master       | I     |               | Master address bus, lower 32 bits for each master |  |  |  |
| P14         | M_BE[0:C_PLBV46_NUM_<br>MASTERS*C_PLBV46_<br>DWIDTH/8-1] | Master       | ı     |               | Master byte enables                               |  |  |  |
| P15         | M_busLock[0:C_PLBV46_NUM_<br>MASTERS-1]                  | Master       | I     |               | Master bus lock                                   |  |  |  |
| P16         | M_TAttribute[0:16*C_PLBV46_<br>NUM_MASTERS-1]            | Master       | I     |               | Master transfer attributes                        |  |  |  |
| P17         | M_lockErr[0:C_PLBV46_NUM_<br>MASTERS-1]                  | Master       | I     |               | Master lock error indicator                       |  |  |  |
| P18         | M_mSize[0:C_PLBV46_NUM_<br>MASTERS*2 -1]                 | Master       | I     |               | Master data bus port width                        |  |  |  |
| P19         | M_priority[0:C_PLBV46_NUM_<br>MASTERS*2 -1]              | Master       | I     |               | Master bus request priority                       |  |  |  |

10



Table 3: PLB Pin Descriptions (Contd)

| Port | Signal Name                                                    | Interface | I/O | Init<br>State | Description                                |
|------|----------------------------------------------------------------|-----------|-----|---------------|--------------------------------------------|
| P20  | M_rdBurst[0:C_PLBV46_NUM_<br>MASTERS-1]                        | Master    | I   |               | Master burst read transfer indicator       |
| P21  | M_request[0:C_PLBV46_NUM_<br>MASTERS-1]                        | Master    | I   |               | Master bus request                         |
| P22  | M_RNW[0:C_PLBV46_NUM_<br>MASTERS-1]                            | Master    | ı   |               | Master read not write                      |
| P23  | M_size[0:C_PLBV46_NUM_<br>MASTERS*4 -1]                        | Master    | I   |               | Master transfer size                       |
| P24  | M_type[0:C_PLBV46_NUM_<br>MASTERS*3-1]                         | Master    | I   |               | Master transfer type                       |
| P25  | M_wrBurst[0:C_PLBV46_<br>NUM_MASTERS-1]                        | Master    | ı   |               | Master burst write transfer indicator      |
| P26  | M_wrDBus[0:C_PLBV46_NUM_<br>MASTERS*C_PLBV46_<br>DWIDTH -1]    | Master    | I   |               | Master write data bus                      |
| P27  | PLB_MAddrAck[0:C_PLBV46_<br>NUM_MASTERS-1]                     | Master    | 0   | 0             | PLB Master address acknowledge             |
| P28  | PLB_MBusy[0:C_PLBV46_NUM<br>_MASTERS-1]                        | Master    | 0   | 0             | PLB Master slave busy indicator            |
| P29  | PLB_MRdErr[0:C_PLBV46_<br>NUM_MASTERS-1]                       | Master    | 0   | 0             | PLB Master slave read error indicator      |
| P30  | PLB_MWrErr[0:C_PLBV46_<br>NUM_MASTERS-1]                       | Master    | 0   | 0             | PLB Master slave write error indicator     |
| P31  | PLB_MRdBTerm[0:C_PLBV46_<br>NUM_MASTERS-1]                     | Master    | 0   | 0             | PLB Master terminate read burst indicator  |
| P32  | PLB_MRdDAck[0:C_PLBV46_<br>NUM_MASTERS-1]                      | Master    | 0   | 0             | PLB Master read data acknowledge           |
| P33  | PLB_MRdDBus[0:C_PLBV46_N<br>UM_MASTERS*C_PLBV46_<br>DWIDTH -1] | Master    | 0   | 0             | PLB Master read data bus                   |
| P34  | PLB_MRdWdAddr[0:C_PLBV46<br>_NUM_MASTERS*4 -1]                 | Master    | 0   | 0             | PLB Master read word address               |
| P35  | PLB_MRearbitrate[0:C_PLBV46 _NUM_MASTERS-1]                    | Master    | 0   | 0             | PLB Master bus rearbitrate indicator       |
| P36  | PLB_MSSize[0:C_PLBV46_<br>NUM_MASTERS*2 -1]                    | Master    | 0   | 0             | PLB Master slave data bus port width       |
| P37  | PLB_MWrBTerm[0:C_PLBV46_<br>NUM_MASTERS-1]                     | Master    | 0   | 0             | PLB Master terminate write burst indicator |
| P38  | PLB_MWrDAck[0:C_PLBV46_<br>NUM_MASTERS-1]                      | Master    | 0   | 0             | PLB Master write data acknowledge          |
| P39  | PLB_MTimeout[0:C_PLBV46_<br>NUM_MASTERS-1]                     | Master    | 0   | 0             | PLB address-phase timeout indicator        |



Table 3: PLB Pin Descriptions (Contd)

| Port | Signal Name                                                     | Interface | I/O | Init<br>State | Description                                      |  |  |  |
|------|-----------------------------------------------------------------|-----------|-----|---------------|--------------------------------------------------|--|--|--|
|      | Slave Signals                                                   |           |     |               |                                                  |  |  |  |
| P40  | PLB_abort                                                       | Slave     | 0   | 0             | PLB abort bus request indicator                  |  |  |  |
| P41  | PLB_ABus[0:31]                                                  | Slave     | 0   | 0             | PLB address bus, lower 32 bits                   |  |  |  |
| P42  | PLB_BE[0:C_PLBV46_DWIDTH /8-1]                                  | Slave     | 0   | 0             | PLB byte enables                                 |  |  |  |
| P43  | PLB_busLock                                                     | Slave     | 0   | 0             | PLB bus lock                                     |  |  |  |
| P44  | PLB_TAttribute[0:15]                                            | Slave     | 0   | 0             | PLB transfer attribute                           |  |  |  |
| P45  | PLB_lockErr                                                     | Slave     | 0   | 0             | PLB lock error indicator                         |  |  |  |
| P46  | PLB_masterID[0:C_PLBV46_MI<br>D_ WIDTH-1]                       | Slave     | 0   | 0             | PLB current master identifier                    |  |  |  |
| P47  | PLB_MSize[0:1]                                                  | Slave     | 0   | 0             | PLB data bus port width indicator                |  |  |  |
| P48  | PLB_PAValid                                                     | Slave     | 0   | 0             | PLB primary address valid indicator              |  |  |  |
| P49  | PLB_rdBurst                                                     | Slave     | 0   | 0             | PLB burst read transfer indicator                |  |  |  |
| P50  | PLB_rdPrim[0:C_PLBV46_NUM _ SLAVES-1]                           | Slave     | 0   | 0             | PLB secondary to primary read request indicator  |  |  |  |
| P51  | PLB_RNW                                                         | Slave     | 0   | 0             | PLB read not write                               |  |  |  |
| P52  | PLB_SAValid                                                     | Slave     | 0   | 0             | PLB secondary address valid                      |  |  |  |
| P53  | PLB_size[0:3]                                                   | Slave     | 0   | 0             | PLB transfer size                                |  |  |  |
| P54  | PLB_type[0:2]                                                   | Slave     | 0   | 0             | PLB transfer type                                |  |  |  |
| P55  | PLB_wrBurst                                                     | Slave     | 0   | 0             | PLB burst write transfer indicator               |  |  |  |
| P56  | PLB_wrDBus[0:C_PLBV46_<br>DWIDTH-1]                             | Slave     | 0   | 0             | PLB write data bus                               |  |  |  |
| P57  | PLB_wrPrim[0:C_PLBV46_NUM _ SLAVES-1]                           | Slave     | 0   | 0             | PLB secondary to primary write request indicator |  |  |  |
| P58  | SI_addrAck[0:C_PLBV46_NUM_<br>SLAVES-1]                         | Slave     | I   |               | Slave address acknowledge                        |  |  |  |
| P59  | SI_MRdErr[0:C_PLBV46_NUM_<br>SLAVES*C_PLBV46_NUM_<br>MASTERS-1] | Slave     | 1   |               | Slave read error indicator                       |  |  |  |
| P60  | SI_MWrErr[0:C_PLBV46_NUM_<br>SLAVES*C_PLBV46_NUM_<br>MASTERS-1] | Slave     | ı   |               | Slave write error indicator                      |  |  |  |
| P61  | SI_MBusy[0:C_PLBV46_NUM_<br>SLAVES*C_PLBV46_NUM_<br>MASTERS-1]  | Slave     | I   |               | Slave busy indicator                             |  |  |  |
| P62  | SI_rdBTerm[0:C_PLBV46_NUM<br>_ SLAVES-1]                        | Slave     | I   |               | Slave terminate read burst transfer              |  |  |  |
| P63  | SI_rdComp[0:C_PLBV46_NUM_<br>SLAVES-1]                          | Slave     | I   |               | Slave read transfer complete indicator           |  |  |  |

12



Table 3: PLB Pin Descriptions (Contd)

| Port | Signal Name                                                   | Interface     | I/O    | Init<br>State      | Description                                                                                                                                                      |
|------|---------------------------------------------------------------|---------------|--------|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| P64  | SI_rdDAck[0:C_PLBV46_NUM_<br>SLAVES-1]                        | Slave         | I      |                    | Slave read data acknowledge                                                                                                                                      |
| P65  | SI_rdDBus[0:C_PLBV46_NUM_<br>SLAVES*C_PLBV46_<br>DWIDTH-1]    | Slave         | ı      |                    | Slave read data bus                                                                                                                                              |
| P66  | SI_rdWdAddr[0:C_PLBV46_NU<br>M_ SLAVES*4-1]                   | Slave         | I      |                    | Slave read word address                                                                                                                                          |
| P67  | SI_rearbitrate[0:C_PLBV46_NU<br>M_ SLAVES-1]                  | Slave         | I      |                    | Slave rearbitrate bus indicator                                                                                                                                  |
| P68  | SI_SSize[0:C_PLBV46_NUM_<br>SLAVES*2-1]                       | Slave         | I      |                    | Slave data bus port size indicator                                                                                                                               |
| P69  | SI_wait[0:C_PLBV46_NUM_<br>SLAVES-1]                          | Slave         | I      |                    | Slave wait indicator                                                                                                                                             |
| P70  | SI_wrBTerm[0:C_PLBV46_NUM<br>_ SLAVES-1]                      | Slave         | I      |                    | Slave terminate write burst transfer                                                                                                                             |
| P71  | SI_wrComp[0:C_PLBV46_NUM_<br>SLAVES-1]                        | Slave         | I      |                    | Slave write transfer complete indicator                                                                                                                          |
| P72  | SI_wrDAck[0:C_PLBV46_NUM_<br>SLAVES-1]                        | Slave         | I      |                    | Slave write data acknowledge                                                                                                                                     |
| P73  | Bus_Error_Det                                                 | System        | 0      | 0                  | Bus Error Interrupt                                                                                                                                              |
|      |                                                               | Interru       | ıpt    | 1                  |                                                                                                                                                                  |
| P74  | SI_MIRQ[0:C_PLBV46_NUM_<br>SLAVES*C_PLBV46_NUM_<br>MASTERS-1] | Slave         | I      |                    | Master Interrupt Request (one per master at each slave). Gives a slave the ability to indicate that it has encountered an event it deems important to the master |
| P75  | PLB_MIRQ[0:C_PLBV46_NUM_<br>MASTERS-1]                        | Slave         | 0      | 0                  | Master Interrupt Request. For each master, indicates whether any slave has encountered an event that it deems important to the master                            |
|      |                                                               | System S      | ignals |                    |                                                                                                                                                                  |
| P76  | PLB_Clk                                                       | System        | I      |                    | System clock                                                                                                                                                     |
| P77  | SYS_Rst                                                       | System        | I      |                    | External system reset                                                                                                                                            |
| P78  | PLB_Rst                                                       | System        | 0      | 0                  | Registered reset output from arbitration logic                                                                                                                   |
| P79  | SPLB_Rst[0:C_PLBV46_NUM_<br>SLAVES-1]                         | System        | 0      | 0                  | Registered reset output from arbitration logic for system slave devices                                                                                          |
| P80  | MPLB_Rst[0:C_PLBV46_NUM_<br>MASTERS-1]                        | System        | 0      | 0                  | Registered reset output from arbitration logic for system master devices                                                                                         |
|      | IE                                                            | BM PLB Toolki | Supp   | ort <sup>(1)</sup> |                                                                                                                                                                  |



Table 3: PLB Pin Descriptions (Contd)

| Port | Signal Name                                             | Interface     | I/O   | Init<br>State | Description                                                                                           |
|------|---------------------------------------------------------|---------------|-------|---------------|-------------------------------------------------------------------------------------------------------|
| P81  | PLB_SaddrAck                                            | Simulation    | 0     | 0             | Output of slave SI_addrAck OR gate                                                                    |
| P82  | PLB_Swait                                               | Simulation    | 0     | 0             | Output of slave SI_wait OR gate                                                                       |
| P83  | PLB_Srearbitrate                                        | Simulation    | 0     | 0             | Output of slave SI_rearbitrate OR gate                                                                |
| P84  | PLB_SwrDAck                                             | Simulation    | 0     | 0             | Output of slave SI_wrDAck OR gate                                                                     |
| P85  | PLB_SwrComp                                             | Simulation    | 0     | 0             | Output of slave SI_wrComp OR gate                                                                     |
| P86  | PLB_SwrBTerm                                            | Simulation    | 0     | 0             | Output of slave SI_wrBTerm OR gate                                                                    |
| P87  | PLB_SrdDBus[0:C_PLBV46_<br>DWIDTH-1]                    | Simulation    | 0     | 0             | Output of slave SI_rdDBus OR gate                                                                     |
| P88  | PLB_SrdWdAddr[0:3]                                      | Simulation    | 0     | 0             | Output of slave SI_rdWdAddr OR gate                                                                   |
| P89  | PLB_SrdDAck                                             | Simulation    | 0     | 0             | Output of slave SI_rdDAck OR gate                                                                     |
| P90  | PLB_SrdComp                                             | Simulation    | 0     | 0             | Output of slave SI_rdComp OR gate                                                                     |
| P91  | PLB_SrdBTerm                                            | Simulation    | 0     | 0             | Output of slave SI_rdBTerm OR gate                                                                    |
| P92  | PLB_SMBusy[0:C_PLBV46_<br>NUM_MASTERS-1]                | Simulation    | 0     | 0             | Output of slave SI_MBusy OR gate                                                                      |
| P93  | PLB_SMRdErr[0:C_PLBV46_<br>NUM_MASTERS-1]               | Simulation    | 0     | 0             | Output of slave SI_MRdErr OR gate                                                                     |
| P94  | PLB_SMWrErr[0:C_PLBV46_<br>NUM_MASTERS-1]               | Simulation    | 0     | 0             | Output of slave SI_MWrErr OR gate                                                                     |
| P95  | PLB_Sssize[0:1]                                         | Simulation    | 0     | 0             | Output of slave SI_SSize OR gate                                                                      |
|      | 1                                                       | Upper Address | Exter | nsion         |                                                                                                       |
| P97  | M_UABus(0:C_PLBV46_NUM_<br>MASTERS*32-1) <sup>(2)</sup> | Master        | I     |               | Master upper address bits. (Only the rightmost C_PLBV46_AWIDTH-32 bits in each 32-bit field are used) |
| P98  | PLB_UABus(0:31) <sup>(2)</sup>                          | Slave         | 0     |               | Slave upper address bits. (Only the rightmost C_PLBV46_AWIDTH-32 bits are used)                       |

### Notes:

- The outputs in this section are required to connect with the PLB Monitor Bus Functional Model (BFM) supplied with the IBM PLB Toolkit. These outputs are not needed otherwise, but can be used as debug signals if desired.
- 2. UABus ports are required for connection in the EDK tool, but the signal usage is ignored in the core. No address bits beyond 32-bits are supported at this time.

## **Parameter/Port Dependencies**

The width of many of the PLB signals depends on the number of PLB masters and number of PLB slaves in the design. In addition, when certain features are parameterized away, the related input signals are unconnected and



the related output signals are set to constant values. The dependencies between the PLB design parameters and I/O signals are shown in Table 4.

Table 4: Parameter-Port Dependencies

| Generic or Port | Name                           | Affects                                         | Depends   | Relationship Description                                                                        |  |  |  |  |
|-----------------|--------------------------------|-------------------------------------------------|-----------|-------------------------------------------------------------------------------------------------|--|--|--|--|
|                 | Design Parameters              |                                                 |           |                                                                                                 |  |  |  |  |
| G1              | C_PLBV46_NUM_<br>MASTERS       | P12-P39<br>P59, P60<br>P61, P74,<br>P75, P94    |           | The width of many buses is set by the number of PLB masters in the design.                      |  |  |  |  |
| G2              | C_PLBV46_NUM_<br>SLAVES        | P58 - P72                                       |           | The width of many buses is set by the number of PLB slaves in the design.                       |  |  |  |  |
| G3              | C_PLBV46_AWIDTH                | P13, P41                                        |           |                                                                                                 |  |  |  |  |
| G4              | C_PLBV46_DWIDTH                | P14, P26,<br>P33, P42,<br>P56, P60,<br>P65, P74 |           |                                                                                                 |  |  |  |  |
| G5              | C_DCR_INTFCE                   | G6 - G9,<br>P1- P6                              |           |                                                                                                 |  |  |  |  |
| G6              | C_BASEADDR                     |                                                 | G5        | Unconnected if C_DCR_INTFCE=0.                                                                  |  |  |  |  |
| G7              | C_HIGHADDR                     |                                                 | G5        | Unconnected if C_DCR_INTFCE=0.                                                                  |  |  |  |  |
| G8              | C_DCR_AWIDTH                   | P1                                              | G5        | Unconnected if C_DCR_INTFCE=0.                                                                  |  |  |  |  |
| G9              | C_DCR_DWIDTH                   | P4, P6                                          | G5        | Unconnected if C_DCR_INTFCE=0.                                                                  |  |  |  |  |
| G10             | C_IRQ_ACTIVE                   | P73                                             |           |                                                                                                 |  |  |  |  |
| G11             | C_EXT_RESET_ HIGH              |                                                 |           |                                                                                                 |  |  |  |  |
| G12             | C_PLBV46_MID_<br>WIDTH         | P46                                             | G1        | Master ID width is log2(C_PLBV46_NUM_MASTERS).                                                  |  |  |  |  |
| G13             | C_FAMILY                       |                                                 |           |                                                                                                 |  |  |  |  |
|                 |                                | 1/0                                             | ) Signals |                                                                                                 |  |  |  |  |
| P1              | DCR_ABus[0:C_DCR_<br>AWIDTH-1] |                                                 | G5, G8    | Width varies with the size of the DCR address bus. This input is unconnected if C_DCR_INTFCE=0. |  |  |  |  |
| P2              | DCR_Read                       |                                                 | G5        | This input is unconnected if C_DCR_INTFCE=0.                                                    |  |  |  |  |
| P3              | DCR_Write                      |                                                 | G5        | This input is unconnected if C_DCR_INTFCE=0.                                                    |  |  |  |  |
| P4              | DCR_DBus[0:C_DCR_<br>DWIDTH-1] |                                                 | G5, G9    | Width varies with the size of the DCR data bus. This input is unconnected if C_DCR_INTFCE=0.    |  |  |  |  |
| P5              | PLB_dcrAck                     |                                                 | G5        | This output is grounded if C_DCR_INTFCE=0.                                                      |  |  |  |  |



Table 4: Parameter-Port Dependencies (Contd)

| Generic<br>or Port | Name                                                         | Affects | Depends | Relationship Description                                                                           |
|--------------------|--------------------------------------------------------------|---------|---------|----------------------------------------------------------------------------------------------------|
| P6                 | PLB_dcrDBus[0:C_DCR<br>_ DWIDTH-1]                           |         | G5, G9  | Width varies with the size of the DCR data bus. This output is grounded if C_DCR_INTFCE=0.         |
| P7                 | PLB_rdPendPri[0:1]                                           |         |         |                                                                                                    |
| P8                 | PLB_wrPendPri[0:1]                                           |         |         |                                                                                                    |
| P9                 | PLB_rdPendReq                                                |         |         |                                                                                                    |
| P10                | PLB_wrPendReq                                                |         |         |                                                                                                    |
| P11                | PLB_reqPri[0:1]                                              |         |         |                                                                                                    |
| P12                | M_abort[0:C_PLBV46_N<br>UM_ MASTERS-1]                       |         | G1      | Width varies with the number of PLB masters.                                                       |
| P13                | M_ABus[0:C_PLBV46_N<br>UM_ MASTERS*32-1]                     |         | G1, G3  | Width varies with the size of the PLB addres bus and the number of PLB masters.                    |
| P14                | M_BE[0:C_PLBV46_NU<br>M_<br>MASTERS*C_PLBV46_<br>DWIDTH/8-1] |         | G1,G4   | Width varies with the size of the PLB data bus and the number of PLB masters.                      |
| P15                | M_busLock[0:C_PLBV46<br>_NUM_MASTERS-1]                      |         | G1      | Width varies with the number of PLB masters.                                                       |
| P16                | M_TAttribute[0:16*C_PL<br>BV46_<br>NUM_MASTERS-1]            |         | G1      | Width varies with the number of PLB masters.                                                       |
| P17                | M_lockErr[0:C_PLBV46_<br>NUM_MASTERS-1]                      |         | G1      | Width varies with the number of PLB masters.                                                       |
| P18                | M_mSize[0:C_PLBV46_<br>NUM_ MASTERS*2 -1]                    |         | G1      | Width varies with the number of PLB masters.                                                       |
| P19                | M_priority[0:C_PLBV46_<br>NUM_MASTERS*2 -1]                  |         | G1, G17 | Width varies with the number of PLB masters. When C_ARB_TYPE = 1, the M_priority bits are ignored. |
| P20                | M_rdBurst[0:C_PLBV46_<br>NUM_MASTERS-1]                      |         | G1      | Width varies with the number of PLB masters.                                                       |
| P21                | M_request[0:C_PLBV46_<br>NUM_MASTERS-1]                      |         | G1      | Width varies with the number of PLB masters.                                                       |
| P22                | M_RNW[0:C_PLBV46_N<br>UM_ MASTERS-1]                         |         | G1      | Width varies with the number of PLB masters.                                                       |
| P23                | M_size[0:C_PLBV46_NU<br>M_ MASTERS*4 -1]                     |         | G1      | Width varies with the number of PLB masters.                                                       |
| P24                | M_type[0:C_PLBV46_NU<br>M_ MASTERS*3-1]                      |         | G1      | Width varies with the number of PLB masters.                                                       |
| P25                | M_wrBurst[0:C_PLBV46<br>_ NUM_MASTERS-1]                     |         | G1      | Width varies with the number of PLB masters.                                                       |



Table 4: Parameter-Port Dependencies (Contd)

| Generic<br>or Port | Name                                                            | Affects | Depends | Relationship Description                                                      |
|--------------------|-----------------------------------------------------------------|---------|---------|-------------------------------------------------------------------------------|
| P26                | M_wrDBus[0:C_PLBV46<br>_NUM_MASTERS*C_PL<br>BV46_ DWIDTH -1]    |         | G1, G4  | Width varies with the size of the PLB data bus and the number of PLB masters. |
| P27                | PLB_MAddrAck[0:C_PLB<br>V46_<br>NUM_MASTERS-1]                  |         | G1      | Width varies with the number of PLB masters.                                  |
| P28                | PLB_MBusy[0:C_PLBV4<br>6_NUM_MASTERS-1]                         |         | G1      | Width varies with the number of PLB masters.                                  |
| P29                | PLB_MRdErr[0:C_PLBV<br>46_ NUM_MASTERS-1]                       |         | G1      | Width varies with the number of PLB masters.                                  |
| P30                | PLB_MWrErr[0:C_PLBV<br>46_ NUM_MASTERS-1]                       |         | G1      | Width varies with the number of PLB masters.                                  |
| P31                | PLB_MRdBTerm[0:C_PL<br>BV46_NUM_MASTERS-<br>1]                  |         | G1      | Width varies with the number of PLB masters.                                  |
| P32                | PLB_MRdDAck[0:C_PLB<br>V46_<br>NUM_MASTERS-1]                   |         | G1      | Width varies with the number of PLB masters.                                  |
| P33                | PLB_MRdDBus[0:C_PLB<br>V46_NUM_MASTERS*C<br>_PLBV46_ DWIDTH -1] |         | G1, G4  | Width varies with the size of the PLB data bus and the number of PLB masters. |
| P34                | PLB_MRdWdAddr[0:C_P<br>LBV46_NUM_MASTERS<br>*4 -1]              |         | G1      | Width varies with the number of PLB masters.                                  |
| P35                | PLB_MRearbitrate[0:C_P<br>LBV46_NUM_MASTERS<br>-1]              |         | G1      | Width varies with the number of PLB masters.                                  |
| P36                | PLB_MSSize[0:C_PLBV<br>46_ NUM_MASTERS*2<br>-1]                 |         | G1      | Width varies with the number of PLB masters.                                  |
| P37                | PLB_MWrBTerm[0:C_PL<br>BV46_NUM_MASTERS-<br>1]                  |         | G1      | Width varies with the number of PLB masters.                                  |
| P38                | PLB_MWrDAck[0:C_PLB<br>V46_<br>NUM_MASTERS-1]                   |         | G1      | Width varies with the number of PLB masters.                                  |
| P39                | PLB_MTimeout[0:C_PLB<br>V46_<br>NUM_MASTERS-1]                  |         | G1      | Width varies with the number of PLB masters.                                  |
| P40                | PLB_abort                                                       |         |         |                                                                               |
| P41                | PLB_ABus[0:31]                                                  |         | G3      | Width varies with the size of the PLB address bus.                            |



Table 4: Parameter-Port Dependencies (Contd)

| Generic | Name                                                                      |         | Danasala | Delationable Description                                                  |
|---------|---------------------------------------------------------------------------|---------|----------|---------------------------------------------------------------------------|
| or Port | Name                                                                      | Affects | Depends  | Relationship Description                                                  |
| P42     | PLB_BE[0:C_PLBV46_D<br>WIDTH/8-1]                                         |         | G4       | Width varies with the size of the PLB data bus.                           |
| P43     | PLB_busLock                                                               |         |          |                                                                           |
| P44     | PLB_TAttribute[0:15]                                                      |         |          |                                                                           |
| P45     | PLB_lockErr                                                               |         |          |                                                                           |
| P46     | PLB_masterID[0:C_PLB<br>V46_MID_ WIDTH-1]                                 |         | G12      | Width varies with the number of PLB masters.                              |
| P47     | PLB_MSize[0:1]                                                            |         |          |                                                                           |
| P48     | PLB_PAValid                                                               |         |          |                                                                           |
| P49     | PLB_rdBurst                                                               |         |          |                                                                           |
| P50     | PLB_rdPrim[0:C_PLBV4<br>6_NUM_<br>SLAVES-1][0:C_PLBV46<br>_NUM_ SLAVES-1] |         |          | Width varies with the number of PLB slaves.                               |
| P51     | PLB_RNW                                                                   |         |          |                                                                           |
| P52     | PLB_SAValid                                                               |         |          |                                                                           |
| P53     | PLB_size[0:3]                                                             |         |          |                                                                           |
| P54     | PLB_type[0:2]                                                             |         |          |                                                                           |
| P55     | PLB_wrBurst                                                               |         |          |                                                                           |
| P56     | PLB_wrDBus[0:C_PLBV<br>46_ DWIDTH-1]                                      |         | G4       | Width varies with the size of the PLB data bus.                           |
| P57     | PLB_wrPrim[0:C_PLBV4<br>6_NUM_<br>SLAVES-1][0:C_PLBV46<br>_NUM_ SLAVES-1] |         |          | Width varies with the number of PLB slaves.                               |
| P58     | SI_addrAck[0:C_PLBV46<br>_NUM_ SLAVES-1]                                  |         | G2       | Width varies with the number of PLB slaves.                               |
| P59     | SI_MRdErr[0:C_PLBV46<br>_NUM_<br>SLAVES*C_PLBV46_NU<br>M_ MASTERS-1]      |         | G1, G2   | Width varies with the number of PLB slaves and the number of PLB masters. |
| P60     | SI_MWrErr[0:C_PLBV46<br>_NUM_<br>SLAVES*C_PLBV46_NU<br>M_ MASTERS-1]      |         | G1, G2   | Width varies with the number of PLB slaves ad the number of PLB masters.  |
| P61     | SI_MBusy[0:C_PLBV46_<br>NUM_<br>SLAVES*C_PLBV46_NU<br>M_ MASTERS-1]       |         | G1, G2   | Width varies with the number of PLB slaves and the number of PLB masters. |
| P62     | SI_rdBTerm[0:C_PLBV46<br>_NUM_ SLAVES-1]                                  |         | G2       | Width varies with the number of PLB slaves.                               |



Table 4: Parameter-Port Dependencies (Contd)

| Generic or Port | Name                                                               | Affects | Depends | Relationship Description                                                                                                                                                                    |
|-----------------|--------------------------------------------------------------------|---------|---------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| P63             | SI_rdComp[0:C_PLBV46<br>_NUM_ SLAVES-1]                            |         | G2      | Width varies with the number of PLB slaves.                                                                                                                                                 |
| P64             | SI_rdDAck[0:C_PLBV46_<br>NUM_ SLAVES-1]                            |         | G2      | Width varies with the number of PLB slaves.                                                                                                                                                 |
| P65             | SI_rdDBus[0:C_PLBV46<br>_NUM_<br>SLAVES*C_PLBV46_<br>DWIDTH-1]     |         | G2,G3   | Width varies with the number of PLB slaves and the size of the PLB data bus.                                                                                                                |
| P66             | SI_rdWdAddr[0:C_PLBV<br>46_NUM_ SLAVES*4-1]                        |         | G2      | Width varies with the number of PLB slaves.                                                                                                                                                 |
| P67             | SI_rearbitrate[0:C_PLBV<br>46_NUM_ SLAVES-1]                       |         | G2      | Width varies with the number of PLB slaves.                                                                                                                                                 |
| P68             | SI_SSize[0:C_PLBV46_<br>NUM_ SLAVES*2-1]                           |         | G2      | Width varies with the number of PLB slaves.                                                                                                                                                 |
| P69             | SI_wait[0:C_PLBV46_NU<br>M_ SLAVES-1]                              |         | G2      | Width varies with the number of PLB slaves.                                                                                                                                                 |
| P70             | SI_wrBTerm[0:C_PLBV4<br>6_NUM_ SLAVES-1]                           |         | G2      | Width varies with the number of PLB slaves.                                                                                                                                                 |
| P71             | SI_wrComp[0:C_PLBV46<br>_NUM_ SLAVES-1]                            |         | G2      | Width varies with the number of PLB slaves.                                                                                                                                                 |
| P72             | SI_wrDAck[0:C_PLBV46<br>_NUM_ SLAVES-1]                            |         | G2      | Width varies with the number of PLB slaves.                                                                                                                                                 |
| P73             | Bus_Error_Det                                                      |         | G5,G10  | C_IRQ_ACTIVE determines the active state of the interrupt. If C_DCR_INTFCE=0, then interrupts are always enabled, otherwise, interrupts are enabled by writing to the PLB Control Register. |
| P74             | SI_MIRQ[0:C_PLBV46_<br>NUM_<br>SLAVES*C_PLBV46_NU<br>M_ MASTERS-1] |         | G1, G2  | Width varies with the number of PLB slaves and the number of PLB masters.                                                                                                                   |
| P75             | PLB_MIRQ[0:C_PLBV46<br>_NUM_ MASTERS-1]                            |         | G1      | Width varies with the number of PLB masters.                                                                                                                                                |
| P76             | PLB_Clk                                                            |         |         |                                                                                                                                                                                             |
| P77             | SYS_Rst                                                            |         |         |                                                                                                                                                                                             |
| P78             | PLB_Rst                                                            |         |         |                                                                                                                                                                                             |
| P79             | SPLB_Rst[0:C_PLBV46_<br>NUM_SLAVES-1]                              |         | G2      | Width varies with the number of PLB slave devices.                                                                                                                                          |
| P80             | MPLB_Rst[0:C_PLBV46<br>_NUM_MASTERS-1]                             |         | G1      | Width varies with the number of PLB master devices.                                                                                                                                         |
| P81             | PLB_SaddrAck                                                       |         |         |                                                                                                                                                                                             |
| P82             | PLB_Swait                                                          |         |         |                                                                                                                                                                                             |
|                 | -                                                                  |         |         |                                                                                                                                                                                             |



Table 4: Parameter-Port Dependencies (Contd)

| Generic<br>or Port | Name                                          | Affects | Depends | Relationship Description                        |
|--------------------|-----------------------------------------------|---------|---------|-------------------------------------------------|
| P83                | PLB_Srearbitrate                              |         |         |                                                 |
| P84                | PLB_SwrDAck                                   |         |         |                                                 |
| P85                | PLB_SwrComp                                   |         |         |                                                 |
| P86                | PLB_SwrBTerm                                  |         |         |                                                 |
| P87                | PLB_SrdDBus[0:C_PLB<br>V46_ DWIDTH-1]         |         | G4      | Width varies with the size of the PLB data bus. |
| P88                | PLB_SrdWdAddr[0:3]                            |         |         |                                                 |
| P89                | PLB_SrdDAck                                   |         |         |                                                 |
| P90                | PLB_SrdComp                                   |         |         |                                                 |
| P91                | PLB_SrdBTerm                                  |         |         |                                                 |
| P92                | PLB_SMBusy[0:C_PLBV<br>46_ NUM_MASTERS-1]     |         | G1      | Width varies with the number of PLB masters.    |
| P93                | PLB_SMRdErr[0:C_PLB<br>V46_<br>NUM_MASTERS-1] |         | G1      | Width varies with the number of PLB masters.    |
| P94                | PLB_SMWrErr[0:C_PLB<br>V46_<br>NUM_MASTERS-1] |         | G1      | Width varies with the number of PLB masters.    |
| P95                | PLB_Sssize[0:1]                               |         | G1      | Width varies with the number of PLB masters.    |



**Product Specification** 

## **PLB Registers**

The PLB may optionally contain DCR-accessible registers to provide error address and status information for attempted transactions that did not get a response from any slave. In what follows, the term *error* refers to such a missing response, which is detected by the arbiter's timeout mechanism. If the design has been parameterized to contain a DCR interface (C\_DCR\_INTFCE = 1), then the registers shown in Table 5 are present.

**Note** The base address for these registers is set in the parameter C\_BASEADDR.

Table 5: PLB DCR Registers

| Register Name    | Description              | DCR Address       | Access              |
|------------------|--------------------------|-------------------|---------------------|
| PESR_MERR_DETECT | Master Error Detect Bits | C_BASEADDR + 0x00 | Read/Write          |
| PESR_MDRIVE_PEAR | Master Driving PEAR      | C_BASEADDR + 0x01 | Read                |
| PESR_RNW_ERR     | Read/Write Error         | C_BASEADDR + 0x02 | Read                |
| PESR_LCK_ERR     | Lock Error Bit           | C_BASEADDR + 0x03 | Read                |
| PEAR_ADDR        | PLB Error Address        | C_BASEADDR + 0x04 | Read <sup>(1)</sup> |
| PEAR_BYTE_EN     | PLB Error Byte Enables   | C_BASEADDR + 0x05 | Read <sup>(1)</sup> |
| PEAR_SIZE_TYPE   | PLB Size and Type        | C_BASEADDR + 0x06 | Read <sup>(1)</sup> |
| PACR             | PLB Control Register     | C_BASEADDR + 0x07 | Read/Write          |

#### **Notes**

## **PLB Error Status Registers**

There are four PESR registers that provide error information - was an error detected, which Master's errant address and byte enables are in the PEARs, was the error due to a read or write transaction, and did the master lock the error condition. If a read of the PESR\_MERR\_DETECT register returns all zeros, then no masters detected any errors and no further reads are necessary.

### **PESR MERR DETECT: Master Error Detect Bits**

This register contains the error detect bit for each master. The bit location corresponds to the PLB Master. For example, if PLB Master 0 has experienced an error, then bit 0 is set. Writing a 1 to a bit in this register clears this bit and the corresponding bit in the other PESRs (PESR\_MDRIVE\_PEAR, PESR\_RNW\_ERR, and PESR\_LCK\_ERR).

If a particular master experienced an error and had locked the PEARs<sup>1</sup>, writing a 1 to the corresponding bit in this register would clear and unlock the master's error fields and unlock the PEARs. The bits in this register are reset when a 1 has been written to the register, SYS\_Rst has been asserted, or a 1 has been written to the Software Reset bit in the PACR. Figure 7 shows the bit definitions of this register when the number of PLB masters is 8.

<sup>1.</sup> These registers can be written if the Test Enable bit is asserted in the PACR.

A master specifies whether errors are to be locked on a transaction by transaction basis by asserting the M\_lockErr qualifier signal.

21



The bit definitions for PESR\_MERR\_DETECT are shown in Table 6. The bits is this register are reset by writing a 1 to the bit.



Figure 7: PESR\_MERR\_DETECT (C\_PLBV46\_NUM\_MASTERS=8, C\_DCR\_DWIDTH=32)

Table 6: PLB PESR\_MERR\_DETECT Bit Definitions

| Bit(s)                 | Name                 | Core Access | Reset Value | Description                                                                                             |  |  |
|------------------------|----------------------|-------------|-------------|---------------------------------------------------------------------------------------------------------|--|--|
|                        |                      |             |             | Master Error Detect.  Read: Error detect bit for PLB Masters 0 to C_PLBV46_NUM_ MASTERS-1 respectively. |  |  |
| 0 to                   |                      |             |             | 1 - error detected                                                                                      |  |  |
| C_PLBV46               | Master               |             |             | 0 - no error detected                                                                                   |  |  |
| _NUM_<br>MASTERS-<br>1 | Error<br>Detect      | Read/Write  | 0           | Write: Clear error bit for PLB Masters 0 to C_PLBV46_NUM_ MASTERS -1 respectively.                      |  |  |
|                        |                      |             |             | 1 - clear and unlock corresponding master's error fields and PESRs                                      |  |  |
|                        |                      |             |             | 0 - do not clear error                                                                                  |  |  |
| Others                 | Unused, read as zero |             |             |                                                                                                         |  |  |

### PESR\_MDRIVE\_PEAR: Master Driving PEAR

This register indicates which PLB Master is driving the PEARs. Each bit location in this register corresponds to a PLB Master. For example, if PLB Master 0 is driving the PEARs, then bit 0 is set. Only one master can drive the PEARs, therefore, only one bit is set in this register. Writing to this register has no effect. The bits in this register are reset when a 1 is written to the corresponding bits in PESR\_MERR\_DETECT, SYS\_Rst has been asserted, or a 1 has been written to the Software Reset bit in the PACR. Figure 8 shows the bit definitions of this register when the number of PLB masters is 8 and the width of the DCR data bus is 32.



The bit definitions for PESR\_MDRIVE\_PEAR are shown in Table 7.



Figure 8: PESR\_MDRIVE\_PEAR (C\_PLBV46\_NUM\_MASTERS=8, C\_DCR\_DWIDTH=32)

Table 7: PLB PESR\_MDRIVE\_PEAR Bit Definitions

| Bit(s)                             | Name                      | Core<br>Access | Reset Value | Description                                                                                                                                                                    |
|------------------------------------|---------------------------|----------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0 to<br>C_PLBV46_NUM_<br>MASTERS-1 | Master<br>Driving<br>PEAR | Read           | 0           | Master Driving PEAR.  Read: PEAR bit for PLB Masters 0 to C_PLBV46_NUM_ MASTERS-1 respectively.  1 - master is driving PEAR  0 - master is not driving PEAR  Write: No effect. |
| Others                             | Unused, read as zero      |                |             |                                                                                                                                                                                |

## PESR\_RNW\_ERR: Master Read/Write Bits

This register indicates the read/write condition that caused the error for each PLB Master. Each bit location in this register corresponds to a PLB Master. For example, if PLB Master 0 experienced an error during a read operation, bit 0 would be set.

If PLB Master 1 experienced an error during a write operation, bit 1 would be reset. Writing to this register has no effect. The bits in this register are reset when a 1 is written to the corresponding bits in PESR\_MERR\_DETECT, SYS\_Rst has been asserted, or a 1 has been written to the Software Reset bit in the PACR. Figure 9 shows the bit definitions of this register when the number of PLB masters is 8 and the width of the DCR data bus is 32.



Figure 9: PESR\_RNW\_ERR (C\_PLBV46\_NUM\_MASTERS=8, C\_DCR\_DWIDTH=32)



The bit definitions for PESR\_RNW\_ERR are shown in Table 8.

Table 8: PLB PESR\_RNW\_ERR Bit Definitions

| Bit(s)                             | Name                        | Core<br>Access       | Reset Value | Description                                                                                                                                            |  |  |
|------------------------------------|-----------------------------|----------------------|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| 0 to<br>C_PLBV46_NUM_<br>MASTERS-1 | Master<br>Read Not<br>Write | Read                 | 0           | Master Read Not Write.  Read: RNW status for each master  1 - error was in response to a read  0 - error was in response to a write  Write: No effect. |  |  |
| Others                             |                             | Unused, read as zero |             |                                                                                                                                                        |  |  |

#### **PESR LCK ERR: Master Lock Error Bits**

This register indicates whether each PLB Master has locked their error bits. Each bit location in this register corresponds to a PLB Master. Setting the Master's lock error bit means that the master's error fields are locked, i.e., subsequent errors cannot overwrite master's error fields until error is cleared.

If the Master's lock error bit is reset, the master's error fields are not locked and subsequent errors will overwrite the master's error fields. Writing to this register has no effect. The bits in this register are reset when a 1 is written to the corresponding bits in PESR\_MERR\_DETECT, SYS\_Rst has been asserted, or a 1 has been written to the Software Reset bit in the PACR. Figure 10 shows the bit definitions of this register when the number of PLB masters is 8 and the width of the DCR data bus is 32. The bit definitions for PESR\_LCK\_ERR are shown in Table 9.



Figure 10: PESR\_LCK\_ERR (C\_PLBV46\_NUM\_MASTERS=8, C\_DCR\_DWIDTH=32)



Table 9: PLB PESR\_LCK\_ERR Bit Definitions

| Bit(s)                              | Name                 | Core<br>Access | Reset<br>Value | Description                                                                                                                                                                                                                                                                        |  |
|-------------------------------------|----------------------|----------------|----------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| 0 to<br>C_PLBV46_NUM<br>_ MASTERS-1 | Master<br>Lock Error | Read           | 0              | Master Lock Error.  Read: Lock error bit for each master  1 -error fields are locked (subsequent errors cannot overwrite master's error fields until error is cleared)  0 - error fields are not locked (subsequent errors can overwrite master's error fields)  Write: No effect. |  |
| Others                              | Unused, read as zero |                |                |                                                                                                                                                                                                                                                                                    |  |

## **Bus Error Address Registers**

There are three PEAR registers. These registers contain the PLB address, PLB byte enables, PLB size, and PLB type of the transaction that caused the error.

### PEAR\_ADDR: PLB Error Address register

This register contains the low-order 32 bits of the PLB address of the transaction that caused the error as shown Figure 11. This register is cleared when SYS\_Rst is asserted or a 1 is written to the Software Reset bit.

The bit definitions for PEAR ADDR are shown in Table 10.



Figure 11: PEAR\_ADDR Register

Table 10: PLB PEAR\_ADDR Bit Definitions

| Bit(s)  | Name                        | Core Access                  | Reset Value | Description                                                                                                                                                                           |
|---------|-----------------------------|------------------------------|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0 to 31 | Bus Error<br>Address<br>Low | Read<br>Write <sup>(1)</sup> | 0           | Bus Error Address, low bits.  Read: PLB address where error occurred  Write: If the Test Enable bit is asserted in the PACR, this field is writable.Otherwise, a write has no effect. |

#### Notes:

1. This register can be written if the Test Enable bit is asserted in the PACR.

### PEAR\_BYTE\_EN: PLB Error Byte Enables and High-order Address

This register contains on the left the values of the PLB byte enables and on the right the high-order address bits of the transaction that caused the error as shown in Figure 12. The width of the PLB byte enable bus is the width of the PLB data bus divided by 8. Therefore, if the PLB data bus is 128 bits wide, there are 16 byte enables. This register is cleared when SYS\_Rst is asserted or a 1 is written to the Software Reset bit.



#### 

Figure 12: PEAR\_BYTE\_EN Register

The bit definitions for PEAR\_BYTE\_EN are shown in Table 11.

Table 11: PLB PEAR\_BYTE\_EN Bit Definitions

| Bit(s)                      | Name                         | Core<br>Access               | Reset<br>Value | Description                                                                                                                                                                               |  |
|-----------------------------|------------------------------|------------------------------|----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| 0 to<br>C_PLBV46_DWIDTH/8-1 | Bus Error<br>Address<br>High | Read<br>Write <sup>(1)</sup> | 0              | Bus Error Byte Enables.  Read: PLB byte enable value when error occurred  Write: If the Test Enable bit is asserted in the PACR, this field is writable.Otherwise, a write has no effect. |  |
| 64-C_PLBV46_AWIDTH to 31    |                              |                              |                | Bus Error Byte Enables, high bits.                                                                                                                                                        |  |
| Others                      | Unused, read as zero         |                              |                |                                                                                                                                                                                           |  |

### Notes:

1. This register can be written if the Test Enable bit is asserted in the PACR. Unused bits are not writable.

### PEAR\_SIZE\_TYPE: PLB Error Size and Type

This register contains the values of the PLB size and type during the transaction that caused the error as shown in Figure 13. This register is cleared when SYS\_Rst is asserted or a 1 is written to the Software Reset bit. The bit definitions for PEAR\_SIZE\_TYPE are shown in Table 12.



Figure 13: PEAR\_SIZE\_TYPE Register

DS531 July 28, 2008 <u>www.xilinx.com</u> 25



Table 12: PLB PEAR\_SIZE\_TYPE Bit Definitions

| Bit(s) | Name                 | Core Access                  | Reset Value | Description                                                                                                                                                           |  |  |
|--------|----------------------|------------------------------|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| 0 to 3 | PLB Size             | Read<br>Write <sup>(1)</sup> | '0000'      | PLB Size.  Read: PLB size value when error occurred  Write: If the Test Enable bit is asserted in the PACR, this field is writable. Otherwise, a write has no effect. |  |  |
| 4 to 6 | PLB Type             | Read<br>Write <sup>(1)</sup> | '00'        | PLB Type.  Read: PLB type value when error occurred  Write: If the Test Enable bit is asserted in the PACR, this field is writable. Otherwise, a write has no effect. |  |  |
| Others | Unused, read as zero |                              |             |                                                                                                                                                                       |  |  |

#### Notes:

## **PLB Control Register**

There is one PLB Control register that enables or disables the interrupt request output from the PLB and provides a software reset.

### **PACR: PLB Control Register**

This register contains one bit that enables or disables the interrupt request and another bit used to reset the PLB as shown in Figure 14.

Note that the default state of the control register is to have interrupts enabled, therefore if the PLB is parameterized to not have a DCR interface (C\_DCR\_INTFCE = 0) then interrupts are still enabled.

Also note that when the Software reset bit is asserted, ALL registers and flip-flops within the PLB including all PEAR/PESR registers are reset. This reset occurs independent of the current PLB transaction state, therefore, this reset should be used carefully.

This register is reset to the default state whenever SYS\_Rst is asserted or a 1 is written to the Software Reset bit. The bit definitions for PACR are shown in Table 13.



Figure 14: PACR (C\_DCR\_DWIDTH=32)

<sup>1.</sup> This register can be written if the Test Enable bit is asserted in the PACR. Unused bits are not writable.



Table 13: PLB PACR Bit Definitions

| Bit(s)                 | Name                             | Core<br>Access | Reset<br>Value | Description                                                                                                                                                       |  |
|------------------------|----------------------------------|----------------|----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| 0                      | Interrupt<br>Enable              | Read/Write     | 1              | Interrupt Enable. Read: PLB Interrupt Enable Write:  1 - enable interrupts 0 - disable interrupts                                                                 |  |
| 1                      | Software<br>Reset <sup>(1)</sup> | Read/Write     | 0              | Software Reset.  Read: This bit will always read 0 because it is reset whenever a 1 is written to it.  Write:  1 - reset the PLB  0 - resume normal PLB operation |  |
| 2                      | Test<br>Enable                   | Read/Write     | 0              | Test Enable.  Read: Test Enable  Write:  1 - Enable writing to the PEAR registers  0 - PEAR registers are not writable                                            |  |
| 3 to<br>C_DCR_DWIDTH-1 | Unused, read as zero             |                |                |                                                                                                                                                                   |  |

#### Notes:

## **PLB Interrupt Description**

The PLB has one interrupt request output called Bus\_Error\_Det. The interrupt is signaled when a bus transfer times out because it is not responded to by any slave. This interrupt is an edge type interrupt and is automatically reset to the inactive state on the next clock cycle, therefore an explicit interrupt acknowledge is not required. The active level of the Bus\_Error\_Det interrupt is determined by the design parameter, C\_IRQ\_ACTIVE.

Note that if interrupts are enabled, then an interrupt request from the PLB is generated whenever any timeout error is detected regardless of whether masters have locked their error fields or not (see "PLB Registers" on page 20). Also note that if the parameter C\_DCR\_INTFCE is 0, indicating that there is no DCR interface, then interrupts will be still be enabled because the default state of the Interrupt Enable bit in the PACR is asserted.

## **Master Interrupt Request**

The Xilinx PLB supports the Sl\_MIRQ(0 to C\_PLBV46\_NUM\_ SLAVES\*C\_PLBV46\_NUM\_ MASTERS - 1) signal, which allows each slave to signal to any master that it has encountered an event that it deems of importance to that master. The only function of the Xilinx PLB with respect to the MIRQ signals is to OR all of the Sl\_MIRQ signals for a given master into the corresponding bit of PLB\_MIRQ(0 to C\_PLBV46\_NUM\_ MASTERS-1).

<sup>1.</sup> The software reset will reset the entire PLB regardless of the current PLB transaction state. Therefore, the software reset should be used with caution.



## **PLB Block Diagram**

Figure 15 provides a comprehensive block diagram of the PLB.



Figure 15: PLB Block Diagram

#### **Address Path Unit**

The PLB address path unit contains the necessary muxing to select the master address which is driven to the slave devices on the PLB address output.

#### Write Data Path Unit

The PLB write data path unit contains the necessary steering logic for the master and slave write data buses.

### **Read Data Path Unit**

The PLB read data path unit contains the necessary steering logic for the master and slave read data buses.

### **Bus Control Unit**

The PLB bus control unit consists of a bus arbitration control unit that manages the address and data flow through the PLB and DCRs. The bus arbitration control unit supports arbitration for 8 PLB masters. The address and data flow control logic provides address pipelining and address and data steering support for 8 PLB masters and 8 PLB slaves.

DCR-accessible, PLB registers may be optioned in for use in reporting timeout errors. The registers are accessed by using the *move from device* control register (*mfdcr*) and *move to device* control register (*mtdcr*) instructions, which move data between the device control registers and the processor's general purpose registers.

Refer to PLB Registers for additional information.

### **Bus Arbitration**

28

The PLB v4.6 arbitration type is selected using the C\_ARB\_TYPE design parameter. When C\_ARB\_TYPE = 0, the arbitration type is a fixed priority arbitration as discussed in "Basic Operation" on page 2.



When C\_ARB\_TYPE = 1, the arbitration logic is configured in a round robin scheme. The round robin implementation on the PLB v4.6 is such that the last master to win arbitration and be "granted" the bus, will be the lowest priority available master to be granted the bus in the next arbitration cycle. The arbitration cycle is indicated by either the assertion of a Sl\_AddrAck, Sl\_reArbitrate, or a PLB timeout condition. Round robin arbitration keeps an embedded priority scheme fixed amongst the masters in the system and rotates the priority ordering based on the last master to win the bus. The arbitration solve to arbitrate on requesting masters indicated by the M\_Request signals at the arbitration clock cycle.

The round robin scheme, allows masters that may have been starved for the bus, a fair chance of being granted the bus. An example of round robin implementation with C NUM MASTERS = 3 is shown in Figure 16 below.



Figure 16: Example of Round Robin Arbitration

## **Watchdog Timer**

The PLB watchdog timer is used to generate the PLB\_MTimeout response when no slave responds. The watchdog time is set to 16 clock cycles.

## Reset Logic

The PLB v4.6 does not include any power-on reset circuitry to ensure that a PLB reset is generated upon power-on if no external reset (Sys\_Rst) is provided. It is the assumption in PLB v4.6 systems, that the designer will include the proc\_sys\_reset core to ensure a power-on reset is asserted for at least 16 clock cycles.

The reset logic in the PLB v4.6 core will provide one stage of synchronization from the external reset (Sys\_Rst) to the output reset signals, PLB\_Rst, SPLB\_Rst, and MPLB\_Rst. The PLB reset is synchronous to the PLB clock.

The additional slave and master vectorized reset signals (SPLB\_Rst and MPLB\_Rst), have identical timing characteristics as the PLB reset (PLB\_Rst).

#### Point-to-Point Mode

The PLB v4.6 core can be optimized for point-to-point connections by setting the design parameter, C\_P2P = 1. This configuration allows for optimization when only a single master and single slave device are required to communicate.

In this mode, components such as the Address Path, Write & Read Data Path Units, and Bus Control Unit are not included in the core to minimize resource utilization and improve latency. In point-to-point mode, the M\_Request signal can be directly routed to PLB\_PAValid with minimal latency. The point-to-point mode still incorporates the Watchdog Timer to allow PLB\_MTimeout to be asserted if the slave device does not respond to PLB\_PAValid.



Enabling address pipelining is configurable in point-to-point mode. By setting the design parameter, C\_ADDR\_PIPELINING\_TYPE = 1, a 2-level pipeline is incorporated in the design. In this configuration, an arbitration state machine controls the assertion of PLB PAValid and PLB SAValid.

When the PLB is configured in a point-to-point mode,  $C_P2P = 1$ , the bus will ignore any assertion by the master device on the M\_busLock signal. Since only one master is utilizing the bus, there is no need to drive PLB\_busLock and the bus will default this output to '0'.

## Master[n] Interface

Figure 17 shows all master[n] interface I/O signals (where *n* is the number of a master 0 to C\_PLBV46\_NUM\_MASTERS-1). Refer to the *IBM 128-Bit Processor Local Bus Architectural Specification (v4.6)* for detailed functional descriptions of these signals. Note that C\_PLBV46\_DWIDTH =128 and C\_PLBV46\_AWIDTH=36 in this diagram.

## Slave Interface[m]

Figure 18 demonstrates all slave[m] interface I/O signals (where m = 0 to C\_PLBV46\_NUM\_ SLAVES-1). Refer to the *IBM 128-Bit Processor Local Bus Architectural Specification (v4.6)* for detailed functional descriptions of these signals. Note that C\_PLBV46\_NUM\_ MASTERS=8, C\_PLBV46\_DWIDTH=128, and C\_PLBV46\_AWIDTH=36 in this diagram.

#### **DCR** Interface

The device control register (DCR) interface allows the CPU core in the system to read and write the DCRs in the PLB. For additional information on the DCR bus, see the *IBM 32-Bit Device Control Register Bus Architecture Specifications*.

Figure 19 demonstrates all DCR interface input/output signals when C\_DCR\_DWIDTH = 32 and C\_DCR\_AWIDTH=10.





DS531\_12\_041807

Figure 17: Master[n] Interface

32





DS531\_13\_051308

Figure 18: Slave[n] Interface





Figure 19: DCR Interface

## **PLB Operations**

The *IBM 128-Bit Processor Local Bus Architectural Specification (v4.6)* document provides a comprehensive discussion on the various PLB operations and transfers. The reader is referred to that document for further protocol description and timing diagrams. Different specific timing relationships can conform to the same protocol and might reflect different trade-offs between Fmax, latency and resource usage. Some expected timing characteristics of a prospective implementation are noted below, without imposing them as rigid requirements.

- M\_request to PLB\_PAValid delay
  - 2 cycles when the number of masters is two or more
  - 1 (or possibly 0) cycles when there is one master
- · Master-to-slave signals flow combinatorially through a multiplexer whose selection is the active master
- Slave-to-master signals flow combinatorially through an OR concentrator over all slaves, then through a
  demultiplexer to the active master
- PLB\_rdPrim and PLB\_wrPrim react combinatorially to the respective Sl\_rdComp or SL\_wrComp

#### **Bus Time-Out**

Because the timeout concept for PLB V4.6 differs from PLB V3.4, it is illustrated here in more detail. Please note that a timeout finishes a transaction in the address phase instead of proceeding, as with V3.4, to a data phase with the arbiter supplying artificial address and data acknowledges. Figure 20 shows a bus time-out for an attempted transfer to which no slave responds within the timeout interval of 16 clocks. The PLB arbitration logic samples the Sl\_wait, Sl\_rearbitrate and M\_Abort signals 16 cycles after the initial assertion of the PLB\_PAValid signal, and if all are negated, it asserts the PLB\_MTimeout signal. This completes all handshaking for the transfer l.

1. Earlier versions of the PLB specified that the arbiter had the responsibility to complete the address and data handshakes for a timed-out transfer. This is no longer needed with addition of the PLB\_MTimeout signal.





Figure 20: Bus Time-Out

## **Time-Out Suppression**

If a slave cannot respond within 16 cycles, it can suppress the timeout and buy more time. Figure 21 shows a slave suppressing the timeout by responding with Sl\_wait[m] within 16 clocks. When the slave is eventually ready, it responds with Sl\_AddrAck[m] (shown) or Sl\_rearbitrate[m].



Figure 21: Time-Out Suppression

## **Design Implementation**

## **Target Technology**

34

The initial target technology is the Virtex and Spartan families FPGAs.

#### **Device Utilization and Performance Benchmarks**

Because the PLB is a module that is used with other design pieces in the FPGA, the utilization and timing numbers reported in this section are just estimates. As the PLB is combined with other pieces of the FPGA design, the utilization of FPGA resources and timing of the PLB design will vary from the results reported here.

The PLB benchmarks shown in Table 14 are for a Virtex-5 (XC5VFX70T) device.



| Parameter Values      |                      |                        |                                        |                             | Device Resources |                    |            |                           |
|-----------------------|----------------------|------------------------|----------------------------------------|-----------------------------|------------------|--------------------|------------|---------------------------|
| C_PLBV46_NUM_ MASTERS | C_PLBV46_NUM_ SLAVES | C_P2P<br>(default = 0) | C_ADDR_ PIPELINING_TYPE<br>(default=1) | C_ARB_TYPE<br>(default = 0) | Slices           | Slice<br>Registers | Slice LUTs | f <sub>MAX</sub><br>(MHz) |
| 1                     | 1                    | 1                      | 0                                      | N/A                         | 4                | 10                 | 14         | 635.3                     |
| 1                     | 1                    | 1                      | 1                                      | N/A                         | 11               | 17                 | 35         | 500.2                     |
| 1                     | 1                    | 0                      | 1                                      | 0                           | 46               | 128                | 67         | 378.7                     |
| 1                     | 4                    | 0                      | 1                                      | 0                           | 64               | 131                | 149        | 357.5                     |
| 4                     | 1                    | 0                      | 1                                      | 0                           | 242              | 175                | 559        | 220.8                     |
| 4                     | 4                    | 0                      | 0                                      | 0                           | 259              | 156                | 658        | 252.5                     |
| 4                     | 4                    | 0                      | 1                                      | 0                           | 243              | 179                | 655        | 222.8                     |
| 4                     | 4                    | 0                      | 1                                      | 1                           | 278              | 197                | 683        | 227.6                     |
| 8                     | 8                    | 0                      | 0                                      | 0                           | 354              | 184                | 1214       | 235.8                     |
| 8                     | 8                    | 0                      | 1                                      | 0                           | 331              | 221                | 1185       | 203.2                     |
| 8                     | 16                   | 0                      | 1                                      | 0                           | 438              | 229                | 1296       | 228.4                     |

Table 14: PLB FPGA Performance and Resource Utilization Benchmarks

#### Notes:

## **Specification Exceptions**

There are few differences that should be noted by the reader of this specification who also reads the IBM PLB v4.6 specification.

#### PLB Bus Structure

The Xilinx PLB provides the full PLB bus structure. No external OR gates are required for the slave input data. Each PLB slave connects directly to the Xilinx PLB as shown in Figure 1.

## I/O Signals

The master interface signals and many of the PLB signals have been combined into a bus with an index that varies with the number of masters. This modification more easily supports the parameterization of the number of masters and the number of slaves supported by the Xilinx PLB.

Signals that have the master designator of Mn in the signal name in the IBM PLB specification have a master designator of M in the signal name in this document. For example, the signal called **PLB\_MnReabitrate** in the IBM specification is called **PLB\_MRearbitrate** here. Similarly, **Mn\_RNW** is called **M\_RNW**.

These benchmark designs contain only the PLB with registered inputs/outputs without any additional logic. Benchmark numbers approach the performance ceiling rather than representing performance under typical user conditions.



The optional parity concept of PLB v4.6 is not supported. No parity signals are included in the ports.

## Differences between the PLB v4.6 and the v3.4

The Xilinx PLB v4.6 bus logic core, the subject of this data sheet, is derived from the PLB v3.4 core. The major difference between the Xilinx PLB v4.6 and Xilinx PLB v3.4 cores are:

- Maximum data width of 128 bits versus 64 bits.
- M\_UABus and PLB\_UABus signals added to allow address to grow beyond 32 bits. Currently, all Xilinx soft IP and EDK tool only utilize 32-bits of the initial PLB v4.6 implementation. The UABus is included as a required port connection on peripherals, but is driven to zeros by Masters and internally ignored by Slave IP devices. The PLB v4.6 upper address bus will be included in the required port interface for peripherals and included in the bus structure multiplexing by the arbiter.
- **PLB\_MTimeout** signal added. If no slave responds to the **PAValid** assertion, the arbiter asserts the **PLB\_MTimeout** signal for one clock. In the PLB v3.4 version the arbiter had responsibility to complete the address acknowledge and data acknowledges (with error qualification on the data acknowledges).
- **SL\_MIRQ** and **PLB\_MIRQ** signals added. These allow any slave to signal an event deemed important to any master.
- Sl\_MErr and PLB\_MErr signals split into separate read and write versions: SL\_MWrErr, Sl\_MRdErr, PLB\_MWrErr and PLB\_MRdErr.
- PLB\_pendReq and PLB\_pendPri signals split into separate read and write version: PLB\_wrPendReq, PLB\_rdPendReq, PLB\_wrPendPri and PLB\_rdPendPri.
- Sixteen-bit M\_TAttribute and PLB\_TAttribute signals added. The compressed, guarded and ordered
  qualifiers are now expressed as TAttribute values, and separate signals for these qualifiers are no longer
  present.

#### **Reference Documents**

The following documents contain reference information important to understanding the Xilinx PLB design:

- IBM 128-Bit Processor Local Bus Architectural Specification (v4.6)
- Processor Local Bus (PLB) v3.4
- IBM 32-Bit Device Control Register Bus Architecture Specifications, Version 2.9



## **Notice of Disclaimer**

Xilinx is providing this design, code, or information (collectively, the "Information") to you "AS-IS" with no warranty of any kind, express or implied. Xilinx makes no representation that the Information, or any particular implementation thereof, is free from any claims of infringement. You are responsible for obtaining any rights you may require for any implementation based on the Information. All specifications are subject to change without notice. XILINX EXPRESSLY DISCLAIMS ANY WARRANTY WHATSOEVER WITH RESPECT TO THE ADEQUACY OF THE INFORMATION OR ANY IMPLEMENTATION BASED THEREON, INCLUDING BUT NOT LIMITED TO ANY WARRANTIES OR REPRESENTATIONS THAT THIS IMPLEMENTATION IS FREE FROM CLAIMS OF INFRINGEMENT AND ANY IMPLIED WARRANTIES OF MERCHANTABILITY OR FITNESS FOR A PARTICULAR PURPOSE. Except as stated herein, none of the Information may be copied, reproduced, distributed, republished, downloaded, displayed, posted, or transmitted in any form or by any means including, but not limited to, electronic, mechanical, photocopying, recording, or otherwise, without the prior written consent of Xilinx.



# **Revision History**

| Date     | Version | Revision                                                                                                                                                                                                                     |  |  |  |
|----------|---------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| 1/9/06   | 1.0     | Initial Xilinx release.                                                                                                                                                                                                      |  |  |  |
| 4/18/07  | 1.1     | Added vectorized reset signals.                                                                                                                                                                                              |  |  |  |
| 4/23/07  | 1.2     | Added C_P2P parameter. Added 32 as an allowable value for C_PLBV46_DWIDTH.                                                                                                                                                   |  |  |  |
| 4/24/07  | 1.3     | Updated 32-bit support to Page 1 Features.                                                                                                                                                                                   |  |  |  |
| 6/7/07   | 1.4     | Add section to describe point-to-point topology configuration. Update reset behavior description in Reset Logic section.                                                                                                     |  |  |  |
| 6/22/07  | 1.5     | Added C_FAMILY supported types. Clarified PLB v4.6 in text.                                                                                                                                                                  |  |  |  |
| 7/17/07  | 1.6     | Update timeout counter values for P2P mode. Change default value of C_ADDR_PIPELINING_TYPE parameter. Added text to indicate that the plb2opb bridge core and the plb_v34 core are both legacy cores in the EDK 9.2 release. |  |  |  |
| 7/24/07  | 1.7     | Edit UABus references.                                                                                                                                                                                                       |  |  |  |
| 8/8/07   | 1.8     | Reword UABus text. Remove P2P timeout counter updates.                                                                                                                                                                       |  |  |  |
| 8/9/07   | 1.9     | Remove 66 MHz reference in Table 3.                                                                                                                                                                                          |  |  |  |
| 10/8/07  | 2.0     | Update to core version v1.01a. Added new design parameter, C_ARB_TYPE to select between existing fixed priority and new feature round robin arbitration type.                                                                |  |  |  |
| 10/22/07 | 2.1     | Update round robin timing diagram and text description.                                                                                                                                                                      |  |  |  |
| 10/30/07 | 2.2     | Add P2P address pipelining description and diagrams.                                                                                                                                                                         |  |  |  |
| 11/7/07  | 2.3     | Remove references to C_NUM_CLK_PLB2OPB_REARB parameter and input signal, PLB2OPB_rearb.                                                                                                                                      |  |  |  |
| 11/8/07  | 2.4     | Added note regarding M_busLock is ignored when C_P2P=1.                                                                                                                                                                      |  |  |  |
| 12/11/07 | 2.5     | Added Virtex-II Pro support.                                                                                                                                                                                                 |  |  |  |
| 12/20/07 | 2.6     | Update resource utilization table with values for Virtex-5. Add notes in Table 2 regarding the tested values of the C_PLBV46_NUM_MASTERS and C_PLBV46_NUM_SLAVES parameters.                                                 |  |  |  |
| 04/15/08 | 2.7     | Update to v1.03a.                                                                                                                                                                                                            |  |  |  |
| 4/22/08  | 2.8     | Added Automotive Spartan-3E, Automotive Spartan-3A, Automotive Spartan-3, and Automotive Spartan-3A DSP support.                                                                                                             |  |  |  |
| 6/13/08  | 2.9     | Revised Figure 18.                                                                                                                                                                                                           |  |  |  |
| 7/28/08  | 3.0     | Added QPro Virtex-4 Hi-Rel, QPro Virtex-4 Rad Tolerant, and Spartan-3AN FPGA support.                                                                                                                                        |  |  |  |

38