| Simulation                                                                                                                                                                                                                                                             |  |
|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| Simulation                                                                                                                                                                                                                                                             |  |
| UCB EECS150 Spring 2010<br>Lab Lecture #4                                                                                                                                                                                                                              |  |
| Lab Lecture #4                                                                                                                                                                                                                                                         |  |
| UCB EECS150 Spring 2010, Lab Lecture #4 1                                                                                                                                                                                                                              |  |
|                                                                                                                                                                                                                                                                        |  |
|                                                                                                                                                                                                                                                                        |  |
|                                                                                                                                                                                                                                                                        |  |
| Agenda                                                                                                                                                                                                                                                                 |  |
| <ul> <li>Simulation</li> <li>Software simulation vs. Hardware testing</li> </ul>                                                                                                                                                                                       |  |
| <ul><li>Administrative Info</li><li>General testing methodologies</li></ul>                                                                                                                                                                                            |  |
| Bottom-up, top-down  Exhaustive, random} testing                                                                                                                                                                                                                       |  |
| • FSM testing                                                                                                                                                                                                                                                          |  |
|                                                                                                                                                                                                                                                                        |  |
| UCB EECS150 Spring 2010, Lab Lecture #4 2                                                                                                                                                                                                                              |  |
|                                                                                                                                                                                                                                                                        |  |
|                                                                                                                                                                                                                                                                        |  |
| Where are we?                                                                                                                                                                                                                                                          |  |
| [Software] Simulation                                                                                                                                                                                                                                                  |  |
| Design Entry  Logic Synthesis  Translate/Map/PAR  BitGen  MPACT  Optionsory  And  Optionsory  Design Entry  MPACT  Optionsory  And  Optionsory  Design Entry  MPACT  Optionsory  Design Entry  MPACT  Optionsory  Design Entry  MPACT  Optionsory  Design Entry  MPACT |  |
|                                                                                                                                                                                                                                                                        |  |
| Verliag HDL Symplify Pro .ncd (optionally modified)                                                                                                                                                                                                                    |  |
| FPGA Editor→ Optional step                                                                                                                                                                                                                                             |  |
|                                                                                                                                                                                                                                                                        |  |

| Test Methodologies (Macro)                                                                                                                                                                                                                                                                                                                                                                                   | (1)       |  |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------|--|
| Why simulate in software?  Design feedback  Waveforms  Text messages  Design visibility  Examine every signal!  Fast startup time  Functional simulation comes before you run the to  Slow running time  It takes 1 s to simulate 1 ms                                                                                                                                                                       | ools<br>4 |  |
| Test Methodologies (Macro)                                                                                                                                                                                                                                                                                                                                                                                   | (2)       |  |
| <ul> <li>Why test in hardware?</li> <li>Fast running time</li> <li>Slow startup time</li> <li>Running the tools takes from minutes to hours</li> <li>[Lack of] design visibility</li> <li>Can only probe several signals at a time (more on this in Lab 5)</li> <li>Subject to "hard" errors (broken FPGA)</li> </ul>                                                                                        | s         |  |
| Test Methodologies (Macro)                                                                                                                                                                                                                                                                                                                                                                                   | (3)       |  |
| When to use software/hardware for testing                                                                                                                                                                                                                                                                                                                                                                    | g         |  |
| - Software simulation: Functional testing  • Very that the circuits behaves correctly  - Outputs correct waveforms  - Interacts with neighboring blocks correctly  - Fully verify to the extent that you can!  - Hardware testing: Live debugging  • When it works in simulation but not in hardware  • Use as a last resort – it is time consuming  • Is all hope lost? No. This will be the subject of lab |           |  |
| UCB EECS150 Spring 2010, Lab Lecture #4                                                                                                                                                                                                                                                                                                                                                                      | 6         |  |

| Administrative Info                                                                                        |            |   |  |
|------------------------------------------------------------------------------------------------------------|------------|---|--|
| Newsgroup                                                                                                  |            |   |  |
| – Post questions!                                                                                          |            |   |  |
| <ul><li>We don't bite! [?]</li><li>SVN is functional</li></ul>                                             |            |   |  |
| Email <u>Ilia</u> with any problems                                                                        |            |   |  |
| <ul> <li>Homework is only accepted through SVN</li> </ul>                                                  |            |   |  |
| <ul><li>Coming up</li><li>– Mini-project (week after next)</li></ul>                                       |            | - |  |
| - Actual project (week after that) - Actual project (week after that)                                      |            |   |  |
| UCB EECS150 Spring 2010, Lab Lecture IM4                                                                   | 7          |   |  |
|                                                                                                            |            |   |  |
|                                                                                                            |            |   |  |
|                                                                                                            |            |   |  |
|                                                                                                            |            |   |  |
| Test Methodologies (Micro)                                                                                 | (1)        |   |  |
|                                                                                                            | <b>\</b> / |   |  |
| <ul> <li>Bottom-up testing         <ul> <li>Design is a tree of modules</li> </ul> </li> </ul>             |            | • |  |
| <ul> <li>Test and verify the "leaves" first, and move up<br/>Example: Broken accumulator</li> </ul>        |            |   |  |
| Test each function in an ALUBitSlice     Verify the entire ALUBitSlice                                     |            |   |  |
| 3. Make sure the registers are instantiated correctly 4. Test the entire accumulator (again)               |            |   |  |
|                                                                                                            |            |   |  |
| Circuits seldom "just work" unless you test individual pieces!                                             |            |   |  |
|                                                                                                            |            |   |  |
| UCB EECS150 Spring 2010, Lab Lecture M4                                                                    | 8          |   |  |
|                                                                                                            |            |   |  |
|                                                                                                            |            |   |  |
|                                                                                                            |            |   |  |
| Toot Mothed delegies (Misse)                                                                               | (2)        |   |  |
| Test Methodologies (Micro)                                                                                 | (2)        |   |  |
| Top-down testing                                                                                           |            |   |  |
| <ul> <li>Recap: don't do this initially</li> <li>Some bugs don't occur when you test pieces apa</li> </ul> | ırt        |   |  |
| - Thus, test procedure really is:                                                                          | •          |   |  |
| <ol> <li>Bottom-up (Simulation)</li> <li>Top-down* (Simulation)</li> </ol>                                 |            |   |  |
| <ol> <li>Top (Hardware): See if it works</li> <li>Top-down (Hardware): If it doesn't work</li> </ol>       |            |   |  |
| *Take the time to build a simulation model of your FPGA_TOF                                                | P file.    |   |  |
| This is the crucial (and most overlooked) step.                                                            |            |   |  |
| UCB EECS150 Spring 2010, Lab Lecture #4                                                                    | 9          |   |  |
|                                                                                                            |            |   |  |

| Test Methodologies (Micro)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | (3)    |  |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|--|
| Exhaustive testing         — Find out input combinations for a circuit         — Drive circuit with every combination of inputs             • "for" loops can handle input generation             — Ideal case: test every input (100% coverage)             • Not often tractable (circuits with many inputs)             • Do the best you can through targeted test vectors             — The Good             • Ideal testing – covers all cases             — The Bad             • Very slow – complexity does not scale with design size. |        |  |
| UCB ECCS150 Spring 2030, lab Lecture #4                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | 10     |  |
| Test Methodologies (Micro)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | (4)    |  |
| <ul> <li>Random testing         <ul> <li>After using targeted test vectors</li> <li>"Lazy man's method"</li> <li>Feed random inputs into design for X days</li> <li>Does it still work? Great! It must be bug free.</li> <li>After targeted test vectors, this works surprisingly we</li> </ul> </li> </ul>                                                                                                                                                                                                                                      | ell    |  |
| <ul> <li>The Good</li> <li>Doesn't require much thought to set up</li> <li>Is decently effective</li> <li>The Bad</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                     |        |  |
| <ul> <li>Isn't necessarily going to test frequently occurring pr</li> <li>UCB EECS150 Spring 2010, Lab Lecture 84</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                     | oblems |  |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |        |  |
| Test Methodologies (Micro)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | (5)    |  |
| <ul> <li>FSM testing</li> <li>The method from lab 3</li> <li>Check every state transition arc</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                         |        |  |
| <ul> <li>Check every state transition arc</li> <li>Check every output</li> <li>Leverage what you have</li> <li>Make this about iterating through input domain</li> </ul>                                                                                                                                                                                                                                                                                                                                                                         |        |  |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |        |  |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |        |  |
| UCB EECS150 Spring 2010, Lab Lecture #4                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | 12     |  |

| Acknowledgements & Contributors                                                                                                            |  |
|--------------------------------------------------------------------------------------------------------------------------------------------|--|
|                                                                                                                                            |  |
| Slides developed by Chris Fletcher & John Wawrzynek (2/2010).                                                                              |  |
| This work is based in part on slides by:                                                                                                   |  |
| Chen Sun (2008-2009)                                                                                                                       |  |
| Sarah Swisher (2008)                                                                                                                       |  |
| Greg Gibeling (2003-2005)                                                                                                                  |  |
| This work has been used by the following courses:  — UC Berkeley CS150 (Spring 2010): Components and Design Techniques for Digital Systems |  |
|                                                                                                                                            |  |
|                                                                                                                                            |  |
|                                                                                                                                            |  |