OpenCores
URL https://opencores.org/ocsvn/dbg_interface/dbg_interface/trunk

Subversion Repositories dbg_interface

[/] [dbg_interface/] [trunk/] [bench/] [verilog/] [dbg_tb.v] - Diff between revs 120 and 121

Go to most recent revision | Show entire file | Details | Blame | View Log

Rev 120 Rev 121
Line 41... Line 41...
//////////////////////////////////////////////////////////////////////
//////////////////////////////////////////////////////////////////////
//
//
// CVS Revision History
// CVS Revision History
//
//
// $Log: not supported by cvs2svn $
// $Log: not supported by cvs2svn $
 
// Revision 1.35  2004/01/22 11:07:28  mohor
 
// test stall_test added.
 
//
// Revision 1.34  2004/01/20 14:24:08  mohor
// Revision 1.34  2004/01/20 14:24:08  mohor
// Define name changed.
// Define name changed.
//
//
// Revision 1.33  2004/01/20 14:05:26  mohor
// Revision 1.33  2004/01/20 14:05:26  mohor
// Data latching changed when testing WB.
// Data latching changed when testing WB.
Line 580... Line 583...
 
 
task stall_test;
task stall_test;
  integer i;
  integer i;
 
 
  begin
  begin
 
    test_text = "stall_test";
    $display("\n\n(%0t) stall_test started", $time);
    $display("\n\n(%0t) stall_test started", $time);
 
 
    // Set bp_i active for 1 clock cycle and check is stall is set or not
    // Set bp_i active for 1 clock cycle and check is stall is set or not
    check_stall(0); // Should not be set at the beginning
    check_stall(0); // Should not be set at the beginning
    @ (posedge wb_clk_i);
    @ (posedge wb_clk_i);
      #1 dbg_tb.i_cpu_behavioral.cpu_bp_o = 1'b1;
      #1 dbg_tb.i_cpu_behavioral.cpu_bp_o = 1'b1;
      check_stall(1); // set?
    #1 check_stall(1); // set?
    @ (posedge wb_clk_i);
    @ (posedge wb_clk_i);
      #1 dbg_tb.i_cpu_behavioral.cpu_bp_o = 1'b0;
      #1 dbg_tb.i_cpu_behavioral.cpu_bp_o = 1'b0;
      check_stall(1); // set?
    #1 check_stall(1); // set?
 
 
    gen_clk(1);
    gen_clk(1);
    check_stall(1); // set?
    #1 check_stall(1); // set?
 
 
    // Unstall with register
    // Unstall with register
    set_instruction(`DEBUG);
    set_instruction(`DEBUG);
    chain_select(`CPU_DEBUG_CHAIN, 1'b0);   // {chain, gen_crc_err}
    chain_select(`CPU_DEBUG_CHAIN, 1'b0);   // {chain, gen_crc_err}
    check_stall(1); // set?
    #1 check_stall(1); // set?
    debug_cpu(`CPU_WRITE_REG, `CPU_OP_ADR, 32'h0, 1'b0, result, "clr unstall"); // {command, addr, data, gen_crc_err, result, text}
    debug_cpu(`CPU_WRITE_REG, `CPU_OP_ADR, 32'h0, 1'b0, result, "clr unstall"); // {command, addr, data, gen_crc_err, result, text}
    check_stall(1); // set?
    #1 check_stall(1); // set?
    debug_cpu(`CPU_GO, 32'h0, 32'h0, 1'b0, result, "go cpu"); // {command, addr, data, gen_crc_err, result, text}
    debug_cpu(`CPU_GO, 32'h0, 32'h0, 1'b0, result, "go cpu"); // {command, addr, data, gen_crc_err, result, text}
    check_stall(0); // reset?
    #1 check_stall(0); // reset?
 
 
    // Set stall with register
    // Set stall with register
    debug_cpu(`CPU_WRITE_REG, `CPU_OP_ADR, 32'h0, 1'b0, result, "clr stall"); // {command, addr, data, gen_crc_err, result, text}
    debug_cpu(`CPU_WRITE_REG, `CPU_OP_ADR, 32'h0, 1'b0, result, "clr stall"); // {command, addr, data, gen_crc_err, result, text}
    check_stall(0); // reset?
    #1 check_stall(0); // reset?
    debug_cpu(`CPU_GO, 32'h0, 32'h1, 1'b0, result, "go cpu"); // {command, addr, data, gen_crc_err, result, text}
    debug_cpu(`CPU_GO, 32'h0, 32'h1, 1'b0, result, "go cpu"); // {command, addr, data, gen_crc_err, result, text}
    check_stall(1); // set?
    #1 check_stall(1); // set?
 
 
    // Unstall with register
    // Unstall with register
    debug_cpu(`CPU_WRITE_REG, `CPU_OP_ADR, 32'h0, 1'b0, result, "clr unstall"); // {command, addr, data, gen_crc_err, result, text}
    debug_cpu(`CPU_WRITE_REG, `CPU_OP_ADR, 32'h0, 1'b0, result, "clr unstall"); // {command, addr, data, gen_crc_err, result, text}
    check_stall(1); // set?
    #1 check_stall(1); // set?
    debug_cpu(`CPU_GO, 32'h0, 32'h0, 1'b0, result, "go cpu"); // {command, addr, data, gen_crc_err, result, text}
    debug_cpu(`CPU_GO, 32'h0, 32'h0, 1'b0, result, "go cpu"); // {command, addr, data, gen_crc_err, result, text}
    check_stall(0); // reset?
    #1 check_stall(0); // reset?
 
 
    $display("\n\n(%0t) stall_test passed\n\n", $time);
    $display("\n\n(%0t) stall_test passed\n\n", $time);
  end
  end
endtask   // stall_test
endtask   // stall_test
 
 

powered by: WebSVN 2.1.0

© copyright 1999-2025 OpenCores.org, equivalent to Oliscience, all rights reserved. OpenCores®, registered trademark.