System and method of maximizing integrated circuit manufacturing yield with fabrication process simulation driven layout optimization

Information

  • Patent Application
  • 20080046846
  • Publication Number
    20080046846
  • Date Filed
    August 01, 2007
    18 years ago
  • Date Published
    February 21, 2008
    17 years ago
Abstract
A system and a method of maximizing the manufacturing yield of integrated circuit (“IC”) design using IC fabrication process simulation driven layout optimization is described. An IC design layout is automatically modified through formulation of a layout optimization problem utilizing the results of layout fabrication process compliance analysis tools. The modification of layout is performed adaptively and iteratively to make an IC layout less susceptible to yield issues while maintaining design rule correctness and minimal circuit performance impact.
Description

BRIEF DESCRIPTION OF THE DRAWINGS


FIG. 1 illustrates a computing environment used in some embodiments of the present invention.



FIG. 2 illustrates a general flow 200 of fabrication driven layout optimization of the present invention.



FIG. 3 illustrates an LFPCA flow in a lithography process simulation embodiment of the present invention.



FIG. 4 illustrates a CMP process simulation based embodiment of the present invention.



FIG. 5 illustrates a particle defect process simulation based embodiment of the present invention.



FIG. 6 illustrates a generalized LFPCA flow for some embodiment of the present invention.



FIG. 7 illustrates an exemplary implementation of representing the location of an edge with variables in a flat design layout.



FIGS. 8-9 illustrates an exemplary implementation of a transform at one level of hierarchical design.



FIG. 10 illustrates how gradients of position variables of LUF are approximately obtained from some embodiment of the current invention.



FIG. 11 illustrates a sub-design containing two edges.



FIG. 12 illustrates two instances of the sub-design of FIG. 11.





DETAILED DESCRIPTION OF THE PREFERRED

EMBODIMENTS


This invention relates to an integrated circuit mask layout optimization system and an integrated circuit mask layout optimization method, and more to a methodology for maximizing manufacturing yield by using automatic layout optimization driven by IC fabrication process simulation and layout fabrication process compliance analysis. The present invention describes a system and a method of representing layout using a set of variables; formulating metrics of fabrication process quality which is directly correlated to manufacturing yield through LFPCA; identifying a function of sensitivity of each variable representing design to the metrics of LFPCA quality and formulating an optimization problem to maximize manufacturing yield by changing the variables representing a design mask layout data within predefined ranges and within the constraints imposed by design rules and other requirements; iterating the procedure in order to converge to a final optimized result.


In the preferred embodiment, a method of formulation and a method of maximizing manufacturing yield by using layout optimization driven by IC fabrication process simulation and layout fabrication process compliance check is presented.


In the following description, numerous details are set forth for purpose of explanation. However, one of skill in the art will realize that the invention may be practiced with the variations of these specific details. In other instances, well-known structures or operations are not shown in detail to avoid obscuring the invention.


Computing Environment


FIG. 1 illustrates a block diagram of the computing environment that one embodiment of the present invention is implemented. Even though the computer system is described with specific components and architecture for illustration, it should be understood that the present invention might be implemented in several other types of embodiments. For example, the invention can be implemented on single computer with a processor chip containing 2 or more processor cores with each core containing additional hardware to maintain state of two or more threads of execution. In addition, each component can be implemented as a combination of one or more of hardware, software and firmware, even though many features of the present invention are described herein as being implemented in software.


The computing environment 100 may contain one or more components such as a communication fabric 110, random access memory (RAM) 120, central processing unit (CPU) 130, read only memory 140 (ROM), secondary memory (Storage) 150, output devices 160, input Devices 170, network interface 180. All the components may communicate with each other over communication fabric 110. The communication fabric 110 collectively represents all systems, peripherals, chipset buses and all other communication pathways that can connect the components of the computing environment 100. The components of FIG. 1 are described below in further detail.


CPU 130 retrieves the instructions and data to process in order to execute the processes of this invention from the various storage components of computing environment 100. The ROM 140 stores the static instruction and data not modified during normal operation and are needed by CPU 130 and any other component of the computing environment 100. Read-write memory (RAM) 120 is a volatile storage that requires power to be supplied to store the instructions and data. Storage 150 is nonvolatile storage that doesn't need power to store instructions and data. In some embodiments, storage 150 use fixed mass-storage devices such as disk drives. Other embodiments use removal mass-storage devices such as removable disk drives. The RAM 120 stores some of the instructions and data that the CPU 130 needs. In some embodiments, the invention's processes are stored in the CPU 130, RAM 120, ROM 140, and/or storage 150.


The input device 170 enables the user to issue commands to the computing environment. Examples of an input device 170 include but are not limited to, keyboards, mouse, and/or tablet and stylus. The output device 160 is used to display images generate by the computing environment such as but not limited to optimized integrated circuit mask layout.


Network interface 180 may be implemented using protocols such as TCP/IP, ATM and/or Ethernet. In this manner, the computer can be a part of a network of computers (such as a local area network (“LAN”), a wide area network (“WAN”), or an Intranet) or a network of networks (such as the Internet). Any, some or all of the components of computing environment 100 may be used in conjunction with the invention. However, one of ordinary skill in the art would appreciate that any other system configuration may also be used in conjunction with the present invention.


As noted above, CPU 130 may retrieve the software instructions, and execute the instructions to provide various features of the present invention. The features of the present invention are described below in further details.


General Flow

The present invention provides a system and a method of maximizing IC manufacturing yield with IC fabrication process simulation driven layout optimization. An IC design layout is adaptively and iteratively modified in a layout optimization system consisting of a layout fabrication process compliance analysis (“LFPCA”) composed of IC fabrication process simulators and layout process compliance analysis, along with a layout optimization step.


It is an object of the present invention to utilize the LFPCA information during the layout optimization step to reduce the design layout susceptibility to LFPCA identified issues so as to improve manufacturing yield.


It is a further object of the present invention to produce an optimized layout which is design rule correct as well as being layout versus schematic (LVS) correct with fewer fabrication process issues than the original layout.


It is another object of the present invention to allow an optimized layout to have the same design hierarchy as that of the starting layout. In a hierarchical layout, the potential exists for LFPCA issues to be resolved by adjusting instance locations rather than layout edges during the layout optimization step of the present invention.


It is a further object of the present invention to have a optimized layout with none or slight perturbation to design performance and other metrics including, but not limited to, area and timing from the starting layout.



FIG. 2 illustrates a general flow 200 of IC fabrication process simulation driven layout optimization described in the present invention. The starting layout 202 is analyzed at the layout fabrication process compliance analysis (“LFPCA”) step 204. At 206, if there are no LFPCA issues, the process continues to 216 where the process terminates. If there are LPCA issues, the process continues to 208 where formulation of a layout optimization problem to resolve the LPCA issues are constructed using the results of LFPCA analysis as well as design and/or manufacturing layout rules (“design rules”) 218. Layout rules include such rules, but are not limited to, the traditional rules included in design rule documents. The process continues to 210 where a layout optimization problem from 208 is solved to produce the optimized layout 212. At 214, the process determines if the maximum number of iterations or other limits have been reached and returns to 204 with the modified layout if not. If the maximum iterations or other limits have been reached, the process continues to 216 and terminates.



FIG. 3 illustrates an embodiment of a lithography simulation based LFPCA process 300 for the present invention. At 304, the process performs resolution enhancement (“RET”) procedure on the mask layout 302 to produce the post RET layout 308. The RET procedure include such operations such as, but not limited to, construction of OPC features and PSM phase assignments. The lithography simulation 310 accepts the post-RET layout 308 and its results are analyzed at 312 for any RET issues.



FIG. 4 illustrates an embodiment of a CMP process simulation based LFPCA process 400 for the present invention. At 404, the process inserts dummy fill geometries on mask layout 402 to produce the post fill layout 408 that has the required pattern density range of values. The ILD variation analysis 410 accepts the post fill layout 408 and produces data used in the ILD variation analysis step 412.



FIG. 5 illustrates an embodiment of a defect density based simulation based LFPCA process 500 for the present invention. At 504, the process performs a critical area analysis of the mask layout 502.



FIG. 6 illustrates an embodiment of a generalized fabrication process simulation LFPCA process 600 for the present invention. At 604, the process takes as input the mask layout 602 to perform all the operations such as, but not limited to, construction of OPC features, geometry phase assignments for PSM, insertion of sub-resolution assist features (“SRAF”) and insertion of dummy fill geometries for pattern density requirements and produces the post process mask layout 608. At 610, the process run various fabrication process simulations such as, but not limited to, lithography simulations (“litho-simulation”), litho-simulation followed by etch models for the actual semiconductor materials such as metal and poly, ILD variation analysis, and critical area analysis. The results of the various process simulations are analyzed at step 612 for any layout fabrication process compliance issues.


Layout Optimization Problem Formulation

The layout optimization procedure requires a representation for a mask layout data, a collection of constraints to be applied to the mask layout data, and an objective cost function to be optimized. The constraints include such items as, but are not limited to, design rule requirements, circuit requirements, connectivity and preservation of hierarchical design integrity. The mask layout data can either be flat or hierarchical.


Mask Layout Data Representation

A layout optimization will adjust edges of the initial mask layout data to produce an optimized mask layout data. Consequently, a representation of mask layout data edges is a required component of a layout optimization system. FIG. 7 illustrates an exemplary implementation of representing the location of an edge with variables in a flat design layout. It is recognized that in the integrated circuit layout, the angles of all edges are multiples of 45 degrees. Each edge is represented by an angle, and a position variable. In cases when the edge is horizontal as edge 702, the angle is 0 or 180 degrees depending on the selection of the starting end point, the position variable is the intersection of the edge or its extension and Y-axis; in cases when the edge is vertical as edge 704, the angle is 90 or 270 degrees depending on the selection of the starting end point, the position variable is the intersection of the edge or its extension and X-axis; in cases when the angle is 45 or 225 degrees as edge 706 depending on the selection of the starting end point, the position variable is the intersection of the edge or its extension and Y-axis; in cases when the angle is 135 or 315 degrees as edge 708 depending on the selection of the starting end point, the position variable is the intersection of the edge or its extension and Y-axis. A corner in a mask layout is recognized as an artificial product of the two edges that intersects at the corner. It is represented by the variables defining the two edges. The formulation depends on the orientation of the two edges. A shape in a mask layout database is represented by the location of the vertices defining the shapes. There are, of course, numerous methods of representing layout geometries as long as they are canonical.


In a hierarchical design, each leaf design, which has no design descendants, has a chain of design ancestors. Each link of the ancestry carries a transform, which reflects how child design at that level is positioned in parent design. Representation of layout geometries at each design, is then transformed recursively upwards till it gets to top design level. FIG. 8-9 illustrates an exemplary implementation of a transform at one level of hierarchical design.


In FIG. 8, a child design instance 804 is positioned inside its parent design 802. The transform is an offset (x0, y0) with no rotation. A variable x representing a geometrical entity is then transformed to:


x+x0 in the framework of parent design.


A variable y representing a geometrical entity is then transformed to:


y+y0 in the framework of parent design.


In FIG. 9 , a child design instance 908 is positioned inside its parent design 906. The transform is an offset (x0,y0) with a clockwise rotation of 90 degrees. A variable x representing a geometrical entity is then transformed to:


x+y0 in the framework of parent design.


A variable y representing a geometrical entity is then transformed to:


−y+x0 in the framework of parent design.


There are, of course, numerous methods of representing layout geometries in hierarchical design as long as they are canonical.


In a flat layout, an edge of a geometrical entity is normally represented by one position variable for the actual edge itself in some embodiments of the present invention. In a hierarchical layout, an edge of a geometrical entity is can be represented by a combination of position variables, as in an example shown in FIGS. 8-9.


An important implication for hierarchical design layout is that a layout optimization has the possibility of resolving LFPCA issues just by adjusting instance positions.


Cost Function Formulation

The present invention requires an LFPCA system produce a value for undesirability of an LFPCA issue. In one embodiment, a lithography simulation based LFPCA could quantify the quality “lithography friendliness” (“LLF”) as the weighted sum of, among others,

    • a function of square of edge placement error (“EPE”) of relevant edges
    • a function of mask enhancement error factor(“MEEF”) of relevant edges
    • a function of normalized image log slope(“NILS”) of the relevant edges.
    • a function of depth of focus (“DOF”) of the relevant edges.







LLF
litho

=



-

C
EPE






i




func
EPE



(


(

EPE
i

)

2

)




-


C
NILS





i




func
NILS



(

NILS
i

)




-


C
MEEF





i




func
MEEF



(

MEEF
i

)




-


C
DOF





i




func
DOF



(

DOF
i

)









In another embodiment, a CMP process simulation based LFPCA system could quantify the ILD variations in a similar fashion as a function of the fabricated ILD thickness from the target ILD thickness.





VARCMP=ΣfuncILD(ILDsimulated,ILDspec)


In yet another embodiment, a critical area analysis based LFPCA system is perhaps the simplest since it only has to integrate critical area with the defect density distribution to get the expected defect limited yield number.





Yielddefect=∫criticalArea(rd)pdf(rd)drd


where

    • criticalArea(rd)—layout regions sensitivity to defect of size rd
    • pdf(rd)—defect size probability density function


Some embodiments of the present invention use a generalized LFPCA undesirability function with various components for specific fabrication process LFPCA issues for various mask layout data configurations. Since the mask layout data can be represented by a vector {circumflex over (v)}=(v1, v2, . . . , vn) for edges and instances as illustrated in FIGS. 7-9, an LFPCA undesirability function (“LUF”) is a function of the mask layout.


LUF({circumflex over (v)})=k1·LLFlinho({circumflex over (v)})+k2·VARCMP({circumflex over (v)})+k3·Yielddefect({circumflex over (v)})+


Some embodiments of the present invention use LUF as one of the components of the objective cost function for the layout optimization step. In general, the LFPCA procedure is a very complex system involving modeling one or more IC fabrication process steps followed by similarly complex analysis. Some embodiments of the present invention utilize an approximation of an LUF function using response surface modeling (“RSM”) that those versed in the arts will recognized.


When all geometries are represented by polynomials (usually linear combinations) of position variables vi illustrated in FIGS. 7-9 exemplarily, LUF may be viewed as an expansion on these variables:






LUF
=

LUF


|


v
i

=



v
i



(
0
)





i







+



i






LUF




v
i





(


v
i

-


v
i



(
0
)



)




+



i







2


LUF




v
i
2






(


v
i

-


v
i



(
0
)



)

2



+







In one embodiment of the present invention, if changes of all variables vi are limited to a reasonably narrow range, only the 1st order gradients are taken into consideration for the evaluation of LUF to be reasonably accurate, i.e.






LUF
=

LUF


|


v
i

=



v
i



(
0
)





i






+



i






LUF




v
i





(


v
i

-
v

)










or






Δ





LUF

=



i






LUF




v
i




Δ






v
i







Therefore, construction of LUF is equivalent to construction of the lower-order gradients of all position variables of LUF; it is equivalent to the 1st order gradients of all position variables of LUF, given all vi change within a reasonably narrow range.


The advantage of using RSM techniques is that there is a plethora of literature on efficient methods of creating the models. This is especially true for specifying the running of the LFPCA analysis required to build LUF approximate models. Some embodiments utilize the two-level fractional factorial experimental design techniques popularized by Box, Hunter and Hunter. Other embodiments utilize other design of experiment techniques for more complex LUF approximations using such techniques, but not limited to, Latin hypercube and central composite sampling strategies.



FIG. 10 illustrates how gradients of position variables of LUF are approximately obtained at certain values of position variables. By measuring LUF using process simulations, the value of variable vi are sampled around its current value x0. The value of LUF is measured at the sampled value of vi. Those versed in the arts will recognize that the sampling strategy is well covered in the design of experiment literature.


Optimization Constraints

The construction of constraints of the optimization problem is done by enforcing: 1) design constraints including, but not limited to, design area, timing, connectivity for LVS (layout versus schematics) correctness; 2) satisfaction of a set of physical design rules between layout geometries; 3) bounds of position variables due to design requirement limits or step size requirements. These are important for a modified design layout to maintain integrity as far as DRC (design rule correct) and LVS (layout versus schematics) clean, meet reasonable requirements, and to ensure the validity of the constructed optimization problem.


After an optimization problem is solved, and an optimal or close to optimal solution is obtained, the design layout from which the optimization problem is constructed is modified by updating the locations of geometrical entities using the value of position values in the solution.


As the flow illustrated in FIG. 2, the loop terminates when the modified design pass LFPCA, or certain criteria are met. The end result is a design layout that is modified from an existing layout. The DRC correct and LVS clean modified layout maximizes manufacturing yield with minimal IC design quality and performance impacts.


Design Hierarchy Preservation

Some embodiments of the present invention preserve the design layout hierarchy. In some cases, a sub-design representation is replicated as one or more instances within the layout hierarchy and presents an opportunity for some embodiments of the present invention to have layout optimization resolve LFPCA issues by adjusting instance locations rather than adjusting layout edges. In other embodiments, a single layout edge adjustment as part of the layout optimization step can resolve multiple LFPCA issues


This is because an edge in a hierarchical design layout can be represented by two or more location variables as illustrated in FIGS. 8-9. One variable is associated with the edge within the sub-design while another variable describes the location of the instance of the sub-design. FIG. 11 illustrates a sub-design layout A (1100) containing edges e1 (1102) and e2 (1102) with location variables v0=(x0, y0) and V1=(x1, y1) respectively. The location variables v0 and v1 uniquely identifies edges within the layout 1100 and is adjusted by layout optimization process.



FIG. 12 illustrates a layout 1200 that contains two instantiations of sub-design A at 1204 and 1214 respectively. The sub-design A instance 1204 has location variable v10=(x10,y10) and sub-design A instance 1214 has location variable v20=(x20,y20). The four edges 1202, 1206, 1212, and 1216 have position variables which are v0+v10, v1+v10, v0+v20, and v1+v20, respectively. Some embodiments of the present invention could have the layout optimization place a higher weight on adjusting position variables v10 and v20 of FIG. 12. A change in variable v10, for example, could result in changes in edges 1202 and 1206.


Another embodiments of a layout optimization of the present invention could place a higher weight on adjusting variable associated only with edges so that sub-design changes are favored over adjustment of instance position variables. For example, a layout optimization embodiment of the present invention adjusting FIG. 12's v0 variable would change edges 1202 and 1212.


These examples illustrate flexibility for layout optimization embodiment of the present invention in resolving LFPCA issues. This flexibility is a consequence of the present invention's approach to modeling the mask data layout as well as retaining the layout hierarchy.


Although the description above contains many specificities, these should be not be construed as limiting the scope of the invention but merely providing illustrations of some of the presently preferred embodiments of this invention.


Thus the scope of the invention should be determined by the appended claims and their equivalents, rather than by the examples given.

Claims
  • 1. A method of improving the manufacturing yield of integrated circuit comprising the steps: receiving a plurality of integrated circuit layout elements;constructing and allocating a plurality of position variables to a plurality of layout elements, wherein position variables represent the location of edges or points of the plurality of layout elements;constructing a constraint system using the positional variables, wherein the constraints represent relationships of edges or points of the plurality of layout elements;constructing a fabrication process compliance analysis undesirability function with inputs consisting of position variables;establishing an objective function composed of fabrication process compliance analysis undesirability function and weighted sum of plurality of position variables;solving the optimization problem of minimizing the objective function subject to the constraint system requirements; andgenerating new layout from the new position variable values.
  • 2. The method of claim 1, wherein the integrated circuit layout is organized in a hierarchical manner consisting of master cells, plurality of instances of master cells, and plurality of instance arrays of master cells.
  • 3. The method of claim 2 further comprising the step of: constructing and allocating a plurality of position variables to a plurality of master cell instances and to a plurality of instance arrays of master cells.
  • 4. The method of claim 1, wherein the step of constructing the fabrication process compliance analysis undesirability function incorporates lithographic considerations.
  • 5. The method of claim 1, wherein the step of constructing the fabrication process compliance analysis undesirability function incorporates critical area considerations.
  • 6. The method of claim 1, wherein the step of constructing the fabrication process compliance analysis undesirability function incorporates chemical mechanical polishing related considerations.
  • 7. The method of claim 1, wherein the step of constructing the fabrication process compliance analysis undesirability function incorporates weighted sum of lithographic, critical area and chemical mechanical polishing considerations. 10
  • 8. A system of improving the manufacturing yield of integrated circuit comprising the steps: means of receiving a plurality of integrated circuit layout elements;means of constructing and allocating a plurality of position variables to a plurality of layout elements, wherein position variables represent the location of edges or points of the plurality of layout elements;means of constructing a constraint system using the positional variables, wherein the constraints represent relationships of edges or points of the plurality of layout elements;means of constructing a fabrication process compliance analysis undesirability function with inputs consisting of position variables;means of establishing an objective function composed of fabrication process compliance analysis undesirability function and weighted sum of plurality of position variables;means of solving the optimization problem of minimizing the objective function subject to the constraint system requirements; andmeans of generating new layout from the new position variable values.
  • 9. The system of claim 8, wherein the integrated circuit layout is organized in a hierarchical manner consisting of master cells, plurality of instances of master cells, and plurality of instance arrays of master cells.
  • 10. The system of claim 9 further comprising the step of: means of constructing and allocating a plurality of position variables to a plurality of master cell instances and to a plurality of instance arrays of master cells.
  • 11. The system of claim 8, wherein the means of constructing the fabrication process compliance analysis undesirability function incorporates lithographic considerations.
  • 12. The system of claim 8, wherein the means of constructing the fabrication process compliance analysis undesirability function incorporates critical area considerations.
  • 13. The system of claim 8, wherein the means of constructing the fabrication process compliance analysis undesirability function incorporates chemical mechanical polishing related considerations.
  • 14. The system of claim 8, wherein the means of constructing the fabrication process compliance analysis undesirability function incorporates weighted sum of lithographic, critical area and chemical mechanical polishing considerations.
CLAIM OF BENEFIT TO PROVISIONAL APPLICATION

This patent application claims the benefit of the earlier filed U.S. Provisional Patent Application entitled “System and method of maximizing integrated circuit manufacturing yield with fabrication process simulation driven layout optimization”, having Ser. No. 60/838,023, and filed Aug. 15, 2006.

Provisional Applications (1)
Number Date Country
60838023 Aug 2006 US