HITDAQ/FPGA_firmware/sensor_algo_qsys/testbench/sts2stl_tb.v
2024-10-11 14:49:54 +02:00

126 lines
2.6 KiB
Verilog

//testbench for sts2stl: ST short 16-bit to ST long 32-bit
`timescale 1 ns / 1 ns
module sts2stl_tb();
localparam CLK_PERIOD = 20;
reg clk;
reg rst;
//avalon ST(Streaming) sink: 0 readlatency and 0 readallowence
reg [15:0] data_in_data;
wire data_in_ready;
wire data_in_valid;
reg [1:0] data_in_empty;
reg data_in_startofpacket;
reg data_in_endofpacket;
//avalon ST(Streaming) source: 0 readlatency and 0 readallowence
wire [31:0] data_out_data; // data_out.data
wire [1:0] data_out_empty; // .empty
wire data_out_endofpacket; // .endofpacket
wire data_out_startofpacket; // .startofpacket
reg data_out_ready; // .ready
wire data_out_valid; // .valid
reg [1:0] state;
localparam STATE_IDLE = 2'd0;
localparam STATE_SEND = 2'd1;
localparam STATE_LOC = 2'd3;
sts2stl sts2stl_dut(
.clk (clk),
.rst (rst),
.data_in_data (data_in_data),
.data_in_ready (data_in_ready),
.data_in_valid (data_in_valid),
.data_in_empty (data_in_empty),
.data_in_startofpacket (data_in_startofpacket),
.data_in_endofpacket (data_in_endofpacket),
.data_out_data (data_out_data),
.data_out_empty (data_out_empty),
.data_out_endofpacket (data_out_endofpacket),
.data_out_startofpacket (data_out_startofpacket),
.data_out_ready (data_out_ready),
.data_out_valid (data_out_valid)
);
initial begin
clk = 1'b1;
rst = 1'b1;
data_in_data = 0;
data_in_empty = 2'b0;
data_in_startofpacket = 1'b0;
data_in_endofpacket = 1'b0;
data_out_ready = 1'b0;
state = STATE_IDLE;
#(CLK_PERIOD*2);
rst = 1'b0;
//the next sink is ready..
#(CLK_PERIOD*20);
data_out_ready = 1'b1;
//start packet
#(CLK_PERIOD*2+1);
data_in_startofpacket = 1'b1;
//end packet
#(CLK_PERIOD*6);
data_in_endofpacket = 1'b1;
#(CLK_PERIOD*200); $stop;
end
//clk
always #(CLK_PERIOD/2) clk = ~ clk;
assign data_in_valid = (state == STATE_SEND || data_in_startofpacket || data_in_endofpacket)? 1'b1 : 1'b0;
always @(posedge clk) begin
case(state)
STATE_IDLE:
begin
if (data_in_startofpacket && data_in_ready)
begin
state <= STATE_SEND;
data_in_data <= data_in_data + 1;
data_in_startofpacket <= 1'b0;
end
end
STATE_SEND:
begin
if (data_in_ready)
begin
if (data_in_endofpacket) begin
state <= STATE_LOC;
data_in_data <= 0;
data_in_endofpacket <= 1'b0;
end else begin
data_in_data <= data_in_data + 1;
end
end
end
STATE_LOC:
begin
state <= STATE_IDLE;
end
endcase
end
endmodule