XeroxCmosCif.cm
Copyright © 1985 by Xerox Corporation. All rights reserved.
by Jim Gasbarro March 12, 1985 12:38:00 pm PST
Last Edited by: Gasbarro, May 8, 1985 5:57:28 pm PDT
CDCmos
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"]
← %CDProperties.PutPropOnLayer[onto: %CMos.nwel, prop: $CDxCIFName, val: NEW[%CIFIntPhase2.CIFDestRec ← [cifDest: "CNW", deltaRadius: -4000 -- nm --]]]
← %CDProperties.PutPropOnLayer[onto: %CMos.pwel, prop: $CDxCIFName, val: "CPW"]
← %CDProperties.PutPropOnLayer[onto: %CMos.ovg, prop: $CDxCIFName, val: "CG"]
← %CDProperties.PutPropOnLayer[onto: %CMos.bur, prop: $CDxCIFName, val: "CB"]
Diffusion is a crock.
← %CDProperties.PutPropOnLayer[onto: %CMos.ndif, prop: $CDxCIFName, val: "CD"]
← %CDProperties.PutPropOnLayer[onto: %CMos.pdif, prop: $CDxCIFName, val: NEW[%CIFIntPhase2.CIFDestRec ← [cifDest: "CPI", deltaRadius: 1500 -- nm --]]]
These are unused layers, put bogus names on them to detach any previous properties
← %CDProperties.PutPropOnLayer[onto: %CMos.imp, prop: $CDxCIFName, val: "CX"]
← %CDProperties.PutPropOnLayer[onto: %CMos.pwelCont, prop: $CDxCIFName, val: "CX"]
← %CDProperties.PutPropOnLayer[onto: %CMos.nwelCont, prop: $CDxCIFName, val: "CX"]
← %CDProperties.PutPropOnLayer[onto: %CMos.snerd, prop: $CDxCIFName, val: "CX"]
← %CDProperties.PutPropOnLayer[onto: %CMos.NOcOL, prop: $CDxCIFName, val: "CX"]
← %CDProperties.PutPropOnTechnology[onto: %CD.FetchTechnology[$cmos], prop: $CDxCIFName, val: "Technology file for use with ReadCif to make Xerox 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.