2014-12-14 17:18:53 -05:00
|
|
|
/*
|
|
|
|
########################################################################
|
|
|
|
EPIPHANY eMesh Arbiter
|
|
|
|
########################################################################
|
|
|
|
|
2015-05-01 17:58:16 -04:00
|
|
|
This block takes three FIFO inputs (write, read request, read response)
|
|
|
|
and the DMA channel, arbitrates between the active channels, and forwards
|
|
|
|
the result to the transmit output pins.
|
2014-12-14 17:18:53 -05:00
|
|
|
|
2015-05-01 17:58:16 -04:00
|
|
|
Arbitration Priority:
|
|
|
|
1) host writes (highest)
|
2015-04-11 00:04:18 -04:00
|
|
|
2) read requests from host
|
|
|
|
3) read responses
|
2015-05-01 17:58:16 -04:00
|
|
|
4) DMA (lowest)
|
2015-04-11 00:04:18 -04:00
|
|
|
|
2014-12-14 17:18:53 -05:00
|
|
|
*/
|
|
|
|
|
|
|
|
module etx_arbiter (/*AUTOARG*/
|
|
|
|
// Outputs
|
2015-05-03 23:25:19 -04:00
|
|
|
txwr_fifo_wait, txrd_fifo_wait, txrr_fifo_wait, edma_wait,
|
2015-05-01 17:58:16 -04:00
|
|
|
etx_access, etx_packet, etx_rr,
|
2014-12-14 17:18:53 -05:00
|
|
|
// Inputs
|
2015-05-03 23:25:19 -04:00
|
|
|
clk, reset, txwr_fifo_access, txwr_fifo_packet, txrd_fifo_access,
|
|
|
|
txrd_fifo_packet, txrr_fifo_access, txrr_fifo_packet, edma_access,
|
|
|
|
edma_packet, etx_rd_wait, etx_wr_wait, etx_io_wait, etx_cfg_wait,
|
|
|
|
ctrlmode_bypass, ctrlmode
|
2014-12-14 17:18:53 -05:00
|
|
|
);
|
|
|
|
|
2015-04-23 17:57:24 -04:00
|
|
|
parameter PW = 104;
|
2015-04-23 23:16:03 -04:00
|
|
|
parameter ID = 0;
|
2015-04-23 17:57:24 -04:00
|
|
|
|
2015-05-01 17:58:16 -04:00
|
|
|
//tx clock and reset
|
|
|
|
input clk;
|
2014-12-14 17:18:53 -05:00
|
|
|
input reset;
|
2015-04-23 17:57:24 -04:00
|
|
|
|
2015-04-13 23:35:21 -04:00
|
|
|
//Write Request (from slave)
|
2015-05-03 23:25:19 -04:00
|
|
|
input txwr_fifo_access;
|
|
|
|
input [PW-1:0] txwr_fifo_packet;
|
|
|
|
output txwr_fifo_wait;
|
2014-12-14 17:18:53 -05:00
|
|
|
|
2015-04-13 23:35:21 -04:00
|
|
|
//Read Request (from slave)
|
2015-05-03 23:25:19 -04:00
|
|
|
input txrd_fifo_access;
|
|
|
|
input [PW-1:0] txrd_fifo_packet;
|
|
|
|
output txrd_fifo_wait;
|
2014-12-14 17:18:53 -05:00
|
|
|
|
2015-04-13 23:35:21 -04:00
|
|
|
//Read Response (from master)
|
2015-05-03 23:25:19 -04:00
|
|
|
input txrr_fifo_access;
|
|
|
|
input [PW-1:0] txrr_fifo_packet;
|
|
|
|
output txrr_fifo_wait;
|
2014-12-14 17:18:53 -05:00
|
|
|
|
2015-05-02 23:04:13 -04:00
|
|
|
//DMA Master (not implemented, TODO)
|
2015-05-01 17:58:16 -04:00
|
|
|
input edma_access;
|
|
|
|
input [PW-1:0] edma_packet;
|
|
|
|
output edma_wait;
|
|
|
|
|
2015-05-03 23:25:19 -04:00
|
|
|
//Wait signal inputs
|
|
|
|
input etx_rd_wait;
|
|
|
|
input etx_wr_wait;
|
|
|
|
input etx_io_wait;
|
|
|
|
input etx_cfg_wait;
|
|
|
|
|
2015-05-01 17:58:16 -04:00
|
|
|
//ctrlmode for rd/wr transactions
|
|
|
|
input ctrlmode_bypass;
|
|
|
|
input [3:0] ctrlmode;
|
|
|
|
|
|
|
|
//Transaction for IO protocol
|
2015-04-23 17:57:24 -04:00
|
|
|
output etx_access;
|
|
|
|
output [PW-1:0] etx_packet;
|
2015-05-01 17:58:16 -04:00
|
|
|
output etx_rr; //bypass translation on read response
|
|
|
|
|
2014-12-14 22:24:16 -05:00
|
|
|
//regs
|
2015-04-23 17:57:24 -04:00
|
|
|
reg etx_access;
|
|
|
|
reg [PW-1:0] etx_packet;
|
2015-05-01 17:58:16 -04:00
|
|
|
reg etx_rr; //bypass translation on read response
|
2015-04-24 17:39:05 -04:00
|
|
|
|
2015-05-03 23:25:19 -04:00
|
|
|
//wires
|
2015-04-23 17:57:24 -04:00
|
|
|
wire [3:0] txrd_ctrlmode;
|
|
|
|
wire [3:0] txwr_ctrlmode;
|
2015-05-03 23:25:19 -04:00
|
|
|
wire access_in;
|
|
|
|
wire [PW-1:0] etx_packet_mux;
|
|
|
|
wire edma_grant;
|
|
|
|
wire txrr_grant;
|
|
|
|
wire txrd_grant;
|
|
|
|
wire txwr_grant;
|
|
|
|
wire edma_arb_wait;
|
|
|
|
wire txrr_arb_wait;
|
|
|
|
wire txrd_arb_wait;
|
|
|
|
wire txwr_arb_wait;
|
|
|
|
wire [PW-1:0] txrd_data;
|
|
|
|
wire [PW-1:0] txwr_data;
|
|
|
|
wire [PW-1:0] etx_mux;
|
2015-04-23 17:57:24 -04:00
|
|
|
|
2015-04-27 11:16:15 -04:00
|
|
|
//##########################################################################
|
2015-05-03 23:25:19 -04:00
|
|
|
//# Insert special control mode
|
2015-04-27 11:16:15 -04:00
|
|
|
//##########################################################################
|
2015-05-01 17:58:16 -04:00
|
|
|
assign txrd_ctrlmode[3:0] = ctrlmode_bypass ? ctrlmode[3:0] :
|
|
|
|
txrd_fifo_packet[7:4];
|
2015-04-23 17:57:24 -04:00
|
|
|
|
2015-05-03 23:25:19 -04:00
|
|
|
assign txrd_data[PW-1:0] = {txrd_fifo_packet[PW-1:8],
|
|
|
|
txrd_ctrlmode[3:0],
|
|
|
|
txrd_fifo_packet[3:0]};
|
|
|
|
|
|
|
|
|
2015-05-01 17:58:16 -04:00
|
|
|
assign txwr_ctrlmode[3:0] = ctrlmode_bypass ? ctrlmode[3:0] :
|
|
|
|
txwr_fifo_packet[7:4];
|
2015-05-03 23:25:19 -04:00
|
|
|
|
|
|
|
assign txwr_data[PW-1:0] = {txwr_fifo_packet[PW-1:8],
|
|
|
|
txwr_ctrlmode[3:0],
|
|
|
|
txwr_fifo_packet[3:0]};
|
|
|
|
|
2015-05-01 17:58:16 -04:00
|
|
|
//##########################################################################
|
2015-05-03 23:25:19 -04:00
|
|
|
//# Arbiter
|
2015-05-01 17:58:16 -04:00
|
|
|
//##########################################################################
|
2015-05-03 23:25:19 -04:00
|
|
|
|
|
|
|
|
|
|
|
arbiter_priority #(.ARW(4)) arbiter (.grant({edma_grant,//lowest priority
|
|
|
|
txrr_grant,
|
|
|
|
txrd_grant,
|
|
|
|
txwr_grant //highest priority
|
|
|
|
}),
|
|
|
|
.await({edma_arb_wait,
|
|
|
|
txrr_arb_wait,
|
|
|
|
txrd_arb_wait,
|
|
|
|
txwr_arb_wait
|
|
|
|
}),
|
|
|
|
.request({edma_access,
|
|
|
|
txrr_fifo_access,
|
|
|
|
txrd_fifo_access,
|
|
|
|
txwr_fifo_access
|
|
|
|
})
|
|
|
|
);
|
|
|
|
//Priority Mux
|
|
|
|
assign etx_mux[PW-1:0] =({(PW){txwr_grant}} & txwr_data[PW-1:0]) |
|
|
|
|
({(PW){txrd_grant}} & txrd_data[PW-1:0]) |
|
|
|
|
({(PW){txrr_grant}} & txrr_fifo_packet[PW-1:0]) |
|
|
|
|
({(PW){edma_grant}} & edma_packet[PW-1:0]);
|
|
|
|
|
|
|
|
//######################################################################
|
|
|
|
//Pushback (stall) Signals
|
|
|
|
//######################################################################
|
|
|
|
|
|
|
|
//Write waits on pin wr wait or cfg_wait
|
|
|
|
assign txwr_fifo_wait = etx_wr_wait |
|
|
|
|
etx_io_wait | etx_cfg_wait;
|
|
|
|
|
|
|
|
//Host read request (self throttling, one read at a time)
|
|
|
|
assign txrd_fifo_wait = etx_rd_wait |
|
|
|
|
etx_io_wait | etx_cfg_wait |
|
|
|
|
txrd_arb_wait;
|
|
|
|
//Read response
|
|
|
|
assign txrr_fifo_wait = etx_wr_wait |
|
|
|
|
etx_io_wait | etx_cfg_wait |
|
|
|
|
txrr_arb_wait;
|
|
|
|
|
|
|
|
//DMA (conservative)
|
|
|
|
assign edma_wait = etx_wr_wait | etx_rd_wait |
|
|
|
|
etx_io_wait | etx_cfg_wait |
|
|
|
|
edma_arb_wait;
|
|
|
|
|
|
|
|
//##########################################################################
|
|
|
|
//# Pipeline stage (arbiter+mux takes time..)
|
|
|
|
//##########################################################################
|
|
|
|
assign access_in = (txwr_grant & ~txwr_fifo_wait) |
|
|
|
|
(txrd_grant & ~txrd_fifo_wait) |
|
|
|
|
(txrr_grant & ~txrr_fifo_wait) |
|
|
|
|
(edma_grant & ~edma_wait);
|
|
|
|
|
|
|
|
//access
|
|
|
|
always @ (posedge clk)
|
|
|
|
etx_access <= access_in;
|
|
|
|
|
|
|
|
//packet
|
|
|
|
always @ (posedge clk)
|
|
|
|
etx_packet[PW-1:0] <= etx_mux[PW-1:0];
|
|
|
|
|
|
|
|
//read request signal for remap/mmu
|
|
|
|
//(otherwise we can't differentiate betwen wr and rr
|
2015-05-01 17:58:16 -04:00
|
|
|
always @ (posedge clk)
|
2015-05-03 23:25:19 -04:00
|
|
|
etx_rr <= txrr_grant;
|
2015-05-01 17:58:16 -04:00
|
|
|
|
2015-04-13 23:35:21 -04:00
|
|
|
endmodule // etx_arbiter
|
2015-05-03 23:25:19 -04:00
|
|
|
// Local Variables:
|
|
|
|
// verilog-library-directories:("." "../../common/hdl")
|
|
|
|
// End:
|
|
|
|
|
|
|
|
|
2015-04-11 00:04:18 -04:00
|
|
|
/*
|
|
|
|
File: etx_arbiter.v
|
|
|
|
|
2015-05-03 23:25:19 -04:00
|
|
|
Copyright (C) 2015 Adapteva, Inc.
|
2015-04-11 00:04:18 -04:00
|
|
|
Contributed by Andreas Olofsson <andreas@adapteva.com>
|
|
|
|
|
|
|
|
This program is free software: you can redistribute it and/or modify
|
|
|
|
it under the terms of the GNU General Public License as published by
|
|
|
|
the Free Software Foundation, either version 3 of the License, or
|
|
|
|
(at your option) any later version.
|
|
|
|
|
|
|
|
This program is distributed in the hope that it will be useful,
|
|
|
|
but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
|
|
GNU General Public License for more details.
|
|
|
|
|
|
|
|
You should have received a copy of the GNU General Public License
|
|
|
|
along with this program (see the file COPYING). If not, see
|
|
|
|
<http://www.gnu.org/licenses/>.
|
|
|
|
*/
|