mirror of
https://github.com/aolofsson/oh.git
synced 2025-01-17 20:02:53 +08:00
0804d8ea29
-Seems vivado doesn't like the "|=" operation??
80 lines
2.0 KiB
Verilog
80 lines
2.0 KiB
Verilog
module emesh_mux (/*AUTOARG*/
|
|
// Outputs
|
|
wait_out, access_out, packet_out,
|
|
// Inputs
|
|
access_in, packet_in, wait_in
|
|
);
|
|
|
|
//#####################################################################
|
|
//# PARAMETERS
|
|
//#####################################################################
|
|
parameter AW = 32;
|
|
parameter PW = 2 * AW + 40;
|
|
parameter N = 99;
|
|
parameter CFG = "STATIC"; //Arbitration configuration
|
|
//"STATIC" fixed priority
|
|
//"DYNAMIC" round robin priority
|
|
|
|
//#####################################################################
|
|
//# INTERFACE
|
|
//#####################################################################
|
|
|
|
//Incoming transaction
|
|
input [N-1:0] access_in;
|
|
input [N*PW-1:0] packet_in;
|
|
output [N-1:0] wait_out;
|
|
|
|
//Outgoing transaction
|
|
output access_out;
|
|
output [PW-1:0] packet_out;
|
|
input wait_in;
|
|
|
|
//#####################################################################
|
|
//# BODY
|
|
//#####################################################################
|
|
|
|
//local variables
|
|
wire [N-1:0] grants;
|
|
reg [PW-1:0] packet_out;
|
|
integer i;
|
|
|
|
//arbiter
|
|
generate
|
|
if(CFG=="STATIC")
|
|
begin
|
|
oh_arbiter #(.N(N))
|
|
arbiter(// Outputs
|
|
.grants (grants[N-1:0]),
|
|
// Inputs
|
|
.requests (access_in[N-1:0])
|
|
);
|
|
end
|
|
else if (CFG=="DYNAMIC")
|
|
begin
|
|
initial
|
|
$display("ROUND ROBIN ARBITER NOT IMPLEMENTED\n");
|
|
end
|
|
endgenerate
|
|
|
|
//access signal
|
|
assign access_out = |(access_in[N-1:0]);
|
|
|
|
//raise wait signals
|
|
assign wait_out[N-1:0] = access_in[N-1:0] & (~grants[N-1:0] | {(N){wait_in}});
|
|
|
|
//parametrized mux
|
|
always @*
|
|
begin
|
|
packet_out[PW-1:0] = 'b0;
|
|
for(i=0;i<N;i=i+1)
|
|
packet_out[PW-1:0] = packet_out[PW-1:0] | {(PW){grants[i]}} & packet_in[((i+1)*PW-1)-:PW];
|
|
end
|
|
|
|
endmodule // mesh_mux
|
|
|
|
// Local Variables:
|
|
// verilog-library-directories:("." "../../common/hdl")
|
|
// End:
|
|
|
|
|