# axis ctrl fifo.v

#### **AUTHORS**

#### **JAY CONVERTINO**

## **DATES**

### 2021/06/29

#### **INFORMATION**

#### **Brief**

Wraps the standard FIFO with an axi streaming interface, Xilinx AXIS FIFO Emulation.

#### 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
=
8,
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_axis_aclk)
```

AXIS fifo control

#### **Parameters**

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

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

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

 $\label{eq:m_axis_tvalid} \textbf{When active high the output data is valid}$ 

 $\label{eq:m_axis_tready} \textbf{ 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.

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.