mirror of
https://github.com/fpganinja/taxi.git
synced 2025-12-09 17:08:38 -08:00
axis: Add AXI stream FIFO module and testbench
Signed-off-by: Alex Forencich <alex@alexforencich.com>
This commit is contained in:
120
tb/axis/taxi_axis_fifo/test_taxi_axis_fifo.sv
Normal file
120
tb/axis/taxi_axis_fifo/test_taxi_axis_fifo.sv
Normal file
@@ -0,0 +1,120 @@
|
||||
// SPDX-License-Identifier: CERN-OHL-S-2.0
|
||||
/*
|
||||
|
||||
Copyright (c) 2025 FPGA Ninja, LLC
|
||||
|
||||
Authors:
|
||||
- Alex Forencich
|
||||
|
||||
*/
|
||||
|
||||
`resetall
|
||||
`timescale 1ns / 1ps
|
||||
`default_nettype none
|
||||
|
||||
/*
|
||||
* AXI4-Stream FIFO testbench
|
||||
*/
|
||||
module test_taxi_axis_fifo #
|
||||
(
|
||||
/* verilator lint_off WIDTHTRUNC */
|
||||
parameter DEPTH = 4096,
|
||||
parameter DATA_W = 8,
|
||||
parameter logic KEEP_EN = (DATA_W>8),
|
||||
parameter KEEP_W = ((DATA_W+7)/8),
|
||||
parameter logic STRB_EN = 1'b0,
|
||||
parameter logic LAST_EN = 1'b1,
|
||||
parameter logic ID_EN = 1'b0,
|
||||
parameter ID_W = 8,
|
||||
parameter logic DEST_EN = 1'b0,
|
||||
parameter DEST_W = 8,
|
||||
parameter logic USER_EN = 1'b1,
|
||||
parameter USER_W = 1,
|
||||
parameter RAM_PIPELINE = 1,
|
||||
parameter logic OUTPUT_FIFO_EN = 1'b0,
|
||||
parameter logic FRAME_FIFO = 1'b0,
|
||||
parameter logic [USER_W-1:0] USER_BAD_FRAME_VALUE = 1'b1,
|
||||
parameter logic [USER_W-1:0] USER_BAD_FRAME_MASK = 1'b1,
|
||||
parameter logic DROP_OVERSIZE_FRAME = FRAME_FIFO,
|
||||
parameter logic DROP_BAD_FRAME = 1'b0,
|
||||
parameter logic DROP_WHEN_FULL = 1'b0,
|
||||
parameter logic MARK_WHEN_FULL = 1'b0,
|
||||
parameter logic PAUSE_EN = 1'b0,
|
||||
parameter logic FRAME_PAUSE = FRAME_FIFO
|
||||
/* verilator lint_on WIDTHTRUNC */
|
||||
)
|
||||
();
|
||||
|
||||
logic clk;
|
||||
logic rst;
|
||||
|
||||
taxi_axis_if #(
|
||||
.DATA_W(DATA_W),
|
||||
.KEEP_EN(KEEP_EN),
|
||||
.KEEP_W(KEEP_W),
|
||||
.STRB_EN(STRB_EN),
|
||||
.LAST_EN(LAST_EN),
|
||||
.ID_EN(ID_EN),
|
||||
.ID_W(ID_W),
|
||||
.DEST_EN(DEST_EN),
|
||||
.DEST_W(DEST_W),
|
||||
.USER_EN(USER_EN),
|
||||
.USER_W(USER_W)
|
||||
) s_axis(), m_axis();
|
||||
|
||||
logic pause_req;
|
||||
logic pause_ack;
|
||||
|
||||
logic [$clog2(DEPTH):0] status_depth;
|
||||
logic [$clog2(DEPTH):0] status_depth_commit;
|
||||
logic status_overflow;
|
||||
logic status_bad_frame;
|
||||
logic status_good_frame;
|
||||
|
||||
taxi_axis_fifo #(
|
||||
.DEPTH(DEPTH),
|
||||
.RAM_PIPELINE(RAM_PIPELINE),
|
||||
.OUTPUT_FIFO_EN(OUTPUT_FIFO_EN),
|
||||
.FRAME_FIFO(FRAME_FIFO),
|
||||
.USER_BAD_FRAME_VALUE(USER_BAD_FRAME_VALUE),
|
||||
.USER_BAD_FRAME_MASK(USER_BAD_FRAME_MASK),
|
||||
.DROP_OVERSIZE_FRAME(DROP_OVERSIZE_FRAME),
|
||||
.DROP_BAD_FRAME(DROP_BAD_FRAME),
|
||||
.DROP_WHEN_FULL(DROP_WHEN_FULL),
|
||||
.MARK_WHEN_FULL(MARK_WHEN_FULL),
|
||||
.PAUSE_EN(PAUSE_EN),
|
||||
.FRAME_PAUSE(FRAME_PAUSE)
|
||||
)
|
||||
uut (
|
||||
.clk(clk),
|
||||
.rst(rst),
|
||||
|
||||
/*
|
||||
* AXI4-Stream input (sink)
|
||||
*/
|
||||
.s_axis(s_axis),
|
||||
|
||||
/*
|
||||
* AXI4-Stream output (source)
|
||||
*/
|
||||
.m_axis(m_axis),
|
||||
|
||||
/*
|
||||
* Pause
|
||||
*/
|
||||
.pause_req(pause_req),
|
||||
.pause_ack(pause_ack),
|
||||
|
||||
/*
|
||||
* Status
|
||||
*/
|
||||
.status_depth(status_depth),
|
||||
.status_depth_commit(status_depth_commit),
|
||||
.status_overflow(status_overflow),
|
||||
.status_bad_frame(status_bad_frame),
|
||||
.status_good_frame(status_good_frame)
|
||||
);
|
||||
|
||||
endmodule
|
||||
|
||||
`resetall
|
||||
Reference in New Issue
Block a user