

# PLBv46 to Wishbone Bridge

Author: Mark Sasten mark.sasten@xilinx.com

> Rev. 0.1 January 20, 2009



This page has been intentionally left blank.



### **Revision History**

| Rev. | Date    | Author      | Description               |
|------|---------|-------------|---------------------------|
| 0.1  | 7/30/08 | Mark Sasten | First Draft               |
| 0.2  | 1/20/09 | Mark Sasten | Added ports and diagrams. |



## Contents

| INTRODUCTION                                  |                                                              |
|-----------------------------------------------|--------------------------------------------------------------|
| ARCHITECTURE                                  |                                                              |
| OPERATION                                     |                                                              |
| REGISTERS                                     | ERROR! BOOKMARK NOT DEFINED.                                 |
| List of Registers<br>Register 1 – Description | Error! Bookmark not defined.<br>Error! Bookmark not defined. |
| CLOCKS                                        | ERROR! BOOKMARK NOT DEFINED.                                 |
| IO PORTS                                      |                                                              |
| APPENDIX A                                    | ERROR! BOOKMARK NOT DEFINED.                                 |
| APPENDIX B                                    | ERROR! BOOKMARK NOT DEFINED.                                 |
| INDEX                                         | ERROR! BOOKMARK NOT DEFINED.                                 |



## Introduction

This document provides specifications for the PLBv46<sup>TM</sup> to Wishbone<sup>TM</sup> bridge that has been made to work inside Xilinx EDK projects. Many embedded projects require simple interfaces to different bus standards. One very popular bus interface is the Wishbone bus used by many OpenCores.org peripherals. This bridge allows Microblaze and PowerPC applications to utilize many of these open source cores.

#### Features:

- PLBv46 Slave Attachment (non-bursting)
  - Native 32-bit slave interface to PLBv46 bus.
  - 32-bit master interface to Wishbone bus.
- > Directly integrated into EDK tools as a custom pcore.
  - o Comes as synthesizable VHDL
  - Microprocessor Peripheral Definition (MPD) file provided.
  - Compiles with PLBv46 subset of IBM CoreConnect<sup>™</sup> Bus Standard.
- > Supports
  - o Handling of retries.
    - User can set the retry wait time.
    - User can set number of times to retry transaction.
    - Result of unsuccessful retry is a PLBv46 bus error ack.
  - o Handling of Bus Errors
    - User can set how long to wait for a bus-timeout resulting from noacknowledgement from a Wishbone transaction.
    - Results in an immediate PLBv46 Bus Error.
    - Will translate Wishbone Bus Errors to PLBv46 bus.



## Architecture

The typical use of the PLBv46 to Wishbone Bridge is to allow the integration of Wishbone Slave peripherals into a Xilinx embedded design application. This could include the utilization of either the Microblaze or PowerPC processors. The standard method for embedding the PLBv46 to Wishbone bridge is to include it into the EDK design and to bring out the Wishbone Bus to an upper level HDL source to connect to the slave peripherals as shown below.







The EDK System is shown in the figure below.



## Operation

This section describes the operation of the core. Specific sequences, such as startup sequences, as well as the modes and states of the block should be described.

### **Clocking and Reset**

Wishbone bridge clock and reset signals are derived from the PLBv46 clock and reset inputs as shown below. They are a direct mapping from the PLB clock source to the wishbone clock. No additional global buffering is required. This means that the WB\_CLK\_O domain will be at the same clock frequency as the SPLB\_Clk domain. No additional clock synchronization is required by the bridge.





### **Address Decoding**

There are two phases to the address decoding for this block. The first is handled by the bridge to map the bridge to the PLB address range. This is handled by the EDK tools when setting the C\_MEM0\_BASEADDR and C\_MEM0\_HIGHADDR in the MHS file.

The second address decoding is performed by user defined logic on the Wishbone side of the bridge. This requires the user to architect the Wishbone bus with the desired peripherals.

The following figure illustrates a typical decoder that will process the Wishbone signals coming out of the PLBv46 to Wishbone bridge and produce signals to decode the individual slave devices.





## **IO Ports**

This section specifies the core IO ports. There are several ports defined by the PLBv46 specification that are not used for this bridge application. This is either due to the Xilinx PLBv46 simplification or because this core does not support burst transfers.

| Port           | Width | Dir | Description                       |
|----------------|-------|-----|-----------------------------------|
| SPLB_Clk       | 1     | Ι   |                                   |
| SPLB_Rst       | 1     | Ι   |                                   |
| PLB_ABus       | 32    | Ι   | PLB Address Bus                   |
| PLB_PAValid    | 1     | Ι   | PLB Primary Address Valid         |
| PLB_masterID   | 4*    | Ι   | PLB current master identifier     |
| PLB_RNW        | 1     | Ι   | PLB read not write                |
| PLB_BE         | 4     | Ι   | PLB byte enables                  |
| PLB_size       | 4     | Ι   | PLB size of requested transfer    |
| PLB_type       | 3     | Ι   | PLB transfer type                 |
| PLB_wrDBus     | 32    | Ι   | PLB write data bus                |
| Sl_addrAck     | 1     | 0   | Slave address acknowledge         |
| Sl_SSize       | 2     | 0   | Slave data bus size               |
| Sl_wait        | 1     | 0   | Slave wait                        |
| Sl_rearbitrate | 1     | 0   | Slave bus rearbitrate             |
| Sl_wrDAck      | 1     | 0   | Slave bus data acknowledge        |
| Sl_wrComp      | 1     | 0   | Slave write transfer complete     |
| Sl_rdDBus      | 32    | 0   | Slave read data bus               |
| Sl_rdDAck      | 1     | 0   | Slave read data acknowledge       |
| Sl_rdComp      | 1     | 0   | Slave read data transfer complete |
| Sl_MBusy       | *     | 0   | Slave busy                        |
| Sl_MWrErr      | *     | 0   | Slave write error                 |
| Sl_MRdErr      | *     | 0   | Slave read error                  |

### PLBv46 Interface Ports

Table: List of PLBv46 ports



| Port           | Width | Dir | Description                                      |
|----------------|-------|-----|--------------------------------------------------|
| PLB_UABus      | 32    | Ι   | PLB upper address bus                            |
| PLB_SAValid    | 1     | Ι   | PLB secondary address valid                      |
| PLB_rdPrim     | 1     | Ι   | PLB secondary to primary read request indicator  |
| PLB_wrPrim     | 1     | Ι   | PLB secondary to primary write request indicator |
| PLB_abort      | 1     | Ι   | PLB abort bus request                            |
| PLB_busLock    | 1     | Ι   | PLB bus lock                                     |
| PLB_MSize      | 2     | Ι   | PLB data bus width indicator                     |
| PLB_TAttribute | 16    | Ι   | PLB transfer attribute                           |
| PLB_lockErr    | 1     | Ι   | PLB lock error                                   |
| PLB_wrBurst    | 1     | Ι   | PLB burst write transfer                         |
| PLB_rdBurst    | 1     | Ι   | PLB burst read transfer                          |
| PLB_wrPendReq  | 1     | Ι   | PLB pending bus write priority                   |
| PLB_rdPendReq  | 1     | Ι   | PLB pending bus read priority                    |
| PLB_wrPendPri  | 2     | Ι   | PLB pending bus write request                    |
| PLB_rdPendPri  | 2     | Ι   | PLB pending bus read request                     |
| PLB_reqPri     | 2     | Ι   | PLB pending write request priority               |
| Sl_wrBTerm     | 1     | 0   | Slave terminate write burst transfer             |
| Sl_rdWdAddr    | 4     | 0   | Slave read word address                          |
| Sl_rdBTerm     | 1     | 0   | Slave read burst terminate                       |
| S1_MIRQ        | *     | 0   | Master interrupt request                         |
|                |       |     |                                                  |

### **Unused PLBv46 Interface Ports**

#### Table: List of Unused PLBv46 ports

### Wishbone Interface Ports

| Port      | Width | Dir | Description                  |
|-----------|-------|-----|------------------------------|
| WB_CLK_O  | 1     | 0   | System clock output (SYSCON) |
| WB_RST_O  | 1     | 0   | System reset output (SYSCON) |
| WB_ADR_O  | 32    | 0   | Address output array         |
| WB_DAT_O  | 32    | 0   | Data from bridge             |
| WB_SEL_O  | 4     | 0   | Byte select signals          |
| WB_CYC_O  | 1     | 0   | Valid bys cycle output       |
| WB_LOCK_O | 1     | 0   | Locked transfer              |
| WB_STB_O  | 1     | 0   | Valid data transfer cycle    |
| WB_WE_O   | 1     | 0   | Write enable output          |
| WB_DAT_I  | 32    | Ι   | Data to bridge               |
| WB_ACK_I  | 1     | Ι   | Transfer acknowledgement     |
| WB_ERR_I  | 1     | Ι   | Bus cycle error input        |
| WB_RTY_I  | 1     | Ι   | Retry signaled to bridge.    |



## **Transaction Waveforms**

TO BE ADDED