

| IBM Labs in Haifa                                                                                                                                                          | IBM               |
|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------|
| <ul> <li>Outline</li> <li>Introduction to functional verification</li> <li>What is functional verification?</li> <li>Leading functional verification techniques</li> </ul> |                   |
| <ul> <li>The SoC challenge</li> <li>What's new in SoC design?</li> <li>Why is verification difficult for SoCs?</li> </ul>                                                  |                   |
| <ul> <li>Possible solutions</li> <li>Raise the abstraction level</li> <li>Test generation examples</li> </ul>                                                              |                   |
| 2 MPSOC 03 © 200                                                                                                                                                           | 3 IBM Corporation |



















| ŧ     | IBM Labs in Haifa                                                                                                                                                  |
|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Checl | king Techniques (2)                                                                                                                                                |
| ♦ Ass | ertions (or properties checking)                                                                                                                                   |
| ۲     | Starting from simple assert statements                                                                                                                             |
|       | $\diamond$ assert (length > 0)reprot "Illegal Length"                                                                                                              |
| ۲     | Assertions can be manually inserted by the designer into the source code<br>of the design, or they can be externally created and inserted by verification<br>tools |
| ۲     | Current assertion techniques use temporal property specification languages to specify complex assertions                                                           |
| ⊗ Beh | avioral rules                                                                                                                                                      |
| *     | Rules that describe the expected behavior of the design                                                                                                            |
| ۲     | Usually rules are more abstract than assertions<br>Not limited to specific facilities                                                                              |
| ۲     | Example: scoreboard                                                                                                                                                |
|       | Check that everything that goes in also comes out                                                                                                                  |
| 12    | MPSOC 03 © 2003 IBM Corporation                                                                                                                                    |











| IBM Labs in Haifa                                                                        |                                |                        |
|------------------------------------------------------------------------------------------|--------------------------------|------------------------|
| Heavy Use of Cores                                                                       |                                |                        |
| <ul> <li>Core are more reliable than cust</li> <li>They have been used and to</li> </ul> | om logic<br>ested before       |                        |
| Unit (core) verification may not b                                                       | e necessary                    |                        |
| <ul> <li>Cores are often black boxes</li> <li>Hard to look inside</li> </ul>             |                                |                        |
| The cores may not be verified fo                                                         | r the specific use scenario o  | f the system           |
| Simulation model of the cores m                                                          | ay not be available            |                        |
| Bebugging is much harder                                                                 |                                |                        |
| <ul> <li>Is the bug in the core or the</li> <li>How do we debug the interr</li> </ul>    | interface?<br>als of the core? |                        |
| <ul> <li>Integration is more difficult</li> </ul>                                        |                                |                        |
| 18                                                                                       | MPSOC 03                       | © 2003 IBM Corporation |



| IBM Labs in Haifa                                                                                                                                                 |     |
|-------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|
| Outline <ul> <li>Introduction to functional verification</li> <li>What is functional verification?</li> <li>Leading functional verification techniques</li> </ul> |     |
| <ul> <li>The SoC challenge</li> <li>What's new in SoC design?</li> <li>Why is verification difficult for SoCs?</li> </ul>                                         |     |
| <ul> <li>Possible solutions</li> <li>Raise the abstraction level</li> <li>Test generation examples</li> </ul>                                                     |     |
| 20 MPSOC 03 © 2003 IBM Corpora                                                                                                                                    | ion |







| IBM Labs in Haifa                                                                                                                                                                                                                                                                                                                                                                  | BM       |
|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------|
| <ul> <li>Checking Techniques for SoC Verification</li> <li>Golden model / expected results</li> <li>Results are hard to predict because of parallel nature of systems</li> <li>Possible solutions:</li> <li>Cycle-accurate golden model</li> </ul>                                                                                                                                 |          |
| <ul> <li>Ignore ordering</li> <li>Needed assertions</li> <li>On the interfaces to detect protocol violations</li> <li>Should be provided by the developers of the cores</li> <li>Transaction level assertions</li> <li>New assertion language with transaction vocabulary</li> <li>Length, fields, actors,</li> <li>Detection of internal transactions may be difficult</li> </ul> |          |
| 24 MPSOC 03 © 2003 IBM Corp                                                                                                                                                                                                                                                                                                                                                        | ooration |







| ا                                                | IBM Labs in Haifa                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | ISIA                   |
|--------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------|
| Step<br>& Ev<br>«<br>«<br>«<br>BI<br>«<br>«<br>« | <ul> <li>1 – Model the System</li> <li>erything is modeled as an HFSM</li> <li>Global HFSM for configuration and test specification</li> <li>Environment HFSM for allowing only legal inputs</li> <li>One HFSM per IP</li> <li>ack box model of the IPs</li> <li>Abstract away the data computation performed in the IP</li> <li>Model configuration and interactions with other IPs</li> <li>Interactions are modeled at the transaction level</li> <li>Outputs are symbolic commands of the IP</li> <li>Inputs are arbitrary</li> <li>Whatever is convenient to drive the tests</li> </ul> |                        |
| 28                                               | MPSOC 03                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | © 2003 IBM Corporation |





















