From a38e37342ca371bc3034bf92d5c41d3fa287ee08 Mon Sep 17 00:00:00 2001 From: Pascal Nasahl Date: Mon, 18 Nov 2024 12:45:35 +0100 Subject: [PATCH] [rtl] Fix zero value in FPGA RF We should use `WordZeroVal` instead of `0` for reads from register `x0` in the FPGA register file. This bug was discovered when enabling the `RegFileECC` parameter. When this is enabled, the core performs ECC checks, expecting that `WordZeroVal` is returned for `x0`. Else, we get a major alert. Fixes lowRISC/opentitan#25146 Signed-off-by: Pascal Nasahl --- rtl/ibex_register_file_fpga.sv | 8 ++++---- 1 file changed, 4 insertions(+), 4 deletions(-) diff --git a/rtl/ibex_register_file_fpga.sv b/rtl/ibex_register_file_fpga.sv index 7a0ae34b15..73e0afab2f 100644 --- a/rtl/ibex_register_file_fpga.sv +++ b/rtl/ibex_register_file_fpga.sv @@ -147,14 +147,14 @@ module ibex_register_file_fpga #( .out_o (mem_o_b) ); - assign rdata_a_o = (raddr_a_i == '0) ? '0 : mem_o_a; - assign rdata_b_o = (raddr_b_i == '0) ? '0 : mem_o_b; + assign rdata_a_o = (raddr_a_i == '0) ? WordZeroVal : mem_o_a; + assign rdata_b_o = (raddr_b_i == '0) ? WordZeroVal : mem_o_b; end else begin : gen_no_rdata_mux_check // async_read a - assign rdata_a_o = (raddr_a_i == '0) ? '0 : mem[raddr_a_i]; + assign rdata_a_o = (raddr_a_i == '0) ? WordZeroVal : mem[raddr_a_i]; // async_read b - assign rdata_b_o = (raddr_b_i == '0) ? '0 : mem[raddr_b_i]; + assign rdata_b_o = (raddr_b_i == '0) ? WordZeroVal : mem[raddr_b_i]; end // we select