root / usrp2 / fifo / fifo36_mux.v @ a932ce2d
History | View | Annotate | Download (1.5 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 |
localparam MUX_IDLE0 = 0; |
| 14 |
localparam MUX_DATA0 = 1; |
| 15 |
localparam MUX_IDLE1 = 2; |
| 16 |
localparam MUX_DATA1 = 3; |
| 17 |
|
| 18 |
reg [1:0] state; |
| 19 |
|
| 20 |
wire eof0 = data0_i[33]; |
| 21 |
wire eof1 = data1_i[33]; |
| 22 |
|
| 23 |
always @(posedge clk) |
| 24 |
if(reset | clear) |
| 25 |
state <= MUX_IDLE0; |
| 26 |
else |
| 27 |
case(state) |
| 28 |
MUX_IDLE0 : |
| 29 |
if(src0_rdy_i) |
| 30 |
state <= MUX_DATA0; |
| 31 |
else if(src1_rdy_i) |
| 32 |
state <= MUX_DATA1; |
| 33 |
|
| 34 |
MUX_DATA0 : |
| 35 |
if(src0_rdy_i & dst_rdy_i & eof0) |
| 36 |
state <= prio ? MUX_IDLE0 : MUX_IDLE1; |
| 37 |
|
| 38 |
MUX_IDLE1 : |
| 39 |
if(src1_rdy_i) |
| 40 |
state <= MUX_DATA1; |
| 41 |
else if(src0_rdy_i) |
| 42 |
state <= MUX_DATA0; |
| 43 |
|
| 44 |
MUX_DATA1 : |
| 45 |
if(src1_rdy_i & dst_rdy_i & eof1) |
| 46 |
state <= MUX_IDLE0; |
| 47 |
|
| 48 |
default : |
| 49 |
state <= MUX_IDLE0; |
| 50 |
endcase // case (state) |
| 51 |
|
| 52 |
assign dst0_rdy_o = (state==MUX_DATA0) ? dst_rdy_i : 0; |
| 53 |
assign dst1_rdy_o = (state==MUX_DATA1) ? dst_rdy_i : 0; |
| 54 |
assign src_rdy_o = (state==MUX_DATA0) ? src0_rdy_i : (state==MUX_DATA1) ? src1_rdy_i : 0; |
| 55 |
assign data_0 = (state==MUX_DATA0) ? data0_i : data1_i; |
| 56 |
|
| 57 |
endmodule // fifo36_demux |