Skip to content

Understanding Physical Verification using open source tools such as Magic and Netgen

Notifications You must be signed in to change notification settings

yathAg/Physical_Verification_SKY130A

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

59 Commits
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Physical_Verification_SKY130A

Workshop-Flyer

This repository contains the documentation of the work done during a five-day physical verification workshop carried out by VSD.

The workshop describes the physical verification process that takes place during an RTL to GDSII flow using Skywater 130nm Technology, including DRC and LVS tests. This helps the participants get ready for the tape out and is particularly helpful for chip fabrication. The workshop assists in locating and fixing violations made during the physical verification stage.

More information about the workshop can be found at https://www.vlsisystemdesign.com/physical-verification-using-sky130/

A special thanks to Tim, Kunal, and Sumanto for creating and helping out during this fantastic workshop

Index

Chapter 0 - Getting the tools

To adequately utilize the open source skywater130 pdk and understand the design flow, we first require to install all the tools, which are

  • open_pdk
  • magic
  • ngspice
  • xschem
  • netgen toolchains

Note: open_pdk has to be installed last so it can correctly associate the xschem and magic directories. Note: if the configure step fails during any process, its most likely due to missing additional packages, and they need to be installed (preferably from source) to complete the installation

Magic

Magic is an open-source VLSI layout tool.

Install steps:

$  git clone git://opencircuitdesign.com/magic
$  cd magic
$	 ./configure
$  make
$  sudo make install

More info can be found at http://opencircuitdesign.com/magic/index.html

Netgen

Netgen is a tool for comparing netlists, a process known as LVS, which stands for "Layout vs. Schematic"

Install steps:

$  git clone git://opencircuitdesign.com/netgen
$  cd netgen
$	./configure
$  make
$  sudo make install

More info can be found at http://opencircuitdesign.com/netgen/index.html

Xschem

Xschem is a schematic capture program

Install steps:

$  git clone https://github.com/StefanSchippers/xschem.git xschem_git
$	./configure
$  make
$  sudo make install

More info can be found at http://repo.hu/projects/xschem/index.html

Ngspice

ngspice is the open-source spice simulator for electric and electronic circuits.

Install steps:

After downloading the tarball from https://sourceforge.net/projects/ngspice/files/ to a local directory, unpack it using:

 $ tar -zxvf ngspice-37.tar.gz
 $ cd ngspice-37
 $ mkdir release
 $ cd release
 $ ../configure  --with-x --with-readline=yes --disable-debug
 $ make
 $ sudo make install

More info can be found at https://ngspice.sourceforge.io/index.html

Please note that to view the simulation graphs of ngspice, xterm is required and can be installed using.

$ sudo apt-get update
$ sudo apt-get install xterm

open_pdk

Open_PDKs is distributed with files that support the Google/SkyWater sky130 open process description https://github.com/google/skywater-pdk. Open_PDKs will set up an environment for using the SkyWater sky130 process with open-source EDA tools and tool flows such as magic, qflow, openlane, netgen, klayout, etc.

Install steps:

$  git clone git://opencircuitdesign.com/open_pdks
$  open_pdks
$	./configure --enable-sky130-pdk
$  make
$  sudo make install

Now that we have all the necessary tools installed let's understand the design flow!

Chapter 1 - Understanding the design flow

Verifiying the open_pdk installation

An initial working directory can be made by copying the required files as follows:

$ mkdir Lab1_and
$ cd Lab1_and
$ mkdir mag
$ mkdir netgen
$ mkdir xschem
$ cd xschem
$ cp /usr/local/share/pdk/sky130A/libs.tech/xschem/xschemrc .
$ cp /usr/local/share/pdk/sky130A/libs.tech/ngspice/spinit .spiceinit
$ cd ../mag
$ cp /usr/local/share/pdk/sky130A/libs.tech/magic/sky130A.magicrc .magicrc
$ cd ../netgen
$ cp /usr/local/share/pdk/sky130A/libs.tech/netgen//sky130A_setup.tcl .

Checking if magic works mag_test

Checking if xschem works xschem_test

Checking if netgen works netgen_test

Checking if ngspice works spice_test

Creating inverter schematic using xschem

An initial schematic is made by placing components from the open_pdk library
The required changes to the properties of the device can be made here and will automatically reflect in the layout xshem_inv

Convert the schematic to a symbol xshem_sym

Using the symbol, we can create an independent test bench to simulate the circuit xshem_tb

Creating and simulating testbench Schematic

The circuit can be simulated in ngspice. make sure to disable .subckt in the simulation tab for the netlist generated for the sim xschem_sim

Creating inverter layout in Magic and exporting its netlist

The original schematic can be used to export a netlist, which can be imported into magic to create the layout.

Set the appropriate device properties and route the layout. mag_p1


mag_p1


mag_net


Performing LVS checks on testbench and layout netlists

The netlist of the layout can be extracted using

% extract do local
% extract all
% ext2spice lvs
% ext2spice

ext files are intermidiate files and can be cleaned using

rm *.ext
/usr/local/share/pdk/scripts/cleanup_unref.py -remove

The schematic netlist and layout netlist can be compared using LVS by netgen

$ netgen -batch lvs "../mag/inverter.spice inverter" "../xschem/inverter.spice inverter"

lvs

Chapter 2 - DRC and LVS Fundamentals

Design Rule Checking (DRC)

Make sure the design layout meets all silicon foundry rules for masks.

Layout vs. Schematic (LVS)

Make sure the design layout matches a simulatable netlist by electrical connectivity and devices.

LVS

Reading GDS files

$ cp /usr/local/share/pdk/sky130A/libs.tech/magic/sky130A.magicrc ./.magicrc
% gds read /usr/local/share/pdk/sky130A/libs.ref/sky130_fd_sc_hd/gds/sky130_fd_sc_hd.gds
% load sky130_fd_sc_hd__and2_1

load_cell

% cif istyle sky130(vendor)
% gds read /usr/local/share/pdk/sky130A/libs.ref/sky130_fd_sc_hd/gds/sky130_fd_sc_hd.gds

change_istyle

Matching ports to spice netlists

% port first
% port 1 name
% port 1 class
% port 1 use

no_metadata

% lef read /usr/local/share/pdk/sky130A/libs.ref/sky130_fd_sc_hd/lef/sky130_fd_sc_hd.lef

lef_metadata

% readspice /usr/local/share/pdk/sky130A/libs.ref/sky130_fd_sc_hd/spice/sky130_fd_sc_hd.spice
% load sky130_fd_sc_hd__and2_1

spice_metadata

Abstract views

Note: the difference between load and getcell

The difference is between a cell and an instance of that cell. If you do load inverter, then you will be editing the cell called inverter. If you do getcell inverter, then you will place an instance of the cell inverter inside the cell you're currently editing.

% lef read /usr/local/share/pdk/sky130A/libs.ref/sky130_fd_sc_hd/lef/sky130_fd_sc_hd.lef
% load sky130_fd_sc_hd__and2_1
% readspice /usr/local/share/pdk/sky130A/libs.ref/sky130_fd_sc_hd/spice/sky130_fd_sc_hd.spice
% load test
% getcell sky130_fd_sc_hd__and2_1
% gds write test     

abstract_view

Restart magic and the cell fails to be adequately loaded because the changes were not saved.

%gds read test
%save test

failed_load

When the test is reloaded after saving, we get the original layout.

% load test
% gds write test

We can edit the cell by making it editable.

% property
% cellname writeable sky130_fd_sc_hd__and2_1 true
% gds write test

editing

And after restarting magic and reloading it, we still get an unchanged cell

% gds read test

reload

Extraction

% extract all
% ext2spice lvs
% ext2spice

spice

% ext2spice cthresh 0.01
% ext2spice

spice_c

% ext2sim labels on
% ext2sim

% extresist tolerance 10
% extresist

% ext2spice lvs
% ext2spice cthresh 0.01
% ext2spice extresist on
% ext2spice

spice_rc

DRC

$ /usr/local/share/pdk/sky130A/libs.tech/magic/run_standard_drc.py /usr/local/share/pdk sky130A/libs.ref/sky130_fd_sc_hd/mag/sky130_fd_sc_hd__and2_1.mag
% drc liastall style
% drc style drc(full)
% drc check
% drc why
% drc find
% getcell sky130_fd_sc_hd__tapvpwrvgnd_1

drc

LVS

gen_spice

netgen -batch lvs "../mag/sky130_fd_sc_hd__and2_1.spice sky130_fd_sc_hd__and2_1" "/usr/local/share/pdk/sky130A/libs.ref/sky130_fd_sc_hd/spice/sky130_fd_sc_hd.spice sky130_fd_sc_hd__and2_1"

lvs_2

XOR

XOR is the process of comparing to GDS files by highlighting any differences between the two.

% flatten -nolabels xor_test

edit the cell

% xor -nolables xor_test
% load xor_test

xor_test

Chapter 3 - DRC Issues

Each foundry has its own manufacturing rules and we have to make sure that the layout abides by these. The stackup for the skywater130 process is as folows: stack

The detailed explaination of all the rules can be found at: https://skywater-pdk.readthedocs.io/en/main/rules.html

Useful Magic commands

  • b
  • s
  • ?
  • : box width 0.14um
  • : stret u 0.14um
  • : move e 0.14um
  • : box grow c 0.01um
  • : paint m1
  • drc find
  • see no *
  • see m1

Solving sample DRC violations in Magic

width_rule

ex_1a

spaceing_rule

ex_1b

wide_spacing_rule

ex_1c

notch_rule

ex_1d

via_size

ex_2a

multiple_vias

ex_2b

via_overlap

ex_2c

auto_generate_via

ex_2d

minimum_area_rule

ex_3a

minimum_hole_rule

ex_3b

wells

ex_4a

deep_nwell

ex_4c_1

automatic_deep_nwell

ex_4c_2

derived_layers

ex_5a

derived_layer_high_voltage

ex_5b

derived_layers_automatic_layers

ex_5c

Parameterized Devices

ex_6a

ex_6b

ex_6c

Angle errors

ex_7a

ex_7b

ex_7c

Overlap Errors

ex_7d

ex_7e

Latchup Rules

ex9

Antenna Rules

% extract all
% antennacheck debug
% antennacheck

ex10_1

ex10_2

ex10_3

Density Rules

The density of the fill pattern can be checked in magic by

% cif cover MET2

ex11_1

After writing the gds file, scripts can be used to generate the fill patterns

$/usr/local/share/pdk/sky130A/libs.tech/magic/check_density.py exercise_11.gds
$/usr/local/share/pdk/sky130A/libs.tech/magic/generate_fill.py exercise_11.mag

ex11_2

The fill patterns can be accurately loaded by

load excercise_11
box values 0 0 0 0
getcell excercise_11_fill_pattern child 0 0

ex11_3

Chapter 4 - LVS

excercise_1

Netgen will compare 2 netlists even if the cells are not contained in subckts. netgen can be launched with a GUI using

$ netgen

And then the 2 spice files can be compared using

% lvs netA.spice netB.spice

ex1_1

The actual information can be better analyzed in the comp.out file. By editing a netlist to mismatch and analyzing it we see ex1_2

netgen does not compare net names but matches them as closely as possible, putting them in the same partition. Here the format cell2/1 = 1 => pin 1 on cell 2 appears once ex1_3

In the device mismatch the Instance: cell3:3 1 = 3 represents pin 1 of the cell3 instance has a fanout of 3

ex1_4

Note: It is usually easier to debug from the net mismatch than the device mismatch

excercise_2

Unlike magic, Netgen has to be reinitialized between runs this can be done by

reinitialize

we can see despite having a subckt definition the devices are not checked ex2_1 A subckt definition is not an active component. It is only a device definition. Only subckt lines starting with x in a spice netlist are considered as active components. Both the spice netlists are considered as empty lists here by netgen

It is better to compare the netlists at a subckt level rather than the top level. we can give the subckt name to netgen by:

% lvs "netA.spice test" "netB.spice test"

ex2_2

Netgen does not care about the order of the pin names. It cares whether all the pin names are the same.

By changing the pin name order in netA.spice and rerunning lvs ex2_3

We see the circuits are matched. By swapping pin names at the top level inside the circuit and rechecking, we get the mismatch error.

ex2_4

this indicates that it is okay to have port order in an netlist in a differnt order, but since netgen cannot make any assumptions about the top level the pin names should match.

excercise_3

Instead of always running the GUI, a batch script can be made to run netgen in batch mode and output the files in a json file with a custom name

$ netgen -batch lvs "netA.spice test" "netB.spice test" \
  /usr/local/share/pdk/sky130A/libs.tech/netgen/sky130A_setup.tcl \
  exercise_3_comp.out -json | tee lvs.log

The json file gives a more machine readable file and can be viewed Using

../count_lvs.py | tee -a lvs.log

subckts that are defined and are completely empty are considered as blackbox entries. Ie the definition is a stand in for the circuit with the correct pin names and order. We can see how these pin names are reflected in the comp.out file. ex3_1

By changing the pin name order of subckt cell1 we do get a mismatch and this shows that the cell names are meaningful ex3_2

By changing the port names in cell1 from A B C to A B D and re running we get proxypins. Since these are blackbox circuits netgen assumes that port c is missing in circuitA and D is missing in circuitB

Netgen assumes that the cell has all pin A B C D and adds the proxy pin to show the missing pin

ex3_3

By changing the cell1 to cell 4 in both the definition and the instantiation.

We see that cells match and the cells are being flattened. This highlights an issue with blackcells. It cannot recognize when it is a blackbox cell and when it is an empty circuit

ex3_4 This can be solved by using the -blackbox flag which tells netgen to treat any empty cells as blackbox entries

$ netgen -batch lvs "netA.spice test" "netB.spice test" \
  /usr/local/share/pdk/sky130A/libs.tech/netgen/sky130A_setup.tcl \
  exercise_3_comp.out -json -blackbox | tee lvs.log

We see how this results in a device count mismatch ex3_5

both the cells show up in the same partition This highlights how even though components in the comp.out file may be aligned but are a complete mismatch

excercise_4

Devices have been added to subckts and as they do not begin with X they are not subckts themselves but low level components.

Low level circuits such as resistors can have their pin swapped ie they are permuteable. We can tell netgen to consider this by:

first copying the tech file to the same directory

$ cp /usr/local/share/pdk/sky130A/libs.tech/netgen//sky130A_setup.tcl .

Editing the run_lvs.sh script

$ netgen -batch lvs "netA.spice test" "netB.spice test" \
  sky130A_setup.tcl \
  exercise_4_comp.out -json | tee lvs.log

Apending the following lines to the bottom of sky130A_setup.tcl

permute "-circuit1 cell1" A C
permute "-circuit2 cell1" A C

pn running lvs we see the circuits match ex4_1

For the diode subckt when pins A and C are swapped both at the port name and low level cells, after running lvs we get no error but the comp.out file highlights how pins A and C have been swapped. ex4_2

excercise_5

Extract the Schematic netlist in xschem

Note: 1.change the extraction directory for the spice netlists 2.make sure the simulation top lvl is a subckt is selected 3.recopy the xcshemrc and .spiceinit files

ex5_1

Extract the netlist from magic

Note: 1.copy the magicrc file 2.run using magic -d XR

ex5_2

On comparing the netlists using netgen we can see that the issue is with the defination of standard cells, as they are missing in the netlist they are treated as blackbox cells. ex5_3

Extract the xschem netlist for the analog wrapper test bench ex5_4 Compare this with the previously extracted layout netlist, and we see that since the subckts are defined only pin matching errors are shown ex5_5

By analysing the example_por we realise that the layout contains top_level_circuits -> Parameterized_devices -> low_level_device as a hirarchy whereas the schematic netlist is top level circuits -> low_level_device.

Netgen automatically flattens these circuits to perform a comparision

We also see that using netgen we can compare any cells in a netlist.

Parameterized devices are extracted as individual devices strung together not as one parameterized devices. netgen flattens these automatically

ex5_6

Analysing the output for the wrapper again we can see the following errors in the comp.out files ex5_7

ex5_8

Lets fic the i0_analog[4] error, In the .mag file for the circuit we can see the 2 nets are shorted, that can be fixed by adding a resistor (resmet3) on the layer and re exporting the netlists make a not of the resistor size. ex5_10

Now edit the schematic bt=y adding the resistor and giving the appropriate values. Make sure to export the tb netlist and not only the subckt. ex5_9

On comparing the netlists again we can see a the mismatch error is resolved ex5_11

excercise_6

The design contains a fill cells that are avoided by Magic during extraction as they do not really contain anything inside them but are accurately placed by the router. ex6_1 So we ignore comparing these cells in netgen by changing the corresponding environment variable. ex6_2

We can do this in the run_lvs file by adding

export MAGIC_EXT_USE_GDS=1

on rerunning netgen we get no errors. ex6_3

excercise_7

If the veilog code is not of stuctural level and has any behavorial assignment netgen treats it as a black box and doesnot evaluate it. ex7_1

Another issue arising in cells are when different power rails are in the layout connected to the same substrate but magic fails to extract this. ex7_2 The different power layers can be tied together in the verilog code to fix this error. ex7_3

excercise_8

Generating the netlists and running netgen we first get a similar issue to ex6 and can be fixed by adding the following line to the run_lvs.sh script

export MAGIC_EXT_USE_GDS=1

ex8_1 Next we have a diode mismatch error and we can see that the diode is missing in the verilog file. The possible reason for this is that the diode was generated in an antennacheck. ex8_3 We can locate the diode in the layout using its instance name from the netgen output.

% select cell sky130_fd_sc_hd__diode_2_0

ex8_2 We can check which node the diode is connected to

% getnode

note : by pressing 's' three times we can select the net in the entire layout

ex8_4

The verilog file can be edited to add the diode circuit ex8_5 Rerunning netgen shows that the diode is available in the verilog netlist ex8_6 Moving on to the nect error we see there is a huge nimber of unconnected devices to the VPWR rail especially in the cell instance_249_ ex8_7 finding this in the layout we see it is missing via3 connections to VPWR ex8_8 This can be resolved by painting in the via3 ex8_9 This fixes all the mismatch issues and now we can move on to the final issue. Seeing the digital_pll circuit it looks like there is a broken net on instance_364_ ex8_10

ex8_11

ex8_12

ex8_13

ex8_14

ex8_15

ex8_16

excercise_9

Elements like resistors,capcitors can have property mismatches like width , lenght etc. These can be corrected in the schematic or layout.

Example of property errors. ex9_1 Errors corrected ex9_2

Additional Content - OpenLANE Design Flow

OpenLANE is an automated RTL to GDSII flow based on several components including OpenROAD, Yosys, Magic, Netgen, Fault, OpenPhySyn, CVC, SPEF-Extractor and custom methodology scripts for design exploration and optimization. The flow performs full ASIC implementation steps from RTL all the way down to GDSII.

Design Flow

flow.ong

  1. Synthesis
    1. yosys/abc - Perform RTL synthesis and technology mapping.
    2. OpenSTA - Performs static timing analysis on the resulting netlist to generate timing reports
  2. Floorplanning
    1. init_fp - Defines the core area for the macro as well as the rows (used for placement) and the tracks (used for routing)
    2. ioplacer - Places the macro input and output ports
    3. pdngen - Generates the power distribution network
    4. tapcell - Inserts welltap and decap cells in the floorplan
  3. Placement
    1. RePLace - Performs global placement
    2. Resizer - Performs optional optimizations on the design
    3. OpenDP - Performs detailed placement to legalize the globally placed components
  4. CTS
    1. TritonCTS - Synthesizes the clock distribution network (the clock tree)
  5. Routing
    1. FastRoute - Performs global routing to generate a guide file for the detailed router
    2. TritonRoute - Performs detailed routing
    3. OpenRCX - Performs SPEF extraction
  6. Tapeout
    1. Magic - Streams out the final GDSII layout file from the routed def
    2. KLayout - Streams out the final GDSII layout file from the routed def as a back-up
  7. Signoff
    1. Magic - Performs DRC Checks & Antenna Checks
    2. KLayout - Performs DRC Checks
    3. Netgen - Performs LVS Checks
    4. CVC - Performs Circuit Validity Checks

All the information about the project can be found in the openlANE documentation: https://openlane.readthedocs.io/en/latest/index.html

config.tcl

this file is necessary for running the openLANE flow and its documentation can be found at: https://openlane.readthedocs.io/en/latest/reference/configuration.html

Example - openLANE without interactive run

run the following in the openLANE directory

export PDK_ROOT=/usr/local/share/pdk
make mount
./flow.tcl -design spm -tag run1

This runs the entire openLANE flow and generates the required GDSII and .mag files which can be viewed in magic

Example - openLANE with interactive run

The interactive flow allows to run each step of the design flow. It can be launched using

export PDK_ROOT=/usr/local/share/pdk
make mount
./flow.tcl -interactive

Start the Design flow and synthesis with the following

package require openlane
prep -design spm -tag run1
run_synthesis

Run the Floorplanning using

run_floorplan

Run the placement using

run_placement

Run the clock tree generation and STA using

run_cts

The clock tree can be optimized using

run_resizer_timing

Run the routing using

run_routing

After all the changes that have taken place a new verilog file can be obtained using

write_powered_verilog
set_netlist $::env(lvs_result_file_tag).powered.v

Generate GDSII file using

run_magic

An alternate GDSII file is generated using klayout for XOR verification

run_klayout

Run the XOR test using

run_klayout_gds_xor

Export spice netlist using

run_magic_spice_export

Run LVS on exported spice netlist and verilog file

run_lvs

DRC checks

run_magic_drc

Antenna Checks

run_antenna_check

LEF checks DRC_checks

run_lef_cvc

Final summary report can be generated using DRC_checks

generate_final_summary_report

Example - Technique to prevent DRC errors

  • Local Interconnect rules : Avoid routing large traces on the local interconnect
  • Density Planning : The utilization ratio can be reduced to form more spaced circuits with lesser errors The FP_CORE_UTIL variable in the .config file
  • Dont use cells : Avoid using cells that are known to cause errors
  • Manual verification : For designs with lower number of DRC errors, the can be corrected with the methods discussed in chapter 3

Workshop Certificate

Certificate

About

Understanding Physical Verification using open source tools such as Magic and Netgen

Resources

Stars

Watchers

Forks

Languages