data:image/s3,"s3://crabby-images/81dbd/81dbdd7b36ca681cbb88fcebb2641cf6295a062e" alt="Home"
data:image/s3,"s3://crabby-images/80187/8018773820b57030e37c4dff605caab8db8d8c24" alt="Sue"
data:image/s3,"s3://crabby-images/1b522/1b5220c6b7ad5714044ce1bf456436929cb55059" alt="Sue Example"
data:image/s3,"s3://crabby-images/7bfa2/7bfa204292bfcb16cb9e6056aab6b22ad1b3f23c" alt="IRSIM"
data:image/s3,"s3://crabby-images/d5a3c/d5a3cfb4a1e6fb8bfbd9bddb4dae8438b1fcf4b9" alt="Netgen"
data:image/s3,"s3://crabby-images/b1b28/b1b28b7282af0ecd05e187a77da660fe2dd37280" alt="Magic"
data:image/s3,"s3://crabby-images/14a36/14a360f412b5f1081d123c201b96502a42c56b2a" alt="Pplot"
data:image/s3,"s3://crabby-images/8e286/8e2868f1db016a08ddc885a07f62b2f112041c87" alt="Mosis"
data:image/s3,"s3://crabby-images/d8ef2/d8ef2d42ea25288665a9fec4d2b5d393a0d7544d" alt="Search"
|
|
Netgen is a program for comparing circuit netlists. Normally it is used to verify circuit layout by comparing a netlist extracted from a circuit layout to a specification netlist that is assumed to be correct. This kind of verification is commonly known as LVS (layout versus schematic). You will use Netgen to compare the netlist generated from Sue (based on the schematic) with the one generated from Magic by ext2sim (based on the layout).
Running Netgen
-
Netgen is significantly disadvantaged, because it has a hard time with the orientation of transistors
that have mirrored ports. MOSFETs have this problem and so its a good idea to correct for this problem
before comparing two circuits.
Lucikly, netgen has a fix for this and so its important to type this command before running LVS.
permute transistors
-
Netgen has a script-level procedure "lvs" which takes care of the above
sequence of commands, as well as dumping the majority of the output to an
output file, and reporting only the final analysis in the console window.
The syntax of this command is:
lvs
<filename1> <filename2> [<logfilename>]
If "logfilename" is not specified, then the default filename "comp.out" will
be used.
-
Interpreting the output:
Illegal fragments are generated around areas where the netlists cannot be
resolved. The worst matches will be listed at the top, which is usually the
place to start looking.
Connectivity of elements and nodes can be traced with commands:
nodes <element_name>
<cellname>
elements <node_name> <cellname>
Where
cellname
is the filename (one of the two files loaded for comparison). The
elements
command prints all of the elements (transistors, capacitors, resistors,
etc.) connected to a specific named node. The
nodes
command prints the node names for each pin of the specified element. For
".sim" netlists containing position information for each transistor, all
transistor elements (and some non-transistor elements such as poly-poly
capacitors and rpoly resistors extracted from magic) will have names like
"n@45,376" indicating an n-type transistor at position x=45, y=376 on the
layout. This naming convention permits tracing errors back to the layout and
schematic.
Netgen ignores all lines in the .sim file that begin with A, B, R,
v and semicolon. There are also a variety of options that can be specified on
the command line. For a full list of options see
Netgen manual page.
Netgen produces certain
information about the circuits (e.g., number of devices, number of nets) and
tries to match all the nodes.
The comparison is successful if you get the
message:
Circuits match uniquely.
LVS done.
If the comparison fails, you will get
the error message (e.g. Graphs do not match, Node mismatch etc.)
If you get this message you should go
back and check your layout for functional differences from the schematic.
|