RVSCC/test/test_instr_memory.sv

70 lines
1.3 KiB
Systemverilog
Raw Normal View History

2023-02-26 23:26:11 +00:00
`timescale 1ns / 1ps
import rv32i_defs::*;
module test_instr_memory ();
localparam string Path = "../fw/test/test-core.mem";
localparam int NumInstr = 32;
localparam int NumBlocks = NumInstr * 4;
localparam int AddrSize = $clog2(NumBlocks);
logic [AddrSize-1:0] addr;
logic [InstructionSize-1:0] instr;
instr_memory #(
.N_INSTR (NumInstr),
.FILE_PATH(Path)
) instruction_memory (
.addr (addr),
.instr(instr)
);
const
int
assert_instr_mem[21] = {
'h00500113,
'h00C00193,
'hFF718393,
'h0023E233,
'h0041F2B3,
'h004282B3,
'h02728863,
'h0041A233,
'h00020463,
'h00000293,
'h0023A233,
'h005203B3,
'h402383B3,
'h0471AA23,
'h06002103,
'h005104B3,
'h008001EF,
'h00100113,
'h00910133,
'h0221A023,
'h00210063
};
initial begin
addr = 'd0;
#1
assert (!$isunknown(instr))
else $error("Instruction memory not loaded");
#1;
foreach (assert_instr_mem[i]) begin
$display(i);
addr = AddrSize'(i * 4);
#1
assert (instr == assert_instr_mem[i])
else
$error(
"Instruction %h at address %h does not match the expected intruction %h",
instr,
addr,
assert_instr_mem[i]
);
end
$finish;
end
endmodule