

2. AXI-Lite

Gisselquist Technology, LLC

Daniel E. Gisselquist, Ph.D.





## **Lesson Overview**

Lesson Overview

**AXI-Lite Simplified** 

**Updated Controller** 

Bridging buses

Objective: To learn and become familiar with using a AXI-lite bus

- AXI is complicated. AXI-lite is (somewhat) better.
  - The handshaking can be hard to get right
  - Handshaking is common to both
- We'll use a AXI-lite bus simplifier in this lesson
  - This will convert AXI-lite into something that handles handshaking across multiple components
  - A similar AXI simplifier also exists
  - Doesn't impact throughput
- Modify our basic general purpose I/O controller for AXI-Lite
- Discuss and invoke bus bridges
  - Wishbone to AXI-Lite
  - AXI-Lite to Wishbone





Lesson Overview

**AXI-Lite** 

Simplified

5 Channels

Handshaking

Backpressure

Handshaking

Registered

Handshake Solutions

Simplified

Two simplifiers

AutoFPGA

**Updated Controller** 

Bridging buses

# **AXI-Lite Simplified**



## **5** Channels



Lesson Overview

**AXI-Lite Simplified** 

→ 5 Channels

Handshaking

Backpressure

Handshaking

Registered

Handshake Solutions

 ${\sf Simplified}$ 

Two simplifiers

**AutoFPGA** 

**Updated Controller** 

Bridging buses

AXI and AXI-Lite both use five separate channels





## 5 Channels



#### Lesson Overview

#### **AXI-Lite Simplified**

Handshaking

Backpressure

Handshaking

Registered

Handshake Solutions

Simplified

Two simplifiers

AutoFPGA

**Updated Controller** 

Bridging buses

AXI and AXI-Lite both use five separate channels

- AW Write address channel
  - Sends the address to be written to
  - W Write data channel
    - Prefixed with W
    - Sends the data to be written to that address
    - The slave needs to synchronize this with the write address
  - B Write response channel
- AR Read address channel
  - Requests a read from a given address
  - R Read data channel
  - Returns any values read



## Handshaking



Lesson Overview

**AXI-Lite Simplified** 

5 Channels

▶ Handshaking

Backpressure

Handshaking

Registered

Handshake Solutions

Simplified

Two simplifiers

AutoFPGA

**Updated Controller** 

Bridging buses

Each channel has associated VALID and READY signals

- When the source wishes to send information, it sets VALID
- When a sink is ready to receive information, it sets READY The AXI specification recommends leaving READY high if possible To prevent deadlock, the VALID signal is not allowed to wait for READY to be high
- A transaction takes place whenever VALID && READY
- A channel is stalled whenever VALID && !READY
   In this case, the source may not change any associated data
- All VALIDs must be cleared on reset



## Backpressure

Lesson Overview

**AXI-Lite Simplified** 

5 Channels

Handshaking

➢ Backpressure

Handshaking

Registered

Handshake Solutions

Simplified

Two simplifiers

AutoFPGA

**Updated Controller** 

Bridging buses

Backpressure: when the master isn't ready to receive the return



Backpressure!

- Ex: master requests several writes, but holds BREADY low
- Ex: master requests several reads, but holds RREADY low
- When sufficiently backed up, the slave must lower AxREADY



## Handshaking

 $\mathcal{W}$ 

Lesson Overview

**AXI-Lite Simplified** 

5 Channels

Handshaking

Backpressure

→ Handshaking

Registered

Handshake Solutions

Simplified

Two simplifiers

AutoFPGA

**Updated Controller** 

Bridging buses

The correct handshaking logic should look something like,

Such combinatorial logic is disallowed by the AXI4 specification



## Registered

Lesson Overview

**AXI-Lite Simplified** 

5 Channels

Handshaking

Backpressure

Handshaking

➢ Registered

Handshake Solutions

Simplified

Two simplifiers

**AutoFPGA** 

**Updated Controller** 

Bridging buses

The AXI4 specification requires that outputs cannot depend combinatorially upon inputs

- All bus signals must be registered
- This includes AWREADY, WREADY and ARREADY
  - We'll call these AxREADY for short



## Registered

Lesson Overview

**AXI-Lite Simplified** 

5 Channels

Handshaking

Backpressure

Handshaking

➢ Registered

Handshake Solutions

Simplified

Two simplifiers

**AutoFPGA** 

**Updated Controller** 

Bridging buses

The AXI4 specification *requires* that outputs cannot depend combinatorially upon inputs



If RVALID && !RREADY, then ...

- 1. The read channel must stall
- 2. Slave cannot lower ARREADY on this same cycle



## Registered

Lesson Overview

**AXI-Lite Simplified** 

5 Channels

Handshaking

Backpressure

Handshaking

➢ Registered

Handshake Solutions

Simplified

Two simplifiers

**AutoFPGA** 

**Updated Controller** 

Bridging buses

The AXI4 specification *requires* that outputs cannot depend combinatorially upon inputs



- 3. Earliest slave can clear ARREADY is one cycle later
- 4. What then happens to the request for A3?





Lesson Overview

**AXI-Lite Simplified** 

5 Channels

Handshaking

Backpressure

Handshaking

Registered

Handshake

➢ Solutions

**Simplified** 

Two simplifiers

AutoFPGA

**Updated Controller** 

Bridging buses

Solutions to this problem include:

Holding AxREADY low until AxVALID is true



- $\neg$  This will limit any core to 50% throughput at best
- This was the solution Xilinx attempted

This is perhaps the simplest solution





Lesson Overview

**AXI-Lite Simplified** 

5 Channels

Handshaking

Backpressure

Handshaking

Registered

Handshake

Solutions

Simplified

Two simplifiers

AutoFPGA

**Updated Controller** 

Bridging buses

Solutions to this problem include:

Holding AxREADY low until AxVALID is true

```
always @(posedge S_AXI_ACLK)
if (!S_AXI_ARESETN)
        S_AXI_AWREADY <= 1'b0;
else if (S_AXI_AWVALID && S_AXI_WVALID
        && (!S_AXI_BVALID || S_AXI_BREADY))
        S_AXI_AWREADY <= 1'b1;
else
        S_AXI_AWREADY <= 1'b0;
always @(posedge S_AXI_ACLK)
if (!S_AXI_ARESETN)
        S_AXI_BVALID <= 1'b0;
else if (!S_AXI_BVALID || S_AXI_BREADY))
        S_AXI_BVALID <= S_AXI_AWREADY;
```





Lesson Overview

**AXI-Lite Simplified** 

5 Channels

Handshaking

Backpressure

Handshaking

Registered

Handshake

➢ Solutions

Simplified

Two simplifiers

AutoFPGA

**Updated Controller** 

Bridging buses

Solutions to this problem include:

- Holding AxREADY low until AxVALID is true
- Using a skid buffer







Lesson Overview

**AXI-Lite Simplified** 

5 Channels

Handshaking

Backpressure

Handshaking

Registered

Handshake

➢ Solutions

Simplified

Two simplifiers

AutoFPGA

**Updated Controller** 

Bridging buses

Solutions to this problem include:

- Holding AxREADY low until AxVALID is true
- Using a skid buffer



With three skid buffers, full throughput is possible again





Lesson Overview

**AXI-Lite Simplified** 

5 Channels

Handshaking

Backpressure

Handshaking

Registered

Handshake

Solutions

Simplified

Two simplifiers

AutoFPGA

**Updated Controller** 

Bridging buses

Solutions to this problem include:

- Holding AxREADY low until AxVALID is true
- Using a skid buffer



This diagram from earlier actually shows a skid buffer implementation

Transaction A3 was buffered in the salve





Lesson Overview

**AXI-Lite Simplified** 

5 Channels

Handshaking

Backpressure

Handshaking

Registered

Handshake

➢ Solutions

Simplified

Two simplifiers

AutoFPGA

**Updated Controller** 

Bridging buses

Solutions to this problem include:

- Holding AxREADY low until AxVALID is true
- Using a skid buffer
  - Buffers the transaction that would be otherwise lost
  - Can be used to achieve 100% throughput
  - Building a skid buffer is a sublesson in itself
  - We'll come back to this in another lesson





Lesson Overview

**AXI-Lite Simplified** 

5 Channels

Handshaking

Backpressure

Handshaking

Registered

Handshake

➢ Solutions

Simplified

Two simplifiers

AutoFPGA

**Updated Controller** 

Bridging buses

Solutions to this problem include:

- Holding AxREADY low until AxVALID is true
- Using a skid buffer
- Simplifying the specification
  - If a group of slaves all shares the same basic logic
  - The handshaking work can be shared
  - Internal buffers can be shared
  - AutoFPGA will do this for SLAVE. TYPEs of both SINGLE and DOUBLE
  - Still achieve 100% throughput

For this lesson, we'll simplify the slave



## **Simplified**



Lesson Overview

**AXI-Lite Simplified** 

5 Channels

Handshaking

Backpressure

Handshaking

Registered

Handshake Solutions

Simplified

Two simplifiers

**AutoFPGA** 

**Updated Controller** 

Bridging buses

#### Simplified AXI protocol rules:

- All ready signals are held high
- All returns come one clock after xVALID
  - The simplifier ignores the slave's BVALID, RVALID, AxREADY and WREADY signals
  - Any slave that would otherwise set its outgoing valid signals with a one clock delay will work here
  - You can also cheat . . .
  - We'll cheat today, to get you up and running quickly
- Write address and data channels synchronized
- Concurrent read and write support is required

This takes all the hard work out of building an AXI-Lite slave

- The difficult synchronization tasks are left to the simplifier
- The bus simplifier can be made application agnostic



## **Simplified**



Lesson Overview

**AXI-Lite Simplified** 

5 Channels

Handshaking

Backpressure

Handshaking

Registered

Handshake Solutions

Simplified

Two simplifiers

**AutoFPGA** 

**Updated Controller** 

Bridging buses

Why should we use a bus simplifier?

- It makes the logic easier on you, the designer
- It's more than just training wheels
- It makes the logic cheaper on the FPGA
  - You should be able to attach more slaves to the bus with the simplifiers
  - Many slaves naturally meet the criteria



## **Simplified**



Lesson Overview

**AXI-Lite Simplified** 

5 Channels

Handshaking

Backpressure

Handshaking

Registered

Handshake Solutions

Simplified

Two simplifiers

**AutoFPGA** 

**Updated Controller** 

Bridging buses

Xilinx uses their own bus simplifier

- They call it "IPIF"
- It only allows one read or one write transaction at a time
- It will get at best 25% throughput



## Two simplifiers



Lesson Overview

**AXI-Lite Simplified** 

5 Channels

Handshaking

Backpressure

Handshaking

Registered

Handshake Solutions

Simplified

Two simplifiers

AutoFPGA

**Updated Controller** 

Bridging buses

Two types of AXI-Lite simplifiers in this repository

- AXI-Lite SINGLE
  - Slaves may only ever have one register
  - Simplifies the bus for a group of slaves
  - We'll discuss these today
- AXI-Lite DOUBLE
  - Slaves may have many registers
  - Must still respond the clock following AxVALID
  - Simplifies the bus for a group of slaves
  - These will be the focus of lesson three

There's also a similar AXI4 simplifier in the same repo

- Supports burst access, and multiple transaction IDs
- Even supports exclusive bus access



#### **AutoFPGA**



#### Lesson Overview

#### **AXI-Lite Simplified**

5 Channels

Handshaking

Backpressure

Handshaking

Registered

Handshake Solutions

Simplified

Two simplifiers

➢ AutoFPGA

**Updated Controller** 

Bridging buses

AutoFPGA will automatically connect bus simplifiers

- Groups all slaves of a given type on the bus
- Slaves of @SLAVE.TYPE=OTHER will not be simplified

| @BUS.TYPE | @SLAVE.TYPE | Simplifier                    |
|-----------|-------------|-------------------------------|
| AXI4-Lite | SINGLE      | axilsingle.v                  |
| AXI4-Lite | DOUBLE      | axildouble.v                  |
| AXI4      | SINGLE      | axisingle.v (not yet written) |
| AXI4      | DOUBLE      | axidouble.v                   |
| WB        | SINGLE      | (added in-line)               |
| WB        | DOUBLE      | (added in-line)               |
|           | •           |                               |

For these groups, only one master can access the group at a time





Lesson Overview

**AXI-Lite Simplified** 

 ${\sf Updated}$ 

Controller
 Controller

**AXI-Lite** 

Wishbone Writes

**AXI-Lite Writes** 

**AXI-Lite Writes** 

Wishbone Reads

**AXI-Lite Reads** 

**AXI-Lite Reads** 

Module declaration

Bridging buses

# **Updated Controller**



## **AXI-Lite**



Lesson Overview

**AXI-Lite Simplified** 

**Updated Controller** 

➢ AXI-Lite

Wishbone Writes

**AXI-Lite Writes** 

**AXI-Lite Writes** 

Wishbone Reads

**AXI-Lite Reads** 

**AXI-Lite Reads** 

Module declaration

Bridging buses

It's time to make a simplified AXI-Lite slave

- We'll start with our WB logic
- Show the differences in a basic AXI-Lite slave



## Wishbone Writes



Lesson Overview

**AXI-Lite Simplified** 

**Updated Controller** 

AXI-Lite

Wishbone

➢ Writes

**AXI-Lite Writes** 

**AXI-Lite Writes** 

Wishbone Reads

**AXI-Lite Reads** 

**AXI-Lite Reads** 

Module declaration

Bridging buses

Here was our wishbone write logic:



## **AXI-Lite Writes**



Lesson Overview

**AXI-Lite Simplified** 

**Updated Controller** 

**AXI-Lite** 

Wishbone Writes

> AXI-Lite Writes

**AXI-Lite Writes** 

Wishbone Reads

**AXI-Lite Reads** 

**AXI-Lite Reads** 

Module declaration

Bridging buses

Here is our modified AXI-Lite write logic:

The simplifier takes care of everything else

- AWVALID && WVALID combined are roughly equivalent to the Wishbone STB && WE signals
- ${\scriptscriptstyle \square}$   ${\scriptscriptstyle \square}$  WSTRB is roughly equivalent to the Wishbone SEL signal



## **AXI-Lite Writes**



Lesson Overview

**AXI-Lite Simplified** 

**Updated Controller** 

**AXI-Lite** 

Wishbone Writes

**AXI-Lite Writes** 

➤ AXI-Lite Writes

Wishbone Reads

AXI-Lite Reads

**AXI-Lite Reads** 

Module declaration

Bridging buses

For completeness sake, you can set the other signals

```
always @(*)
begin // Always be ready
        S AXI AWREADY = 1'b1:
        S_AXI_WREADY = 1'b1;
end
// Acknowledge on the clock following AWVALID
always @(posedge S_AXI_ACLK)
if (!S_AXI_ARESETN) // Negative reset!
        S_AXI_BVALID <= 0;
else
        S AXI BVALID <= S AXI AWVALID:
```

They'll be ignored, but at least they'll be (roughly) valid

This logic could likely lock up a normal AXI-Lite design



## Wishbone Reads



Lesson Overview

**AXI-Lite Simplified** 

**Updated Controller** 

**AXI-Lite** 

Wishbone Writes

**AXI-Lite Writes** 

**AXI-Lite Writes** 

**AXI-Lite Reads** 

**AXI-Lite Reads** 

Module declaration

Bridging buses

Here was our wishbone read logic:

```
// Bus slave logic
assign o_wb_stall = 1'b0;
assign o_wb_ack = i_wb_stb;
assign o_wb_data = { 31'h0, s_button };
```



## **AXI-Lite Reads**



Lesson Overview

**AXI-Lite Simplified** 

**Updated Controller** 

**AXI-Lite** 

Wishbone Writes

**AXI-Lite Writes** 

**AXI-Lite Writes** 

Wishbone Reads

➤ AXI-Lite Reads

**AXI-Lite Reads** 

Module declaration

Bridging buses

Here's our modified AXI-Lite read logic:

```
// Always return "okay"
always @(*)
        S_AXI_RRESP = 2'b00;

always @(posedge S_AXI_ACLK)
        S_AXI_RDATA <= { 31'h0, s_button };</pre>
```



## **AXI-Lite Reads**



Lesson Overview

**AXI-Lite Simplified** 

**Updated Controller** 

**AXI-Lite** 

Wishbone Writes

**AXI-Lite Writes** 

**AXI-Lite Writes** 

Wishbone Reads

**AXI-Lite Reads** 

AXI-Lite Reads

Module declaration

Bridging buses

For completeness, you can set the other read signals

As with the write half, these only "look" right

- Without the simplifier,
- This logic would likely lock up a normal AXI-Lite design



## Module declaration



Lesson Overview

**AXI-Lite Simplified** 

**Updated Controller** 

**AXI-Lite** 

Wishbone Writes

**AXI-Lite Writes** 

**AXI-Lite Writes** 

Wishbone Reads

**AXI-Lite Reads** 

AXI-Lite Reads Module

Bridging buses

With all of the AXI-Lite signals, declaration gets verbose

- You can find an example in the course notes
  - ledcontrol.v, or buttonreader.v
- Requires 55 lines to declare signals we'll mostly ignore
  - typedef, struct, and modports could help here
  - Many tools don't (yet) support these SV constructs





Lesson Overview

**AXI-Lite Simplified** 

**Updated Controller** 

➢ Bridging buses

Bus Structure

Bridge to AXI-Lite

Count the Cost

Bridge to Wishbone

Bridge to Wishbone

**AXI-Lite Hexbus** 

Your turn

# **Bridging buses**



#### **Bus Structure**

Lesson Overview

**AXI-Lite Simplified** 

**Updated Controller** 

Bridging buses

➢ Bus Structure Bridge to AXI-Lite

Count the Cost

Bridge to Wishbone

Bridge to Wishbone

AXI-Lite Hexbus

Your turn

Two approaches to integrating this module into our design

 $\neg$  We can start w/ WB and bridge to AXI-Lite





## **Bus Structure**

Lesson Overview

**AXI-Lite Simplified** 

**Updated Controller** 

Bridging buses ➢ Bus Structure

Bridge to AXI-Lite

Count the Cost

Bridge to Wishbone

Bridge to Wishbone

**AXI-Lite Hexbus** 

Your turn

Two approaches to integrating this module into our design

- We can start w/WB and bridge to AXI-Lite, or
- We could start w/ AXI-Lite and bridge to WB





## Bridge to AXI-Lite



Lesson Overview

**AXI-Lite Simplified** 

Updated Controller

Bridging buses

Bus Structure
Bridge to

➢ AXI-Lite

Count the Cost

Bridge to Wishbone

Bridge to Wishbone

AXI-Lite Hexbus

Your turn

Let's add a bridge to AXI-Lite

- The WB2AXIP repo contains a WB to AXI-Lite bridge
- We need to tell AutoFPGA about it
  - We'll start by defining a new bus we'll call axil
  - It'll also be of type axil, for AXI-Lite

@PREFIX=wb2axil

@BUS.NAME=axil

@BUS.TYPE=axil

@BUS.WIDTH=32

All AXI-Lite buses are 32-bits wide

@BUS.CLOCK=clk





Lesson Overview

**AXI-Lite Simplified** 

**Updated Controller** 

Bridging buses

Bus Structure Bridge to ➤ AXI-Lite

Your turn

Count the Cost Bridge to Wishbone Bridge to Wishbone **AXI-Lite Hexbus** 

Let's bridge from WB to AXI-Lite

- We can add the bridge description to the same component
- A bridge has both master and slave interfaces
- The master interface is that of a SUBBUS
  - This allows the slave's address width to be determined by the subbus'es address width

@SLAVE.BUS=wb

**@SLAVE.TYPE=OTHER** 

@MASTER.BUS=axil

@MASTER.TYPE=SUBBUS

@ERROR.WIRE=@\$(SLAVE.PREFIX)\_err Declare WB buserr sig

Connect to Wishbone

A normal connection

Drive AXI-Lite

Place master under slave

@\$(SLAVE.PREFIX) is a prefix assigned to the connection

- From the interconnect to this bus slave
- All bus wires to this slave will share this prefix





Lesson Overview

**AXI-Lite Simplified** 

**Updated Controller** 

Bridging buses

Bus Structure
Bridge to

➤ AXI-Lite

Your turn

Count the Cost Bridge to Wishbone Bridge to Wishbone AXI-Lite Hexbus Let's bridge from WB to AXI-Lite

- Depending on how your design build is set up
- You might want to add wbm2axilite.v to your Makefile
- This can be done via AutoFPGA as well

@RTL.MAKE.GROUP=WB2AXIL

@RTL.MAKE.SUBD=../wb2axip

@RTL.MAKE.FILES=wbm2axilite.v





Lesson Overview

**AXI-Lite Simplified** 

**Updated Controller** 

Bridging buses

Bus Structure
Bridge to

➤ AXI-Lite

Count the Cost

Bridge to Wishbone Bridge to Wishbone

**AXI-Lite Hexbus** 

Your turn

Let's bridge from WB to AXI-Lite

- The last step is the actual logic of the bridge
- MASTER.BUS.AWID is the bus'es address width
  - Determined by the sub-bus'es slave address widths

@MAIN.INSERT= // copy this code into main.v

- SLAVE.PORTLIST expands to the slave connections
- MASTER.PORTLIST to the bus master connections





Lesson Overview

**AXI-Lite Simplified** 

**Updated Controller** 

Bridging buses

Bus Structure
Bridge to

➤ AXI-Lite

Count the Cost Bridge to Wishbone Bridge to Wishbone

AXI-Lite Hexbus

Your turn

Let's bridge from WB to AXI-Lite

- The last step is the actual logic of the bridge
- MASTER.BUS.AWID is the bus'es address width
  - Determined by the sub-bus'es slave address widths

@MAIN.INSERT= // copy this code into main.v

- MASTER.BUS.AWID is the bus'es address width
  - Determined by the sub-bus'es slave address widths





Lesson Overview

**AXI-Lite Simplified** 

**Updated Controller** 

Bridging buses

Bus Structure

Bridge to AXI-Lite

Count the Cost

Bridge to Wishbone

Bridge to Wishbone

**AXI-Lite Hexbus** 

Your turn

Setting an LED should be simple



Ideally it should be just this easy





Lesson Overview

**AXI-Lite Simplified** 

**Updated Controller** 

Bridging buses

Bus Structure

Bridge to AXI-Lite

Count the Cost

Bridge to Wishbone

Bridge to Wishbone

**AXI-Lite Hexbus** 

Your turn

Going through an interconnect has a cost







Lesson Overview

**AXI-Lite Simplified** 

**Updated Controller** 

Bridging buses

Bus Structure

Bridge to AXI-Lite

Count the Cost

Bridge to Wishbone

Bridge to Wishbone

**AXI-Lite Hexbus** 

Your turn

The WB to AXI-Lite bridge has a cost







Lesson Overview

**AXI-Lite Simplified** 

**Updated Controller** 

Bridging buses

Bus Structure

Bridge to AXI-Lite

Count the Cost

Bridge to Wishbone

Bridge to Wishbone

**AXI-Lite Hexbus** 

Your turn

The simplifier adds an additional cost







Lesson Overview

**AXI-Lite Simplified** 

**Updated Controller** 

Bridging buses

Bus Structure

Bridge to AXI-Lite

Count the Cost

Bridge to Wishbone

Bridge to Wishbone

AXI-Lite Hexbus

Your turn

Where'd all the time go?

- An AXI-Lite bridge has a minimum 4-clock round trip
  - AXI outputs can't depend combinatorially on inputs
- Handling backpressure in the simplifier requires a FIFO
  - One clock to write to memory, another to read—adds more
  - Plus the bridge cost
- The interconnect requires three more
  - Decoding the address
  - Registering the outputs
  - Registering the return

A 2 clock operation turned into 11 clocks!



## Consequences



Lesson Overview

**AXI-Lite Simplified** 

**Updated Controller** 

Bridging buses

Bus Structure

Bridge to AXI-Lite

Count the Cost

Bridge to Wishbone

Bridge to Wishbone

AXI-Lite Hexbus

Your turn

Bridges have consequences

- Not all features translate
  - AxPROT field tracks data vs instruction access
    - No Wishbone equivalent
  - AWVALID & ARVALID might both be true
    - Wishbone only allows read or write, never both
  - Wishbone achieves lock by holding CYC high
    - AXI-Lite has no equivalent
    - AXI has AxLOCK, but the semantics don't translate
  - AXI byte zero is xDATA[7:0]
    - Wishbone has no explicit endianness
    - May require an endian swap



# Consequences



Lesson Overview

**AXI-Lite Simplified** 

**Updated Controller** 

Bridging buses

Bus Structure

Bridge to AXI-Lite

Count the Cost

Bridge to Wishbone

Bridge to Wishbone

AXI-Lite Hexbus

Your turn

### Bridges have consequences

- Not all features translate
- Yes, each of these bridges is high performance
  - Each can achieve 100% throughput
- You'll pay for every bridge
  - Each bridge introduces a lag
  - Not all features will translate
  - I haven't mentioned the logic cost

#### Conclusion?

It's an engineering decision, know the trade space Don't bridge across buses if you don't need to



# Bridge to Wishbone



Lesson Overview

**AXI-Lite Simplified** 

**Updated Controller** 

Bridging buses

Bus Structure

Bridge to AXI-Lite

Count the Cost Bridge to

Bridge to Wishbone

**AXI-Lite Hexbus** 

Your turn

We could also bridge from AXI-Lite to WB





# Bridge to Wishbone



Lesson Overview

**AXI-Lite Simplified** 

**Updated Controller** 

Bridging buses

Bus Structure

Bridge to AXI-Lite

Count the Cost

Bridge to Wishbone

Bridge to

**AXI-Lite Hexbus** 

Your turn

We could also bridge from AXI-Lite to WB

- The process is the same
- The core is configured a touch different
  - We can either bridge from AXI-Lite write and read channels separately, or
  - We can arbitrate between the two and bridge them together into one WB channel
  - If we do the latter, a good crossbar would still allow us two separate channels of WB
- Either way the AutoFPGA configuration starts the same way

@PREFIX=axil2wb

@SLAVE.BUS=axil

@SLAVE.TYPE=OTHER

@MASTER.BUS=wb

@MASTER.TYPE=SUBBUS



## **AXI-Lite Hexbus**



Lesson Overview

**AXI-Lite Simplified** 

**Updated Controller** 

Bridging buses

Your turn

Bus Structure Bridge to AXI-Lite Count the Cost Bridge to Wishbone Bridge to Wishbone AXI-Lite Hexbus We would need an original AXI-Lite master

- There's one in the dbgbus repo
- It's called hbaxil.v
- You should be able to modify hexbus.txt to work with hbaxil.v
  - Replace hbbus with hbaxil
  - Add hbaxil.v and hbexecaxil.v to the file lists
  - Change the MASTER.BUS to read axil
  - You can leave the wb bus definition in place—it won't hurt anything, and we'll still need it anyway



### Your turn



Lesson Overview

**AXI-Lite Simplified** 

Updated Controller

Bridging buses

Bus Structure

Bridge to AXI-Lite

Count the Cost

Bridge to Wishbone

Bridge to Wishbone

AXI-Lite Hexbus

AAI-LILE HEXDU

> Your turn

Your turn: Do your AXI-Lite LED and buttons work?

- Try the AXI-Lite blinker
- Does the LED still turn on when you press the button?
- Does the LED still turn off when you release the button?
- Can you bridge from WB to AXI-Lite?
- Can you bridge from AXI-Lite to WB?