



DV UVM based AMS co-simulation and verification  
methodology for mixed signal designs

Sandeep Sharma  
Meta reality labs



# Agenda

- AMS verification challenges
- Legacy verification flow
- New MSV architecture
- Mixed signal co-simulation setup
- Verification improvements
- Future work
- Conclusion

# Challenges in AMS Verification

- Handling the complexity of AMS designs
- Automation gap between analog and digital
- Prolonged analog/spice simulation run times
- Integration of analog and digital components
- Ensuring accuracy and performance
- No clear indication of verification completeness



# Digital Verification Advancements

- Easier development and automation of digital design and verification methodologies
- Advanced simulation and formal verification tools enable thorough testing of complex designs
- AI and ML integration
- Hardware description language evolution and standardization

# Limitations of Traditional SPICE Simulation

- Time-consuming nature of SPICE simulation
- Wide performance gap between spice and digital simulators
- Inefficient in handling complex SoC designs
- Lack of integration with digital verification tools



Image source: Cadence design systems

# DUT and Design Environment

- Primary application: sampling real-world signals, process, and propagate to SoC
- Input analog signal amplified by analog front end (AFE) and then Sampled for digital conversion
- Digital data processed by digital ADC controller and loaded into FIFO
- Final digitized data output from subsystem accessed by SoC using SPI interface
- SoC acts as master device and provides clock to AMS subsystem



# Legacy AMS Verification Environment Overview

- Separate workflows for analog and digital verification
- Reduced productivity
- Impact on development time and efficiency
- Misalignment in development schedules
- Challenges in maintaining consistency across designs



# Introduction to New MSV Architecture

- Address limitations with a new MSV architecture
- Digital on top verification strategy
- Leveraging advanced digital verification concepts:
  - UVM
  - SV assertions
  - Coverage analysis and closure
  - Constraint randomization
- Improved functional coverage at chip-level
- Enhanced analog verification through nightly regressions at full digital speeds using DMS simulation



# Mixed Signal Co-Simulation Setup

- Integration of analog spice simulator in DV UVM testbench environment
  - Analog control file
  - AMS control file
- Connect modules for mixed signal co-simulation
- SV and Spice netlist extraction from analog design environment
- Command line simulation script with appropriate simulation switches

# Integration of Analog SPICE Simulator in DV UVM Testbench Environment

- Initially, DV UVM environment only used for digital mixed-signal (DMS) configuration
- Analog simulation engine is used during co-simulation with SPICE
- Analog control file needed to describe analog simulator options

```
1// Analog simulation control file.  
2// It specifies the options and analyses for the Spectre analog solver.  
3  
4simulator lang=spectre  
5  
6global 0  
7  
8simulatorOptions options temp=27 tnom=27 scale=1.0 scalem=1.0 reltol=1e-3 \  
9vabstol=1e-6 iabstol=1e-12 gmin=1e-12 rforce=1 maxnotes=5 maxwarns=5 \  
10digits=5 pivrel=1e-3 checklimitdest=psf  
11  
12tran tran start=1.79m stop=100m write="spectre.ic" writefinal="spectre.fc" \  
13annotate=status maxiters=5  
14  
15finalTimeOP info what=oppoint where=rawfile  
16  
17//modelParameter info what=models where=rawfile  
18//element info what=inst where=rawfile  
19//outputParameter info what=output where=rawfile  
20  
21wave_out options rawfmt=sst2
```

# Integration of Analog SPICE Simulator in DV UVM Testbench Environment

- AMS control file sets up AMS configurations
- Centralizes controls for MS simulations
- Typical contents:
  - Inclusion of analog objects
  - Design configuration (spice vs SV vs verilog-A, etc.)
  - Analog and digital connectivity
  - Supply specification
  - Connect module setup

```
1 // scs
2 simulator lang=spectre
3 include "$AH_ROOT/src/ah_models/misc/includes/amsControlSpectre.scs"
4 include "$AH_ROOT/src/ah_models/afe/afe_top.scs"
5
6 amsd{
7     ie vsup=2.5
8
9     portmap subckt=afe_top_die_a file="$AH_ROOT/src/ah_models/misc/includes/afe_top.pb"
10    config inst=ah_tb.ah_top_1.IANA.I_AFE_CH1.I_afe_top use=spice
11
12    ie connrules=CR_full_fast vsup=2.5 inst=ah_tb.ah_top_1.IANA.I_AFE_CH1 vdelta=0.000001 rout=0
13    ie vsup=2.5 instport=ah_tb.ah_top_1.IANA.I_AFE_CH1.Ibn_50nA_bg currentmode=1 idelta=1e-9 rout=0 rz=5000M
14    ie vsup=2.5 instport=ah_tb.ah_top_1.IANA.I_AFE_CH1.Ibn_50nA_ptat_bg currentmode=1 idelta=1e-9 rout=0 rz=5000M
15    ie vsup=2.5 net=ah_tb.ah_top_1.IANA.I_AFE_CH1.Ibn_250nA_bg_temp currentmode=1 idelta=1e-9 rout=0 rz=5000M
16
17 }
```

# Connect Module Setup for Mixed Signal Co-Simulation

- CM's can be configured within an AMS control file
- Key considerations while configuring CM's:
  - Analog sampling speed
  - Input/output impedance parameters ( $r_{in}$ ,  $r_{out}$ )
  - Nominal supply voltage value ( $v_{sup}$ )
- Incorrect settings can lead to simulation slowdowns or incorrect results
- Careful attention to these parameters is crucial for optimal performance and accuracy



Image source: Cadence design systems

# Advantages of New AMS co-simulation Environment

- Capability to run nightly regressions at full digital speeds (DMS simulations)
- Increase in analog functional coverage at chip level
- Capability to run nightly regressions for co-simulation tests with spice
- Use of SV constraint randomization for DMS and AMS co-simulation
- Use of SV assertions to check digital and spice signals in design hierarchy
- Use of advanced digital tools to analyze and debug simulation

# Nightly DMS and Cosimulation Regressions

- Use of SV-RNM models enhance chip-level verification
- Accelerated verification cycle through digital-speed DMS regressions
- SV-RNM models are key enablers for advancing automated verification methodologies at chip-level
- SPICE Netlist integration enables nightly regressions for co-sim tests
- Robust verification and analog performance evaluation of important design blocks at chip level
- Use of Fast Spice simulators for reduced simulation time

# Increased Analog Functional Coverage at Chip Level

- DMS model integration in DV-UVM eliminated simulation speed bottlenecks.
- Increased execution of functional scenarios led to substantial coverage improvement.
- More robust and thorough analog verification due to use of DV-UVM framework

# SV Constraint Randomization for Co-Simulation

- Use of constraint randomization to avoid excessive verification in both DMS and AMS tests
  - Nightly chip-level tests are conducted
  - In just one week, we can verify seven different configurations with a single AMS spice test.

```

18 `include "ah_seq_list.sv"
19 `include "ah_reset_if.sv"
20
21 import ah_reset_component_pkg::*;
22
23 class ah_adc_dual_8b_test extends ah_base_test;
24   `uvm_component_utils(ah_adc_dual_8b_test)
25
26 constraint test_cfg_c {
27   cfg.ah_cnt inside {1,2,3,4}; //supported range: 1-4
28   cfg.ch0_enb[0] inside {0,1};
29   cfg.ch1_enb[0] inside {0,1};
30   cfg.ch0_enb[1] inside {0,1};
31   cfg.ch1_enb[1] inside {0,1};
32   cfg.ch0_enb[2] inside {0,1};
33   cfg.ch1_enb[2] inside {0,1};
34   cfg.ch0_enb[3] inside {0,1};
35   cfg.ch1_enb[3] inside {0,1};
36   cfg.burst_length inside {16,32,64,128}; //supported range: 16-128
37   cfg.burst_count inside {[1:4]}; //supported range: 1-10
38   cfg.sample_width == 8; //inside {8,10,12}; //supported range: 8-13
39   cfg.clk_sel == ah_enum_pkg::OSC_CLK; //cfg.OSC_CLK; //supported values: OSC_CLK, EXT_CLK
40   cfg.ext_clk_freq_sel inside {EXT_CLK_1, EXT_CLK_2, EXT_CLK_3, EXT_CLK_4};
41   cfg.calib_enb inside {0,1}'h0; //bit
42   cfg.calib_gain == 16'h0082; // 0x80: 1 in 2.7 Fixed Point Format 0x82: 1/128 or 1.015625
43   cfg.calib_offset == 16'h2;
44   cfg.th_enb == 0; //bit
45   cfg.comp_sample_timer == 8'h1; //bit[7:0]
46   cfg.adc_samples == 8'h2; //bit[7:0]
47 }
48
49
50 //Global members
51 virtual ah_reset_if           ah_rst_vif;
52 virtual ah_tb_verif_if        ah_tb_vif;
53
814 function void ah_base_test::randomize_cfg();
815   assert(randomize()) else
816     `uvm_fatal(get_type_name(), "Unable to randomize test configuration")
817
818   `uvm_info(get_type_name(), $sformatf("Test CFG:\n%s", cfg.sprint()), UVM_NONE)
819 endfunction : randomize_cfg

```

# Use of SV Assertions to Check Digital and SPICE Signals in Design Hierarchy

- DV-based UVM testbench enables writing SV assertions to verify key digital and analog nets in AMS and DMS simulations
- SV assertion use for analog nets allows automatic checking, verifying correct device behavior for all possible stimulus variations
- Below snapshot demonstrates SVA on electrical net to check node voltage does not fall below 0.6V

```
540
541 //SV assertions for spice nets:
542
543     check_bg_voltage: assert property (
544         @ (posedge clk)
545         assert_en | -> ##1 $cgav("ah_tb.ah_top_1_IANA.IAFE_CH1.Vbg","potential") < 0.6
546     );
547
```

# Future Work

- Explore SV EEnet Modeling for Analog
- For complex designs, AMS co-simulation flow may not be feasible due to simulation time bottlenecks
- Advanced methodologies like SV EEnet modeling can be leveraged in such scenarios
- SV model capable of modeling electrical quantities (voltage, current, frequency, phase) on a single net using custom user-defined nettypes (UDN)
- Closer to schematic design in terms of electrical accuracy
- SV RNM suitable for transferring single values between blocks, but EEnet required for interactions between modules, such as:
  - Voltage divider relationships with finite resistance
  - Current sources and resistive loads
  - Power supplies responding to changes in load current
  - Capacitive loading effects in certain analog designs

# Future Work

- Adopting UVM-AMS Standard for Mixed Signal Verification
  - DV UVM testbenches lack an easy way to generate analog source signals for analog nodes
  - UVM-AMS methodology under development for improved verification of analog components at system level
  - Unified approach makes UVM more mixed-signal aware, enhancing verification of analog and mixed-signal components/subsystems
  - Objective of UVM-AMS standard is to standardize a method for driving and monitoring mixed-signal nets within UVM, including stimulus, scoreboarding, and analysis

# Conclusion

- Legacy verification flow and gaps discussed
- Command-line-based MSV methodology introduced
- Integration of AMS sub-system testbench into SoC environment
- Incorporation of advanced features at SoC level
- Adaptable environment for multiple projects
- Potential widespread adoption of unified mixed-signal methodology
- More analog designers running mixed-signal verification from command line
- Testing spice blocks at chip level with advanced techniques
- Reuse of advanced testbenches created by DV team
- Highlighted verification improvements following new MSV architecture adoption

# Acknowledgement

- I extend my heartfelt gratitude to the Meta design and DV engineers for their invaluable support and expertise in crafting this innovative AMS verification methodology. Special thanks to:
  - Justin Schauer
  - Joe Dao
  - Kamran Haqqani
  - Hisham Qureshi
  - Atif Malik
  - Chifa Dammak
  - Nirali Patel
- Your contributions have been instrumental in achieving our goals. Thank you for your dedication and assistance throughout this endeavor.

# Questions?