minor update
This commit is contained in:
@@ -1,71 +0,0 @@
|
|||||||
`include "VX_define.vh"
|
|
||||||
|
|
||||||
module VX_csr_io_arb (
|
|
||||||
input wire clk,
|
|
||||||
input wire reset,
|
|
||||||
|
|
||||||
// bus select
|
|
||||||
input wire select_io_rsp,
|
|
||||||
|
|
||||||
// input requets
|
|
||||||
VX_csr_req_if csr_core_req_if,
|
|
||||||
VX_csr_io_req_if csr_io_req_if,
|
|
||||||
|
|
||||||
// output request
|
|
||||||
VX_csr_pipe_req_if csr_pipe_req_if,
|
|
||||||
|
|
||||||
// input response
|
|
||||||
VX_commit_if csr_pipe_rsp_if,
|
|
||||||
|
|
||||||
// outputs responses
|
|
||||||
VX_commit_if csr_commit_if,
|
|
||||||
VX_csr_io_rsp_if csr_io_rsp_if
|
|
||||||
);
|
|
||||||
`UNUSED_VAR (clk)
|
|
||||||
`UNUSED_VAR (reset)
|
|
||||||
|
|
||||||
wire [31:0] csr_core_req_data = csr_core_req_if.use_imm ? 32'(csr_core_req_if.rs1) : csr_core_req_if.rs1_data;
|
|
||||||
|
|
||||||
// requests
|
|
||||||
assign csr_pipe_req_if.valid = csr_core_req_if.valid || csr_io_req_if.valid;
|
|
||||||
assign csr_pipe_req_if.wid = csr_core_req_if.wid;
|
|
||||||
assign csr_pipe_req_if.tmask = csr_core_req_if.tmask;
|
|
||||||
assign csr_pipe_req_if.PC = csr_core_req_if.PC;
|
|
||||||
assign csr_pipe_req_if.op_type = csr_core_req_if.valid ? csr_core_req_if.op_type : (csr_io_req_if.rw ? `CSR_RW : `CSR_RS);
|
|
||||||
assign csr_pipe_req_if.addr = csr_core_req_if.valid ? csr_core_req_if.addr : csr_io_req_if.addr;
|
|
||||||
assign csr_pipe_req_if.data = csr_core_req_if.valid ? csr_core_req_data : (csr_io_req_if.rw ? csr_io_req_if.data : 32'b0);
|
|
||||||
assign csr_pipe_req_if.rd = csr_core_req_if.rd;
|
|
||||||
assign csr_pipe_req_if.wb = csr_core_req_if.wb;
|
|
||||||
assign csr_pipe_req_if.is_io = !csr_core_req_if.valid;
|
|
||||||
|
|
||||||
// core always takes priority over IO bus
|
|
||||||
assign csr_core_req_if.ready = csr_pipe_req_if.ready;
|
|
||||||
assign csr_io_req_if.ready = csr_pipe_req_if.ready && !csr_core_req_if.valid;
|
|
||||||
|
|
||||||
// responses
|
|
||||||
wire csr_io_rsp_ready;
|
|
||||||
VX_skid_buffer #(
|
|
||||||
.DATAW (32)
|
|
||||||
) csr_io_out_buffer (
|
|
||||||
.clk (clk),
|
|
||||||
.reset (reset),
|
|
||||||
.valid_in (csr_pipe_rsp_if.valid & select_io_rsp),
|
|
||||||
.data_in (csr_pipe_rsp_if.data[0]),
|
|
||||||
.ready_in (csr_io_rsp_ready),
|
|
||||||
.valid_out (csr_io_rsp_if.valid),
|
|
||||||
.data_out (csr_io_rsp_if.data),
|
|
||||||
.ready_out (csr_io_rsp_if.ready)
|
|
||||||
);
|
|
||||||
|
|
||||||
assign csr_commit_if.valid = csr_pipe_rsp_if.valid & ~select_io_rsp;
|
|
||||||
assign csr_commit_if.wid = csr_pipe_rsp_if.wid;
|
|
||||||
assign csr_commit_if.tmask = csr_pipe_rsp_if.tmask;
|
|
||||||
assign csr_commit_if.PC = csr_pipe_rsp_if.PC;
|
|
||||||
assign csr_commit_if.rd = csr_pipe_rsp_if.rd;
|
|
||||||
assign csr_commit_if.wb = csr_pipe_rsp_if.wb;
|
|
||||||
assign csr_commit_if.eop = csr_pipe_rsp_if.eop;
|
|
||||||
assign csr_commit_if.data = csr_pipe_rsp_if.data;
|
|
||||||
|
|
||||||
assign csr_pipe_rsp_if.ready = select_io_rsp ? csr_io_rsp_ready : csr_commit_if.ready;
|
|
||||||
|
|
||||||
endmodule
|
|
||||||
@@ -39,7 +39,7 @@ module VX_instr_demux (
|
|||||||
|
|
||||||
VX_skid_buffer #(
|
VX_skid_buffer #(
|
||||||
.DATAW (`NW_BITS + `NUM_THREADS + 32 + 32 + `ALU_BITS + `MOD_BITS + 32 + 1 + 1 + `NR_BITS + 1 + `NT_BITS + (2 * `NUM_THREADS * 32)),
|
.DATAW (`NW_BITS + `NUM_THREADS + 32 + 32 + `ALU_BITS + `MOD_BITS + 32 + 1 + 1 + `NR_BITS + 1 + `NT_BITS + (2 * `NUM_THREADS * 32)),
|
||||||
.BUFFERED (1)
|
.USE_FASTREG (1)
|
||||||
) alu_buffer (
|
) alu_buffer (
|
||||||
.clk (clk),
|
.clk (clk),
|
||||||
.reset (reset),
|
.reset (reset),
|
||||||
@@ -57,7 +57,7 @@ module VX_instr_demux (
|
|||||||
|
|
||||||
VX_skid_buffer #(
|
VX_skid_buffer #(
|
||||||
.DATAW (`NW_BITS + `NUM_THREADS + 32 + `LSU_BITS + 32 + `NR_BITS + 1 + (2 * `NUM_THREADS * 32)),
|
.DATAW (`NW_BITS + `NUM_THREADS + 32 + `LSU_BITS + 32 + `NR_BITS + 1 + (2 * `NUM_THREADS * 32)),
|
||||||
.BUFFERED (1)
|
.USE_FASTREG (1)
|
||||||
) lsu_buffer (
|
) lsu_buffer (
|
||||||
.clk (clk),
|
.clk (clk),
|
||||||
.reset (reset),
|
.reset (reset),
|
||||||
@@ -75,7 +75,7 @@ module VX_instr_demux (
|
|||||||
|
|
||||||
VX_skid_buffer #(
|
VX_skid_buffer #(
|
||||||
.DATAW (`NW_BITS + `NUM_THREADS + 32 + `CSR_BITS + `CSR_ADDR_BITS + `NR_BITS + 1 + 1 + `NR_BITS + 32),
|
.DATAW (`NW_BITS + `NUM_THREADS + 32 + `CSR_BITS + `CSR_ADDR_BITS + `NR_BITS + 1 + 1 + `NR_BITS + 32),
|
||||||
.BUFFERED (1)
|
.USE_FASTREG (1)
|
||||||
) csr_buffer (
|
) csr_buffer (
|
||||||
.clk (clk),
|
.clk (clk),
|
||||||
.reset (reset),
|
.reset (reset),
|
||||||
@@ -94,7 +94,7 @@ module VX_instr_demux (
|
|||||||
|
|
||||||
VX_skid_buffer #(
|
VX_skid_buffer #(
|
||||||
.DATAW (`NW_BITS + `NUM_THREADS + 32 + `FPU_BITS + `MOD_BITS + `NR_BITS + 1 + (3 * `NUM_THREADS * 32)),
|
.DATAW (`NW_BITS + `NUM_THREADS + 32 + `FPU_BITS + `MOD_BITS + `NR_BITS + 1 + (3 * `NUM_THREADS * 32)),
|
||||||
.BUFFERED (1)
|
.USE_FASTREG (1)
|
||||||
) fpu_buffer (
|
) fpu_buffer (
|
||||||
.clk (clk),
|
.clk (clk),
|
||||||
.reset (reset),
|
.reset (reset),
|
||||||
@@ -116,7 +116,7 @@ module VX_instr_demux (
|
|||||||
|
|
||||||
VX_skid_buffer #(
|
VX_skid_buffer #(
|
||||||
.DATAW (`NW_BITS + `NUM_THREADS + 32 + 32 + `GPU_BITS + `NR_BITS + 1 + (`NUM_THREADS * 32 + 32)),
|
.DATAW (`NW_BITS + `NUM_THREADS + 32 + 32 + `GPU_BITS + `NR_BITS + 1 + (`NUM_THREADS * 32 + 32)),
|
||||||
.BUFFERED (1)
|
.USE_FASTREG (1)
|
||||||
) gpu_buffer (
|
) gpu_buffer (
|
||||||
.clk (clk),
|
.clk (clk),
|
||||||
.reset (reset),
|
.reset (reset),
|
||||||
|
|||||||
@@ -256,26 +256,19 @@ module VX_mem_unit # (
|
|||||||
);
|
);
|
||||||
end else begin
|
end else begin
|
||||||
// core to D-cache request
|
// core to D-cache request
|
||||||
for (genvar i = 0; i < `DNUM_REQS; ++i) begin
|
assign dcache_req_if.valid = dcache_core_req_if.valid;
|
||||||
VX_skid_buffer #(
|
assign dcache_req_if.addr = dcache_core_req_if.addr;
|
||||||
.DATAW (`DCORE_ADDR_WIDTH + 1 + `DWORD_SIZE + (`DWORD_SIZE*8) + `DCORE_TAG_WIDTH)
|
assign dcache_req_if.rw = dcache_core_req_if.rw;
|
||||||
) core_req_buf (
|
assign dcache_req_if.byteen = dcache_core_req_if.byteen;
|
||||||
.clk (clk),
|
assign dcache_req_if.data = dcache_core_req_if.data;
|
||||||
.reset (reset),
|
assign dcache_req_if.tag = dcache_core_req_if.tag;
|
||||||
.valid_in (dcache_core_req_if.valid[i]),
|
assign dcache_core_req_if.ready = dcache_req_if.ready;
|
||||||
.data_in ({dcache_core_req_if.addr[i], dcache_core_req_if.rw[i], dcache_core_req_if.byteen[i], dcache_core_req_if.data[i], dcache_core_req_if.tag[i]}),
|
|
||||||
.ready_in (dcache_core_req_if.ready[i]),
|
|
||||||
.valid_out (dcache_req_if.valid[i]),
|
|
||||||
.data_out ({dcache_req_if.addr[i], dcache_req_if.rw[i], dcache_req_if.byteen[i], dcache_req_if.data[i], dcache_req_if.tag[i]}),
|
|
||||||
.ready_out (dcache_req_if.ready[i])
|
|
||||||
);
|
|
||||||
end
|
|
||||||
|
|
||||||
// D-cache to core reponse
|
// D-cache to core reponse
|
||||||
assign dcache_core_rsp_if.valid = dcache_rsp_if.valid;
|
assign dcache_core_rsp_if.valid = dcache_rsp_if.valid;
|
||||||
assign dcache_core_rsp_if.tag = dcache_rsp_if.tag;
|
assign dcache_core_rsp_if.tag = dcache_rsp_if.tag;
|
||||||
assign dcache_core_rsp_if.data = dcache_rsp_if.data;
|
assign dcache_core_rsp_if.data = dcache_rsp_if.data;
|
||||||
assign dcache_rsp_if.ready = dcache_core_rsp_if.ready;
|
assign dcache_rsp_if.ready = dcache_core_rsp_if.ready;
|
||||||
end
|
end
|
||||||
|
|
||||||
wire [`DMEM_TAG_WIDTH-1:0] icache_mem_req_tag = `DMEM_TAG_WIDTH'(icache_mem_req_if.tag);
|
wire [`DMEM_TAG_WIDTH-1:0] icache_mem_req_tag = `DMEM_TAG_WIDTH'(icache_mem_req_if.tag);
|
||||||
@@ -289,7 +282,7 @@ module VX_mem_unit # (
|
|||||||
.ADDR_WIDTH (`DMEM_ADDR_WIDTH),
|
.ADDR_WIDTH (`DMEM_ADDR_WIDTH),
|
||||||
.TAG_IN_WIDTH (`DMEM_TAG_WIDTH),
|
.TAG_IN_WIDTH (`DMEM_TAG_WIDTH),
|
||||||
.BUFFERED_REQ (1),
|
.BUFFERED_REQ (1),
|
||||||
.BUFFERED_RSP (0)
|
.BUFFERED_RSP (1)
|
||||||
) mem_arb (
|
) mem_arb (
|
||||||
.clk (clk),
|
.clk (clk),
|
||||||
.reset (reset),
|
.reset (reset),
|
||||||
|
|||||||
2
hw/rtl/cache/VX_bank.v
vendored
2
hw/rtl/cache/VX_bank.v
vendored
@@ -476,7 +476,7 @@ module VX_bank #(
|
|||||||
|
|
||||||
VX_skid_buffer #(
|
VX_skid_buffer #(
|
||||||
.DATAW (CORE_TAG_WIDTH + (1 + `WORD_WIDTH + `REQS_BITS) * NUM_PORTS),
|
.DATAW (CORE_TAG_WIDTH + (1 + `WORD_WIDTH + `REQS_BITS) * NUM_PORTS),
|
||||||
.BUFFERED (NUM_BANKS == 1)
|
.USE_FASTREG (NUM_BANKS == 1)
|
||||||
) core_rsp_req (
|
) core_rsp_req (
|
||||||
.clk (clk),
|
.clk (clk),
|
||||||
.reset (reset),
|
.reset (reset),
|
||||||
|
|||||||
4
hw/rtl/cache/VX_cache_core_rsp_merge.v
vendored
4
hw/rtl/cache/VX_cache_core_rsp_merge.v
vendored
@@ -107,7 +107,7 @@ module VX_cache_core_rsp_merge #(
|
|||||||
|
|
||||||
VX_skid_buffer #(
|
VX_skid_buffer #(
|
||||||
.DATAW (NUM_REQS + CORE_TAG_WIDTH + (NUM_REQS *`WORD_WIDTH)),
|
.DATAW (NUM_REQS + CORE_TAG_WIDTH + (NUM_REQS *`WORD_WIDTH)),
|
||||||
.BUFFERED (1)
|
.USE_FASTREG (1)
|
||||||
) pipe_reg (
|
) pipe_reg (
|
||||||
.clk (clk),
|
.clk (clk),
|
||||||
.reset (reset),
|
.reset (reset),
|
||||||
@@ -156,7 +156,7 @@ module VX_cache_core_rsp_merge #(
|
|||||||
for (genvar i = 0; i < NUM_REQS; i++) begin
|
for (genvar i = 0; i < NUM_REQS; i++) begin
|
||||||
VX_skid_buffer #(
|
VX_skid_buffer #(
|
||||||
.DATAW (CORE_TAG_WIDTH + `WORD_WIDTH),
|
.DATAW (CORE_TAG_WIDTH + `WORD_WIDTH),
|
||||||
.BUFFERED (1)
|
.USE_FASTREG (1)
|
||||||
) pipe_reg (
|
) pipe_reg (
|
||||||
.clk (clk),
|
.clk (clk),
|
||||||
.reset (reset),
|
.reset (reset),
|
||||||
|
|||||||
@@ -4,7 +4,7 @@ module VX_skid_buffer #(
|
|||||||
parameter DATAW = 1,
|
parameter DATAW = 1,
|
||||||
parameter PASSTHRU = 0,
|
parameter PASSTHRU = 0,
|
||||||
parameter NOBACKPRESSURE = 0,
|
parameter NOBACKPRESSURE = 0,
|
||||||
parameter BUFFERED = 0
|
parameter USE_FASTREG = 0
|
||||||
) (
|
) (
|
||||||
input wire clk,
|
input wire clk,
|
||||||
input wire reset,
|
input wire reset,
|
||||||
@@ -50,7 +50,7 @@ module VX_skid_buffer #(
|
|||||||
|
|
||||||
end else begin
|
end else begin
|
||||||
|
|
||||||
if (BUFFERED) begin
|
if (USE_FASTREG) begin
|
||||||
|
|
||||||
reg [DATAW-1:0] data_out_r;
|
reg [DATAW-1:0] data_out_r;
|
||||||
reg [DATAW-1:0] buffer;
|
reg [DATAW-1:0] buffer;
|
||||||
|
|||||||
@@ -76,16 +76,16 @@ $(FPGA_BUILD_DIR)_4c/build/dcp.qpf:
|
|||||||
afu_synth_setup -s setup.cfg $(FPGA_BUILD_DIR)_4c
|
afu_synth_setup -s setup.cfg $(FPGA_BUILD_DIR)_4c
|
||||||
|
|
||||||
$(FPGA_BUILD_DIR)_8c/build/dcp.qpf:
|
$(FPGA_BUILD_DIR)_8c/build/dcp.qpf:
|
||||||
afu_synth_setup -s setup.cfg $(FPGA_BUILD_DIR)_8c
|
afu_synth_setup -s setup8.cfg $(FPGA_BUILD_DIR)_8c
|
||||||
|
|
||||||
$(FPGA_BUILD_DIR)_16c/build/dcp.qpf:
|
$(FPGA_BUILD_DIR)_16c/build/dcp.qpf:
|
||||||
afu_synth_setup -s setup.cfg $(FPGA_BUILD_DIR)_16c
|
afu_synth_setup -s setup16.cfg $(FPGA_BUILD_DIR)_16c
|
||||||
|
|
||||||
$(FPGA_BUILD_DIR)_32c/build/dcp.qpf:
|
$(FPGA_BUILD_DIR)_32c/build/dcp.qpf:
|
||||||
afu_synth_setup -s setup.cfg $(FPGA_BUILD_DIR)_32c
|
afu_synth_setup -s setup16.cfg $(FPGA_BUILD_DIR)_32c
|
||||||
|
|
||||||
$(FPGA_BUILD_DIR)_64c/build/dcp.qpf:
|
$(FPGA_BUILD_DIR)_64c/build/dcp.qpf:
|
||||||
afu_synth_setup -s setup.cfg $(FPGA_BUILD_DIR)_64c
|
afu_synth_setup -s setup16.cfg $(FPGA_BUILD_DIR)_64c
|
||||||
|
|
||||||
gen-sources-1c:
|
gen-sources-1c:
|
||||||
./gen_sources.sh $(CFLAGS) $(CONFIG1) > sources.txt
|
./gen_sources.sh $(CFLAGS) $(CONFIG1) > sources.txt
|
||||||
|
|||||||
7
hw/syn/opae/setup16.cfg
Normal file
7
hw/syn/opae/setup16.cfg
Normal file
@@ -0,0 +1,7 @@
|
|||||||
|
+define+SYNTHESIS
|
||||||
|
+define+QUARTUS
|
||||||
|
|
||||||
|
vortex_afu16.json
|
||||||
|
QI:vortex_afu.qsf
|
||||||
|
|
||||||
|
C:sources.txt
|
||||||
7
hw/syn/opae/setup8.cfg
Normal file
7
hw/syn/opae/setup8.cfg
Normal file
@@ -0,0 +1,7 @@
|
|||||||
|
+define+SYNTHESIS
|
||||||
|
+define+QUARTUS
|
||||||
|
|
||||||
|
vortex_afu8.json
|
||||||
|
QI:vortex_afu.qsf
|
||||||
|
|
||||||
|
C:sources.txt
|
||||||
@@ -18,10 +18,7 @@
|
|||||||
"mmio-status": 18,
|
"mmio-status": 18,
|
||||||
"mmio-scope-read": 20,
|
"mmio-scope-read": 20,
|
||||||
"mmio-scope-write": 22,
|
"mmio-scope-write": 22,
|
||||||
"mmio-csr-core": 24,
|
"mmio-dev-caps": 24,
|
||||||
"mmio-csr-addr": 26,
|
|
||||||
"mmio-csr-data": 28,
|
|
||||||
"mmio-csr-read": 30,
|
|
||||||
|
|
||||||
"afu-top-interface":
|
"afu-top-interface":
|
||||||
{
|
{
|
||||||
|
|||||||
@@ -18,10 +18,7 @@
|
|||||||
"mmio-status": 18,
|
"mmio-status": 18,
|
||||||
"mmio-scope-read": 20,
|
"mmio-scope-read": 20,
|
||||||
"mmio-scope-write": 22,
|
"mmio-scope-write": 22,
|
||||||
"mmio-csr-core": 24,
|
"mmio-dev-caps": 24,
|
||||||
"mmio-csr-addr": 26,
|
|
||||||
"mmio-csr-data": 28,
|
|
||||||
"mmio-csr-read": 30,
|
|
||||||
|
|
||||||
"afu-top-interface":
|
"afu-top-interface":
|
||||||
{
|
{
|
||||||
|
|||||||
Reference in New Issue
Block a user