# AXIS\_FIFO



November 21, 2024

Jay Convertino

# **Contents**

| 1 | Usage                         | 2     |
|---|-------------------------------|-------|
|   | 1.1 Introduction              | <br>2 |
|   | 1.2 Dependencies              | <br>2 |
|   | 1.2.1 fusesoc info Depenecies | <br>2 |
|   | 1.3 In a Project              | <br>2 |
| 2 | Architecture                  | 2     |
| 3 | Building                      | 3     |
|   | 3.1 fusesoc                   | <br>3 |
|   | 3.2 Source Files              | <br>3 |
|   | 3.2 Source Files              | <br>3 |
|   | 3.3 Targets                   | <br>4 |
|   | 3.3.1 fusesoc_info Targets    | <br>4 |
|   | 3.4 Directory Guide           | <br>4 |
| 4 | Simulation                    | 5     |
|   | 4.1 iverilog                  | <br>5 |
|   | 4.2 cocotb                    | <br>5 |
| 5 | Module Documentation          | 6     |
|   | 5.1 axis fifo                 | <br>7 |
|   | 5.2 axis fifo ctrl            |       |

# 1 Usage

#### 1.1 Introduction

Standard AXIS FIFO with multiple options. The FIFO uses a AXIS interface for data in and out. It also emulates the Xilinx AXIS FIFO bugs and all. This is NOT dependent on Xilinx FPGA's and can be used on any FPGA supporting the Verilog block ram style primitive.

## 1.2 Dependencies

The following are the dependencies of the cores.

- fusesoc 2.X
- · iverilog (simulation)
- cocotb (simulation)

#### 1.2.1 fusesoc\_info Depenecies

- dep
  - AFRL:buffer:fifo
  - AFRL:utility:helper:1.0.0
- dep\_tb
  - AFRL:simulation:axis stimulator
  - AFRL:simulation:clock\_stimulator
  - AFRL:utility:sim\_helper

### 1.3 In a Project

Simply use this core between a sink and source devices. This buffer data from one bus to another. Check the code to see if others will work correctly.

### 2 Architecture

This AXIS FIFO is made for two modules. They are the FIFO, and AXIS FIFO control. The combination of these two provide the AXIS FIFO module. Having it made this way allows for future modules to be customized and brought in to change the FIFO's behavior. The current

modules emulate the Xilinx AXIS FIFO IP core availble in Vivado 2018 and up.

AXIS FIFO control is the heart of the core when it comes to how it responds. The logic in the core is designed to emulate the Xilinx AXIS FIFO IP.

Please see 5 for more information.

# 3 Building

The AXIS FIFO core is written in Verilog 2001. They should synthesize in any modern FPGA software. The core comes as a fusesoc packaged core and can be included in any other core. Be sure to make sure you have meet the dependencies listed in the previous section.

#### 3.1 fusesoc

Fusesoc is a system for building FPGA software without relying on the internal project management of the tool. Avoiding vendor lock in to Vivado or Quartus. These cores, when included in a project, can be easily integrated and targets created based upon the end developer needs. The core by itself is not a part of a system and should be integrated into a fusesoc based system. Simulations are setup to use fusesoc and are a part of its targets.

#### 3.2 Source Files

#### 3.2.1 fusesoc info File List

- src
  - src/axis\_fifo.v
  - src/axis\_fifo\_ctrl.v
- tb
  - 'tb/tb\_axis.v': 'file\_type': 'verilogSource'
- ut
  - 'ut/cocotb\_axis\_verification.py': 'file\_type': 'user', 'copyto': '.'

### 3.3 Targets

#### 3.3.1 fusesoc info Targets

default

Info: Default for IP intergration.

• sim

Info: Constant data value with file check.

sim\_rand\_data

Info: Feed random data input with file check

• sim\_rand\_ready\_rand\_data

Info: Feed random data input, and randomize the read ready on the output. Perform output file check.

sim\_8bit\_count\_data

Info: Feed a counter data as input, perform file check.

sim\_rand\_ready\_8bit\_count\_data

Info: Feed a counter data a input, and randomize the read ready on the output. Perform output file check.

### 3.4 Directory Guide

Below highlights important folders from the root of the directory.

- 1. **docs** Contains all documentation related to this project.
  - **manual** Contains user manual and github page that are generated from the latex sources.
- 2. **src** Contains source files for the core
- 3. **tb** Contains test bench files for iverilog and cocotb
  - cocotb testbench files

# 4 Simulation

There are a few different simulations that can be run for this core.

# 4.1 iverilog

iverilog is used for simple test benches for quick verification, visually, of the core.

# 4.2 cocotb

Future simulations will use cocotb. This feature is not yet implemented.

# **5 Module Documentation**

There is a single async module for this core.

- AXIS\_FIFO will buffer data from input to output.
- **AXIS\_FIFO\_CONTROL** emulates the Xilinx FIFO IP interface and its behavior.

The next sections document the module in great detail.

# axis\_fifo.v

#### **AUTHORS**

### **JAY CONVERTINO**

#### **DATES**

#### 2021/06/29

### **INFORMATION**

#### **Brief**

Wraps the standard FIFO with an axi streaming interface.

#### **License MIT**

Copyright 2021 Jay Convertino

Permission is hereby granted, free of charge, to any person obtaining a copy of this software and associated documentation files (the "Software"), to deal in the Software without restriction, including without limitation the rights to use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of the Software, and to permit persons to whom the Software is furnished to do so, subject to the following conditions:

The above copyright notice and this permission notice shall be included in all copies or substantial portions of the Software.

THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.

### axis fifo

```
module axis_fifo #(
parameter
FIFO_DEPTH
=
256,
parameter
COUNT_WIDTH
=
8,
parameter
BUS_WIDTH
```

```
1,
parameter
USER_WIDTH
parameter
DEST_WIDTH
parameter
RAM_TYPE
"block",
parameter
PACKET_MODE
parameter
COUNT_DELAY
parameter
COUNT_ENA
) ( input m_axis_aclk, input m_axis_arstn, output m_axis_tvalid, input m_ax
```

AXIS fifo

#### **Parameters**

FIFO\_DEPTH Depth of the fifo, must be a power of two number(divisable aka 256 = 2^8). Any non-power of two will be rounded up to the next closest. parameter

COUNT\_WIDTH Data count output width in bits. Should be the same power of two as fifo parameter

depth(256 for fifo depth... this should be 8).

**BUS WIDTH** Width of the axis data bus input/output in bytes.

parameter

USER\_WIDTH Width of the axis user bus input/output in bits.

parameter

DEST\_WIDTH Width of the axis dest bus input/output in bits.

parameter

RAM\_TYPE RAM type setting.

parameter

PACKET\_MODE Set axis fifo to wait for tlast before allowing a read on master port output.

parameter

COUNT\_DELAY Delay count by one clock cycle of the data count clock.

parameter

COUNT ENA Enable count, set this to 0 to disable (only disable if read/write/data\_count

parameter are on the same clock domain!).

**Ports** 

Clock for AXIS m\_axis\_aclk

m\_axis\_arstn Negative reset for AXIS

When active high the output data is valid m\_axis\_tvalid

m axis tready When set active high the output device is ready for data. m\_axis\_tdata Output data m\_axis\_tkeep Output valid byte indicator m\_axis\_tlast Indicates last word in stream. m\_axis\_tuser Output user bus m\_axis\_tdest Output destination s\_axis\_aclk Clock for AXIS s\_axis\_arstn Negative reset for AXIS s\_axis\_tvalid When set active high the input data is valid s\_axis\_tready When active high the device is ready for input data. s\_axis\_tdata Input data s\_axis\_tkeep Input valid byte indicator s\_axis\_tlast Is this the last word in the stream (active high). s\_axis\_tuser Input user bus s\_axis\_tdest Input desitination data\_count\_aclk Clock for data count Negative edge reset for data count. data\_count\_arstn data\_count Output that indicates the amount of data in the FIFO.

#### **INSTANTIATED MODULES**

# axis\_fifo

```
fifo #(
FIFO_DEPTH
                                                                            (
c_FIFO_DEPTH),
BYTE_WIDTH
                                                                            (
c_FIFO_WIDTH),
COUNT_WIDTH
                                                                            (
COUNT_WIDTH),
FWFT
                                                                            (
1),
RD_SYNC_DEPTH
                                                                            (
0),
WR_SYNC_DEPTH
                                                                            (
0),
DC_SYNC_DEPTH
                                                                            (
Θ),
```

```
COUNT_DELAY),

COUNT_ENA

COUNT_ENA),

DATA_ZERO

1),

ACK_ENA

0),

RAM_TYPE

RAM_TYPE

RAM_TYPE)

axis_fifo ( .rd_clk (m_axis_aclk), .rd_rstn (m_axis_arstn), .rd_en (s_rd_e)
```

Generic FIFO that acts like a Xilinx FIFO.

# axis\_control

```
axis_fifo_ctrl #(

BUS_WIDTH

(BUS_WIDTH),

FIFO_WIDTH

(_FIFO_WIDTH),

USER_WIDTH

(_USER_WIDTH),

DEST_WIDTH

(_DEST_WIDTH),

PACKET_MODE(PACKET_MODE)
) axis_control ( .m_axis_aclk (m_axis_aclk), .m_axis_arstn (m_axis_arstn),
```

Create signals to control FIFO and provide AXIS interace.

# axis\_ctrl\_fifo.v

#### **AUTHORS**

### **JAY CONVERTINO**

#### **DATES**

#### 2021/06/29

### **INFORMATION**

#### **Brief**

Wraps the standard FIFO with an axi streaming interface.

#### **License MIT**

Copyright 2021 Jay Convertino

Permission is hereby granted, free of charge, to any person obtaining a copy of this software and associated documentation files (the "Software"), to deal in the Software without restriction, including without limitation the rights to use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of the Software, and to permit persons to whom the Software is furnished to do so, subject to the following conditions:

The above copyright notice and this permission notice shall be included in all copies or substantial portions of the Software.

THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.

### axis\_fifo\_ctrl

```
module axis_fifo_ctrl #(
parameter
BUS_WIDTH
=
1,
parameter
FIFO_WIDTH
=
8,
parameter
FIFO_POWER
```

```
parameter
USER_WIDTH

=
1,
parameter
DEST_WIDTH
=
1,
parameter
PACKET_MODE
=
0
) ( input m_axis_aclk, input m_axis_arstn, output m_axis_tvalid, input m_ax:
```

AXIS fifo control

#### **Parameters**

BUS\_WIDTH Width of the axis data bus input/output in bytes. FIFO WIDTH -

parameter FIFO\_POWER -

**USER\_WIDTH** Width of the axis user bus input/output in bits.

parameter

**DEST\_WIDTH** Width of the axis dest bus input/output in bits.

parameter

**PACKET\_MODE** Set axis fifo to wait for tlast before allowing a read on master port output.

parameter

#### **Ports**

m\_axis\_aclk Clock for AXIS

m\_axis\_arstn Negative reset for AXIS

m\_axis\_tvalid When active high the output data is valid

m\_axis\_tready When set active high the output device is ready for data.

m\_axis\_tdata Output data

m\_axis\_tkeep Output valid byte indicatorm\_axis\_tlast Indicates last word in stream.

**s\_axis\_tlast** Is this the last word in the stream (active high).

rd\_en Active high enable of read interface.rd\_valid Active high output that the data is valid.

rd\_data Output data

rd\_empty Active high output when read is empty.wr\_full Active high output that the FIFO is full.