



# **Mixed Mode Simulation**

P. Fischer

Lehrstuhl für Schaltungstechnik und Simulation ZITI, Uni Heidelberg

(Based on slides from Florian Erdinger)

VLSI Design - Mixed Mode Simulation

© P. Fischer, ZITI, Uni Heidelberg Page 1

### Why Simulate in Mixed Mode?

- Most analog circuits need interaction with digital circuits
  - control logic to steer the analogue part
  - processing / verification of results
- Simple digital functionality can be obtained by spice sources (vpulse, vpwl,...), but this is tedious, inflexible,...
- (More flexibility by using Verilog-A. Good for simple extensions (DAC..), but not suited for large digital parts)

### $\rightarrow$ Mixed Mode Simulation:

- Digital parts:
  - Hardware Description Language (Verilog, VHDL) very flexible
  - Digital simulator
- Analog parts:
  - Schematics
  - Analog simulator

### Mixed Mode Simulation

- Two simulators run in parallel
  - Digital Sim. for digital part, Analogue sim. for analogue part
  - Interface Elements translate between domains (what is 'True'?)
- Time must be (internally) synchronized between the sim.



- Advantages:
  - Complex steering / logic easy to implement
  - **Much** faster simulation in large designs (once it runs...)
- Drawbacks:
  - More complex.
  - Long simulator startup.



- There are many ways to do a Mixed Mode Simulation.
- I show here just one solution, which is easy to use for a start, but not so well suited for larger designs
- For large designs, it is efficient to
  - first produce all 'netlists'
  - work 'on the shell' to put things together and set up and run the simulation

These slides

• Extract results with a graphical viewer of automatically

Jargon: 'Digital on Top' vs. 'Analog on Top'



### What do we Need?





# A SIMPLE EXAMPLE

## Workflow

- The following slides show how to set up a simple Mixed Mode Simulation in the Virtuoso ADE environment. Steps:
  - 1. Creating a *Verilog module* for stimulus with a matching *symbol*
  - 2. Creating a *top-level simulation schematic* instantiating the Verilog symbol and some analog circuit connected to it
  - 3. Creating a 'config' view of the top-level simulation schematic
  - 4. Edit the config view telling the simulation what to do
  - 5. Simulate using the AMS simulator



Note: The interface elements are created more or less automatically...

- We need to make the 'connectlib' available.
- Check your cds.lib or see in the library manager

Make sure you have the line SOFTINCLUDE \$IUSDIR/tools/inca/files/cds.lib

If this does not work, add it explicitly by adding SOFTINCLUDE /net/eda/INCISIV102/tools.lnx86/affirma\_ams/ etc/connect\_lib/cds.lib

### 1a. Creating a New Verilog Module

| File                                     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| rife                                     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| Library                                  | VLSI2324                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| Cell                                     | VLSI2425_Stimulus                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| View                                     | functional                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| Туре                                     | Verilog                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| Application                              |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| Open with                                | Text Editor                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| -                                        | his application for this type of file                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| Aiways use t                             | his application for this type of hie                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| Library path file                        | :                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| /home/fische                             | r/cadence/umc_018/0A/cds.lib                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
|                                          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|                                          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|                                          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|                                          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|                                          | OK Cancel Help                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|                                          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|                                          |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| Text Edi                                 | tor (Verilog) Ve A _                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| _                                        | tor (Verilog) Ve 🔺 💷 🗙                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| Launch File                              | tor (Verilog) Ve × _ □ ×<br>Edit View Create » cādence                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| Launch File                              | tor (Verilog) Ve 🔺 💷 🗙                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| Launch File                              | tor (Verilog) Ve A _ D X<br>Edit View Create » cādence                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| Launch File L<br>C - » Ba<br>1 //Verilog | tor (Verilog) Ve ∧ _ □ ×<br>Edit View Create »cādence                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| Launch File I                            | tor (Verilog) Ve A _ O X<br>Edit View Create » cādence<br>Control Control |
| Launch File I                            | tor (Verilog) Ve A _ O X<br>Edit View Create > cadence<br>Sic > > 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| Launch File I                            | tor (Verilog) Ve A _ O X<br>Edit View Create > cadence<br>Sic > > 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| Launch File I                            | tor (Verilog) Ve A _ O X<br>Edit View Create > cadence<br>Sic > > 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| Launch File I                            | tor (Verilog) Ve A _ O X<br>Edit View Create > cadence<br>Sic > > 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| Launch File I                            | tor (Verilog) Ve A _ O X<br>Edit View Create > cadence<br>Sic > > 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| Launch File I                            | tor (Verilog) Ve A _ O X<br>Edit View Create > cadence<br>Sic > > 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
| Launch File I                            | tor (Verilog) Ve A _ O X<br>Edit View Create > cadence<br>Sic > > 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |

- We will use this module to generate a rectangular signal to stimulate our analogue circuit.
- In 'Library Manager:
  - File  $\rightarrow$  New  $\rightarrow$  Cell View
  - 'Cell': name of verilog module
  - 'Type': Verilog
  - 'View': will change to 'functional'
- The Cadence text editor opens with an empty Verilog module

## 1b. Fill the Verilog Module

- Fill the Verilog module with some code.
  - The code does *not* have to be synthesizable
- You may use parameters.
- For instance

(1 time step = 1 ns by default)

- When you close the text file, it is automatically parsed. This takes a moment.
- Correct it until there are no errors left.



- In my editor, the log file can be seen with View->Parser Log
- Error messages of Verilog compilation end up in .cadence/dfII/TextSupport/Logs/Parser/verilog...
- Use the latest file there

### 1c. Create the Symbol

- When the Verilog file is closed, the tool offers to create a symbol if there is none (or to modify an existing symbol which does not fit to the declared interface).
- Create the symbol.
- You may then edit the symbol to make it nicer.

## 2. Creating A Top-Level Simulation Module

- In 'Library Manager'
  - File  $\rightarrow$  New  $\rightarrow$  Cell View
  - Create a schematic



- Put an instance of your Verilog module, i.e. the symbol
- If the Verilog contains *parameters*, the symbol inherits them.
  - To see them: In the instantiated symbol, select CDF Parameter of view -> functional (not 'Use Tool Filter')
- Add some analog circuit (symbols, primitives, sources, ...) which can also be in symbols.

## 3. Creating the Simulation Configuration View

|              | New File             | •             | Ф 🗆 8         | ×            |      |         |      |
|--------------|----------------------|---------------|---------------|--------------|------|---------|------|
| File         |                      |               |               |              |      |         |      |
| Library      | VLSI2020             |               |               |              |      |         |      |
| Cell         | MixedSi              | m2            |               |              |      |         |      |
| View         | config               |               |               |              |      |         |      |
| Туре         | config               |               | 3             |              |      |         |      |
| Application  |                      | _             |               |              |      |         |      |
| Open with    | Hierarchy            | Editor 🔽      |               |              |      |         |      |
| Always us    | se this application  | for this type | of file       |              |      |         |      |
| Library path | file                 |               |               |              |      |         |      |
| $\odot$      |                      | New Confi     | guration      |              | 2    | $\odot$ | Ģ    |
|              | 1ixedSim<br>chematic |               |               |              |      | -       |      |
| Global Bir   |                      |               | Use Template  |              | 0 0  |         |      |
| Library Li:  | r 🔾 🛇                |               | ose rempiace  |              | 00   | 0       |      |
| View List:   | Name: AM             | ИS            |               |              |      |         |      |
| Stop List:   | From File: 7h        | ome/fischer/  | hierEditor/te | mplates      | /AMS |         |      |
| Constraint   |                      |               |               |              |      |         |      |
| Descriptic   | •                    | OK Ca         | ncel Ap       | ply)         | Help |         |      |
|              |                      |               |               |              |      |         |      |
|              |                      |               |               |              |      | $\succ$ |      |
|              |                      |               |               |              |      |         |      |
|              |                      |               |               |              |      |         | - J. |
|              |                      |               |               |              |      |         |      |
|              | -                    |               |               | $\checkmark$ |      |         |      |

- The AMS simulator needs a 'config' view for the simulation schematic
- In 'Library Manager:
  - Select your simulation schematic
  - File  $\rightarrow$  New  $\rightarrow$  Cell View
  - 'Type': config (name changes to 'config')
- Note that 'Application' switches automatically to 'Hierarchy Editor'
- In the next window: change 'View' to 'schematic'
- Click 'Use Template' (bottom)
  - Select 'AMS' (this will be our simulator)

• OK

OK

# 4. Changing 'config' view with the Hierarchy Editor

- The config view is edited in the 'Hierarchy Editor' and configures the netlisting procedure for simulation.
- Cells can have multiple representations, for instance a 'verilog' view and a 'schematic' view at the same time.
- The config view specifies the view to use for netlisting for each cell (or even instance)

|                                          | Launch <u>File Edit View</u>                            | oso® Hierarchy Edito | or: New Configura | tion (Save Needed        | l) (+ = ×<br>cādence     | A cell can have                                                               |     |
|------------------------------------------|---------------------------------------------------------|----------------------|-------------------|--------------------------|--------------------------|-------------------------------------------------------------------------------|-----|
|                                          | Top Cell                                                | ) 🥱 🥐 🕕 🖶 🦂          | Search            | Global Bindings          | Update Needed            | several view, e<br>'verilog',                                                 | .g. |
| 'Table view'<br>lists cells per<br>type. | Library: VLSI2020<br>Cell: MixedSim2<br>View: schematic | AD                   |                   | Library List: basic anal | ogLib                    | 'functional' or<br>'schematic'.<br>The view to use<br>is specified <b>her</b> | -   |
| 'Tree view'<br>shows all                 | Table View Tree View                                    |                      |                   |                          |                          |                                                                               |     |
| instances                                | Library                                                 | Cell                 | View Found        | View To Use              | Inherited View List      |                                                                               |     |
|                                          | VLSI2020                                                | Inverter             | schematic         | schematic                | verilogams veriloga beha | Discht Cliek                                                                  |     |
|                                          | VLSI2020                                                | MixedSim2            | schematic         |                          | verilogams veriloga beba | Right Click                                                                   |     |
|                                          | VLSI2020                                                | MyFirstStimulus      | verilog           | verilog                  | Verliggenie verlige      | to select                                                                     |     |
|                                          | analogLib                                               | cap                  | spectre           |                          | verilogams veriloga beha |                                                                               |     |
|                                          | analogLib                                               | res                  | spectre           |                          | verilogams veriloga beha | (now                                                                          |     |
|                                          | analogLib                                               | vdc                  | spectre           |                          | verilogams veriloga beha | 'functional')                                                                 |     |

## 5a. Setting Up the Simulation and Outputs

| Launch Session S                | sso® Analog Design Environment (1) - playground SIM_MixedModeExample config 🐷 🔊<br>Setyp Analyses Yariables Qutputs Simulation Results Iools Help <b>cādenc</b> | e                 |
|---------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------|
| Design Variables                | Value           Rnalyses         ?                                                                                                                              | AC<br>DC<br>Trans |
|                                 | Simulator ams Project Directory //thp/AIE-Sim-endingen<br>Host Mode • local • remote • distributed                                                              |                   |
| <pre>&gt; Results in /tmp</pre> | o/ADE-Sim-erdinge Plot after simula/Auto Plotting mocReplace<br>M:<br>Status: Ready   T=27 C   Simulator: ams(Spectre)Mode: batch   State: tmpstat              | 2:                |

| 8         | 27                     | 🕹 🎾 🖆 🗹                                                                                                                                   |                        |          |      |                   |    |
|-----------|------------------------|-------------------------------------------------------------------------------------------------------------------------------------------|------------------------|----------|------|-------------------|----|
| esign Van | ishlas                 | Ana<br>osing Design Virtud                                                                                                                | lyses<br>so@ Analog De |          | (x)  | ?                 | B× |
| Name      | Library Name           | playground                                                                                                                                | Joo Childing De        |          | 0    |                   | Ĩ  |
|           | Cell Name              | SIM_GCC<br>SIM_LATCH_SYNC<br>SIM_LFSR_3<br>SIM_LVDS_IOBoard<br>SIM_MixedModeExa<br>SIM_TOGGLE_FF<br>SIM_inv<br>SIM_leakage<br>SIM_ringosc |                        |          |      | ?<br>Save Options |    |
|           | View Name<br>Open Mode | config 🔽                                                                                                                                  |                        |          |      |                   |    |
|           |                        |                                                                                                                                           |                        | K Cancel | Help |                   | -  |

- Open the top level simulation schematic
- In menu: Launch  $\rightarrow$  ADE L (or higher)
- Setup  $\rightarrow$  Design
  - Change 'View Name' to 'config' (which we have created before)
- Setup → Simulator/Directory/...
  - Change 'Simulator' to 'ams' this takes a moment...
- Add a transient simulation

- AMS saves only selected nets by default.
  - In small designs, it is more convenient to save all, so that you do not have to re-run the simulation if you want to view more signals
- In Simulation window, go to 'Outputs  $\rightarrow$  Save All...'
- In the category NETS, select 'all' to save all node voltages
  - If you want to also save nets INSIDE of modules / instances, select Levels -> 'all'
- If you want to look at currents:
  - In the category CURRENTS, select 'all'
  - Do not do this all the time, because the larger choice of signals makes it more confusing later to select the right ones...

### (Connect Rules – defaults should be ok...)

- This is a bit tricky. The mechanism has changed depending on software version.
- At the moment, you can access the connect rules from Setup->Connect Rules
- In the window, go to 'advanced setup'.
  - Make sure 1.8 V are set!
  - The simple model assumes a series resistor and a rise time.



Launch Session

🖻 🧔

Design Variables

Name

Setup Analyses Variables Outputs

High-Performance Simulation ...

Simulator/Directory/Host ...

Model Libraries ...
Temperature ...

💾 Design ...

## 5c. Setting up The Library Path

- If you want to use active devices, like transistors, the models must be defined in Setup->Model Libraries
  - Check that they are set!
  - Note: You may have to pick a 'section' (right column)



- These files are defined in your .cdsinit.
- If the are wrong (because UMC or cadence versions have changed), update them there and re-run .cdsinit (load ".cdsinit")

You may want to save the state before you run...

- Run the simulation ('play button')
- In the log file you can see that there are several steps:
  - Compilation
  - Elaboration
  - Simulation
- Errors are in Simulation->Output Log->...
- Verilog \$display task prints to the log file
- Open the results browser to look at the results: in the ADE menu: Tools → Results Browser …

### Selecting Waveforms

- To select digital waveforms, open the 'results browser'
  - for instance from the schematic window (next to 'calculator icon')
  - Or from the simulator  $\rightarrow$  tools  $\rightarrow$  ..
  - $\rightarrow$  You get a pane with 3 entries (calc., res. browser, results)
- Select
   Sim->tran->Top
  - In Verilog Instance, you can select internal variables.



### The Results Browser



### Adding Functional Models

- You can add a functional (e.g. Verilog) model to a schematic, for instance to a gate
- You can start from the schematic and then Create->Cellview->From Cellview -> Verilog-Editor
- Add the Verilog Code to describe the behavior. Note: This code is *not* compared to the real behavior of the schematic. You can get it wrong!!





# Sample Output

### Here, The inverter is simulated with its ,*functional*<sup>4</sup> model:

| Library  | Cell            | View Found | View To Use |
|----------|-----------------|------------|-------------|
| VLSI2020 | Inverter        | functional | functional  |
| VLSI2020 | MixedSim_Top    | schematic  |             |
| VLSI2020 | MyFirstStimulus | verilog    | verilog     |

module Inverter ( output out, input in ); assign out = ~in; endmodule

### • 'outinv' is a *digital* signal



### • Now, The inverter is simulated with its *schematic* model:

| Library     | Cell            | View Found | View To Use |
|-------------|-----------------|------------|-------------|
| UMC_18_CMOS | N_18_MM         | spectre    |             |
| UMC_18_CMOS | P_18_MM         | spectre    |             |
| VLSI2020    | Inverter        | schematic  | schematic   |
| VLSI2020    | MixedSim_Top    | schematic  |             |
| VLSI2020    | MyFirstStimulus | verilog    | verilog     |

#### 'outinv' is now an analogue signal



VLSI Design - Mixed Mode Simulation



# Mixing stuff

- If you have several instances of the same type, you can select for each instance separately which view to use.
- You must use the 'Tree View' tab of the Hierarchy Editor:



## More Sophisticated Verilog...

129

- In the Verilog you can
  - Define tasks to better structure your code
  - Use memories to store data
  - Use \$random to create random data
  - Use Boolean to collect error messages
  - Print to console (using \$display())

| 91<br>92<br>93                                                                          |                                                                                                                                                                                                                                                                                                                                                                                                                             |                                                                                                                                                                                  |
|-----------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                                                                                         | task LoadRORegister; // Load the content of the a                                                                                                                                                                                                                                                                                                                                                                           | occumulator to the readout shift register                                                                                                                                        |
| 0.2                                                                                     | begin                                                                                                                                                                                                                                                                                                                                                                                                                       |                                                                                                                                                                                  |
| 32                                                                                      | ROLoad = 1'b1;                                                                                                                                                                                                                                                                                                                                                                                                              |                                                                                                                                                                                  |
| 94                                                                                      | DoROC1k;                                                                                                                                                                                                                                                                                                                                                                                                                    |                                                                                                                                                                                  |
| 95                                                                                      | ROLoad = 1'b0;                                                                                                                                                                                                                                                                                                                                                                                                              |                                                                                                                                                                                  |
| 96                                                                                      |                                                                                                                                                                                                                                                                                                                                                                                                                             |                                                                                                                                                                                  |
| 97                                                                                      | endtask                                                                                                                                                                                                                                                                                                                                                                                                                     |                                                                                                                                                                                  |
| 98                                                                                      |                                                                                                                                                                                                                                                                                                                                                                                                                             |                                                                                                                                                                                  |
| 99                                                                                      |                                                                                                                                                                                                                                                                                                                                                                                                                             |                                                                                                                                                                                  |
| 100                                                                                     | initial begin                                                                                                                                                                                                                                                                                                                                                                                                               |                                                                                                                                                                                  |
| 101                                                                                     |                                                                                                                                                                                                                                                                                                                                                                                                                             | ister, adder, accumulator                                                                                                                                                        |
| 102                                                                                     |                                                                                                                                                                                                                                                                                                                                                                                                                             |                                                                                                                                                                                  |
| 103                                                                                     | 0                                                                                                                                                                                                                                                                                                                                                                                                                           |                                                                                                                                                                                  |
| 104                                                                                     |                                                                                                                                                                                                                                                                                                                                                                                                                             |                                                                                                                                                                                  |
| 105                                                                                     |                                                                                                                                                                                                                                                                                                                                                                                                                             |                                                                                                                                                                                  |
| 106                                                                                     | LoadShiftB = 1'b0; // 1: Load, 0: shift                                                                                                                                                                                                                                                                                                                                                                                     |                                                                                                                                                                                  |
| 107                                                                                     |                                                                                                                                                                                                                                                                                                                                                                                                                             | (clocked by ClkShift)                                                                                                                                                            |
| 108                                                                                     |                                                                                                                                                                                                                                                                                                                                                                                                                             |                                                                                                                                                                                  |
| 109                                                                                     | LoadMask = 1'b1; // Must be 1 to inject top hor                                                                                                                                                                                                                                                                                                                                                                             | izontal shift register signals to column and to pa                                                                                                                               |
| 110                                                                                     |                                                                                                                                                                                                                                                                                                                                                                                                                             |                                                                                                                                                                                  |
| 111                                                                                     | \$display("//===================================                                                                                                                                                                                                                                                                                                                                                                            | "");                                                                                                                                                                             |
| 112                                                                                     | <pre>\$display("// Generate a random mask pattern for ea</pre>                                                                                                                                                                                                                                                                                                                                                              |                                                                                                                                                                                  |
| 112                                                                                     |                                                                                                                                                                                                                                                                                                                                                                                                                             | ich chip and write all patterns to the matrices");                                                                                                                               |
| 113                                                                                     | \$display(" //===================================                                                                                                                                                                                                                                                                                                                                                                           | <pre>ich chip and write all patterns to the matrices");<br/></pre>                                                                                                               |
|                                                                                         |                                                                                                                                                                                                                                                                                                                                                                                                                             |                                                                                                                                                                                  |
| 113                                                                                     |                                                                                                                                                                                                                                                                                                                                                                                                                             |                                                                                                                                                                                  |
| 113<br>114                                                                              | GenerateRandomMaskPatterns;                                                                                                                                                                                                                                                                                                                                                                                                 | ");                                                                                                                                                                              |
| 113<br>114<br>115                                                                       | GenerateRandomMaskPatterns;<br>LoadMask = 1'b1;                                                                                                                                                                                                                                                                                                                                                                             | ");                                                                                                                                                                              |
| 113<br>114<br>115<br>116                                                                | <pre>GenerateRandomMaskPatterns;<br/>LoadMask = 1'b1;<br/>for (irow=0; irow<nrow; begin<="" irow="irow+1)" pre=""></nrow;></pre>                                                                                                                                                                                                                                                                                            | // Generate the mask pattern with 50% 1/0<br>// We write row after row                                                                                                           |
| 113<br>114<br>115<br>116<br>117                                                         | <pre>GenerateRandomMaskPatterns;<br/>LoadMask = 1'b1;<br/>for (irow=0; irow<nrow; begin<br="" irow="irow+1)">for (ichip=0; ichip<nchip; begin<="" ichip="ichip+1)" pre=""></nchip;></nrow;></pre>                                                                                                                                                                                                                           | // Generate the mask pattern with 50% 1/0<br>// We write row after row                                                                                                           |
| 113<br>114<br>115<br>116<br>117<br>118                                                  | <pre>GenerateRandomMaskPatterns;<br/>LoadMask = 1'b1;<br/>for (irow=0; irow<nrow; begin<br="" irow="irow+1)">for (ichip=0; ichip<nchip; begin<br="" ichip="ichip+1)">for (icol=0; icol<ncol; begin<="" icol="icol+1)" pre=""></ncol;></nchip;></nrow;></pre>                                                                                                                                                                | // Generate the mask pattern with 50% 1/0<br>// We write row after row                                                                                                           |
| 113<br>114<br>115<br>116<br>117<br>118<br>119                                           | <pre>GenerateRandomMaskPatterns;<br/>LoadMask = 1'b1;<br/>for (irow=0; irow<nrow; begin<br="" irow="irow+1)">for (ichip=0; ichip<nchip; begin<br="" ichip="ichip+1)">for (icol=0; icol<ncol; begin<br="" icol="icol+1)">HorSI = Wmask[ichip][irow][icol];</ncol;></nchip;></nrow;></pre>                                                                                                                                    | <pre>// Generate the mask pattern with 50% 1/0 // We write row after row // clock in the NCOL*NCHIP values</pre>                                                                 |
| 113<br>114<br>115<br>116<br>117<br>118<br>119<br>120                                    | <pre>GenerateRandomMaskPatterns;<br/>LoadMask = 1'b1;<br/>for (irow=0; irow<nrow; begin<br="" irow="irow+1)">for (ichip=0; ichip<nchip; begin<br="" ichip="ichip+1)">for (icol=0; icol<ncol; begin<br="" icol="icol+1)">HorSI = Wmask[ichip][irow][icol];<br/>DoROClk;</ncol;></nchip;></nrow;></pre>                                                                                                                       | <pre>// Generate the mask pattern with 50% 1/0 // We write row after row // clock in the NCOL*NCHIP values // take it from the Wmask register</pre>                              |
| 113<br>114<br>115<br>116<br>117<br>118<br>119<br>120<br>121                             | <pre>GenerateRandomMaskPatterns;<br/>LoadMask = 1'b1;<br/>for (irow=0; irow<nrow; begin<br="" irow="irow+1)">for (ichip=0; ichip<nchip; begin<br="" ichip="ichip+1)">for (icol=0; icol<ncol; begin<br="" icol="icol+1)">HorSI = Wmask[ichip][irow][icol];<br/>DoROClk;<br/>end // icol</ncol;></nchip;></nrow;></pre>                                                                                                       | <pre>// Generate the mask pattern with 50% 1/0 // We write row after row // clock in the NCOL*NCHIP values // take it from the Wmask register</pre>                              |
| 113<br>114<br>115<br>116<br>117<br>118<br>119<br>120<br>121<br>122                      | <pre>GenerateRandomMaskPatterns;<br/>LoadMask = 1'b1;<br/>for (irow=0; irow<nrow; begin<br="" irow="irow+1)">for (ichip=0; ichip<nchip; begin<br="" ichip="ichip+1)">for (icol=0; icol<ncol; begin<br="" icol="icol+1)">HorSI = Wmask[ichip][irow][icol];<br/>DoROClk;<br/>end // icol<br/>end // ichip</ncol;></nchip;></nrow;></pre>                                                                                      | <pre>// Generate the mask pattern with 50% 1/0 // We write row after row // clock in the NCOL*NCHIP values // take it from the Wmask register</pre>                              |
| 113<br>114<br>115<br>116<br>117<br>118<br>119<br>120<br>121<br>122<br>123               | <pre>GenerateRandomMaskPatterns;<br/>LoadMask = 1'b1;<br/>for (irow=0; irow<nrow; begin<br="" irow="irow+1)">for (ichip=0; ichip<nchip; begin<br="" ichip="ichip+1)">for (icol=0; icol<ncol; begin<br="" icol="icol+1)">HorSI = Wmask[ichip][irow][icol];<br/>DoROClk;<br/>end // icol<br/>end // ichip<br/>DoShiftClk;</ncol;></nchip;></nrow;></pre>                                                                      | <pre>// Generate the mask pattern with 50% 1/0 // We write row after row // clock in the NCOL*NCHIP values // take it from the Wmask register // Clock horizontal register</pre> |
| 113<br>114<br>115<br>116<br>117<br>118<br>119<br>120<br>121<br>122<br>123<br>124        | <pre>GenerateRandomMaskPatterns;<br/>LoadMask = 1'b1;<br/>for (irow=0; irow<nrow; begin<br="" irow="irow+1)">for (ichip=0; ichip<nchip; begin<br="" ichip="ichip+1)">for (icol=0; icol<ncol; begin<br="" icol="icol+1)">HorSI = Wmask[ichip][irow][icol];<br/>DoROClk;<br/>end // icol<br/>end // ichip<br/>DoShiftClk;<br/>\$display("Row %d DONE.", irow);</ncol;></nchip;></nrow;></pre>                                 | <pre>// Generate the mask pattern with 50% 1/0 // We write row after row // clock in the NCOL*NCHIP values // take it from the Wmask register // Clock horizontal register</pre> |
| 113<br>114<br>115<br>116<br>117<br>118<br>119<br>120<br>121<br>122<br>123<br>124<br>125 | <pre>GenerateRandomMaskPatterns;<br/>LoadMask = 1'b1;<br/>for (irow=0; irow<nrow; begin<br="" irow="irow+1)">for (ichip=0; ichip<nchip; begin<br="" ichip="ichip+1)">for (icol=0; icol<ncol; begin<br="" icol="icol+1)">HorSI = Wmask[ichip][irow][icol];<br/>DoROClk;<br/>end // icol<br/>end // icol<br/>end // ichip<br/>DoShiftClk;<br/>\$display("Row %d DONE.", irow);<br/>end // irow</ncol;></nchip;></nrow;></pre> | <pre>// Generate the mask pattern with 50% 1/0 // We write row after row // clock in the NCOL*NCHIP values // take it from the Wmask register // Clock horizontal register</pre> |
| 113<br>114<br>115<br>116<br>117<br>118<br>119<br>120<br>121<br>122<br>123<br>124        | <pre>GenerateRandomMaskPatterns;<br/>LoadMask = 1'b1;<br/>for (irow=0; irow<nrow; begin<br="" irow="irow+1)">for (ichip=0; ichip<nchip; begin<br="" ichip="ichip+1)">for (icol=0; icol<ncol; begin<br="" icol="icol+1)">HorSI = Wmask[ichip][irow][icol];<br/>DoROClk;<br/>end // icol<br/>end // ichip<br/>DoShiftClk;</ncol;></nchip;></nrow;></pre>                                                                      | <pre>// Generate the mask pattern with 50% 1/0 // We write row after row // clock in the NCOL*NCHIP values // take it from the Wmask register // Clock horizontal register</pre> |

### **Checking Inputs**

 You can pass analogue values (after conversion in an IE) to the Verilog and inspect them.





## **EXERCISE: MIXED MODE SIMULATION**

### **Exercise: Clock Generation**

- Step 1: Create a 'ClockGenerator' cell
  - Generate a Verilog view
  - Use a parameter parameter del=10;

to set the clock period. (Parameters can be overwritten in the properties of the symbol. You may have to change the 'CDF Parameter of view' combo box to 'verilog')

- Follow all steps until you have the symbol
- Step 2: Create a new schematic (for simulation)
  - Instantiate the ClockGenerator
  - Add an inverter or at lease a RC element to do something with the clock
- Step 3: Mixed mode simulation
  - Follow all described steps to setup and run a mixed mode simulation
  - Browse through the results

- Step 4: Divide by 2:
  - Create an edge triggered flipflop from two latches (or take if from a SUSLIB..)
  - Use it to divide the clock by 2.
- Step 5: Checking via Verilog: 'ClockChecker' cell
  - Make a Verilog module which has a clock output and an *input* for the divided clock
  - Use Verilog code to verify that the clock is divided correctly
- NOTE: When re-running the simulation, the results in the lower hierarchy might be missing despite for 'save all'.
   → Closing and re-opening the results browser should fix this.