93 lines
2.6 KiB
Systemverilog
93 lines
2.6 KiB
Systemverilog
|
|
||
|
wire ram_clk = `TB.U_CHIP_TOP.U_DTCM.U_tsmc_dpram.dpram_32X4096_generation.U0_TSDN28HPCPUHDB4096X32M4MWR.CLK;
|
||
|
wire ram_cs = `TB.U_CHIP_TOP.U_DTCM.U_tsmc_dpram.dpram_32X4096_generation.U0_TSDN28HPCPUHDB4096X32M4MWR.CEBA;
|
||
|
wire reg_clk = tbtop.U_CHIP_TOP.U_qbmcu.U_qbmcu_regfile.clk;
|
||
|
wire reg_en = tbtop.U_CHIP_TOP.U_qbmcu.U_qbmcu_regfile.wbck_dest_wen;
|
||
|
reg ram_cs_dly1 ;
|
||
|
reg reg_en_dly1 ;
|
||
|
always @(posedge ram_clk) begin
|
||
|
ram_cs_dly1 <= ~ram_cs;
|
||
|
reg_en_dly1 <= reg_en;
|
||
|
end
|
||
|
|
||
|
reg [15:0] temp;
|
||
|
initial begin
|
||
|
#1ns;
|
||
|
//@(posedge ram_cs_dly1 );
|
||
|
#5ns;
|
||
|
//while(1)begin
|
||
|
#1ns;
|
||
|
REGFILE_CHECK(6'd3,32'h8765_4000);
|
||
|
REGFILE_CHECK(6'd3,32'h8765_4321);
|
||
|
REGFILE_CHECK(6'd4,32'hfedc_b000);
|
||
|
REGFILE_CHECK(6'd4,32'hfedc_b7f5);
|
||
|
REGFILE_CHECK(6'd1,32'h0010_0000);
|
||
|
REGFILE_CHECK(6'd2,32'h0010_4000);
|
||
|
for(int i = 4095; i > 0; i--) begin
|
||
|
temp = i*4;
|
||
|
REGFILE_CHECK(6'd2,{16'h0010,temp});
|
||
|
//$monitor($time, " Simulation time: %t", $time);
|
||
|
DRAM_DATA_CHECK(i,{16'h0010,temp});
|
||
|
end
|
||
|
//@(posedge reg_en_dly1 );
|
||
|
|
||
|
#10us;
|
||
|
TEST_PASS;
|
||
|
end
|
||
|
|
||
|
task DRAM_DATA_CHECK;
|
||
|
input [12:0] addr ;
|
||
|
input [31:0] edata ;
|
||
|
|
||
|
logic [31:0] ram_data;
|
||
|
|
||
|
@(posedge ram_cs_dly1 );
|
||
|
@(posedge ram_clk );
|
||
|
//$monitor($time, " Simulation time: %t", $time);
|
||
|
if(ram_cs_dly1) begin
|
||
|
ram_data = `TB_DRAM.mem[addr];
|
||
|
//$display("* RAM_DATA[%x]: %x | EXP_DATA: %x ",addr,ram_data, edata);
|
||
|
if(ram_data !== edata) begin
|
||
|
$display("* RAM_DATA[%x]: %x | EXP_DATA: %x => Error!!!",addr,ram_data, edata);
|
||
|
#1us;
|
||
|
TEST_FAIL;
|
||
|
end
|
||
|
$display("* RAM_DATA[%x]: %x | EXP_DATA: %x => OK!!!",addr, ram_data, edata);
|
||
|
end
|
||
|
else begin
|
||
|
$display("* DRAM CS is High => Error!!!");
|
||
|
TEST_FAIL;
|
||
|
end
|
||
|
endtask
|
||
|
|
||
|
task REGFILE_CHECK;
|
||
|
input [4:0] addr ;
|
||
|
input [31:0] edata ;
|
||
|
|
||
|
logic [31:0] reg_data;
|
||
|
@(posedge reg_en );
|
||
|
@(posedge reg_clk);
|
||
|
if(reg_en)begin
|
||
|
reg_data = tbtop.U_CHIP_TOP.U_qbmcu.U_qbmcu_regfile.wbck_dest_dat;
|
||
|
if(reg_data !== edata) begin
|
||
|
$display("* REG_DATA[%x]: %x | EXP_DATA: %x => Error!!!",addr,reg_data, edata);
|
||
|
#1us;
|
||
|
//TEST_FAIL;
|
||
|
end
|
||
|
$display("* REG_DATA[%x]: %x | EXP_DATA: %x => OK!!!",addr, reg_data, edata);
|
||
|
end
|
||
|
else begin
|
||
|
$display("* REG WR EN is High => Error!!!");
|
||
|
//TEST_FAIL;
|
||
|
end
|
||
|
|
||
|
endtask
|
||
|
|
||
|
initial begin
|
||
|
#10000us;
|
||
|
$display("\n----------------------------------------\n");
|
||
|
$display("\t Timeout Error !!!!\n");
|
||
|
TEST_FAIL;
|
||
|
end
|
||
|
|