# Co-simulation Verilog – ngspice, example SAR ADC

Software by Giles Atkinson

|   | ٠ | ı | _ |   |
|---|---|---|---|---|
| ⊢ | ı | ı | ρ | ς |
|   |   |   | • | - |

| user<br>provided                    | adc.cir               | ngspice netlist: analog part, digital support, interface with code model, simulation control |  |  |  |
|-------------------------------------|-----------------------|----------------------------------------------------------------------------------------------|--|--|--|
|                                     | adc.v                 | digital ADC part, Verilog code                                                               |  |  |  |
| within<br>ngspice –<br>distribution | verilator_main.c      | main required by Verilator                                                                   |  |  |  |
|                                     | verilator_shim.c      | structure of shared lib to be linked to d_cosim code model                                   |  |  |  |
|                                     | vnlnggen              | ngspice control language script for creating shared lib adc.so                               |  |  |  |
|                                     | digital.cm -> d_cosim | code model, loading adc.so, interface to digital part of netlist                             |  |  |  |
| external install; Linux, Windows    | Verilator             | Verilator (Linux, Windows)                                                                   |  |  |  |
|                                     | ngspice               | simulator, version 42 and up                                                                 |  |  |  |

# Co-simulation Verilog – ngspice, example SAR ADC Procedure → two commands only!

#### Command

#### ngspice vlnggen adc.v

- calls Verilator to compile adc.v into adc.c
- calls g++ (msvc) to compile adc.c, verilator\_main.c, verilator\_shim.c and some other files generated or provided by Verilator, and links them into shared library adc.so (adc.dll)

#### Command

#### ngspice adc.cir

- Load code model d cosim
- Load netlist adc.cir
  - Load shared lib adc.so
- Run simulation (e.g. transient)
- Save and/or plot data

### Verilog

```
module adc(Clk, Comp, Start, Sample, Done, Result);
input wire Clk, Comp, Start;
output reg Sample, Done;
output reg [Bits - 1 : 0] Result;
parameter Bits=6;
...
```

Link between verilog module header and code model interface to ngspice netlist

Code model

adut [ Clk Comp Start] [Sample Valid ~d5 ~d4 ~d3 ~d2 ~d1 ~d0] null dut .model dut d\_cosim simulation="./adc.so"

## Co-simulation Verilog – ngspice, example SAR ADC **Links, manual**

Example https://sourceforge.net/p/ngspice/ngspice/ci/master/tree/examples/xspice/verilator/

Sources <a href="https://sourceforge.net/p/ngspice/ngspice/ci/master/tree/src/xspice/verilog/">https://sourceforge.net/p/ngspice/ngspice/ci/master/tree/src/xspice/verilog/</a>

Help <a href="https://sourceforge.net/p/ngspice/discussion/127605/">https://sourceforge.net/p/ngspice/discussion/127605/</a>

Manual <a href="https://ngspice.sourceforge.io/docs/ngspice-42-manual.pdf">https://ngspice.sourceforge.io/docs/ngspice-42-manual.pdf</a>
Chapters

- 12.4.25 d\_cosim
- 14.3 Digital devices defined by a Hardware Description Language