diff options
author | matt | 2009-03-30 02:54:51 +0000 |
---|---|---|
committer | matt | 2009-03-30 02:54:51 +0000 |
commit | 8599dee8d6795d65fb9be9e9264c16c9257fb77a (patch) | |
tree | c7108eda436959d7146037b981e89397917967fe /usrp2/fpga/control_lib/newfifo/fifo19_to_fifo36.v | |
parent | 09526676f951056543a2891db36ef5d7ec804b4a (diff) | |
download | gnuradio-8599dee8d6795d65fb9be9e9264c16c9257fb77a.tar.gz gnuradio-8599dee8d6795d65fb9be9e9264c16c9257fb77a.tar.bz2 gnuradio-8599dee8d6795d65fb9be9e9264c16c9257fb77a.zip |
new fifos copied over from other project
git-svn-id: http://gnuradio.org/svn/gnuradio/trunk@10709 221aa14e-8319-0410-a670-987f0aec2ac5
Diffstat (limited to 'usrp2/fpga/control_lib/newfifo/fifo19_to_fifo36.v')
-rw-r--r-- | usrp2/fpga/control_lib/newfifo/fifo19_to_fifo36.v | 71 |
1 files changed, 71 insertions, 0 deletions
diff --git a/usrp2/fpga/control_lib/newfifo/fifo19_to_fifo36.v b/usrp2/fpga/control_lib/newfifo/fifo19_to_fifo36.v new file mode 100644 index 000000000..e22ca0a49 --- /dev/null +++ b/usrp2/fpga/control_lib/newfifo/fifo19_to_fifo36.v @@ -0,0 +1,71 @@ + +module fifo19_to_fifo36 + (input clk, input reset, input clear, + input [18:0] f19_datain, + input f19_src_rdy_i, + output f19_dst_rdy_o, + + output [35:0] f36_dataout, + output f36_src_rdy_o, + input f36_dst_rdy_i + ); + + reg f36_sof, f36_eof, f36_occ; + + reg [1:0] state; + reg [15:0] dat0, dat1; + + wire f19_sof = f19_datain[16]; + wire f19_eof = f19_datain[17]; + wire f19_occ = f19_datain[18]; + + wire xfer_out = f36_src_rdy_o & f36_dst_rdy_i; + + always @(posedge clk) + if(f19_src_rdy_i & ((state==0)|xfer_out)) + f36_sof <= f19_sof; + + always @(posedge clk) + if(f19_src_rdy_i & ((state != 2)|xfer_out)) + f36_eof <= f19_eof; + + always @(posedge clk) // FIXME check this + if(f19_eof) + f36_occ <= {state[0],f19_occ}; + else + f36_occ <= 0; + + always @(posedge clk) + if(reset) + state <= 0; + else + if(f19_src_rdy_i) + case(state) + 0 : + if(f19_eof) + state <= 2; + else + state <= 1; + 1 : + state <= 2; + 2 : + if(xfer_out) + state <= 1; + endcase // case(state) + else + if(xfer_out) + state <= 0; + + always @(posedge clk) + if(f19_src_rdy_i & (state==1)) + dat1 <= f19_datain; + + always @(posedge clk) + if(f19_src_rdy_i & ((state==0) | xfer_out)) + dat0 <= f19_datain; + + assign f19_dst_rdy_o = xfer_out | (state != 2); + assign f36_dataout = {f36_occ,f36_eof,f36_sof,dat0,dat1}; + assign f36_src_rdy_o = (state == 2); + +endmodule // fifo19_to_fifo36 |