mirror of https://github.com/KLayout/klayout.git
WIP: some fixes and small enhancements. New tests.
This commit is contained in:
parent
bc2d9448d6
commit
b48453633f
|
|
@ -2166,6 +2166,10 @@ template <class T>
|
||||||
recursive_cluster_shape_iterator<T>::recursive_cluster_shape_iterator (const hier_clusters<T> &hc, unsigned int layer, db::cell_index_type ci, typename local_cluster<T>::id_type id)
|
recursive_cluster_shape_iterator<T>::recursive_cluster_shape_iterator (const hier_clusters<T> &hc, unsigned int layer, db::cell_index_type ci, typename local_cluster<T>::id_type id)
|
||||||
: mp_hc (&hc), m_layer (layer), m_id (id)
|
: mp_hc (&hc), m_layer (layer), m_id (id)
|
||||||
{
|
{
|
||||||
|
if (id == 0) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
down (ci, id, db::ICplxTrans ());
|
down (ci, id, db::ICplxTrans ());
|
||||||
|
|
||||||
while (m_shape_iter.at_end () && ! m_conn_iter_stack.empty ()) {
|
while (m_shape_iter.at_end () && ! m_conn_iter_stack.empty ()) {
|
||||||
|
|
|
||||||
|
|
@ -311,6 +311,8 @@ void LayoutToNetlistStandardReader::read_netlist (db::Netlist *netlist, db::Layo
|
||||||
read_device (netlist, l2n, circuit, *map, connections);
|
read_device (netlist, l2n, circuit, *map, connections);
|
||||||
} else if (test (skeys::circuit_key) || test (lkeys::circuit_key)) {
|
} else if (test (skeys::circuit_key) || test (lkeys::circuit_key)) {
|
||||||
read_subcircuit (netlist, l2n, circuit, *map, connections);
|
read_subcircuit (netlist, l2n, circuit, *map, connections);
|
||||||
|
} else if (at_end ()) {
|
||||||
|
throw tl::Exception (tl::to_string (tr ("Unexpected end of file inside circuit definition (net, pin, device or circuit expected)")));
|
||||||
} else {
|
} else {
|
||||||
throw tl::Exception (tl::to_string (tr ("Invalid keyword inside circuit definition (net, pin, device or circuit expected)")));
|
throw tl::Exception (tl::to_string (tr ("Invalid keyword inside circuit definition (net, pin, device or circuit expected)")));
|
||||||
}
|
}
|
||||||
|
|
@ -368,6 +370,8 @@ void LayoutToNetlistStandardReader::read_netlist (db::Netlist *netlist, db::Layo
|
||||||
|
|
||||||
if (test (skeys::terminal_key) || test (lkeys::terminal_key)) {
|
if (test (skeys::terminal_key) || test (lkeys::terminal_key)) {
|
||||||
read_abstract_terminal (l2n, dm, gen_dc ? dc : 0);
|
read_abstract_terminal (l2n, dm, gen_dc ? dc : 0);
|
||||||
|
} else if (at_end ()) {
|
||||||
|
throw tl::Exception (tl::to_string (tr ("Unexpected end of file inside device abstract definition (terminal expected)")));
|
||||||
} else {
|
} else {
|
||||||
throw tl::Exception (tl::to_string (tr ("Invalid keyword inside device abstract definition (terminal expected)")));
|
throw tl::Exception (tl::to_string (tr ("Invalid keyword inside device abstract definition (terminal expected)")));
|
||||||
}
|
}
|
||||||
|
|
@ -378,6 +382,8 @@ void LayoutToNetlistStandardReader::read_netlist (db::Netlist *netlist, db::Layo
|
||||||
|
|
||||||
} else if (nested) {
|
} else if (nested) {
|
||||||
break;
|
break;
|
||||||
|
} else if (at_end ()) {
|
||||||
|
throw tl::Exception (tl::to_string (tr ("Unexpected end of file")));
|
||||||
} else {
|
} else {
|
||||||
throw tl::Exception (tl::to_string (tr ("Invalid keyword")));
|
throw tl::Exception (tl::to_string (tr ("Invalid keyword")));
|
||||||
}
|
}
|
||||||
|
|
@ -448,6 +454,8 @@ LayoutToNetlistStandardReader::read_geometry (db::LayoutToNetlist *l2n)
|
||||||
poly.assign_hull (pt.begin (), pt.end ());
|
poly.assign_hull (pt.begin (), pt.end ());
|
||||||
return std::make_pair (lid, db::PolygonRef (poly, l2n->internal_layout ()->shape_repository ()));
|
return std::make_pair (lid, db::PolygonRef (poly, l2n->internal_layout ()->shape_repository ()));
|
||||||
|
|
||||||
|
} else if (at_end ()) {
|
||||||
|
throw tl::Exception (tl::to_string (tr ("Unexpected end of file inside net or terminal definition (polygon or rect expected)")));
|
||||||
} else {
|
} else {
|
||||||
throw tl::Exception (tl::to_string (tr ("Invalid keyword inside net or terminal definition (polygon or rect expected)")));
|
throw tl::Exception (tl::to_string (tr ("Invalid keyword inside net or terminal definition (polygon or rect expected)")));
|
||||||
}
|
}
|
||||||
|
|
@ -700,6 +708,8 @@ LayoutToNetlistStandardReader::read_device (db::Netlist *netlist, db::LayoutToNe
|
||||||
|
|
||||||
device->set_parameter_value (pid, value);
|
device->set_parameter_value (pid, value);
|
||||||
|
|
||||||
|
} else if (at_end ()) {
|
||||||
|
throw tl::Exception (tl::to_string (tr ("Unexpected end of file inside device definition (location, scale, mirror, rotation, param or terminal expected)")));
|
||||||
} else {
|
} else {
|
||||||
throw tl::Exception (tl::to_string (tr ("Invalid keyword inside device definition (location, scale, mirror, rotation, param or terminal expected)")));
|
throw tl::Exception (tl::to_string (tr ("Invalid keyword inside device definition (location, scale, mirror, rotation, param or terminal expected)")));
|
||||||
}
|
}
|
||||||
|
|
@ -875,6 +885,8 @@ LayoutToNetlistStandardReader::read_subcircuit (db::Netlist *netlist, db::Layout
|
||||||
refs.push_back (Connections (net->cluster_id (), sc_net->cluster_id ()));
|
refs.push_back (Connections (net->cluster_id (), sc_net->cluster_id ()));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
} else if (at_end ()) {
|
||||||
|
throw tl::Exception (tl::to_string (tr ("Unexpected end of file inside subcircuit definition (location, rotation, mirror, scale or pin expected)")));
|
||||||
} else {
|
} else {
|
||||||
throw tl::Exception (tl::to_string (tr ("Invalid keyword inside subcircuit definition (location, rotation, mirror, scale or pin expected)")));
|
throw tl::Exception (tl::to_string (tr ("Invalid keyword inside subcircuit definition (location, rotation, mirror, scale or pin expected)")));
|
||||||
}
|
}
|
||||||
|
|
|
||||||
|
|
@ -103,6 +103,8 @@ void LayoutVsSchematicStandardReader::read_netlist (db::LayoutVsSchematic *lvs)
|
||||||
read_xref (xref);
|
read_xref (xref);
|
||||||
xref->gen_end_netlist (lvs->netlist (), lvs->reference_netlist ());
|
xref->gen_end_netlist (lvs->netlist (), lvs->reference_netlist ());
|
||||||
|
|
||||||
|
} else if (at_end ()) {
|
||||||
|
throw tl::Exception (tl::to_string (tr ("Unexpected end of file")));
|
||||||
} else {
|
} else {
|
||||||
throw tl::Exception (tl::to_string (tr ("Invalid keyword")));
|
throw tl::Exception (tl::to_string (tr ("Invalid keyword")));
|
||||||
}
|
}
|
||||||
|
|
@ -145,6 +147,8 @@ void LayoutVsSchematicStandardReader::read_xrefs_for_circuits (db::NetlistCrossR
|
||||||
read_device_pair (xref, circuit_a, circuit_b);
|
read_device_pair (xref, circuit_a, circuit_b);
|
||||||
} else if (test (skeys::circuit_key) || test (lkeys::circuit_key)) {
|
} else if (test (skeys::circuit_key) || test (lkeys::circuit_key)) {
|
||||||
read_subcircuit_pair (xref, circuit_a, circuit_b);
|
read_subcircuit_pair (xref, circuit_a, circuit_b);
|
||||||
|
} else if (at_end ()) {
|
||||||
|
throw tl::Exception (tl::to_string (tr ("Unexpected end of file inside circuit definition (net, pin, device or circuit expected)")));
|
||||||
} else {
|
} else {
|
||||||
throw tl::Exception (tl::to_string (tr ("Invalid keyword inside circuit definition (net, pin, device or circuit expected)")));
|
throw tl::Exception (tl::to_string (tr ("Invalid keyword inside circuit definition (net, pin, device or circuit expected)")));
|
||||||
}
|
}
|
||||||
|
|
@ -192,6 +196,8 @@ void LayoutVsSchematicStandardReader::read_xref (db::NetlistCrossReference *xref
|
||||||
// continue
|
// continue
|
||||||
} else if (test (skeys::xref_key) || test (lkeys::xref_key)) {
|
} else if (test (skeys::xref_key) || test (lkeys::xref_key)) {
|
||||||
read_xrefs_for_circuits (xref, circuit_a, circuit_b);
|
read_xrefs_for_circuits (xref, circuit_a, circuit_b);
|
||||||
|
} else if (at_end ()) {
|
||||||
|
throw tl::Exception (tl::to_string (tr ("Unexpected end of file inside circuit definition (status keyword of xrefs expected)")));
|
||||||
} else {
|
} else {
|
||||||
throw tl::Exception (tl::to_string (tr ("Invalid keyword inside circuit definition (status keyword of xrefs expected)")));
|
throw tl::Exception (tl::to_string (tr ("Invalid keyword inside circuit definition (status keyword of xrefs expected)")));
|
||||||
}
|
}
|
||||||
|
|
|
||||||
|
|
@ -57,7 +57,8 @@ module LVS
|
||||||
@lvs = RBA::LayoutVsSchematic::new(@engine._dss)
|
@lvs = RBA::LayoutVsSchematic::new(@engine._dss)
|
||||||
else
|
else
|
||||||
layout = @engine.source.layout
|
layout = @engine.source.layout
|
||||||
@lvs = RBA::LayoutVsSchematic::new(layout.top_cell.name, layout.dbu)
|
cell = @engine.source.cell_obj
|
||||||
|
@lvs = RBA::LayoutVsSchematic::new(cell.name, layout.dbu)
|
||||||
end
|
end
|
||||||
|
|
||||||
@l2n = @lvs
|
@l2n = @lvs
|
||||||
|
|
@ -122,7 +123,11 @@ module LVS
|
||||||
# @synopsis same_nets(circuit_a, net_a, circuit_b, net_b)
|
# @synopsis same_nets(circuit_a, net_a, circuit_b, net_b)
|
||||||
# This method will force an equivalence between the net_a and net_b from circuit_a
|
# This method will force an equivalence between the net_a and net_b from circuit_a
|
||||||
# and circuit_b (circuit in the three-argument form is for both circuit_a and circuit_b).
|
# and circuit_b (circuit in the three-argument form is for both circuit_a and circuit_b).
|
||||||
# Circuit and nets are string giving a circuit and net by name.
|
#
|
||||||
|
# In the four-argument form, the circuits can be either given by name or as Circuit
|
||||||
|
# objects. In the three-argument form, the circuit has to be given by name.
|
||||||
|
# Nets can be either given by name or as Net objects.
|
||||||
|
#
|
||||||
# After using this function, the compare algorithm will consider these nets equivalent.
|
# After using this function, the compare algorithm will consider these nets equivalent.
|
||||||
# Use this method to provide hints for the comparer in cases which are difficult to
|
# Use this method to provide hints for the comparer in cases which are difficult to
|
||||||
# resolve otherwise.
|
# resolve otherwise.
|
||||||
|
|
@ -132,9 +137,6 @@ module LVS
|
||||||
|
|
||||||
def same_nets(*args)
|
def same_nets(*args)
|
||||||
|
|
||||||
pins.each do |a|
|
|
||||||
a.is_a?(String) || raise("All arguments of 'same_nets' need to be strings")
|
|
||||||
end
|
|
||||||
if args.size < 3
|
if args.size < 3
|
||||||
raise("Too few arguments to 'same_nets' (need at least 3)")
|
raise("Too few arguments to 'same_nets' (need at least 3)")
|
||||||
end
|
end
|
||||||
|
|
@ -145,17 +147,43 @@ module LVS
|
||||||
if args.size == 3
|
if args.size == 3
|
||||||
( ca, a, b ) = args
|
( ca, a, b ) = args
|
||||||
cb = ca
|
cb = ca
|
||||||
|
ca.is_a?(String) || raise("Circuit argument of 'same_nets' must be a string")
|
||||||
else
|
else
|
||||||
( ca, a, cb, b ) = args
|
( ca, a, cb, b ) = args
|
||||||
|
[ ca, cb ].each do |n|
|
||||||
|
n.is_a?(String) || n.is_a?(RBA::Net) || raise("Circuit arguments of 'same_nets' must be strings or Net objects")
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
[ a, b ].each do |n|
|
||||||
|
n.is_a?(String) || n.is_a?(RBA::Net) || raise("Net arguments of 'same_nets' must be strings or Net objects")
|
||||||
end
|
end
|
||||||
|
|
||||||
( nl_a, nl_b ) = _ensure_two_netlists
|
( nl_a, nl_b ) = _ensure_two_netlists
|
||||||
|
|
||||||
|
if ca.is_a?(String)
|
||||||
circuit_a = nl_a.circuit_by_name(ca) || raise("Not a valid circuit name in extracted netlist: #{ca}")
|
circuit_a = nl_a.circuit_by_name(ca) || raise("Not a valid circuit name in extracted netlist: #{ca}")
|
||||||
circuit_b = nl_b.circuit_by_name(cb) || raise("Not a valid circuit name in reference netlist: #{cb}")
|
else
|
||||||
|
circuit_a = ca
|
||||||
|
end
|
||||||
|
|
||||||
|
if cb.is_a?(String)
|
||||||
|
circuit_b = nl_b.circuit_by_name(cb) || raise("Not a valid circuit name in reference netlist: #{cb}")
|
||||||
|
else
|
||||||
|
circuit_b = cb
|
||||||
|
end
|
||||||
|
|
||||||
|
if a.is_a?(String)
|
||||||
net_a = circuit_a.net_by_name(a) || raise("Not a valid net name in extracted netlist: #{a} (for circuit #{circuit_a})")
|
net_a = circuit_a.net_by_name(a) || raise("Not a valid net name in extracted netlist: #{a} (for circuit #{circuit_a})")
|
||||||
|
else
|
||||||
|
net_a = a
|
||||||
|
end
|
||||||
|
|
||||||
|
if b.is_a?(String)
|
||||||
net_b = circuit_b.net_by_name(b) || raise("Not a valid net name in reference netlist: #{b} (for circuit #{circuit_b})")
|
net_b = circuit_b.net_by_name(b) || raise("Not a valid net name in reference netlist: #{b} (for circuit #{circuit_b})")
|
||||||
|
else
|
||||||
|
net_b = b
|
||||||
|
end
|
||||||
|
|
||||||
@comparer.same_nets(net_a, net_b)
|
@comparer.same_nets(net_a, net_b)
|
||||||
|
|
||||||
|
|
|
||||||
|
|
@ -94,3 +94,27 @@ TEST(4_simple_implicit_connections)
|
||||||
run_test (_this, "ringo_simple_implicit_connections", "ringo_implicit_connections.gds");
|
run_test (_this, "ringo_simple_implicit_connections", "ringo_implicit_connections.gds");
|
||||||
}
|
}
|
||||||
|
|
||||||
|
TEST(5_simple_same_device_classes)
|
||||||
|
{
|
||||||
|
run_test (_this, "ringo_simple_same_device_classes", "ringo.gds");
|
||||||
|
}
|
||||||
|
|
||||||
|
TEST(6_simple_pin_swapping)
|
||||||
|
{
|
||||||
|
run_test (_this, "ringo_simple_pin_swapping", "ringo.gds");
|
||||||
|
}
|
||||||
|
|
||||||
|
TEST(7_net_and_circuit_equivalence)
|
||||||
|
{
|
||||||
|
run_test (_this, "ringo_simple_net_and_circuit_equivalence", "ringo_renamed.gds");
|
||||||
|
}
|
||||||
|
|
||||||
|
TEST(8_simplification)
|
||||||
|
{
|
||||||
|
run_test (_this, "ringo_simple_simplification", "ringo_for_simplification.gds");
|
||||||
|
}
|
||||||
|
|
||||||
|
TEST(9_blackboxing)
|
||||||
|
{
|
||||||
|
run_test (_this, "ringo_simple_blackboxing", "ringo_for_blackboxing.gds");
|
||||||
|
}
|
||||||
|
|
|
||||||
|
|
@ -0,0 +1,32 @@
|
||||||
|
|
||||||
|
.SUBCKT RINGO VSS VDD FB ENABLE OUT
|
||||||
|
X$1 VDD 1 VSS VDD FB ENABLE VSS ND2X1
|
||||||
|
X$2 VDD 2 VSS VDD 1 VSS INVX1
|
||||||
|
X$3 VDD 3 VSS VDD 2 VSS INVX1
|
||||||
|
X$4 VDD 4 VSS VDD 3 VSS INVX1
|
||||||
|
X$5 VDD 5 VSS VDD 4 VSS INVX1
|
||||||
|
X$6 VDD 6 VSS VDD 5 VSS INVX1
|
||||||
|
X$7 VDD 7 VSS VDD 6 VSS INVX1
|
||||||
|
X$8 VDD 8 VSS VDD 7 VSS INVX1
|
||||||
|
X$9 VDD 9 VSS VDD 8 VSS INVX1
|
||||||
|
X$10 VDD 10 VSS VDD 9 VSS INVX1
|
||||||
|
X$11 VDD FB VSS VDD 10 VSS INVX1
|
||||||
|
X$12 VDD OUT VSS VDD FB VSS INVX2
|
||||||
|
.ENDS RINGO
|
||||||
|
|
||||||
|
.SUBCKT ND2X1 VDD OUT VSS NWELL B A BULK
|
||||||
|
M$1 OUT A VDD NWELL PMOS L=0.25U W=1.5U
|
||||||
|
M$2 VDD B OUT NWELL PMOS L=0.25U W=1.5U
|
||||||
|
M$3 VSS A 1 BULK NMOS L=0.25U W=0.95U
|
||||||
|
M$4 1 B OUT BULK NMOS L=0.25U W=0.95U
|
||||||
|
.ENDS ND2X1
|
||||||
|
|
||||||
|
.SUBCKT INVX1 VDD OUT VSS NWELL IN BULK
|
||||||
|
M$1 VDD IN OUT NWELL PMOS L=0.25U W=1.5U
|
||||||
|
M$2 VSS IN OUT BULK NMOS L=0.25U W=0.95U
|
||||||
|
.ENDS INVX1
|
||||||
|
|
||||||
|
.SUBCKT INVX2 VDD OUT VSS NWELL IN BULK
|
||||||
|
M$1 VDD IN OUT NWELL PMOS L=0.25U W=3.0U
|
||||||
|
M$2 VSS IN OUT BULK NMOS L=0.25U W=1.9U
|
||||||
|
.ENDS INVX1
|
||||||
Binary file not shown.
|
|
@ -0,0 +1,32 @@
|
||||||
|
|
||||||
|
.SUBCKT RINGO VSS VDD FB ENABLE OUT
|
||||||
|
X$1 VDD 1 VSS VDD FB ENABLE VSS ND2X1
|
||||||
|
X$2 VDD 2 VSS VDD 1 VSS INVX1
|
||||||
|
X$3 VDD 3 VSS VDD 2 VSS INVX1
|
||||||
|
X$4 VDD 4 VSS VDD 3 VSS INVX1
|
||||||
|
X$5 VDD 5 VSS VDD 4 VSS INVX1
|
||||||
|
X$6 VDD 6 VSS VDD 5 VSS INVX1
|
||||||
|
X$7 VDD 7 VSS VDD 6 VSS INVX1
|
||||||
|
X$8 VDD 8 VSS VDD 7 VSS INVX1
|
||||||
|
X$9 VDD 9 VSS VDD 8 VSS INVX1
|
||||||
|
X$10 VDD 10 VSS VDD 9 VSS INVX1
|
||||||
|
X$11 VDD FB VSS VDD 10 VSS INVX1
|
||||||
|
X$12 VDD OUT VSS VDD FB VSS INVX2
|
||||||
|
.ENDS RINGO
|
||||||
|
|
||||||
|
.SUBCKT ND2X1 VDD OUT VSS NWELL B A BULK
|
||||||
|
M$1 OUT A VDD NWELL PMOS L=0.25U W=1.5U
|
||||||
|
M$2 VDD B OUT NWELL PMOS L=0.25U W=1.5U
|
||||||
|
M$3 VSS A 1 BULK NMOS L=0.25U W=0.95U
|
||||||
|
M$4 1 B OUT BULK NMOS L=0.25U W=0.95U
|
||||||
|
.ENDS ND2X1
|
||||||
|
|
||||||
|
.SUBCKT INVX1 VDD OUT VSS NWELL IN BULK
|
||||||
|
M$1 VDD IN OUT NWELL PMOS L=0.25U W=1.5U
|
||||||
|
M$2 VSS IN OUT BULK NMOS L=0.25U W=0.95U
|
||||||
|
.ENDS INVX1
|
||||||
|
|
||||||
|
.SUBCKT INVX2 VDD OUT VSS NWELL IN BULK
|
||||||
|
M$1 VDD IN OUT NWELL PMOS L=0.25U W=3.0U
|
||||||
|
M$2 VSS IN OUT BULK NMOS L=0.25U W=1.9U
|
||||||
|
.ENDS INVX1
|
||||||
Binary file not shown.
|
|
@ -0,0 +1,27 @@
|
||||||
|
|
||||||
|
.SUBCKT RINGO VSS VDD FB ENABLE OUT
|
||||||
|
X$1 VDD 1 VSS VDD FB ENABLE VSS ND2X1
|
||||||
|
X$2 VDD 2 VSS VDD 1 VSS INVX1
|
||||||
|
X$3 VDD 3 VSS VDD 2 VSS INVX1
|
||||||
|
X$4 VDD 4 VSS VDD 3 VSS INVX1
|
||||||
|
X$5 VDD 5 VSS VDD 4 VSS INVX1
|
||||||
|
X$6 VDD 6 VSS VDD 5 VSS INVX1
|
||||||
|
X$7 VDD 7 VSS VDD 6 VSS INVX1
|
||||||
|
X$8 VDD 8 VSS VDD 7 VSS INVX1
|
||||||
|
X$9 VDD 9 VSS VDD 8 VSS INVX1
|
||||||
|
X$10 VDD 10 VSS VDD 9 VSS INVX1
|
||||||
|
X$11 VDD FB VSS VDD 10 VSS INVX1
|
||||||
|
X$12 VDD OUT VSS VDD FB VSS INVX1
|
||||||
|
.ENDS RINGO
|
||||||
|
|
||||||
|
.SUBCKT ND2X1 VDD OUT VSS NWELL A B BULK
|
||||||
|
M$1 OUT A VDD NWELL PMOS L=0.25U W=1.5U
|
||||||
|
M$2 VDD B OUT NWELL PMOS L=0.25U W=1.5U
|
||||||
|
M$3 VSS A 1 BULK NMOS L=0.25U W=0.95U
|
||||||
|
M$4 1 B OUT BULK NMOS L=0.25U W=0.95U
|
||||||
|
.ENDS ND2X1
|
||||||
|
|
||||||
|
.SUBCKT INVX1 VDD OUT VSS NWELL IN BULK
|
||||||
|
M$1 VDD IN OUT NWELL PMOS L=0.25U W=1.5U
|
||||||
|
M$2 VSS IN OUT BULK NMOS L=0.25U W=0.95U
|
||||||
|
.ENDS INVX1
|
||||||
Binary file not shown.
|
|
@ -0,0 +1,102 @@
|
||||||
|
* Extracted by KLayout
|
||||||
|
|
||||||
|
* cell RINGO
|
||||||
|
* pin FB
|
||||||
|
* pin VDD
|
||||||
|
* pin OUT
|
||||||
|
* pin ENABLE
|
||||||
|
* pin VSS
|
||||||
|
.SUBCKT RINGO 5 6 7 8 9
|
||||||
|
* net 5 FB
|
||||||
|
* net 6 VDD
|
||||||
|
* net 7 OUT
|
||||||
|
* net 8 ENABLE
|
||||||
|
* net 9 VSS
|
||||||
|
* cell instance $1 r0 *1 1.8,0
|
||||||
|
X$1 6 1 9 6 5 8 9 ND2X1
|
||||||
|
* cell instance $2 r0 *1 4.2,0
|
||||||
|
X$2 6 2 9 6 1 9 INVX1
|
||||||
|
* cell instance $3 r0 *1 6,0
|
||||||
|
X$3 6 10 9 6 2 9 INVX1
|
||||||
|
* cell instance $4 r0 *1 16.8,0
|
||||||
|
X$4 6 3 9 6 11 9 INVX1
|
||||||
|
* cell instance $5 r0 *1 18.6,0
|
||||||
|
X$5 6 4 9 6 3 9 INVX1
|
||||||
|
* cell instance $6 r0 *1 20.4,0
|
||||||
|
X$6 6 5 9 6 4 9 INVX1
|
||||||
|
* cell instance $7 r0 *1 22.2,0
|
||||||
|
X$7 5 6 7 9 6 9 INVX2
|
||||||
|
* cell instance $17 r0 *1 7.8,0
|
||||||
|
X$17 6 12 9 6 10 9 INVX1
|
||||||
|
* cell instance $18 r0 *1 9.6,0
|
||||||
|
X$18 6 13 9 6 12 9 INVX1
|
||||||
|
* cell instance $19 r0 *1 11.4,0
|
||||||
|
X$19 6 14 9 6 13 9 INVX1
|
||||||
|
* cell instance $20 r0 *1 13.2,0
|
||||||
|
X$20 6 15 9 6 14 9 INVX1
|
||||||
|
* cell instance $21 r0 *1 15,0
|
||||||
|
X$21 6 11 9 6 15 9 INVX1
|
||||||
|
.ENDS RINGO
|
||||||
|
|
||||||
|
* cell INVX2
|
||||||
|
* pin IN
|
||||||
|
* pin VDD
|
||||||
|
* pin OUT
|
||||||
|
* pin VSS
|
||||||
|
* pin
|
||||||
|
* pin SUBSTRATE
|
||||||
|
.SUBCKT INVX2 1 2 3 4 5 6
|
||||||
|
* net 1 IN
|
||||||
|
* net 2 VDD
|
||||||
|
* net 3 OUT
|
||||||
|
* net 4 VSS
|
||||||
|
* net 6 SUBSTRATE
|
||||||
|
* device instance $1 r0 *1 0.85,5.8 PMOS
|
||||||
|
M$1 2 1 3 5 PMOS L=0.25U W=3U AS=0.975P AD=0.975P PS=5.8U PD=5.8U
|
||||||
|
* device instance $3 r0 *1 0.85,2.135 NMOS
|
||||||
|
M$3 4 1 3 6 NMOS L=0.25U W=1.9U AS=0.6175P AD=0.6175P PS=4.15U PD=4.15U
|
||||||
|
.ENDS INVX2
|
||||||
|
|
||||||
|
* cell INVX1
|
||||||
|
* pin VDD
|
||||||
|
* pin OUT
|
||||||
|
* pin VSS
|
||||||
|
* pin
|
||||||
|
* pin IN
|
||||||
|
* pin SUBSTRATE
|
||||||
|
.SUBCKT INVX1 1 2 3 4 5 6
|
||||||
|
* net 1 VDD
|
||||||
|
* net 2 OUT
|
||||||
|
* net 3 VSS
|
||||||
|
* net 5 IN
|
||||||
|
* net 6 SUBSTRATE
|
||||||
|
* device instance $1 r0 *1 0.85,5.8 PMOS
|
||||||
|
M$1 1 5 2 4 PMOS L=0.25U W=1.5U AS=0.6375P AD=0.6375P PS=3.85U PD=3.85U
|
||||||
|
* device instance $2 r0 *1 0.85,2.135 NMOS
|
||||||
|
M$2 3 5 2 6 NMOS L=0.25U W=0.95U AS=0.40375P AD=0.40375P PS=2.75U PD=2.75U
|
||||||
|
.ENDS INVX1
|
||||||
|
|
||||||
|
* cell ND2X1
|
||||||
|
* pin VDD
|
||||||
|
* pin OUT
|
||||||
|
* pin VSS
|
||||||
|
* pin
|
||||||
|
* pin B
|
||||||
|
* pin A
|
||||||
|
* pin SUBSTRATE
|
||||||
|
.SUBCKT ND2X1 1 2 3 4 5 6 7
|
||||||
|
* net 1 VDD
|
||||||
|
* net 2 OUT
|
||||||
|
* net 3 VSS
|
||||||
|
* net 5 B
|
||||||
|
* net 6 A
|
||||||
|
* net 7 SUBSTRATE
|
||||||
|
* device instance $1 r0 *1 0.85,5.8 PMOS
|
||||||
|
M$1 2 6 1 4 PMOS L=0.25U W=1.5U AS=0.6375P AD=0.3375P PS=3.85U PD=1.95U
|
||||||
|
* device instance $2 r0 *1 1.55,5.8 PMOS
|
||||||
|
M$2 1 5 2 4 PMOS L=0.25U W=1.5U AS=0.3375P AD=0.6375P PS=1.95U PD=3.85U
|
||||||
|
* device instance $3 r0 *1 0.85,2.135 NMOS
|
||||||
|
M$3 3 6 8 7 NMOS L=0.25U W=0.95U AS=0.40375P AD=0.21375P PS=2.75U PD=1.4U
|
||||||
|
* device instance $4 r0 *1 1.55,2.135 NMOS
|
||||||
|
M$4 8 5 2 7 NMOS L=0.25U W=0.95U AS=0.21375P AD=0.40375P PS=1.4U PD=2.75U
|
||||||
|
.ENDS ND2X1
|
||||||
|
|
@ -0,0 +1,85 @@
|
||||||
|
|
||||||
|
source($lvs_test_source, "RINGO")
|
||||||
|
|
||||||
|
report_lvs($lvs_test_target_lvsdb)
|
||||||
|
|
||||||
|
target_netlist($lvs_test_target_cir, write_spice, "Extracted by KLayout")
|
||||||
|
|
||||||
|
schematic("ringo_for_blackboxing.cir")
|
||||||
|
|
||||||
|
deep
|
||||||
|
|
||||||
|
# Drawing layers
|
||||||
|
|
||||||
|
nwell = input(1, 0)
|
||||||
|
active = input(2, 0)
|
||||||
|
pplus = input(3, 0)
|
||||||
|
nplus = input(4, 0)
|
||||||
|
poly = input(5, 0)
|
||||||
|
contact = input(8, 0)
|
||||||
|
metal1 = input(9, 0)
|
||||||
|
via1 = input(10, 0)
|
||||||
|
metal2 = input(11, 0)
|
||||||
|
|
||||||
|
# Bulk layer for terminal provisioning
|
||||||
|
|
||||||
|
bulk = polygon_layer
|
||||||
|
|
||||||
|
# Computed layers
|
||||||
|
|
||||||
|
active_in_nwell = active & nwell
|
||||||
|
pactive = active_in_nwell & pplus
|
||||||
|
pgate = pactive & poly
|
||||||
|
psd = pactive - pgate
|
||||||
|
ntie = active_in_nwell & nplus
|
||||||
|
|
||||||
|
active_outside_nwell = active - nwell
|
||||||
|
nactive = active_outside_nwell & nplus
|
||||||
|
ngate = nactive & poly
|
||||||
|
nsd = nactive - ngate
|
||||||
|
ptie = active_outside_nwell & pplus
|
||||||
|
|
||||||
|
# Device extraction
|
||||||
|
|
||||||
|
# PMOS transistor device extraction
|
||||||
|
extract_devices(mos4("PMOS"), { "SD" => psd, "G" => pgate, "W" => nwell,
|
||||||
|
"tS" => psd, "tD" => psd, "tG" => poly, "tW" => nwell })
|
||||||
|
|
||||||
|
# NMOS transistor device extraction
|
||||||
|
extract_devices(mos4("NMOS"), { "SD" => nsd, "G" => ngate, "W" => bulk,
|
||||||
|
"tS" => nsd, "tD" => nsd, "tG" => poly, "tW" => bulk })
|
||||||
|
|
||||||
|
# Define connectivity for netlist extraction
|
||||||
|
|
||||||
|
# Inter-layer
|
||||||
|
connect(psd, contact)
|
||||||
|
connect(nsd, contact)
|
||||||
|
connect(poly, contact)
|
||||||
|
connect(ntie, contact)
|
||||||
|
connect(nwell, ntie)
|
||||||
|
connect(ptie, contact)
|
||||||
|
connect(contact, metal1)
|
||||||
|
connect(metal1, via1)
|
||||||
|
connect(via1, metal2)
|
||||||
|
|
||||||
|
# Global
|
||||||
|
connect_global(bulk, "SUBSTRATE")
|
||||||
|
connect_global(ptie, "SUBSTRATE")
|
||||||
|
|
||||||
|
# Compare section
|
||||||
|
|
||||||
|
netlist.flatten_circuit("INVCHAIN")
|
||||||
|
netlist.blank_circuit("INVX1")
|
||||||
|
netlist.blank_circuit("INVX2")
|
||||||
|
netlist.blank_circuit("ND2X1")
|
||||||
|
schematic.blank_circuit("INVX1")
|
||||||
|
schematic.blank_circuit("INVX2")
|
||||||
|
schematic.blank_circuit("ND2X1")
|
||||||
|
|
||||||
|
netlist.make_top_level_pins
|
||||||
|
netlist.purge
|
||||||
|
netlist.combine_devices
|
||||||
|
netlist.purge_nets
|
||||||
|
|
||||||
|
compare
|
||||||
|
|
||||||
File diff suppressed because it is too large
Load Diff
|
|
@ -0,0 +1,83 @@
|
||||||
|
* Extracted by KLayout
|
||||||
|
|
||||||
|
* cell top
|
||||||
|
* pin FB
|
||||||
|
* pin VDD
|
||||||
|
* pin OUT
|
||||||
|
* pin ENABLE
|
||||||
|
* pin VSS
|
||||||
|
.SUBCKT top 11 12 13 14 15
|
||||||
|
* net 11 FB
|
||||||
|
* net 12 VDD
|
||||||
|
* net 13 OUT
|
||||||
|
* net 14 ENABLE
|
||||||
|
* net 15 VSS
|
||||||
|
* cell instance $1 r0 *1 1.8,0
|
||||||
|
X$1 12 1 15 12 11 14 15 nd2X1
|
||||||
|
* cell instance $2 r0 *1 4.2,0
|
||||||
|
X$2 12 2 15 12 1 15 INV
|
||||||
|
* cell instance $3 r0 *1 6,0
|
||||||
|
X$3 12 3 15 12 2 15 INV
|
||||||
|
* cell instance $4 r0 *1 7.8,0
|
||||||
|
X$4 12 4 15 12 3 15 INV
|
||||||
|
* cell instance $5 r0 *1 9.6,0
|
||||||
|
X$5 12 5 15 12 4 15 INV
|
||||||
|
* cell instance $6 r0 *1 11.4,0
|
||||||
|
X$6 12 6 15 12 5 15 INV
|
||||||
|
* cell instance $7 r0 *1 13.2,0
|
||||||
|
X$7 12 7 15 12 6 15 INV
|
||||||
|
* cell instance $8 r0 *1 15,0
|
||||||
|
X$8 12 8 15 12 7 15 INV
|
||||||
|
* cell instance $9 r0 *1 16.8,0
|
||||||
|
X$9 12 9 15 12 8 15 INV
|
||||||
|
* cell instance $10 r0 *1 18.6,0
|
||||||
|
X$10 12 10 15 12 9 15 INV
|
||||||
|
* cell instance $11 r0 *1 20.4,0
|
||||||
|
X$11 12 11 15 12 10 15 INV
|
||||||
|
* cell instance $12 r0 *1 22.2,0
|
||||||
|
X$12 12 13 15 12 11 15 INV
|
||||||
|
.ENDS top
|
||||||
|
|
||||||
|
* cell INV
|
||||||
|
* pin VDD
|
||||||
|
* pin OUT
|
||||||
|
* pin VSS
|
||||||
|
* pin
|
||||||
|
* pin IN
|
||||||
|
* pin SUBSTRATE
|
||||||
|
.SUBCKT INV 1 2 3 4 5 6
|
||||||
|
* net 1 VDD
|
||||||
|
* net 2 OUT
|
||||||
|
* net 3 VSS
|
||||||
|
* net 5 IN
|
||||||
|
* net 6 SUBSTRATE
|
||||||
|
* device instance $1 r0 *1 0.85,5.8 PMOS
|
||||||
|
M$1 1 5 2 4 PMOS L=0.25U W=1.5U AS=0.6375P AD=0.6375P PS=3.85U PD=3.85U
|
||||||
|
* device instance $2 r0 *1 0.85,2.135 NMOS
|
||||||
|
M$2 3 5 2 6 NMOS L=0.25U W=0.95U AS=0.40375P AD=0.40375P PS=2.75U PD=2.75U
|
||||||
|
.ENDS INV
|
||||||
|
|
||||||
|
* cell nd2X1
|
||||||
|
* pin VDD
|
||||||
|
* pin OUT
|
||||||
|
* pin VSS
|
||||||
|
* pin
|
||||||
|
* pin B
|
||||||
|
* pin A
|
||||||
|
* pin SUBSTRATE
|
||||||
|
.SUBCKT nd2X1 1 2 3 4 5 6 7
|
||||||
|
* net 1 VDD
|
||||||
|
* net 2 OUT
|
||||||
|
* net 3 VSS
|
||||||
|
* net 5 B
|
||||||
|
* net 6 A
|
||||||
|
* net 7 SUBSTRATE
|
||||||
|
* device instance $1 r0 *1 0.85,5.8 PMOS
|
||||||
|
M$1 2 6 1 4 PMOS L=0.25U W=1.5U AS=0.6375P AD=0.3375P PS=3.85U PD=1.95U
|
||||||
|
* device instance $2 r0 *1 1.55,5.8 PMOS
|
||||||
|
M$2 1 5 2 4 PMOS L=0.25U W=1.5U AS=0.3375P AD=0.6375P PS=1.95U PD=3.85U
|
||||||
|
* device instance $3 r0 *1 0.85,2.135 NMOS
|
||||||
|
M$3 3 6 8 7 NMOS L=0.25U W=0.95U AS=0.40375P AD=0.21375P PS=2.75U PD=1.4U
|
||||||
|
* device instance $4 r0 *1 1.55,2.135 NMOS
|
||||||
|
M$4 8 5 2 7 NMOS L=0.25U W=0.95U AS=0.21375P AD=0.40375P PS=1.4U PD=2.75U
|
||||||
|
.ENDS nd2X1
|
||||||
|
|
@ -0,0 +1,78 @@
|
||||||
|
|
||||||
|
source($lvs_test_source, "top")
|
||||||
|
|
||||||
|
report_lvs($lvs_test_target_lvsdb)
|
||||||
|
|
||||||
|
target_netlist($lvs_test_target_cir, write_spice, "Extracted by KLayout")
|
||||||
|
|
||||||
|
schematic("ringo.cir")
|
||||||
|
|
||||||
|
deep
|
||||||
|
|
||||||
|
# Drawing layers
|
||||||
|
|
||||||
|
nwell = input(1, 0)
|
||||||
|
active = input(2, 0)
|
||||||
|
pplus = input(3, 0)
|
||||||
|
nplus = input(4, 0)
|
||||||
|
poly = input(5, 0)
|
||||||
|
contact = input(8, 0)
|
||||||
|
metal1 = input(9, 0)
|
||||||
|
via1 = input(10, 0)
|
||||||
|
metal2 = input(11, 0)
|
||||||
|
|
||||||
|
# Bulk layer for terminal provisioning
|
||||||
|
|
||||||
|
bulk = polygon_layer
|
||||||
|
|
||||||
|
# Computed layers
|
||||||
|
|
||||||
|
active_in_nwell = active & nwell
|
||||||
|
pactive = active_in_nwell & pplus
|
||||||
|
pgate = pactive & poly
|
||||||
|
psd = pactive - pgate
|
||||||
|
ntie = active_in_nwell & nplus
|
||||||
|
|
||||||
|
active_outside_nwell = active - nwell
|
||||||
|
nactive = active_outside_nwell & nplus
|
||||||
|
ngate = nactive & poly
|
||||||
|
nsd = nactive - ngate
|
||||||
|
ptie = active_outside_nwell & pplus
|
||||||
|
|
||||||
|
# Device extraction
|
||||||
|
|
||||||
|
# PMOS transistor device extraction
|
||||||
|
extract_devices(mos4("PMOS"), { "SD" => psd, "G" => pgate, "W" => nwell,
|
||||||
|
"tS" => psd, "tD" => psd, "tG" => poly, "tW" => nwell })
|
||||||
|
|
||||||
|
# NMOS transistor device extraction
|
||||||
|
extract_devices(mos4("NMOS"), { "SD" => nsd, "G" => ngate, "W" => bulk,
|
||||||
|
"tS" => nsd, "tD" => nsd, "tG" => poly, "tW" => bulk })
|
||||||
|
|
||||||
|
# Define connectivity for netlist extraction
|
||||||
|
|
||||||
|
# Inter-layer
|
||||||
|
connect(psd, contact)
|
||||||
|
connect(nsd, contact)
|
||||||
|
connect(poly, contact)
|
||||||
|
connect(ntie, contact)
|
||||||
|
connect(nwell, ntie)
|
||||||
|
connect(ptie, contact)
|
||||||
|
connect(contact, metal1)
|
||||||
|
connect(metal1, via1)
|
||||||
|
connect(via1, metal2)
|
||||||
|
|
||||||
|
# Global
|
||||||
|
connect_global(bulk, "SUBSTRATE")
|
||||||
|
connect_global(ptie, "SUBSTRATE")
|
||||||
|
|
||||||
|
# Compare section
|
||||||
|
|
||||||
|
same_circuits("top", "RINGO")
|
||||||
|
same_circuits("INV", "INVX1")
|
||||||
|
same_nets("top", "ENABLE", "RINGO", "ENABLE")
|
||||||
|
|
||||||
|
netlist.simplify
|
||||||
|
|
||||||
|
compare
|
||||||
|
|
||||||
|
|
@ -0,0 +1,961 @@
|
||||||
|
#%lvsdb-klayout
|
||||||
|
|
||||||
|
# Layout
|
||||||
|
layout(
|
||||||
|
top(top)
|
||||||
|
unit(0.001)
|
||||||
|
|
||||||
|
# Layer section
|
||||||
|
# This section lists the mask layers (drawing or derived) and their connections.
|
||||||
|
|
||||||
|
# Mask layers
|
||||||
|
layer(l3 '1/0')
|
||||||
|
layer(l4 '5/0')
|
||||||
|
layer(l8 '8/0')
|
||||||
|
layer(l11 '9/0')
|
||||||
|
layer(l12 '10/0')
|
||||||
|
layer(l13 '11/0')
|
||||||
|
layer(l7)
|
||||||
|
layer(l1)
|
||||||
|
layer(l9)
|
||||||
|
layer(l5)
|
||||||
|
layer(l10)
|
||||||
|
|
||||||
|
# Mask layer connectivity
|
||||||
|
connect(l3 l3 l9)
|
||||||
|
connect(l4 l4 l8)
|
||||||
|
connect(l8 l4 l8 l11 l1 l9 l5 l10)
|
||||||
|
connect(l11 l8 l11 l12)
|
||||||
|
connect(l12 l11 l12 l13)
|
||||||
|
connect(l13 l12 l13)
|
||||||
|
connect(l7 l7)
|
||||||
|
connect(l1 l8 l1)
|
||||||
|
connect(l9 l3 l8 l9)
|
||||||
|
connect(l5 l8 l5)
|
||||||
|
connect(l10 l8 l10)
|
||||||
|
|
||||||
|
# Global nets and connectivity
|
||||||
|
global(l7 SUBSTRATE)
|
||||||
|
global(l10 SUBSTRATE)
|
||||||
|
|
||||||
|
# Device class section
|
||||||
|
class(PMOS MOS4)
|
||||||
|
class(NMOS MOS4)
|
||||||
|
|
||||||
|
# Device abstracts section
|
||||||
|
# Device abstracts list the pin shapes of the devices.
|
||||||
|
device(D$PMOS PMOS
|
||||||
|
terminal(S
|
||||||
|
rect(l1 (-550 -750) (425 1500))
|
||||||
|
)
|
||||||
|
terminal(G
|
||||||
|
rect(l4 (-125 -750) (250 1500))
|
||||||
|
)
|
||||||
|
terminal(D
|
||||||
|
rect(l1 (125 -750) (450 1500))
|
||||||
|
)
|
||||||
|
terminal(B
|
||||||
|
rect(l3 (-125 -750) (250 1500))
|
||||||
|
)
|
||||||
|
)
|
||||||
|
device(D$PMOS$1 PMOS
|
||||||
|
terminal(S
|
||||||
|
rect(l1 (-575 -750) (450 1500))
|
||||||
|
)
|
||||||
|
terminal(G
|
||||||
|
rect(l4 (-125 -750) (250 1500))
|
||||||
|
)
|
||||||
|
terminal(D
|
||||||
|
rect(l1 (125 -750) (425 1500))
|
||||||
|
)
|
||||||
|
terminal(B
|
||||||
|
rect(l3 (-125 -750) (250 1500))
|
||||||
|
)
|
||||||
|
)
|
||||||
|
device(D$PMOS$2 PMOS
|
||||||
|
terminal(S
|
||||||
|
rect(l1 (-550 -750) (425 1500))
|
||||||
|
)
|
||||||
|
terminal(G
|
||||||
|
rect(l4 (-125 -750) (250 1500))
|
||||||
|
)
|
||||||
|
terminal(D
|
||||||
|
rect(l1 (125 -750) (425 1500))
|
||||||
|
)
|
||||||
|
terminal(B
|
||||||
|
rect(l3 (-125 -750) (250 1500))
|
||||||
|
)
|
||||||
|
)
|
||||||
|
device(D$NMOS NMOS
|
||||||
|
terminal(S
|
||||||
|
rect(l5 (-550 -475) (425 950))
|
||||||
|
)
|
||||||
|
terminal(G
|
||||||
|
rect(l4 (-125 -475) (250 950))
|
||||||
|
)
|
||||||
|
terminal(D
|
||||||
|
rect(l5 (125 -475) (450 950))
|
||||||
|
)
|
||||||
|
terminal(B
|
||||||
|
rect(l7 (-125 -475) (250 950))
|
||||||
|
)
|
||||||
|
)
|
||||||
|
device(D$NMOS$1 NMOS
|
||||||
|
terminal(S
|
||||||
|
rect(l5 (-575 -475) (450 950))
|
||||||
|
)
|
||||||
|
terminal(G
|
||||||
|
rect(l4 (-125 -475) (250 950))
|
||||||
|
)
|
||||||
|
terminal(D
|
||||||
|
rect(l5 (125 -475) (425 950))
|
||||||
|
)
|
||||||
|
terminal(B
|
||||||
|
rect(l7 (-125 -475) (250 950))
|
||||||
|
)
|
||||||
|
)
|
||||||
|
device(D$NMOS$2 NMOS
|
||||||
|
terminal(S
|
||||||
|
rect(l5 (-550 -475) (425 950))
|
||||||
|
)
|
||||||
|
terminal(G
|
||||||
|
rect(l4 (-125 -475) (250 950))
|
||||||
|
)
|
||||||
|
terminal(D
|
||||||
|
rect(l5 (125 -475) (425 950))
|
||||||
|
)
|
||||||
|
terminal(B
|
||||||
|
rect(l7 (-125 -475) (250 950))
|
||||||
|
)
|
||||||
|
)
|
||||||
|
|
||||||
|
# Circuit section
|
||||||
|
# Circuits are the hierarchical building blocks of the netlist.
|
||||||
|
circuit(nd2X1
|
||||||
|
|
||||||
|
# Nets with their geometries
|
||||||
|
net(1 name(VDD)
|
||||||
|
rect(l8 (1110 5160) (180 180))
|
||||||
|
rect(l8 (-180 920) (180 180))
|
||||||
|
rect(l8 (-180 -730) (180 180))
|
||||||
|
rect(l11 (-240 -790) (300 1700))
|
||||||
|
rect(l11 (-1350 0) (2400 800))
|
||||||
|
rect(l11 (-1151 -401) (2 2))
|
||||||
|
rect(l1 (-276 -2151) (425 1500))
|
||||||
|
rect(l1 (-400 -1500) (425 1500))
|
||||||
|
)
|
||||||
|
net(2 name(OUT)
|
||||||
|
rect(l8 (1810 1770) (180 180))
|
||||||
|
rect(l8 (-180 370) (180 180))
|
||||||
|
rect(l8 (-1580 3760) (180 180))
|
||||||
|
rect(l8 (-180 -730) (180 180))
|
||||||
|
rect(l8 (-180 -730) (180 180))
|
||||||
|
rect(l8 (1220 920) (180 180))
|
||||||
|
rect(l8 (-180 -1280) (180 180))
|
||||||
|
rect(l8 (-180 370) (180 180))
|
||||||
|
polygon(l11 (-240 -4180) (0 1390) (490 0) (0 -300) (-190 0) (0 -1090))
|
||||||
|
rect(l11 (-110 1390) (300 1400))
|
||||||
|
polygon(l11 (-1890 0) (0 600) (300 0) (0 -300) (1590 0) (0 -300))
|
||||||
|
rect(l11 (-141 -501) (2 2))
|
||||||
|
rect(l11 (-1751 1099) (300 1400))
|
||||||
|
rect(l11 (1100 -1700) (300 300))
|
||||||
|
rect(l11 (-300 0) (300 1400))
|
||||||
|
rect(l1 (-1750 -1450) (425 1500))
|
||||||
|
rect(l1 (950 -1500) (425 1500))
|
||||||
|
rect(l5 (-425 -4890) (425 950))
|
||||||
|
)
|
||||||
|
net(3 name(VSS)
|
||||||
|
rect(l8 (410 1770) (180 180))
|
||||||
|
rect(l8 (-180 370) (180 180))
|
||||||
|
rect(l11 (-240 -1300) (300 1360))
|
||||||
|
rect(l11 (-650 -2160) (2400 800))
|
||||||
|
rect(l11 (-1151 -401) (2 2))
|
||||||
|
rect(l5 (-951 859) (425 950))
|
||||||
|
)
|
||||||
|
net(4
|
||||||
|
rect(l3 (-100 4500) (2600 3500))
|
||||||
|
)
|
||||||
|
net(5 name(B)
|
||||||
|
rect(l4 (1425 2860) (250 1940))
|
||||||
|
rect(l4 (-345 -950) (300 300))
|
||||||
|
rect(l4 (-205 650) (250 2000))
|
||||||
|
rect(l4 (-250 -2000) (250 2000))
|
||||||
|
rect(l4 (-250 -5390) (250 1450))
|
||||||
|
rect(l8 (-285 1050) (180 180))
|
||||||
|
rect(l11 (-71 -91) (2 2))
|
||||||
|
rect(l11 (-171 -151) (300 300))
|
||||||
|
)
|
||||||
|
net(6 name(A)
|
||||||
|
rect(l4 (725 2860) (250 1940))
|
||||||
|
rect(l4 (-325 -1850) (300 300))
|
||||||
|
rect(l4 (-225 1550) (250 2000))
|
||||||
|
rect(l4 (-250 -2000) (250 2000))
|
||||||
|
rect(l4 (-250 -5390) (250 1450))
|
||||||
|
rect(l8 (-265 150) (180 180))
|
||||||
|
rect(l11 (-91 -91) (2 2))
|
||||||
|
rect(l11 (-151 -151) (300 300))
|
||||||
|
)
|
||||||
|
net(7 name(SUBSTRATE))
|
||||||
|
net(8
|
||||||
|
rect(l5 (975 1660) (425 950))
|
||||||
|
rect(l5 (-400 -950) (425 950))
|
||||||
|
)
|
||||||
|
|
||||||
|
# Outgoing pins and their connections to nets
|
||||||
|
pin(1 name(VDD))
|
||||||
|
pin(2 name(OUT))
|
||||||
|
pin(3 name(VSS))
|
||||||
|
pin(4)
|
||||||
|
pin(5 name(B))
|
||||||
|
pin(6 name(A))
|
||||||
|
pin(7 name(SUBSTRATE))
|
||||||
|
|
||||||
|
# Devices and their connections
|
||||||
|
device(1 D$PMOS
|
||||||
|
location(850 5800)
|
||||||
|
param(L 0.25)
|
||||||
|
param(W 1.5)
|
||||||
|
param(AS 0.6375)
|
||||||
|
param(AD 0.3375)
|
||||||
|
param(PS 3.85)
|
||||||
|
param(PD 1.95)
|
||||||
|
terminal(S 2)
|
||||||
|
terminal(G 6)
|
||||||
|
terminal(D 1)
|
||||||
|
terminal(B 4)
|
||||||
|
)
|
||||||
|
device(2 D$PMOS$1
|
||||||
|
location(1550 5800)
|
||||||
|
param(L 0.25)
|
||||||
|
param(W 1.5)
|
||||||
|
param(AS 0.3375)
|
||||||
|
param(AD 0.6375)
|
||||||
|
param(PS 1.95)
|
||||||
|
param(PD 3.85)
|
||||||
|
terminal(S 1)
|
||||||
|
terminal(G 5)
|
||||||
|
terminal(D 2)
|
||||||
|
terminal(B 4)
|
||||||
|
)
|
||||||
|
device(3 D$NMOS
|
||||||
|
location(850 2135)
|
||||||
|
param(L 0.25)
|
||||||
|
param(W 0.95)
|
||||||
|
param(AS 0.40375)
|
||||||
|
param(AD 0.21375)
|
||||||
|
param(PS 2.75)
|
||||||
|
param(PD 1.4)
|
||||||
|
terminal(S 3)
|
||||||
|
terminal(G 6)
|
||||||
|
terminal(D 8)
|
||||||
|
terminal(B 7)
|
||||||
|
)
|
||||||
|
device(4 D$NMOS$1
|
||||||
|
location(1550 2135)
|
||||||
|
param(L 0.25)
|
||||||
|
param(W 0.95)
|
||||||
|
param(AS 0.21375)
|
||||||
|
param(AD 0.40375)
|
||||||
|
param(PS 1.4)
|
||||||
|
param(PD 2.75)
|
||||||
|
terminal(S 8)
|
||||||
|
terminal(G 5)
|
||||||
|
terminal(D 2)
|
||||||
|
terminal(B 7)
|
||||||
|
)
|
||||||
|
|
||||||
|
)
|
||||||
|
circuit(INV
|
||||||
|
|
||||||
|
# Nets with their geometries
|
||||||
|
net(1 name(VDD)
|
||||||
|
rect(l8 (410 6260) (180 180))
|
||||||
|
rect(l8 (-180 -730) (180 180))
|
||||||
|
rect(l8 (-180 -730) (180 180))
|
||||||
|
rect(l11 (-240 -240) (300 1400))
|
||||||
|
rect(l11 (-650 300) (1800 800))
|
||||||
|
rect(l11 (-1450 -1100) (300 300))
|
||||||
|
rect(l11 (299 399) (2 2))
|
||||||
|
rect(l1 (-651 -2151) (425 1500))
|
||||||
|
)
|
||||||
|
net(2 name(OUT)
|
||||||
|
rect(l8 (1110 5160) (180 180))
|
||||||
|
rect(l8 (-180 920) (180 180))
|
||||||
|
rect(l8 (-180 -730) (180 180))
|
||||||
|
rect(l8 (-180 -4120) (180 180))
|
||||||
|
rect(l8 (-180 370) (180 180))
|
||||||
|
rect(l11 (-240 -790) (300 4790))
|
||||||
|
rect(l11 (-151 -2501) (2 2))
|
||||||
|
rect(l1 (-226 1049) (425 1500))
|
||||||
|
rect(l5 (-425 -4890) (425 950))
|
||||||
|
)
|
||||||
|
net(3 name(VSS)
|
||||||
|
rect(l8 (410 1770) (180 180))
|
||||||
|
rect(l8 (-180 370) (180 180))
|
||||||
|
rect(l11 (-240 -1300) (300 1360))
|
||||||
|
rect(l11 (-650 -2160) (1800 800))
|
||||||
|
rect(l11 (-851 -401) (2 2))
|
||||||
|
rect(l5 (-651 859) (425 950))
|
||||||
|
)
|
||||||
|
net(4
|
||||||
|
rect(l3 (-100 4500) (2000 3500))
|
||||||
|
)
|
||||||
|
net(5 name(IN)
|
||||||
|
rect(l4 (725 2860) (250 1940))
|
||||||
|
rect(l4 (-525 -1850) (300 300))
|
||||||
|
rect(l4 (-25 1550) (250 2000))
|
||||||
|
rect(l4 (-250 -2000) (250 2000))
|
||||||
|
rect(l4 (-250 -5390) (250 1450))
|
||||||
|
rect(l8 (-465 150) (180 180))
|
||||||
|
rect(l11 (-91 -91) (2 2))
|
||||||
|
rect(l11 (-151 -151) (300 300))
|
||||||
|
)
|
||||||
|
net(6 name(SUBSTRATE))
|
||||||
|
|
||||||
|
# Outgoing pins and their connections to nets
|
||||||
|
pin(1 name(VDD))
|
||||||
|
pin(2 name(OUT))
|
||||||
|
pin(3 name(VSS))
|
||||||
|
pin(4)
|
||||||
|
pin(5 name(IN))
|
||||||
|
pin(6 name(SUBSTRATE))
|
||||||
|
|
||||||
|
# Devices and their connections
|
||||||
|
device(1 D$PMOS$2
|
||||||
|
location(850 5800)
|
||||||
|
param(L 0.25)
|
||||||
|
param(W 1.5)
|
||||||
|
param(AS 0.6375)
|
||||||
|
param(AD 0.6375)
|
||||||
|
param(PS 3.85)
|
||||||
|
param(PD 3.85)
|
||||||
|
terminal(S 1)
|
||||||
|
terminal(G 5)
|
||||||
|
terminal(D 2)
|
||||||
|
terminal(B 4)
|
||||||
|
)
|
||||||
|
device(2 D$NMOS$2
|
||||||
|
location(850 2135)
|
||||||
|
param(L 0.25)
|
||||||
|
param(W 0.95)
|
||||||
|
param(AS 0.40375)
|
||||||
|
param(AD 0.40375)
|
||||||
|
param(PS 2.75)
|
||||||
|
param(PD 2.75)
|
||||||
|
terminal(S 3)
|
||||||
|
terminal(G 5)
|
||||||
|
terminal(D 2)
|
||||||
|
terminal(B 6)
|
||||||
|
)
|
||||||
|
|
||||||
|
)
|
||||||
|
circuit(top
|
||||||
|
|
||||||
|
# Nets with their geometries
|
||||||
|
net(1
|
||||||
|
rect(l8 (4710 3010) (180 180))
|
||||||
|
rect(l11 (-850 -240) (610 300))
|
||||||
|
rect(l1 (-2550 1800) (425 1500))
|
||||||
|
rect(l1 (950 -1500) (425 1500))
|
||||||
|
rect(l5 (-425 -4890) (425 950))
|
||||||
|
)
|
||||||
|
net(2
|
||||||
|
rect(l8 (6510 3010) (180 180))
|
||||||
|
rect(l11 (-1140 -240) (900 300))
|
||||||
|
rect(l1 (-1275 1800) (425 1500))
|
||||||
|
rect(l5 (-425 -4890) (425 950))
|
||||||
|
)
|
||||||
|
net(3
|
||||||
|
rect(l8 (8310 3010) (180 180))
|
||||||
|
rect(l11 (-1140 -240) (900 300))
|
||||||
|
rect(l1 (-1275 1800) (425 1500))
|
||||||
|
rect(l5 (-425 -4890) (425 950))
|
||||||
|
)
|
||||||
|
net(4
|
||||||
|
rect(l8 (10110 3010) (180 180))
|
||||||
|
rect(l11 (-1140 -240) (900 300))
|
||||||
|
rect(l1 (-1275 1800) (425 1500))
|
||||||
|
rect(l5 (-425 -4890) (425 950))
|
||||||
|
)
|
||||||
|
net(5
|
||||||
|
rect(l8 (11910 3010) (180 180))
|
||||||
|
rect(l11 (-1140 -240) (900 300))
|
||||||
|
rect(l1 (-1275 1800) (425 1500))
|
||||||
|
rect(l5 (-425 -4890) (425 950))
|
||||||
|
)
|
||||||
|
net(6
|
||||||
|
rect(l8 (13710 3010) (180 180))
|
||||||
|
rect(l11 (-1140 -240) (900 300))
|
||||||
|
rect(l1 (-1275 1800) (425 1500))
|
||||||
|
rect(l5 (-425 -4890) (425 950))
|
||||||
|
)
|
||||||
|
net(7
|
||||||
|
rect(l8 (15510 3010) (180 180))
|
||||||
|
rect(l11 (-1140 -240) (900 300))
|
||||||
|
rect(l1 (-1275 1800) (425 1500))
|
||||||
|
rect(l5 (-425 -4890) (425 950))
|
||||||
|
)
|
||||||
|
net(8
|
||||||
|
rect(l8 (17310 3010) (180 180))
|
||||||
|
rect(l11 (-1140 -240) (900 300))
|
||||||
|
rect(l1 (-1275 1800) (425 1500))
|
||||||
|
rect(l5 (-425 -4890) (425 950))
|
||||||
|
)
|
||||||
|
net(9
|
||||||
|
rect(l8 (19110 3010) (180 180))
|
||||||
|
rect(l11 (-1140 -240) (900 300))
|
||||||
|
rect(l1 (-1275 1800) (425 1500))
|
||||||
|
rect(l5 (-425 -4890) (425 950))
|
||||||
|
)
|
||||||
|
net(10
|
||||||
|
rect(l8 (20910 3010) (180 180))
|
||||||
|
rect(l11 (-1140 -240) (900 300))
|
||||||
|
rect(l1 (-1275 1800) (425 1500))
|
||||||
|
rect(l5 (-425 -4890) (425 950))
|
||||||
|
)
|
||||||
|
net(11 name(FB)
|
||||||
|
rect(l8 (22710 3010) (180 180))
|
||||||
|
rect(l8 (-19700 720) (180 180))
|
||||||
|
rect(l11 (18380 -1140) (900 300))
|
||||||
|
rect(l11 (-19530 590) (320 320))
|
||||||
|
rect(l11 (17820 -320) (320 320))
|
||||||
|
rect(l12 (-18400 -260) (200 200))
|
||||||
|
rect(l12 (17940 -200) (200 200))
|
||||||
|
rect(l13 (-18040 -300) (17740 400))
|
||||||
|
rect(l13 (-17921 -201) (2 2))
|
||||||
|
rect(l13 (-221 -201) (400 400))
|
||||||
|
rect(l13 (17740 -400) (400 400))
|
||||||
|
rect(l1 (-245 850) (425 1500))
|
||||||
|
rect(l5 (-425 -4890) (425 950))
|
||||||
|
)
|
||||||
|
net(12 name(VDD)
|
||||||
|
rect(l3 (500 4500) (1400 3500))
|
||||||
|
rect(l3 (-1900 -3500) (600 3500))
|
||||||
|
rect(l3 (23300 -3500) (1400 3500))
|
||||||
|
rect(l3 (-100 -3500) (600 3500))
|
||||||
|
rect(l8 (-24690 -1240) (180 180))
|
||||||
|
rect(l8 (-180 370) (180 180))
|
||||||
|
rect(l8 (-180 -1280) (180 180))
|
||||||
|
rect(l8 (23220 370) (180 180))
|
||||||
|
rect(l8 (-180 370) (180 180))
|
||||||
|
rect(l8 (-180 -1280) (180 180))
|
||||||
|
rect(l11 (-21741 859) (2 2))
|
||||||
|
rect(l11 (-2351 -451) (1200 800))
|
||||||
|
rect(l11 (-750 -1450) (300 1400))
|
||||||
|
rect(l11 (-101 -351) (2 2))
|
||||||
|
rect(l11 (-1251 -401) (600 800))
|
||||||
|
rect(l11 (23400 -800) (1200 800))
|
||||||
|
rect(l11 (-750 -1450) (300 1400))
|
||||||
|
rect(l11 (-101 -351) (2 2))
|
||||||
|
rect(l11 (549 -401) (600 800))
|
||||||
|
rect(l1 (-23025 -2550) (425 1500))
|
||||||
|
rect(l1 (-400 -1500) (425 1500))
|
||||||
|
rect(l1 (1275 -1500) (425 1500))
|
||||||
|
rect(l1 (1375 -1500) (425 1500))
|
||||||
|
rect(l1 (1375 -1500) (425 1500))
|
||||||
|
rect(l1 (1375 -1500) (425 1500))
|
||||||
|
rect(l1 (1375 -1500) (425 1500))
|
||||||
|
rect(l1 (1375 -1500) (425 1500))
|
||||||
|
rect(l1 (1375 -1500) (425 1500))
|
||||||
|
rect(l1 (1375 -1500) (425 1500))
|
||||||
|
rect(l1 (1375 -1500) (425 1500))
|
||||||
|
rect(l1 (1375 -1500) (425 1500))
|
||||||
|
rect(l1 (1375 -1500) (425 1500))
|
||||||
|
rect(l9 (-21975 -450) (500 1500))
|
||||||
|
rect(l9 (22900 -1500) (500 1500))
|
||||||
|
)
|
||||||
|
net(13 name(OUT)
|
||||||
|
rect(l11 (23440 3840) (320 320))
|
||||||
|
rect(l12 (-260 -260) (200 200))
|
||||||
|
rect(l13 (-101 -101) (2 2))
|
||||||
|
rect(l13 (-201 -201) (400 400))
|
||||||
|
rect(l1 (-625 850) (425 1500))
|
||||||
|
rect(l5 (-425 -4890) (425 950))
|
||||||
|
)
|
||||||
|
net(14 name(ENABLE)
|
||||||
|
rect(l8 (2510 3010) (180 180))
|
||||||
|
rect(l11 (-250 -250) (320 320))
|
||||||
|
rect(l12 (-260 -260) (200 200))
|
||||||
|
rect(l13 (-101 -101) (2 2))
|
||||||
|
rect(l13 (-201 -201) (400 400))
|
||||||
|
)
|
||||||
|
net(15 name(VSS)
|
||||||
|
rect(l8 (1110 1610) (180 180))
|
||||||
|
rect(l8 (-180 -1280) (180 180))
|
||||||
|
rect(l8 (-180 370) (180 180))
|
||||||
|
rect(l8 (23220 370) (180 180))
|
||||||
|
rect(l8 (-180 -1280) (180 180))
|
||||||
|
rect(l8 (-180 370) (180 180))
|
||||||
|
rect(l11 (-21741 -391) (2 2))
|
||||||
|
rect(l11 (-1901 -401) (300 1400))
|
||||||
|
rect(l11 (-750 -1450) (1200 800))
|
||||||
|
rect(l11 (-551 -401) (2 2))
|
||||||
|
rect(l11 (-1251 -401) (600 800))
|
||||||
|
rect(l11 (23850 -750) (300 1400))
|
||||||
|
rect(l11 (-750 -1450) (1200 800))
|
||||||
|
rect(l11 (-551 -401) (2 2))
|
||||||
|
rect(l11 (549 -401) (600 800))
|
||||||
|
rect(l5 (-23700 460) (425 950))
|
||||||
|
rect(l5 (1975 -950) (425 950))
|
||||||
|
rect(l5 (1375 -950) (425 950))
|
||||||
|
rect(l5 (1375 -950) (425 950))
|
||||||
|
rect(l5 (1375 -950) (425 950))
|
||||||
|
rect(l5 (1375 -950) (425 950))
|
||||||
|
rect(l5 (1375 -950) (425 950))
|
||||||
|
rect(l5 (1375 -950) (425 950))
|
||||||
|
rect(l5 (1375 -950) (425 950))
|
||||||
|
rect(l5 (1375 -950) (425 950))
|
||||||
|
rect(l5 (1375 -950) (425 950))
|
||||||
|
rect(l5 (1375 -950) (425 950))
|
||||||
|
rect(l10 (-21975 -2210) (500 1500))
|
||||||
|
rect(l10 (22900 -1500) (500 1500))
|
||||||
|
)
|
||||||
|
|
||||||
|
# Outgoing pins and their connections to nets
|
||||||
|
pin(11 name(FB))
|
||||||
|
pin(12 name(VDD))
|
||||||
|
pin(13 name(OUT))
|
||||||
|
pin(14 name(ENABLE))
|
||||||
|
pin(15 name(VSS))
|
||||||
|
|
||||||
|
# Subcircuits and their connections
|
||||||
|
circuit(1 nd2X1 location(1800 0)
|
||||||
|
pin(0 12)
|
||||||
|
pin(1 1)
|
||||||
|
pin(2 15)
|
||||||
|
pin(3 12)
|
||||||
|
pin(4 11)
|
||||||
|
pin(5 14)
|
||||||
|
pin(6 15)
|
||||||
|
)
|
||||||
|
circuit(2 INV location(4200 0)
|
||||||
|
pin(0 12)
|
||||||
|
pin(1 2)
|
||||||
|
pin(2 15)
|
||||||
|
pin(3 12)
|
||||||
|
pin(4 1)
|
||||||
|
pin(5 15)
|
||||||
|
)
|
||||||
|
circuit(3 INV location(6000 0)
|
||||||
|
pin(0 12)
|
||||||
|
pin(1 3)
|
||||||
|
pin(2 15)
|
||||||
|
pin(3 12)
|
||||||
|
pin(4 2)
|
||||||
|
pin(5 15)
|
||||||
|
)
|
||||||
|
circuit(4 INV location(7800 0)
|
||||||
|
pin(0 12)
|
||||||
|
pin(1 4)
|
||||||
|
pin(2 15)
|
||||||
|
pin(3 12)
|
||||||
|
pin(4 3)
|
||||||
|
pin(5 15)
|
||||||
|
)
|
||||||
|
circuit(5 INV location(9600 0)
|
||||||
|
pin(0 12)
|
||||||
|
pin(1 5)
|
||||||
|
pin(2 15)
|
||||||
|
pin(3 12)
|
||||||
|
pin(4 4)
|
||||||
|
pin(5 15)
|
||||||
|
)
|
||||||
|
circuit(6 INV location(11400 0)
|
||||||
|
pin(0 12)
|
||||||
|
pin(1 6)
|
||||||
|
pin(2 15)
|
||||||
|
pin(3 12)
|
||||||
|
pin(4 5)
|
||||||
|
pin(5 15)
|
||||||
|
)
|
||||||
|
circuit(7 INV location(13200 0)
|
||||||
|
pin(0 12)
|
||||||
|
pin(1 7)
|
||||||
|
pin(2 15)
|
||||||
|
pin(3 12)
|
||||||
|
pin(4 6)
|
||||||
|
pin(5 15)
|
||||||
|
)
|
||||||
|
circuit(8 INV location(15000 0)
|
||||||
|
pin(0 12)
|
||||||
|
pin(1 8)
|
||||||
|
pin(2 15)
|
||||||
|
pin(3 12)
|
||||||
|
pin(4 7)
|
||||||
|
pin(5 15)
|
||||||
|
)
|
||||||
|
circuit(9 INV location(16800 0)
|
||||||
|
pin(0 12)
|
||||||
|
pin(1 9)
|
||||||
|
pin(2 15)
|
||||||
|
pin(3 12)
|
||||||
|
pin(4 8)
|
||||||
|
pin(5 15)
|
||||||
|
)
|
||||||
|
circuit(10 INV location(18600 0)
|
||||||
|
pin(0 12)
|
||||||
|
pin(1 10)
|
||||||
|
pin(2 15)
|
||||||
|
pin(3 12)
|
||||||
|
pin(4 9)
|
||||||
|
pin(5 15)
|
||||||
|
)
|
||||||
|
circuit(11 INV location(20400 0)
|
||||||
|
pin(0 12)
|
||||||
|
pin(1 11)
|
||||||
|
pin(2 15)
|
||||||
|
pin(3 12)
|
||||||
|
pin(4 10)
|
||||||
|
pin(5 15)
|
||||||
|
)
|
||||||
|
circuit(12 INV location(22200 0)
|
||||||
|
pin(0 12)
|
||||||
|
pin(1 13)
|
||||||
|
pin(2 15)
|
||||||
|
pin(3 12)
|
||||||
|
pin(4 11)
|
||||||
|
pin(5 15)
|
||||||
|
)
|
||||||
|
|
||||||
|
)
|
||||||
|
)
|
||||||
|
|
||||||
|
# Reference netlist
|
||||||
|
reference(
|
||||||
|
|
||||||
|
# Device class section
|
||||||
|
class(PMOS MOS4)
|
||||||
|
class(NMOS MOS4)
|
||||||
|
|
||||||
|
# Circuit section
|
||||||
|
# Circuits are the hierarchical building blocks of the netlist.
|
||||||
|
circuit(ND2X1
|
||||||
|
|
||||||
|
# Nets
|
||||||
|
net(1 name(VDD))
|
||||||
|
net(2 name(OUT))
|
||||||
|
net(3 name(VSS))
|
||||||
|
net(4 name(NWELL))
|
||||||
|
net(5 name(B))
|
||||||
|
net(6 name(A))
|
||||||
|
net(7 name(BULK))
|
||||||
|
net(8 name('1'))
|
||||||
|
|
||||||
|
# Outgoing pins and their connections to nets
|
||||||
|
pin(1)
|
||||||
|
pin(2)
|
||||||
|
pin(3)
|
||||||
|
pin(4)
|
||||||
|
pin(5)
|
||||||
|
pin(6)
|
||||||
|
pin(7)
|
||||||
|
|
||||||
|
# Devices and their connections
|
||||||
|
device(1 PMOS
|
||||||
|
name($1)
|
||||||
|
param(L 0.25)
|
||||||
|
param(W 1.5)
|
||||||
|
param(AS 0)
|
||||||
|
param(AD 0)
|
||||||
|
param(PS 0)
|
||||||
|
param(PD 0)
|
||||||
|
terminal(S 2)
|
||||||
|
terminal(G 6)
|
||||||
|
terminal(D 1)
|
||||||
|
terminal(B 4)
|
||||||
|
)
|
||||||
|
device(2 PMOS
|
||||||
|
name($2)
|
||||||
|
param(L 0.25)
|
||||||
|
param(W 1.5)
|
||||||
|
param(AS 0)
|
||||||
|
param(AD 0)
|
||||||
|
param(PS 0)
|
||||||
|
param(PD 0)
|
||||||
|
terminal(S 1)
|
||||||
|
terminal(G 5)
|
||||||
|
terminal(D 2)
|
||||||
|
terminal(B 4)
|
||||||
|
)
|
||||||
|
device(3 NMOS
|
||||||
|
name($3)
|
||||||
|
param(L 0.25)
|
||||||
|
param(W 0.95)
|
||||||
|
param(AS 0)
|
||||||
|
param(AD 0)
|
||||||
|
param(PS 0)
|
||||||
|
param(PD 0)
|
||||||
|
terminal(S 3)
|
||||||
|
terminal(G 6)
|
||||||
|
terminal(D 8)
|
||||||
|
terminal(B 7)
|
||||||
|
)
|
||||||
|
device(4 NMOS
|
||||||
|
name($4)
|
||||||
|
param(L 0.25)
|
||||||
|
param(W 0.95)
|
||||||
|
param(AS 0)
|
||||||
|
param(AD 0)
|
||||||
|
param(PS 0)
|
||||||
|
param(PD 0)
|
||||||
|
terminal(S 8)
|
||||||
|
terminal(G 5)
|
||||||
|
terminal(D 2)
|
||||||
|
terminal(B 7)
|
||||||
|
)
|
||||||
|
|
||||||
|
)
|
||||||
|
circuit(INVX1
|
||||||
|
|
||||||
|
# Nets
|
||||||
|
net(1 name(VDD))
|
||||||
|
net(2 name(OUT))
|
||||||
|
net(3 name(VSS))
|
||||||
|
net(4 name(NWELL))
|
||||||
|
net(5 name(IN))
|
||||||
|
net(6 name(BULK))
|
||||||
|
|
||||||
|
# Outgoing pins and their connections to nets
|
||||||
|
pin(1)
|
||||||
|
pin(2)
|
||||||
|
pin(3)
|
||||||
|
pin(4)
|
||||||
|
pin(5)
|
||||||
|
pin(6)
|
||||||
|
|
||||||
|
# Devices and their connections
|
||||||
|
device(1 PMOS
|
||||||
|
name($1)
|
||||||
|
param(L 0.25)
|
||||||
|
param(W 1.5)
|
||||||
|
param(AS 0)
|
||||||
|
param(AD 0)
|
||||||
|
param(PS 0)
|
||||||
|
param(PD 0)
|
||||||
|
terminal(S 1)
|
||||||
|
terminal(G 5)
|
||||||
|
terminal(D 2)
|
||||||
|
terminal(B 4)
|
||||||
|
)
|
||||||
|
device(2 NMOS
|
||||||
|
name($2)
|
||||||
|
param(L 0.25)
|
||||||
|
param(W 0.95)
|
||||||
|
param(AS 0)
|
||||||
|
param(AD 0)
|
||||||
|
param(PS 0)
|
||||||
|
param(PD 0)
|
||||||
|
terminal(S 3)
|
||||||
|
terminal(G 5)
|
||||||
|
terminal(D 2)
|
||||||
|
terminal(B 6)
|
||||||
|
)
|
||||||
|
|
||||||
|
)
|
||||||
|
circuit(RINGO
|
||||||
|
|
||||||
|
# Nets
|
||||||
|
net(1 name(VSS))
|
||||||
|
net(2 name(VDD))
|
||||||
|
net(3 name(FB))
|
||||||
|
net(4 name(ENABLE))
|
||||||
|
net(5 name(OUT))
|
||||||
|
net(6 name('1'))
|
||||||
|
net(7 name('2'))
|
||||||
|
net(8 name('3'))
|
||||||
|
net(9 name('4'))
|
||||||
|
net(10 name('5'))
|
||||||
|
net(11 name('6'))
|
||||||
|
net(12 name('7'))
|
||||||
|
net(13 name('8'))
|
||||||
|
net(14 name('9'))
|
||||||
|
net(15 name('10'))
|
||||||
|
|
||||||
|
# Outgoing pins and their connections to nets
|
||||||
|
pin(1)
|
||||||
|
pin(2)
|
||||||
|
pin(3)
|
||||||
|
pin(4)
|
||||||
|
pin(5)
|
||||||
|
|
||||||
|
# Subcircuits and their connections
|
||||||
|
circuit(1 ND2X1 name($1)
|
||||||
|
pin(0 2)
|
||||||
|
pin(1 6)
|
||||||
|
pin(2 1)
|
||||||
|
pin(3 2)
|
||||||
|
pin(4 3)
|
||||||
|
pin(5 4)
|
||||||
|
pin(6 1)
|
||||||
|
)
|
||||||
|
circuit(2 INVX1 name($2)
|
||||||
|
pin(0 2)
|
||||||
|
pin(1 7)
|
||||||
|
pin(2 1)
|
||||||
|
pin(3 2)
|
||||||
|
pin(4 6)
|
||||||
|
pin(5 1)
|
||||||
|
)
|
||||||
|
circuit(3 INVX1 name($3)
|
||||||
|
pin(0 2)
|
||||||
|
pin(1 8)
|
||||||
|
pin(2 1)
|
||||||
|
pin(3 2)
|
||||||
|
pin(4 7)
|
||||||
|
pin(5 1)
|
||||||
|
)
|
||||||
|
circuit(4 INVX1 name($4)
|
||||||
|
pin(0 2)
|
||||||
|
pin(1 9)
|
||||||
|
pin(2 1)
|
||||||
|
pin(3 2)
|
||||||
|
pin(4 8)
|
||||||
|
pin(5 1)
|
||||||
|
)
|
||||||
|
circuit(5 INVX1 name($5)
|
||||||
|
pin(0 2)
|
||||||
|
pin(1 10)
|
||||||
|
pin(2 1)
|
||||||
|
pin(3 2)
|
||||||
|
pin(4 9)
|
||||||
|
pin(5 1)
|
||||||
|
)
|
||||||
|
circuit(6 INVX1 name($6)
|
||||||
|
pin(0 2)
|
||||||
|
pin(1 11)
|
||||||
|
pin(2 1)
|
||||||
|
pin(3 2)
|
||||||
|
pin(4 10)
|
||||||
|
pin(5 1)
|
||||||
|
)
|
||||||
|
circuit(7 INVX1 name($7)
|
||||||
|
pin(0 2)
|
||||||
|
pin(1 12)
|
||||||
|
pin(2 1)
|
||||||
|
pin(3 2)
|
||||||
|
pin(4 11)
|
||||||
|
pin(5 1)
|
||||||
|
)
|
||||||
|
circuit(8 INVX1 name($8)
|
||||||
|
pin(0 2)
|
||||||
|
pin(1 13)
|
||||||
|
pin(2 1)
|
||||||
|
pin(3 2)
|
||||||
|
pin(4 12)
|
||||||
|
pin(5 1)
|
||||||
|
)
|
||||||
|
circuit(9 INVX1 name($9)
|
||||||
|
pin(0 2)
|
||||||
|
pin(1 14)
|
||||||
|
pin(2 1)
|
||||||
|
pin(3 2)
|
||||||
|
pin(4 13)
|
||||||
|
pin(5 1)
|
||||||
|
)
|
||||||
|
circuit(10 INVX1 name($10)
|
||||||
|
pin(0 2)
|
||||||
|
pin(1 15)
|
||||||
|
pin(2 1)
|
||||||
|
pin(3 2)
|
||||||
|
pin(4 14)
|
||||||
|
pin(5 1)
|
||||||
|
)
|
||||||
|
circuit(11 INVX1 name($11)
|
||||||
|
pin(0 2)
|
||||||
|
pin(1 3)
|
||||||
|
pin(2 1)
|
||||||
|
pin(3 2)
|
||||||
|
pin(4 15)
|
||||||
|
pin(5 1)
|
||||||
|
)
|
||||||
|
circuit(12 INVX1 name($12)
|
||||||
|
pin(0 2)
|
||||||
|
pin(1 5)
|
||||||
|
pin(2 1)
|
||||||
|
pin(3 2)
|
||||||
|
pin(4 3)
|
||||||
|
pin(5 1)
|
||||||
|
)
|
||||||
|
|
||||||
|
)
|
||||||
|
)
|
||||||
|
|
||||||
|
# Cross reference
|
||||||
|
xref(
|
||||||
|
circuit(INV INVX1 match
|
||||||
|
xref(
|
||||||
|
net(4 4 match)
|
||||||
|
net(5 5 match)
|
||||||
|
net(2 2 match)
|
||||||
|
net(6 6 match)
|
||||||
|
net(1 1 match)
|
||||||
|
net(3 3 match)
|
||||||
|
pin(3 3 match)
|
||||||
|
pin(4 4 match)
|
||||||
|
pin(1 1 match)
|
||||||
|
pin(5 5 match)
|
||||||
|
pin(0 0 match)
|
||||||
|
pin(2 2 match)
|
||||||
|
device(1 1 match)
|
||||||
|
device(2 2 match)
|
||||||
|
)
|
||||||
|
)
|
||||||
|
circuit(nd2X1 ND2X1 match
|
||||||
|
xref(
|
||||||
|
net(8 8 match)
|
||||||
|
net(4 4 match)
|
||||||
|
net(6 6 match)
|
||||||
|
net(5 5 match)
|
||||||
|
net(2 2 match)
|
||||||
|
net(7 7 match)
|
||||||
|
net(1 1 match)
|
||||||
|
net(3 3 match)
|
||||||
|
pin(3 3 match)
|
||||||
|
pin(5 5 match)
|
||||||
|
pin(4 4 match)
|
||||||
|
pin(1 1 match)
|
||||||
|
pin(6 6 match)
|
||||||
|
pin(0 0 match)
|
||||||
|
pin(2 2 match)
|
||||||
|
device(1 1 match)
|
||||||
|
device(2 2 match)
|
||||||
|
device(3 3 match)
|
||||||
|
device(4 4 match)
|
||||||
|
)
|
||||||
|
)
|
||||||
|
circuit(top RINGO match
|
||||||
|
xref(
|
||||||
|
net(1 6 match)
|
||||||
|
net(10 15 match)
|
||||||
|
net(2 7 match)
|
||||||
|
net(3 8 match)
|
||||||
|
net(4 9 match)
|
||||||
|
net(5 10 match)
|
||||||
|
net(6 11 match)
|
||||||
|
net(7 12 match)
|
||||||
|
net(8 13 match)
|
||||||
|
net(9 14 match)
|
||||||
|
net(11 3 match)
|
||||||
|
net(13 5 match)
|
||||||
|
net(12 2 match)
|
||||||
|
net(15 1 match)
|
||||||
|
pin(3 3 match)
|
||||||
|
pin(0 2 match)
|
||||||
|
pin(2 4 match)
|
||||||
|
pin(1 1 match)
|
||||||
|
pin(4 0 match)
|
||||||
|
circuit(1 1 match)
|
||||||
|
circuit(10 10 match)
|
||||||
|
circuit(11 11 match)
|
||||||
|
circuit(12 12 match)
|
||||||
|
circuit(2 2 match)
|
||||||
|
circuit(3 3 match)
|
||||||
|
circuit(4 4 match)
|
||||||
|
circuit(5 5 match)
|
||||||
|
circuit(6 6 match)
|
||||||
|
circuit(7 7 match)
|
||||||
|
circuit(8 8 match)
|
||||||
|
circuit(9 9 match)
|
||||||
|
)
|
||||||
|
)
|
||||||
|
)
|
||||||
|
|
@ -0,0 +1,83 @@
|
||||||
|
* Extracted by KLayout
|
||||||
|
|
||||||
|
* cell RINGO
|
||||||
|
* pin FB
|
||||||
|
* pin VDD
|
||||||
|
* pin OUT
|
||||||
|
* pin ENABLE
|
||||||
|
* pin VSS
|
||||||
|
.SUBCKT RINGO 11 12 13 14 15
|
||||||
|
* net 11 FB
|
||||||
|
* net 12 VDD
|
||||||
|
* net 13 OUT
|
||||||
|
* net 14 ENABLE
|
||||||
|
* net 15 VSS
|
||||||
|
* cell instance $1 r0 *1 1.8,0
|
||||||
|
X$1 12 1 15 12 11 14 15 ND2X1
|
||||||
|
* cell instance $2 r0 *1 4.2,0
|
||||||
|
X$2 12 2 15 12 1 15 INVX1
|
||||||
|
* cell instance $3 r0 *1 6,0
|
||||||
|
X$3 12 3 15 12 2 15 INVX1
|
||||||
|
* cell instance $4 r0 *1 7.8,0
|
||||||
|
X$4 12 4 15 12 3 15 INVX1
|
||||||
|
* cell instance $5 r0 *1 9.6,0
|
||||||
|
X$5 12 5 15 12 4 15 INVX1
|
||||||
|
* cell instance $6 r0 *1 11.4,0
|
||||||
|
X$6 12 6 15 12 5 15 INVX1
|
||||||
|
* cell instance $7 r0 *1 13.2,0
|
||||||
|
X$7 12 7 15 12 6 15 INVX1
|
||||||
|
* cell instance $8 r0 *1 15,0
|
||||||
|
X$8 12 8 15 12 7 15 INVX1
|
||||||
|
* cell instance $9 r0 *1 16.8,0
|
||||||
|
X$9 12 9 15 12 8 15 INVX1
|
||||||
|
* cell instance $10 r0 *1 18.6,0
|
||||||
|
X$10 12 10 15 12 9 15 INVX1
|
||||||
|
* cell instance $11 r0 *1 20.4,0
|
||||||
|
X$11 12 11 15 12 10 15 INVX1
|
||||||
|
* cell instance $12 r0 *1 22.2,0
|
||||||
|
X$12 12 13 15 12 11 15 INVX1
|
||||||
|
.ENDS RINGO
|
||||||
|
|
||||||
|
* cell INVX1
|
||||||
|
* pin VDD
|
||||||
|
* pin OUT
|
||||||
|
* pin VSS
|
||||||
|
* pin
|
||||||
|
* pin IN
|
||||||
|
* pin SUBSTRATE
|
||||||
|
.SUBCKT INVX1 1 2 3 4 5 6
|
||||||
|
* net 1 VDD
|
||||||
|
* net 2 OUT
|
||||||
|
* net 3 VSS
|
||||||
|
* net 5 IN
|
||||||
|
* net 6 SUBSTRATE
|
||||||
|
* device instance $1 r0 *1 0.85,5.8 PMOS
|
||||||
|
M$1 1 5 2 4 PMOS L=0.25U W=1.5U AS=0.6375P AD=0.6375P PS=3.85U PD=3.85U
|
||||||
|
* device instance $2 r0 *1 0.85,2.135 NMOS
|
||||||
|
M$2 3 5 2 6 NMOS L=0.25U W=0.95U AS=0.40375P AD=0.40375P PS=2.75U PD=2.75U
|
||||||
|
.ENDS INVX1
|
||||||
|
|
||||||
|
* cell ND2X1
|
||||||
|
* pin VDD
|
||||||
|
* pin OUT
|
||||||
|
* pin VSS
|
||||||
|
* pin
|
||||||
|
* pin B
|
||||||
|
* pin A
|
||||||
|
* pin SUBSTRATE
|
||||||
|
.SUBCKT ND2X1 1 2 3 4 5 6 7
|
||||||
|
* net 1 VDD
|
||||||
|
* net 2 OUT
|
||||||
|
* net 3 VSS
|
||||||
|
* net 5 B
|
||||||
|
* net 6 A
|
||||||
|
* net 7 SUBSTRATE
|
||||||
|
* device instance $1 r0 *1 0.85,5.8 PMOS
|
||||||
|
M$1 2 6 1 4 PMOS L=0.25U W=1.5U AS=0.6375P AD=0.3375P PS=3.85U PD=1.95U
|
||||||
|
* device instance $2 r0 *1 1.55,5.8 PMOS
|
||||||
|
M$2 1 5 2 4 PMOS L=0.25U W=1.5U AS=0.3375P AD=0.6375P PS=1.95U PD=3.85U
|
||||||
|
* device instance $3 r0 *1 0.85,2.135 NMOS
|
||||||
|
M$3 3 6 8 7 NMOS L=0.25U W=0.95U AS=0.40375P AD=0.21375P PS=2.75U PD=1.4U
|
||||||
|
* device instance $4 r0 *1 1.55,2.135 NMOS
|
||||||
|
M$4 8 5 2 7 NMOS L=0.25U W=0.95U AS=0.21375P AD=0.40375P PS=1.4U PD=2.75U
|
||||||
|
.ENDS ND2X1
|
||||||
|
|
@ -0,0 +1,76 @@
|
||||||
|
|
||||||
|
source($lvs_test_source, "RINGO")
|
||||||
|
|
||||||
|
report_lvs($lvs_test_target_lvsdb)
|
||||||
|
|
||||||
|
target_netlist($lvs_test_target_cir, write_spice, "Extracted by KLayout")
|
||||||
|
|
||||||
|
schematic("ringo_pin_swapping.cir")
|
||||||
|
|
||||||
|
deep
|
||||||
|
|
||||||
|
# Drawing layers
|
||||||
|
|
||||||
|
nwell = input(1, 0)
|
||||||
|
active = input(2, 0)
|
||||||
|
pplus = input(3, 0)
|
||||||
|
nplus = input(4, 0)
|
||||||
|
poly = input(5, 0)
|
||||||
|
contact = input(8, 0)
|
||||||
|
metal1 = input(9, 0)
|
||||||
|
via1 = input(10, 0)
|
||||||
|
metal2 = input(11, 0)
|
||||||
|
|
||||||
|
# Bulk layer for terminal provisioning
|
||||||
|
|
||||||
|
bulk = polygon_layer
|
||||||
|
|
||||||
|
# Computed layers
|
||||||
|
|
||||||
|
active_in_nwell = active & nwell
|
||||||
|
pactive = active_in_nwell & pplus
|
||||||
|
pgate = pactive & poly
|
||||||
|
psd = pactive - pgate
|
||||||
|
ntie = active_in_nwell & nplus
|
||||||
|
|
||||||
|
active_outside_nwell = active - nwell
|
||||||
|
nactive = active_outside_nwell & nplus
|
||||||
|
ngate = nactive & poly
|
||||||
|
nsd = nactive - ngate
|
||||||
|
ptie = active_outside_nwell & pplus
|
||||||
|
|
||||||
|
# Device extraction
|
||||||
|
|
||||||
|
# PMOS transistor device extraction
|
||||||
|
extract_devices(mos4("PMOS"), { "SD" => psd, "G" => pgate, "W" => nwell,
|
||||||
|
"tS" => psd, "tD" => psd, "tG" => poly, "tW" => nwell })
|
||||||
|
|
||||||
|
# NMOS transistor device extraction
|
||||||
|
extract_devices(mos4("NMOS"), { "SD" => nsd, "G" => ngate, "W" => bulk,
|
||||||
|
"tS" => nsd, "tD" => nsd, "tG" => poly, "tW" => bulk })
|
||||||
|
|
||||||
|
# Define connectivity for netlist extraction
|
||||||
|
|
||||||
|
# Inter-layer
|
||||||
|
connect(psd, contact)
|
||||||
|
connect(nsd, contact)
|
||||||
|
connect(poly, contact)
|
||||||
|
connect(ntie, contact)
|
||||||
|
connect(nwell, ntie)
|
||||||
|
connect(ptie, contact)
|
||||||
|
connect(contact, metal1)
|
||||||
|
connect(metal1, via1)
|
||||||
|
connect(via1, metal2)
|
||||||
|
|
||||||
|
# Global
|
||||||
|
connect_global(bulk, "SUBSTRATE")
|
||||||
|
connect_global(ptie, "SUBSTRATE")
|
||||||
|
|
||||||
|
# Compare section
|
||||||
|
|
||||||
|
equivalent_pins("ND2X1", 4, 5)
|
||||||
|
|
||||||
|
netlist.simplify
|
||||||
|
|
||||||
|
compare
|
||||||
|
|
||||||
|
|
@ -0,0 +1,962 @@
|
||||||
|
#%lvsdb-klayout
|
||||||
|
|
||||||
|
# Layout
|
||||||
|
layout(
|
||||||
|
top(RINGO)
|
||||||
|
unit(0.001)
|
||||||
|
|
||||||
|
# Layer section
|
||||||
|
# This section lists the mask layers (drawing or derived) and their connections.
|
||||||
|
|
||||||
|
# Mask layers
|
||||||
|
layer(l3 '1/0')
|
||||||
|
layer(l4 '5/0')
|
||||||
|
layer(l8 '8/0')
|
||||||
|
layer(l11 '9/0')
|
||||||
|
layer(l12 '10/0')
|
||||||
|
layer(l13 '11/0')
|
||||||
|
layer(l7)
|
||||||
|
layer(l1)
|
||||||
|
layer(l9)
|
||||||
|
layer(l5)
|
||||||
|
layer(l10)
|
||||||
|
|
||||||
|
# Mask layer connectivity
|
||||||
|
connect(l3 l3 l9)
|
||||||
|
connect(l4 l4 l8)
|
||||||
|
connect(l8 l4 l8 l11 l1 l9 l5 l10)
|
||||||
|
connect(l11 l8 l11 l12)
|
||||||
|
connect(l12 l11 l12 l13)
|
||||||
|
connect(l13 l12 l13)
|
||||||
|
connect(l7 l7)
|
||||||
|
connect(l1 l8 l1)
|
||||||
|
connect(l9 l3 l8 l9)
|
||||||
|
connect(l5 l8 l5)
|
||||||
|
connect(l10 l8 l10)
|
||||||
|
|
||||||
|
# Global nets and connectivity
|
||||||
|
global(l7 SUBSTRATE)
|
||||||
|
global(l10 SUBSTRATE)
|
||||||
|
|
||||||
|
# Device class section
|
||||||
|
class(PMOS MOS4)
|
||||||
|
class(NMOS MOS4)
|
||||||
|
|
||||||
|
# Device abstracts section
|
||||||
|
# Device abstracts list the pin shapes of the devices.
|
||||||
|
device(D$PMOS PMOS
|
||||||
|
terminal(S
|
||||||
|
rect(l1 (-550 -750) (425 1500))
|
||||||
|
)
|
||||||
|
terminal(G
|
||||||
|
rect(l4 (-125 -750) (250 1500))
|
||||||
|
)
|
||||||
|
terminal(D
|
||||||
|
rect(l1 (125 -750) (450 1500))
|
||||||
|
)
|
||||||
|
terminal(B
|
||||||
|
rect(l3 (-125 -750) (250 1500))
|
||||||
|
)
|
||||||
|
)
|
||||||
|
device(D$PMOS$1 PMOS
|
||||||
|
terminal(S
|
||||||
|
rect(l1 (-575 -750) (450 1500))
|
||||||
|
)
|
||||||
|
terminal(G
|
||||||
|
rect(l4 (-125 -750) (250 1500))
|
||||||
|
)
|
||||||
|
terminal(D
|
||||||
|
rect(l1 (125 -750) (425 1500))
|
||||||
|
)
|
||||||
|
terminal(B
|
||||||
|
rect(l3 (-125 -750) (250 1500))
|
||||||
|
)
|
||||||
|
)
|
||||||
|
device(D$PMOS$2 PMOS
|
||||||
|
terminal(S
|
||||||
|
rect(l1 (-550 -750) (425 1500))
|
||||||
|
)
|
||||||
|
terminal(G
|
||||||
|
rect(l4 (-125 -750) (250 1500))
|
||||||
|
)
|
||||||
|
terminal(D
|
||||||
|
rect(l1 (125 -750) (425 1500))
|
||||||
|
)
|
||||||
|
terminal(B
|
||||||
|
rect(l3 (-125 -750) (250 1500))
|
||||||
|
)
|
||||||
|
)
|
||||||
|
device(D$NMOS NMOS
|
||||||
|
terminal(S
|
||||||
|
rect(l5 (-550 -475) (425 950))
|
||||||
|
)
|
||||||
|
terminal(G
|
||||||
|
rect(l4 (-125 -475) (250 950))
|
||||||
|
)
|
||||||
|
terminal(D
|
||||||
|
rect(l5 (125 -475) (450 950))
|
||||||
|
)
|
||||||
|
terminal(B
|
||||||
|
rect(l7 (-125 -475) (250 950))
|
||||||
|
)
|
||||||
|
)
|
||||||
|
device(D$NMOS$1 NMOS
|
||||||
|
terminal(S
|
||||||
|
rect(l5 (-575 -475) (450 950))
|
||||||
|
)
|
||||||
|
terminal(G
|
||||||
|
rect(l4 (-125 -475) (250 950))
|
||||||
|
)
|
||||||
|
terminal(D
|
||||||
|
rect(l5 (125 -475) (425 950))
|
||||||
|
)
|
||||||
|
terminal(B
|
||||||
|
rect(l7 (-125 -475) (250 950))
|
||||||
|
)
|
||||||
|
)
|
||||||
|
device(D$NMOS$2 NMOS
|
||||||
|
terminal(S
|
||||||
|
rect(l5 (-550 -475) (425 950))
|
||||||
|
)
|
||||||
|
terminal(G
|
||||||
|
rect(l4 (-125 -475) (250 950))
|
||||||
|
)
|
||||||
|
terminal(D
|
||||||
|
rect(l5 (125 -475) (425 950))
|
||||||
|
)
|
||||||
|
terminal(B
|
||||||
|
rect(l7 (-125 -475) (250 950))
|
||||||
|
)
|
||||||
|
)
|
||||||
|
|
||||||
|
# Circuit section
|
||||||
|
# Circuits are the hierarchical building blocks of the netlist.
|
||||||
|
circuit(ND2X1
|
||||||
|
|
||||||
|
# Nets with their geometries
|
||||||
|
net(1 name(VDD)
|
||||||
|
rect(l8 (1110 5160) (180 180))
|
||||||
|
rect(l8 (-180 920) (180 180))
|
||||||
|
rect(l8 (-180 -730) (180 180))
|
||||||
|
rect(l11 (-240 -790) (300 1700))
|
||||||
|
rect(l11 (-1350 0) (2400 800))
|
||||||
|
rect(l11 (-1151 -401) (2 2))
|
||||||
|
rect(l1 (-276 -2151) (425 1500))
|
||||||
|
rect(l1 (-400 -1500) (425 1500))
|
||||||
|
)
|
||||||
|
net(2 name(OUT)
|
||||||
|
rect(l8 (1810 1770) (180 180))
|
||||||
|
rect(l8 (-180 370) (180 180))
|
||||||
|
rect(l8 (-1580 3760) (180 180))
|
||||||
|
rect(l8 (-180 -730) (180 180))
|
||||||
|
rect(l8 (-180 -730) (180 180))
|
||||||
|
rect(l8 (1220 920) (180 180))
|
||||||
|
rect(l8 (-180 -1280) (180 180))
|
||||||
|
rect(l8 (-180 370) (180 180))
|
||||||
|
polygon(l11 (-240 -4180) (0 1390) (490 0) (0 -300) (-190 0) (0 -1090))
|
||||||
|
rect(l11 (-110 1390) (300 1400))
|
||||||
|
polygon(l11 (-1890 0) (0 600) (300 0) (0 -300) (1590 0) (0 -300))
|
||||||
|
rect(l11 (-141 -501) (2 2))
|
||||||
|
rect(l11 (-1751 1099) (300 1400))
|
||||||
|
rect(l11 (1100 -1700) (300 300))
|
||||||
|
rect(l11 (-300 0) (300 1400))
|
||||||
|
rect(l1 (-1750 -1450) (425 1500))
|
||||||
|
rect(l1 (950 -1500) (425 1500))
|
||||||
|
rect(l5 (-425 -4890) (425 950))
|
||||||
|
)
|
||||||
|
net(3 name(VSS)
|
||||||
|
rect(l8 (410 1770) (180 180))
|
||||||
|
rect(l8 (-180 370) (180 180))
|
||||||
|
rect(l11 (-240 -1300) (300 1360))
|
||||||
|
rect(l11 (-650 -2160) (2400 800))
|
||||||
|
rect(l11 (-1151 -401) (2 2))
|
||||||
|
rect(l5 (-951 859) (425 950))
|
||||||
|
)
|
||||||
|
net(4
|
||||||
|
rect(l3 (-100 4500) (2600 3500))
|
||||||
|
)
|
||||||
|
net(5 name(B)
|
||||||
|
rect(l4 (1425 2860) (250 1940))
|
||||||
|
rect(l4 (-345 -950) (300 300))
|
||||||
|
rect(l4 (-205 650) (250 2000))
|
||||||
|
rect(l4 (-250 -2000) (250 2000))
|
||||||
|
rect(l4 (-250 -5390) (250 1450))
|
||||||
|
rect(l8 (-285 1050) (180 180))
|
||||||
|
rect(l11 (-71 -91) (2 2))
|
||||||
|
rect(l11 (-171 -151) (300 300))
|
||||||
|
)
|
||||||
|
net(6 name(A)
|
||||||
|
rect(l4 (725 2860) (250 1940))
|
||||||
|
rect(l4 (-325 -1850) (300 300))
|
||||||
|
rect(l4 (-225 1550) (250 2000))
|
||||||
|
rect(l4 (-250 -2000) (250 2000))
|
||||||
|
rect(l4 (-250 -5390) (250 1450))
|
||||||
|
rect(l8 (-265 150) (180 180))
|
||||||
|
rect(l11 (-91 -91) (2 2))
|
||||||
|
rect(l11 (-151 -151) (300 300))
|
||||||
|
)
|
||||||
|
net(7 name(SUBSTRATE))
|
||||||
|
net(8
|
||||||
|
rect(l5 (975 1660) (425 950))
|
||||||
|
rect(l5 (-400 -950) (425 950))
|
||||||
|
)
|
||||||
|
|
||||||
|
# Outgoing pins and their connections to nets
|
||||||
|
pin(1 name(VDD))
|
||||||
|
pin(2 name(OUT))
|
||||||
|
pin(3 name(VSS))
|
||||||
|
pin(4)
|
||||||
|
pin(5 name(B))
|
||||||
|
pin(6 name(A))
|
||||||
|
pin(7 name(SUBSTRATE))
|
||||||
|
|
||||||
|
# Devices and their connections
|
||||||
|
device(1 D$PMOS
|
||||||
|
location(850 5800)
|
||||||
|
param(L 0.25)
|
||||||
|
param(W 1.5)
|
||||||
|
param(AS 0.6375)
|
||||||
|
param(AD 0.3375)
|
||||||
|
param(PS 3.85)
|
||||||
|
param(PD 1.95)
|
||||||
|
terminal(S 2)
|
||||||
|
terminal(G 6)
|
||||||
|
terminal(D 1)
|
||||||
|
terminal(B 4)
|
||||||
|
)
|
||||||
|
device(2 D$PMOS$1
|
||||||
|
location(1550 5800)
|
||||||
|
param(L 0.25)
|
||||||
|
param(W 1.5)
|
||||||
|
param(AS 0.3375)
|
||||||
|
param(AD 0.6375)
|
||||||
|
param(PS 1.95)
|
||||||
|
param(PD 3.85)
|
||||||
|
terminal(S 1)
|
||||||
|
terminal(G 5)
|
||||||
|
terminal(D 2)
|
||||||
|
terminal(B 4)
|
||||||
|
)
|
||||||
|
device(3 D$NMOS
|
||||||
|
location(850 2135)
|
||||||
|
param(L 0.25)
|
||||||
|
param(W 0.95)
|
||||||
|
param(AS 0.40375)
|
||||||
|
param(AD 0.21375)
|
||||||
|
param(PS 2.75)
|
||||||
|
param(PD 1.4)
|
||||||
|
terminal(S 3)
|
||||||
|
terminal(G 6)
|
||||||
|
terminal(D 8)
|
||||||
|
terminal(B 7)
|
||||||
|
)
|
||||||
|
device(4 D$NMOS$1
|
||||||
|
location(1550 2135)
|
||||||
|
param(L 0.25)
|
||||||
|
param(W 0.95)
|
||||||
|
param(AS 0.21375)
|
||||||
|
param(AD 0.40375)
|
||||||
|
param(PS 1.4)
|
||||||
|
param(PD 2.75)
|
||||||
|
terminal(S 8)
|
||||||
|
terminal(G 5)
|
||||||
|
terminal(D 2)
|
||||||
|
terminal(B 7)
|
||||||
|
)
|
||||||
|
|
||||||
|
)
|
||||||
|
circuit(INVX1
|
||||||
|
|
||||||
|
# Nets with their geometries
|
||||||
|
net(1 name(VDD)
|
||||||
|
rect(l8 (410 6260) (180 180))
|
||||||
|
rect(l8 (-180 -730) (180 180))
|
||||||
|
rect(l8 (-180 -730) (180 180))
|
||||||
|
rect(l11 (-240 -240) (300 1400))
|
||||||
|
rect(l11 (-650 300) (1800 800))
|
||||||
|
rect(l11 (-1450 -1100) (300 300))
|
||||||
|
rect(l11 (299 399) (2 2))
|
||||||
|
rect(l1 (-651 -2151) (425 1500))
|
||||||
|
)
|
||||||
|
net(2 name(OUT)
|
||||||
|
rect(l8 (1110 5160) (180 180))
|
||||||
|
rect(l8 (-180 920) (180 180))
|
||||||
|
rect(l8 (-180 -730) (180 180))
|
||||||
|
rect(l8 (-180 -4120) (180 180))
|
||||||
|
rect(l8 (-180 370) (180 180))
|
||||||
|
rect(l11 (-240 -790) (300 4790))
|
||||||
|
rect(l11 (-151 -2501) (2 2))
|
||||||
|
rect(l1 (-226 1049) (425 1500))
|
||||||
|
rect(l5 (-425 -4890) (425 950))
|
||||||
|
)
|
||||||
|
net(3 name(VSS)
|
||||||
|
rect(l8 (410 1770) (180 180))
|
||||||
|
rect(l8 (-180 370) (180 180))
|
||||||
|
rect(l11 (-240 -1300) (300 1360))
|
||||||
|
rect(l11 (-650 -2160) (1800 800))
|
||||||
|
rect(l11 (-851 -401) (2 2))
|
||||||
|
rect(l5 (-651 859) (425 950))
|
||||||
|
)
|
||||||
|
net(4
|
||||||
|
rect(l3 (-100 4500) (2000 3500))
|
||||||
|
)
|
||||||
|
net(5 name(IN)
|
||||||
|
rect(l4 (725 2860) (250 1940))
|
||||||
|
rect(l4 (-525 -1850) (300 300))
|
||||||
|
rect(l4 (-25 1550) (250 2000))
|
||||||
|
rect(l4 (-250 -2000) (250 2000))
|
||||||
|
rect(l4 (-250 -5390) (250 1450))
|
||||||
|
rect(l8 (-465 150) (180 180))
|
||||||
|
rect(l11 (-91 -91) (2 2))
|
||||||
|
rect(l11 (-151 -151) (300 300))
|
||||||
|
)
|
||||||
|
net(6 name(SUBSTRATE))
|
||||||
|
|
||||||
|
# Outgoing pins and their connections to nets
|
||||||
|
pin(1 name(VDD))
|
||||||
|
pin(2 name(OUT))
|
||||||
|
pin(3 name(VSS))
|
||||||
|
pin(4)
|
||||||
|
pin(5 name(IN))
|
||||||
|
pin(6 name(SUBSTRATE))
|
||||||
|
|
||||||
|
# Devices and their connections
|
||||||
|
device(1 D$PMOS$2
|
||||||
|
location(850 5800)
|
||||||
|
param(L 0.25)
|
||||||
|
param(W 1.5)
|
||||||
|
param(AS 0.6375)
|
||||||
|
param(AD 0.6375)
|
||||||
|
param(PS 3.85)
|
||||||
|
param(PD 3.85)
|
||||||
|
terminal(S 1)
|
||||||
|
terminal(G 5)
|
||||||
|
terminal(D 2)
|
||||||
|
terminal(B 4)
|
||||||
|
)
|
||||||
|
device(2 D$NMOS$2
|
||||||
|
location(850 2135)
|
||||||
|
param(L 0.25)
|
||||||
|
param(W 0.95)
|
||||||
|
param(AS 0.40375)
|
||||||
|
param(AD 0.40375)
|
||||||
|
param(PS 2.75)
|
||||||
|
param(PD 2.75)
|
||||||
|
terminal(S 3)
|
||||||
|
terminal(G 5)
|
||||||
|
terminal(D 2)
|
||||||
|
terminal(B 6)
|
||||||
|
)
|
||||||
|
|
||||||
|
)
|
||||||
|
circuit(RINGO
|
||||||
|
|
||||||
|
# Nets with their geometries
|
||||||
|
net(1
|
||||||
|
rect(l8 (4710 3010) (180 180))
|
||||||
|
rect(l11 (-850 -240) (610 300))
|
||||||
|
rect(l1 (-2550 1800) (425 1500))
|
||||||
|
rect(l1 (950 -1500) (425 1500))
|
||||||
|
rect(l5 (-425 -4890) (425 950))
|
||||||
|
)
|
||||||
|
net(2
|
||||||
|
rect(l8 (6510 3010) (180 180))
|
||||||
|
rect(l11 (-1140 -240) (900 300))
|
||||||
|
rect(l1 (-1275 1800) (425 1500))
|
||||||
|
rect(l5 (-425 -4890) (425 950))
|
||||||
|
)
|
||||||
|
net(3
|
||||||
|
rect(l8 (8310 3010) (180 180))
|
||||||
|
rect(l11 (-1140 -240) (900 300))
|
||||||
|
rect(l1 (-1275 1800) (425 1500))
|
||||||
|
rect(l5 (-425 -4890) (425 950))
|
||||||
|
)
|
||||||
|
net(4
|
||||||
|
rect(l8 (10110 3010) (180 180))
|
||||||
|
rect(l11 (-1140 -240) (900 300))
|
||||||
|
rect(l1 (-1275 1800) (425 1500))
|
||||||
|
rect(l5 (-425 -4890) (425 950))
|
||||||
|
)
|
||||||
|
net(5
|
||||||
|
rect(l8 (11910 3010) (180 180))
|
||||||
|
rect(l11 (-1140 -240) (900 300))
|
||||||
|
rect(l1 (-1275 1800) (425 1500))
|
||||||
|
rect(l5 (-425 -4890) (425 950))
|
||||||
|
)
|
||||||
|
net(6
|
||||||
|
rect(l8 (13710 3010) (180 180))
|
||||||
|
rect(l11 (-1140 -240) (900 300))
|
||||||
|
rect(l1 (-1275 1800) (425 1500))
|
||||||
|
rect(l5 (-425 -4890) (425 950))
|
||||||
|
)
|
||||||
|
net(7
|
||||||
|
rect(l8 (15510 3010) (180 180))
|
||||||
|
rect(l11 (-1140 -240) (900 300))
|
||||||
|
rect(l1 (-1275 1800) (425 1500))
|
||||||
|
rect(l5 (-425 -4890) (425 950))
|
||||||
|
)
|
||||||
|
net(8
|
||||||
|
rect(l8 (17310 3010) (180 180))
|
||||||
|
rect(l11 (-1140 -240) (900 300))
|
||||||
|
rect(l1 (-1275 1800) (425 1500))
|
||||||
|
rect(l5 (-425 -4890) (425 950))
|
||||||
|
)
|
||||||
|
net(9
|
||||||
|
rect(l8 (19110 3010) (180 180))
|
||||||
|
rect(l11 (-1140 -240) (900 300))
|
||||||
|
rect(l1 (-1275 1800) (425 1500))
|
||||||
|
rect(l5 (-425 -4890) (425 950))
|
||||||
|
)
|
||||||
|
net(10
|
||||||
|
rect(l8 (20910 3010) (180 180))
|
||||||
|
rect(l11 (-1140 -240) (900 300))
|
||||||
|
rect(l1 (-1275 1800) (425 1500))
|
||||||
|
rect(l5 (-425 -4890) (425 950))
|
||||||
|
)
|
||||||
|
net(11 name(FB)
|
||||||
|
rect(l8 (22710 3010) (180 180))
|
||||||
|
rect(l8 (-19700 720) (180 180))
|
||||||
|
rect(l11 (18380 -1140) (900 300))
|
||||||
|
rect(l11 (-19530 590) (320 320))
|
||||||
|
rect(l11 (17820 -320) (320 320))
|
||||||
|
rect(l12 (-18400 -260) (200 200))
|
||||||
|
rect(l12 (17940 -200) (200 200))
|
||||||
|
rect(l13 (-18040 -300) (17740 400))
|
||||||
|
rect(l13 (-17921 -201) (2 2))
|
||||||
|
rect(l13 (-221 -201) (400 400))
|
||||||
|
rect(l13 (17740 -400) (400 400))
|
||||||
|
rect(l1 (-245 850) (425 1500))
|
||||||
|
rect(l5 (-425 -4890) (425 950))
|
||||||
|
)
|
||||||
|
net(12 name(VDD)
|
||||||
|
rect(l3 (500 4500) (1400 3500))
|
||||||
|
rect(l3 (-1900 -3500) (600 3500))
|
||||||
|
rect(l3 (23300 -3500) (1400 3500))
|
||||||
|
rect(l3 (-100 -3500) (600 3500))
|
||||||
|
rect(l8 (-24690 -1240) (180 180))
|
||||||
|
rect(l8 (-180 370) (180 180))
|
||||||
|
rect(l8 (-180 -1280) (180 180))
|
||||||
|
rect(l8 (23220 370) (180 180))
|
||||||
|
rect(l8 (-180 370) (180 180))
|
||||||
|
rect(l8 (-180 -1280) (180 180))
|
||||||
|
rect(l11 (-21741 859) (2 2))
|
||||||
|
rect(l11 (-2351 -451) (1200 800))
|
||||||
|
rect(l11 (-750 -1450) (300 1400))
|
||||||
|
rect(l11 (-101 -351) (2 2))
|
||||||
|
rect(l11 (-1251 -401) (600 800))
|
||||||
|
rect(l11 (23400 -800) (1200 800))
|
||||||
|
rect(l11 (-750 -1450) (300 1400))
|
||||||
|
rect(l11 (-101 -351) (2 2))
|
||||||
|
rect(l11 (549 -401) (600 800))
|
||||||
|
rect(l1 (-23025 -2550) (425 1500))
|
||||||
|
rect(l1 (-400 -1500) (425 1500))
|
||||||
|
rect(l1 (1275 -1500) (425 1500))
|
||||||
|
rect(l1 (1375 -1500) (425 1500))
|
||||||
|
rect(l1 (1375 -1500) (425 1500))
|
||||||
|
rect(l1 (1375 -1500) (425 1500))
|
||||||
|
rect(l1 (1375 -1500) (425 1500))
|
||||||
|
rect(l1 (1375 -1500) (425 1500))
|
||||||
|
rect(l1 (1375 -1500) (425 1500))
|
||||||
|
rect(l1 (1375 -1500) (425 1500))
|
||||||
|
rect(l1 (1375 -1500) (425 1500))
|
||||||
|
rect(l1 (1375 -1500) (425 1500))
|
||||||
|
rect(l1 (1375 -1500) (425 1500))
|
||||||
|
rect(l9 (-21975 -450) (500 1500))
|
||||||
|
rect(l9 (22900 -1500) (500 1500))
|
||||||
|
)
|
||||||
|
net(13 name(OUT)
|
||||||
|
rect(l11 (23440 3840) (320 320))
|
||||||
|
rect(l12 (-260 -260) (200 200))
|
||||||
|
rect(l13 (-101 -101) (2 2))
|
||||||
|
rect(l13 (-201 -201) (400 400))
|
||||||
|
rect(l1 (-625 850) (425 1500))
|
||||||
|
rect(l5 (-425 -4890) (425 950))
|
||||||
|
)
|
||||||
|
net(14 name(ENABLE)
|
||||||
|
rect(l8 (2510 3010) (180 180))
|
||||||
|
rect(l11 (-250 -250) (320 320))
|
||||||
|
rect(l12 (-260 -260) (200 200))
|
||||||
|
rect(l13 (-101 -101) (2 2))
|
||||||
|
rect(l13 (-201 -201) (400 400))
|
||||||
|
)
|
||||||
|
net(15 name(VSS)
|
||||||
|
rect(l8 (1110 1610) (180 180))
|
||||||
|
rect(l8 (-180 -1280) (180 180))
|
||||||
|
rect(l8 (-180 370) (180 180))
|
||||||
|
rect(l8 (23220 370) (180 180))
|
||||||
|
rect(l8 (-180 -1280) (180 180))
|
||||||
|
rect(l8 (-180 370) (180 180))
|
||||||
|
rect(l11 (-21741 -391) (2 2))
|
||||||
|
rect(l11 (-1901 -401) (300 1400))
|
||||||
|
rect(l11 (-750 -1450) (1200 800))
|
||||||
|
rect(l11 (-551 -401) (2 2))
|
||||||
|
rect(l11 (-1251 -401) (600 800))
|
||||||
|
rect(l11 (23850 -750) (300 1400))
|
||||||
|
rect(l11 (-750 -1450) (1200 800))
|
||||||
|
rect(l11 (-551 -401) (2 2))
|
||||||
|
rect(l11 (549 -401) (600 800))
|
||||||
|
rect(l5 (-23700 460) (425 950))
|
||||||
|
rect(l5 (1975 -950) (425 950))
|
||||||
|
rect(l5 (1375 -950) (425 950))
|
||||||
|
rect(l5 (1375 -950) (425 950))
|
||||||
|
rect(l5 (1375 -950) (425 950))
|
||||||
|
rect(l5 (1375 -950) (425 950))
|
||||||
|
rect(l5 (1375 -950) (425 950))
|
||||||
|
rect(l5 (1375 -950) (425 950))
|
||||||
|
rect(l5 (1375 -950) (425 950))
|
||||||
|
rect(l5 (1375 -950) (425 950))
|
||||||
|
rect(l5 (1375 -950) (425 950))
|
||||||
|
rect(l5 (1375 -950) (425 950))
|
||||||
|
rect(l10 (-21975 -2210) (500 1500))
|
||||||
|
rect(l10 (22900 -1500) (500 1500))
|
||||||
|
)
|
||||||
|
|
||||||
|
# Outgoing pins and their connections to nets
|
||||||
|
pin(11 name(FB))
|
||||||
|
pin(12 name(VDD))
|
||||||
|
pin(13 name(OUT))
|
||||||
|
pin(14 name(ENABLE))
|
||||||
|
pin(15 name(VSS))
|
||||||
|
|
||||||
|
# Subcircuits and their connections
|
||||||
|
circuit(1 ND2X1 location(1800 0)
|
||||||
|
pin(0 12)
|
||||||
|
pin(1 1)
|
||||||
|
pin(2 15)
|
||||||
|
pin(3 12)
|
||||||
|
pin(4 11)
|
||||||
|
pin(5 14)
|
||||||
|
pin(6 15)
|
||||||
|
)
|
||||||
|
circuit(2 INVX1 location(4200 0)
|
||||||
|
pin(0 12)
|
||||||
|
pin(1 2)
|
||||||
|
pin(2 15)
|
||||||
|
pin(3 12)
|
||||||
|
pin(4 1)
|
||||||
|
pin(5 15)
|
||||||
|
)
|
||||||
|
circuit(3 INVX1 location(6000 0)
|
||||||
|
pin(0 12)
|
||||||
|
pin(1 3)
|
||||||
|
pin(2 15)
|
||||||
|
pin(3 12)
|
||||||
|
pin(4 2)
|
||||||
|
pin(5 15)
|
||||||
|
)
|
||||||
|
circuit(4 INVX1 location(7800 0)
|
||||||
|
pin(0 12)
|
||||||
|
pin(1 4)
|
||||||
|
pin(2 15)
|
||||||
|
pin(3 12)
|
||||||
|
pin(4 3)
|
||||||
|
pin(5 15)
|
||||||
|
)
|
||||||
|
circuit(5 INVX1 location(9600 0)
|
||||||
|
pin(0 12)
|
||||||
|
pin(1 5)
|
||||||
|
pin(2 15)
|
||||||
|
pin(3 12)
|
||||||
|
pin(4 4)
|
||||||
|
pin(5 15)
|
||||||
|
)
|
||||||
|
circuit(6 INVX1 location(11400 0)
|
||||||
|
pin(0 12)
|
||||||
|
pin(1 6)
|
||||||
|
pin(2 15)
|
||||||
|
pin(3 12)
|
||||||
|
pin(4 5)
|
||||||
|
pin(5 15)
|
||||||
|
)
|
||||||
|
circuit(7 INVX1 location(13200 0)
|
||||||
|
pin(0 12)
|
||||||
|
pin(1 7)
|
||||||
|
pin(2 15)
|
||||||
|
pin(3 12)
|
||||||
|
pin(4 6)
|
||||||
|
pin(5 15)
|
||||||
|
)
|
||||||
|
circuit(8 INVX1 location(15000 0)
|
||||||
|
pin(0 12)
|
||||||
|
pin(1 8)
|
||||||
|
pin(2 15)
|
||||||
|
pin(3 12)
|
||||||
|
pin(4 7)
|
||||||
|
pin(5 15)
|
||||||
|
)
|
||||||
|
circuit(9 INVX1 location(16800 0)
|
||||||
|
pin(0 12)
|
||||||
|
pin(1 9)
|
||||||
|
pin(2 15)
|
||||||
|
pin(3 12)
|
||||||
|
pin(4 8)
|
||||||
|
pin(5 15)
|
||||||
|
)
|
||||||
|
circuit(10 INVX1 location(18600 0)
|
||||||
|
pin(0 12)
|
||||||
|
pin(1 10)
|
||||||
|
pin(2 15)
|
||||||
|
pin(3 12)
|
||||||
|
pin(4 9)
|
||||||
|
pin(5 15)
|
||||||
|
)
|
||||||
|
circuit(11 INVX1 location(20400 0)
|
||||||
|
pin(0 12)
|
||||||
|
pin(1 11)
|
||||||
|
pin(2 15)
|
||||||
|
pin(3 12)
|
||||||
|
pin(4 10)
|
||||||
|
pin(5 15)
|
||||||
|
)
|
||||||
|
circuit(12 INVX1 location(22200 0)
|
||||||
|
pin(0 12)
|
||||||
|
pin(1 13)
|
||||||
|
pin(2 15)
|
||||||
|
pin(3 12)
|
||||||
|
pin(4 11)
|
||||||
|
pin(5 15)
|
||||||
|
)
|
||||||
|
|
||||||
|
)
|
||||||
|
)
|
||||||
|
|
||||||
|
# Reference netlist
|
||||||
|
reference(
|
||||||
|
|
||||||
|
# Device class section
|
||||||
|
class(PMOS MOS4)
|
||||||
|
class(NMOS MOS4)
|
||||||
|
|
||||||
|
# Circuit section
|
||||||
|
# Circuits are the hierarchical building blocks of the netlist.
|
||||||
|
circuit(ND2X1
|
||||||
|
|
||||||
|
# Nets
|
||||||
|
net(1 name(VDD))
|
||||||
|
net(2 name(OUT))
|
||||||
|
net(3 name(VSS))
|
||||||
|
net(4 name(NWELL))
|
||||||
|
net(5 name(A))
|
||||||
|
net(6 name(B))
|
||||||
|
net(7 name(BULK))
|
||||||
|
net(8 name('1'))
|
||||||
|
|
||||||
|
# Outgoing pins and their connections to nets
|
||||||
|
pin(1)
|
||||||
|
pin(2)
|
||||||
|
pin(3)
|
||||||
|
pin(4)
|
||||||
|
pin(5)
|
||||||
|
pin(6)
|
||||||
|
pin(7)
|
||||||
|
|
||||||
|
# Devices and their connections
|
||||||
|
device(1 PMOS
|
||||||
|
name($1)
|
||||||
|
param(L 0.25)
|
||||||
|
param(W 1.5)
|
||||||
|
param(AS 0)
|
||||||
|
param(AD 0)
|
||||||
|
param(PS 0)
|
||||||
|
param(PD 0)
|
||||||
|
terminal(S 2)
|
||||||
|
terminal(G 5)
|
||||||
|
terminal(D 1)
|
||||||
|
terminal(B 4)
|
||||||
|
)
|
||||||
|
device(2 PMOS
|
||||||
|
name($2)
|
||||||
|
param(L 0.25)
|
||||||
|
param(W 1.5)
|
||||||
|
param(AS 0)
|
||||||
|
param(AD 0)
|
||||||
|
param(PS 0)
|
||||||
|
param(PD 0)
|
||||||
|
terminal(S 1)
|
||||||
|
terminal(G 6)
|
||||||
|
terminal(D 2)
|
||||||
|
terminal(B 4)
|
||||||
|
)
|
||||||
|
device(3 NMOS
|
||||||
|
name($3)
|
||||||
|
param(L 0.25)
|
||||||
|
param(W 0.95)
|
||||||
|
param(AS 0)
|
||||||
|
param(AD 0)
|
||||||
|
param(PS 0)
|
||||||
|
param(PD 0)
|
||||||
|
terminal(S 3)
|
||||||
|
terminal(G 5)
|
||||||
|
terminal(D 8)
|
||||||
|
terminal(B 7)
|
||||||
|
)
|
||||||
|
device(4 NMOS
|
||||||
|
name($4)
|
||||||
|
param(L 0.25)
|
||||||
|
param(W 0.95)
|
||||||
|
param(AS 0)
|
||||||
|
param(AD 0)
|
||||||
|
param(PS 0)
|
||||||
|
param(PD 0)
|
||||||
|
terminal(S 8)
|
||||||
|
terminal(G 6)
|
||||||
|
terminal(D 2)
|
||||||
|
terminal(B 7)
|
||||||
|
)
|
||||||
|
|
||||||
|
)
|
||||||
|
circuit(INVX1
|
||||||
|
|
||||||
|
# Nets
|
||||||
|
net(1 name(VDD))
|
||||||
|
net(2 name(OUT))
|
||||||
|
net(3 name(VSS))
|
||||||
|
net(4 name(NWELL))
|
||||||
|
net(5 name(IN))
|
||||||
|
net(6 name(BULK))
|
||||||
|
|
||||||
|
# Outgoing pins and their connections to nets
|
||||||
|
pin(1)
|
||||||
|
pin(2)
|
||||||
|
pin(3)
|
||||||
|
pin(4)
|
||||||
|
pin(5)
|
||||||
|
pin(6)
|
||||||
|
|
||||||
|
# Devices and their connections
|
||||||
|
device(1 PMOS
|
||||||
|
name($1)
|
||||||
|
param(L 0.25)
|
||||||
|
param(W 1.5)
|
||||||
|
param(AS 0)
|
||||||
|
param(AD 0)
|
||||||
|
param(PS 0)
|
||||||
|
param(PD 0)
|
||||||
|
terminal(S 1)
|
||||||
|
terminal(G 5)
|
||||||
|
terminal(D 2)
|
||||||
|
terminal(B 4)
|
||||||
|
)
|
||||||
|
device(2 NMOS
|
||||||
|
name($2)
|
||||||
|
param(L 0.25)
|
||||||
|
param(W 0.95)
|
||||||
|
param(AS 0)
|
||||||
|
param(AD 0)
|
||||||
|
param(PS 0)
|
||||||
|
param(PD 0)
|
||||||
|
terminal(S 3)
|
||||||
|
terminal(G 5)
|
||||||
|
terminal(D 2)
|
||||||
|
terminal(B 6)
|
||||||
|
)
|
||||||
|
|
||||||
|
)
|
||||||
|
circuit(RINGO
|
||||||
|
|
||||||
|
# Nets
|
||||||
|
net(1 name(VSS))
|
||||||
|
net(2 name(VDD))
|
||||||
|
net(3 name(FB))
|
||||||
|
net(4 name(ENABLE))
|
||||||
|
net(5 name(OUT))
|
||||||
|
net(6 name('1'))
|
||||||
|
net(7 name('2'))
|
||||||
|
net(8 name('3'))
|
||||||
|
net(9 name('4'))
|
||||||
|
net(10 name('5'))
|
||||||
|
net(11 name('6'))
|
||||||
|
net(12 name('7'))
|
||||||
|
net(13 name('8'))
|
||||||
|
net(14 name('9'))
|
||||||
|
net(15 name('10'))
|
||||||
|
|
||||||
|
# Outgoing pins and their connections to nets
|
||||||
|
pin(1)
|
||||||
|
pin(2)
|
||||||
|
pin(3)
|
||||||
|
pin(4)
|
||||||
|
pin(5)
|
||||||
|
|
||||||
|
# Subcircuits and their connections
|
||||||
|
circuit(1 ND2X1 name($1)
|
||||||
|
pin(0 2)
|
||||||
|
pin(1 6)
|
||||||
|
pin(2 1)
|
||||||
|
pin(3 2)
|
||||||
|
pin(4 3)
|
||||||
|
pin(5 4)
|
||||||
|
pin(6 1)
|
||||||
|
)
|
||||||
|
circuit(2 INVX1 name($2)
|
||||||
|
pin(0 2)
|
||||||
|
pin(1 7)
|
||||||
|
pin(2 1)
|
||||||
|
pin(3 2)
|
||||||
|
pin(4 6)
|
||||||
|
pin(5 1)
|
||||||
|
)
|
||||||
|
circuit(3 INVX1 name($3)
|
||||||
|
pin(0 2)
|
||||||
|
pin(1 8)
|
||||||
|
pin(2 1)
|
||||||
|
pin(3 2)
|
||||||
|
pin(4 7)
|
||||||
|
pin(5 1)
|
||||||
|
)
|
||||||
|
circuit(4 INVX1 name($4)
|
||||||
|
pin(0 2)
|
||||||
|
pin(1 9)
|
||||||
|
pin(2 1)
|
||||||
|
pin(3 2)
|
||||||
|
pin(4 8)
|
||||||
|
pin(5 1)
|
||||||
|
)
|
||||||
|
circuit(5 INVX1 name($5)
|
||||||
|
pin(0 2)
|
||||||
|
pin(1 10)
|
||||||
|
pin(2 1)
|
||||||
|
pin(3 2)
|
||||||
|
pin(4 9)
|
||||||
|
pin(5 1)
|
||||||
|
)
|
||||||
|
circuit(6 INVX1 name($6)
|
||||||
|
pin(0 2)
|
||||||
|
pin(1 11)
|
||||||
|
pin(2 1)
|
||||||
|
pin(3 2)
|
||||||
|
pin(4 10)
|
||||||
|
pin(5 1)
|
||||||
|
)
|
||||||
|
circuit(7 INVX1 name($7)
|
||||||
|
pin(0 2)
|
||||||
|
pin(1 12)
|
||||||
|
pin(2 1)
|
||||||
|
pin(3 2)
|
||||||
|
pin(4 11)
|
||||||
|
pin(5 1)
|
||||||
|
)
|
||||||
|
circuit(8 INVX1 name($8)
|
||||||
|
pin(0 2)
|
||||||
|
pin(1 13)
|
||||||
|
pin(2 1)
|
||||||
|
pin(3 2)
|
||||||
|
pin(4 12)
|
||||||
|
pin(5 1)
|
||||||
|
)
|
||||||
|
circuit(9 INVX1 name($9)
|
||||||
|
pin(0 2)
|
||||||
|
pin(1 14)
|
||||||
|
pin(2 1)
|
||||||
|
pin(3 2)
|
||||||
|
pin(4 13)
|
||||||
|
pin(5 1)
|
||||||
|
)
|
||||||
|
circuit(10 INVX1 name($10)
|
||||||
|
pin(0 2)
|
||||||
|
pin(1 15)
|
||||||
|
pin(2 1)
|
||||||
|
pin(3 2)
|
||||||
|
pin(4 14)
|
||||||
|
pin(5 1)
|
||||||
|
)
|
||||||
|
circuit(11 INVX1 name($11)
|
||||||
|
pin(0 2)
|
||||||
|
pin(1 3)
|
||||||
|
pin(2 1)
|
||||||
|
pin(3 2)
|
||||||
|
pin(4 15)
|
||||||
|
pin(5 1)
|
||||||
|
)
|
||||||
|
circuit(12 INVX1 name($12)
|
||||||
|
pin(0 2)
|
||||||
|
pin(1 5)
|
||||||
|
pin(2 1)
|
||||||
|
pin(3 2)
|
||||||
|
pin(4 3)
|
||||||
|
pin(5 1)
|
||||||
|
)
|
||||||
|
|
||||||
|
)
|
||||||
|
)
|
||||||
|
|
||||||
|
# Cross reference
|
||||||
|
xref(
|
||||||
|
circuit(INVX1 INVX1 match
|
||||||
|
xref(
|
||||||
|
net(4 4 match)
|
||||||
|
net(5 5 match)
|
||||||
|
net(2 2 match)
|
||||||
|
net(6 6 match)
|
||||||
|
net(1 1 match)
|
||||||
|
net(3 3 match)
|
||||||
|
pin(3 3 match)
|
||||||
|
pin(4 4 match)
|
||||||
|
pin(1 1 match)
|
||||||
|
pin(5 5 match)
|
||||||
|
pin(0 0 match)
|
||||||
|
pin(2 2 match)
|
||||||
|
device(1 1 match)
|
||||||
|
device(2 2 match)
|
||||||
|
)
|
||||||
|
)
|
||||||
|
circuit(ND2X1 ND2X1 match
|
||||||
|
xref(
|
||||||
|
net(8 8 match)
|
||||||
|
net(4 4 match)
|
||||||
|
net(6 5 match)
|
||||||
|
net(5 6 match)
|
||||||
|
net(2 2 match)
|
||||||
|
net(7 7 match)
|
||||||
|
net(1 1 match)
|
||||||
|
net(3 3 match)
|
||||||
|
pin(3 3 match)
|
||||||
|
pin(5 4 match)
|
||||||
|
pin(4 5 match)
|
||||||
|
pin(1 1 match)
|
||||||
|
pin(6 6 match)
|
||||||
|
pin(0 0 match)
|
||||||
|
pin(2 2 match)
|
||||||
|
device(1 1 match)
|
||||||
|
device(2 2 match)
|
||||||
|
device(3 3 match)
|
||||||
|
device(4 4 match)
|
||||||
|
)
|
||||||
|
)
|
||||||
|
circuit(RINGO RINGO match
|
||||||
|
xref(
|
||||||
|
net(1 6 match)
|
||||||
|
net(10 15 match)
|
||||||
|
net(2 7 match)
|
||||||
|
net(3 8 match)
|
||||||
|
net(4 9 match)
|
||||||
|
net(5 10 match)
|
||||||
|
net(6 11 match)
|
||||||
|
net(7 12 match)
|
||||||
|
net(8 13 match)
|
||||||
|
net(9 14 match)
|
||||||
|
net(14 4 match)
|
||||||
|
net(11 3 match)
|
||||||
|
net(13 5 match)
|
||||||
|
net(12 2 match)
|
||||||
|
net(15 1 mismatch)
|
||||||
|
pin(3 3 match)
|
||||||
|
pin(0 2 match)
|
||||||
|
pin(2 4 match)
|
||||||
|
pin(1 1 match)
|
||||||
|
pin(4 0 match)
|
||||||
|
circuit(1 1 match)
|
||||||
|
circuit(10 10 match)
|
||||||
|
circuit(11 11 match)
|
||||||
|
circuit(12 12 match)
|
||||||
|
circuit(2 2 match)
|
||||||
|
circuit(3 3 match)
|
||||||
|
circuit(4 4 match)
|
||||||
|
circuit(5 5 match)
|
||||||
|
circuit(6 6 match)
|
||||||
|
circuit(7 7 match)
|
||||||
|
circuit(8 8 match)
|
||||||
|
circuit(9 9 match)
|
||||||
|
)
|
||||||
|
)
|
||||||
|
)
|
||||||
|
|
@ -0,0 +1,31 @@
|
||||||
|
* Extracted by KLayout
|
||||||
|
|
||||||
|
.SUBCKT RINGO FB VDD OUT ENABLE VSS
|
||||||
|
X$1 VDD \$1 VSS VDD FB ENABLE VSS ND2X1
|
||||||
|
X$2 VDD \$2 VSS VDD \$1 VSS INVX1
|
||||||
|
X$3 VDD \$3 VSS VDD \$2 VSS INVX1
|
||||||
|
X$4 VDD \$4 VSS VDD \$3 VSS INVX1
|
||||||
|
X$5 VDD \$5 VSS VDD \$4 VSS INVX1
|
||||||
|
X$6 VDD \$6 VSS VDD \$5 VSS INVX1
|
||||||
|
X$7 VDD \$7 VSS VDD \$6 VSS INVX1
|
||||||
|
X$8 VDD \$8 VSS VDD \$7 VSS INVX1
|
||||||
|
X$9 VDD \$9 VSS VDD \$8 VSS INVX1
|
||||||
|
X$10 VDD \$10 VSS VDD \$9 VSS INVX1
|
||||||
|
X$11 VDD FB VSS VDD \$10 VSS INVX1
|
||||||
|
X$12 VDD OUT VSS VDD FB VSS INVX1
|
||||||
|
.ENDS RINGO
|
||||||
|
|
||||||
|
.SUBCKT INVX1 VDD OUT VSS \$4 IN SUBSTRATE
|
||||||
|
M$1 VDD IN OUT \$4 PM L=0.25U W=1.5U AS=0.6375P AD=0.6375P PS=3.85U PD=3.85U
|
||||||
|
M$2 VSS IN OUT SUBSTRATE NM L=0.25U W=0.95U AS=0.40375P AD=0.40375P PS=2.75U
|
||||||
|
+ PD=2.75U
|
||||||
|
.ENDS INVX1
|
||||||
|
|
||||||
|
.SUBCKT ND2X1 VDD OUT VSS \$4 B A SUBSTRATE
|
||||||
|
M$1 OUT A VDD \$4 PM L=0.25U W=1.5U AS=0.6375P AD=0.3375P PS=3.85U PD=1.95U
|
||||||
|
M$2 VDD B OUT \$4 PM L=0.25U W=1.5U AS=0.3375P AD=0.6375P PS=1.95U PD=3.85U
|
||||||
|
M$3 VSS A \$I3 SUBSTRATE NM L=0.25U W=0.95U AS=0.40375P AD=0.21375P PS=2.75U
|
||||||
|
+ PD=1.4U
|
||||||
|
M$4 \$I3 B OUT SUBSTRATE NM L=0.25U W=0.95U AS=0.21375P AD=0.40375P PS=1.4U
|
||||||
|
+ PD=2.75U
|
||||||
|
.ENDS ND2X1
|
||||||
|
|
@ -0,0 +1,78 @@
|
||||||
|
|
||||||
|
source($lvs_test_source, "RINGO")
|
||||||
|
|
||||||
|
report_lvs($lvs_test_target_lvsdb)
|
||||||
|
|
||||||
|
writer = write_spice(true, false)
|
||||||
|
target_netlist($lvs_test_target_cir, writer, "Extracted by KLayout")
|
||||||
|
|
||||||
|
schematic("ringo.cir")
|
||||||
|
|
||||||
|
deep
|
||||||
|
|
||||||
|
# Drawing layers
|
||||||
|
|
||||||
|
nwell = input(1, 0)
|
||||||
|
active = input(2, 0)
|
||||||
|
pplus = input(3, 0)
|
||||||
|
nplus = input(4, 0)
|
||||||
|
poly = input(5, 0)
|
||||||
|
contact = input(8, 0)
|
||||||
|
metal1 = input(9, 0)
|
||||||
|
via1 = input(10, 0)
|
||||||
|
metal2 = input(11, 0)
|
||||||
|
|
||||||
|
# Bulk layer for terminal provisioning
|
||||||
|
|
||||||
|
bulk = polygon_layer
|
||||||
|
|
||||||
|
# Computed layers
|
||||||
|
|
||||||
|
active_in_nwell = active & nwell
|
||||||
|
pactive = active_in_nwell & pplus
|
||||||
|
pgate = pactive & poly
|
||||||
|
psd = pactive - pgate
|
||||||
|
ntie = active_in_nwell & nplus
|
||||||
|
|
||||||
|
active_outside_nwell = active - nwell
|
||||||
|
nactive = active_outside_nwell & nplus
|
||||||
|
ngate = nactive & poly
|
||||||
|
nsd = nactive - ngate
|
||||||
|
ptie = active_outside_nwell & pplus
|
||||||
|
|
||||||
|
# Device extraction
|
||||||
|
|
||||||
|
# PMOS transistor device extraction
|
||||||
|
extract_devices(mos4("PM"), { "SD" => psd, "G" => pgate, "W" => nwell,
|
||||||
|
"tS" => psd, "tD" => psd, "tG" => poly, "tW" => nwell })
|
||||||
|
|
||||||
|
# NMOS transistor device extraction
|
||||||
|
extract_devices(mos4("NM"), { "SD" => nsd, "G" => ngate, "W" => bulk,
|
||||||
|
"tS" => nsd, "tD" => nsd, "tG" => poly, "tW" => bulk })
|
||||||
|
|
||||||
|
# Define connectivity for netlist extraction
|
||||||
|
|
||||||
|
# Inter-layer
|
||||||
|
connect(psd, contact)
|
||||||
|
connect(nsd, contact)
|
||||||
|
connect(poly, contact)
|
||||||
|
connect(ntie, contact)
|
||||||
|
connect(nwell, ntie)
|
||||||
|
connect(ptie, contact)
|
||||||
|
connect(contact, metal1)
|
||||||
|
connect(metal1, via1)
|
||||||
|
connect(via1, metal2)
|
||||||
|
|
||||||
|
# Global
|
||||||
|
connect_global(bulk, "SUBSTRATE")
|
||||||
|
connect_global(ptie, "SUBSTRATE")
|
||||||
|
|
||||||
|
# Compare section
|
||||||
|
|
||||||
|
netlist.simplify
|
||||||
|
|
||||||
|
same_device_classes("PM", "PMOS")
|
||||||
|
same_device_classes("NM", "NMOS")
|
||||||
|
|
||||||
|
compare
|
||||||
|
|
||||||
|
|
@ -0,0 +1,962 @@
|
||||||
|
#%lvsdb-klayout
|
||||||
|
|
||||||
|
# Layout
|
||||||
|
layout(
|
||||||
|
top(RINGO)
|
||||||
|
unit(0.001)
|
||||||
|
|
||||||
|
# Layer section
|
||||||
|
# This section lists the mask layers (drawing or derived) and their connections.
|
||||||
|
|
||||||
|
# Mask layers
|
||||||
|
layer(l3 '1/0')
|
||||||
|
layer(l4 '5/0')
|
||||||
|
layer(l8 '8/0')
|
||||||
|
layer(l11 '9/0')
|
||||||
|
layer(l12 '10/0')
|
||||||
|
layer(l13 '11/0')
|
||||||
|
layer(l7)
|
||||||
|
layer(l1)
|
||||||
|
layer(l9)
|
||||||
|
layer(l5)
|
||||||
|
layer(l10)
|
||||||
|
|
||||||
|
# Mask layer connectivity
|
||||||
|
connect(l3 l3 l9)
|
||||||
|
connect(l4 l4 l8)
|
||||||
|
connect(l8 l4 l8 l11 l1 l9 l5 l10)
|
||||||
|
connect(l11 l8 l11 l12)
|
||||||
|
connect(l12 l11 l12 l13)
|
||||||
|
connect(l13 l12 l13)
|
||||||
|
connect(l7 l7)
|
||||||
|
connect(l1 l8 l1)
|
||||||
|
connect(l9 l3 l8 l9)
|
||||||
|
connect(l5 l8 l5)
|
||||||
|
connect(l10 l8 l10)
|
||||||
|
|
||||||
|
# Global nets and connectivity
|
||||||
|
global(l7 SUBSTRATE)
|
||||||
|
global(l10 SUBSTRATE)
|
||||||
|
|
||||||
|
# Device class section
|
||||||
|
class(PM MOS4)
|
||||||
|
class(NM MOS4)
|
||||||
|
|
||||||
|
# Device abstracts section
|
||||||
|
# Device abstracts list the pin shapes of the devices.
|
||||||
|
device(D$PM PM
|
||||||
|
terminal(S
|
||||||
|
rect(l1 (-550 -750) (425 1500))
|
||||||
|
)
|
||||||
|
terminal(G
|
||||||
|
rect(l4 (-125 -750) (250 1500))
|
||||||
|
)
|
||||||
|
terminal(D
|
||||||
|
rect(l1 (125 -750) (450 1500))
|
||||||
|
)
|
||||||
|
terminal(B
|
||||||
|
rect(l3 (-125 -750) (250 1500))
|
||||||
|
)
|
||||||
|
)
|
||||||
|
device(D$PM$1 PM
|
||||||
|
terminal(S
|
||||||
|
rect(l1 (-575 -750) (450 1500))
|
||||||
|
)
|
||||||
|
terminal(G
|
||||||
|
rect(l4 (-125 -750) (250 1500))
|
||||||
|
)
|
||||||
|
terminal(D
|
||||||
|
rect(l1 (125 -750) (425 1500))
|
||||||
|
)
|
||||||
|
terminal(B
|
||||||
|
rect(l3 (-125 -750) (250 1500))
|
||||||
|
)
|
||||||
|
)
|
||||||
|
device(D$PM$2 PM
|
||||||
|
terminal(S
|
||||||
|
rect(l1 (-550 -750) (425 1500))
|
||||||
|
)
|
||||||
|
terminal(G
|
||||||
|
rect(l4 (-125 -750) (250 1500))
|
||||||
|
)
|
||||||
|
terminal(D
|
||||||
|
rect(l1 (125 -750) (425 1500))
|
||||||
|
)
|
||||||
|
terminal(B
|
||||||
|
rect(l3 (-125 -750) (250 1500))
|
||||||
|
)
|
||||||
|
)
|
||||||
|
device(D$NM NM
|
||||||
|
terminal(S
|
||||||
|
rect(l5 (-550 -475) (425 950))
|
||||||
|
)
|
||||||
|
terminal(G
|
||||||
|
rect(l4 (-125 -475) (250 950))
|
||||||
|
)
|
||||||
|
terminal(D
|
||||||
|
rect(l5 (125 -475) (450 950))
|
||||||
|
)
|
||||||
|
terminal(B
|
||||||
|
rect(l7 (-125 -475) (250 950))
|
||||||
|
)
|
||||||
|
)
|
||||||
|
device(D$NM$1 NM
|
||||||
|
terminal(S
|
||||||
|
rect(l5 (-575 -475) (450 950))
|
||||||
|
)
|
||||||
|
terminal(G
|
||||||
|
rect(l4 (-125 -475) (250 950))
|
||||||
|
)
|
||||||
|
terminal(D
|
||||||
|
rect(l5 (125 -475) (425 950))
|
||||||
|
)
|
||||||
|
terminal(B
|
||||||
|
rect(l7 (-125 -475) (250 950))
|
||||||
|
)
|
||||||
|
)
|
||||||
|
device(D$NM$2 NM
|
||||||
|
terminal(S
|
||||||
|
rect(l5 (-550 -475) (425 950))
|
||||||
|
)
|
||||||
|
terminal(G
|
||||||
|
rect(l4 (-125 -475) (250 950))
|
||||||
|
)
|
||||||
|
terminal(D
|
||||||
|
rect(l5 (125 -475) (425 950))
|
||||||
|
)
|
||||||
|
terminal(B
|
||||||
|
rect(l7 (-125 -475) (250 950))
|
||||||
|
)
|
||||||
|
)
|
||||||
|
|
||||||
|
# Circuit section
|
||||||
|
# Circuits are the hierarchical building blocks of the netlist.
|
||||||
|
circuit(ND2X1
|
||||||
|
|
||||||
|
# Nets with their geometries
|
||||||
|
net(1 name(VDD)
|
||||||
|
rect(l8 (1110 5160) (180 180))
|
||||||
|
rect(l8 (-180 920) (180 180))
|
||||||
|
rect(l8 (-180 -730) (180 180))
|
||||||
|
rect(l11 (-240 -790) (300 1700))
|
||||||
|
rect(l11 (-1350 0) (2400 800))
|
||||||
|
rect(l11 (-1151 -401) (2 2))
|
||||||
|
rect(l1 (-276 -2151) (425 1500))
|
||||||
|
rect(l1 (-400 -1500) (425 1500))
|
||||||
|
)
|
||||||
|
net(2 name(OUT)
|
||||||
|
rect(l8 (1810 1770) (180 180))
|
||||||
|
rect(l8 (-180 370) (180 180))
|
||||||
|
rect(l8 (-1580 3760) (180 180))
|
||||||
|
rect(l8 (-180 -730) (180 180))
|
||||||
|
rect(l8 (-180 -730) (180 180))
|
||||||
|
rect(l8 (1220 920) (180 180))
|
||||||
|
rect(l8 (-180 -1280) (180 180))
|
||||||
|
rect(l8 (-180 370) (180 180))
|
||||||
|
polygon(l11 (-240 -4180) (0 1390) (490 0) (0 -300) (-190 0) (0 -1090))
|
||||||
|
rect(l11 (-110 1390) (300 1400))
|
||||||
|
polygon(l11 (-1890 0) (0 600) (300 0) (0 -300) (1590 0) (0 -300))
|
||||||
|
rect(l11 (-141 -501) (2 2))
|
||||||
|
rect(l11 (-1751 1099) (300 1400))
|
||||||
|
rect(l11 (1100 -1700) (300 300))
|
||||||
|
rect(l11 (-300 0) (300 1400))
|
||||||
|
rect(l1 (-1750 -1450) (425 1500))
|
||||||
|
rect(l1 (950 -1500) (425 1500))
|
||||||
|
rect(l5 (-425 -4890) (425 950))
|
||||||
|
)
|
||||||
|
net(3 name(VSS)
|
||||||
|
rect(l8 (410 1770) (180 180))
|
||||||
|
rect(l8 (-180 370) (180 180))
|
||||||
|
rect(l11 (-240 -1300) (300 1360))
|
||||||
|
rect(l11 (-650 -2160) (2400 800))
|
||||||
|
rect(l11 (-1151 -401) (2 2))
|
||||||
|
rect(l5 (-951 859) (425 950))
|
||||||
|
)
|
||||||
|
net(4
|
||||||
|
rect(l3 (-100 4500) (2600 3500))
|
||||||
|
)
|
||||||
|
net(5 name(B)
|
||||||
|
rect(l4 (1425 2860) (250 1940))
|
||||||
|
rect(l4 (-345 -950) (300 300))
|
||||||
|
rect(l4 (-205 650) (250 2000))
|
||||||
|
rect(l4 (-250 -2000) (250 2000))
|
||||||
|
rect(l4 (-250 -5390) (250 1450))
|
||||||
|
rect(l8 (-285 1050) (180 180))
|
||||||
|
rect(l11 (-71 -91) (2 2))
|
||||||
|
rect(l11 (-171 -151) (300 300))
|
||||||
|
)
|
||||||
|
net(6 name(A)
|
||||||
|
rect(l4 (725 2860) (250 1940))
|
||||||
|
rect(l4 (-325 -1850) (300 300))
|
||||||
|
rect(l4 (-225 1550) (250 2000))
|
||||||
|
rect(l4 (-250 -2000) (250 2000))
|
||||||
|
rect(l4 (-250 -5390) (250 1450))
|
||||||
|
rect(l8 (-265 150) (180 180))
|
||||||
|
rect(l11 (-91 -91) (2 2))
|
||||||
|
rect(l11 (-151 -151) (300 300))
|
||||||
|
)
|
||||||
|
net(7 name(SUBSTRATE))
|
||||||
|
net(8
|
||||||
|
rect(l5 (975 1660) (425 950))
|
||||||
|
rect(l5 (-400 -950) (425 950))
|
||||||
|
)
|
||||||
|
|
||||||
|
# Outgoing pins and their connections to nets
|
||||||
|
pin(1 name(VDD))
|
||||||
|
pin(2 name(OUT))
|
||||||
|
pin(3 name(VSS))
|
||||||
|
pin(4)
|
||||||
|
pin(5 name(B))
|
||||||
|
pin(6 name(A))
|
||||||
|
pin(7 name(SUBSTRATE))
|
||||||
|
|
||||||
|
# Devices and their connections
|
||||||
|
device(1 D$PM
|
||||||
|
location(850 5800)
|
||||||
|
param(L 0.25)
|
||||||
|
param(W 1.5)
|
||||||
|
param(AS 0.6375)
|
||||||
|
param(AD 0.3375)
|
||||||
|
param(PS 3.85)
|
||||||
|
param(PD 1.95)
|
||||||
|
terminal(S 2)
|
||||||
|
terminal(G 6)
|
||||||
|
terminal(D 1)
|
||||||
|
terminal(B 4)
|
||||||
|
)
|
||||||
|
device(2 D$PM$1
|
||||||
|
location(1550 5800)
|
||||||
|
param(L 0.25)
|
||||||
|
param(W 1.5)
|
||||||
|
param(AS 0.3375)
|
||||||
|
param(AD 0.6375)
|
||||||
|
param(PS 1.95)
|
||||||
|
param(PD 3.85)
|
||||||
|
terminal(S 1)
|
||||||
|
terminal(G 5)
|
||||||
|
terminal(D 2)
|
||||||
|
terminal(B 4)
|
||||||
|
)
|
||||||
|
device(3 D$NM
|
||||||
|
location(850 2135)
|
||||||
|
param(L 0.25)
|
||||||
|
param(W 0.95)
|
||||||
|
param(AS 0.40375)
|
||||||
|
param(AD 0.21375)
|
||||||
|
param(PS 2.75)
|
||||||
|
param(PD 1.4)
|
||||||
|
terminal(S 3)
|
||||||
|
terminal(G 6)
|
||||||
|
terminal(D 8)
|
||||||
|
terminal(B 7)
|
||||||
|
)
|
||||||
|
device(4 D$NM$1
|
||||||
|
location(1550 2135)
|
||||||
|
param(L 0.25)
|
||||||
|
param(W 0.95)
|
||||||
|
param(AS 0.21375)
|
||||||
|
param(AD 0.40375)
|
||||||
|
param(PS 1.4)
|
||||||
|
param(PD 2.75)
|
||||||
|
terminal(S 8)
|
||||||
|
terminal(G 5)
|
||||||
|
terminal(D 2)
|
||||||
|
terminal(B 7)
|
||||||
|
)
|
||||||
|
|
||||||
|
)
|
||||||
|
circuit(INVX1
|
||||||
|
|
||||||
|
# Nets with their geometries
|
||||||
|
net(1 name(VDD)
|
||||||
|
rect(l8 (410 6260) (180 180))
|
||||||
|
rect(l8 (-180 -730) (180 180))
|
||||||
|
rect(l8 (-180 -730) (180 180))
|
||||||
|
rect(l11 (-240 -240) (300 1400))
|
||||||
|
rect(l11 (-650 300) (1800 800))
|
||||||
|
rect(l11 (-1450 -1100) (300 300))
|
||||||
|
rect(l11 (299 399) (2 2))
|
||||||
|
rect(l1 (-651 -2151) (425 1500))
|
||||||
|
)
|
||||||
|
net(2 name(OUT)
|
||||||
|
rect(l8 (1110 5160) (180 180))
|
||||||
|
rect(l8 (-180 920) (180 180))
|
||||||
|
rect(l8 (-180 -730) (180 180))
|
||||||
|
rect(l8 (-180 -4120) (180 180))
|
||||||
|
rect(l8 (-180 370) (180 180))
|
||||||
|
rect(l11 (-240 -790) (300 4790))
|
||||||
|
rect(l11 (-151 -2501) (2 2))
|
||||||
|
rect(l1 (-226 1049) (425 1500))
|
||||||
|
rect(l5 (-425 -4890) (425 950))
|
||||||
|
)
|
||||||
|
net(3 name(VSS)
|
||||||
|
rect(l8 (410 1770) (180 180))
|
||||||
|
rect(l8 (-180 370) (180 180))
|
||||||
|
rect(l11 (-240 -1300) (300 1360))
|
||||||
|
rect(l11 (-650 -2160) (1800 800))
|
||||||
|
rect(l11 (-851 -401) (2 2))
|
||||||
|
rect(l5 (-651 859) (425 950))
|
||||||
|
)
|
||||||
|
net(4
|
||||||
|
rect(l3 (-100 4500) (2000 3500))
|
||||||
|
)
|
||||||
|
net(5 name(IN)
|
||||||
|
rect(l4 (725 2860) (250 1940))
|
||||||
|
rect(l4 (-525 -1850) (300 300))
|
||||||
|
rect(l4 (-25 1550) (250 2000))
|
||||||
|
rect(l4 (-250 -2000) (250 2000))
|
||||||
|
rect(l4 (-250 -5390) (250 1450))
|
||||||
|
rect(l8 (-465 150) (180 180))
|
||||||
|
rect(l11 (-91 -91) (2 2))
|
||||||
|
rect(l11 (-151 -151) (300 300))
|
||||||
|
)
|
||||||
|
net(6 name(SUBSTRATE))
|
||||||
|
|
||||||
|
# Outgoing pins and their connections to nets
|
||||||
|
pin(1 name(VDD))
|
||||||
|
pin(2 name(OUT))
|
||||||
|
pin(3 name(VSS))
|
||||||
|
pin(4)
|
||||||
|
pin(5 name(IN))
|
||||||
|
pin(6 name(SUBSTRATE))
|
||||||
|
|
||||||
|
# Devices and their connections
|
||||||
|
device(1 D$PM$2
|
||||||
|
location(850 5800)
|
||||||
|
param(L 0.25)
|
||||||
|
param(W 1.5)
|
||||||
|
param(AS 0.6375)
|
||||||
|
param(AD 0.6375)
|
||||||
|
param(PS 3.85)
|
||||||
|
param(PD 3.85)
|
||||||
|
terminal(S 1)
|
||||||
|
terminal(G 5)
|
||||||
|
terminal(D 2)
|
||||||
|
terminal(B 4)
|
||||||
|
)
|
||||||
|
device(2 D$NM$2
|
||||||
|
location(850 2135)
|
||||||
|
param(L 0.25)
|
||||||
|
param(W 0.95)
|
||||||
|
param(AS 0.40375)
|
||||||
|
param(AD 0.40375)
|
||||||
|
param(PS 2.75)
|
||||||
|
param(PD 2.75)
|
||||||
|
terminal(S 3)
|
||||||
|
terminal(G 5)
|
||||||
|
terminal(D 2)
|
||||||
|
terminal(B 6)
|
||||||
|
)
|
||||||
|
|
||||||
|
)
|
||||||
|
circuit(RINGO
|
||||||
|
|
||||||
|
# Nets with their geometries
|
||||||
|
net(1
|
||||||
|
rect(l8 (4710 3010) (180 180))
|
||||||
|
rect(l11 (-850 -240) (610 300))
|
||||||
|
rect(l1 (-2550 1800) (425 1500))
|
||||||
|
rect(l1 (950 -1500) (425 1500))
|
||||||
|
rect(l5 (-425 -4890) (425 950))
|
||||||
|
)
|
||||||
|
net(2
|
||||||
|
rect(l8 (6510 3010) (180 180))
|
||||||
|
rect(l11 (-1140 -240) (900 300))
|
||||||
|
rect(l1 (-1275 1800) (425 1500))
|
||||||
|
rect(l5 (-425 -4890) (425 950))
|
||||||
|
)
|
||||||
|
net(3
|
||||||
|
rect(l8 (8310 3010) (180 180))
|
||||||
|
rect(l11 (-1140 -240) (900 300))
|
||||||
|
rect(l1 (-1275 1800) (425 1500))
|
||||||
|
rect(l5 (-425 -4890) (425 950))
|
||||||
|
)
|
||||||
|
net(4
|
||||||
|
rect(l8 (10110 3010) (180 180))
|
||||||
|
rect(l11 (-1140 -240) (900 300))
|
||||||
|
rect(l1 (-1275 1800) (425 1500))
|
||||||
|
rect(l5 (-425 -4890) (425 950))
|
||||||
|
)
|
||||||
|
net(5
|
||||||
|
rect(l8 (11910 3010) (180 180))
|
||||||
|
rect(l11 (-1140 -240) (900 300))
|
||||||
|
rect(l1 (-1275 1800) (425 1500))
|
||||||
|
rect(l5 (-425 -4890) (425 950))
|
||||||
|
)
|
||||||
|
net(6
|
||||||
|
rect(l8 (13710 3010) (180 180))
|
||||||
|
rect(l11 (-1140 -240) (900 300))
|
||||||
|
rect(l1 (-1275 1800) (425 1500))
|
||||||
|
rect(l5 (-425 -4890) (425 950))
|
||||||
|
)
|
||||||
|
net(7
|
||||||
|
rect(l8 (15510 3010) (180 180))
|
||||||
|
rect(l11 (-1140 -240) (900 300))
|
||||||
|
rect(l1 (-1275 1800) (425 1500))
|
||||||
|
rect(l5 (-425 -4890) (425 950))
|
||||||
|
)
|
||||||
|
net(8
|
||||||
|
rect(l8 (17310 3010) (180 180))
|
||||||
|
rect(l11 (-1140 -240) (900 300))
|
||||||
|
rect(l1 (-1275 1800) (425 1500))
|
||||||
|
rect(l5 (-425 -4890) (425 950))
|
||||||
|
)
|
||||||
|
net(9
|
||||||
|
rect(l8 (19110 3010) (180 180))
|
||||||
|
rect(l11 (-1140 -240) (900 300))
|
||||||
|
rect(l1 (-1275 1800) (425 1500))
|
||||||
|
rect(l5 (-425 -4890) (425 950))
|
||||||
|
)
|
||||||
|
net(10
|
||||||
|
rect(l8 (20910 3010) (180 180))
|
||||||
|
rect(l11 (-1140 -240) (900 300))
|
||||||
|
rect(l1 (-1275 1800) (425 1500))
|
||||||
|
rect(l5 (-425 -4890) (425 950))
|
||||||
|
)
|
||||||
|
net(11 name(FB)
|
||||||
|
rect(l8 (22710 3010) (180 180))
|
||||||
|
rect(l8 (-19700 720) (180 180))
|
||||||
|
rect(l11 (18380 -1140) (900 300))
|
||||||
|
rect(l11 (-19530 590) (320 320))
|
||||||
|
rect(l11 (17820 -320) (320 320))
|
||||||
|
rect(l12 (-18400 -260) (200 200))
|
||||||
|
rect(l12 (17940 -200) (200 200))
|
||||||
|
rect(l13 (-18040 -300) (17740 400))
|
||||||
|
rect(l13 (-17921 -201) (2 2))
|
||||||
|
rect(l13 (-221 -201) (400 400))
|
||||||
|
rect(l13 (17740 -400) (400 400))
|
||||||
|
rect(l1 (-245 850) (425 1500))
|
||||||
|
rect(l5 (-425 -4890) (425 950))
|
||||||
|
)
|
||||||
|
net(12 name(VDD)
|
||||||
|
rect(l3 (500 4500) (1400 3500))
|
||||||
|
rect(l3 (-1900 -3500) (600 3500))
|
||||||
|
rect(l3 (23300 -3500) (1400 3500))
|
||||||
|
rect(l3 (-100 -3500) (600 3500))
|
||||||
|
rect(l8 (-24690 -1240) (180 180))
|
||||||
|
rect(l8 (-180 370) (180 180))
|
||||||
|
rect(l8 (-180 -1280) (180 180))
|
||||||
|
rect(l8 (23220 370) (180 180))
|
||||||
|
rect(l8 (-180 370) (180 180))
|
||||||
|
rect(l8 (-180 -1280) (180 180))
|
||||||
|
rect(l11 (-21741 859) (2 2))
|
||||||
|
rect(l11 (-2351 -451) (1200 800))
|
||||||
|
rect(l11 (-750 -1450) (300 1400))
|
||||||
|
rect(l11 (-101 -351) (2 2))
|
||||||
|
rect(l11 (-1251 -401) (600 800))
|
||||||
|
rect(l11 (23400 -800) (1200 800))
|
||||||
|
rect(l11 (-750 -1450) (300 1400))
|
||||||
|
rect(l11 (-101 -351) (2 2))
|
||||||
|
rect(l11 (549 -401) (600 800))
|
||||||
|
rect(l1 (-23025 -2550) (425 1500))
|
||||||
|
rect(l1 (-400 -1500) (425 1500))
|
||||||
|
rect(l1 (1275 -1500) (425 1500))
|
||||||
|
rect(l1 (1375 -1500) (425 1500))
|
||||||
|
rect(l1 (1375 -1500) (425 1500))
|
||||||
|
rect(l1 (1375 -1500) (425 1500))
|
||||||
|
rect(l1 (1375 -1500) (425 1500))
|
||||||
|
rect(l1 (1375 -1500) (425 1500))
|
||||||
|
rect(l1 (1375 -1500) (425 1500))
|
||||||
|
rect(l1 (1375 -1500) (425 1500))
|
||||||
|
rect(l1 (1375 -1500) (425 1500))
|
||||||
|
rect(l1 (1375 -1500) (425 1500))
|
||||||
|
rect(l1 (1375 -1500) (425 1500))
|
||||||
|
rect(l9 (-21975 -450) (500 1500))
|
||||||
|
rect(l9 (22900 -1500) (500 1500))
|
||||||
|
)
|
||||||
|
net(13 name(OUT)
|
||||||
|
rect(l11 (23440 3840) (320 320))
|
||||||
|
rect(l12 (-260 -260) (200 200))
|
||||||
|
rect(l13 (-101 -101) (2 2))
|
||||||
|
rect(l13 (-201 -201) (400 400))
|
||||||
|
rect(l1 (-625 850) (425 1500))
|
||||||
|
rect(l5 (-425 -4890) (425 950))
|
||||||
|
)
|
||||||
|
net(14 name(ENABLE)
|
||||||
|
rect(l8 (2510 3010) (180 180))
|
||||||
|
rect(l11 (-250 -250) (320 320))
|
||||||
|
rect(l12 (-260 -260) (200 200))
|
||||||
|
rect(l13 (-101 -101) (2 2))
|
||||||
|
rect(l13 (-201 -201) (400 400))
|
||||||
|
)
|
||||||
|
net(15 name(VSS)
|
||||||
|
rect(l8 (1110 1610) (180 180))
|
||||||
|
rect(l8 (-180 -1280) (180 180))
|
||||||
|
rect(l8 (-180 370) (180 180))
|
||||||
|
rect(l8 (23220 370) (180 180))
|
||||||
|
rect(l8 (-180 -1280) (180 180))
|
||||||
|
rect(l8 (-180 370) (180 180))
|
||||||
|
rect(l11 (-21741 -391) (2 2))
|
||||||
|
rect(l11 (-1901 -401) (300 1400))
|
||||||
|
rect(l11 (-750 -1450) (1200 800))
|
||||||
|
rect(l11 (-551 -401) (2 2))
|
||||||
|
rect(l11 (-1251 -401) (600 800))
|
||||||
|
rect(l11 (23850 -750) (300 1400))
|
||||||
|
rect(l11 (-750 -1450) (1200 800))
|
||||||
|
rect(l11 (-551 -401) (2 2))
|
||||||
|
rect(l11 (549 -401) (600 800))
|
||||||
|
rect(l5 (-23700 460) (425 950))
|
||||||
|
rect(l5 (1975 -950) (425 950))
|
||||||
|
rect(l5 (1375 -950) (425 950))
|
||||||
|
rect(l5 (1375 -950) (425 950))
|
||||||
|
rect(l5 (1375 -950) (425 950))
|
||||||
|
rect(l5 (1375 -950) (425 950))
|
||||||
|
rect(l5 (1375 -950) (425 950))
|
||||||
|
rect(l5 (1375 -950) (425 950))
|
||||||
|
rect(l5 (1375 -950) (425 950))
|
||||||
|
rect(l5 (1375 -950) (425 950))
|
||||||
|
rect(l5 (1375 -950) (425 950))
|
||||||
|
rect(l5 (1375 -950) (425 950))
|
||||||
|
rect(l10 (-21975 -2210) (500 1500))
|
||||||
|
rect(l10 (22900 -1500) (500 1500))
|
||||||
|
)
|
||||||
|
|
||||||
|
# Outgoing pins and their connections to nets
|
||||||
|
pin(11 name(FB))
|
||||||
|
pin(12 name(VDD))
|
||||||
|
pin(13 name(OUT))
|
||||||
|
pin(14 name(ENABLE))
|
||||||
|
pin(15 name(VSS))
|
||||||
|
|
||||||
|
# Subcircuits and their connections
|
||||||
|
circuit(1 ND2X1 location(1800 0)
|
||||||
|
pin(0 12)
|
||||||
|
pin(1 1)
|
||||||
|
pin(2 15)
|
||||||
|
pin(3 12)
|
||||||
|
pin(4 11)
|
||||||
|
pin(5 14)
|
||||||
|
pin(6 15)
|
||||||
|
)
|
||||||
|
circuit(2 INVX1 location(4200 0)
|
||||||
|
pin(0 12)
|
||||||
|
pin(1 2)
|
||||||
|
pin(2 15)
|
||||||
|
pin(3 12)
|
||||||
|
pin(4 1)
|
||||||
|
pin(5 15)
|
||||||
|
)
|
||||||
|
circuit(3 INVX1 location(6000 0)
|
||||||
|
pin(0 12)
|
||||||
|
pin(1 3)
|
||||||
|
pin(2 15)
|
||||||
|
pin(3 12)
|
||||||
|
pin(4 2)
|
||||||
|
pin(5 15)
|
||||||
|
)
|
||||||
|
circuit(4 INVX1 location(7800 0)
|
||||||
|
pin(0 12)
|
||||||
|
pin(1 4)
|
||||||
|
pin(2 15)
|
||||||
|
pin(3 12)
|
||||||
|
pin(4 3)
|
||||||
|
pin(5 15)
|
||||||
|
)
|
||||||
|
circuit(5 INVX1 location(9600 0)
|
||||||
|
pin(0 12)
|
||||||
|
pin(1 5)
|
||||||
|
pin(2 15)
|
||||||
|
pin(3 12)
|
||||||
|
pin(4 4)
|
||||||
|
pin(5 15)
|
||||||
|
)
|
||||||
|
circuit(6 INVX1 location(11400 0)
|
||||||
|
pin(0 12)
|
||||||
|
pin(1 6)
|
||||||
|
pin(2 15)
|
||||||
|
pin(3 12)
|
||||||
|
pin(4 5)
|
||||||
|
pin(5 15)
|
||||||
|
)
|
||||||
|
circuit(7 INVX1 location(13200 0)
|
||||||
|
pin(0 12)
|
||||||
|
pin(1 7)
|
||||||
|
pin(2 15)
|
||||||
|
pin(3 12)
|
||||||
|
pin(4 6)
|
||||||
|
pin(5 15)
|
||||||
|
)
|
||||||
|
circuit(8 INVX1 location(15000 0)
|
||||||
|
pin(0 12)
|
||||||
|
pin(1 8)
|
||||||
|
pin(2 15)
|
||||||
|
pin(3 12)
|
||||||
|
pin(4 7)
|
||||||
|
pin(5 15)
|
||||||
|
)
|
||||||
|
circuit(9 INVX1 location(16800 0)
|
||||||
|
pin(0 12)
|
||||||
|
pin(1 9)
|
||||||
|
pin(2 15)
|
||||||
|
pin(3 12)
|
||||||
|
pin(4 8)
|
||||||
|
pin(5 15)
|
||||||
|
)
|
||||||
|
circuit(10 INVX1 location(18600 0)
|
||||||
|
pin(0 12)
|
||||||
|
pin(1 10)
|
||||||
|
pin(2 15)
|
||||||
|
pin(3 12)
|
||||||
|
pin(4 9)
|
||||||
|
pin(5 15)
|
||||||
|
)
|
||||||
|
circuit(11 INVX1 location(20400 0)
|
||||||
|
pin(0 12)
|
||||||
|
pin(1 11)
|
||||||
|
pin(2 15)
|
||||||
|
pin(3 12)
|
||||||
|
pin(4 10)
|
||||||
|
pin(5 15)
|
||||||
|
)
|
||||||
|
circuit(12 INVX1 location(22200 0)
|
||||||
|
pin(0 12)
|
||||||
|
pin(1 13)
|
||||||
|
pin(2 15)
|
||||||
|
pin(3 12)
|
||||||
|
pin(4 11)
|
||||||
|
pin(5 15)
|
||||||
|
)
|
||||||
|
|
||||||
|
)
|
||||||
|
)
|
||||||
|
|
||||||
|
# Reference netlist
|
||||||
|
reference(
|
||||||
|
|
||||||
|
# Device class section
|
||||||
|
class(PMOS MOS4)
|
||||||
|
class(NMOS MOS4)
|
||||||
|
|
||||||
|
# Circuit section
|
||||||
|
# Circuits are the hierarchical building blocks of the netlist.
|
||||||
|
circuit(ND2X1
|
||||||
|
|
||||||
|
# Nets
|
||||||
|
net(1 name(VDD))
|
||||||
|
net(2 name(OUT))
|
||||||
|
net(3 name(VSS))
|
||||||
|
net(4 name(NWELL))
|
||||||
|
net(5 name(B))
|
||||||
|
net(6 name(A))
|
||||||
|
net(7 name(BULK))
|
||||||
|
net(8 name('1'))
|
||||||
|
|
||||||
|
# Outgoing pins and their connections to nets
|
||||||
|
pin(1)
|
||||||
|
pin(2)
|
||||||
|
pin(3)
|
||||||
|
pin(4)
|
||||||
|
pin(5)
|
||||||
|
pin(6)
|
||||||
|
pin(7)
|
||||||
|
|
||||||
|
# Devices and their connections
|
||||||
|
device(1 PMOS
|
||||||
|
name($1)
|
||||||
|
param(L 0.25)
|
||||||
|
param(W 1.5)
|
||||||
|
param(AS 0)
|
||||||
|
param(AD 0)
|
||||||
|
param(PS 0)
|
||||||
|
param(PD 0)
|
||||||
|
terminal(S 2)
|
||||||
|
terminal(G 6)
|
||||||
|
terminal(D 1)
|
||||||
|
terminal(B 4)
|
||||||
|
)
|
||||||
|
device(2 PMOS
|
||||||
|
name($2)
|
||||||
|
param(L 0.25)
|
||||||
|
param(W 1.5)
|
||||||
|
param(AS 0)
|
||||||
|
param(AD 0)
|
||||||
|
param(PS 0)
|
||||||
|
param(PD 0)
|
||||||
|
terminal(S 1)
|
||||||
|
terminal(G 5)
|
||||||
|
terminal(D 2)
|
||||||
|
terminal(B 4)
|
||||||
|
)
|
||||||
|
device(3 NMOS
|
||||||
|
name($3)
|
||||||
|
param(L 0.25)
|
||||||
|
param(W 0.95)
|
||||||
|
param(AS 0)
|
||||||
|
param(AD 0)
|
||||||
|
param(PS 0)
|
||||||
|
param(PD 0)
|
||||||
|
terminal(S 3)
|
||||||
|
terminal(G 6)
|
||||||
|
terminal(D 8)
|
||||||
|
terminal(B 7)
|
||||||
|
)
|
||||||
|
device(4 NMOS
|
||||||
|
name($4)
|
||||||
|
param(L 0.25)
|
||||||
|
param(W 0.95)
|
||||||
|
param(AS 0)
|
||||||
|
param(AD 0)
|
||||||
|
param(PS 0)
|
||||||
|
param(PD 0)
|
||||||
|
terminal(S 8)
|
||||||
|
terminal(G 5)
|
||||||
|
terminal(D 2)
|
||||||
|
terminal(B 7)
|
||||||
|
)
|
||||||
|
|
||||||
|
)
|
||||||
|
circuit(INVX1
|
||||||
|
|
||||||
|
# Nets
|
||||||
|
net(1 name(VDD))
|
||||||
|
net(2 name(OUT))
|
||||||
|
net(3 name(VSS))
|
||||||
|
net(4 name(NWELL))
|
||||||
|
net(5 name(IN))
|
||||||
|
net(6 name(BULK))
|
||||||
|
|
||||||
|
# Outgoing pins and their connections to nets
|
||||||
|
pin(1)
|
||||||
|
pin(2)
|
||||||
|
pin(3)
|
||||||
|
pin(4)
|
||||||
|
pin(5)
|
||||||
|
pin(6)
|
||||||
|
|
||||||
|
# Devices and their connections
|
||||||
|
device(1 PMOS
|
||||||
|
name($1)
|
||||||
|
param(L 0.25)
|
||||||
|
param(W 1.5)
|
||||||
|
param(AS 0)
|
||||||
|
param(AD 0)
|
||||||
|
param(PS 0)
|
||||||
|
param(PD 0)
|
||||||
|
terminal(S 1)
|
||||||
|
terminal(G 5)
|
||||||
|
terminal(D 2)
|
||||||
|
terminal(B 4)
|
||||||
|
)
|
||||||
|
device(2 NMOS
|
||||||
|
name($2)
|
||||||
|
param(L 0.25)
|
||||||
|
param(W 0.95)
|
||||||
|
param(AS 0)
|
||||||
|
param(AD 0)
|
||||||
|
param(PS 0)
|
||||||
|
param(PD 0)
|
||||||
|
terminal(S 3)
|
||||||
|
terminal(G 5)
|
||||||
|
terminal(D 2)
|
||||||
|
terminal(B 6)
|
||||||
|
)
|
||||||
|
|
||||||
|
)
|
||||||
|
circuit(RINGO
|
||||||
|
|
||||||
|
# Nets
|
||||||
|
net(1 name(VSS))
|
||||||
|
net(2 name(VDD))
|
||||||
|
net(3 name(FB))
|
||||||
|
net(4 name(ENABLE))
|
||||||
|
net(5 name(OUT))
|
||||||
|
net(6 name('1'))
|
||||||
|
net(7 name('2'))
|
||||||
|
net(8 name('3'))
|
||||||
|
net(9 name('4'))
|
||||||
|
net(10 name('5'))
|
||||||
|
net(11 name('6'))
|
||||||
|
net(12 name('7'))
|
||||||
|
net(13 name('8'))
|
||||||
|
net(14 name('9'))
|
||||||
|
net(15 name('10'))
|
||||||
|
|
||||||
|
# Outgoing pins and their connections to nets
|
||||||
|
pin(1)
|
||||||
|
pin(2)
|
||||||
|
pin(3)
|
||||||
|
pin(4)
|
||||||
|
pin(5)
|
||||||
|
|
||||||
|
# Subcircuits and their connections
|
||||||
|
circuit(1 ND2X1 name($1)
|
||||||
|
pin(0 2)
|
||||||
|
pin(1 6)
|
||||||
|
pin(2 1)
|
||||||
|
pin(3 2)
|
||||||
|
pin(4 3)
|
||||||
|
pin(5 4)
|
||||||
|
pin(6 1)
|
||||||
|
)
|
||||||
|
circuit(2 INVX1 name($2)
|
||||||
|
pin(0 2)
|
||||||
|
pin(1 7)
|
||||||
|
pin(2 1)
|
||||||
|
pin(3 2)
|
||||||
|
pin(4 6)
|
||||||
|
pin(5 1)
|
||||||
|
)
|
||||||
|
circuit(3 INVX1 name($3)
|
||||||
|
pin(0 2)
|
||||||
|
pin(1 8)
|
||||||
|
pin(2 1)
|
||||||
|
pin(3 2)
|
||||||
|
pin(4 7)
|
||||||
|
pin(5 1)
|
||||||
|
)
|
||||||
|
circuit(4 INVX1 name($4)
|
||||||
|
pin(0 2)
|
||||||
|
pin(1 9)
|
||||||
|
pin(2 1)
|
||||||
|
pin(3 2)
|
||||||
|
pin(4 8)
|
||||||
|
pin(5 1)
|
||||||
|
)
|
||||||
|
circuit(5 INVX1 name($5)
|
||||||
|
pin(0 2)
|
||||||
|
pin(1 10)
|
||||||
|
pin(2 1)
|
||||||
|
pin(3 2)
|
||||||
|
pin(4 9)
|
||||||
|
pin(5 1)
|
||||||
|
)
|
||||||
|
circuit(6 INVX1 name($6)
|
||||||
|
pin(0 2)
|
||||||
|
pin(1 11)
|
||||||
|
pin(2 1)
|
||||||
|
pin(3 2)
|
||||||
|
pin(4 10)
|
||||||
|
pin(5 1)
|
||||||
|
)
|
||||||
|
circuit(7 INVX1 name($7)
|
||||||
|
pin(0 2)
|
||||||
|
pin(1 12)
|
||||||
|
pin(2 1)
|
||||||
|
pin(3 2)
|
||||||
|
pin(4 11)
|
||||||
|
pin(5 1)
|
||||||
|
)
|
||||||
|
circuit(8 INVX1 name($8)
|
||||||
|
pin(0 2)
|
||||||
|
pin(1 13)
|
||||||
|
pin(2 1)
|
||||||
|
pin(3 2)
|
||||||
|
pin(4 12)
|
||||||
|
pin(5 1)
|
||||||
|
)
|
||||||
|
circuit(9 INVX1 name($9)
|
||||||
|
pin(0 2)
|
||||||
|
pin(1 14)
|
||||||
|
pin(2 1)
|
||||||
|
pin(3 2)
|
||||||
|
pin(4 13)
|
||||||
|
pin(5 1)
|
||||||
|
)
|
||||||
|
circuit(10 INVX1 name($10)
|
||||||
|
pin(0 2)
|
||||||
|
pin(1 15)
|
||||||
|
pin(2 1)
|
||||||
|
pin(3 2)
|
||||||
|
pin(4 14)
|
||||||
|
pin(5 1)
|
||||||
|
)
|
||||||
|
circuit(11 INVX1 name($11)
|
||||||
|
pin(0 2)
|
||||||
|
pin(1 3)
|
||||||
|
pin(2 1)
|
||||||
|
pin(3 2)
|
||||||
|
pin(4 15)
|
||||||
|
pin(5 1)
|
||||||
|
)
|
||||||
|
circuit(12 INVX1 name($12)
|
||||||
|
pin(0 2)
|
||||||
|
pin(1 5)
|
||||||
|
pin(2 1)
|
||||||
|
pin(3 2)
|
||||||
|
pin(4 3)
|
||||||
|
pin(5 1)
|
||||||
|
)
|
||||||
|
|
||||||
|
)
|
||||||
|
)
|
||||||
|
|
||||||
|
# Cross reference
|
||||||
|
xref(
|
||||||
|
circuit(INVX1 INVX1 match
|
||||||
|
xref(
|
||||||
|
net(4 4 match)
|
||||||
|
net(5 5 match)
|
||||||
|
net(2 2 match)
|
||||||
|
net(6 6 match)
|
||||||
|
net(1 1 match)
|
||||||
|
net(3 3 match)
|
||||||
|
pin(3 3 match)
|
||||||
|
pin(4 4 match)
|
||||||
|
pin(1 1 match)
|
||||||
|
pin(5 5 match)
|
||||||
|
pin(0 0 match)
|
||||||
|
pin(2 2 match)
|
||||||
|
device(1 1 match)
|
||||||
|
device(2 2 match)
|
||||||
|
)
|
||||||
|
)
|
||||||
|
circuit(ND2X1 ND2X1 match
|
||||||
|
xref(
|
||||||
|
net(8 8 match)
|
||||||
|
net(4 4 match)
|
||||||
|
net(6 6 match)
|
||||||
|
net(5 5 match)
|
||||||
|
net(2 2 match)
|
||||||
|
net(7 7 match)
|
||||||
|
net(1 1 match)
|
||||||
|
net(3 3 match)
|
||||||
|
pin(3 3 match)
|
||||||
|
pin(5 5 match)
|
||||||
|
pin(4 4 match)
|
||||||
|
pin(1 1 match)
|
||||||
|
pin(6 6 match)
|
||||||
|
pin(0 0 match)
|
||||||
|
pin(2 2 match)
|
||||||
|
device(1 1 match)
|
||||||
|
device(2 2 match)
|
||||||
|
device(3 3 match)
|
||||||
|
device(4 4 match)
|
||||||
|
)
|
||||||
|
)
|
||||||
|
circuit(RINGO RINGO match
|
||||||
|
xref(
|
||||||
|
net(1 6 match)
|
||||||
|
net(10 15 match)
|
||||||
|
net(2 7 match)
|
||||||
|
net(3 8 match)
|
||||||
|
net(4 9 match)
|
||||||
|
net(5 10 match)
|
||||||
|
net(6 11 match)
|
||||||
|
net(7 12 match)
|
||||||
|
net(8 13 match)
|
||||||
|
net(9 14 match)
|
||||||
|
net(14 4 match)
|
||||||
|
net(11 3 match)
|
||||||
|
net(13 5 match)
|
||||||
|
net(12 2 match)
|
||||||
|
net(15 1 match)
|
||||||
|
pin(3 3 match)
|
||||||
|
pin(0 2 match)
|
||||||
|
pin(2 4 match)
|
||||||
|
pin(1 1 match)
|
||||||
|
pin(4 0 match)
|
||||||
|
circuit(1 1 match)
|
||||||
|
circuit(10 10 match)
|
||||||
|
circuit(11 11 match)
|
||||||
|
circuit(12 12 match)
|
||||||
|
circuit(2 2 match)
|
||||||
|
circuit(3 3 match)
|
||||||
|
circuit(4 4 match)
|
||||||
|
circuit(5 5 match)
|
||||||
|
circuit(6 6 match)
|
||||||
|
circuit(7 7 match)
|
||||||
|
circuit(8 8 match)
|
||||||
|
circuit(9 9 match)
|
||||||
|
)
|
||||||
|
)
|
||||||
|
)
|
||||||
|
|
@ -0,0 +1,102 @@
|
||||||
|
* Extracted by KLayout
|
||||||
|
|
||||||
|
* cell RINGO
|
||||||
|
* pin FB
|
||||||
|
* pin VDD
|
||||||
|
* pin OUT
|
||||||
|
* pin ENABLE
|
||||||
|
* pin VSS
|
||||||
|
.SUBCKT RINGO 5 6 7 8 9
|
||||||
|
* net 5 FB
|
||||||
|
* net 6 VDD
|
||||||
|
* net 7 OUT
|
||||||
|
* net 8 ENABLE
|
||||||
|
* net 9 VSS
|
||||||
|
* cell instance $1 r0 *1 1.8,0
|
||||||
|
X$1 6 1 9 6 5 8 9 ND2X1
|
||||||
|
* cell instance $2 r0 *1 4.2,0
|
||||||
|
X$2 6 2 9 6 1 9 INVX1
|
||||||
|
* cell instance $3 r0 *1 6,0
|
||||||
|
X$3 6 10 9 6 2 9 INVX1
|
||||||
|
* cell instance $4 r0 *1 16.8,0
|
||||||
|
X$4 6 3 9 6 11 9 INVX1
|
||||||
|
* cell instance $5 r0 *1 18.6,0
|
||||||
|
X$5 6 4 9 6 3 9 INVX1
|
||||||
|
* cell instance $6 r0 *1 20.4,0
|
||||||
|
X$6 6 5 9 6 4 9 INVX1
|
||||||
|
* cell instance $7 r0 *1 22.2,0
|
||||||
|
X$7 5 6 7 9 6 9 INVX2
|
||||||
|
* cell instance $17 r0 *1 7.8,0
|
||||||
|
X$17 6 12 9 6 10 9 INVX1
|
||||||
|
* cell instance $18 r0 *1 9.6,0
|
||||||
|
X$18 6 13 9 6 12 9 INVX1
|
||||||
|
* cell instance $19 r0 *1 11.4,0
|
||||||
|
X$19 6 14 9 6 13 9 INVX1
|
||||||
|
* cell instance $20 r0 *1 13.2,0
|
||||||
|
X$20 6 15 9 6 14 9 INVX1
|
||||||
|
* cell instance $21 r0 *1 15,0
|
||||||
|
X$21 6 11 9 6 15 9 INVX1
|
||||||
|
.ENDS RINGO
|
||||||
|
|
||||||
|
* cell INVX2
|
||||||
|
* pin IN
|
||||||
|
* pin VDD
|
||||||
|
* pin OUT
|
||||||
|
* pin VSS
|
||||||
|
* pin
|
||||||
|
* pin SUBSTRATE
|
||||||
|
.SUBCKT INVX2 1 2 3 4 5 6
|
||||||
|
* net 1 IN
|
||||||
|
* net 2 VDD
|
||||||
|
* net 3 OUT
|
||||||
|
* net 4 VSS
|
||||||
|
* net 6 SUBSTRATE
|
||||||
|
* device instance $1 r0 *1 0.85,5.8 PMOS
|
||||||
|
M$1 2 1 3 5 PMOS L=0.25U W=3U AS=0.975P AD=0.975P PS=5.8U PD=5.8U
|
||||||
|
* device instance $3 r0 *1 0.85,2.135 NMOS
|
||||||
|
M$3 4 1 3 6 NMOS L=0.25U W=1.9U AS=0.6175P AD=0.6175P PS=4.15U PD=4.15U
|
||||||
|
.ENDS INVX2
|
||||||
|
|
||||||
|
* cell INVX1
|
||||||
|
* pin VDD
|
||||||
|
* pin OUT
|
||||||
|
* pin VSS
|
||||||
|
* pin
|
||||||
|
* pin IN
|
||||||
|
* pin SUBSTRATE
|
||||||
|
.SUBCKT INVX1 1 2 3 4 5 6
|
||||||
|
* net 1 VDD
|
||||||
|
* net 2 OUT
|
||||||
|
* net 3 VSS
|
||||||
|
* net 5 IN
|
||||||
|
* net 6 SUBSTRATE
|
||||||
|
* device instance $1 r0 *1 0.85,5.8 PMOS
|
||||||
|
M$1 1 5 2 4 PMOS L=0.25U W=1.5U AS=0.6375P AD=0.6375P PS=3.85U PD=3.85U
|
||||||
|
* device instance $2 r0 *1 0.85,2.135 NMOS
|
||||||
|
M$2 3 5 2 6 NMOS L=0.25U W=0.95U AS=0.40375P AD=0.40375P PS=2.75U PD=2.75U
|
||||||
|
.ENDS INVX1
|
||||||
|
|
||||||
|
* cell ND2X1
|
||||||
|
* pin VDD
|
||||||
|
* pin OUT
|
||||||
|
* pin VSS
|
||||||
|
* pin
|
||||||
|
* pin B
|
||||||
|
* pin A
|
||||||
|
* pin SUBSTRATE
|
||||||
|
.SUBCKT ND2X1 1 2 3 4 5 6 7
|
||||||
|
* net 1 VDD
|
||||||
|
* net 2 OUT
|
||||||
|
* net 3 VSS
|
||||||
|
* net 5 B
|
||||||
|
* net 6 A
|
||||||
|
* net 7 SUBSTRATE
|
||||||
|
* device instance $1 r0 *1 0.85,5.8 PMOS
|
||||||
|
M$1 2 6 1 4 PMOS L=0.25U W=1.5U AS=0.6375P AD=0.3375P PS=3.85U PD=1.95U
|
||||||
|
* device instance $2 r0 *1 1.55,5.8 PMOS
|
||||||
|
M$2 1 5 2 4 PMOS L=0.25U W=1.5U AS=0.3375P AD=0.6375P PS=1.95U PD=3.85U
|
||||||
|
* device instance $3 r0 *1 0.85,2.135 NMOS
|
||||||
|
M$3 3 6 8 7 NMOS L=0.25U W=0.95U AS=0.40375P AD=0.21375P PS=2.75U PD=1.4U
|
||||||
|
* device instance $4 r0 *1 1.55,2.135 NMOS
|
||||||
|
M$4 8 5 2 7 NMOS L=0.25U W=0.95U AS=0.21375P AD=0.40375P PS=1.4U PD=2.75U
|
||||||
|
.ENDS ND2X1
|
||||||
|
|
@ -0,0 +1,79 @@
|
||||||
|
|
||||||
|
source($lvs_test_source, "RINGO")
|
||||||
|
|
||||||
|
report_lvs($lvs_test_target_lvsdb)
|
||||||
|
|
||||||
|
target_netlist($lvs_test_target_cir, write_spice, "Extracted by KLayout")
|
||||||
|
|
||||||
|
schematic("ringo_for_simplification.cir")
|
||||||
|
|
||||||
|
deep
|
||||||
|
|
||||||
|
# Drawing layers
|
||||||
|
|
||||||
|
nwell = input(1, 0)
|
||||||
|
active = input(2, 0)
|
||||||
|
pplus = input(3, 0)
|
||||||
|
nplus = input(4, 0)
|
||||||
|
poly = input(5, 0)
|
||||||
|
contact = input(8, 0)
|
||||||
|
metal1 = input(9, 0)
|
||||||
|
via1 = input(10, 0)
|
||||||
|
metal2 = input(11, 0)
|
||||||
|
|
||||||
|
# Bulk layer for terminal provisioning
|
||||||
|
|
||||||
|
bulk = polygon_layer
|
||||||
|
|
||||||
|
# Computed layers
|
||||||
|
|
||||||
|
active_in_nwell = active & nwell
|
||||||
|
pactive = active_in_nwell & pplus
|
||||||
|
pgate = pactive & poly
|
||||||
|
psd = pactive - pgate
|
||||||
|
ntie = active_in_nwell & nplus
|
||||||
|
|
||||||
|
active_outside_nwell = active - nwell
|
||||||
|
nactive = active_outside_nwell & nplus
|
||||||
|
ngate = nactive & poly
|
||||||
|
nsd = nactive - ngate
|
||||||
|
ptie = active_outside_nwell & pplus
|
||||||
|
|
||||||
|
# Device extraction
|
||||||
|
|
||||||
|
# PMOS transistor device extraction
|
||||||
|
extract_devices(mos4("PMOS"), { "SD" => psd, "G" => pgate, "W" => nwell,
|
||||||
|
"tS" => psd, "tD" => psd, "tG" => poly, "tW" => nwell })
|
||||||
|
|
||||||
|
# NMOS transistor device extraction
|
||||||
|
extract_devices(mos4("NMOS"), { "SD" => nsd, "G" => ngate, "W" => bulk,
|
||||||
|
"tS" => nsd, "tD" => nsd, "tG" => poly, "tW" => bulk })
|
||||||
|
|
||||||
|
# Define connectivity for netlist extraction
|
||||||
|
|
||||||
|
# Inter-layer
|
||||||
|
connect(psd, contact)
|
||||||
|
connect(nsd, contact)
|
||||||
|
connect(poly, contact)
|
||||||
|
connect(ntie, contact)
|
||||||
|
connect(nwell, ntie)
|
||||||
|
connect(ptie, contact)
|
||||||
|
connect(contact, metal1)
|
||||||
|
connect(metal1, via1)
|
||||||
|
connect(via1, metal2)
|
||||||
|
|
||||||
|
# Global
|
||||||
|
connect_global(bulk, "SUBSTRATE")
|
||||||
|
connect_global(ptie, "SUBSTRATE")
|
||||||
|
|
||||||
|
# Compare section
|
||||||
|
|
||||||
|
netlist.flatten_circuit("INVCHAIN")
|
||||||
|
|
||||||
|
netlist.make_top_level_pins
|
||||||
|
netlist.purge
|
||||||
|
netlist.combine_devices
|
||||||
|
netlist.purge_nets
|
||||||
|
|
||||||
|
compare
|
||||||
|
|
||||||
File diff suppressed because it is too large
Load Diff
Loading…
Reference in New Issue