# 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_axi
```

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.

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

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 parameter

Enable count, set this to 0 to disable (only disable if read/write/data\_count are on the same clock domain!).

**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 indicator Indicates last word in stream. m\_axis\_tlast 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 Output that indicates the amount of data in the FIFO. data\_count

### **INSTANTIATED MODULES**

# axis\_fifo

```
fifo #(
FIFO_DEPTH
                                                                            (
c_FIFO_DEPTH),
BYTE_WIDTH
                                                                            (
c_FIFO_WIDTH),
COUNT_WIDTH
                                                                            (
COUNT_WIDTH),
FWFT
                                                                            (
1),
RD_SYNC_DEPTH
                                                                            (
Θ),
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.