mirror of
https://github.com/vortexgpgpu/vortex.git
synced 2025-04-24 22:07:41 -04:00
119 lines
No EOL
4.4 KiB
Verilog
119 lines
No EOL
4.4 KiB
Verilog
`include "VX_define.vh"
|
|
|
|
module VX_databus_arb (
|
|
input wire clk,
|
|
input wire reset,
|
|
|
|
// input request
|
|
VX_dcache_core_req_if core_req_if,
|
|
|
|
// output requests
|
|
VX_dcache_core_req_if cache_req_if,
|
|
VX_dcache_core_req_if smem_req_if,
|
|
|
|
// input responses
|
|
VX_dcache_core_rsp_if cache_rsp_if,
|
|
VX_dcache_core_rsp_if smem_rsp_if,
|
|
|
|
// output response
|
|
VX_dcache_core_rsp_if core_rsp_if
|
|
);
|
|
localparam SMEM_ASHIFT = `CLOG2(`SHARED_MEM_BASE_ADDR_ALIGN);
|
|
localparam REQ_ASHIFT = `CLOG2(`DWORD_SIZE);
|
|
localparam REQ_ADDRW = 32 - REQ_ASHIFT;
|
|
localparam REQ_DATAW = 1 + REQ_ADDRW + 1 + `DWORD_SIZE + (`DWORD_SIZE*8) + `DCORE_TAG_WIDTH;
|
|
localparam RSP_DATAW = `NUM_THREADS + `NUM_THREADS * (`DWORD_SIZE*8) + `DCORE_TAG_WIDTH;
|
|
|
|
//
|
|
// handle requests
|
|
//
|
|
|
|
for (genvar i = 0; i < `NUM_THREADS; ++i) begin
|
|
|
|
wire cache_req_valid_out, cache_req_ready_out;
|
|
wire is_smem_addr_in, is_smem_addr_out;
|
|
|
|
// select shared memory bus
|
|
assign is_smem_addr_in = core_req_if.valid[i] && `SM_ENABLE
|
|
&& (core_req_if.addr[i][REQ_ADDRW-1:SMEM_ASHIFT-REQ_ASHIFT] >= (32-SMEM_ASHIFT)'((`SHARED_MEM_BASE_ADDR - `SMEM_SIZE) >> SMEM_ASHIFT))
|
|
&& (core_req_if.addr[i][REQ_ADDRW-1:SMEM_ASHIFT-REQ_ASHIFT] < (32-SMEM_ASHIFT)'(`SHARED_MEM_BASE_ADDR >> SMEM_ASHIFT));
|
|
|
|
VX_skid_buffer #(
|
|
.DATAW (REQ_DATAW)
|
|
) out_buffer (
|
|
.clk (clk),
|
|
.reset (reset),
|
|
.valid_in (core_req_if.valid[i]),
|
|
.data_in ({is_smem_addr_in, core_req_if.addr[i], core_req_if.rw[i], core_req_if.byteen[i], core_req_if.data[i], core_req_if.tag[i]}),
|
|
.ready_in (core_req_if.ready[i]),
|
|
.valid_out (cache_req_valid_out),
|
|
.data_out ({is_smem_addr_out, cache_req_if.addr[i], cache_req_if.rw[i], cache_req_if.byteen[i], cache_req_if.data[i], cache_req_if.tag[i]}),
|
|
.ready_out (cache_req_ready_out)
|
|
);
|
|
|
|
if (`SM_ENABLE ) begin
|
|
assign cache_req_if.valid[i] = cache_req_valid_out && ~is_smem_addr_out;
|
|
assign smem_req_if.valid[i] = cache_req_valid_out && is_smem_addr_out;
|
|
assign cache_req_ready_out = is_smem_addr_out ? smem_req_if.ready[i] : cache_req_if.ready[i];
|
|
|
|
assign smem_req_if.addr[i] = cache_req_if.addr[i];
|
|
assign smem_req_if.rw[i] = cache_req_if.rw[i];
|
|
assign smem_req_if.byteen[i] = cache_req_if.byteen[i];
|
|
assign smem_req_if.data[i] = cache_req_if.data[i];
|
|
assign smem_req_if.tag[i] = cache_req_if.tag[i];
|
|
end else begin
|
|
`UNUSED_VAR (is_smem_addr_out)
|
|
assign cache_req_if.valid[i] = cache_req_valid_out;
|
|
assign cache_req_ready_out = cache_req_if.ready[i];
|
|
end
|
|
end
|
|
|
|
//
|
|
// handle responses
|
|
//
|
|
|
|
if (`SM_ENABLE ) begin
|
|
|
|
wire [1:0][RSP_DATAW-1:0] rsp_data_in;
|
|
wire [1:0] rsp_valid_in;
|
|
wire [1:0] rsp_ready_in;
|
|
|
|
wire core_rsp_valid;
|
|
wire [`NUM_THREADS-1:0] core_rsp_valid_tmask;
|
|
|
|
assign rsp_data_in[0] = {cache_rsp_if.valid, cache_rsp_if.data, cache_rsp_if.tag};
|
|
assign rsp_data_in[1] = {smem_rsp_if.valid, smem_rsp_if.data, smem_rsp_if.tag};
|
|
|
|
assign rsp_valid_in[0] = (| cache_rsp_if.valid);
|
|
assign rsp_valid_in[1] = (| smem_rsp_if.valid) & `SM_ENABLE;
|
|
|
|
VX_stream_arbiter #(
|
|
.NUM_REQS (2),
|
|
.DATAW (RSP_DATAW),
|
|
.BUFFERED (0)
|
|
) rsp_arb (
|
|
.clk (clk),
|
|
.reset (reset),
|
|
.valid_in (rsp_valid_in),
|
|
.data_in (rsp_data_in),
|
|
.ready_in (rsp_ready_in),
|
|
.valid_out (core_rsp_valid),
|
|
.data_out ({core_rsp_valid_tmask, core_rsp_if.data, core_rsp_if.tag}),
|
|
.ready_out (core_rsp_if.ready)
|
|
);
|
|
|
|
assign cache_rsp_if.ready = rsp_ready_in[0];
|
|
assign smem_rsp_if.ready = rsp_ready_in[1];
|
|
|
|
assign core_rsp_if.valid = {`NUM_THREADS{core_rsp_valid}} & core_rsp_valid_tmask;
|
|
|
|
end else begin
|
|
|
|
assign core_rsp_if.valid = cache_rsp_if.valid;
|
|
assign core_rsp_if.tag = cache_rsp_if.tag;
|
|
assign core_rsp_if.data = cache_rsp_if.data;
|
|
assign cache_rsp_if.ready = core_rsp_if.ready;
|
|
|
|
end
|
|
|
|
endmodule |