58 lines
1.3 KiB
Systemverilog
58 lines
1.3 KiB
Systemverilog
`timescale 1ns / 1ps
|
|
|
|
module Test_DataMemory ();
|
|
logic clk, rst;
|
|
logic [31:0] addr;
|
|
logic write_enable;
|
|
logic [31:0] write_data;
|
|
logic [31:0] read_data;
|
|
|
|
localparam int MemorySize = 16;
|
|
DataMemory #(
|
|
.SIZE(MemorySize)
|
|
) DUT (
|
|
.clk(clk),
|
|
.rst(rst),
|
|
.addr(addr),
|
|
.write_enable(write_enable),
|
|
.write_data(write_data),
|
|
.read_data(read_data)
|
|
);
|
|
|
|
always #1 clk = ~clk;
|
|
|
|
localparam int MemoryWriteRange = 16;
|
|
|
|
logic [MemoryWriteRange:0][31:0] write_values;
|
|
int start_addr;
|
|
initial begin
|
|
// Reset
|
|
clk = 0;
|
|
rst = 1;
|
|
write_enable = 0;
|
|
#4;
|
|
rst = 0;
|
|
#1;
|
|
// Write to a range of values in memory
|
|
write_enable = 1;
|
|
start_addr = $urandom_range(15);
|
|
for (int i = 0; i < MemoryWriteRange; i++) begin
|
|
addr = start_addr + i*4;
|
|
write_values[i] = $urandom();
|
|
write_data = write_values[i];
|
|
#2;
|
|
end
|
|
// Read and compare the same range of values
|
|
write_enable = 0;
|
|
#4;
|
|
for (int i = 0; i < MemoryWriteRange; i++) begin
|
|
addr = start_addr + i*4;
|
|
#1;
|
|
assert (read_data == write_values[i])
|
|
else $error("Read failed at address %h", addr);
|
|
#1;
|
|
end
|
|
$finish;
|
|
end
|
|
endmodule
|