URL
https://opencores.org/ocsvn/robust_axi_fabric/robust_axi_fabric/trunk
Subversion Repositories robust_axi_fabric
[/] [robust_axi_fabric/] [trunk/] [src/] [base/] [ic_arbiter.v] - Rev 5
Go to most recent revision | Compare with Previous | Blame | View Log
OUTFILE PREFIX_ic_MSTR_SLV_arbiter.v ITER MX MSTRNUM ITER SX SLVNUM module PREFIX_ic_MSTR_SLV_arbiter(PORTS); input clk; input reset; input [MSTRNUM-1:0] M_last; input [MSTRNUM-1:0] M_req; input [MSTRNUM-1:0] M_grant; input [LOG2(SLVNUM)-1:0] MMX_slave; output [MSTRNUM-1:0] SSX_master; reg [MSTRNUM:0] SSX_master_prio_reg; wire [MSTRNUM-1:0] SSX_master_prio; reg [MSTRNUM-1:0] SSX_master_d; wire [MSTRNUM-1:0] M_SSX; wire [MSTRNUM-1:0] M_SSX_valid; wire [MSTRNUM-1:0] M_SSX_prio; reg [MSTRNUM-1:0] M_SSX_burst; parameter MASTER_NONE = BIN(0 MSTRNUM); parameter MASTERMX = BIN(EXPR(2^MX) MSTRNUM); IFDEF DEF_PRIO always @(posedge clk or posedge reset) if (reset) begin SSX_master_prio_reg[MSTRNUM:1] <= #FFD {MSTRNUM{1'b0}}; SSX_master_prio_reg[0] <= #FFD 1'b1; end else if (|(M_req & M_grant & M_last)) begin SSX_master_prio_reg[MSTRNUM:1] <= #FFD SSX_master_prio_reg[MSTRNUM-1:0]; SSX_master_prio_reg[0] <= #FFD SSX_master_prio_reg[MSTRNUM-1]; end assign SSX_master_prio = SSX_master_prio_reg[MSTRNUM-1:0]; assign M_SSX_prio = M_SSX_valid & SSX_master_prio; ENDIF DEF_PRIO always @(posedge clk or posedge reset) if (reset) begin SSX_master_d <= #FFD {MSTRNUM{1'b0}}; end else begin SSX_master_d <= #FFD SSX_master; end LOOP MX MSTRNUM always @(posedge clk or posedge reset) if (reset) begin M_SSX_burst[MX] <= #FFD 1'b0; end else if (M_req[MX]) begin M_SSX_burst[MX] <= #FFD SSX_master[MX] & (M_grant[MX] ? (~M_last[MX]) : 1'b1); end ENDLOOP MX assign M_SSX = {CONCAT(MMX_slave == 'dSX ,)}; assign M_SSX_valid = M_SSX & M_req; LOOP SX SLVNUM assign SSX_master = M_SSX_burst[MX] ? SSX_master_d : IF DEF_PRIO M_SSX_prio[MX] ? MASTERMX : M_SSX_valid[MX] ? MASTERMX : MASTER_NONE; ENDLOOP SX endmodule
Go to most recent revision | Compare with Previous | Blame | View Log