ChipwichCmosCif.load
Copyright © 1985 by Xerox Corporation. All rights reserved.
by Jim Gasbarro March 12, 1985 12:38:00 pm PST
Last Edited by: Gasbarro, March 18, 1985 10:02:08 am PST
Frank Bowers January 24, 1986 4:57:06 pm PST
Bowers, October 15, 1985 9:59:06 am PDT
CDCmosA
GraphicsSubset
run InsertChipwichPins
run ReadCifPackage
This technology file works for reading files that have been generated in the standard Xerox Cif format. This format maps pdif and pwelCont into implanted n-diffusion (two separate layers, CPI and CD), and ndif and nwelCont into just n-diffusion (CD). Since Readcif does not detect rectangle intersections, it has no way of recovering the original layers. Thus pdif and pwelCont appear as overlapping n-diffusion and p-diffusion (CD -> n-diffusion, CPI -> p-diffusion), and nwel and nwelCont appear as just n-diffusion.
← %CDProperties.PutPropOnTechnology[onto: %CD.FetchTechnology[$cmos], prop: $CDxCIFName, val: NIL] -- in case this cm file doesn't finish running
← %CDProperties.PutPropOnLayer[onto: %CMos.met2, prop: $CDxCIFName, val: "CM2"]
← %CDProperties.PutPropOnLayer[onto: %CMos.met, prop: $CDxCIFName, val: "CM"]
← %CDProperties.PutPropOnLayer[onto: %CMos.pol, prop: $CDxCIFName, val: "CP"]
← %CDProperties.PutPropOnLayer[onto: %CMos.cut2, prop: $CDxCIFName, val: "CC2"]
← %CDProperties.PutPropOnLayer[onto: %CMos.cut, prop: $CDxCIFName, val: "CC"]
Compensate to make 2 Lambda contact cuts
← %CDProperties.PutPropOnLayer[onto: %CMos.cut2, prop: $CDxCIFName, val: NEW[%CIFIntPhase2.CIFDestRec ← [cifDest: "CC2", deltaRadius: 0 -- nm --]]]
← %CDProperties.PutPropOnLayer[onto: %CMos.cut, prop: $CDxCIFName, val: NEW[%CIFIntPhase2.CIFDestRec ← [cifDest: "CC", deltaRadius: 250 -- nm --]]]
← %CDProperties.PutPropOnLayer[onto: %CMos.nwell, prop: $CDxCIFName, val: "CNW"]
← %CDProperties.PutPropOnLayer[onto: %CMos.pwell, prop: $CDxCIFName, val: "CPW"]
← %CDProperties.PutPropOnLayer[onto: %CMos.ovg, prop: $CDxCIFName, val: "CG"]
Diffusion is a crock.
← %CDProperties.PutPropOnLayer[onto: %CMos.ndif, prop: $CDxCIFName, val: NEW[%CIFIntPhase2.CIFDestRec ← [cifDest: "CPI", deltaRadius: 0 -- nm --]]]
← %CDProperties.PutPropOnLayer[onto: %CMos.pdif, prop: $CDxCIFName, val: NEW[%CIFIntPhase2.CIFDestRec ← [cifDest: "CD", deltaRadius: 0 -- nm --]]]
These are unused layers, put bogus names on them to detach any previous properties
← %CDProperties.PutPropOnLayer[onto: %CMos.bur, prop: $CDxCIFName, val: "CX"]
← %CDProperties.PutPropOnLayer[onto: %CMos.imp, prop: $CDxCIFName, val: "CX"]
← %CDProperties.PutPropOnLayer[onto: %CMos.pwellCont, prop: $CDxCIFName, val: "CX"]
← %CDProperties.PutPropOnLayer[onto: %CMos.nwellCont, prop: $CDxCIFName, val: "CX"]
← %CDProperties.PutPropOnTechnology[onto: %CD.FetchTechnology[$cmos], prop: $CDxCIFName, val: "Technology file for use with ReadCif to make Xerox-ED CMOS CIF viewable"] -- done
ReadCif compensation example:
← %CDProperties.PutPropOnLayer[onto: %CMos.nwel, prop: $CDxCIFName, val: NEW[%CIFIntPhase2.CIFDestRec ← [cifDest: "CNW", deltaRadius: -4000 -- nm --]]]
This line would bloat all n-well rectangles by 4 microns. The sign of deltaRadius corresponds to the tranformation applied when writing the Cif file. Thus, BrandyCIFter would use this property to shrink by 4u while ReadCif bloats by 4u. ReadCif only performs "simple-minded" shrinks, so it is possible that you will end up with disjoint rectangles that were originally connected. Sorry.