mirror of https://github.com/KLayout/klayout.git
483 lines
12 KiB
Plaintext
483 lines
12 KiB
Plaintext
#%l2n-klayout
|
|
|
|
# General section
|
|
|
|
top(RINGO)
|
|
unit(0.001)
|
|
|
|
# Layer section
|
|
# This section lists the mask layers (drawing or derived) and their connections.
|
|
|
|
# Mask layers
|
|
layer(poly)
|
|
layer(poly_lbl)
|
|
layer(diff_cont)
|
|
layer(poly_cont)
|
|
layer(metal1)
|
|
layer(metal1_lbl)
|
|
layer(via1)
|
|
layer(metal2)
|
|
layer(metal2_lbl)
|
|
layer(psd)
|
|
layer(nsd)
|
|
|
|
# Mask layer connectivity
|
|
connect(poly poly poly_lbl poly_cont)
|
|
connect(poly_lbl poly)
|
|
connect(diff_cont diff_cont metal1 psd nsd)
|
|
connect(poly_cont poly poly_cont metal1)
|
|
connect(metal1 diff_cont poly_cont metal1 metal1_lbl via1)
|
|
connect(metal1_lbl metal1)
|
|
connect(via1 metal1 via1 metal2)
|
|
connect(metal2 via1 metal2 metal2_lbl)
|
|
connect(metal2_lbl metal2)
|
|
connect(psd diff_cont psd)
|
|
connect(nsd diff_cont nsd)
|
|
|
|
# Device abstracts section
|
|
# Device abstracts list the pin shapes of the devices.
|
|
device(D$PMOS PMOS
|
|
terminal(S
|
|
rect(psd -650 -475 -125 475)
|
|
)
|
|
terminal(G
|
|
rect(poly -125 -475 125 475)
|
|
)
|
|
terminal(D
|
|
rect(psd 125 -475 675 475)
|
|
)
|
|
)
|
|
device(D$PMOS$1 PMOS
|
|
terminal(S
|
|
rect(psd -675 -475 -125 475)
|
|
)
|
|
terminal(G
|
|
rect(poly -125 -475 125 475)
|
|
)
|
|
terminal(D
|
|
rect(psd 125 -475 650 475)
|
|
)
|
|
)
|
|
device(D$NMOS NMOS
|
|
terminal(S
|
|
rect(nsd -650 -475 -125 475)
|
|
)
|
|
terminal(G
|
|
rect(poly -125 -475 125 475)
|
|
)
|
|
terminal(D
|
|
rect(nsd 125 -475 675 475)
|
|
)
|
|
)
|
|
device(D$NMOS$1 NMOS
|
|
terminal(S
|
|
rect(nsd -675 -475 -125 475)
|
|
)
|
|
terminal(G
|
|
rect(poly -125 -475 125 475)
|
|
)
|
|
terminal(D
|
|
rect(nsd 125 -475 650 475)
|
|
)
|
|
)
|
|
|
|
# Circuit section
|
|
# Circuits are the hierarchical building blocks of the netlist.
|
|
circuit(INV2
|
|
|
|
# Nets with their geometries
|
|
net(1 name(IN)
|
|
rect(poly -525 -250 -275 2250)
|
|
rect(poly -1700 1620 -400 1980)
|
|
rect(poly -525 -800 -275 800)
|
|
rect(poly -525 2000 -275 3600)
|
|
rect(poly_lbl -801 1799 -799 1801)
|
|
rect(poly_cont -1630 1690 -1410 1910)
|
|
)
|
|
net(2
|
|
rect(poly 275 -250 525 2250)
|
|
rect(poly 220 820 580 1180)
|
|
rect(poly 275 2000 525 3600)
|
|
rect(poly 275 -800 525 800)
|
|
rect(diff_cont -910 2490 -690 2710)
|
|
rect(diff_cont -910 2890 -690 3110)
|
|
rect(diff_cont -910 -310 -690 -90)
|
|
rect(diff_cont -910 90 -690 310)
|
|
rect(poly_cont 290 890 510 1110)
|
|
rect(metal1 -800 820 580 1180)
|
|
rect(metal1 -980 -420 -620 2420)
|
|
rect(metal1 -980 2420 -620 3180)
|
|
rect(metal1 -980 -380 -620 380)
|
|
rect(psd -1050 2325 -525 3275)
|
|
rect(nsd -1050 -475 -525 475)
|
|
)
|
|
net(3 name(OUT)
|
|
rect(diff_cont 690 2890 910 3110)
|
|
rect(diff_cont 690 2490 910 2710)
|
|
rect(diff_cont 690 90 910 310)
|
|
rect(diff_cont 690 -310 910 -90)
|
|
polygon(metal1 800 20 * 380 940 * * 1620 620 * * 2420 980 * * 1980 1300 * * 20)
|
|
rect(metal1 620 2420 980 3180)
|
|
rect(metal1 620 -380 980 380)
|
|
rect(metal1_lbl 799 1799 801 1801)
|
|
rect(psd 525 2325 1050 3275)
|
|
rect(nsd 525 -475 1050 475)
|
|
)
|
|
net(4
|
|
rect(diff_cont -110 -310 110 -90)
|
|
rect(diff_cont -110 90 110 310)
|
|
rect(diff_cont -110 90 110 310)
|
|
rect(diff_cont -110 -310 110 -90)
|
|
rect(metal1 -180 -380 180 380)
|
|
rect(metal1 -180 -380 180 380)
|
|
rect(via1 -125 -325 125 -75)
|
|
rect(via1 -125 75 125 325)
|
|
rect(metal2 -1400 -450 1400 450)
|
|
rect(nsd -275 -475 275 475)
|
|
)
|
|
net(5
|
|
rect(diff_cont -110 2490 110 2710)
|
|
rect(diff_cont -110 2890 110 3110)
|
|
rect(diff_cont -110 2890 110 3110)
|
|
rect(diff_cont -110 2490 110 2710)
|
|
rect(metal1 -180 2420 180 3180)
|
|
rect(metal1 -180 2420 180 3180)
|
|
rect(via1 -125 2475 125 2725)
|
|
rect(via1 -125 2875 125 3125)
|
|
rect(metal2 -1400 2350 1400 3250)
|
|
rect(psd -275 2325 275 3275)
|
|
)
|
|
|
|
# Outgoing pins and their connections to nets
|
|
pin(IN 1)
|
|
pin($1 2)
|
|
pin(OUT 3)
|
|
pin($3 4)
|
|
pin($4 5)
|
|
|
|
# Devices and their connections
|
|
device($1 D$PMOS
|
|
location(-400 2800)
|
|
param(L 0.25)
|
|
param(W 0.95)
|
|
param(AS 0.49875)
|
|
param(AD 0.26125)
|
|
param(PS 2.95)
|
|
param(PD 1.5)
|
|
terminal(S 2)
|
|
terminal(G 1)
|
|
terminal(D 5)
|
|
)
|
|
device($2 D$PMOS$1
|
|
location(400 2800)
|
|
param(L 0.25)
|
|
param(W 0.95)
|
|
param(AS 0.26125)
|
|
param(AD 0.49875)
|
|
param(PS 1.5)
|
|
param(PD 2.95)
|
|
terminal(S 5)
|
|
terminal(G 2)
|
|
terminal(D 3)
|
|
)
|
|
device($3 D$NMOS
|
|
location(-400 0)
|
|
param(L 0.25)
|
|
param(W 0.95)
|
|
param(AS 0.49875)
|
|
param(AD 0.26125)
|
|
param(PS 2.95)
|
|
param(PD 1.5)
|
|
terminal(S 2)
|
|
terminal(G 1)
|
|
terminal(D 4)
|
|
)
|
|
device($4 D$NMOS$1
|
|
location(400 0)
|
|
param(L 0.25)
|
|
param(W 0.95)
|
|
param(AS 0.26125)
|
|
param(AD 0.49875)
|
|
param(PS 1.5)
|
|
param(PD 2.95)
|
|
terminal(S 4)
|
|
terminal(G 2)
|
|
terminal(D 3)
|
|
)
|
|
|
|
)
|
|
circuit(RINGO
|
|
|
|
# Nets with their geometries
|
|
net(1 name(FB)
|
|
rect(diff_cont 22850 2490 23070 2710)
|
|
rect(diff_cont 22850 2890 23070 3110)
|
|
rect(diff_cont 22850 -310 23070 -90)
|
|
rect(diff_cont 22850 90 23070 310)
|
|
rect(metal1 -1700 1620 -1340 1980)
|
|
rect(via1 -1645 1675 -1395 1925)
|
|
rect(via1 22835 1675 23085 1925)
|
|
rect(metal2 -1720 1600 23160 2000)
|
|
rect(metal2_lbl -1 1799 1 1801)
|
|
)
|
|
net(2 name(OSC)
|
|
rect(diff_cont 24450 2890 24670 3110)
|
|
rect(diff_cont 24450 2490 24670 2710)
|
|
rect(diff_cont 24450 90 24670 310)
|
|
rect(diff_cont 24450 -310 24670 -90)
|
|
rect(via1 24435 1675 24685 1925)
|
|
rect(metal2 24360 1600 24760 2000)
|
|
rect(metal2_lbl 24559 1799 24561 1801)
|
|
)
|
|
net(3 name(VSS)
|
|
rect(diff_cont 2530 -310 2750 -90)
|
|
rect(diff_cont 2530 90 2750 310)
|
|
rect(diff_cont 2530 90 2750 310)
|
|
rect(diff_cont 2530 -310 2750 -90)
|
|
rect(diff_cont -110 -310 110 -90)
|
|
rect(diff_cont -110 90 110 310)
|
|
rect(diff_cont -110 90 110 310)
|
|
rect(diff_cont -110 -310 110 -90)
|
|
rect(diff_cont 5170 -310 5390 -90)
|
|
rect(diff_cont 5170 90 5390 310)
|
|
rect(diff_cont 5170 90 5390 310)
|
|
rect(diff_cont 5170 -310 5390 -90)
|
|
rect(diff_cont 7810 -310 8030 -90)
|
|
rect(diff_cont 7810 90 8030 310)
|
|
rect(diff_cont 7810 90 8030 310)
|
|
rect(diff_cont 7810 -310 8030 -90)
|
|
rect(diff_cont 10450 -310 10670 -90)
|
|
rect(diff_cont 10450 90 10670 310)
|
|
rect(diff_cont 10450 90 10670 310)
|
|
rect(diff_cont 10450 -310 10670 -90)
|
|
rect(diff_cont 13090 -310 13310 -90)
|
|
rect(diff_cont 13090 90 13310 310)
|
|
rect(diff_cont 13090 90 13310 310)
|
|
rect(diff_cont 13090 -310 13310 -90)
|
|
rect(diff_cont 15730 -310 15950 -90)
|
|
rect(diff_cont 15730 90 15950 310)
|
|
rect(diff_cont 15730 90 15950 310)
|
|
rect(diff_cont 15730 -310 15950 -90)
|
|
rect(diff_cont 18370 -310 18590 -90)
|
|
rect(diff_cont 18370 90 18590 310)
|
|
rect(diff_cont 18370 90 18590 310)
|
|
rect(diff_cont 18370 -310 18590 -90)
|
|
rect(diff_cont 21010 -310 21230 -90)
|
|
rect(diff_cont 21010 90 21230 310)
|
|
rect(diff_cont 21010 90 21230 310)
|
|
rect(diff_cont 21010 -310 21230 -90)
|
|
rect(diff_cont 23650 -310 23870 -90)
|
|
rect(diff_cont 23650 90 23870 310)
|
|
rect(diff_cont 23650 90 23870 310)
|
|
rect(diff_cont 23650 -310 23870 -90)
|
|
rect(metal1 2460 -380 2820 380)
|
|
rect(metal1 2460 -380 2820 380)
|
|
rect(metal1 -180 -380 180 380)
|
|
rect(metal1 -180 -380 180 380)
|
|
rect(metal1 5100 -380 5460 380)
|
|
rect(metal1 5100 -380 5460 380)
|
|
rect(metal1 7740 -380 8100 380)
|
|
rect(metal1 7740 -380 8100 380)
|
|
rect(metal1 10380 -380 10740 380)
|
|
rect(metal1 10380 -380 10740 380)
|
|
rect(metal1 13020 -380 13380 380)
|
|
rect(metal1 13020 -380 13380 380)
|
|
rect(metal1 15660 -380 16020 380)
|
|
rect(metal1 15660 -380 16020 380)
|
|
rect(metal1 18300 -380 18660 380)
|
|
rect(metal1 18300 -380 18660 380)
|
|
rect(metal1 20940 -380 21300 380)
|
|
rect(metal1 20940 -380 21300 380)
|
|
rect(metal1 23580 -380 23940 380)
|
|
rect(metal1 23580 -380 23940 380)
|
|
rect(metal2_lbl -1 -1 1 1)
|
|
)
|
|
net(4 name(VDD)
|
|
rect(diff_cont 2530 2490 2750 2710)
|
|
rect(diff_cont 2530 2890 2750 3110)
|
|
rect(diff_cont 2530 2890 2750 3110)
|
|
rect(diff_cont 2530 2490 2750 2710)
|
|
rect(diff_cont -110 2490 110 2710)
|
|
rect(diff_cont -110 2890 110 3110)
|
|
rect(diff_cont -110 2890 110 3110)
|
|
rect(diff_cont -110 2490 110 2710)
|
|
rect(diff_cont 5170 2490 5390 2710)
|
|
rect(diff_cont 5170 2890 5390 3110)
|
|
rect(diff_cont 5170 2890 5390 3110)
|
|
rect(diff_cont 5170 2490 5390 2710)
|
|
rect(diff_cont 7810 2490 8030 2710)
|
|
rect(diff_cont 7810 2890 8030 3110)
|
|
rect(diff_cont 7810 2890 8030 3110)
|
|
rect(diff_cont 7810 2490 8030 2710)
|
|
rect(diff_cont 10450 2490 10670 2710)
|
|
rect(diff_cont 10450 2890 10670 3110)
|
|
rect(diff_cont 10450 2890 10670 3110)
|
|
rect(diff_cont 10450 2490 10670 2710)
|
|
rect(diff_cont 13090 2490 13310 2710)
|
|
rect(diff_cont 13090 2890 13310 3110)
|
|
rect(diff_cont 13090 2890 13310 3110)
|
|
rect(diff_cont 13090 2490 13310 2710)
|
|
rect(diff_cont 15730 2490 15950 2710)
|
|
rect(diff_cont 15730 2890 15950 3110)
|
|
rect(diff_cont 15730 2890 15950 3110)
|
|
rect(diff_cont 15730 2490 15950 2710)
|
|
rect(diff_cont 18370 2490 18590 2710)
|
|
rect(diff_cont 18370 2890 18590 3110)
|
|
rect(diff_cont 18370 2890 18590 3110)
|
|
rect(diff_cont 18370 2490 18590 2710)
|
|
rect(diff_cont 21010 2490 21230 2710)
|
|
rect(diff_cont 21010 2890 21230 3110)
|
|
rect(diff_cont 21010 2890 21230 3110)
|
|
rect(diff_cont 21010 2490 21230 2710)
|
|
rect(diff_cont 23650 2490 23870 2710)
|
|
rect(diff_cont 23650 2890 23870 3110)
|
|
rect(diff_cont 23650 2890 23870 3110)
|
|
rect(diff_cont 23650 2490 23870 2710)
|
|
rect(metal1 2460 2420 2820 3180)
|
|
rect(metal1 2460 2420 2820 3180)
|
|
rect(metal1 -180 2420 180 3180)
|
|
rect(metal1 -180 2420 180 3180)
|
|
rect(metal1 5100 2420 5460 3180)
|
|
rect(metal1 5100 2420 5460 3180)
|
|
rect(metal1 7740 2420 8100 3180)
|
|
rect(metal1 7740 2420 8100 3180)
|
|
rect(metal1 10380 2420 10740 3180)
|
|
rect(metal1 10380 2420 10740 3180)
|
|
rect(metal1 13020 2420 13380 3180)
|
|
rect(metal1 13020 2420 13380 3180)
|
|
rect(metal1 15660 2420 16020 3180)
|
|
rect(metal1 15660 2420 16020 3180)
|
|
rect(metal1 18300 2420 18660 3180)
|
|
rect(metal1 18300 2420 18660 3180)
|
|
rect(metal1 20940 2420 21300 3180)
|
|
rect(metal1 20940 2420 21300 3180)
|
|
rect(metal1 23580 2420 23940 3180)
|
|
rect(metal1 23580 2420 23940 3180)
|
|
rect(metal2_lbl -1 2799 1 2801)
|
|
)
|
|
net(5
|
|
rect(diff_cont 690 2890 910 3110)
|
|
rect(diff_cont 690 2490 910 2710)
|
|
rect(diff_cont 690 90 910 310)
|
|
rect(diff_cont 690 -310 910 -90)
|
|
)
|
|
net(6
|
|
rect(diff_cont 21810 2890 22030 3110)
|
|
rect(diff_cont 21810 2490 22030 2710)
|
|
rect(diff_cont 21810 90 22030 310)
|
|
rect(diff_cont 21810 -310 22030 -90)
|
|
)
|
|
net(7
|
|
rect(diff_cont 19170 2890 19390 3110)
|
|
rect(diff_cont 19170 2490 19390 2710)
|
|
rect(diff_cont 19170 90 19390 310)
|
|
rect(diff_cont 19170 -310 19390 -90)
|
|
)
|
|
net(8
|
|
rect(diff_cont 16530 2890 16750 3110)
|
|
rect(diff_cont 16530 2490 16750 2710)
|
|
rect(diff_cont 16530 90 16750 310)
|
|
rect(diff_cont 16530 -310 16750 -90)
|
|
)
|
|
net(9
|
|
rect(diff_cont 13890 2890 14110 3110)
|
|
rect(diff_cont 13890 2490 14110 2710)
|
|
rect(diff_cont 13890 90 14110 310)
|
|
rect(diff_cont 13890 -310 14110 -90)
|
|
)
|
|
net(10
|
|
rect(diff_cont 11250 2890 11470 3110)
|
|
rect(diff_cont 11250 2490 11470 2710)
|
|
rect(diff_cont 11250 90 11470 310)
|
|
rect(diff_cont 11250 -310 11470 -90)
|
|
)
|
|
net(11
|
|
rect(diff_cont 8610 2890 8830 3110)
|
|
rect(diff_cont 8610 2490 8830 2710)
|
|
rect(diff_cont 8610 90 8830 310)
|
|
rect(diff_cont 8610 -310 8830 -90)
|
|
)
|
|
net(12
|
|
rect(diff_cont 5970 2890 6190 3110)
|
|
rect(diff_cont 5970 2490 6190 2710)
|
|
rect(diff_cont 5970 90 6190 310)
|
|
rect(diff_cont 5970 -310 6190 -90)
|
|
)
|
|
net(13
|
|
rect(diff_cont 3330 2890 3550 3110)
|
|
rect(diff_cont 3330 2490 3550 2710)
|
|
rect(diff_cont 3330 90 3550 310)
|
|
rect(diff_cont 3330 -310 3550 -90)
|
|
)
|
|
|
|
# Outgoing pins and their connections to nets
|
|
pin(FB 1)
|
|
pin(OSC 2)
|
|
pin(VSS 3)
|
|
pin(VDD 4)
|
|
|
|
# Subcircuits and their connections
|
|
circuit($1 INV2 location(23760 0)
|
|
pin(IN 6)
|
|
pin($1 1)
|
|
pin(OUT 2)
|
|
pin($3 3)
|
|
pin($4 4)
|
|
)
|
|
circuit($2 INV2 location(0 0)
|
|
pin(IN 1)
|
|
pin(OUT 5)
|
|
pin($3 3)
|
|
pin($4 4)
|
|
)
|
|
circuit($3 INV2 location(2640 0)
|
|
pin(IN 5)
|
|
pin(OUT 13)
|
|
pin($3 3)
|
|
pin($4 4)
|
|
)
|
|
circuit($4 INV2 location(5280 0)
|
|
pin(IN 13)
|
|
pin(OUT 12)
|
|
pin($3 3)
|
|
pin($4 4)
|
|
)
|
|
circuit($5 INV2 location(7920 0)
|
|
pin(IN 12)
|
|
pin(OUT 11)
|
|
pin($3 3)
|
|
pin($4 4)
|
|
)
|
|
circuit($6 INV2 location(10560 0)
|
|
pin(IN 11)
|
|
pin(OUT 10)
|
|
pin($3 3)
|
|
pin($4 4)
|
|
)
|
|
circuit($7 INV2 location(13200 0)
|
|
pin(IN 10)
|
|
pin(OUT 9)
|
|
pin($3 3)
|
|
pin($4 4)
|
|
)
|
|
circuit($8 INV2 location(15840 0)
|
|
pin(IN 9)
|
|
pin(OUT 8)
|
|
pin($3 3)
|
|
pin($4 4)
|
|
)
|
|
circuit($9 INV2 location(18480 0)
|
|
pin(IN 8)
|
|
pin(OUT 7)
|
|
pin($3 3)
|
|
pin($4 4)
|
|
)
|
|
circuit($10 INV2 location(21120 0)
|
|
pin(IN 7)
|
|
pin(OUT 6)
|
|
pin($3 3)
|
|
pin($4 4)
|
|
)
|
|
|
|
)
|