# WbXbc Manual

Dirk Heisswolf

# **Table of Contents**

| Overview                                                  | 1  |
|-----------------------------------------------------------|----|
| Integration Parameters                                    | 2  |
| Interface Signals                                         | 3  |
| General Signals (SYSCON)                                  | 3  |
| Initiator Bus Signals.                                    | 3  |
| Target Bus Signals                                        | 4  |
| Crossbar Switch components                                | 6  |
| WbXbc Address Decoder                                     | 6  |
| WbXbc Error Generator                                     | 8  |
| WbXbc Splitter                                            | 10 |
| WbXbc Arbiter                                             | 13 |
| WbXbc Expander                                            | 15 |
| WbXbc Reducer                                             | 17 |
| WbXbc Accelerator                                         | 20 |
| WbXbc Decelerator                                         | 22 |
| WbXbc Pipeliner                                           | 24 |
| WbXbc Standardizer                                        | 26 |
| WbXbc Distributor                                         | 28 |
| WbXbc Xbar                                                | 31 |
| My Interpretation of the Pipelined Wishbone Protocol Spec | 35 |
| Protocol Signals Driven by the Initiator                  | 35 |
| Protocol Signals Driven by the Target                     | 39 |
| Bibliography                                              | 41 |

# **Overview**

TBD

# **Integration Parameters**

This section specifies the integration parameters to configure the WbXbc components. Each WbXbc component supports a subset of the parameters listed below.

#### ITR CNT

The number of initiator bus interfaces to be offered by the WbXbc component

#### TGT CNT

The number of target bus interfaces to be offered by the WbXbc component

#### ADDR\_WIDTH

Width of all address busses (ADR\_I and ADR\_0)

#### ITR\_ADDR\_WIDTH

Width of the initiator address bus(ses) (ADR\_I), in case it differs from the target address bus(es) (ADR\_O)

#### **SEL WIDTH**

Number data select lines of all initiator and target busses (SEL\_I and SEL\_O)

#### ITR\_SEL\_WIDTH

Number of data select lines of the initiator bus (SEL\_I), in case it from the target bus (SEL\_O)

#### DATA\_WIDTH

Width of all data busses (initiator and target, read and write direction)

#### ITR DATA WIDTH

Width of the initiator's data busses (read and write direction

#### TGA\_WIDTH

Number of tags associated with the address busses of the initiator and the target (TGA\_I and TGA\_O)

#### TGC\_WIDTH

Number of tags associated with the cycle indicators (CYC\_I and CYC\_O) of thw initiator and the target (TGC\_I and TGC\_O)

#### TGRD\_WIDTH

Number of tags associated with the read data busses of the initiator and the target (TGD\_O and TGD\_I)

#### TGWD\_WIDTH

Number of tags associated with the write data busses of the initiator and the target (TGD\_I and TGD\_O)

#### **BIG ENDIAN**

Selects the endianess of the design (1=big endian, 0=little endian)

# **Interface Signals**

All WbXbc components share common interface signals, which are described in this chapter. Most of these signals refer directly to the Wishbone specification [1].

## **General Signals (SYSCON)**

#### clk i

Common clock input for all Wishbone interfaces

#### itr clk i

clock input for all initiator busses. Target busses must be clocked by synchronous and subdivided clock.

#### tgt\_clk\_i

clock input for all target busses. Initiator busses must be clocked by synchronous and subdivided clock.

#### itr2tgt\_sync\_i

This signal indicates a common positive clock edge of the initiator clock and the synchronous and subdivided target clock.

## tgt2itr\_sync\_i

This signal indicates a common positive clock edge of the targert clock and the synchronous and subdivided initiator clock.

#### async\_rst\_i

An optional asynchronous reset signal for all sequential logic. This reset signal may assert asynchronously, but must deassert synchronously. If no asynchronous reset is implemented, this input must be tied to zero.

#### sync\_rst\_i

A synchronous reset signal as required by the Wishbone specification (RST\_I). For WbXBC components, this synchronous reset is not required, if an asynchronous reset is provided. If no synchronous reset is implemented, this input must be tied to zero.

## **Initiator Bus Signals**

# itr\_cyc\_i TBD itr\_stb\_i

## itr\_we\_i

**TBD** 

**TBD** 

```
itr_lock_i
  TBD
itr\_sel\_i
  TBD
itr_adr_i
  TBD
itr_dat_i
  TBD
itr_tga_i
  TBD
itr_tgc_i
  TBD
itr_tgd_i
  TBD
itr_ack_o
  TBD
itr_err_o
  TBD
itr_rty_o
  TBD
itr_stall_o
  TBD
itr_dat_o
  TBD
itr_tgd_o
  TBD
```

# **Target Bus Signals**

tgt\_cyc\_o

TBD

tgt\_stb\_o

TBD

tgt\_we\_o TBD tgt\_lock\_o TBD tgt\_sel\_o TBD tgt\_adr\_o TBD tgt\_dat\_o TBD tgt\_tga\_o TBD tgt\_tgc\_o TBD tgt\_tgd\_o TBD tgt\_ack\_i TBD tgt\_err\_i TBD tgt\_rty\_i TBD tgt\_stall\_i

TBD

tgt\_dat\_i TBD

tgt\_tgd\_i TBD

# **Crossbar Switch components**

**TBD** 

# **WbXbc Address Decoder**



This module implements an address decoder for the Wishbone protocol. It propagates accesses from the initiator bus to the target bus and adds a set of address tags which selecting the target block.

## **Integration Parameters**

| Parameter  | Default Value | Description                          |
|------------|---------------|--------------------------------------|
| TGT_CNT    | 4             | number of target addresses to decode |
| ADDR_WIDTH | 16            | width of the address bus             |
| DATA_WIDTH | 16            | width of each data bus               |
| SEL_WIDTH  | 2             | number of data select lines          |
| TGA_WIDTH  | 1             | number of address tags               |
| TGC_WIDTH  | 1             | number of cycle tags                 |
| TGRD_WIDTH | 1             | number of read data tags             |
| TGWD_WIDTH | 1             | number of write data tags            |

Section Integration Parameters gives a detailed description of each parameter listed above.

| Signal                 | Range                    | Direction | Description                                             |
|------------------------|--------------------------|-----------|---------------------------------------------------------|
| Target Address Regions |                          |           |                                                         |
| region_addr            | (TGT_CNT*ADDR_WIDTH)-1:0 | input     | target address                                          |
| region_mask            | (TGT_CNT*ADDR_WIDTH)-1:0 | input     | selects relevant address bits (1: relevant, 0: ignored) |
| Initiator Interface    |                          |           |                                                         |
| itr_cyc_i              |                          | input     | bus cycle indicator                                     |

| Signal           | Range          | Direction | Description               |
|------------------|----------------|-----------|---------------------------|
| itr_stb_i        |                | input     | access request            |
| itr_we_i         |                | input     | write enable              |
| itr_lock_i       |                | input     | uninterruptable bus cycle |
| itr_sel_i        | SEL_WIDTH-1:0  | input     | write data selects        |
| itr_adr_i        | ADDR_WIDTH-1:0 | input     | address bus               |
| itr_dat_i        | DATA_WIDTH-1:0 | input     | write data bus            |
| itr_tga_i        | TGA_WIDTH-1:0  | input     | address tags              |
| itr_tgc_i        | TGC_WIDTH-1:0  | input     | bus cycle tags            |
| itr_tgd_i        | TGWD_WIDTH-1:0 | input     | write data tags           |
| itr_ack_o        |                | output    | bus cycle acknowledge     |
| itr_err_o        |                | output    | error indicator           |
| itr_rty_o        |                | output    | retry request             |
| itr_stall_o      |                | output    | access delay              |
| itr_dat_o        | DATA_WIDTH-1:0 | output    | read data bus             |
| itr_tgd_o        | TGRD_WIDTH-1:0 | output    | read data tags            |
| Target Interface |                |           |                           |
| tgt_cyc_o        |                | output    | bus cycle indicator       |
| tgt_stb_o        |                | output    | access request            |
| tgt_we_o         |                | output    | write enable              |
| tgt_lock_o       |                | output    | uninterruptable bus cycle |
| tgt_sel_o        | SEL_WIDTH-1:0  | output    | write data selects        |
| tgt_adr_o        | ADDR_WIDTH-1:0 | output    | write data selects        |
| tgt_dat_o        | DATA_WIDTH-1:0 | output    | write data bus            |
| tgt_tga_o        | TGA_WIDTH-1:0  | output    | address tags              |
| itr_tga_tgtsel_o | TGT_CNT-1:0    | output    | target select tags        |
| tgt_tgc_o        | TGC_WIDTH-1:0  | output    | bus cycle tags            |
| tgt_tgd_o        | TGWD_WIDTH-1:0 | output    | write data tags           |
| tgt_ack_i        |                | input     | bus cycle acknowledge     |
| tgt_err_i        |                | input     | error indicator           |
| tgt_rty_i        |                | input     | retry request             |
| tgt_stall_i      |                | input     | access delay              |
| tgt_dat_i        | DATA_WIDTH-1:0 | input     | read data bus             |
| tgt_tgd_i        | TGRD_WIDTH-1:0 | input     | read data tags            |

## **Verification Status**

| Configuration         |     | Linting   | Simulation | Formal | FPGA |
|-----------------------|-----|-----------|------------|--------|------|
| <b>Default Config</b> | ura | tion      |            |        |      |
| TGT_CNT               | 4   |           |            |        |      |
| ADDR_WIDTH            | 16  |           |            |        |      |
| DATA_WIDTH            | 16  |           |            |        |      |
| SEL_WIDTH             | 2   | iVerilog, |            |        |      |
| TGA_WIDTH             | 1   | Yosys     |            |        |      |
| TGC_WIDTH             | 1   |           |            |        |      |
| TGRD_WIDTH            | 1   |           |            |        |      |
| TGWD_WIDTH            | 1   |           |            |        |      |

All lint checks have been done with the Icarus Verilog simulator [2] and the Yosys synthesis tool [3].

# **WbXbc Error Generator**



This module implements an error generator or dummy target for the pipelined Wishbone protocol. It propagates accesses from the initiator to the target bus, but intercepts accesses without a target, signaling an error condition to the initiator. The target association is determined by a set of address tags, generated by the address decoder.

## **Integration Parameters**

| Parameter  | Default Value | Description                 |
|------------|---------------|-----------------------------|
| TGT_CNT    | 4             | number of target busses     |
| ADDR_WIDTH | 16            | width of the address bus    |
| DATA_WIDTH | 16            | width of each data bus      |
| SEL_WIDTH  | 2             | number of data select lines |
| TGA_WIDTH  | 1             | number of address tags      |
| TGC_WIDTH  | 1             | number of cycle tags        |
| TGRD_WIDTH | 1             | number of read data tags    |
| TGWD_WIDTH | 1             | number of write data tags   |

Section Integration Parameters gives a detailed description of each parameter listed above.

| Signal              | Range          | Direction | Description               |  |
|---------------------|----------------|-----------|---------------------------|--|
| Clock and Reset     |                |           |                           |  |
| clk_i               |                | input     | module clock              |  |
| async_rst_i         |                | input     | asynchronous reset        |  |
| sync_rst_i          |                | input     | synchronous reset         |  |
| Initiator Interface |                |           |                           |  |
| itr_cyc_i           |                | input     | bus cycle indicator       |  |
| itr_stb_i           |                | input     | access request            |  |
| itr_we_i            |                | input     | write enable              |  |
| itr_lock_i          |                | input     | uninterruptable bus cycle |  |
| itr_sel_i           | SEL_WIDTH-1:0  | input     | write data selects        |  |
| itr_adr_i           | ADDR_WIDTH-1:0 | input     | address bus               |  |
| itr_dat_i           | DATA_WIDTH-1:0 | input     | write data bus            |  |
| itr_tga_i           | TGA_WIDTH-1:0  | input     | address tags              |  |
| itr_tga_tgtsel_i    | TGT_CNT-1:0    | input     | target select tags        |  |
| itr_tgc_i           | TGC_WIDTH-1:0  | input     | bus cycle tags            |  |
| itr_tgd_i           | TGWD_WIDTH-1:0 | input     | write data tags           |  |
| itr_ack_o           |                | output    | bus cycle acknowledge     |  |
| itr_err_o           |                | output    | error indicator           |  |
| itr_rty_o           |                | output    | retry request             |  |
| itr_stall_o         |                | output    | access delay              |  |
| itr_dat_o           | DATA_WIDTH-1:0 | output    | read data bus             |  |
| itr_tgd_o           | TGRD_WIDTH-1:0 | output    | read data tags            |  |
| Target Interface    |                |           |                           |  |
| tgt_cyc_o           |                | output    | bus cycle indicator       |  |
| tgt_stb_o           |                | output    | access request            |  |
| tgt_we_o            |                | output    | write enable              |  |
| tgt_lock_o          |                | output    | uninterruptable bus cycle |  |
| tgt_sel_o           | SEL_WIDTH-1:0  | output    | write data selects        |  |
| tgt_adr_o           | ADDR_WIDTH-1:0 | output    | write data selects        |  |
| tgt_dat_o           | DATA_WIDTH-1:0 | output    | write data bus            |  |
| tgt_tga_o           | TGA_WIDTH-1:0  | output    | address tags              |  |
| itr_tga_tgtsel_o    | TGT_CNT-1:0    | output    | target select tags        |  |
| tgt_tgc_o           | TGC_WIDTH-1:0  | output    | bus cycle tags            |  |

| Signal      | Range          | Direction | Description           |
|-------------|----------------|-----------|-----------------------|
| tgt_tgd_o   | TGWD_WIDTH-1:0 | output    | write data tags       |
| tgt_ack_i   |                | input     | bus cycle acknowledge |
| tgt_err_i   |                | input     | error indicator       |
| tgt_rty_i   |                | input     | retry request         |
| tgt_stall_i |                | input     | access delay          |
| tgt_dat_i   | DATA_WIDTH-1:0 | input     | read data bus         |
| tgt_tgd_i   | TGRD_WIDTH-1:0 | input     | read data tags        |

## **Verification Status**

| Configuration         |     | Linting   | Simulation | Formal | FPGA |
|-----------------------|-----|-----------|------------|--------|------|
| <b>Default Config</b> | ura | tion      |            |        |      |
| TGT_CNT               | 4   |           |            |        |      |
| ADDR_WIDTH            | 16  |           |            |        |      |
| DATA_WIDTH            | 16  |           |            |        |      |
| SEL_WIDTH             | 2   | iVerilog, |            |        |      |
| TGA_WIDTH             | 1   | Yosys     |            |        |      |
| TGC_WIDTH             | 1   |           |            |        |      |
| TGRD_WIDTH            | 1   |           |            |        |      |
| TGWD_WIDTH            | 1   |           |            |        |      |

All lint checks have been done with the Icarus Verilog simulator [2] and the Yosys synthesis tool [3].

# **WbXbc Splitter**



This module implements a bus splitter for the pipelined Wishbone protocol. Accesses from the initiator bus are propagated to one of the target busses. The target busses are selected by a set of address tags, generated by the address decoder.

# **Integration Parameters**

| Parameter  | Default Value | Description                 |
|------------|---------------|-----------------------------|
| TGT_CNT    | 4             | number of target busses     |
| ADDR_WIDTH | 16            | width of the address bus    |
| DATA_WIDTH | 16            | width of each data bus      |
| SEL_WIDTH  | 2             | number of data select lines |
| TGA_WIDTH  | 1             | number of address tags      |
| TGC_WIDTH  | 1             | number of cycle tags        |
| TGRD_WIDTH | 1             | number of read data tags    |
| TGWD_WIDTH | 1             | number of write data tags   |

Section Integration Parameters gives a detailed description of each parameter listed above.

| Signal              | Range          | Direction | Description               |  |
|---------------------|----------------|-----------|---------------------------|--|
| Clock and Reset     |                |           |                           |  |
| clk_i               |                | input     | module clock              |  |
| async_rst_i         |                | input     | asynchronous reset        |  |
| sync_rst_i          |                | input     | synchronous reset         |  |
| Initiator Interface |                |           |                           |  |
| itr_cyc_i           |                | input     | bus cycle indicator       |  |
| itr_stb_i           |                | input     | access request            |  |
| itr_we_i            |                | input     | write enable              |  |
| itr_lock_i          |                | input     | uninterruptable bus cycle |  |
| itr_sel_i           | SEL_WIDTH-1:0  | input     | write data selects        |  |
| itr_adr_i           | ADDR_WIDTH-1:0 | input     | address bus               |  |
| itr_dat_i           | DATA_WIDTH-1:0 | input     | write data bus            |  |
| itr_tga_i           | TGA_WIDTH-1:0  | input     | address tags              |  |
| itr_tga_tgtsel_i    | TGT_CNT-1:0    | input     | target select tags        |  |
| itr_tgc_i           | TGC_WIDTH-1:0  | input     | bus cycle tags            |  |
| itr_tgd_i           | TGWD_WIDTH-1:0 | input     | write data tags           |  |
| itr_ack_o           |                | output    | bus cycle acknowledge     |  |
| itr_err_o           |                | output    | error indicator           |  |
| itr_rty_o           |                | output    | retry request             |  |
| itr_stall_o         |                | output    | access delay              |  |
| itr_dat_o           | DATA_WIDTH-1:0 | output    | read data bus             |  |
| itr_tgd_o           | TGRD_WIDTH-1:0 | output    | read data tags            |  |

| Signal            | Range                    | Direction | Description                         |
|-------------------|--------------------------|-----------|-------------------------------------|
| Target Interfaces |                          |           |                                     |
| tgt_cyc_o         | TGT_CNT-1:0              | output    | concatinated bus cycle indicators   |
| tgt_stb_o         | TGT_CNT-1:0              | output    | concatinated access requests        |
| tgt_we_o          | TGT_CNT-1:0              | output    | concatinated write enables          |
| tgt_lock_o        | TGT_CNT-1:0              | output    | concatinated bus cycle locks        |
| tgt_sel_o         | (TGT_CNT*SEL_WIDTH)-1:0  | output    | concatinated write data selects     |
| tgt_adr_o         | (TGT_CNT*ADDR_WIDTH)-1:0 | output    | concatinated write data selects     |
| tgt_dat_o         | (TGT_CNT*DATA_WIDTH)-1:0 | output    | concatinated write data busses      |
| tgt_tga_o         | (TGT_CNT*TGA_WIDTH)-1:0  | output    | concatinated address tags           |
| tgt_tgc_o         | (TGT_CNT*TGC_WIDTH)-1:0  | output    | concatinated bus cycle tags         |
| tgt_tgd_o         | (TGT_CNT*TGWD_WIDTH)-1:0 | output    | concatinated write data tags        |
| tgt_ack_i         | TGT_CNT-1:0              | input     | concatinated bus cycle acknowledges |
| tgt_err_i         | TGT_CNT-1:0              | input     | concatinated error indicators       |
| tgt_rty_i         | TGT_CNT-1:0              | input     | concatinated retry requests         |
| tgt_stall_i       | TGT_CNT-1:0              | input     | concatinated access delays          |
| tgt_dat_i         | (TGT_CNT*DATA_WIDTH)-1:0 | input     | concatinated read data<br>busses    |
| tgt_tgd_i         | (TGT_CNT*TGRD_WIDTH)-1:0 | input     | concatinated read data tags         |

## **Verification Status**

| Configuration         |     | Linting   | Simulation | Formal | FPGA |
|-----------------------|-----|-----------|------------|--------|------|
| <b>Default Config</b> | ura | tion      |            |        |      |
| TGT_CNT               | 4   |           |            |        |      |
| ADDR_WIDTH            | 16  |           |            |        |      |
| DATA_WIDTH            | 16  |           |            |        |      |
| SEL_WIDTH             | 2   | iVerilog, |            |        |      |
| TGA_WIDTH             | 1   | Yosys     |            |        |      |
| TGC_WIDTH             | 1   |           |            |        |      |
| TGRD_WIDTH            | 1   |           |            |        |      |
| TGWD_WIDTH            | 1   |           |            |        |      |

## **WbXbc** Arbiter



This module implements a bus arbiter for the pipelined Wishbone protocol. Accesses from multiple initiator busses are arbitrated and propagated to the target bus. Each initiator bus can request bus accesses at two priority levels. The priority levels are selected via a set of address tags. Access requests of equal priority are arbitrated with a fixed priority (initiator 0 has the higheest priority).

## **Integration Parameters**

| Parameter  | Default Value | Description                       |
|------------|---------------|-----------------------------------|
| ITR_CNT    | 4             | number of initiator busses        |
| ADDR_WIDTH | 16            | width of the address bus          |
| DATA_WIDTH | 16            | width of each data bus            |
| SEL_WIDTH  | 2             | number of write data select lines |
| TGA_WIDTH  | 1             | number of address tags            |
| TGC_WIDTH  | 1             | number of cycle tags              |
| TGRD_WIDTH | 1             | number of read data tags          |
| TGWD_WIDTH | 1             | number of write data tags         |

Section Integration Parameters gives a detailed description of each parameter listed above.

| Signal              | Range           | Direction | Description                       |  |  |  |  |
|---------------------|-----------------|-----------|-----------------------------------|--|--|--|--|
| Clock and Reset     | Clock and Reset |           |                                   |  |  |  |  |
| clk_i               |                 | input     | module clock                      |  |  |  |  |
| async_rst_i         |                 | input     | asynchronous reset                |  |  |  |  |
| sync_rst_i          |                 | input     | synchronous reset                 |  |  |  |  |
| Initiator Interface |                 |           |                                   |  |  |  |  |
| itr_cyc_i           | ITR_CNT-1:0     | input     | concatinated bus cycle indicators |  |  |  |  |
| itr_stb_i           | ITR_CNT-1:0     | input     | concatinated access requests      |  |  |  |  |

| Signal           | Range                    | Direction | Description                         |
|------------------|--------------------------|-----------|-------------------------------------|
| itr_we_i         | ITR_CNT-1:0              | input     | concatinated write enables          |
| itr_lock_i       | ITR_CNT-1:0              | input     | concatinated bus cycle locks        |
| itr_sel_i        | (ITR_CNT*SEL_WIDTH)-1:0  | input     | concatinated write data selects     |
| itr_adr_i        | (ITR_CNT*ADDR_WIDTH)-1:0 | input     | concatinated address busses         |
| itr_dat_i        | (ITR_CNT*DATA_WIDTH)-1:0 | input     | concatinated write data busses      |
| itr_tga_i        | (ITR_CNT*TGA_WIDTH)-1:0  | input     | concatinated address tags           |
| itr_tga_prio_i   | ITR_CNT-1:0              | input     | concatinated access priorities      |
| itr_tgc_i        | (ITR_CNT*TGC_WIDTH)-1:0  | input     | concatinated bus cycle tags         |
| itr_tgd_i        | (ITR_CNT*TGWD_WIDTH)-1:0 | input     | concatinated write data tags        |
| itr_ack_o        | ITR_CNT-1:0              | output    | concatinated bus cycle acknowledges |
| itr_err_o        | ITR_CNT-1:0              | output    | concatinated error indicators       |
| itr_rty_o        | ITR_CNT-1:0              | output    | concatinated retry requests         |
| itr_stall_o      | ITR_CNT-1:0              | output    | concatinated access delays          |
| itr_dat_o        | (ITR_CNT*DATA_WIDTH)-1:0 | output    | concatinated read data<br>buses     |
| itr_tgd_o        | (ITR_CNT*TGRD_WIDTH)-1:0 | output    | concatinated read data tags         |
| Target Interface |                          |           |                                     |
| tgt_cyc_o        |                          | output    | bus cycle indicator                 |
| tgt_stb_o        |                          | output    | access request                      |
| tgt_we_o         |                          | output    | write enable                        |
| tgt_lock_o       |                          | output    | uninterruptable bus cycle           |
| tgt_sel_o        | SEL_WIDTH-1:0            | output    | write data selects                  |
| tgt_adr_o        | ADDR_WIDTH-1:0           | output    | write data selects                  |
| tgt_dat_o        | DATA_WIDTH-1:0           | output    | write data bus                      |
| tgt_tga_o        | TGA_WIDTH-1:0            | output    | address tags                        |
| tgt_tgc_o        | TGC_WIDTH-1:0            | output    | bus cycle tags                      |
| tgt_tgd_o        | TGWD_WIDTH-1:0           | output    | write data tags                     |
| tgt_ack_i        |                          | input     | bus cycle acknowledge               |
| tgt_err_i        |                          | input     | error indicator                     |
| tgt_rty_i        |                          | input     | retry request                       |
| tgt_stall_i      |                          | input     | access delay                        |
| tgt_dat_i        | DATA_WIDTH-1:0           | input     | read data bus                       |
| tgt_tgd_i        | TGRD_WIDTH-1:0           | input     | read data tags                      |

## **Verification Status**

| Configuration         |                       | Linting   | Simulation | Formal | FPGA |  |  |  |
|-----------------------|-----------------------|-----------|------------|--------|------|--|--|--|
| <b>Default Config</b> | Default Configuration |           |            |        |      |  |  |  |
| ITR_CNT               | 4                     |           |            |        |      |  |  |  |
| ADDR_WIDTH            | 16                    |           |            |        |      |  |  |  |
| DATA_WIDTH            | 16                    |           |            |        |      |  |  |  |
| SEL_WIDTH             | 2                     | iVerilog, |            |        |      |  |  |  |
| TGA_WIDTH             | 1                     | Yosys     |            |        |      |  |  |  |
| TGC_WIDTH             | 1                     |           |            |        |      |  |  |  |
| TGRD_WIDTH            | 1                     |           |            |        |      |  |  |  |
| TGWD_WIDTH            | 1                     |           |            |        |      |  |  |  |

All lint checks have been done with the Icarus Verilog simulator [2] and the Yosys synthesis tool [3].

# **WbXbc** Expander



This module connects a pipelined Wishbone initiator to a target with wider data busses (twice the width of the initiator's data busses).

## **Integration Parameters**

| Parameter      | Default Value | Description                           |
|----------------|---------------|---------------------------------------|
| ITR_ADDR_WIDTH | 16            | width of the initiator address bus    |
| ITR_DATA_WIDTH | 16            | width of each initiator data bus      |
| ITR_SEL_WIDTH  | 2             | number of initiator data select lines |
| TGA_WIDTH      | 1             | number of address tags                |
| TGC_WIDTH      | 1             | number of cycle tags                  |
| TGRD_WIDTH     | 1             | number of read data tags              |
| TGWD_WIDTH     | 1             | number of write data tags             |
| BIG_ENDIAN     | 1             | endianess of the component            |

Section Integration Parameters gives a detailed description of each parameter listed above.

| Signal              | Range                  | Direction | Description               |  |  |  |  |
|---------------------|------------------------|-----------|---------------------------|--|--|--|--|
| Clock and Reset     |                        |           |                           |  |  |  |  |
| clk_i               |                        | input     | module clock              |  |  |  |  |
| async_rst_i         |                        | input     | asynchronous reset        |  |  |  |  |
| sync_rst_i          |                        | input     | synchronous reset         |  |  |  |  |
| Initiator Interface |                        |           |                           |  |  |  |  |
| itr_cyc_i           |                        | input     | bus cycle indicator       |  |  |  |  |
| itr_stb_i           |                        | input     | access request            |  |  |  |  |
| itr_we_i            |                        | input     | write enable              |  |  |  |  |
| itr_lock_i          |                        | input     | uninterruptable bus cycle |  |  |  |  |
| itr_sel_i           | ITR_SEL_WIDTH-1:0      | input     | write data selects        |  |  |  |  |
| itr_adr_i           | ITR_ADDR_WIDTH-1:0     | input     | address bus               |  |  |  |  |
| itr_dat_i           | ITR_DATA_WIDTH-1:0     | input     | write data bus            |  |  |  |  |
| itr_tga_i           | TGA_WIDTH-1:0          | input     | address tags              |  |  |  |  |
| itr_tgc_i           | TGC_WIDTH-1:0          | input     | bus cycle tags            |  |  |  |  |
| itr_tgd_i           | TGWD_WIDTH-1:0         | input     | write data tags           |  |  |  |  |
| itr_ack_o           |                        | output    | bus cycle acknowledge     |  |  |  |  |
| itr_err_o           |                        | output    | error indicator           |  |  |  |  |
| itr_rty_o           |                        | output    | retry request             |  |  |  |  |
| itr_stall_o         |                        | output    | access delay              |  |  |  |  |
| itr_dat_o           | DATA_WIDTH-1:0         | output    | read data bus             |  |  |  |  |
| itr_tgd_o           | TGRD_WIDTH-1:0         | output    | read data tags            |  |  |  |  |
| Target Interface    |                        |           |                           |  |  |  |  |
| tgt_cyc_o           |                        | output    | bus cycle indicator       |  |  |  |  |
| tgt_stb_o           |                        | output    | access request            |  |  |  |  |
| tgt_we_o            |                        | output    | write enable              |  |  |  |  |
| tgt_lock_o          |                        | output    | uninterruptable bus cycle |  |  |  |  |
| tgt_sel_o           | (ITR_SEL_WIDTH*2)-1:0  | output    | write data selects        |  |  |  |  |
| tgt_adr_o           | ITR_ADDR_WIDTH-2:0     | output    | write data selects        |  |  |  |  |
| tgt_dat_o           | (ITR_DATA_WIDTH*2)-1:0 | output    | write data bus            |  |  |  |  |
| tgt_tga_o           | TGA_WIDTH-1:0          | output    | address tags              |  |  |  |  |
| tgt_tgc_o           | TGC_WIDTH-1:0          | output    | bus cycle tags            |  |  |  |  |
| tgt_tgd_o           | TGWD_WIDTH-1:0         | output    | write data tags           |  |  |  |  |
| tgt_ack_i           |                        | input     | bus cycle acknowledge     |  |  |  |  |

| Signal      | Range                  | Direction | Description     |
|-------------|------------------------|-----------|-----------------|
| tgt_err_i   |                        | input     | error indicator |
| tgt_rty_i   |                        | input     | retry request   |
| tgt_stall_i |                        | input     | access delay    |
| tgt_dat_i   | (ITR_DATA_WIDTH*2)-1:0 | input     | read data bus   |
| tgt_tgd_i   | TGRD_WIDTH-1:0         | input     | read data tags  |

## **Verification Status**

| Configuration      |                       | Linting   | Simulation | Formal | FPGA |  |  |  |
|--------------------|-----------------------|-----------|------------|--------|------|--|--|--|
| Default Config     | Default Configuration |           |            |        |      |  |  |  |
| TGT_ADDR_WI<br>DTH | 16                    |           |            |        |      |  |  |  |
| TGT_DATA_WI<br>DTH | 16                    |           |            |        |      |  |  |  |
| TGT_SEL_WID TH     | 2                     | iVerilog, |            |        |      |  |  |  |
| TGA_WIDTH          | 1                     | Yosys     |            |        |      |  |  |  |
| TGC_WIDTH          | 1                     |           |            |        |      |  |  |  |
| TGRD_WIDTH         | 1                     |           |            |        |      |  |  |  |
| TGWD_WIDTH         | 1                     |           |            |        |      |  |  |  |
| BIG_ENDIAN         | 1                     |           |            |        |      |  |  |  |

All lint checks have been done with the Icarus Verilog simulator [2] and the Yosys synthesis tool [3].

## WbXbc Reducer



This module connects a pipelined Wishbone initiator to a target with narrower data busses (half the width of the initiator's data busses). Initiator bus accesses may be converted into two consecutive accesses to the target bus.

# **Integration Parameters**

| Parameter      | Default Value | Description                           |
|----------------|---------------|---------------------------------------|
| ITR_ADDR_WIDTH | 16            | width of the initiator address bus    |
| ITR_DATA_WIDTH | 16            | width of each initiator data bus      |
| ITR_SEL_WIDTH  | 2             | number of initiator data select lines |
| TGA_WIDTH      | 1             | number of address tags                |
| TGC_WIDTH      | 1             | number of cycle tags                  |
| TGRD_WIDTH     | 1             | number of read data tags              |
| TGWD_WIDTH     | 1             | number of write data tags             |
| BIG_ENDIAN     | 1             | endianess of the component            |

Section Integration Parameters gives a detailed description of each parameter listed above.

| Signal              | Range          | Direction | Description               |  |  |  |
|---------------------|----------------|-----------|---------------------------|--|--|--|
| Clock and Reset     |                |           |                           |  |  |  |
| clk_i               |                | input     | module clock              |  |  |  |
| async_rst_i         |                | input     | asynchronous reset        |  |  |  |
| sync_rst_i          |                | input     | synchronous reset         |  |  |  |
| Initiator Interface |                |           |                           |  |  |  |
| itr_cyc_i           |                | input     | bus cycle indicator       |  |  |  |
| itr_stb_i           |                | input     | access request            |  |  |  |
| itr_we_i            |                | input     | write enable              |  |  |  |
| itr_lock_i          |                | input     | uninterruptable bus cycle |  |  |  |
| itr_sel_i           | SEL_WIDTH-1:0  | input     | write data selects        |  |  |  |
| itr_adr_i           | ADDR_WIDTH-1:0 | input     | address bus               |  |  |  |
| itr_dat_i           | DATA_WIDTH-1:0 | input     | write data bus            |  |  |  |
| itr_tga_i           | TGA_WIDTH-1:0  | input     | address tags              |  |  |  |
| itr_tgc_i           | TGC_WIDTH-1:0  | input     | bus cycle tags            |  |  |  |
| itr_tgd_i           | TGWD_WIDTH-1:0 | input     | write data tags           |  |  |  |
| itr_ack_o           |                | output    | bus cycle acknowledge     |  |  |  |
| itr_err_o           |                | output    | error indicator           |  |  |  |
| itr_rty_o           |                | output    | retry request             |  |  |  |
| itr_stall_o         |                | output    | access delay              |  |  |  |
| itr_dat_o           | DATA_WIDTH-1:0 | output    | read data bus             |  |  |  |
| itr_tgd_o           | TGRD_WIDTH-1:0 | output    | read data tags            |  |  |  |
| Target Interface    |                |           |                           |  |  |  |

| Signal      | Range                  | Direction | Description               |
|-------------|------------------------|-----------|---------------------------|
| tgt_cyc_o   |                        | output    | bus cycle indicator       |
| tgt_stb_o   |                        | output    | access request            |
| tgt_we_o    |                        | output    | write enable              |
| tgt_lock_o  |                        | output    | uninterruptable bus cycle |
| tgt_sel_o   | (ITR_SEL_WIDTH/2)-1:0  | output    | write data selects        |
| tgt_adr_o   | ITR_ADDR_WIDTH:0       | output    | write data selects        |
| tgt_dat_o   | (ITR_DATA_WIDTH/2)-1:0 | output    | write data bus            |
| tgt_tga_o   | TGA_WIDTH-1:0          | output    | address tags              |
| tgt_tgc_o   | TGC_WIDTH-1:0          | output    | bus cycle tags            |
| tgt_tgd_o   | TGWD_WIDTH-1:0         | output    | write data tags           |
| tgt_ack_i   |                        | input     | bus cycle acknowledge     |
| tgt_err_i   |                        | input     | error indicator           |
| tgt_rty_i   |                        | input     | retry request             |
| tgt_stall_i |                        | input     | access delay              |
| tgt_dat_i   | (ITR_DATA_WIDTH/2)-1:0 | input     | read data bus             |
| tgt_tgd_i   | TGRD_WIDTH-1:0         | input     | read data tags            |

## **Verification Status**

| Configuration         |                       | Linting   | Simulation | Formal | FPGA |  |  |  |
|-----------------------|-----------------------|-----------|------------|--------|------|--|--|--|
| <b>Default Config</b> | Default Configuration |           |            |        |      |  |  |  |
| TGT_ADDR_WI<br>DTH    | 16                    |           |            |        |      |  |  |  |
| TGT_DATA_WI<br>DTH    | 16                    |           |            |        |      |  |  |  |
| TGT_SEL_WID TH        | 2                     | iVerilog, |            |        |      |  |  |  |
| TGA_WIDTH             | 1                     | Yosys     |            |        |      |  |  |  |
| TGC_WIDTH             | 1                     |           |            |        |      |  |  |  |
| TGRD_WIDTH            | 1                     |           |            |        |      |  |  |  |
| TGWD_WIDTH            | 1                     |           |            |        |      |  |  |  |
| BIG_ENDIAN            | 1                     |           |            |        |      |  |  |  |

All lint checks have been done with the Icarus Verilog simulator [2] and the Yosys synthesis tool [3].

# **WbXbc** Accelerator



This module connects a pipelined Wishbone initiator, running at a higher frequency to a target, running at a lower frequency.

## **Integration Parameters**

| Parameter  | Default Value | Description                   |
|------------|---------------|-------------------------------|
| ADDR_WIDTH | 16            | width of the address bus      |
| DATA_WIDTH | 16            | width of each data bus        |
| SEL_WIDTH  | 2             | number of data select lines   |
| TGA_WIDTH  | 1             | number of address tags        |
| TGC_WIDTH  | 1             | number of cycle tags          |
| TGRD_WIDTH | 1             | number of read data tags      |
| TGWD_WIDTH | 1             | number of write data tags     |
| REG_ITR    | 0             | register initiator bus inputs |

Section Integration Parameters gives a detailed description of each parameter listed above.

| Signal              | Range | Direction | Description               |  |  |  |
|---------------------|-------|-----------|---------------------------|--|--|--|
| Clock and Reset     |       |           |                           |  |  |  |
| tgt_clk_i           |       | input     | target clock              |  |  |  |
| tgt2itr_sync_i      |       | input     | clock sync signal         |  |  |  |
| async_rst_i         |       | input     | asynchronous reset        |  |  |  |
| sync_rst_i          |       | input     | synchronous reset         |  |  |  |
| Initiator Interface | •     |           |                           |  |  |  |
| itr_cyc_i           |       | input     | bus cycle indicator       |  |  |  |
| itr_stb_i           |       | input     | access request            |  |  |  |
| itr_we_i            |       | input     | write enable              |  |  |  |
| itr_lock_i          |       | input     | uninterruptable bus cycle |  |  |  |

| Signal           | Range          | Direction | Description               |
|------------------|----------------|-----------|---------------------------|
| itr_sel_i        | SEL_WIDTH-1:0  | input     | write data selects        |
| itr_adr_i        | ADDR_WIDTH-1:0 | input     | address bus               |
| itr_dat_i        | DATA_WIDTH-1:0 | input     | write data bus            |
| itr_tga_i        | TGA_WIDTH-1:0  | input     | address tags              |
| itr_tgc_i        | TGC_WIDTH-1:0  | input     | bus cycle tags            |
| itr_tgd_i        | TGWD_WIDTH-1:0 | input     | write data tags           |
| itr_ack_o        |                | output    | bus cycle acknowledge     |
| itr_err_o        |                | output    | error indicator           |
| itr_rty_o        |                | output    | retry request             |
| itr_stall_o      |                | output    | access delay              |
| itr_dat_o        | DATA_WIDTH-1:0 | output    | read data bus             |
| itr_tgd_o        | TGRD_WIDTH-1:0 | output    | read data tags            |
| Target Interface |                |           |                           |
| tgt_cyc_o        |                | output    | bus cycle indicator       |
| tgt_stb_o        |                | output    | access request            |
| tgt_we_o         |                | output    | write enable              |
| tgt_lock_o       |                | output    | uninterruptable bus cycle |
| tgt_sel_o        | SEL_WIDTH-1:0  | output    | write data selects        |
| tgt_adr_o        | ADDR_WIDTH-1:0 | output    | write data selects        |
| tgt_dat_o        | DATA_WIDTH-1:0 | output    | write data bus            |
| tgt_tga_o        | TGA_WIDTH-1:0  | output    | address tags              |
| tgt_tgc_o        | TGC_WIDTH-1:0  | output    | bus cycle tags            |
| tgt_tgd_o        | TGWD_WIDTH-1:0 | output    | write data tags           |
| tgt_ack_i        |                | input     | bus cycle acknowledge     |
| tgt_err_i        |                | input     | error indicator           |
| tgt_rty_i        |                | input     | retry request             |
| tgt_stall_i      |                | input     | access delay              |
| tgt_dat_i        | DATA_WIDTH-1:0 | input     | read data bus             |
| tgt_tgd_i        | TGRD_WIDTH-1:0 | input     | read data tags            |

## **Verification Status**

| Configuration         | Linting | Simulation | Formal | FPGA |  |
|-----------------------|---------|------------|--------|------|--|
| Default Configuration |         |            |        |      |  |

| Configuration |    | Linting   | Simulation | Formal | FPGA |
|---------------|----|-----------|------------|--------|------|
| ADDR_WIDTH    | 16 |           |            |        |      |
| DATA_WIDTH    | 16 |           |            |        |      |
| SEL_WIDTH     | 2  |           |            |        |      |
| TGA_WIDTH     | 1  | iVerilog, |            |        |      |
| TGC_WIDTH     | 1  | Yosys     |            |        |      |
| TGRD_WIDTH    | 1  |           |            |        |      |
| TGWD_WIDTH    | 1  |           |            |        |      |
| REG_ITR       | 0  |           |            |        |      |

All lint checks have been done with the Icarus Verilog simulator [2] and the Yosys synthesis tool [3].

## **WbXbc Decelerator**



This module connects a pipelined Wishbone initiator, running at a higher frequency to a target, running at a lower frequency:.

## **Integration Parameters**

| Parameter  | Default Value | Description                   |
|------------|---------------|-------------------------------|
| ADDR_WIDTH | 16            | width of the address bus      |
| DATA_WIDTH | 16            | width of each data bus        |
| SEL_WIDTH  | 2             | number of data select lines   |
| TGA_WIDTH  | 1             | number of address tags        |
| TGC_WIDTH  | 1             | number of cycle tags          |
| TGRD_WIDTH | 1             | number of read data tags      |
| TGWD_WIDTH | 1             | number of write data tags     |
| REG_ITR    | 0             | register initiator bus inputs |
| REG_TGT    | 0             | register target bus inputs    |

Section Integration Parameters gives a detailed description of each parameter listed above.

| Signal              | Range          | Direction | Description               |
|---------------------|----------------|-----------|---------------------------|
| Clock and Reset     |                |           |                           |
| itr_clk_i           |                | input     | initiator clock           |
| itr2tgt_sync_i      |                | input     | clock sync signal         |
| async_rst_i         |                | input     | asynchronous reset        |
| sync_rst_i          |                | input     | synchronous reset         |
| Initiator Interface |                |           |                           |
| itr_cyc_i           |                | input     | bus cycle indicator       |
| itr_stb_i           |                | input     | access request            |
| itr_we_i            |                | input     | write enable              |
| itr_lock_i          |                | input     | uninterruptable bus cycle |
| itr_sel_i           | SEL_WIDTH-1:0  | input     | write data selects        |
| itr_adr_i           | ADDR_WIDTH-1:0 | input     | address bus               |
| itr_dat_i           | DATA_WIDTH-1:0 | input     | write data bus            |
| itr_tga_i           | TGA_WIDTH-1:0  | input     | address tags              |
| itr_tgc_i           | TGC_WIDTH-1:0  | input     | bus cycle tags            |
| itr_tgd_i           | TGWD_WIDTH-1:0 | input     | write data tags           |
| itr_ack_o           |                | output    | bus cycle acknowledge     |
| itr_err_o           |                | output    | error indicator           |
| itr_rty_o           |                | output    | retry request             |
| itr_stall_o         |                | output    | access delay              |
| itr_dat_o           | DATA_WIDTH-1:0 | output    | read data bus             |
| itr_tgd_o           | TGRD_WIDTH-1:0 | output    | read data tags            |
| Target Interface    |                |           |                           |
| tgt_cyc_o           |                | output    | bus cycle indicator       |
| tgt_stb_o           |                | output    | access request            |
| tgt_we_o            |                | output    | write enable              |
| tgt_lock_o          |                | output    | uninterruptable bus cycle |
| tgt_sel_o           | SEL_WIDTH-1:0  | output    | write data selects        |
| tgt_adr_o           | ADDR_WIDTH-1:0 | output    | write data selects        |
| tgt_dat_o           | DATA_WIDTH-1:0 | output    | write data bus            |
| tgt_tga_o           | TGA_WIDTH-1:0  | output    | address tags              |
| tgt_tgc_o           | TGC_WIDTH-1:0  | output    | bus cycle tags            |
| tgt_tgd_o           | TGWD_WIDTH-1:0 | output    | write data tags           |
| tgt_ack_i           |                | input     | bus cycle acknowledge     |

| Signal      | Range          | Direction | Description     |
|-------------|----------------|-----------|-----------------|
| tgt_err_i   |                | input     | error indicator |
| tgt_rty_i   |                | input     | retry request   |
| tgt_stall_i |                | input     | access delay    |
| tgt_dat_i   | DATA_WIDTH-1:0 | input     | read data bus   |
| tgt_tgd_i   | TGRD_WIDTH-1:0 | input     | read data tags  |

## **Verification Status**

| Configuration         |     | Linting   | Simulation | Formal | FPGA |
|-----------------------|-----|-----------|------------|--------|------|
| <b>Default Config</b> | ura | tion      |            |        |      |
| ADDR_WIDTH            | 16  |           |            |        |      |
| DATA_WIDTH            | 16  |           |            |        |      |
| SEL_WIDTH             | 2   |           |            |        |      |
| TGA_WIDTH             | 1   |           |            |        |      |
| TGC_WIDTH             | 1   | iVerilog, |            |        |      |
| TGRD_WIDTH            | 1   | Yosys     |            |        |      |
| TGWD_WIDTH            | 1   |           |            |        |      |
| REG_ITR               | 0   |           |            |        |      |
| REG_TGT               | 0   |           |            |        |      |

All lint checks have been done with the Icarus Verilog simulator [2] and the Yosys synthesis tool [3].

# **WbXbc Pipeliner**



This module connects a standard protocol Wishbone initiator to a pipelined target.

## **Integration Parameters**

| Parameter  | Default Value | Description              |
|------------|---------------|--------------------------|
| ADDR_WIDTH | 16            | width of the address bus |

| Parameter  | Default Value | Description                 |
|------------|---------------|-----------------------------|
| DATA_WIDTH | 16            | width of each data bus      |
| SEL_WIDTH  | 2             | number of data select lines |
| TGA_WIDTH  | 1             | number of address tags      |
| TGC_WIDTH  | 1             | number of cycle tags        |
| TGRD_WIDTH | 1             | number of read data tags    |
| TGWD_WIDTH | 1             | number of write data tags   |

Section Integration Parameters gives a detailed description of each parameter listed above.

| Signal              | Range            | Direction | Description               |  |  |  |
|---------------------|------------------|-----------|---------------------------|--|--|--|
| Clock and Reset     | Clock and Reset  |           |                           |  |  |  |
| clk_i               |                  | input     | module clock              |  |  |  |
| async_rst_i         |                  | input     | asynchronous reset        |  |  |  |
| sync_rst_i          |                  | input     | synchronous reset         |  |  |  |
| Initiator Interface |                  |           |                           |  |  |  |
| itr_cyc_i           |                  | input     | bus cycle indicator       |  |  |  |
| itr_stb_i           |                  | input     | access request            |  |  |  |
| itr_we_i            |                  | input     | write enable              |  |  |  |
| itr_lock_i          |                  | input     | uninterruptable bus cycle |  |  |  |
| itr_sel_i           | SEL_WIDTH-1:0    | input     | write data selects        |  |  |  |
| itr_adr_i           | ADDR_WIDTH-1:0   | input     | address bus               |  |  |  |
| itr_dat_i           | DATA_WIDTH-1:0   | input     | write data bus            |  |  |  |
| itr_tga_i           | TGA_WIDTH-1:0    | input     | address tags              |  |  |  |
| itr_tgc_i           | TGC_WIDTH-1:0    | input     | bus cycle tags            |  |  |  |
| itr_tgd_i           | TGWD_WIDTH-1:0   | input     | write data tags           |  |  |  |
| itr_ack_o           |                  | output    | bus cycle acknowledge     |  |  |  |
| itr_err_o           |                  | output    | error indicator           |  |  |  |
| itr_rty_o           |                  | output    | retry request             |  |  |  |
| itr_stall_o         |                  | output    | access delay              |  |  |  |
| itr_dat_o           | DATA_WIDTH-1:0   | output    | read data bus             |  |  |  |
| itr_tgd_o           | TGRD_WIDTH-1:0   | output    | read data tags            |  |  |  |
| Target Interface    | Target Interface |           |                           |  |  |  |
| tgt_cyc_o           |                  | output    | bus cycle indicator       |  |  |  |
| tgt_stb_o           |                  | output    | access request            |  |  |  |
| tgt_we_o            |                  | output    | write enable              |  |  |  |

| Signal      | Range          | Direction | Description               |
|-------------|----------------|-----------|---------------------------|
| tgt_lock_o  |                | output    | uninterruptable bus cycle |
| tgt_sel_o   | SEL_WIDTH-1:0  | output    | write data selects        |
| tgt_adr_o   | ADDR_WIDTH-1:0 | output    | write data selects        |
| tgt_dat_o   | DATA_WIDTH-1:0 | output    | write data bus            |
| tgt_tga_o   | TGA_WIDTH-1:0  | output    | address tags              |
| tgt_tgc_o   | TGC_WIDTH-1:0  | output    | bus cycle tags            |
| tgt_tgd_o   | TGWD_WIDTH-1:0 | output    | write data tags           |
| tgt_ack_i   |                | input     | bus cycle acknowledge     |
| tgt_err_i   |                | input     | error indicator           |
| tgt_rty_i   |                | input     | retry request             |
| tgt_stall_i |                | input     | access delay              |
| tgt_dat_i   | DATA_WIDTH-1:0 | input     | read data bus             |
| tgt_tgd_i   | TGRD_WIDTH-1:0 | input     | read data tags            |

## **Verification Status**

| Configuration         |     | Linting            | Simulation | Formal | FPGA |
|-----------------------|-----|--------------------|------------|--------|------|
| <b>Default Config</b> | ura | tion               |            |        |      |
| ADDR_WIDTH            | 16  |                    |            |        |      |
| DATA_WIDTH            | 16  |                    |            |        |      |
| SEL_WIDTH             | 2   | iVerilog,<br>Yosys |            |        |      |
| TGA_WIDTH             | 1   |                    |            |        |      |
| TGC_WIDTH             | 1   | 103y3              |            |        |      |
| TGRD_WIDTH            | 1   |                    |            |        |      |
| TGWD_WIDTH            | 1   |                    |            |        |      |

All lint checks have been done with the Icarus Verilog simulator [2] and the Yosys synthesis tool [3].

# **WbXbc Standardizer**



This module connects a pipelined Wishbone initiator to a standard protocol target.

## **Integration Parameters**

| Parameter  | Default Value | Description                 |
|------------|---------------|-----------------------------|
| ADDR_WIDTH | 16            | width of the address bus    |
| DATA_WIDTH | 16            | width of each data bus      |
| SEL_WIDTH  | 2             | number of data select lines |
| TGA_WIDTH  | 1             | number of address tags      |
| TGC_WIDTH  | 1             | number of cycle tags        |
| TGRD_WIDTH | 1             | number of read data tags    |
| TGWD_WIDTH | 1             | number of write data tags   |

Section Integration Parameters gives a detailed description of each parameter listed above.

| Signal              | Range           | Direction | Description               |  |  |  |
|---------------------|-----------------|-----------|---------------------------|--|--|--|
| Clock and Reset     | Clock and Reset |           |                           |  |  |  |
| clk_i               |                 | input     | module clock              |  |  |  |
| async_rst_i         |                 | input     | asynchronous reset        |  |  |  |
| sync_rst_i          |                 | input     | synchronous reset         |  |  |  |
| Initiator Interface |                 |           |                           |  |  |  |
| itr_cyc_i           |                 | input     | bus cycle indicator       |  |  |  |
| itr_stb_i           |                 | input     | access request            |  |  |  |
| itr_we_i            |                 | input     | write enable              |  |  |  |
| itr_lock_i          |                 | input     | uninterruptable bus cycle |  |  |  |
| itr_sel_i           | SEL_WIDTH-1:0   | input     | write data selects        |  |  |  |
| itr_adr_i           | ADDR_WIDTH-1:0  | input     | address bus               |  |  |  |
| itr_dat_i           | DATA_WIDTH-1:0  | input     | write data bus            |  |  |  |
| itr_tga_i           | TGA_WIDTH-1:0   | input     | address tags              |  |  |  |
| itr_tgc_i           | TGC_WIDTH-1:0   | input     | bus cycle tags            |  |  |  |
| itr_tgd_i           | TGWD_WIDTH-1:0  | input     | write data tags           |  |  |  |
| itr_ack_o           |                 | output    | bus cycle acknowledge     |  |  |  |
| itr_err_o           |                 | output    | error indicator           |  |  |  |
| itr_rty_o           |                 | output    | retry request             |  |  |  |
| itr_stall_o         |                 | output    | access delay              |  |  |  |
| itr_dat_o           | DATA_WIDTH-1:0  | output    | read data bus             |  |  |  |
| itr_tgd_o           | TGRD_WIDTH-1:0  | output    | read data tags            |  |  |  |

| Signal           | Range            | Direction | Description               |  |  |  |  |
|------------------|------------------|-----------|---------------------------|--|--|--|--|
| Target Interface | Farget Interface |           |                           |  |  |  |  |
| tgt_cyc_o        |                  | output    | bus cycle indicator       |  |  |  |  |
| tgt_stb_o        |                  | output    | access request            |  |  |  |  |
| tgt_we_o         |                  | output    | write enable              |  |  |  |  |
| tgt_lock_o       |                  | output    | uninterruptable bus cycle |  |  |  |  |
| tgt_sel_o        | SEL_WIDTH-1:0    | output    | write data selects        |  |  |  |  |
| tgt_adr_o        | ADDR_WIDTH-1:0   | output    | write data selects        |  |  |  |  |
| tgt_dat_o        | DATA_WIDTH-1:0   | output    | write data bus            |  |  |  |  |
| tgt_tga_o        | TGA_WIDTH-1:0    | output    | address tags              |  |  |  |  |
| tgt_tgc_o        | TGC_WIDTH-1:0    | output    | bus cycle tags            |  |  |  |  |
| tgt_tgd_o        | TGWD_WIDTH-1:0   | output    | write data tags           |  |  |  |  |
| tgt_ack_i        |                  | input     | bus cycle acknowledge     |  |  |  |  |
| tgt_err_i        |                  | input     | error indicator           |  |  |  |  |
| tgt_rty_i        |                  | input     | retry request             |  |  |  |  |
| tgt_stall_i      |                  | input     | access delay              |  |  |  |  |
| tgt_dat_i        | DATA_WIDTH-1:0   | input     | read data bus             |  |  |  |  |
| tgt_tgd_i        | TGRD_WIDTH-1:0   | input     | read data tags            |  |  |  |  |

## **Verification Status**

| Configuration         |     | Linting   | Simulation | Formal | FPGA |
|-----------------------|-----|-----------|------------|--------|------|
| <b>Default Config</b> | ura | tion      |            |        |      |
| ADDR_WIDTH            | 16  |           |            |        |      |
| DATA_WIDTH            | 16  |           |            |        |      |
| SEL_WIDTH             | 2   |           |            |        |      |
| TGA_WIDTH             | 1   | iVerilog, |            |        |      |
| TGC_WIDTH             | 1   | Yosys     |            |        |      |
| TGRD_WIDTH            | 1   |           |            |        |      |
| TGWD_WIDTH            | 1   |           |            |        |      |

All lint checks have been done with the Icarus Verilog simulator [2] and the Yosys synthesis tool [3].

# **WbXbc** Distributor



This module implements an address decoder for the Wishbone protocol. It propagates accesses from the initiator bus to the target bus and adds a set of address tags which selecting the target block.

## **Integration Parameters**

| Parameter  | Default Value | Description                 |
|------------|---------------|-----------------------------|
| TGT_CNT    | 4             | number of target busses     |
| ADDR_WIDTH | 16            | width of the address bus    |
| DATA_WIDTH | 16            | width of each data bus      |
| SEL_WIDTH  | 2             | number of data select lines |
| TGA_WIDTH  | 1             | number of address tags      |
| TGC_WIDTH  | 1             | number of cycle tags        |
| TGRD_WIDTH | 1             | number of read data tags    |
| TGWD_WIDTH | 1             | number of write data tags   |

Section Integration Parameters gives a detailed description of each parameter listed above.

| Signal              | Range                    | Direction | Description                   |  |  |  |  |
|---------------------|--------------------------|-----------|-------------------------------|--|--|--|--|
| Clock and Reset     | Clock and Reset          |           |                               |  |  |  |  |
| clk_i               |                          | input     | module clock                  |  |  |  |  |
| async_rst_i         |                          | input     | asynchronous reset            |  |  |  |  |
| sync_rst_i          |                          | input     | synchronous reset             |  |  |  |  |
| Target Address Re   | Target Address Regions   |           |                               |  |  |  |  |
| region_addr         | (TGT_CNT*ADDR_WIDTH)-1:0 | input     | target address                |  |  |  |  |
| region_mask         | (TGT_CNT*ADDR_WIDTH)-1:0 | input     | selects relevant address bits |  |  |  |  |
| Initiator Interface |                          |           |                               |  |  |  |  |
| itr_cyc_i           |                          | input     | bus cycle indicator           |  |  |  |  |
| itr_stb_i           |                          | input     | access request                |  |  |  |  |
| itr_we_i            |                          | input     | write enable                  |  |  |  |  |
| itr_lock_i          |                          | input     | uninterruptable bus cycle     |  |  |  |  |

| Signal            | Range                    | Direction | Description                         |
|-------------------|--------------------------|-----------|-------------------------------------|
| itr_sel_i         | SEL_WIDTH-1:0            | input     | write data selects                  |
| itr_adr_i         | ADDR_WIDTH-1:0           | input     | address bus                         |
| itr_dat_i         | DATA_WIDTH-1:0           | input     | write data bus                      |
| itr_tga_i         | TGA_WIDTH-1:0            | input     | address tags                        |
| itr_tgc_i         | TGC_WIDTH-1:0            | input     | bus cycle tags                      |
| itr_tgd_i         | TGWD_WIDTH-1:0           | input     | write data tags                     |
| itr_ack_o         |                          | output    | bus cycle acknowledge               |
| itr_err_o         |                          | output    | error indicator                     |
| itr_rty_o         |                          | output    | retry request                       |
| itr_stall_o       |                          | output    | access delay                        |
| itr_dat_o         | DATA_WIDTH-1:0           | output    | read data bus                       |
| itr_tgd_o         | TGRD_WIDTH-1:0           | output    | read data tags                      |
| Target Interfaces |                          |           |                                     |
| tgt_cyc_o         | TGT_CNT-1:0              | output    | concatinated bus cycle indicators   |
| tgt_stb_o         | TGT_CNT-1:0              | output    | concatinated access requests        |
| tgt_we_o          | TGT_CNT-1:0              | output    | concatinated write enables          |
| tgt_lock_o        | TGT_CNT-1:0              | output    | concatinated bus cycle locks        |
| tgt_sel_o         | (TGT_CNT*SEL_WIDTH)-1:0  | output    | concatinated write data selects     |
| tgt_adr_o         | (TGT_CNT*ADDR_WIDTH)-1:0 | output    | concatinated write data selects     |
| tgt_dat_o         | (TGT_CNT*DATA_WIDTH)-1:0 | output    | concatinated write data busses      |
| tgt_tga_o         | (TGT_CNT*TGA_WIDTH)-1:0  | output    | concatinated address tags           |
| tgt_tgc_o         | (TGT_CNT*TGC_WIDTH)-1:0  | output    | concatinated bus cycle tags         |
| tgt_tgd_o         | (TGT_CNT*TGWD_WIDTH)-1:0 | output    | concatinated write data tags        |
| tgt_ack_i         | TGT_CNT-1:0              | input     | concatinated bus cycle acknowledges |
| tgt_err_i         | TGT_CNT-1:0              | input     | concatinated error indicators       |
| tgt_rty_i         | TGT_CNT-1:0              | input     | concatinated retry requests         |
| tgt_stall_i       | TGT_CNT-1:0              | input     | concatinated access delays          |
| tgt_dat_i         | (TGT_CNT*DATA_WIDTH)-1:0 | input     | concatinated read data<br>busses    |
| tgt_tgd_i         | (TGT_CNT*TGRD_WIDTH)-1:0 | input     | concatinated read data tags         |

## **Verification Status**

| Configuration         |     | Linting   | Simulation | Formal | FPGA |
|-----------------------|-----|-----------|------------|--------|------|
| <b>Default Config</b> | ura | tion      |            |        |      |
| TGT_CNT               | 4   |           |            |        |      |
| ADDR_WIDTH            | 16  |           |            |        |      |
| DATA_WIDTH            | 16  |           |            |        |      |
| SEL_WIDTH             | 2   | iVerilog, |            |        |      |
| TGA_WIDTH             | 1   | Yosys     |            |        |      |
| TGC_WIDTH             | 1   |           |            |        |      |
| TGRD_WIDTH            | 1   |           |            |        |      |
| TGWD_WIDTH            | 1   |           |            |        |      |

All lint checks have been done with the Icarus Verilog simulator [2] and the Yosys synthesis tool [3].

## WbXbc Xbar



This module implements a full crossbar switch between a set of initator busses and a set of target busses, all using the pipelined Wishbone protocol.

## **Integration Parameters**

| Parameter  | Default Value | Description                 |
|------------|---------------|-----------------------------|
| ITR_CNT    | 4             | number of initiator busses  |
| TGT_CNT    | 4             | number of target busses     |
| ADDR_WIDTH | 16            | width of the address bus    |
| DATA_WIDTH | 16            | width of each data bus      |
| SEL_WIDTH  | 2             | number of data select lines |
| TGA_WIDTH  | 1             | number of address tags      |
| TGC_WIDTH  | 1             | number of cycle tags        |
| TGRD_WIDTH | 1             | number of read data tags    |
| TGWD_WIDTH | 1             | number of write data tags   |

Section Integration Parameters gives a detailed description of each parameter listed above.

| Signal              | Range                    | Direction | Description                       |  |  |  |
|---------------------|--------------------------|-----------|-----------------------------------|--|--|--|
| Clock and Reset     |                          |           |                                   |  |  |  |
| clk_i               |                          | input     | module clock                      |  |  |  |
| async_rst_i         | input                    |           | asynchronous reset                |  |  |  |
| sync_rst_i          |                          | input     | synchronous reset                 |  |  |  |
| Target Address Re   | Target Address Regions   |           |                                   |  |  |  |
| region_addr         | (TGT_CNT*ADDR_WIDTH)-1:0 | input     | target address                    |  |  |  |
| region_mask         | (TGT_CNT*ADDR_WIDTH)-1:0 | input     | selects relevant address bits     |  |  |  |
| Initiator Interface | Initiator Interface      |           |                                   |  |  |  |
| itr_cyc_i           | ITR_CNT-1:0              | input     | concatinated bus cycle indicators |  |  |  |
| itr_stb_i           | ITR_CNT-1:0              | input     | concatinated access requests      |  |  |  |
| itr_we_i            | ITR_CNT-1:0              | input     | concatinated write enables        |  |  |  |
| itr_lock_i          | ITR_CNT-1:0              | input     | concatinated bus cycle locks      |  |  |  |
| itr_sel_i           | (ITR_CNT*SEL_WIDTH)-1:0  | input     | concatinated write data selects   |  |  |  |
| itr_adr_i           | (ITR_CNT*ADDR_WIDTH)-1:0 | input     | concatinated address busses       |  |  |  |
| itr_dat_i           | (ITR_CNT*DATA_WIDTH)-1:0 | input     | concatinated write data busses    |  |  |  |
| itr_tga_i           | (ITR_CNT*TGA_WIDTH)-1:0  | input     | concatinated address tags         |  |  |  |
| itr_tga_prio_i      | ITR_CNT-1:0              | input     | concatinated access priorities    |  |  |  |
| itr_tgc_i           | (ITR_CNT*TGC_WIDTH)-1:0  | input     | concatinated bus cycle tags       |  |  |  |
| itr_tgd_i           | (ITR_CNT*TGWD_WIDTH)-1:0 | input     | concatinated write data tags      |  |  |  |

| Signal            | Range                    | Direction | Description                         |  |
|-------------------|--------------------------|-----------|-------------------------------------|--|
| itr_ack_o         | ITR_CNT-1:0              | output    | concatinated bus cycle acknowledges |  |
| itr_err_o         | ITR_CNT-1:0              | output    | concatinated error indicators       |  |
| itr_rty_o         | ITR_CNT-1:0              | output    | concatinated retry requests         |  |
| itr_stall_o       | ITR_CNT-1:0              | output    | concatinated access delays          |  |
| itr_dat_o         | (ITR_CNT*DATA_WIDTH)-1:0 | output    | concatinated read data buses        |  |
| itr_tgd_o         | (ITR_CNT*TGRD_WIDTH)-1:0 | output    | concatinated read data tags         |  |
| Target Interfaces |                          |           |                                     |  |
| tgt_cyc_o         | TGT_CNT-1:0              | output    | concatinated bus cycle indicators   |  |
| tgt_stb_o         | TGT_CNT-1:0              | output    | concatinated access requests        |  |
| tgt_we_o          | TGT_CNT-1:0              | output    | concatinated write enables          |  |
| tgt_lock_o        | TGT_CNT-1:0              | output    | concatinated bus cycle locks        |  |
| tgt_sel_o         | (TGT_CNT*SEL_WIDTH)-1:0  | output    | concatinated write data selects     |  |
| tgt_adr_o         | (TGT_CNT*ADDR_WIDTH)-1:0 | output    | concatinated write data selects     |  |
| tgt_dat_o         | (TGT_CNT*DATA_WIDTH)-1:0 | output    | concatinated write data busses      |  |
| tgt_tga_o         | (TGT_CNT*TGA_WIDTH)-1:0  | output    | concatinated address tags           |  |
| tgt_tgc_o         | (TGT_CNT*TGC_WIDTH)-1:0  | output    | concatinated bus cycle tags         |  |
| tgt_tgd_o         | (TGT_CNT*TGWD_WIDTH)-1:0 | output    | concatinated write data tags        |  |
| tgt_ack_i         | TGT_CNT-1:0              | input     | concatinated bus cycle acknowledges |  |
| tgt_err_i         | TGT_CNT-1:0              | input     | concatinated error indicators       |  |
| tgt_rty_i         | TGT_CNT-1:0              | input     | concatinated retry requests         |  |
| tgt_stall_i       | TGT_CNT-1:0              | input     | concatinated access delays          |  |
| tgt_dat_i         | (TGT_CNT*DATA_WIDTH)-1:0 | input     | concatinated read data<br>busses    |  |
| tgt_tgd_i         | (TGT_CNT*TGRD_WIDTH)-1:0 | input     | concatinated read data tags         |  |

## **Verification Status**

| Configuration         | Linting | Simulation | Formal | FPGA |  |
|-----------------------|---------|------------|--------|------|--|
| Default Configuration |         |            |        |      |  |

| Configuration |    | Linting            | Simulation | Formal | FPGA |
|---------------|----|--------------------|------------|--------|------|
| ITR_CNT       | 4  |                    |            |        |      |
| TGT_CNT       | 4  |                    |            |        |      |
| ADDR_WIDTH    | 16 |                    |            |        |      |
| DATA_WIDTH    | 16 |                    |            |        |      |
| SEL_WIDTH     | 2  | iVerilog,<br>Yosys |            |        |      |
| TGA_WIDTH     | 1  | Tosys              |            |        |      |
| TGC_WIDTH     | 1  |                    |            |        |      |
| TGRD_WIDTH    | 1  |                    |            |        |      |
| TGWD_WIDTH    | 1  |                    |            |        |      |

All lint checks have been done with the Icarus Verilog simulator [2] and the Yosys synthesis tool [3].

# My Interpretation of the Pipelined Wishbone Protocol Spec

# **Protocol Signals Driven by the Initiator**

Cycle Indicator: CYC\_0, CYC\_I

#### **Care Condition**



#### **Stable Condition**



Transfer Request: STB\_0, STB\_I

#### **Care Condition**



**Stable Condition** 



Address Bus: ADR\_0, ADR\_I

## **Care Condition**



#### **Stable Condition**



Data Select: SEL\_0, SEL\_I





Data Direction: WE\_0, WE\_I

## **Care Condition**



## **Stable Condition**

Target Lock: LOCK\_0, LOCK\_I

## **Care Condition**

## **Stable Condition**



Write Data: DAT\_0, DAT\_I



Cycle Tags: TGC\_0, TGC\_I

## **Care Condition**



## **Stable Condition**

Address Tags: TGA\_0, TGA\_I

## **Care Condition**

#### **Stable Condition**



Write Data Tags: TGD\_0, TGD\_I



# **Protocol Signals Driven by the Target**

Transfer Completion Indicator: ACK\_0, ACK\_I

**Care Condition** 

**Stable Condition** 



**Permanent Error Indicator:** ERR\_0, ERR\_I

**Care Condition** 

**Stable Condition** 



Temporary Error Indicator: RTY\_0, RTY\_I



Transfer Delay: STALL\_0, STALL\_I

## **Care Condition**



## **Stable Condition**



Read Data: DAT\_0, DAT\_I

**Care Condition** 

**Stable Condition** 

Read Data Tags: TGD\_0, TGD\_I

**Care Condition** 

**Stable Condition** 

# **Bibliography**

- 1. Wishbone B4. Open Cores, 2010.
- 2. S. Williams, "Icarus Verilog." http://iverilog.icarus.com/.
- 3. C. Wolf, "Yosys Open SYnthesis Suite." http://www.clifford.at/yosys/.

```
Failed to generate image: Could not find the 'WaveDromEditor' executable in PATH; add
it to the PATH or specify its location using the 'WaveDromEditor' document attribute
{signal: [
 //clock
 {name: 'CLK_I', wave: 'P.....'},
 ['Standard',
 {name: 'STB_0', wave: '01.....|.0'},
 {name: 'STB_0', wave: '0101.01|.0'},
 {name: 'WE_O', wave: 'z=z=.z=|.z', data: ['we0', 'we1', 'we2']},
 {name: 'ADR_0', wave: 'x=x=.x=|.x', data: ['addr0', 'addr1', 'addr2']},
 {name: 'DAT_0', wave: 'x=x=.x=.|x', data: ['wdata0', 'wdata1', 'wdata2']},
 {name: 'ACK_I', wave: '010.10.|10'},
 {name: 'DAT_I', wave: 'x=x.=x', data: ['rdata0','rdata1', 'rdata2']},
 1,
 {},
 ['Pipelined',
 {name: 'CYC_0',
                   wave: '01..|..|0.'},
 {name: 'STB_0',
                   wave: '0110|1.|.0'},
                   wave: 'z===|..|x.', data: ['we0', 'we1', 'we2']},
 {name: 'WE_0',
                   wave: 'x===|..|x.', data: ['addr0', 'addr1', 'addr2']},
 {name: 'ADR_0',
                   wave: 'x===|..|x.', data: ['wdata0', 'wdata1', 'wdata2']},
 {name: 'DAT_0',
 {name: 'STALL_I', wave: '0...|1.|0.'},
 {name: 'ACK_I', wave: '0.10|10|10'},
                   wave: 'x.=x|=x|=x', data: ['rdata0','rdata1', 'rdata2']},
 {name: 'DAT I',
 ],
 {},
1,
   config: {hscale: 2},
 head: {text: 'Whishbone'}
}
```