User Tools


Differences

This shows you the differences between two versions of the page.

Link to this comparison view

Both sides previous revision Previous revision
Next revision
Previous revision
testbenches [2020/03/17 08:28]
nelson [Other Resources]
testbenches [2020/03/17 08:58] (current)
nelson [Writing a Self-Checking Testbench]
Line 183: Line 183:
     function void checkData(logic expected);     function void checkData(logic expected);
       if (expected != q) begin       if (expected != q) begin
-        $display("​ERROR %t: %d != %d", $time, ​expecteddata_out);+        $display("​ERROR ​at time %t: got a %d but expected a %d", $time, ​qexpected);
         error_count++;​         error_count++;​
       end       end
Line 210: Line 210:
 Also, the list of inputs and expected values could be stored in an array or read from a file.  ​ Also, the list of inputs and expected values could be stored in an array or read from a file.  ​
  
-Then, why require the user to even compute the expected value? ​ Maybe a python script or C program ​could be written ​to do that and create ​the list of inputs and expected output(s) ​for you.  ​+A similar structure ​could be applied ​to the construction ​of a testbench ​for a sequential circuit.  ​
  
 /* /*
 And, it could go on and on and on.  For example, there is a whole object oriented side to SystemVerilog (which can only be used in testbenches) so that advanced test frameworks can be constructed (we teach a graduate course on that topic). ​ So, did you really think they simulate their quad-core Pentium processor designs containing billions of transistors at Intel by typing Tcl scripts in by hand?  :-) And, it could go on and on and on.  For example, there is a whole object oriented side to SystemVerilog (which can only be used in testbenches) so that advanced test frameworks can be constructed (we teach a graduate course on that topic). ​ So, did you really think they simulate their quad-core Pentium processor designs containing billions of transistors at Intel by typing Tcl scripts in by hand?  :-)
 */ */
 +
 +
 ==== Using $finish ==== ==== Using $finish ====
 By default, when you start a simulation in Vivado it will run for a set amount of time (1000ns) and then stop, awaiting further input from you. By default, when you start a simulation in Vivado it will run for a set amount of time (1000ns) and then stop, awaiting further input from you.
Line 247: Line 249:
 How do you set a breakpoint? ​ It is pretty simple - the large circles next to each executable line of testbench code are the breakpoint markers. ​ Click one, it becomes solid colored, and you have now set a breakpoint at that line.  Click it again, it becomes open, and you have unset the breakpoint. How do you set a breakpoint? ​ It is pretty simple - the large circles next to each executable line of testbench code are the breakpoint markers. ​ Click one, it becomes solid colored, and you have now set a breakpoint at that line.  Click it again, it becomes open, and you have unset the breakpoint.
  
-==== Other Resources ==== +==== Other Resources ​To Learn More==== 
-If you have read this far, you are definitely interested in learning to simulate more effectively using testbenches.  A web search for "​verilog testbench"​ or "​systemverilog testbench"​ will turn up many, many tutorials on the subject.+If you have read this far, you are definitely interested in learning to simulate more effectively using testbenches. ​
  
-Some words of CAUTION are in order  +Where to go to next? A web search for "​verilog testbench"​ or "​systemverilog testbench"​ will turn up many, many tutorials on the subject. ​ But, some words of CAUTION are in order  
-  * There is, frankly, a lot of junk out there on the web regarding testbench design so be careful. ​ For example, some will advocate changing the inputs at the rising of the clock (good luck pulling your hair out if you encounter a "​race"​ as a result ​but you might get lucky). ​  +  * There is, frankly, a lot of junk out there on the web regarding testbench design so be careful. ​ For example, some will advocate changing the inputs at the rising of the clock (bad idea are you feeling ​lucky?).   
-  * Others ​will attempt to fix the race using #0 delays (don't even ask what these are for --- they are a kludgy patch on an already bad design practice).+  * Many will attempt to fix the above bad practice ​using #0 delays (don't even ask what these are for --- they are a kludgy patch on an already bad design practice).  Instead stick with what was shown above --- changing inputs on the falling edge of the clock is a commonly accepted practice that avoids a number of race problems.
   * A final challenge you will have is that if you search for "​systemverilog testbench"​ you will likely find some advanced materials on using the object oriented SystemVerilog features to create very sophisticated testbenches. While this is good, these might be beyond what you are looking for.   * A final challenge you will have is that if you search for "​systemverilog testbench"​ you will likely find some advanced materials on using the object oriented SystemVerilog features to create very sophisticated testbenches. While this is good, these might be beyond what you are looking for.
  
-So, what to do to learn more?  The basic structure above is perfectly fine for typical testbenches. ​ Through the use of functions and tasks you can organize and make your testbenches efficient.  ​Learning ​about loops, file I/O, and the like in SystemVerilog will allow you to enhance them even more.+So, what to do to learn more?  The basic structure above is perfectly fine for typical testbenches. ​ Through the use of functions and tasks you can organize and make your testbenches ​even more efficient.  ​Then, learn about SystemVerilog'​s data structures for simulation (arrays, queues, etc).  Finally, learn about loops, file I/O, and the like.
  
-Finally, if you would like to learn about the advanced SystemVerilog features ​here are two ideas:+If you would like to learn more, here are some ideas:
  
-  - We teach SystemVerilog-based testing as a grad course in the department. ​ Talk to the faculty. +  - Read through the testbenches used in the 220 class labs.  Most are written in basic Verilog but some are SystemVerilog. ​ You can learn from all of them.   
-  - The best book on the subject is: "​SYSTEMVERILOG FOR VERIFICATION - A Guide to Learning the Testbench Language Features",​ Third Edition by Spear and Tumbush, 2011.+  - In the past we have taught ​SystemVerilog-based testing as a grad course in the department. ​ Talk to the CpE faculty ​to learn more
 +  - The very best book on the subject is: "​SYSTEMVERILOG FOR VERIFICATION - A Guide to Learning the Testbench Language Features",​ Third Edition by Spear and Tumbush, 2011.  It is what we use in our class.