# A MIXED-SIGNAL UNIVERSAL TESTBENCH FOR RTL/DMS/AMS (UTB)

25<sup>TH</sup> OCTOBER 2022 PETER GROVE SENIOR MEMBER OF TECHNICAL STAFF RENESAS ELECTRONICS CORPORATION



© 2022 Renesas Electronics Corporation. All rights reserved.



<u>Acronyms</u>

- Digital Verification (DV)
- Digital-Mixed-Signal (DMS)
- Analog-Mixed-Signal (AMS)

### Often what works in DV/DMS often causes issues in AMS

> Verification techniques need to be adjusted to align with multi-discipline usage.

- > Understanding where to create the stimulus and monitor values.
- > Understanding the implications of a verification procedure has in AMS.
- ➤ How out-of-module references effect Connect Modules.

> Testbench structures need to adjustment to enable smooth dual discipline usage

> Todays focus is on a DMS/AMS testbench and automation, but the same setup works for RTL blocks.



### **UNIFIED TESTBENCH (UTB)**

- Why bother with a Unified TestBench
  - Allows shared resources both in terms of engineers and verification IP between DV, DMS and AMS.
  - Enables fast test case development with DMS modelling before running in AMS at schematic level.
    - Often DMS verification engineers can run the test in AMS without any assistance.
  - Avoids duplication of effort in maintaining numerous testbenches and styles for different disciplines.
  - Creates Verification engineers who are Mixed-Signal skilled. (They can then earn more!)



- Some key requirements to enable a Unified TestBench
  - Ensure the driver connection to any pin can change based on the abstraction of said pin, and easily.
    - E.g. Swap between Logic, real, UDN, electrical with minimal effort, in the physical module layer.
  - Block OOMR's to nodes where the coerced nettype can be different due to model abstraction.
    - Set nets to used 'interconnect' as OOMR's are not allowed, use the VPI Instead for this, <u>SNUG Paper 2022</u>
    - In AMS avoids 'T' style connect module insertion (merged CM), often a cause of issues.
  - Ensure debug of DC-Op is easy for AMS.
  - Limit the number of Connect Modules inserted in the testbench.

### **HOLISTIC CONCEPT**

- <u>2 \$roots</u> modules (UVM Dual Top Methodology)
  - test\_case (TC) to encapsulate the stimulus requests.
  - test\_env (TB) to encapsulate the physical environment such as
    - Pin Drivers, monitor, external components.
    - Could reside in Schematic capture tool
- Scalable approach
  - test\_case can utilize more of a SW methodology.
  - test\_env can use hardware accelerators/emulators.
- Reduces cost by
  - Maximizing reuse between all DUT abstractions
  - Automating a common verification task of creating a TB and UVM environment.



BIG IDEAS FOR EVERY SPACE

RENESAS

### **AUTOMATED TESTBENCH REQUIREMENTS**

- Able to generate a TB either from an RTL definition, netlist, or schematic symbol view.
- Support complex port structures for pure RTL DUT's. (OpenAccess limits support on schematics to 1-dimensional arrays.)
  - Multi-dimensional arrays mixing packed and unpacked sizes.
  - System Verilog Interfaces
  - Parameterised port sizes whether in a SV IF or not for a parameterised TB.
- Use only valid constructs in 1800-2012 LRM in the generated code. No vendor extensions!
  - Allows other parsers/tools to read the generated code. Vendor extensions are often limited to just one tool not all.
- Easy of use, regeneration and configuration. (Don't be a burden to the users!)
  - Support user code within generated files and structure it so template code is never needed to be hacked.
- Partition filelists/command line arguments so it easy to add/remove some option. E.g. UPF, Code coverage
- Work in harmony with Virtuoso (or your schematic framework tool) for DMS/AMS netlisting and integration.









### WHY IMPORT DMS/AMS TESTBENCH INTO SCHEMATIC TOOL?

- Schematic Capture tools come with netlisters and hierarchy editors (HED).
  - The hierarchy editor provides a nice and easy way to configure the design via a GUI.
  - Netlisters use the hierarchy editor to extract a netlist with a binding configuration file.
  - Makes sharing the testbench between DMS and AMS a lot easier.
  - Support text views just as well as schematic based views
    - So can work for digital-on-top or analog-on-top
- Pro's
  - Creating a binding file by hand can be error prone so use a tool.
    - E.g. lib.map and Verilog-Configuration files.
  - Far easier to stitch a design together for AMS, where spice uses order connection.
  - Graphical view of the hierarchy to easily root cause binding mistakes.
- Con's
  - Conditional typology within text views will not work, whether with a parameter or generate statement.
  - Generate statements can cause issues as the netlister/HED will not know what path to follow.
  - Not what a 'digital' guy would want to use.

| ile <u>E</u> di           | it <u>V</u> iew <u>P</u> lugins <u>H</u> elp                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |                                                                                                                              | cāde                                                                                                                                                                            | nce   |
|---------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|
| 6                         | । 🖓 🕹 🥱 🥐 🖧 🛈 🗁 😂                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |                                                                                                                              |                                                                                                                                                                                 |       |
| op Cell                   | ? 8                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | Global Binding                                                                                                               | js                                                                                                                                                                              | ? 🖥 X |
| .ibrary:                  | EEC119_ramirtha                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | Library List:                                                                                                                | myLib                                                                                                                                                                           |       |
| Cell:                     | lab3_add32_tb                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | View List:                                                                                                                   | \$default                                                                                                                                                                       |       |
| /iew:                     | schematic                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | Step List.                                                                                                                   | aniaa uavilaa uavilaabtattiat                                                                                                                                                   |       |
|                           |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | Stup Lise                                                                                                                    | spice venioù venioùneuisi                                                                                                                                                       |       |
|                           |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                                                                                                                              |                                                                                                                                                                                 |       |
| Open<br>Table<br>Target   | Edit<br>View Tree View<br>: Instance                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | Constraint List                                                                                                              | Inherited View List                                                                                                                                                             |       |
| Open<br>Table<br>Target   | Edit<br>View Tree View<br>: Instance<br>(FEC119 ramitha Jab3, adi32, th schemalic)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | Constraint List                                                                                                              | Inherited View List                                                                                                                                                             |       |
| Open<br>Table<br>Target   | Edit  View Tree View  Instance  Instance  (EEC119_ramitha lab3_add32_tb schematic)  Il11 (EEC119_ramitha invCC_1x functional)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | Constraint List                                                                                                              | Inherited View List                                                                                                                                                             |       |
| Table<br>Table            | Edit  View Tree View  Instance  (EEC119_ramitha lab3_add32_tb schematic)  EEC119_ramitha invCC_1x functional)  112 (EEC119_ramitha inv_1x schematic)  112 (EEC119_ramitha inv_1x schematic)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | Constraint List:                                                                                                             | Inherited View List<br>\$default                                                                                                                                                |       |
| Table<br>Targel           | Edit<br>View Tree View<br>Instance<br>(EEC119_ramitha lab3_add32_tb schematic)<br>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | Constraint List                                                                                                              | Inherited View List<br>\$default<br>\$default<br>\$default                                                                                                                      |       |
| Table                     | Edit<br>View Tree View<br>Instance<br>(EEC119_ramitha lab3_add32_tb schemelic)<br>II1 (EEC119_ramitha inv_CC_1× functional)<br>II1 (EEC119_ramitha inv_1x schematic)<br>III (EEC119_ramitha addr32b schematic)<br>III (V0b-31-0; CEEC119_ramitha addr32b schematic)<br>III (V0b-31-0; CEEC119_ramitha invCC_1x schematic)<br>III (V0b-31-0; CEEC119_ramitha invCC_1x schematic)<br>IIII (V0b-31-0; CEEC119_ramitha invCC_1x schematic)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | Constraint List                                                                                                              | Inherited View List<br>\$default<br>\$default<br>\$default<br>\$default                                                                                                         |       |
| Table<br>Target           | Edit  View Tree View  Instance  Instance  (EEC119_ramirtha inb3_add32_tb schematic)  I11 (EEC119_ramirtha inv_CC_1× functional)  I12 (EEC119_ramirtha inv_CC_1× functional) I12 (EEC119_ramirtha inv_CC_1× schematic) I14V06vt-31.0+ (EEC119_ramirtha invCC_1× schematic) I14V06vt-31.0+ (EEC119_ramirtha invC_1× schematic) I14V06vt-31.0+ (EEC119_ | Constraint List<br>View To Use<br>schematic<br>schematic                                                                     | Inherited View List<br>\$default<br>\$default<br>\$default<br>\$default<br>\$default<br>\$default                                                                               |       |
| Table<br>Target           | Edit  View Tree View  Instance  Instance  (EEC119_ramitha lab3_add32_tb schematic)  I12 (EEC119_ramitha invCC_1× functional)  I12 (EEC119_ramitha invCC_1× functional)  I12 (EEC119_ramitha invCC_1× schematic)  I1470b.431.05 (EEC119_ramitha invCC_1× schematic)  I1470b.(EEC119_ramitha invCC_1× schematic)  I1471b (EEC119_ramitha invC_1× schematic)  I1471b ( | Constraint List<br>View To Use<br>schematic<br>schematic                                                                     | Inherited View List<br>\$default<br>\$default<br>\$default<br>\$default<br>\$default<br>\$default                                                                               |       |
| Table                     | Edit  View Tree View  Instance  Instance  (EEC119_ramitha invCC_1x functional)  IDUTA0 (EEC119_ramitha invCC_1x functional)  IDUTA0 (EEC119_ramitha invCC_1x schematic)  IDUTA0 (EEC119_ramitha invCC_1x functional)  IDUTA0 (EEC119_ramitha invCC_1x schematic)  IdV0bx31.0• (EEC119_ramitha invCC_1x functional)  IdV1bt (EEC119_ramitha invCC_1x functional)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | Constraint List<br>View To Use<br>schematic<br>schematic<br>schematic<br>schematic                                           | Inherited View List<br>\$default<br>\$default<br>\$default<br>\$default<br>\$default<br>\$default<br>\$default<br>\$default                                                     |       |
| Open (<br>Table           | Edit  View Tree View  Instance  Instance  Instance  Itestones  Itestones Itestones Itestones Itestones Itestones Itestones Itestones Itestones Itestones Itestones Itestones Itestones Itestones Itestones Itestones Itestones Itestones Itestones Itestones Itestones Itestones Itestones Itestones Itestones Itestones Itestones Itestones Itestones Itestones Itestones Itestones Itestones Itestones Itestones Itestones Itestones Itestones Itestones Itestones Itestones Itestones Itestones Itestones Itestones Itestones Itestones Itestones Itestones Itestones Itestones Itestones Itestones Itestones Itestones Itestones Itestones Itestones Itestones Itestones Itestones Itestones Itestones Itestones Itestones Itestones Itestones Itestones Itestones Itestones Itestones Itestones Itestones Itestones Itestones Itestones Itestones Itestones Itestones Itestones Itestones Itestones Itestones Itestones Itestones Itestones Itestones Itestones Itestones Itestones Itestones Itestones Itestones Itestones Itestones Itestones Itestones Itestones Itestones Itestones Itestones Itestones Itestones Itestones Itestones Itestones Itestones Itestones Itestones Itestones Itestones Itestones Itestones Itestones Itestones Itestones Itestones Itestones Itestones Itestones Itestones Itestones Itestones Itestones Itestones Itestones Itestones Itestones Itestones Itestones Itestones Itestones Itestones Itestones Itestones Itestones Itestones Itestones Itestones Itestones Itestones Itestones Itestones Itestones Itestones Itestones Itestones Itestones Itestones Itestones Itestones Itestones Itestones Itestones Itestones Itestones Itestones Itestones Itestones Itestones Itestones Itestones Itestones Itestones Itestones Itestones Itestones Itestones Itestones Itestones Itestones Itestones Itestones Itestones Itestones Itestones Itestones Itestones Itestones Itestones Itestones Itestones Itestones Itestones Itestones Itestones Itestones Itestones Itestones Itestones Itestones Itestones Itestones Itestones Itestones Itestones Itestones Itestones Itestones Ite | Constraint List<br>Constraint List<br>View To Use<br>schematic<br>schematic<br>schematic<br>schematic                        | Inherited View List<br>\$default<br>\$default<br>\$default<br>\$default<br>\$default<br>\$default<br>\$default<br>\$default<br>\$default<br>\$default<br>\$default<br>\$default |       |
| Open (<br>Table<br>Target | Edit  View Tree View  Instance  Instance  (EEC119_ramirtha inv_CC_1x functional)  II1 (EEC119_ramirtha inv_CC_1x functional)  II1 (EEC119_ramirtha inv_CC_1x functional)  II1 (EEC119_ramirtha inv_CC_1x schematic)  II1 (V0b<31.0> (EEC119_ramirtha invCC_1x schematic)  II1 (V10cEC119_ramirtha invCC_1x schematic)  II1 (V10cEC119_ramirtha invCC_1x functional)  II1 (V10cEEC119_ramirtha invCL)  II1 (V10cEEC119_ramirtha invCL)  II1 (V10cEEC119_ramirtha invCL)  II1 (V10cEEC119_ramirtha invCL)  II1 (V10cEEC | Constraint List<br>View To Use<br>schematic<br>schematic<br>schematic<br>schematic<br>)<br>schematic                         | inherited View List<br>\$default<br>\$default<br>\$default<br>\$default<br>\$default<br>\$default<br>\$default<br>\$default<br>\$default<br>\$default<br>\$default<br>\$default |       |
| Open                      | Edit  View Tree View  Instance  Instance  (EEC119_ramirtha lab3_add32_tb schematic)  I11 (EEC119_ramirtha inv_CC_1× functional)  I12 (EEC119_ramirtha inv_CC_1× functional) I13 (EEC119_ramirtha invCC_1× schematic) IIdY0bvc31.0+ (EEC119_ramirtha invCC_1× schematic) IIdY0bvc31.0+ (EEC119_ramirtha invC_1× schematic) IIdY1b (EEC119_ramirtha invC_1× schematic) IIdY1b (EEC119_ramirtha invC_1× functional) IIdY1b (EEC119_ramirtha invC_1× functional) IIdY1b (EEC119_ramirtha invC_1× schematic) IIdY1b (EEC119_ramirtha invC_1× functional) IIdY1b (EEC119_ram | Constraint List<br>Constraint List<br>View To Use<br>schematic<br>schematic<br>schematic<br>)<br>schematic<br>)<br>schematic | Inherited View List<br>\$default<br>\$default<br>\$default<br>\$default<br>\$default<br>\$default<br>\$default<br>\$default<br>\$default<br>\$default<br>\$default<br>\$default |       |

## **PHYSICAL TESTBENCH COMPONENTS**

- Logic drivers/monitors
- Electrical drivers/monitors
- Passives Components/Networks
- Analog load models
- Digital UVC's



RENESAS

BIG IDEAS FOR EVERY SPACE

#### To share the testbench between DMS and AMS these components need multiple views

### **POSSIBLE LOGIC INSTRUMENT** DRIVER/MONITOR FOR LOGIC PINS IN DMS/AMS



- **lio** pin connects to DUT logic pin
- **ref\_vdd/ref\_vss** connect to an 'electrical' node for Connect Modules in AMS, unused in DMS/DV.
- **bypass\_logic** used as bidirectional connection to lio other stimulus to DUT pin that is parametrised.
  - Multiple UVC's can be connected to this node.
- SystemVerilog Interface (SV IF) / Proxy to enable class based interaction.



### POSSIBLE ELECTRICAL INSTRUMENT EXTENDS LOGIC INSTRUMENT



Source Gen is a real number passed to the driver stage.

In **AMS** Source Gen, Driver, and Monitor is in an analog statement.

- bypass\_real pin is a unidirectional input stimulus that is parameterised.
- out pin is the 'Electrical' output.
  - Support of Voltage, Current or Tristate output, with optional compliance.
- ref\_vdd/ref\_vss used to level shift logic to Voltage level in DMS and AMS.
- SystemVerilog Interface (SV IF) / Proxy to enable class based interaction.

### **ANALOG SIGNAL GENERATION**

- Analog Signal generation MUST be done in electric\_instrument\_core, not the UVM sequencer. (See UVM-AMS)
  - Ensure the right domain is used for 'electrical' signal generation ensuring best simulation runtime performance.
  - Signal instructions for sine wave, like frequency, phase and amplitude sent as a request to the drivers core.
    - Any change to variables used in analog statement is seen as a D2A event generating an analog matrix evaluation. \$\$\$
    - Enables the analog solver to choose the best simulation timestep to use. (dynamic timestep algorithm)
    - DMS can choose the number of samples to create per period, for accuracy/performance
- Surely I can do this digitally (only if you can be sure the hidden issues don't cause verification issues)
  - AMS *transition* filter statement must have a tolerance of 0 and tr/tf must be exactly the same as the digital period for each sample.
    - Analog solvers rely on tolerances so a setting of 0 is bad and probably ignored. (Issue 1)
  - D2A event may not be exactly when digital happens but femto seconds later depending on the analog solver. Nasty harmonics! (<u>Issue 2</u>)
  - D2A event could create an unnecessary analog matrix solution to get good enough signal quality. (Issue 3)





### **ANALOG SIGNAL MONITORING**

- Analog Signal monitoring is **BEST** be done in electric\_instrument\_core, not the UVM sequencer. (See UVM-AMS)
  - Verilog-AMS has only the absdelta function to take a analog value and convert to a digital variable.
    - Can cause excessive A2D events slowing down simulations.
    - Can miss key values due to tolerances.
    - No one size fits all set of values, it depends on the signal been monitored.
  - Use analog statement to implement checkers and pass result to digital.

### **PASSIVES OR OTHER COMPONENTS**

- Use a SV wrapper module around a core element.
  - Core element is swapped from DMS, AMS or other views based on abstraction.
  - SV wrapper to enable software connection to test\_case module via intf/Proxy.
  - Renesas donation, including code/example, to create UVM-AMS.



# TEST\_ENV

- Each pin has a Logic or Electrical Instrument
- Users have the ability to add electrical models/components to electrical pins.
  - Cap, Res, Ind and maybe other electrical instruments on these networks, or instance a schematic for example.
- Support parameters on instances to set initial values for UVM config DB.
- Users can easily hook-up a bespoke logic driver(s) to the **bypass\_logic**, e.g. I2C, SPI,SPMI etc.
- Users can easily create arbitrary reals signals via bypass\_real
- Limit OOMR by using 'interconnect' for connectivity. (Except where datatype is fixed whether run in DMS or AMS.)
  - For DMS/AMS everything used interconnect other than bypass\_logic connections.
- Limit user code to tb\_analog\_comps, tb\_analog\_bypass\_real and tb\_digital\_bypass\_logic modules.
- Support many use cases:
  - System level mixed signal (chip) to support AMS and/or DMS simulations
  - System/subsystem level mixed signal to support DMS only
  - Analogue block level schematic/model to support AMS/DMS
  - Pure digital block level for DV and DMS

### **TESTBENCH PHYSICAL STRUCTURE**





### **TESTBENCH PHYSICAL STRUCTURE**



- Instance logic instruments for 'digital' ports
  - Ports unravelled so one instrument per bit
    - SVIF unravelled to *lio* port per bit.
  - Parameterised ports utilize generate loops.
- ref\_vdd/vss usually connect to one of DUT pins for AMS.
   Option have this as a TB only net.
- Ideal\_Ground also ported in from tb\_analog\_ports, which is the node 0 for a reference.
- bypass\_logic constructed to align with DUT port.
  - > SVIF recreated per bit connection.
  - Parameterised ports supported.

### **ADDING DIGITAL UVC'S**





#### Logic Instruments set bypass\_logic path

- Simple tranif1 statement between lio and bypass\_logic pin
- Net collapsing means there is little to no runtime cost.

#### • Electrical Instruments set bypass\_logic path

- Bidirectional level shifter in the path. (A2D and D2A)
- Rest comes from logic instrument instanced in electrical instrument.
- Instance I2C SV Interface in tb\_digital\_bypass\_logic
- Use existing I2C Interface and API to do I2C reads/writes whether DUT is DMS or AMS.
- Internals to tb\_digital\_bypass\_logic can use any SV constructs as always treated as digital in all use cases.
- Default is tb\_digital\_bypass\_logic ports are driven with 1'bz.



### ATTACHING A DCDC BUCK OUTPUT FILTER



- Components default values can be on the instance.
- Utilize Simulator scheduling to reprogram the DUT components via the test case rather than via view binding.
  - In AMS this can be before a DC-OP has happened but after the matrix is formed.

RENESAS

**BIG IDEAS FOR EVERY SPACE** 

#### Normal Usage

- FB instrument can act as load.
- LX instrument is left as tristate.
- Control ind/cap settings controlled by API.

#### ATE testing

- FB instrument can act as source/load.
- LX instrument can act as source/load.
- ind/cap act as open via API.
- Optional DMS (based on DCDC model)
  - Views of components are empty modules.

### TESTCASE

- test\_case kept as separate top level module for the software layer.
  - Imports UVM
  - Include file for all the user packages that need importing.
  - Import for base package
  - Include file for base environment that extend uvm\_env
  - Base test class that extend uvm\_test
    - Contains all test case classes for run time selection.
    - Could be autogenerated when a simulation is run, allowing filtering to tests to include/exclude.
  - <u>One</u> Initial block that calls run\_test() for UVM.
- Template test case class sets the instruments and other components at time 0 pre DC-OP.
  - Allows reconfiguration of the electrical instrument and other electrical components before DC-OP
    - Step change cap values or instrument mode without convergence issues. Save numerous DUT configurations.
  - Electrical instruments default to 0V or 0A so DC-OP is easily found!
    - Value changes requested after at least #(1step) has happened.

### VERILOG-AMS SIMULATOR SCHEDULING – TIME 0



### **AMS/DMS START-UP AND PHASING**



(Optional) Modify params from UVM test

virtual function void my\_test::end\_of\_elaboration\_phase(...); env.agent.cfg.rseries = 1e4; // 10k rseries in this test endfunction : end\_of\_elaboration\_phase

RENESAS

### AMS/DMS STARTUP IN UVM RUN\_PHASE()



RENESAS

### **MAKETB SCRIPT**





BIG IDEAS FOR EVERY SPACE

logic hookup

instrument

instrument

# **DUT PIN CONFIGURATION**

#### From DUT's definition

#### **User Controls**

| 4  | A             | В               | С         | D                  | E                   | F           | G              | Н            |                 | J              | K             |         | L               | M   | N        |
|----|---------------|-----------------|-----------|--------------------|---------------------|-------------|----------------|--------------|-----------------|----------------|---------------|---------|-----------------|-----|----------|
| 1  | <u>Module</u> | <u> PinName</u> | <u>10</u> | PackedDims         | <u>UnpackedDims</u> | Input Class | Input Subclass | Output Class | Output Subclass | <u>Default</u> | <u>Vddsrc</u> | Vsss    | r <u>c ActH</u> | Act | <u>1</u> |
| 2  | loop_ctl      | rst_n           | input     |                    |                     | Digital     | Digital_Input  |              |                 | 1'b0           | IDEAL_G       | IDEA    | L_GND           |     |          |
| 3  | loop_ctl      | clk             | input     |                    |                     | Digital     | Digital_Input  |              |                 | 1'b0           | IDEAL_G       | SN IDEA | L_GND           |     |          |
| 4  | loop_ctl      | ticks           | input     | [P_TICK_WIDTH-1:0] |                     | Digital     | Digital_Input  |              |                 | {22 {1'b0}}    | IDEAL_G       | IDEA    | L_GND           |     |          |
| 5  | loop_ctl      | set_vsys_       | input     | [2:0]              |                     | Digital     | Digital_Input  |              |                 | {3 {1'b0}}     | IDEAL_G       | SN IDEA | L_GND           |     |          |
| 6  | loop_ctl      | set_vbat_       | input     | [6:0]              |                     | Digital     | Digital_Input  |              |                 | {7 {1'b0}}     | IDEAL_G       | SN IDEA | IL_GND          |     |          |
| 7  | loop_ctl      | vbat_chg_       | input     | [9:0]              |                     | Digital     | Digital_Input  |              |                 | {10 {1'b0}}    | IDEAL_G       | SN IDEA | L_GND           |     |          |
| 8  | loop_ctl      | set_iprec       | input     |                    |                     | Digital     | Digital_Input  |              |                 | 1'b0           | IDEAL_G       | SN IDEA | L_GND           |     |          |
| 9  | loop_ctl      | set_ilim_       | input     | [7:0]              |                     | Digital     | Digital_Input  |              |                 | {8 {1'b0}}     | IDEAL_G       | SN IDEA | L_GND           |     |          |
| 10 | loop_ctl      | set_itopo       | input     | [4:0]              |                     | Digital     | Digital_Input  |              |                 | {5 {1'b0}}     | IDEAL_G       | IDEA    | L_GND           |     |          |
| 11 | loop ctl      | ibat chg        | input     | [7:0]              |                     | Digital     | Digital Input  |              |                 | {8 {1'b0}}     | IDEAL G       | IDEA    | l GND           |     |          |

- DUT's IO defines port direction input/output/inout/SV IF, name and diamensions.
- User Controls
  - Class is Digital/Analog
    - Sub Class defines it default configuration. E.g. Analog class, has subclass options like V\_Analog\_Input.
  - Default is the default drive value if an input.
  - Vddsrc/Vssrc define connections to ref\_vdd/ref\_vss on instruments to set logic levels



## WORKFLOW



- RTL passed to make\_testbench.pl for DUT IO details
  - Cadence's oa2verilog used if DUT is a schematic in dfII
  - Ports/Parameters used to create/update config.xlsx
- Editing of config.xlxs
  - Control pins' function/parameter values
  - Auto-insertion of some digital components into tb\_digital\_bypass\_logic
- Import into dfll for DUT's for a schematic.
  - Unix script for those 'digital' guys
- Netlisting can use Cadence's VSVN or UNL-AMS.
  - Unix script for those 'digital' guys
- Simulation will run out the box!

### **FILE LIST PARTITIONING**

- Source code and command line arguments order is important.
  - SV Packages must be parsed before imported. E.g. UVM often is the first to be required.
  - Leaf modules should be parsed before instanced.
  - Make use of -v/-y for libraries.
- Enable ease of control
  - Whether an feature is required or not. E.g. Code Coverage, GLS or RTL.
  - Switching from running a DMS simulation to an AMS one.
- Suggested order;
  - Defines
  - UVM
  - Other Packages based on order dependencies.
  - Interfaces
  - Leaf modules

### FILELIST PARTITIONING EXAMPLE

| Cadance             | Synopsys           | Description/Contents                                                                                | Order # |  |  |
|---------------------|--------------------|-----------------------------------------------------------------------------------------------------|---------|--|--|
| xrunargs.c.f        | vcsargs.c.f        | C code command line switches.                                                                       |         |  |  |
| xrunargs.com.f      | vcsargs.com.f      | General command line switches.                                                                      | 3       |  |  |
| xrunargs.cov.f      | vcsargs.cov.f      | Code Coverage command line switches.                                                                |         |  |  |
| xrunargs.uvc.f      | vcsargs.uvc.f      | UVC's                                                                                               | 5       |  |  |
| xrunargs.last.f     | vcsargs.last.f     | Last *.f file in generated file list if there are specific options that must be last.               |         |  |  |
| xrunargs.msg.f      | vcsargs.msg.f      | Command switch to control simulator messages.                                                       | 4       |  |  |
| xrunargs.rtl.f      | vcsargs.rtl.f      | RTL level command line switches.                                                                    |         |  |  |
| xrunargs.sdf_fast.f | vcsargs.sdf_fast.f | Settings for SDF fast corner files                                                                  |         |  |  |
| xrunargs.sdf_slow.f | vcsargs.sdf_slow.f | Settings for SDF slow corner files                                                                  |         |  |  |
| xrunargs.uvm.f      | vcsargs.uvm.f      | UVM command line switches.                                                                          | 1       |  |  |
| xrunargs.vhdl.f     | vcsargs.vhdl.f     | VHDL code command line switches.                                                                    |         |  |  |
| sdf.fast.cmd        | -                  | Cadence SDF control file for the fast corner                                                        |         |  |  |
| sdf.slow.cmd        | -                  | Cadence SDF control file for the slow corner                                                        |         |  |  |
| sdf.tfile           | sdf.vcs.cmd        | File to control timing checks, such as disabling them on sync cells.                                |         |  |  |
| files.com.f         |                    | Files, incdir, defines and libraries that are needed for the test_env and test_case hierarchy. E.g. | 2       |  |  |
|                     |                    | packages/interfaces                                                                                 |         |  |  |
| files.hw.f          |                    | Files for the test_env hierarchy excluding the DUT netlist.                                         | •       |  |  |
| files.sw.f          |                    | Files for the test_case hierarchy.                                                                  |         |  |  |

### **CURRENT LIMITATIONS**

- Good open source SystemVerilog Parsers/Elaborators are hard to find. Some recent ones look promising.
- Getting IO details can require pre and post elaboration details. E.g. Width of Enum's defined in package file.
  - Order of package file search is required.
- Currently using the Verilog-Perl parser the Renesas implementation can't handle
  - Nested SV interfaces.
  - Ports using packages to define the datatype. (Requires elaboration)



