# Formal Verification Seminar Presented by SYCHOI - ASIC Verification Methodology - What is the Formal Verification? - Why Equivalence Checking? - Equivalence Checking Flow - How to use Conformal LEC - Libraries - Environment Variables - Quartus II settings - Quiz # **ASIC** Verification Methodology # **Verification Comparison** Compare **Functional (RTL)** Synthesized netlist **Scan Insertion Placement Clock Tree Synthesis** #### **ASIC Verification Tools** - Event Based Simulators - 1000 Cycles/Sec - VCS, NC-SIM, ModelSim - \$5000 to \$50,000 - Cycle Based Simulators - 5000 Cycles/Sec - Scirocco, SpeedSim - \$50,000 to \$100,000 #### **ASIC** Verification tools - Hardware Accelerators - 100,000 Cycles/Sec - Hammer, CoBalt Plus - -> \$250,000 - Hardware Emulation - 1,000,000 Cycles/Sec - VN-Cover - > \$250,000 - FPGA Prototyping #### **Emulators and Accelerators** - V-Station - Co-modelling - Celaro - ARES RTL Acceleration - Mercury Plus - Palladium - SpeedBridge - What is Formal Verification? - Why Equivalence Checking? - Equivalence Checking Flow - How to use Conformal LEC - Libraries - Environment Variables - Quartus II settings #### What is Formal Verification? - Formal Verification is Equivalence Checking: - Very fast replacement of gate-level simulation for regression testing - 100% verification of all functionality without vectors - Formal Verification proves mathematically that two designs have the same functionality: - RTL-to-gates - Gates-to-gates - RTL-to-RTL - Verifies that design function has not changed AUTERA # **Equivalence Checking Using Conformal LEC** - Why Equivalence Checking? - Equivalence Checking Flow - How to use Conformal LEC - Libraries - Environment Variables - Quartus II settings # **Problems with Simulation** **Approach** - Designs continue to grow in accordance with Moore's law - Effort required to verify these new designs doubles every 6 to 9 months Simulation simply cannot fill the verification gap # What are the Components of Verification? Engineers need to catch functional bugs associated with | Functional Inconsistency | Unintended and unexpected design behavior | |--------------------------|--------------------------------------------------| | Semantic Inconsistency | Introduced by unsafe RTL code | | Logical Inconsistency | Introduced by design implementation process | | Structural Inconsistency | Bus contention, bus floating, tri-state stuck-at | | Initialization | Start-up state problems | | Test Logic | Boundary scan, internal scan, test logic | | Clock Synchronization | Signals cross clock domains w/o proper synch. | Today, most engineers still depend on simulation to catch these bugs. # Growing Need for Equivalence Checking in FPGA - FPGA devices approaching ASIC complexity - Speed, Capacity, SOPC style (embedded memories, Intellectual Property, DSPs, CPU) - ASIC-like design verification challenges in FPGA's - Implementation process involves many netlist changes ### **Equivalence Checking Advantages** - Very high capacity and performance: - Orders of magnitude faster than simulation - Best assurance of design correctness: - 100% complete functional verification without using test vectors - Easy to adopt and use: - Integrates smoothly in existing flows - Effective debugging capabilities - Why Equivalence Checking? - Equivalence Checking Flow - How to use Conformal LEC - Libraries - Environment Variables - Quartus II settings #### Equivalence Checking – Altera Supported - Why Equivalence Checking? - Equivalence Checking Flow - How to use Conformal LEC - Libraries - Environment Variables - Quartus II settings # **Formal Verification Library** <quartus\_install>/eda/fv\_lib Supported families - 1. apex20ke\_atoms.v apex20ke\_bbox.v - 2. apexii\_atoms.v apexii\_bbox.v - 3. cyclone\_atoms.v cyclone\_bbox.v - 4. stratix\_atoms.v stratix\_bbox.v - stratixgx\_atoms.v stratixgx\_bbox.v mfs\_hssi\_bbox.v lpms.v prims.v lpms\_bbox.v mfs\_bbox.v Common set of files that have to be read with all the families #### **Platforms & Tools** - Platforms - Solaris, HP Unix and Linux - Tools - Synplify, Conformal LEC & Quartus II # **Quartus II Settings** Assignment -> EDA **Tools Settings** Set Formal Verification = Conformal LEC ### **Quartus II settings** # IP and Megafunction Support SOPC Design Elements # IP and Megafunction Support Encrypted IP and Mega functions are treated as black boxes Selecting the black box to set the preserve hierarchy property ### **IP and Megafunction Support** Assignment Editor -> preserve hierarchy property -> Firm - Why Equivalence Checking? - Equivalence Checking Flow - How to use Conformal LEC - Libraries - Environment Variables - Quartus II settings #### **POP Quiz** - Formal Verification is performed to verify - 1. Equivalence between RTL to Gate - 2. Functional equivalence between two netlists - 3. Real timing simulation #### **Quiz Answer** - Formal Verification is performed to verify - Functional equivalence between two netlists - Gate level timing - Functional RTL Verification - Synthesis results # **Summary** Advances In Verification Technology Make The Entire Design Cycle Time Shorter Effectively Reducing The Time To Market # Before - •Hardware Emulation/Acceleration - Formal Verification