## **PCT** #### WORLD INTELLECTUAL PROPERTY ORGANIZATION International Bureau # INTERNATIONAL APPLICATION PUBLISHED UNDER THE PATENT COOPERATION TREATY (PCT) (51) International Patent Classification 5: (11) International Publication Number: WO 93/15471 **A1** G06F 15/60 (43) International Publication Date: 5 August 1993 (05.08.93) US (21) International Application Number: PCT/US93/00217 (22) International Filing Date: 14 January 1993 (14.01.93) 24 January 1992 (24.01.92) (30) Priority data: 07/825,490 (71) Applicant: VLSI TECHNOLOGY, INC. [US/US]; 1109 McKay Drive, San Jose, CA 95131 (US). (72) Inventors: LIN, Pei; 3173 Mt. McKinley Dr., San Jose, CA 95127 (US). DUPREZ, Herve, G.; 1299 Arroyo Seco Dr., Campbell, CA 95008 (US). (74) Agent: KREBS, Robert, E.; Burns, Doane, Swecker & Mathis, George Mason Building, Washington and Prince Streets, P.O. Box 1404, Alexandria, VA 22313-1404 (US). (81) Designated States: JP, KR, European patent (AT, BE, CH, DE, DK, ES, FR, GB, GR, IE, IT, LU, MC, NL, PT, #### **Published** With international search report. Before the expiration of the time limit for amending the claims and to be republished in the event of the receipt of amendments. (54) Title: METHOD FOR VERIFYING CIRCUIT LAYOUT DESIGN #### (57) Abstract 1 The present invention is directed to methods to assist designing integrated circuits by verifying that design constraints (e.g., minimum path width) are satisfied between two arbitrary nodes of a circuit layout. In an exemplary embodiment, a method for designing an integrated circuit layout (2) by verifying that predetermined design constraints are satisfied for an arbitrary path defined by at least two nodes comprises the steps of labelling all polygons of the integrated circuit layout with a name which corresponds to a layer of the integrated circuit layout in which each polygon is located (20), creating a file of polygons which includes polygons located along the arbitrary path (22, 24), and determining whether polygons located along the arbitrary path satisfy predetermined design constraints specified for that path (26). 1 ريّر ا # FOR THE PURPOSES OF INFORMATION ONLY Codes used to identify States party to the PCT on the front pages of pamphlets publishing international applications under the PCT. | AT | Austria | FR | France | MR | Mauritania | |----|--------------------------|-----|------------------------------|----|--------------------------| | ΑU | Australia | GA | Gabon | MW | Malawi | | BB | Barbados | GB | United Kingdom | NL | Netherlands | | BE | Belgium | GN | Guinea | NO | Norway | | BF | Burkina Faso | GR | Greece | NZ | New Zealand | | BG | Bulgaria | HU | Hungary | PL | Poland | | ВJ | Benin | ΙE | Ireland | PT | Portugal | | BR | Brazil | ΙT | Italy | RO | Romania | | CA | Canada | JР | Japan | RU | Russian Federation | | CF | Central African Republic | KP | Democratic People's Republic | SD | Sudan | | CG | Congo | | of Korea | SE | Sweden | | CH | Switzerland | KR | Republic of Korea | SK | Slovak Republic | | CI | Côte d'Ivoire | ΚZ | Kazakhstan | SN | Senegal | | CM | Cameroon | LI | Liechtenstein | SU | Soviet Union | | CS | Czechoslovakia - | LK | Sri Lanka | TD | Chad | | CZ | Czech Republic | 1.U | Luxembourg | TG | Togo | | DE | Germany | MC | Monaco | UA | Ukraine | | DK | Denmark | MG | Madagascar | US | United States of America | | ES | Spain | MI. | Mali | ٧N | Viet Nam | | FI | Finland | MN | Mongolia | | | #### METHOD FOR VERIFYING CIRCUIT LAYOUT DESIGN ## BACKGROUND OF THE INVENTION ## Field of the Invention The present invention relates generally to designing integrated circuits, and more particularly relates to methods for verifying that a given circuit layout design conforms to predetermined design constraints. ## State of the Art 10 Generally speaking, techniques are known for verifying that a circuit layout (e.g., standard cell) conforms with predetermined design constraints. example, design rule checking techniques are known for verifying that the geometries (e.g., conductive or non-15 conductive paths) included in all layers of a given integrated circuit layout comply with predetermined minimum width requirements. At best, these techniques can verify that all geometries in a given layer of an integrated circuit layout satisfy the minimum width constraint. It is important to verify that all paths 20 in the circuit layout comply with minimum width requirements to avoid problems such as metal migration, voltage division, timing problems and so forth. There is a continual effort to reduce 25 integrated circuit size, and to increase operational speed. For example, to increase signal processing speed it would be desirable to increase transistor power. This entails providing higher V<sub>dd</sub> (drain) and V<sub>ss</sub> (source) currents. Higher V<sub>dd</sub> and V<sub>ss</sub> currents require 30 that the paths conducting these currents be designed 5 10 15 20 25 30 -2- larger (e.g., wider design specifications) to avoid problems such as metal migration. However, no techniques currently exist for separately verifying proper design of this wider path. That is, no practical way exists for verifying that a path between two arbitrary nodes satisfies predetermined minimum width constraints which are different from minimum width constraints for remaining portions of the circuit layout. Thus, the probability of errors in the design is great. #### SUMMARY OF THE INVENTION The present invention is therefore directed to methods to assist in designing integrated circuits by verifying that design constraints (e.g., minimum path width) are satisfied between two arbitrary nodes of a circuit layout. In an exemplary embodiment, a method for designing an integrated circuit layout by verifying that predetermined design constraints are satisfied for an arbitrary path defined by at least two nodes comprises the steps of labeling all polygons of said integrated circuit layout with a name which corresponds to a layer or layers of the integrated circuit layout, creating a file of polygons which includes polygons located along said arbitrary path, and determining whether polygons located along said arbitrary path satisfy predetermined design constraints specified for that path. For purposes of the present invention, the arbitrary path can be between nodes on one or more layers of the circuit layout, and therefore the arbitrary path can include polygons from one or more layers. -3- #### BRIEF DESCRIPTION OF THE DRAWINGS These and other objects and advantages of the present invention will become more apparent from the following detailed description of preferred embodiments when read in conjunction with the accompanying drawings, wherein like elements are designated by like numerals, and wherein: Figures 1a, 1b, 2a, 2b, 3a and 3b illustrate methods associated with the present invention; Figure 4 illustrates a flow chart for implementing an exemplary embodiment of the invention; and 10 Figure 5 illustrates results associated with the Figure 4 flow chart. ## 15 <u>DETAILED DESCRIPTION OF THE PREFERRED EMBODIMENTS</u> Figure 1a shows merged polygons associated with a single layer 2 of an exemplary integrated circuit layout. The geometries 4, 6, 8, 10, and 12 represent disjointed portions of the layer which 20 includes, for example, conductive paths. geometries shown in Figure 1a are for the layer which includes node mark 1 and node mark 2, corresponding to nodes 1 and 2 at the locations "x". Each of these geometries represents a combination of one or more 25 polygons which have been previously identified during circuit design. The geometries can include polygons from one or more layers. For example, in Figure 1a the geometry 8 can include polygons from one or more merged layers associated with the nodes of interest. Using a standard design verification technique, predetermined design constraints for the integrated circuit, which includes the layer shown in 5 10 15 20 25 30 -4- Figure 1, can be verified. For example, a minimum path width for all geometries represented in Figure 1 (as well as other layers at the integrated circuit layout) can be verified. However, as described previously, known verification techniques do not permit an arbitrarily specified path between nodes 1 and 2 to be separately verified. For example, assuming that the path between nodes 1 and 2 is designed to have larger minimum width requirements than other portions of the layer shown, there is no present technique for verifying that this path conforms to these requirements. Accordingly, to verify that the path between nodes 1 and 2 conforms to larger width requirements, all polygons representing the integrated circuit layout are labeled with a name which corresponds to a layer or a combination of layers (e.g., metallization layers) of the integrated circuit layout in which each polygon is located. Such information is typically generated during the design phase of an integrated circuit layout. information is stored and used to subsequently create a file of polygons which includes those polygons located along the arbitrary path. The step of creating includes a step of identifying the layer or combination of layers of the integrated circuit layout that includes at least two nodes which define the arbitrary path of interest. Further, the step of creating includes a step of building a file of polygons for the identified layer or layers. The building of a polygon file for this layer or layers of the integrated circuit layout further includes steps of sorting and merging the polygon file to identify those polygons in each of the layers which contact one another. Thus, the polygons of a given 5 10 15 20 25 30 $\alpha_3$ layer can be displayed as a plurality of geometries, such as the geometries shown in Figure 1a. Afterwards, a separate file of polygons which include only those polygons located along the arbitrary path is created by manually identifying those polygons which constitute part of the path of interest. This separate file can be used to create an overlay layer 14 (e.g., manually draw the area shaded in Figure 1b) which corresponds to the region to be checked for compliance with minimum width requirements (i.e., the arbitrary path). This overlay layer can then be independently verified for compliance with a minimum width requirement using a standard design rule checking technique, with the minimum width specified corresponding to the larger value set for the path of interest. The overlay layer does not constitute part of the integrated circuit layout, and is formed by tracing over the widest regions which form the arbitrary path of interest. For example, as shown in Figure 1b, the overlay layer is created as the superimposed, shaded portion of the Figure 1a layer which includes the path between nodes 1 and 2. Minimum width requirements of the path between nodes 1 and 2 are verified by using standard design rule verification techniques for the superimposed, shaded portion. While the visual determination of polygons associated with the Figure 1b analysis described above may be suitable for relatively simple designs, this technique becomes increasingly inaccurate as circuit layout complexity increases. In some cases, it may be virtually impossible to create an overlay associated with the arbitrary path of interest. Further, it is 5 10 15 20 25 30 -6- time-consuming to maintain an updated version of an overlay which will permit accurate verification of the arbitrary path despite ongoing circuit layout design changes. In addition, multiple overlay layers must be created whenever multiple arbitrary paths of interest are involved. An alternate technique of verifying design constraints for an arbitrary path defined by at least two nodes will now be described. Polygonal and geometrical information associated with a given layer of an integrated circuit is generated in a manner similar to that described with respect to Figure 1a. To determine whether polygons located along the arbitrary path satisfy predetermined design constraints, the design verification technique is modified as follows. After the standard design verification technique has been run for the entire integrated circuit, the predetermined design criteria (e.g., minimum path width) are reset to the larger requirement associated with the path between the arbitrary nodes of interest. For example, if the minimum path width for all paths in the circuit layout is 8 units (e.g., microns), but the minimum path width requirement for the path between the nodes of interest is 30 units, the standard design verification technique is run for the layer which includes nodes 1 and 2 using the 30 unit value. Thus, all portions of the layer's geometry which do not satisfy the 30 unit constraint are sequentially displayed, one at a time, with an error message. If no portions of the geometry which interconnects the nodes of interest are displayed, the minimum width requirements for that path are considered to be satisfactory. 5 10 10 15 -7- Although this alternate technique will work in some cases, it can result in the generation of false For example, with regard to Figure 2a, the geometry which interconnects node 1 and node 2 includes errors which are highlighted in bold in Figure 2b. can be seen, a number of portions of the layer geometry which interconnects nodes 1 and 2 would be displayed such that the user would falsely believe that a path with a continuous 30 units width did not exist between nodes 1 and 2. Thus, the designer must continually verify that any error generated represents an actual error for the path of interest. However, assuming all portions of the layer geometry which do conform with the minimum width requirements (e.g., shaded portion of Figure 1b) can be independently displayed, the user can visually verify that a path which satisfies the minimum width requirements between nodes 1 and 2 does exist. Such a technique can be performed using the steps described below with respect to Figure 4. 20 An alternate technique for verifying that predetermined design constraints are satisfied for an arbitrary path defined by at least two nodes will now be described with respect to Figures 3a and 3b. with Figures 1a and 2a, the method associated with Figure 3a begins by labeling all polygons in the 25 integrated circuit so that the geometries associated with any desired integrated circuit layout can be separately displayed. To determine whether polygons located along a path between arbitrarily specified nodes conform with minimum width requirements for that 30 path, all polygons in the layer which includes the nodes of interest are reduced in size by an amount slightly less than the minimum width requirement. Thus, remaining portions displayed will verify whether a path between the nodes possesses the minimum width 35 -8- requirements, as shown, for example, by the area 16 in Figure 3b. Although a technique as described with respect to Figures 3a-3b will work in most cases, an error is introduced in the determination. This error is due to the Figure 3a polygons being reduced in size by an amount slightly less than the desired minimum width as illustrated by the highlighted lines in Figure 3a. 5 30 10 Because the techniques associated with Figures 1-3 include varying degrees of error, an alternate, fully automated, technique will be described with respect to Figures 4 and 5. In accordance with the Figure 4 flow chart, a labeling step 20 similar to that described with respect to Figure 1a is initiated. 15 Further, a file of polygons for an integrated circuit layout layer which includes those polygons located along the arbitrary path is created (i.e., steps 22 and 24) in a manner similar to that described with respect to Figure 1a. Thus, the geometry of any integrated 20 circuit layout layer can be identified to produce the Figure 1a information. However, because a fully automated technique is used for this embodiment, the geometry of a layer which includes the nodes of interest need not be displayed. 25 After building a file of polygons included in a layer of interest, a determination is made as to whether polygons located along the arbitrary path satisfy predetermined design constraints (e.g., minimum width requirements), specified for that path. For this purpose, the step of determining includes a step 26 for verifying that all paths defined by the merged polygons in the layer of interest comply with 5 10 -9- the predetermined design constraints established for the arbitrary path of interest. Any non-conforming geometries represented by portions of the merged polygons which, for example, do not possess the minimum width, are eliminated in step 28. For example, where the path between nodes 1 and 2 possesses a minimum width requirement of $30\lambda$ , geometries which do not conform with this requirement are eliminated. Were the results of this step to be displayed, the resulting geometry for the Figure 1a layer would be as shown by geometry 29 in Figure 5. Remaining polygons of the merged geometries in the layer of interest are subsequently labeled in step 30 with a unique index for each unconnected node. For purposes of illustration, the sole remaining 15 geometry shown in Figure 5 is shown broken down into its original polygon components A, B, C, D, E and F associated with the initial polygon labeling. Using an automated scanning and labeling technique as described in allowed, commonly assigned U.S. Patent No. 20 5,113,451, the disclosure of which is hereby incorporated by reference in its entirety, root polygons are identified. All connected polygons are then merged to identify any unconnected nodes, each of 25 the unconnected nodes being associated with a unique root polygon index. As shown in Figure 5, the only polygons remaining after the step of elimination are all connected. Accordingly, the polygons which form the remaining geometry of Figure 5 would all be associated with a single root polygon index. 30 Having determined the root index for any remaining geometries, the at least two nodes are located relative to these remaining geometries in step 32. The location of each node is then correlated to a 5 10 15 20 25 30 -10- root polygon index for the geometry in which it is located. The unique index for any remaining portion corresponding to a first of the at least two nodes is then compared with the unique index for any remaining portion corresponding to a second of the at least two nodes in step 34. If the unique indices for any remaining portions corresponding to the first and second nodes match, then polygons exist which interconnect the two nodes and which conform to the minimum width requirements specified for the two nodes. indication of the verification of a minimum path width for the arbitrary path specified can then be provided to the designer in step 36. Alternately, if the unique indices for any remaining portions corresponding to the first and second nodes do not match, then there is no path between the at least two nodes which complies with the minimum width requirements specified. In this case, an error in the minimum path width can be indicated to the designer in step 36 so that the integrated circuit layout can be redesigned to conform with the design constraints specified. It will be appreciated by those skilled in the art that the present invention can be embodied in other specific forms without departing from the spirit or essential characteristics thereof. The presently disclosed embodiments are therefore considered in all respects to be illustrative and not restrictive. The scope of the invention is indicated by the appended claims rather than the foregoing description, and all changes that come within the meaning and range of equivalents thereof are intended to be embraced therein. -11- #### What Is Claimed Is: 5 1. Method for designing an integrated circuit layout by verifying that predetermined design constraints are satisfied for an arbitrary path defined by at least two nodes, comprising the steps of: labeling all polygons of said integrated circuit layout with a name which corresponds to a layer of the integrated circuit layout; creating a file of polygons which includes 10 polygons located along said arbitrary path; and determining whether polygons located along said arbitrary path satisfy predetermined design constraints specified for that path. 2. Method according to Claim 1, wherein 15 said step of creating further includes the steps of: identifying a layer of said integrated circuit layout which includes said at least two nodes; and building a file of polygons included in said 20 layer. - 3. Method according to Claim 2, wherein said step of building further includes the step of: sorting and merging said file of polygons to identify those polygons which contact one another. - 4. Method according to Claim 3, wherein said step of determining further includes the steps of: verifying those paths defined by said merged polygons in said layer which comply with a first set of design constraints; and - eliminating those portions of said merged polygons which fail to comply with said predetermined design constraints. -12- 5 - 6. Method according to Claim 5, wherein said step of labeling further includes the steps of: automatically scanning said remaining portions to identify root polygons; and - merging all connected polygons to identify any unconnected nodes, each of said unconnected nodes being associated with only one root polygon upon completion of said scanning, with each root polygon representing one of said unique indices. - 7. Method according to Claim 5, wherein said step of determining further includes the steps of: locating said at least two nodes relative to said remaining portions; and - comparing the unique index for any remaining portion corresponding to a first of said at least two nodes with the unique index for any remaining portion corresponding to a second of said at least two nodes. - 8. Method according to Claim 7, further including a step of: - indicating verification of minimum path width for said arbitrary path if the unique indices for any remaining portions corresponding to said first and said second nodes match. - 9. Method according to Claim 7, further 30 including a step of: indicating an error in minimum path width for said arbitrary path if the unique indices for any 5 10 15 25 30 -13- remaining portions corresponding to said first and said second nodes do not match. 10. Method for designing an integrated circuit layout by verifying that predetermined design constraints are satisfied for an arbitrary path defined by at least two nodes, comprising the steps of: labeling all polygons of said integrated circuit layout with a name which corresponds to a layer of the integrated circuit layout in which each polygon is located: creating a file of polygons which includes polygons located along said arbitrary path; and determining whether polygons located along said arbitrary path satisfy predetermined design constraints specified for that path wherein said step of determining further includes the steps of: verifying those paths defined by said merged polygons in said layer which comply with a first set of design constraints; eliminating those portions of said merged polygons which fail to comply with said predetermined design constraints; labeling any remaining portions of said merged polygons with a unique index for each unconnected node; locating said at least two nodes relative to said remaining portions; and comparing the unique index for any remaining portion corresponding to a first of said at least two nodes with the unique index for any remaining portion corresponding to a second of said at least two nodes. 11. Method according to Claim 10, wherein said step of creating further includes the steps of: -14- identifying a layer of said integrated circuit layout which includes said at least two nodes; and building a file of polygons included in said 5 layer. 12. Method according to Claim 11, wherein said step of building further includes the step of: sorting and merging said file of polygons to identify those polygons which contact one another. \* completion of said scanning, with each root polygon 14. Method according to Claim 12, further 20 including a step of: representing one of said unique indices. indicating verification of minimum path width for said arbitrary path if the unique indices for any remaining portions corresponding to said first and said second nodes match. 25 15. Method according to Claim 12, further including a step of: 30 indicating an error in minimum path width for said arbitrary path if the unique indices for any remaining portions corresponding to said first and said second nodes do not match. FIG.\_1B FIG.\_3B SUBSTITUTE SHEET FIG.\_4 SUBSTITUTE SHEET # INTERNATIONAL SEARCH REPORT International application No. PCT/US93/00217 | A. CLASSIFICATION OF SUBJECT MATTER IPC(5) :G06F 15/60 | | | | | | | | | |--------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------|--|--|--|--|--| | US CL | :364/491 | | · | | | | | | | | to International Patent Classification (IPC) or to both | national classification and IPC | - · · · · · · · · · · · · · · · · · · · | | | | | | | | LDS SEARCHED | | | | | | | | | | locumentation searched (classification system followers 364/488,489,490,578; 371/23;395/500 | of by classification symbols) | | | | | | | | Documental | Documentation searched other than minimum documentation to the extent that such documents are included in the fields searched | | | | | | | | | | | | | | | | | | | Electronic of none | data base consulted during the international search (n | ame of data base and, where practicable | , search terms used) | | | | | | | C. DOC | CUMENTS CONSIDERED TO BE RELEVANT | | | | | | | | | Category* | Citation of document, with indication, where a | ppropriate, of the relevant passages | Relevant to claim No. | | | | | | | X | "Programs for Verifying Circuit Connectivity of MOS/LSI Mask Artwork" by M. Takashima et al., IEEE 19th Design Automation Conference, 1982, pages 544-550; especially, pages 545 and 548-549. | | | | | | | | | <u>X</u><br>Y | US,A, 4,554,625 (Otten) 19 November col. 5, line 10. | 1.2.10.11<br>3-9,12-15 | | | | | | | | A | US,A, 4,791,586 (Maeda et al.) 13 December 1988. See the entire document. | | | | | | | | | Y | US,A, 4,805,113 (Ishii et al.) 14 Feb. 7C. | ruary 1989. See Figures 7A- | 1-15 | | | | | | | | | | | | | | | | | X Further documents are listed in the continuation of Box C. See patent family annex. | | | | | | | | | | "A" do | ecial categories of cited documents:<br>cument defining the general state of the art which is not considered<br>be part of particular relevance | "T" later document published after the inte<br>date and not in conflict with the applica<br>principle or theory underlying the inve | tion but cited to understand the | | | | | | | | rlier document published on or after the international filing date<br>cument which may throw doubts on priority claim(s) or which is | "X" document of particular relevance; the<br>considered novel or cannot be consider<br>when the document is taken alone | e claimed invention cannot be<br>red to involve an inventive step | | | | | | | r cita | ed to establish the publication date of another citation or other<br>scial reason (as specified) cument referring to an oral disclosure, use, exhibition or other | "Y" document of particular relevance; the considered to involve an inventive combined with one or more other such | step when the document is | | | | | | | "P" do | ans<br>cument published prior to the international filing date but later than | being obvious to a person skilled in th "&" document member of the same patent | e art | | | | | | | Date of the actual completion of the international search | | Date of mailing of the international search report | | | | | | | | 14 MAY 1993 28 JUN 1993 | | | | | | | | | | Name and mailing address of the ISA/US Commissioner of Patents and Trademarks Box PCT Washington, D.C. 20231 | | Authorized officer My M Coss WINCENT N. TRANC | | | | | | | | Facsimile No. NOT APPLICABLE | | Telephone No. (703) 305-9750 | | | | | | | Form PCT/ISA/210 (second sheet)(July 1992)★ Ż ## INTERNATIONAL SEARCH REPORT International application No. PCT/US93/00217 | | TO BE BELLEVANT | | |---------------|----------------------------------------------------------------------------------------------------------------------------------------|------------------------| | C (Continua | tion). DOCUMENTS CONSIDERED TO BE RELEVANT | D. Laurente alaba Ma | | Category* | Citation of document, with indication, where appropriate, of the relevant passages | Relevant to claim No. | | A | US,A, 4,829,446 (Draney) 09 May 1989. See the entire document. | 1-15 | | A | US,A, 4,872,103 (Kingsley) 03 October 1989. See the entire document. | 1-15 | | A | US,A, 4,918,614 (Modarres et al.) 17 April 1990. See the entire document. | 1-15 | | <u>X</u><br>Y | US, A, 5,062,054 (Kawakami et al.) 29 October 1991. See abstract; col. 2, line 34- col. 3, line 15; col. 7, line 53- col. 10, line 32. | 1-5,10-12<br>6-9,13-15 | | A | US,A, 5,065,355 (Hayase) 12 November 1991. See the entire document. | 1-15 | | | | | | | | | | | | | | | - | | | | | | | | · | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | | # | | | | ` | | | | | | | | |