





| Simulation                                                                                                                                                                                                                                                                                                                                                                                                                                                       |                         |          |   |  |
|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------|----------|---|--|
| <ul> <li>Task : Create test vectors and simulate model</li> <li>Inputs <ul> <li>Specification</li> <li>Typically natural language, incomplete and informal</li> <li>Used to create interesting stimuli and monitors</li> </ul> </li> <li>Model of DUT <ul> <li>Typically written in HDL or C or both</li> </ul> </li> <li>Output <ul> <li>Failed test vectors</li> <li>Pointed out in different design representations by debugging tools</li> </ul> </li> </ul> |                         |          |   |  |
| Specification                                                                                                                                                                                                                                                                                                                                                                                                                                                    |                         |          |   |  |
| Embedded System Design of the system Design                                                                                                                                                                                                                                                                                                                                                                                                                      | Chapter 7: Verification | 7/8/2009 | 4 |  |







































| С            | overag                                       | e                                                         |                                                                                                                                                       |                                                   |                         |
|--------------|----------------------------------------------|-----------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------|-------------------------|
|              | High                                         | Model checking<br>Theorem proving<br>Equivalence checking | <ul> <li>Formal method<br/>complete cover</li> <li>For a specified</li> <li>For a reference</li> </ul>                                                | <b>s provide</b><br>rage<br>I property<br>e model | )                       |
|              | Medium                                       | Symbolic simulation<br>Simulation with Assertions         | <ul> <li>Simulation with assertions</li> <li>Improves understanding of design         <ul> <li>White box vs. black box testing</li> </ul> </li> </ul> |                                                   | <b>ns</b><br>Of<br>ting |
|              | Low                                          | Pseudo-random simulation                                  |                                                                                                                                                       |                                                   |                         |
| Emb<br>© 200 | edded System [<br>9: Gajski, Abdi, Gerstlaue | Design Chap                                               | ter 7: Verification                                                                                                                                   | 7/8/2009                                          | 24                      |



| S              | calabi                                | lity                                                   |                                                                                                  |                                       |    |
|----------------|---------------------------------------|--------------------------------------------------------|--------------------------------------------------------------------------------------------------|---------------------------------------|----|
|                |                                       |                                                        |                                                                                                  |                                       |    |
|                | High                                  | Pseudo-random simulation<br>Simulation with Assertions | <ul> <li>Simulation based m</li> <li>Scale easily to lar</li> <li>Any model can be</li> </ul>    | ethods<br>ge designs<br>e simulated ! |    |
|                |                                       |                                                        | <ul> <li>Theorem proving</li> <li>Any type of design</li> </ul>                                  | n                                     |    |
|                | Medium                                | Equivalence checking<br>Theorem proving                | <ul> <li>Symbolic simulation</li> <li>BDD blowup for late</li> <li>Limited to RTL and</li> </ul> | n<br>arge designs<br>id below         |    |
|                | Low                                   | Symbolic simulation<br>Model checking                  | <ul> <li>Model checking</li> <li>State space explosion</li> </ul>                                |                                       |    |
| Embe<br>© 2009 | edded System<br>Gajski, Abdi, Gerstla | Design Ch                                              | apter 7: Verification                                                                            | 7/8/2009                              | 26 |

| Evaluating Verification Techniques                                                                                         |          |                 |             |    |  |  |
|----------------------------------------------------------------------------------------------------------------------------|----------|-----------------|-------------|----|--|--|
|                                                                                                                            |          |                 |             |    |  |  |
| Metric<br>Technique                                                                                                        | Coverage | Cost and Effort | Scalability |    |  |  |
| Pseudo random simulation                                                                                                   | L        | L               | Н           |    |  |  |
| Simulation w/ assertions                                                                                                   | М        | м               | Н           |    |  |  |
| Symbolic simulation                                                                                                        | М        | L               | L           |    |  |  |
| Equivalence checking                                                                                                       | н        | м               | М           |    |  |  |
| Model checking                                                                                                             | н        | м               | L           |    |  |  |
| Theorem proving                                                                                                            | н        | н               | М           |    |  |  |
| <ul> <li>Well accepted techniques in industry</li> <li>Simulation with assertions</li> <li>Equivalence checking</li> </ul> |          |                 |             |    |  |  |
| Embedded System Design Chapter 7: Verification                                                                             |          |                 | 7/8/2009    | 27 |  |  |



















## Conclusion

## Variety of verification techniques available

- · Several tools from industry and academia
- · Each technique works well for specific kind / level of models
- Challenges for verification of large system designs
  - Simulation based techniques take way too long
    - Time to market issues
  - · Most formal techniques cannot scale
    - Memory requirement explosion
    - Too much manual effort required
- Modeling is pushed to system level

## · Future design and verification

- Complete and executable functional specification model
- · Well defined semantics for models at different abstraction levels

Chapter 7: Verification

7/8/2009

37

- · Well defined transformations for design decisions
  - Verify transformations
- Automate refinements

## Formalism helps system verification !

Embedded System Design

References 1. Devadas, Ma, Newton, "On the verification of sequential machines at different levels of abstraction", 24th DAC, pp.271-276, June 1987 2. Clarke, Grumberg, Peled, "Model Checking", MIT Press 3. K.L. McMillan, "Symbolic Model Checking: An approach to the State Explosion Problem", Kluwer Academic 1993 4. McFarland, "Formal Verification of Sequential Hardware: A tutorial", IEEE Transaction on CAD, pp. 633-653, May 1993 5. Thomas Kropf, "Introduction to Formal Hardware Verification" Springer, 1999 6. Gordon, "Specification and Verification of Hardware", University of Cambridge, October 1992 7. Lionel Bening, Harry Foster, "Principles of Verifiable RTL Design", Kluwer 2000 Embedded System Design Chapter 7: Verification 7/8/2009 38