Revision a932ce2d
| b/usrp2/fifo/fifo36_mux.v | ||
|---|---|---|
| 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 |
|
Also available in: Unified diff