wire cache_hit = cache_valid[idx] && (cache_tags[idx] == tag);
+ wire [31:0] curdata = cache_data[idx][didx_word];
always @(*) begin
rw_wait = (rd_req && !cache_hit) || (wr_req && (!bus_ack || !bus_ready));
- rd_data = cache_data[idx][didx_word];
+ rd_data = curdata;
if (!rw_wait && rd_req)
$display("DCACHE: READ COMPLETE: Addr %08x, data %08x", addr, rd_data);
end
cache_valid[idx] <= 0;
end
end else if (wr_req && cache_hit)
- cache_data[idx][addr[5:2]] = wr_data;
+ cache_data[idx][addr[5:2]] <= wr_data;
end
endmodule
reg [31:0] prev_rd_addr = 32'hFFFFFFFF;
wire cache_hit = cache_valid[rd_idx] && (cache_tags[rd_idx] == rd_tag);
-
- always @(*) begin /* XXX does this work nowadays? */
+
+ wire [31:0] curdata = cache_data[rd_idx][rd_didx_word];
+ always @(*) begin
rd_wait = rd_req && !cache_hit;
- rd_data = cache_data[rd_idx][rd_didx_word];
+ rd_data = curdata;
end
reg [3:0] cache_fill_pos = 0;