# Examples of the Practical Application of Al in Design Verification Author and Presenter: Dr. Mike Bartley, Founder/CEO, Alpinum Consulting Co-author: Marmik Soni, Manager, Tessolve Semiconductor ## Outline - An Effective Company-wide Al Strategy - AI/ML Experiments in IP Verification - Al Ecosystem - Collaboration Opportunity - Tool 1: UVM AI Training Tool - Tool 2: Assertify Tool - Tool 3: Spec Extraction Tool - Tool 4: RAG Assessment - Tool 5: UVM TB Automation with Python scripts - Tool 6: Coverage Closure (Flow) - Summary ## An Effective Company-wide Al Strategy - Models are replaceable - Ensure our data is stored to re-train new model releases - Maintaining security - Different set of infra for various security needs - Centre supports innovation at the edge - Bot infra design/ suggestions - Prompt expertise - Model selection - Model adaptation - Al infra migration - Custom solution design - Access control - External tool/ vendor scrutiny #### Central AI services: - Services/Guidance/reviews Central SW services - SW dev services ## AI/ML Experiments in IP Verification ## Al Ecosystem #### Knowledge Bots: - Features: Faster to develop & deploy - Use case: With less confidential data, Project CoPilot - **Security:** Low - Cost: Low - Reasonable accuracy, - Project: UVM Chatbot, FUSA Chatbot Build: Cloud Deploy: Cloud/ Hosting Services - **Feature:** Faster develop & deploy - **Use case:** Client projects, highly confidential data. - Security: High - Cost: High Build: Local Deploy: Local - Features: Slower to develop & slower to deploy - **Use case:** For highly confidential data - Security: High - Cost: High - Challenge: Less Adaptability, less Scalability, Upfront Cost #### Al Apps - DV Spec Analysis Tool - DV AI TB Tool - Assertify Tool - Domain/ Project based AI models - PDK AI Training Tool - •Al Code Copilot ## **Tool 1:** UVM AI Training Tool ## **Organized Content** Follows planned flow ## **Quick Topics** • Most important topics' explanation ## **MCQs** • Test, Evaluation, weak concept suggestions ## **FAQs** • Clarifies on common important doubts ## Q&A • ANY question support #### **About** • Tool briefing for effective use #### **Benefits:** - Self guided and self paced flow - Analytics & custom topic suggestions - Ask anything about UVM - Improved accessibility - Reduced training time - Scalable for other domains ## Tool 1: UVM AI Training Tool ## **Tessolve UVM AI Training Tool** Q&A Chat - Explain UVM Sequencer please! - UVM Sequencer #### Introduction In Universal Verification Methodology (UVM), the sequencer is a key component responsible for controlling the flor sequences that generate complex stimulus and the drivers that convert these stimuli into pin-level activities. **Role of the Sequencer** Developed by AI CoE team ## Tool 1: UVM AI Training Tool # **Tool 2: Assertify Tool** Problems around Assertions are: | Growing Complexity in Verification | Time intensive asks | Human Errors | Lack of Consistency and Skill Gap #### Use case: - 1. Generate Assertions from spec/engineer's simple description using Al models. - 2. Generate description from the SVA code. # Tool 2: Assertify Tool (Description -> SVA) cadence CONNECT TESSOLVE A HERO ELECTRONIX VENTURE | Description | SVA Code | | | |-------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--| | • Ensure that signal <b>a</b> is always high at every rising edge of the clock <b>clk</b> . | <ul> <li>property a_always_high; @(posedge clk) a == 1;<br/>endproperty</li> </ul> | | | | Ensure that signal_x changes its value on every clock cycle. | <ul> <li>property signal_x_changes;</li> <li>@(posedge clk) signal_x !== signal_x[1];</li> <li>endproperty</li> <li>signal_x_changes_check: assert property (signal_x_changes);</li> </ul> | | | | <ul> <li>check if sig_a is down , sig_b may only rise for<br/>one cycle before the next time that sig_a is<br/>asserted.</li> </ul> | <ul> <li>property sig_b_rise_after_sig_a_down; @(posedge clk) (sig_a == 0) -&gt; ##1 (sig_b == 1) ##1 (sig_b == 0) -&gt; (sig_a == 1);</li> <li>endproperty</li> <li>sig_b_rise_after_sig_a_down_check: assert property (sig_b_rise_after_sig_a_down);</li> </ul> | | | # Tool 2: Assertify Tool (SVA -> Description) cadence CONNECT TESSOLVE AHERO ELECTRONIX VENTURE | SVA | Description | |-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | <ul> <li>assert property (@(posedge clk) a<br/> -&gt; ##1 (b throughout [*5]));</li> </ul> | This assertion checks that whenever signal 'a' is true at a rising clock edge, signal 'b' must remain true for the next 5 consecutive clock cycles. | | <ul> <li>assert property (@(posedge clk) disable iff (resetn == 0) (reset == 1));</li> </ul> | The assertion ensures that whenever the system is not in a reset state (i.e., resetn is high), the reset signal must be high. If resetn is low, the check is disabled, allowing the system to remain in reset without triggering this assertion. | | <ul> <li>@(posedge ACLK) disable iff<br/>(!ARESETn) AWVALID &amp;&amp;<br/>AWREADY) -&gt; ##[0:\$] (WVALID &amp;&amp;<br/>WREADY &amp;&amp; WLAST) [*1:\$];<br/>endproperty</li> </ul> | This SystemVerilog assertion checks that whenever AWVALID and AWREADY are both true at the rising edge of ACLK, then eventually WVALID, WREADY, and WLAST will all be true at the same time, at least once, within an unbounded number of clock cycles, provided ARESETn is not deasserted. | # Tool 2: Assertify Tool - Signal match analysis | # | Approach | Top signal | Assertify tool input english description signal | Signal in generated SVA | |----------|----------------------|-------------|-------------------------------------------------|-------------------------| | 1 | Case mismatch | axi_awvalid | AXI_AWVALID | axi_awvalid | | <b>±</b> | Case Illisillateii | axi_awready | AXI_AWREADY | axi_awready | | 2 | Additional character | axi_awvalid | AXIVALID | axi_awvalid | | 2 | | axi_awready | AXIREADY | axi_awready | | 3 | Partial match | axi_awvalid | AXIVLD | axi_awvalid | | 3 | | axi_awready | AXIRD | axi_awready | | 4 | Partial match | axi_awvalid | valid | axi_awvalid | | 4 | | axi_awready | ready | axi_awready | | 5 | Highly mismatch | axi_awvalid | VLD | axi_awvalid | | | | axi_awready | RDY | axi_awready | # **Tool 2: Assertify Tool** ## Tool 3: Spec Extraction Tool - RAG (Retrieval Augmented Generation) Tool for DV Spec Extraction - Inputs: Project Spec, Training Data, - Prompt (Character) - User Prompt - LLM Intelligence - Output ## Flow ## Tool 3: Spec Extraction Tool ## Tool 3: Extraction Process ### **Tessolve Chatbot v6.0** please generate detailed AXI4 feature list with different bus channels, unaligned data transfers, burst based transactions with more details on burst type, burst size and length from the uploaded pdf #### **Detailed AXI4 Feature List** #### 1. AXI4 Bus Channels The AXI4 protocol defines several independent transaction channels to facilitate high-performance and high-frequency system designs. These channels are: - Read Address Channel: Carries control information describing the nature of the data to be transferred for read operations. - Read Data Channel: Transfers data from the slave to the master during read operations. - Write Address Channel: Carries control information describing the nature of the data to be transferred for write operations. - Write Data Channel: Transfers data from the master to the slave during write operations. - Write Response Channel: Signals the completion of the write transfer from the slave to the master. These channels allow for the separation of address/control and data phases, which helps in achieving high-frequency operation without using complex bridges. #### 2. Unaligned Data Transfers The AXI protocol supports unaligned data transfers using byte strobes. This feature is crucial for accessing mixed-endian data structures in a single memory space. The protocol uses a byte-invariant endianness scheme, which ensures that any multi-byte element in a data structure: - Uses the same continuous bytes of memory, regardless of the endianness of the data. - The order of bytes in memory is determined by the endianness, indicating whether the first byte in memory is the most significant byte (MSB) or the least significant byte (LSB) of the element. - Any byte transfer to a given address passes the eight bits of data on the same data bus wires to the same address location, regardless of the endianness of any data element. #### 3. Burst-Based Transactions The AXI protocol is burst-based and defines three burst types: - Fixed Burst: The address remains constant for every transfer in the burst. - Incrementing Burst (INCR): The address increments by the size of the transfer for each transfer in the burst. - Wrapping Burst: The address increments like an incrementing burst but wraps around to a lower address when a wrap boundary is reached. Burst Size # **Tool 4: RAG Assessment** | question | answer | contexts | ground_truth | faithfulness | answer_relevancy | context_recall | context_precision | |---------------------------------------------------------|---------------------------------------------------------|------------------------------------------------------|---------------------------------------------------------|--------------|------------------|----------------|-------------------| | What role do integrated circuits (ICs) play in | Integrated<br>circuits (ICs) are<br>used in virtuall | [Applications in<br>Electronics\nThe ability<br>to c | Integrated<br>circuits (ICs) are<br>fundamental<br>buil | 1.000000 | 0.946481 | 1.00 | 1.0 | | What are the potential future developments in | The future of semiconductors will likely invol | [Future Directions\nThe<br>future of<br>semiconducto | The future of semiconductors is poised for exc | 1.000000 | 0.992269 | 1.00 | 1.0 | | How does<br>Moore's Law<br>relate to the<br>development | Moore's Law<br>predicts that the<br>number of<br>transi | [The Role in<br>Technological<br>Advancement\nThe co | Moore's Law<br>predicts that<br>the number of<br>transi | 0.833333 | 0.936722 | 1.00 | 1.0 | # Tool 5: UVM TB Automation with Python scripts #### Input User should provide Design, Interface, Config (optional), Memory (optional) files. #### **Backend System** - The UVM standard code will be saved in python script. - Python script will extract signals from design and interface files. - By utilizing the extracted signals, the test bench components gets created. #### Output • The UVM testbench components in **System Verilog** format will get saved. **FIFO** - **Single Port RAM** - **Dual Port RAM** - AXI.... Al for Config files, ML for parameter optimization # Tool 5: UVM TB Automation with Python scripts ## Tool 5:: UVM TB Automation - Benefits - ~90% time reduction in the efforts needed for UVM TB generation - Higher accuracy - Consistent process - Less chances of human errors # Tool 5: UVM TB Automation - Challenges New designs may bring unseen challenges # Tool 5: UVM TB Automation - Roadmap - Al to generate config file - Generated TB is completely in control by parameters - Use of AI to optimize parameters ## Collaboration with Al Assisted DV Flow **Register Extraction** Test Plan Generation **Testcases** **Specification Analysis** **Coverage Planning** **Assertions** **Cover points** Testbench Automation **Feature Description** Unit Test Bench Generation Al Agents for Tasks Tool Integration & Automated Validation # **Thank You!** ## Any questions, please reach out Mike Bartley, Founder/CEO, Alpinum Consulting mike@alpinumconsulting.com +44 (0) 7796 307958 Visit our website Book a call LinkedIn Marmik Soni, Technical Manager, Tessolve Semiconductor Pvt Ltd. marmikbhupendrakumar.soni@tessolve.com +91 90339 67780 Marmik Soni | LinkedIn