- Caltech Intermediate Form
Infobox file format
name = Caltech Intermediate Form(at)
extension = .cif
mime =
owner =
creatorcode = strubin
genre = EDA file format
containerfor =
containedby =
extendedfrom =
extendedto =Caltech Intermediate Form (CIF) is a
file format for describingintegrated circuit s.CIF provides a limited set of graphics primitives that are useful for describing the two-dimensionalshapes on the different layers of a chip.The format allows hierarchical description, which makes the representation concise.In addition, it is a terse buthuman-readable text format.Overview
Each statement in CIF consists of a keyword or letter followed by parameters and terminatedwith a semicolon.Spaces must separate the parameters but there are no restrictions on the number of statementsper line or of the particular columns of any field.Comments can be inserted anywhere by enclosing them in parenthesis.
There are only a few CIF statements and they fall into one of two categories: geometry or control.The geometry statements are:
LAYER
to switch mask layers,BOX
to draw arectangle,WIRE
to draw a path,ROUNDFLASH
to draw a circle,POLYGON
to draw an arbitraryfigure, andCALL
to draw a subroutine of other geometry statements.The control statements areDS
to start the definition of a subroutine,DF
to finish thedefinition of a subroutine,DD
to delete the definition of subroutines,0
through9
toinclude additional user-specified information, andEND
to terminate a CIF file.All of these keywords are usually abbreviated to one or two letters that are unique.Geometry
The
LAYER
statement (or the letterL
) sets the mask layer to be usedfor all subsequent geometry until the next such statement.Following theLAYER
keyword comes a single layer-name parameter.For example, the command: L CC;sets the layer to be the CMOS contact cut (see Fig. B.1 for some typical MOS layer names).NM
nMOS metal NP
nMOS polysilicon ND
nMOS diffusion NC
nMOS contact NI
nMOS implant NB
nMOS buried NG
nMOS overglass CMF
CMOS metal 1 CMS
CMOS metal 2 CPG
CMOS polysilicon CAA
CMOS active CSG
CMOS select CWG
CMOS well CC
CMOS contact CVA
CMOS via COG
CMOS overglass FIGURE B.1 CIF layer names for MOS processes. The
BOX
statement (or the letterB
) is the most commonly used way ofspecifying geometry.It describes a rectangle by giving its length, width, center position, and an optional rotation.The format is as follows: B length width xpos ypos [rotation] ;Without the rotation field, the four numbers specify a box the center of which isat ("xpos", "ypos") and is "length" across in x and "width" tall in y.All numbers in CIF are integers that refer to centimicrons of distance, unless subroutinescaling is specified (described later).The optional "rotation" field contains two numbers that define a vector endpointstarting at the origin.The default value of this field is (1, 0), which is a right-pointing vector.Thus the rotation clause10 5
defines a 30-degree counterclockwise rotation from the normal.Similarly,10 -10
will rotate clockwise by 45 degrees.Note that the magnitude of this rotation vector has no meaning.The
WIRE
statement (or the letterW
) is used to construct apath that runs between a set of points.The path can have a nonzero width and has rounded corners.After theWIRE
keyword comes the width value and then an arbitrarynumber of coordinate pairs that describe the endpoints.Figure B.2 shows a sample wire.Note that the endpoint and corner rounding are implicitly handled.The
ROUNDFLASH
statement (or the letterR
) draws a filledcircle, given the diameter and the center coordinate. For example, the statement: R 20 30 40;will draw a circle that has a radius of 10 (diameter of 20), centered at (30, 40).The
POLYGON
statement (or the letterP
) takes a series ofcoordinate pairs and draws a filled polygon from them.Since filled polygons must be closed, the first and last coordinate points areimplicitly connected and need not be the same.Polygons can be arbitrarily complex, including concavity and self-intersection.Figure B.3 illustrates a polygon statement.Hierarchy
The
CALL
statement (or the letterC
) invokes a collectionof other statements that have been packaged withDS
andDF
.All subroutines are given numbers when they are defined and these numbers are used intheCALL
to identify them.If, for example, aLAYER
statement and aBOX
statement arepackaged into subroutine 4, then the statement: C 4;will cause the box to be drawn on that layer.In addition to simply invoking the subroutine, a
CALL
statement can includetransformations to affect the geometry inside the subroutine.Three transformations can be applied to a subroutine in CIF: translation, rotation, and mirroring.Translation is specified as the letterT
followed by an x, y offset.These offsets will be added to all coordinates in the subroutine, to translate itsgraphics across the mask.Rotation is specified as the letterR
followed by an x, y vector endpointthat, much like the rotation clause in theBOX
statement, defines a line to the origin.The unrotated line has the endpoint (1, 0), which points to the right.Mirroring is available in two forms:MX
to mirror in x andMY
to mirror in y.Mirroring is a bit confusing, becauseMX
causes a negation of the xcoordinate, which effectively mirrors about the y axis.Any number of transformations can be applied to an object and their listed orderis the sequence that will be used to apply them.Figure B.4 shows some examples, illustrating the importance of ordering thetransformations (notice that Figs. B.4c and B.4d produce different results byrearranging the transformations).
Defining subroutines for use in a
CALL
statement is quite simple.The statements to be packaged are enclosed betweenDS
(definitionstart) andDF
(definition finish) statements.Arguments to theDS
statement are the subroutine number and a subroutine scaling factor.There are no arguments to theDF
statement.The scaling factor for a subroutine consists of a numerator followed by a denominatorthat will be applied to all values inside the subroutine.This scaling allows large numbers to be expressed with fewer digits and allows easeof rescaling a design.The scale factor cannot be changed for each invocation of the subroutine since itis applied to the definition.As an example, the subroutine of Fig. B.4 can be described formally as follows: DS 10 20 2; B10 20 5 5; W1 5 5 10 15; DF;Note that the scale factor is 20/2, which allows the trailing zero to be droppedfrom all values inside the subroutine.Arbitrary depth of hierarchy is allowed in CIF subroutines.Forward references are allowed provided that a subroutine is defined before it is used.Thus the sequence: DS 10; ... C 11; DF; DS 11; ... DF; C 10;is legal, but the sequence: C 11; DS 11; ... DF;is not. This is because the actual invocation of subroutine 11 doesnot occur until after its definition in the first example.
Control
CIF subroutines can be overwritten by deleting them and then redefining them.The
DD
statement (delete definition) takes a single parameter anddeletes every subroutine that has a number greater than or equal to this value.The statement is useful when merging multiple CIF files because designs can bedefined, invoked, and deleted without causing naming conflicts.However, it is not recommended for general use by CAD systems.Extensions to CIF can be done with the numeric statements
0
through9
.Although not officially part of CIF, certain conventions have evolved for theuse of these extensions (see Fig. B.5).0
x y layerN
name;
Set named node on specified layer and position 0V
x1 y1 x2 y2 ... xn yn;
Draw vectors 2A
"msg"T
x y;
Place message above specified location 2B
"msg"T
x y;
Place message below specified location 2C
"msg"T
x y;
Place message centered at specified location 2L
"msg"T
x y;
Place message left of specified location 2R
"msg"T
x y;
Place message right of specified location 4A
lowx lowy highx highy;
Declare cell boundary 4B
instancename;
Attach instance name to cell 4N
signalname x y;
Labels a signal at a location 9
cellname;
Declare cell name 91
instancename;
Attach instance name to cell 94
label x y;
Place label in specified location 95
label length width x y;
Place label in specified area FIGURE B.5 Typical user extensions to CIF. The final statement in a CIF file is the
END
statement (or the letterE
).It takes no parameters and typically does not include a semicolon.References
* [http://www.rulabinsky.com/cavd/text/chapb.html Computer Aids for VLSI Design - Appendix B: Caltech Intermediate Format by Steven M. Rubin]
*Hon, Robert W. and Sequin, Carlo H., "A Guide to LSI Implementation," 2nd Edition, Xerox Palo Alto Research Center technical memo SSL-79-7, January 1980.
Wikimedia Foundation. 2010.