Topic of the project:

Project name: "ASIC design with open source tools"

Developing of an low resolution ADC. As example an 4-Bit ADC with conversion of the thermometer code into binary code.

# Steps:

A small CMOS inverter with xschem and the sky130a technology (PDK) and simulate the circuit with ngspice:

## **Binary Logic level assumption**

https://en.wikipedia.org/wiki/Logic level

| Technology | L Voltage       | H Voltage         | note                 |
|------------|-----------------|-------------------|----------------------|
| CMOS       | 0 to 30% of Vdd | 70% of Vdd to Vdd | Vdd = Supply voltage |
|            | ≈0.5 Volt       | ≈1.25 Volts       | Vdd = 1.8 Volts      |



The above figure is the schematic for 15<sup>th</sup> threshold point of the analogue part of the ADC. The plot is as follows:



The inverter will switch from logic-low to logic-high when input voltage exceeds 1.782 volts. So, for this inverter the threshold is 1.782 volts.

For a 4-bit ADC we need 16 voltage level including zero (0 $\sim$ 1.782 volts). The quantization should be 1.782/15=0.1188 volts.

#### Vdd = 1.8 V

### Th. 15: 1.782

For calculation the schematic and the plot already mentioned earlier. Remove all source to make symbol from schematic. As the symbol will have to be connected to Vdd and GND, those pins are replaced with Vp and Vn accordingly.







Magic=>before importing netlist to ngspice check LVS net



The simplified schematic is as follows:



The plot is similar to the previous figure.

Th. 14: 1.6632





Rest of the figures are similar to the previous figures.

Th. 13: 1.5444:





Th. 12: 1.4256





Th. 11: 1.3068





Th. 10: 1.188





Th. 9: 1.0692





Th. 8: 0.9504





Th. 7: 0.8316





Th. 6: 0.7128





Th. 5: 0.594





Th. 4: 0.4752





Th. 3: 0.3564





Th. 2: 0.2376





Th. 1: 0.1188





# **Combined Analog sch.**





http://web02.gonzaga.edu/faculty/talarico/vlsi/xschemTut.html

https://ngspice.sourceforge.io/ngspice-control-language-tutorial.html

#### Alter subckt tutorial—

https://sourceforge.net/p/ngspice/discussion/133842/thread/5ad086c79f

https://sourceforge.net/p/ngspice/discussion/133842/thread/9a75acf2/#bf90/45b3/ea48

## **Pyspice ngspice interpreter**

https://pyspice.fabrice-salvaire.fr/releases/v1.3/examples/ngspice-shared/ngspice-interpreter.html

https://github.com/ashwith/ngspicepy

## Read spice raw output data

https://gist.githubusercontent.com/snmishra/27dcc624b639c2626137/raw/742fe0dd59c7b2c41b71a1c8c1c2506d13affc53/rawread.py

## ngspice wrapper for python

https://github.com/eps82/lyngspice/wiki

# write some verilog code to convert the thermometer code (from the inverter stages) into the binary code

```
module thermometer_to_binary (
 input [14:0] ith,
 output reg [3:0] binary
);
always @(*) begin
 case (ith)
    16'b000000000000001: binary = 4'b0001; //\sim 0.1188
    16'b00000000000011: binary = 4'b0010; // \sim 0.2376
    16'b000000000000111: binary = 4'b0011; // \sim 0.3564
    16'b00000000001111: binary = 4'b0100; // \sim 0.4752
    16'b00000000011111: binary = 4'b0101; // \sim 0.5940
    16'b00000000111111: binary = 4'b0110; // \sim 0.7128
    16'b0000000011111111: binary = 4'b0111; // ~0.8316
    16'b000000011111111: binary = 4'b1000; //~0.9504
    16'b000000111111111: binary = 4'b1001; //~1.0692
    16'b0000011111111111: binary = 4'b1010; //~1.1880
    16'b000011111111111: binary = 4'b1011; //~1.3068
    16'b000111111111111: binary = 4'b1100; //~1.4256
    16'b001111111111111: binary = 4'b1101; //~1.5444
    16'b011111111111111: binary = 4'b1110; //~1.6632
    16'b111111111111111: binary = 4'b1111; //~1.7820
    default: binary = 4'bxxxx; // Don't care
  endcase
end
```

#### endmodule

http://www.asic-world.com/verilog/veritut.html

https://nandland.com/introduction-to-verilog-for-beginners-with-code-examples/

https://www.youtube.com/playlist?list=PLfGJEQLQIDBN0VsXQ68\_FEYyqcym8CTDN

https://github.com/Swagatika-Meher/msvsd2bitcomp

## ALIGN Tool-

https://www.youtube.com/playlist?list=PLvXKBnlvcSm30Y0zu1765oG x-ECU8tVG

https://learning.edx.org/course/course-v1:HarveyMuddX+ENGR85A+3T2021/home

https://www.vlsiuniverse.com/digital-thermometer-code-in-verilog-vhdl-flash-adc-binary-encoder/

https://www.classcentral.com/subject/vlsi?free=true

https://www.eng.biu.ac.il/temanad/digital-vlsi-design/

https://www.youtube.com/playlist?list=PLZU5hLL 713x0 AV rVbay0pWmED7992G

https://youtu.be/BlqLk23hE90?list=PLZU5hLL 713x0 AV rVbay0pWmED7992G

# get familiar with the yosis syntesis tool to convert the verilog code into a CMOS circuit

https://www.mehmetburakaykenar.com/synthesis-n-bit-counter-with-open-source-yosys-synthesizer/294/

https://github.com/spdy1895/RTL synthesis using sky130

https://github.com/Imellal/RTL-workshop-Sky130-PDK

After install YoSys (see the bash file in the repository), run the following commands—

>> yosys // open yosys console in terminal

>> read liberty -lib

/usr/local/share/pdk/sky130A/libs.ref/sky130 fd sc hd/lib/sky130 fd sc hd tt 025C 1v80.lib

// reading the suitable liberty file (see the screenshot below)



>> read\_verilog therm\_code.v // read the verilog file



>> synth -top thermometer\_to\_binary // synthesize the module

```
>> abc -liberty
/usr/local/share/pdk/sky130A/libs.ref/sky130 fd sc hd/lib/sky130 fd sc hd tt 025C 1v80.lib
                // // to invoke flat synthesis after netlist generation
>> flatten
// netlist generation
>> show // vew graphical
>> write_verilog therm.v // write the generated netlist to a new module/verilog file
for verification
>> write verilog -noattr therm.v // // to write verilog netlist without
attributes(clean)
Optimize:
>> flatten
>> opt clean -purge
                   // running optimization
>> show
>> write_spice therm.spice
>> show -prefix therm -format svg//save diagram in .svg
>> show -prefix therm -format dot//save diagram in .dot
```

>> **show -enum -prefix therm -format dot** //save diagram in .dot with gate numbers



#### Netlist to schematic conversion:

https://github.com/aidangoettsch/asg

#### install NetlistViewer:

https://github.com/f18m/netlist-

viewer/blob/master/NetlistViewer/build/linux/README.md

#### doteditor:

https://sourceforge.net/projects/netlistviewer/

## Iverilog with gtkwave:

https://youtu.be/Ryt1ms8Tido





# - simulate the complete (ultra small) ADC

# Prelayout simulation:



## References:

https://github.com/bluecmd/learn-sky130/blob/main/schematic/xschem/getting-started.md

| Run iverilo/icarus |
|--------------------|
| iverilog file.v    |
| vvp a.out          |
|                    |