-
Notifications
You must be signed in to change notification settings - Fork 708
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
[RVV] CVA6 re-parametrization and MMU interface #2652
base: master
Are you sure you want to change the base?
Conversation
core/acc_dispatcher.sv
Outdated
parameter type acc_resp_t = logic, | ||
parameter type accelerator_req_t = logic, | ||
parameter type accelerator_resp_t = logic, | ||
parameter type acc_mmu_req_t = logic, |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
[verible-verilog-format] reported by reviewdog 🐶
parameter type acc_mmu_req_t = logic, | |
parameter type acc_mmu_req_t = logic, |
core/acc_dispatcher.sv
Outdated
logic acc_req_valid; | ||
logic acc_req_ready; |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
[verible-verilog-format] reported by reviewdog 🐶
logic acc_req_valid; | |
logic acc_req_ready; | |
logic acc_req_valid; | |
logic acc_req_ready; |
core/acc_dispatcher.sv
Outdated
.clk_i (clk_i), | ||
.rst_ni (rst_ni), | ||
.clr_i (1'b0), | ||
.testmode_i(1'b0), | ||
.data_i (acc_req), | ||
.valid_i (acc_req_valid), | ||
.ready_o (acc_req_ready), | ||
.data_o (acc_req_int), | ||
.valid_o (acc_req_o.req_valid), | ||
.ready_i (acc_resp_i.req_ready) | ||
.valid_o (acc_req_o.acc_req.req_valid), | ||
.ready_i (acc_resp_i.acc_resp.req_ready) |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
[verible-verilog-format] reported by reviewdog 🐶
.clk_i (clk_i), | |
.rst_ni (rst_ni), | |
.clr_i (1'b0), | |
.testmode_i(1'b0), | |
.data_i (acc_req), | |
.valid_i (acc_req_valid), | |
.ready_o (acc_req_ready), | |
.data_o (acc_req_int), | |
.valid_o (acc_req_o.req_valid), | |
.ready_i (acc_resp_i.req_ready) | |
.valid_o (acc_req_o.acc_req.req_valid), | |
.ready_i (acc_resp_i.acc_resp.req_ready) | |
.clk_i (clk_i), | |
.rst_ni (rst_ni), | |
.data_i (acc_req), | |
.valid_i(acc_req_valid), | |
.ready_o(acc_req_ready), | |
.data_o (acc_req_int), | |
.valid_o(acc_req_o.acc_req.req_valid), | |
.ready_i(acc_resp_i.acc_resp.req_ready) |
core/acc_dispatcher.sv
Outdated
assign acc_req_o.acc_mmu_resp = acc_mmu_resp_i; | ||
assign acc_req_o.acc_mmu_en = acc_mmu_en_i; |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
[verible-verilog-format] reported by reviewdog 🐶
assign acc_req_o.acc_mmu_resp = acc_mmu_resp_i; | |
assign acc_req_o.acc_mmu_en = acc_mmu_en_i; | |
assign acc_req_o.acc_mmu_resp = acc_mmu_resp_i; | |
assign acc_req_o.acc_mmu_en = acc_mmu_en_i; |
core/acc_dispatcher.sv
Outdated
assign acc_trans_id_o = acc_resp_i.acc_resp.trans_id; | ||
assign acc_result_o = acc_resp_i.acc_resp.result; | ||
assign acc_valid_o = acc_resp_i.acc_resp.resp_valid; | ||
assign acc_exception_o = acc_resp_i.acc_resp.exception; |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
[verible-verilog-format] reported by reviewdog 🐶
assign acc_trans_id_o = acc_resp_i.acc_resp.trans_id; | |
assign acc_result_o = acc_resp_i.acc_resp.result; | |
assign acc_valid_o = acc_resp_i.acc_resp.resp_valid; | |
assign acc_exception_o = acc_resp_i.acc_resp.exception; | |
assign acc_trans_id_o = acc_resp_i.acc_resp.trans_id; | |
assign acc_result_o = acc_resp_i.acc_resp.result; | |
assign acc_valid_o = acc_resp_i.acc_resp.resp_valid; | |
assign acc_exception_o = acc_resp_i.acc_resp.exception; |
core/load_store_unit.sv
Outdated
end | ||
end | ||
end | ||
|
||
if (CVA6Cfg.EnableAccelerator) begin | ||
// The MMU can be connected to CVA6 or the ACCELERATOR | ||
enum logic {CVA6, ACC} mmu_state_d, mmu_state_q; |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
[verible-verilog-format] reported by reviewdog 🐶
enum logic {CVA6, ACC} mmu_state_d, mmu_state_q; | |
enum logic { | |
CVA6, | |
ACC | |
} | |
mmu_state_d, mmu_state_q; |
core/load_store_unit.sv
Outdated
// This logic can be optimized to reduce answer latency and contention | ||
always_comb begin | ||
// Maintain state | ||
mmu_state_d = mmu_state_q; |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
[verible-verilog-format] reported by reviewdog 🐶
mmu_state_d = mmu_state_q; | |
mmu_state_d = mmu_state_q; |
core/load_store_unit.sv
Outdated
assign cva6_dtlb_hit = dtlb_hit; | ||
assign cva6_dtlb_ppn = dtlb_ppn; | ||
// No accelerator | ||
assign acc_mmu_resp_o = '0; |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
[verible-verilog-format] reported by reviewdog 🐶
assign acc_mmu_resp_o = '0; | |
assign acc_mmu_resp_o = '0; |
core/load_store_unit.sv
Outdated
// No accelerator | ||
assign acc_mmu_resp_o = '0; | ||
// Feed forward the lsu_ctrl bypass | ||
assign lsu_ctrl = lsu_ctrl_byp; |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
[verible-verilog-format] reported by reviewdog 🐶
assign lsu_ctrl = lsu_ctrl_byp; | |
assign lsu_ctrl = lsu_ctrl_byp; |
core/load_store_unit.sv
Outdated
ld_valid_i = 1'b0; | ||
st_valid_i = 1'b0; |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
[verible-verilog-format] reported by reviewdog 🐶
ld_valid_i = 1'b0; | |
st_valid_i = 1'b0; | |
ld_valid_i = 1'b0; | |
st_valid_i = 1'b0; |
❌ failed run, report available here. |
Hello @mp-17 To solve the Verible format issues, you can execute the Verible command from https://github.com/openhwgroup/cva6/blob/master/CONTRIBUTING.md |
Hello @JeanRochCoulon, thanks, I will! The PR is still work in progress, I put it here as a placeholder. I will rework it today and ping you when it's ready. Don't spend time on the diff now, it's full of unrelated stuff :-) |
core/acc_dispatcher.sv
Outdated
assign acc_ld_disp = acc_req_valid && (acc_insn_queue_o.operation == ACCEL_OP_LOAD); | ||
assign acc_st_disp = acc_req_valid && (acc_insn_queue_o.operation == ACCEL_OP_STORE); |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
[verible-verilog-format] reported by reviewdog 🐶
assign acc_ld_disp = acc_req_valid && (acc_insn_queue_o.operation == ACCEL_OP_LOAD); | |
assign acc_st_disp = acc_req_valid && (acc_insn_queue_o.operation == ACCEL_OP_STORE); | |
assign acc_ld_disp = acc_req_valid && (acc_insn_queue_o.operation == ACCEL_OP_LOAD); | |
assign acc_st_disp = acc_req_valid && (acc_insn_queue_o.operation == ACCEL_OP_STORE); |
core/load_store_unit.sv
Outdated
logic [ 31:0] mmu_tinst; | ||
logic mmu_hs_ld_st_inst; | ||
logic mmu_hlvx_inst; | ||
exception_t mmu_exception, cva6_mmu_exception, acc_mmu_exception; | ||
exception_t pmp_exception; | ||
icache_areq_t pmp_icache_areq_i; | ||
logic pmp_translation_valid; | ||
logic dtlb_hit, cva6_dtlb_hit, acc_dtlb_hit; | ||
logic [ CVA6Cfg.PPNW-1:0] dtlb_ppn, cva6_dtlb_ppn, acc_dtlb_ppn; | ||
|
||
logic ld_valid; | ||
logic [CVA6Cfg.TRANS_ID_BITS-1:0] ld_trans_id; | ||
logic [ CVA6Cfg.XLEN-1:0] ld_result; | ||
logic st_valid; | ||
logic [CVA6Cfg.TRANS_ID_BITS-1:0] st_trans_id; | ||
logic [ CVA6Cfg.XLEN-1:0] st_result; | ||
|
||
logic [ 11:0] page_offset; | ||
logic page_offset_matches; | ||
|
||
exception_t misaligned_exception, cva6_misaligned_exception, acc_misaligned_exception; | ||
exception_t ld_ex; | ||
exception_t st_ex; | ||
|
||
logic hs_ld_st_inst; | ||
logic hlvx_inst; |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
[verible-verilog-format] reported by reviewdog 🐶
logic [ 31:0] mmu_tinst; | |
logic mmu_hs_ld_st_inst; | |
logic mmu_hlvx_inst; | |
exception_t mmu_exception, cva6_mmu_exception, acc_mmu_exception; | |
exception_t pmp_exception; | |
icache_areq_t pmp_icache_areq_i; | |
logic pmp_translation_valid; | |
logic dtlb_hit, cva6_dtlb_hit, acc_dtlb_hit; | |
logic [ CVA6Cfg.PPNW-1:0] dtlb_ppn, cva6_dtlb_ppn, acc_dtlb_ppn; | |
logic ld_valid; | |
logic [CVA6Cfg.TRANS_ID_BITS-1:0] ld_trans_id; | |
logic [ CVA6Cfg.XLEN-1:0] ld_result; | |
logic st_valid; | |
logic [CVA6Cfg.TRANS_ID_BITS-1:0] st_trans_id; | |
logic [ CVA6Cfg.XLEN-1:0] st_result; | |
logic [ 11:0] page_offset; | |
logic page_offset_matches; | |
exception_t misaligned_exception, cva6_misaligned_exception, acc_misaligned_exception; | |
exception_t ld_ex; | |
exception_t st_ex; | |
logic hs_ld_st_inst; | |
logic hlvx_inst; | |
logic [31:0] mmu_tinst; | |
logic mmu_hs_ld_st_inst; | |
logic mmu_hlvx_inst; | |
exception_t mmu_exception, cva6_mmu_exception, acc_mmu_exception; | |
exception_t pmp_exception; | |
icache_areq_t pmp_icache_areq_i; | |
logic pmp_translation_valid; | |
logic dtlb_hit, cva6_dtlb_hit, acc_dtlb_hit; | |
logic [CVA6Cfg.PPNW-1:0] dtlb_ppn, cva6_dtlb_ppn, acc_dtlb_ppn; | |
logic ld_valid; | |
logic [CVA6Cfg.TRANS_ID_BITS-1:0] ld_trans_id; | |
logic [ CVA6Cfg.XLEN-1:0] ld_result; | |
logic st_valid; | |
logic [CVA6Cfg.TRANS_ID_BITS-1:0] st_trans_id; | |
logic [ CVA6Cfg.XLEN-1:0] st_result; | |
logic [ 11:0] page_offset; | |
logic page_offset_matches; | |
exception_t misaligned_exception, cva6_misaligned_exception, acc_misaligned_exception; | |
exception_t ld_ex; | |
exception_t st_ex; | |
logic hs_ld_st_inst; | |
logic hlvx_inst; |
❌ failed run, report available here. |
function automatic logic [CVA6Cfg.PLEN-1:0] paddrSizeAlign( | ||
input logic [CVA6Cfg.PLEN-1:0] paddr, input logic [2:0] size); |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
[verible-verilog-format] reported by reviewdog 🐶
function automatic logic [CVA6Cfg.PLEN-1:0] paddrSizeAlign( | |
input logic [CVA6Cfg.PLEN-1:0] paddr, input logic [2:0] size); | |
function automatic logic [CVA6Cfg.PLEN-1:0] paddrSizeAlign(input logic [CVA6Cfg.PLEN-1:0] paddr, | |
input logic [2:0] size); |
input logic [CVA6Cfg.XLEN-1:0] data, | ||
input logic [CVA6Cfg.XLEN_ALIGN_BYTES-1:0] offset, input logic [1:0] size); |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
[verible-verilog-format] reported by reviewdog 🐶
input logic [CVA6Cfg.XLEN-1:0] data, | |
input logic [CVA6Cfg.XLEN_ALIGN_BYTES-1:0] offset, input logic [1:0] size); | |
input logic [CVA6Cfg.XLEN-1:0] data, input logic [CVA6Cfg.XLEN_ALIGN_BYTES-1:0] offset, | |
input logic [1:0] size); |
input logic [CVA6Cfg.XLEN-1:0] data, | ||
input logic [CVA6Cfg.XLEN_ALIGN_BYTES-1:0] offset, input logic [1:0] size); |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
[verible-verilog-format] reported by reviewdog 🐶
input logic [CVA6Cfg.XLEN-1:0] data, | |
input logic [CVA6Cfg.XLEN_ALIGN_BYTES-1:0] offset, input logic [1:0] size); | |
input logic [CVA6Cfg.XLEN-1:0] data, input logic [CVA6Cfg.XLEN_ALIGN_BYTES-1:0] offset, | |
input logic [1:0] size); |
core/cva6_mmu/cva6_shared_tlb.sv
Outdated
logic [CVA6Cfg.SharedTlbDepth-1:0][SHARED_TLB_WAYS-1:0] | ||
shared_tag_valid_q, shared_tag_valid_d; |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
[verible-verilog-format] reported by reviewdog 🐶
logic [CVA6Cfg.SharedTlbDepth-1:0][SHARED_TLB_WAYS-1:0] | |
shared_tag_valid_q, shared_tag_valid_d; | |
logic [CVA6Cfg.SharedTlbDepth-1:0][SHARED_TLB_WAYS-1:0] shared_tag_valid_q, shared_tag_valid_d; |
core/cva6_mmu/cva6_shared_tlb.sv
Outdated
logic [CVA6Cfg.PtLevels+HYP_EXT-1:0][(CVA6Cfg.VpnLen/CVA6Cfg.PtLevels)-1:0] | ||
vpn_d, vpn_q; |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
[verible-verilog-format] reported by reviewdog 🐶
logic [CVA6Cfg.PtLevels+HYP_EXT-1:0][(CVA6Cfg.VpnLen/CVA6Cfg.PtLevels)-1:0] | |
vpn_d, vpn_q; | |
logic [CVA6Cfg.PtLevels+HYP_EXT-1:0][(CVA6Cfg.VpnLen/CVA6Cfg.PtLevels)-1:0] vpn_d, vpn_q; |
core/frontend/frontend.sv
Outdated
logic [CVA6Cfg.INSTR_PER_FETCH-1:0] | ||
rvc_branch, rvc_jump, rvc_jr, rvc_return, rvc_jalr, rvc_call; |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
[verible-verilog-format] reported by reviewdog 🐶
logic [CVA6Cfg.INSTR_PER_FETCH-1:0] | |
rvc_branch, rvc_jump, rvc_jr, rvc_return, rvc_jalr, rvc_call; | |
logic [CVA6Cfg.INSTR_PER_FETCH-1:0] rvc_branch, rvc_jump, rvc_jr, rvc_return, rvc_jalr, rvc_call; |
core/pmp/tb/tb_pkg.sv
Outdated
static function logic [PMP_LEN-1:0] base_to_conf(logic [WIDTH-1:0] base, | ||
int unsigned size_i); |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
[verible-verilog-format] reported by reviewdog 🐶
static function logic [PMP_LEN-1:0] base_to_conf(logic [WIDTH-1:0] base, | |
int unsigned size_i); | |
static function logic [PMP_LEN-1:0] base_to_conf(logic [WIDTH-1:0] base, int unsigned size_i); |
core/scoreboard.sv
Outdated
logic [CVA6Cfg.NrCommitPorts-1:0][CVA6Cfg.TRANS_ID_BITS-1:0] | ||
commit_pointer_n, commit_pointer_q; |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
[verible-verilog-format] reported by reviewdog 🐶
logic [CVA6Cfg.NrCommitPorts-1:0][CVA6Cfg.TRANS_ID_BITS-1:0] | |
commit_pointer_n, commit_pointer_q; | |
logic [CVA6Cfg.NrCommitPorts-1:0][CVA6Cfg.TRANS_ID_BITS-1:0] commit_pointer_n, commit_pointer_q; |
Hi @JeanRochCoulon, I cleaned up the code diff so that we can start discussing how to integrate the interface and re-parametrization modifications. I have added additional localparams (such as |
❌ failed run, report available here. |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
It seems that you add fields to cva6_user_cfg_t
not because you need to assign specific values to them, but because you want to access them in your configuration package.
This will impact all configurations and imply repetition.
Instead, you could call build_config
once to be able to have access to the calculated values.
localparam cfg = build_config(cva6_cfg);
However, this would prevent from creating heterogeneous designs.
If you have one top-level module above cva6
, I advise you to not add types into cv64a6_imafdcv_sv39_config_pkg
. Instead, you can add them as localparam
right into your top-level module and propagate them to cva6 and other modules.
To access to all calculated values, first add at the beginning of your top-level module:
parameter config_pkg::cva6_cfg_t CVA6Cfg = build_config_pkg::build_config(
cva6_config_pkg::cva6_cfg
),
This is how it is done in cva6.sv
.
Also, when you instantiate CVA6, you can add cva6 #(.CVA6Cfg(CVA6Cfg))
parameter to re-use the configuration that you already calculated instead of implicitly calling build_config
again to build the default value. This is what allows heterogeneous designs.
If you need several top level modules, we have another solution that we use for RVFI, just ask me if you need it.
PS: These modifications seem related to accelerator port, what about using CV-X-IF instead?
Hello @cathales, Thanks for the reply!
|
core/cva6_mmu/cva6_mmu.sv
Outdated
@@ -100,8 +100,8 @@ module cva6_mmu | |||
|
|||
// PMP | |||
|
|||
input riscv::pmpcfg_t [CVA6Cfg.NrPMPEntries-1:0] pmpcfg_i, | |||
input logic [CVA6Cfg.NrPMPEntries-1:0][CVA6Cfg.PLEN-3:0] pmpaddr_i | |||
input riscv::pmpcfg_t [(CVA6Cfg.NrPMPEntries > 0 ? CVA6Cfg.NrPMPEntries-1 : 0):0] pmpcfg_i, |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
[verible-verilog-format] reported by reviewdog 🐶
input riscv::pmpcfg_t [(CVA6Cfg.NrPMPEntries > 0 ? CVA6Cfg.NrPMPEntries-1 : 0):0] pmpcfg_i, | |
input riscv::pmpcfg_t [(CVA6Cfg.NrPMPEntries > 0 ? CVA6Cfg.NrPMPEntries-1 : 0):0] pmpcfg_i, |
core/load_store_unit.sv
Outdated
@@ -148,9 +154,9 @@ module load_store_unit | |||
input amo_resp_t amo_resp_i, | |||
|
|||
// PMP configuration - CSR_REGFILE | |||
input riscv::pmpcfg_t [CVA6Cfg.NrPMPEntries-1:0] pmpcfg_i, | |||
input riscv::pmpcfg_t [(CVA6Cfg.NrPMPEntries > 0 ? CVA6Cfg.NrPMPEntries-1 : 0):0] pmpcfg_i, |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
[verible-verilog-format] reported by reviewdog 🐶
input riscv::pmpcfg_t [(CVA6Cfg.NrPMPEntries > 0 ? CVA6Cfg.NrPMPEntries-1 : 0):0] pmpcfg_i, | |
input riscv::pmpcfg_t [(CVA6Cfg.NrPMPEntries > 0 ? CVA6Cfg.NrPMPEntries-1 : 0):0] pmpcfg_i, |
Hi @cathales, I have implemented the requested modifications. As now listed in the PR description, I needed to make further collateral modifications and fixes to compile the code with my settings. Let me know if you prefer I split this PR into a main and a collateral PR. Also, please let me know if the interfaces are now okay or if I need to implement other modifications. |
✔️ successful run, report available here. |
1 similar comment
✔️ successful run, report available here. |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
LGTM for the interfaces and parametrization.
@yanicasa can you please review the changes in core/load_store_unit.sv
?
core/pmp/src/pmp.sv
Outdated
input logic [NR_ENTRIES-1:0][PMP_LEN-1:0] conf_addr_i, | ||
input riscv::pmpcfg_t [NR_ENTRIES-1:0] conf_i, | ||
input logic [(NR_ENTRIES > 0 ? NR_ENTRIES-1 : 0):0][PMP_LEN-1:0] conf_addr_i, | ||
input riscv::pmpcfg_t [(NR_ENTRIES > 0 ? NR_ENTRIES-1 : 0):0] conf_i, |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
You repeat this, or equivalently CVA6Cfg.NrPMPEntries > 0 ? CVA6Cfg.NrPMPEntries-1 : 0
, many times.
You could add this to the configuration built with build_config
to be more DRY
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Sure! I originally stuck to what I found in the csr_regfile module not to introduce additional style modifications. I will change that, too.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Actually I am not 100% sold on the definition of an abstract quantity in the build_config
.
Maybe a avoid_neg()
function is cleaner?
Something like:
Pseudocode
// Defined in a package
function avoid_neg(a)
return (a < 0) ? 0 : a;
...
// Interface signal declaration
input logic [avoid_neg(NR_ENTRIES-1):0][PMP_LEN-1:0] conf_addr_i
Would this work?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I think so, and it could be used at many places!
I’m wondering if a function which would do x -> avoid_neg(x - 1)
would be good as it seems to be always the same use-case… But I cannot find a clear name for it; and I think writing/reading avoid_neg(foo - 1)
already makes the intent really clear.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
True! I will think about it as well, even if it's already better than before.
In the meantime, I pushed the avoid_neg
button to clean the diff a bit.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Another argument for avoid_neg
: we are already used to write arrays shape as [Length-1:0]
and [avoid_neg(Length-1):0]
is closer to this than than [foo(Length):0]
is.
// Accelerator - CVA6 | ||
parameter type accelerator_req_t = logic, | ||
parameter type accelerator_resp_t = logic, | ||
|
||
// Accelerator - CVA6's MMU | ||
parameter type acc_mmu_req_t = logic, | ||
parameter type acc_mmu_resp_t = logic, |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
We will need to document somewhere what is expected in these structures, and the protocol used.
But I think it can wait, especially if we will soon switch to CV-X-IF.
core/cva6.sv
Outdated
// branchpredict scoreboard entry | ||
// this is the struct which we will inject into the pipeline to guide the various | ||
// units towards the correct branch decision and resolve | ||
localparam type branchpredict_sbe_t = struct packed { | ||
cf_t cf; // type of control flow prediction | ||
logic [CVA6Cfg.VLEN-1:0] predict_address; // target address at which to jump, or not | ||
}, |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Can you please restore the previous order to reduce the diff? Unless this change is needed, of course.
We already have parameter
later in the configuration so we do not have to keep parameter
above localparam
here.
❌ failed run, report available here. |
❌ failed run, report available here. |
1 similar comment
❌ failed run, report available here. |
✔️ successful run, report available here. |
✔️ successful run, report available here. |
2 similar comments
✔️ successful run, report available here. |
✔️ successful run, report available here. |
✔️ successful run, report available here. |
2 similar comments
✔️ successful run, report available here. |
✔️ successful run, report available here. |
❌ failed run, report available here. |
core/load_store_unit.sv
Outdated
@@ -148,9 +154,9 @@ module load_store_unit | |||
input amo_resp_t amo_resp_i, | |||
|
|||
// PMP configuration - CSR_REGFILE | |||
input riscv::pmpcfg_t [(CVA6Cfg.NrPMPEntries > 0 ? CVA6Cfg.NrPMPEntries-1 : 0):0] pmpcfg_i, | |||
input riscv::pmpcfg_t [avoid_neg(CVA6Cfg.NrPMPEntries-1):0] pmpcfg_i, |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
[verible-verilog-format] reported by reviewdog 🐶
input riscv::pmpcfg_t [avoid_neg(CVA6Cfg.NrPMPEntries-1):0] pmpcfg_i, | |
input riscv::pmpcfg_t [avoid_neg(CVA6Cfg.NrPMPEntries-1):0] pmpcfg_i, |
❌ failed run, report available here. |
✔️ successful run, report available here. |
✔️ successful run, report available here. |
1 similar comment
✔️ successful run, report available here. |
@JeanRochCoulon, the branch is now ready for review and merging! Thanks a lot in advance :-) |
✔️ successful run, report available here. |
Follow-up to the discussion on extending Linux support to the Ara vector processor.
Main changes:
Addition:
avoid_neg()
function used to clip negative numbers to zero. Useful for parametric array sizes and vector multipliers.Modifications:
cv64a6_imafdcv_config_pkg
.exception_t
fromlocalparam
toparam
incva6.sv
.accelerator_req_t
,accelerator_resp_t
,acc_mmu_req_t
, andacc_mmu_resp_t
tocva6.sv
.acc_dispatcher
to decouple timing with the accelerator.cv64a6_imafdcv_sv39_config_pkg
.Bender.yml
package name fromariane
tocva6
.csr_regfile
.Collateral changes:
Fixes:
cva6.sv
.NrCommitPorts
.Bender.yml
.Todo: