MADVLSI Mini Project 1 Vienna Scheyer February 16, 2021

Github: <a href="https://github.com/vscheyer/MADVLSI">https://github.com/vscheyer/MADVLSI</a>

### 1. Schematic Capture and Simulation

Inverter Schematic:



### Inverter Symbol:



# NAND Gate Schematic:



## NAND Gate Symbol



## AND Gate Schematic:



# AND Gate Symbol:



Top Level AND Gate Schematic For Simulation:



# AND Gate Simulation Output:



# Inverter Subcircuit Layout:



# NAND Gate Subcircuit Layout:



## AND Gate Layout:



(NAND subsircuit on the left, inverter subcircuit on the right. Letters denote inputs and outputs.)

Layout Versus Schematic Comparison:

advlstgmadvlst-ubuntu:-/Documents/Mini\_Project\_1/lvs\$ netgen -batch lvs
nd\_gate\_lvs\_xschem.spice and\_gate\_layout.spice -/skywater/open\_pdks/sky1
0/pstpn/kui30\_catus\_tal 30/netgen/sky130\_setup.tcl Netgen 1.5.166 compiled on Mon 15 Feb 2021 11:47:17 PM EST Warning: netgen command 'format' use fully-qualified name '::netgen::form Warning: netgen command 'global' use fully-qualified name '::netgen::glob al'
Reading netlist file and\_gate\_lvs\_xschem.spice
Call to undefined subcircuit AND Gate
Creating placeholder cell definition.
Call to undefined subcircuit NAND\_Gate
Creating placeholder cell definition.
Call to undefined subcircuit Inverter
Creating placeholder cell definition.
Call to undefined subcircuit inverter
Creating placeholder cell definition. Creating placeholder cell definition.

Call to undefined subcircuit sky130\_fd\_pr\_\_nfet\_01v8

Creating placeholder cell definition.

Call to undefined subcircuit sky130\_fd\_pr\_\_pfet\_01v8

Creating placeholder cell definition.

Reading netlist file and\_gate\_layout.spice

Call to undefined subcircuit sky130\_fd\_pr\_\_nfet\_01v8

Creating placeholder cell definition.

Call to undefined subcircuit sky130\_fd\_pr\_\_pfet\_01v8

Creating placeholder cell definition.

Reading setup file /home/madvlsi/skywater/open\_pdks/sky130/netgen/sky130\_

setup.tcl

Model sky130\_fd\_pr\_\_nfet\_01v8 pin 1 == 3 Reading setup file /home/madVisi/skywater/open\_pdks/skyl30 setup.tcl
Model skyl30\_fd\_pr\_\_nfet\_01v8 pin 1 == 3
Model skyl30\_fd\_pr\_\_nfet\_01v8 pin 1 == 3
No property mult found for device skyl30\_fd\_pr\_\_nfet\_01v8
No property sa found for device skyl30\_fd\_pr\_\_nfet\_01v8
No property sb found for device skyl30\_fd\_pr\_\_nfet\_01v8
No property sf found for device skyl30\_fd\_pr\_\_nfet\_01v8
No property nrd found for device skyl30\_fd\_pr\_\_nfet\_01v8
Nodel skyl30\_fd\_pr\_\_pfet\_01v8 pin 1 == 3
Model skyl30\_fd\_pr\_\_pfet\_01v8 pin 1 == 3
No property so found for device skyl30\_fd\_pr\_\_pfet\_01v8
No property sa found for device skyl30\_fd\_pr\_\_pfet\_01v8
No property so found for device skyl30\_fd\_pr\_\_pfet\_01v8
No property sf found for device skyl30\_fd\_pr\_\_pfet\_01v8
No property nrf found for device skyl30\_fd\_pr\_\_pfet\_01v8
No property nrf found for device skyl30\_fd\_pr\_\_pfet\_01v8
No property nrf found for device skyl30\_fd\_pr\_\_pfet\_01v8
No property nrs found for device skyl30\_fd\_pr\_\_pfet\_01v8
No property nrs found for device skyl30\_fd\_pr\_\_pfet\_01v8
No property nrs found for device skyl30\_fd\_pr\_\_pfet\_01v8
Comparison output logged to file comp.out No property nrs found for device sky130\_fd\_pr\_\_pfet\_01v8
Comparison output logged to file comp.out
Logging to file "comp.out" enabled
Contents of circuit 1: Circuit: 'sky130\_fd\_pr\_\_nfet\_01v8'
Circuit sky130\_fd\_pr\_\_nfet\_01v8 contains 0 device instances.
Circuit contains 0 nets.
Contents of circuit 2: Circuit: 'sky130\_fd\_pr\_\_nfet\_01v8'
Circuit sky130\_fd\_pr\_\_nfet\_01v8 contains 0 device instances.
Circuit contains 0 nets. Circuit contains 0 nets.

Circuit sky130\_fd\_pr\_\_pfet\_01v8 contains no devices.

Contents of circuit 1: Circuit: 'NAND\_Gate'

Circuit NAND\_Gate contains 4 device instances.

Class: sky130\_fd\_pr\_\_nfet\_01v8 instances: 2

Circuit contains 6 nets.

Contents of circuit 2: Circuit: 'nand\_gate'

Circuit nand\_gate contains 4 device instances.

Class: sky130\_fd\_pr\_\_nfet\_01v8 instances: 2

Class: sky130\_fd\_pr\_\_pfet\_01v8 instances: 2

Circuit contains 6 nets. Circuit 1 contains 4 devices, Circuit 2 contains 4 devices. Circuit 1 contains 6 nets, Circuit 2 contains 6 nets. Netlists match uniquely. Contents of circuit 1: Circuit: 'Inverter' Contents of circuit 1: Circuit: 'Inverter' Circuit Inverter contains 2 device instances. Class: sky130\_fd\_pr\_\_nfet\_01v8 instances: Class: sky130\_fd\_pr\_\_pfet\_01v8 instances: Circuit contains 4 nets.

Contents of circuit 2: Circuit: 'inverter' Circuit inverter contains 2 device instances. Class: sky130\_fd\_pr\_\_nfet\_01v8 instances: Class: sky130\_fd\_pr\_\_pfet\_01v8 instances: Class: sky130\_fd\_pr\_\_pfet\_01v8 instances: Circuit contains 4 nets. Circuit 1 contains 2 devices, Circuit 2 contains 2 devices. Circuit 1 contains 4 nets, Circuit 2 contains 4 nets. Netlists match uniquely. Contents of circuit 1: Circuit: 'and\_gate\_lvs\_xschem.spice' Circuit and\_gate\_lvs\_xschem.spice contains 2 device instances. Class: NAND\_Gate Class: Inverter instances: instances: circuit contains 6 nets.
Contents of circuit 2: Circuit: 'and\_gate\_layout.spice'
Circuit and\_gate\_layout.spice contains 2 device instances. Class: nand\_gate instances: Class: inverter instances: Circuit contains 6 nets. Circuit 1 contains 2 devices, Circuit 2 contains 2 devices. Circuit 1 contains 6 nets, Circuit 2 contains 6 nets.

Netlists match uniquely. Result: Circuits match uniquely. Logging to file "comp.out" disabled LVS Done.