This is an old revision of the document!
Verilog AXI Stream Components Readme
Introduction
Collection of AXI Stream bus components. Most components are fully parametrizable in interface widths. Includes full MyHDL testbench with intelligent bus cosimulation endpoints.
Documentation
Common signals
tdata : Data (width generally DATA_WIDTH) tkeep : Data word valid (width generally KEEP_WIDTH, default DATA_WIDTH/8, present on _64 modules) tvalid : Data valid tready : Sink ready tlast : End-of-frame tuser : Bad frame (valid with tlast & tvalid)
Source Files
rtl/axis_adapter.v : Parametrizable bus width adapter rtl/axis_async_fifo.v : Asynchronous FIFO rtl/axis_async_fifo_64.v : Asynchronous FIFO (64 bit) rtl/axis_async_frame_fifo.v : Asynchronous frame FIFO rtl/axis_async_frame_fifo_64.v : Asynchronous frame FIFO (64 bit) rtl/axis_fifo.v : Synchronous FIFO rtl/axis_fifo_64.v : Synchronous FIFO (64 bit) rtl/axis_frame_fifo.v : Synchronous frame FIFO rtl/axis_frame_fifo_64.v : Synchronous frame FIFO (64 bit) rtl/axis_frame_join.py : Frame joiner generator rtl/axis_frame_join_4.v : 4 port frame joiner rtl/axis_ll_bridge.v : AXI stream to LocalLink bridge rtl/axis_rate_limit.v : Fractional rate limiter rtl/axis_rate_limit_64.v : Fractional rate limiter (64 bit) rtl/axis_register.v : AXI Stream register rtl/axis_register_64.v : AXI Stream register (64 bit) rtl/axis_stat_counter.v : Statistics counter rtl/ll_axis_bridge.v : LocalLink to AXI stream bridge
AXI Stream Interface Example
two byte transfer with sink pause after each byte
__ __ __ __ __ __ __ __ __ clk __/ \__/ \__/ \__/ \__/ \__/ \__/ \__/ \__/ \__ _____ _________________ tdata XXXXXXXXX_D0__X_D1______________XXXXXXXXXXXXXXXXXXXXXXXX _____ _________________ tkeep XXXXXXXXX_K0__X_K1______________XXXXXXXXXXXXXXXXXXXXXXXX _______________________ tvalid ________/ \_______________________ ______________ _____ ___________ tready \___________/ \___________/ _________________ tlast ______________/ \_______________________ tuser ________________________________________________________
two back-to-back packets, no pauses
__ __ __ __ __ __ __ __ __ clk __/ \__/ \__/ \__/ \__/ \__/ \__/ \__/ \__/ \__ _____ _____ _____ _____ _____ _____ tdata XXXXXXXXX_A0__X_A1__X_A2__X_B0__X_B1__X_B2__XXXXXXXXXXXX _____ _____ _____ _____ _____ _____ tkeep XXXXXXXXX_K0__X_K1__X_K2__X_K0__X_K1__X_K2__XXXXXXXXXXXX ___________________________________ tvalid ________/ \___________ ________________________________________________________ tready _____ _____ tlast ____________________/ \___________/ \___________ tuser ________________________________________________________
bad frame
__ __ __ __ __ __ clk __/ \__/ \__/ \__/ \__/ \__/ \__ _____ _____ _____ tdata XXXXXXXXX_A0__X_A1__X_A2__XXXXXXXXXXXX _____ _____ _____ tkeep XXXXXXXXX_K0__X_K1__X_K2__XXXXXXXXXXXX _________________ tvalid ________/ \___________ ______________________________________ tready _____ tlast ____________________/ \___________ _____ tuser ____________________/ \___________
Testing
Running the included testbenches requires MyHDL and Icarus Verilog. Make sure that myhdl.vpi is installed properly for cosimulation to work correctly. The testbenches can be run with a Python test runner like nose or py.test, or the individual test scripts can be run with python directly.
Testbench Files
tb/axis_ep.py : MyHDL AXI Stream endpoints tb/ll_ep.py : MyHDL LocalLink endpoints