root / usrp2 / fifo / fifo36_mux.v @ 98a1a03d
History | View | Annotate | Download (2.42 KB)
| 1 |
|
|---|---|
| 2 |
// Mux packets from multiple FIFO interfaces onto a single one. |
| 3 |
// Can alternate or give priority to one port (port 0) |
| 4 |
// In prio mode, port 1 will never get access if port 0 is always busy |
| 5 |
|
| 6 |
module fifo36_mux |
| 7 |
#(parameter prio = 0) |
| 8 |
(input clk, input reset, input clear, |
| 9 |
input [35:0] data0_i, input src0_rdy_i, output dst0_rdy_o, |
| 10 |
input [35:0] data1_i, input src1_rdy_i, output dst1_rdy_o, |
| 11 |
output [35:0] data_o, output src_rdy_o, input dst_rdy_i); |
| 12 |
|
| 13 |
wire [35:0] data0_int, data1_int; |
| 14 |
wire src0_rdy_int, dst0_rdy_int, src1_rdy_int, dst1_rdy_int; |
| 15 |
|
| 16 |
fifo_short #(.WIDTH(36)) mux_fifo_in0 |
| 17 |
(.clk(clk), .reset(reset), .clear(clear), |
| 18 |
.datain(data0_i), .src_rdy_i(src0_rdy_i), .dst_rdy_o(dst0_rdy_i), |
| 19 |
.dataout(data0_int), .src_rdy_o(src0_rdy_int), .dst_rdy_i(dst0_rdy_int)); |
| 20 |
|
| 21 |
fifo_short #(.WIDTH(36)) mux_fifo_in1 |
| 22 |
(.clk(clk), .reset(reset), .clear(clear), |
| 23 |
.datain(data1_i), .src_rdy_i(src1_rdy_i), .dst_rdy_o(dst1_rdy_i), |
| 24 |
.dataout(data1_int), .src_rdy_o(src1_rdy_int), .dst_rdy_i(dst1_rdy_int)); |
| 25 |
|
| 26 |
localparam MUX_IDLE0 = 0; |
| 27 |
localparam MUX_DATA0 = 1; |
| 28 |
localparam MUX_IDLE1 = 2; |
| 29 |
localparam MUX_DATA1 = 3; |
| 30 |
|
| 31 |
reg [1:0] state; |
| 32 |
|
| 33 |
wire eof0 = data0_int[33]; |
| 34 |
wire eof1 = data1_int[33]; |
| 35 |
|
| 36 |
wire [35:0] data_int; |
| 37 |
wire src_rdy_int, dst_rdy_int; |
| 38 |
|
| 39 |
always @(posedge clk) |
| 40 |
if(reset | clear) |
| 41 |
state <= MUX_IDLE0; |
| 42 |
else |
| 43 |
case(state) |
| 44 |
MUX_IDLE0 : |
| 45 |
if(src0_rdy_int) |
| 46 |
state <= MUX_DATA0; |
| 47 |
else if(src1_rdy_int) |
| 48 |
state <= MUX_DATA1; |
| 49 |
|
| 50 |
MUX_DATA0 : |
| 51 |
if(src0_rdy_int & dst_rdy_int & eof0) |
| 52 |
state <= prio ? MUX_IDLE0 : MUX_IDLE1; |
| 53 |
|
| 54 |
MUX_IDLE1 : |
| 55 |
if(src1_rdy_int) |
| 56 |
state <= MUX_DATA1; |
| 57 |
else if(src0_rdy_int) |
| 58 |
state <= MUX_DATA0; |
| 59 |
|
| 60 |
MUX_DATA1 : |
| 61 |
if(src1_rdy_int & dst_rdy_int & eof1) |
| 62 |
state <= MUX_IDLE0; |
| 63 |
|
| 64 |
default : |
| 65 |
state <= MUX_IDLE0; |
| 66 |
endcase // case (state) |
| 67 |
|
| 68 |
assign dst0_rdy_int = (state==MUX_DATA0) ? dst_rdy_int : 0; |
| 69 |
assign dst1_rdy_int = (state==MUX_DATA1) ? dst_rdy_int : 0; |
| 70 |
assign src_rdy_int = (state==MUX_DATA0) ? src0_rdy_int : (state==MUX_DATA1) ? src1_rdy_int : 0; |
| 71 |
assign data_int = (state==MUX_DATA0) ? data0_int : data1_int; |
| 72 |
|
| 73 |
fifo_short #(.WIDTH(36)) mux_fifo |
| 74 |
(.clk(clk), .reset(reset), .clear(clear), |
| 75 |
.datain(data_int), .src_rdy_i(src_rdy_int), .dst_rdy_o(dst_rdy_int), |
| 76 |
.dataout(data_o), .src_rdy_o(src_rdy_o), .dst_rdy_i(dst_rdy_i)); |
| 77 |
endmodule // fifo36_demux |