aboutsummaryrefslogtreecommitdiffstats
path: root/fpga/usrp3/lib/fifo/axi_fifo_cascade.v
diff options
context:
space:
mode:
Diffstat (limited to 'fpga/usrp3/lib/fifo/axi_fifo_cascade.v')
-rw-r--r--fpga/usrp3/lib/fifo/axi_fifo_cascade.v48
1 files changed, 48 insertions, 0 deletions
diff --git a/fpga/usrp3/lib/fifo/axi_fifo_cascade.v b/fpga/usrp3/lib/fifo/axi_fifo_cascade.v
new file mode 100644
index 000000000..84c009c42
--- /dev/null
+++ b/fpga/usrp3/lib/fifo/axi_fifo_cascade.v
@@ -0,0 +1,48 @@
+//
+// Copyright 2012-2013 Ettus Research LLC
+// Copyright 2018 Ettus Research, a National Instruments Company
+//
+// SPDX-License-Identifier: LGPL-3.0-or-later
+//
+
+
+
+// Cascade FIFO : ShortFIFO -> Block RAM fifo -> ShortFIFO for timing and placement help
+
+// Special case SIZE <= 5 uses a short fifo in the middle, which is not too useful in this case
+
+module axi_fifo_cascade
+ #(parameter WIDTH=32, SIZE=9)
+ (input clk, input reset, input clear,
+ input [WIDTH-1:0] i_tdata,
+ input i_tvalid,
+ output i_tready,
+ output [WIDTH-1:0] o_tdata,
+ output o_tvalid,
+ input o_tready,
+
+ output [15:0] space,
+ output [15:0] occupied);
+
+ wire [WIDTH-1:0] int1_tdata, int2_tdata;
+ wire int1_tvalid, int1_tready, int2_tvalid, int2_tready;
+
+ axi_fifo_flop2 #(.WIDTH(WIDTH)) pre_fifo
+ (.clk(clk), .reset(reset), .clear(clear),
+ .i_tdata(i_tdata), .i_tvalid(i_tvalid), .i_tready(i_tready),
+ .o_tdata(int1_tdata), .o_tvalid(int1_tvalid), .o_tready(int1_tready),
+ .space(), .occupied());
+
+ axi_fifo #(.WIDTH(WIDTH), .SIZE(SIZE)) main_fifo
+ (.clk(clk), .reset(reset), .clear(clear),
+ .i_tdata(int1_tdata), .i_tvalid(int1_tvalid), .i_tready(int1_tready),
+ .o_tdata(int2_tdata), .o_tvalid(int2_tvalid), .o_tready(int2_tready),
+ .space(space), .occupied(occupied)); // May change unexpectedly, but are always conservative
+
+ axi_fifo_flop2 #(.WIDTH(WIDTH)) post_fifo
+ (.clk(clk), .reset(reset), .clear(clear),
+ .i_tdata(int2_tdata), .i_tvalid(int2_tvalid), .i_tready(int2_tready),
+ .o_tdata(o_tdata), .o_tvalid(o_tvalid), .o_tready(o_tready),
+ .space(), .occupied());
+
+endmodule // axi_fifo_cascade