diff options
author | Ian Buckley <ianb@server2.(none)> | 2010-08-12 12:00:01 -0700 |
---|---|---|
committer | Ian Buckley <ianb@server2.(none)> | 2010-08-12 12:00:01 -0700 |
commit | 6e0d78f4cbf6f0d6cda6007f11b4fb4dd4edaee9 (patch) | |
tree | 34c44eeea94ac1682284f8462d38dc38804345a7 /usrp2/extramfifo/ext_fifo_tb.v | |
parent | 2e5effd0b664413c4d3cbbe08d3d841eee051dcc (diff) | |
download | uhd-6e0d78f4cbf6f0d6cda6007f11b4fb4dd4edaee9.tar.gz uhd-6e0d78f4cbf6f0d6cda6007f11b4fb4dd4edaee9.tar.bz2 uhd-6e0d78f4cbf6f0d6cda6007f11b4fb4dd4edaee9.zip |
Found bug due to not accounting for the correct number of possible in flight READ operations that can be in the extfifo pipeline.
Regenerated fifo_xlnx_512x36_2clk_18to36 to include prog_full output triggered at 1017 so that there are 6 empty spaces to accept
in flight read data upon completion.
Had to generate the FIFO using Coregen from ISE12.1 due to 10.1 verion not working correctly in FPGA
Still have to tackle making this simulate in Icarus
Diffstat (limited to 'usrp2/extramfifo/ext_fifo_tb.v')
-rw-r--r-- | usrp2/extramfifo/ext_fifo_tb.v | 39 |
1 files changed, 39 insertions, 0 deletions
diff --git a/usrp2/extramfifo/ext_fifo_tb.v b/usrp2/extramfifo/ext_fifo_tb.v index 38df4a285..a93d524d5 100644 --- a/usrp2/extramfifo/ext_fifo_tb.v +++ b/usrp2/extramfifo/ext_fifo_tb.v @@ -51,6 +51,44 @@ module ext_fifo_tb(); always #4 ext_clk <= ~ext_clk; + initial + begin + rst <= 1; + repeat (5) @(negedge int_clk); + rst <= 0; + @(negedge int_clk); + while (datain < 10000) + begin + @(negedge int_clk); + datain <= datain + dst_rdy_o; + src_rdy_i <= dst_rdy_o; + end + end // initial begin + + + initial + begin + repeat (20) @(negedge int_clk); + + // Fall through fifo, first output already valid + if (dataout !== ref_dataout) + $display("Error: Expected %x, got %x",ref_dataout, dataout); + + while (ref_dataout < 10000) + begin + @(negedge int_clk); + ref_dataout <= ref_dataout + src_rdy_o ; + dst_rdy_i <= src_rdy_o; + if ((dataout !== ref_dataout) && src_rdy_o) + $display("Error: Expected %x, got %x",ref_dataout, dataout); + @(negedge int_clk); + dst_rdy_i <= 0; + repeat(6) @(negedge int_clk); + end + end + + +/* -----\/----- EXCLUDED -----\/----- initial begin @@ -112,6 +150,7 @@ module ext_fifo_tb(); end // initial begin + -----/\----- EXCLUDED -----/\----- */ /////////////////////////////////////////////////////////////////////////////////// // Simulation control // /////////////////////////////////////////////////////////////////////////////////// |