US20110288671A1 - Equation based retargeting of design layouts - Google Patents
Equation based retargeting of design layouts Download PDFInfo
- Publication number
- US20110288671A1 US20110288671A1 US12/782,407 US78240710A US2011288671A1 US 20110288671 A1 US20110288671 A1 US 20110288671A1 US 78240710 A US78240710 A US 78240710A US 2011288671 A1 US2011288671 A1 US 2011288671A1
- Authority
- US
- United States
- Prior art keywords
- combination
- values
- layout
- computer usable
- desirable
- Prior art date
- Legal status (The legal status is an assumption and is not a legal conclusion. Google has not performed a legal analysis and makes no representation as to the accuracy of the status listed.)
- Granted
Links
- 238000013461 design Methods 0.000 title claims abstract description 81
- 238000000034 method Methods 0.000 claims abstract description 62
- 238000012545 processing Methods 0.000 claims description 41
- 238000004519 manufacturing process Methods 0.000 claims description 19
- 238000004088 simulation Methods 0.000 claims description 13
- 238000003860 storage Methods 0.000 claims description 12
- 238000001459 lithography Methods 0.000 claims description 8
- 230000008569 process Effects 0.000 description 38
- 238000005457 optimization Methods 0.000 description 23
- 230000015654 memory Effects 0.000 description 22
- 238000010586 diagram Methods 0.000 description 7
- 230000003287 optical effect Effects 0.000 description 6
- 238000012938 design process Methods 0.000 description 5
- 238000004891 communication Methods 0.000 description 4
- 238000013500 data storage Methods 0.000 description 3
- XUIMIQQOPSSXEZ-UHFFFAOYSA-N Silicon Chemical compound [Si] XUIMIQQOPSSXEZ-UHFFFAOYSA-N 0.000 description 2
- 238000013459 approach Methods 0.000 description 2
- 238000004590 computer program Methods 0.000 description 2
- 239000004744 fabric Substances 0.000 description 2
- 230000006870 function Effects 0.000 description 2
- 238000012986 modification Methods 0.000 description 2
- 230000004048 modification Effects 0.000 description 2
- 230000002093 peripheral effect Effects 0.000 description 2
- 238000000206 photolithography Methods 0.000 description 2
- 229920003023 plastic Polymers 0.000 description 2
- 239000004065 semiconductor Substances 0.000 description 2
- 229910052710 silicon Inorganic materials 0.000 description 2
- 239000010703 silicon Substances 0.000 description 2
- 229920000426 Microplastic Polymers 0.000 description 1
- 230000008859 change Effects 0.000 description 1
- 238000012937 correction Methods 0.000 description 1
- 230000000694 effects Effects 0.000 description 1
- 238000005516 engineering process Methods 0.000 description 1
- 238000001914 filtration Methods 0.000 description 1
- 239000012535 impurity Substances 0.000 description 1
- 238000005259 measurement Methods 0.000 description 1
- 239000002184 metal Substances 0.000 description 1
- 238000007639 printing Methods 0.000 description 1
- 230000005855 radiation Effects 0.000 description 1
- 239000007787 solid Substances 0.000 description 1
- 239000000758 substrate Substances 0.000 description 1
- 238000012360 testing method Methods 0.000 description 1
- 238000012546 transfer Methods 0.000 description 1
- 238000012795 verification Methods 0.000 description 1
Images
Classifications
-
- G—PHYSICS
- G03—PHOTOGRAPHY; CINEMATOGRAPHY; ANALOGOUS TECHNIQUES USING WAVES OTHER THAN OPTICAL WAVES; ELECTROGRAPHY; HOLOGRAPHY
- G03F—PHOTOMECHANICAL PRODUCTION OF TEXTURED OR PATTERNED SURFACES, e.g. FOR PRINTING, FOR PROCESSING OF SEMICONDUCTOR DEVICES; MATERIALS THEREFOR; ORIGINALS THEREFOR; APPARATUS SPECIALLY ADAPTED THEREFOR
- G03F1/00—Originals for photomechanical production of textured or patterned surfaces, e.g., masks, photo-masks, reticles; Mask blanks or pellicles therefor; Containers specially adapted therefor; Preparation thereof
- G03F1/36—Masks having proximity correction features; Preparation thereof, e.g. optical proximity correction [OPC] design processes
-
- G—PHYSICS
- G03—PHOTOGRAPHY; CINEMATOGRAPHY; ANALOGOUS TECHNIQUES USING WAVES OTHER THAN OPTICAL WAVES; ELECTROGRAPHY; HOLOGRAPHY
- G03F—PHOTOMECHANICAL PRODUCTION OF TEXTURED OR PATTERNED SURFACES, e.g. FOR PRINTING, FOR PROCESSING OF SEMICONDUCTOR DEVICES; MATERIALS THEREFOR; ORIGINALS THEREFOR; APPARATUS SPECIALLY ADAPTED THEREFOR
- G03F1/00—Originals for photomechanical production of textured or patterned surfaces, e.g., masks, photo-masks, reticles; Mask blanks or pellicles therefor; Containers specially adapted therefor; Preparation thereof
- G03F1/68—Preparation processes not covered by groups G03F1/20 - G03F1/50
- G03F1/70—Adapting basic layout or design of masks to lithographic process requirements, e.g., second iteration correction of mask patterns for imaging
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F30/00—Computer-aided design [CAD]
- G06F30/30—Circuit design
- G06F30/39—Circuit design at the physical level
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F2119/00—Details relating to the type or aim of the analysis or the optimisation
- G06F2119/18—Manufacturability analysis or optimisation for manufacturability
-
- H—ELECTRICITY
- H01—ELECTRIC ELEMENTS
- H01L—SEMICONDUCTOR DEVICES NOT COVERED BY CLASS H10
- H01L27/00—Devices consisting of a plurality of semiconductor or other solid-state components formed in or on a common substrate
- H01L27/02—Devices consisting of a plurality of semiconductor or other solid-state components formed in or on a common substrate including semiconductor components specially adapted for rectifying, oscillating, amplifying or switching and having potential barriers; including integrated passive circuit elements having potential barriers
- H01L27/0203—Particular design considerations for integrated circuits
-
- Y—GENERAL TAGGING OF NEW TECHNOLOGICAL DEVELOPMENTS; GENERAL TAGGING OF CROSS-SECTIONAL TECHNOLOGIES SPANNING OVER SEVERAL SECTIONS OF THE IPC; TECHNICAL SUBJECTS COVERED BY FORMER USPC CROSS-REFERENCE ART COLLECTIONS [XRACs] AND DIGESTS
- Y02—TECHNOLOGIES OR APPLICATIONS FOR MITIGATION OR ADAPTATION AGAINST CLIMATE CHANGE
- Y02P—CLIMATE CHANGE MITIGATION TECHNOLOGIES IN THE PRODUCTION OR PROCESSING OF GOODS
- Y02P90/00—Enabling technologies with a potential contribution to greenhouse gas [GHG] emissions mitigation
- Y02P90/02—Total factory control, e.g. smart factories, flexible manufacturing systems [FMS] or integrated manufacturing systems [IMS]
Definitions
- the present invention relates generally to an improved integrated circuit design system, and in particular, to a method for modifying an integrated circuit design for manufacture. Still more particularly, the present invention relates to a method, system, and computer usable program code for equation based retargeting of design layouts.
- Modern day electronics include components that use integrated circuits (ICs).
- ICs are electronic circuits formed using Silicon as a substrate and by adding impurities to form solid-state electronic devices, such as transistors, diodes, and resistors.
- Solid-state electronic devices such as transistors, diodes, and resistors.
- a chip an integrated circuit is generally encased in hard plastic.
- the components in modern day electronics generally appear to be rectangular black plastic pellets with connector pins protruding from the plastic encasement.
- Circuit designers use a variety of software tools to design and test electronic circuits that accomplish an intended task.
- a digital circuit may be designed to accept digital inputs, perform some computation, and produce a digital output.
- An analog circuit may be designed to accept analog signals, manipulate the analog signals, such as my amplifying, filtering, or mixing the signals, and produce an analog or digital output.
- any type of circuit can be designed as an IC.
- a design layout also referred to simply as a layout
- the design is converted into a set of masks for lithography.
- a set of masks for lithography is one or more masks for lithography.
- a Silicon wafer is exposed to light or radiation through a set of masks to form microscopic components of the IC.
- a layout includes shapes that the designer selects and positions to achieve a design objective.
- the objective is to have the shape—the target shape—appear on the wafer as designed.
- the shapes may not appear exactly as designed when manufactured on the wafer through photolithography. For example, a rectangular shape with sharp corners may appear as a rectangular shape with rounded corners on the wafer.
- the illustrative embodiments provide a method, system, and computer usable program product for equation based retargeting of design layout.
- an embodiment determines a set of desirable combination of values of a set of layout parameters of the design layout.
- the embodiment determines a desirable region including the set of the desirable combination of values.
- the embodiment computes an equation to determine a retargeting value for a first combination of values of the set of layout parameters with respect to the desirable region.
- the embodiment generates instructions to adjust a value in the first combination to generate a second combination of values of the set of layout parameters such that the second combination falls in the desirable region.
- the embodiment retargets a shape in the design layout to form a retargeted shape such that the retargeted shape uses the second combination of values of the set of layout parameters.
- An embodiment may manufacture the IC using the retargeted shape.
- FIG. 1 depicts a block diagram of an IC design process in which the illustrative embodiments may be implemented
- FIG. 2 depicts a block diagram of a data processing system in which illustrative embodiments may be implemented
- FIG. 3 depicts a block diagram of an IC design process including equation based retargeting in accordance with an illustrative embodiment
- FIG. 4 depicts a graph of a continuous relationship between two example layout parameters in accordance with an illustrative embodiment
- FIG. 5 depicts a flowchart of a process of equation based retargeting in accordance with an illustrative embodiment
- FIG. 6 depicts a flowchart of a process of equation based retargeting in accordance with an illustrative embodiment.
- a layout of an IC has to conform to certain design rules.
- a design rule may specify that a component cannot exceed a specified size, or be within a specified distance of another specified component.
- a layout that conforms to all the applicable design rules is called a design rule clean layout.
- a design rule clean layout may not be producible on a wafer for a variety of reasons. For example, light may diffuse to cause a sharp corner of a shape in a mask to appear rounded on the wafer. To correct for manufacturing idiosyncrasies, optical distortion, distance limitations, and other manufacturing considerations the shapes in a layout may be adjusted.
- mask optimization which may include optical proximity correction (OPC) is utilized to make changes to a mask so that the mask can compensate for manufacturing limitations.
- OPC optical proximity correction
- the shaped provided by a designer have been used as the shapes for lithography.
- the invention recognizes that with the ever-reducing size of IC components and the increasing number of components per unit area, the designer provided shapes are becoming increasingly difficult to reproduce on wafer.
- the illustrative embodiments used to describe the invention address and solve these and other problems related to printing shapes of a layout in photolithography.
- the illustrative embodiments provide a method, computer usable program product, and an apparatus for equation based retargeting of design layouts.
- Retargeting modifies the shapes provided by the designer to generate new target shapes that have improved printability.
- Retargeting according to an embodiment is different from mask optimization.
- Present mask optimization process changes the mask for manufacturability and not the target layout.
- Retargeting according to an embodiment changes the shapes that are used to produce the mask.
- a rule based retargeting method employs simple one or two dimensional retargeting rules to modify shapes that are known to cause difficulties at the manufacturing stage.
- a rule based retargeting method may include a retargeting rule that for a given pitch and width of a component M 1 , bias the metal shapes by x nanometers.
- Another example rule in rule based retargeting may be that if a notch is of size y nanometers, fill the notch by z nanometers.
- rule based retargeting suffers from several limitations. For example, all possible poor manufacturability conditions have to be known a priori to create corresponding retargeting rules. However, the invention recognizes that such knowledge is not always available and therefore the rules created are limited in the conditions they can correct, leaving certain layout conditions uncorrected.
- Bucketing is the process of applying a set, or bucket, of rules to a set of conditions as a whole. Accordingly, some conditions are better addressed by a bucket of rules than other conditions addressed by the same bucket of rules.
- Application of the rules is choppy and not continuous over the range of conditions that may require retargeting.
- rules are inadequate where retargeting value depends on more than two layout parameters. Typical rules are one or two dimensional and can not cover the multi-dimensional layout space.
- Model based retargeting retargets shapes during mask optimization iterations.
- the retargeting operation is included with the mask optimization operation so that the retargeting is done as a part of the iterations of the mask optimization process.
- the invention recognizes that mask optimization itself is a computationally intensive process. Including retargeting steps in the mask optimization process causes the mask optimization process to consume even more time and computing resources.
- results of retargeting in model based retargeting are not predictable in advance.
- the retargeting results from mask optimization iterations cannot be made available to the designer in advance. Accordingly, a designer cannot evaluate whether or not a retargeted shape is acceptable within other design considerations.
- An embodiment of the invention provides a middle path between the rule based retargeting approach and a model based retargeting approach.
- An embodiment improves coverage of retargeting over rule based retargeting, while reducing the complexity of retargeting over the model based retargeting.
- An embodiment improves the accuracy of retargeting over the rule based retargeting method while imposing less runtime overhead as compared to the model based retargeting method.
- the illustrative embodiments are described using specific code, data structures, designs, layouts, schematics, and tools only as examples and are not limiting on the illustrative embodiments.
- the illustrative embodiments may be implemented with respect to other similarly purposed code, data structures, designs, layouts, schematics, and tools within the scope of the invention.
- the illustrative embodiments may be described in some instances using particular systems, applications, or architectures only as an example for the clarity of the description.
- the illustrative embodiments may be used in conjunction with other comparable or similarly purposed systems, applications, or architectures.
- Process 100 can be loosely divided into three stages, namely, design stage 102 , mask optimization stage 104 where, for example mask optimization may be performed, and manufacturing stage 106 .
- Chip design application 108 may be a software application usable for creating shapes in a design layout.
- Application 108 may accept design specification 110 as an input, which may specify a goal to be accomplished by the design layout.
- Design rules 112 may be a set of design rules.
- a set of rules is one or more rules.
- a set of design rules is one or more design rules.
- Rules 112 may or may not include rules for rule based retargeting.
- Design 114 may include a set of shapes—the set of target shapes.
- a set of shapes is one or more shapes.
- a set of target shapes is one or more target shapes.
- Design 114 including a set of target shapes is provided to mask optimization (OPC) stage 104 .
- Mask optimization application 116 may be a software application configured to generate a set of masks suitable for manufacturing design 114 on wafer.
- Application 116 may execute any number of mask optimization iterations to optimize or modify one or more mask shapes.
- Application 116 may or may not include instructions for model based retargeting.
- Application 116 provides a set of mask shapes, or masks, to manufacturing stage 106 .
- Masks 118 is such a set of masks.
- Chip manufacturing system 120 uses masks 118 to produce one or more patterns on a wafer.
- the patterns so produced accomplish the objectives specified in specification 110 .
- a shape created on the wafer may be retargeted and may not be similar to the corresponding target shape in design 114 .
- Data processing system 200 is an example of a computer, such as server 104 or client 110 in FIG. 1 , in which computer usable program code or instructions implementing the processes may be located for the illustrative embodiments.
- data processing system 200 employs a hub architecture including North Bridge and memory controller hub (NB/MCH) 202 and south bridge and input/output (I/O) controller hub (SB/ICH) 204 .
- Processing unit 206 , main memory 208 , and graphics processor 210 are coupled to north bridge and memory controller hub (NB/MCH) 202 .
- Processing unit 206 may contain one or more processors and may be implemented using one or more heterogeneous processor systems.
- Graphics processor 210 may be coupled to the NB/MCH through an accelerated graphics port (AGP) in certain implementations.
- AGP accelerated graphics port
- local area network (LAN) adapter 212 is coupled to south bridge and I/O controller hub (SB/ICH) 204 .
- Audio adapter 216 , keyboard and mouse adapter 220 , modem 222 , read only memory (ROM) 224 , universal serial bus (USB) and other ports 232 , and PCI/PCIe devices 234 are coupled to south bridge and I/O controller hub 204 through bus 238 .
- Hard disk drive (HDD) 226 and CD-ROM 230 are coupled to south bridge and I/O controller hub 204 through bus 240 .
- PCI/PCIe devices may include, for example, Ethernet adapters, add-in cards, and PC cards for notebook computers. PCI uses a card bus controller, while PCIe does not.
- ROM 224 may be, for example, a flash binary input/output system (BIOS).
- Hard disk drive 226 and CD-ROM 230 may use, for example, an integrated drive electronics (IDE) or serial advanced technology attachment (SATA) interface.
- IDE integrated drive electronics
- SATA serial advanced technology attachment
- a super I/O (SIO) device 236 may be coupled to south bridge and I/O controller hub (SB/ICH) 204 .
- An operating system runs on processing unit 206 .
- the operating system coordinates and provides control of various components within data processing system 200 in FIG. 2 .
- the operating system may be a commercially available operating system such as Microsoft° Windows® (Microsoft and Windows are trademarks of Microsoft Corporation in the United States and other countries), or Linux° (Linux is a trademark of Linus Torvalds in the United States and other countries).
- An object oriented programming system such as the JavaTM programming system, may run in conjunction with the operating system and provides calls to the operating system from JavaTM programs or applications executing on data processing system 200 (Java is a trademark of Sun Microsystems, Inc., in the United States and other countries).
- Instructions for the operating system, the object-oriented programming system, and applications or programs are located on storage devices, such as hard disk drive 226 , and may be loaded into main memory 208 for execution by processing unit 206 .
- the processes of the illustrative embodiments may be performed by processing unit 206 using computer implemented instructions, which may be located in a memory, such as, for example, main memory 208 , read only memory 224 , or in one or more peripheral devices.
- FIGS. 1-2 may vary depending on the implementation.
- Other internal hardware or peripheral devices such as flash memory, equivalent non-volatile memory, or optical disk drives and the like, or other comparable software or firmware may be used in addition to or in place of the hardware depicted in FIGS. 1-2 .
- the processes of the illustrative embodiments may be applied to a multiprocessor data processing system.
- data processing system 200 may be a personal digital assistant (PDA), which is generally configured with flash memory to provide non-volatile memory for storing operating system files and/or user-generated data.
- PDA personal digital assistant
- a bus system may comprise one or more buses, such as a system bus, an I/O bus, and a PCI bus.
- the bus system may be implemented using any type of communications fabric or architecture that provides for a transfer of data between different components or devices attached to the fabric or architecture.
- a communications unit may include one or more devices used to transmit and receive data, such as a modem or a network adapter.
- a memory may be, for example, main memory 208 or a cache, such as the cache found in north bridge and memory controller hub 202 .
- a processing unit may include one or more processors or CPUs.
- data processing system 200 also may be a tablet computer, laptop computer, or telephone device in addition to taking the form of a PDA.
- FIG. 3 this figure depicts a block diagram of an IC design process including equation based retargeting in accordance with an illustrative embodiment.
- Process 300 can be loosely divided into four stages, namely, design stage 302 , retargeting stage 304 , mask optimization (OPC) stage 306 , and manufacturing stage 308 .
- Design stage 302 , mask optimization stage 306 , and manufacturing stage 308 may be similar to design stage 102 , mask optimization stage 104 , and manufacturing stage 106 respectively in FIG. 1 .
- Chip design application 310 may operate in a manner similar to application 108 in FIG. 1 .
- Specification 312 and design rules 314 may be similar to specification 110 and design rule 112 respectively in FIG. 1 .
- Target shapes 316 may be similar to target shapes included in design 114 in FIG. 1 .
- Retargeting stage 304 may include an embodiment of the invention in equation based retargeting application 318 .
- equation based retargeting application 318 may operate as a distinct step after the design process is complete and before the mask optimization process is executed.
- Application 318 outputs a set of retargeted shapes.
- Retargeted shapes 320 is such a set.
- Retargeted shapes 320 may include retargeted shapes for some or all of target shapes 316 .
- Retargeted shapes 320 are provided to mask optimization application 322 , which may produce set of masks 324 as described in FIG. 1 .
- Retargeting stage 304 is depicted as a distinct stage only for the clarity of the description and is not a limitation on the invention.
- retargeting stage 304 may be an extension of either design stage 302 or mask optimization stage 306 within the scope of the invention.
- equation based retargeting application 318 may be configured to operate with chip design application 310 .
- equation based retargeting application 318 may be configured to operate with a mask optimization process, such as in mask optimization application 322 .
- Equation based retargeting determines a continuous relationship between an amount of retargeting and a set of layout parameters.
- a layout parameter is a feature, measurement, limitation, constraint, dimension, specification, or another aspect in the layout.
- a set of layout parameters is one or more layout parameter.
- any factor affecting a layout can be used as a layout parameter.
- any aspect of a layout or a component therein that is alterable during retargeting can be a layout parameter within the scope of the invention.
- width of components may be an example layout parameter. Spacing between components in the layout may be another example layout parameter.
- a continuous relationship can be plotted as a continuous n-dimensional surface in an n-dimensional graph, where n is the number of layout parameters in the set.
- a first continuous relationship may exist between the n parameters, where n may be the number of layout parameters in the set.
- the relationship may be depicted in an n-dimensional space and desirable relationship contours in the n-dimensional space may identify the desirable relationship values or combinations for the n parameters.
- retargeting value “R” may be an n-tuple where n is the number of layout parameters in the set.
- the retargeting value may be an (n ⁇ x) tuple, (n ⁇ x) being the number of parameters to be retargeted in a subset of the set of parameters.
- a second continuous relationship may exist between the retargeting value such that the retargeting value is depicted in the (n+1) st dimension and the second relationship is capable of being depicted in the n+1 dimensional space.
- a continuous relationship between retargeting value and a set of layout parameters is a relationship such that for any given values of layout parameters in a set of layout parameters, the relationship equation can provide corresponding desirable values, or retargeting values, for one or more layout parameters in the set.
- a continuous relationship is distinct from a discrete relationship in that a discrete relationship provides corresponding retargeting values at only certain discrete values of layout parameters in the set.
- discrete relationships are implemented as rules, which then provide choppy or bucketed coverage for retargeting layout shapes.
- this figure depicts a graph of a continuous relationship between two example layout parameters in accordance with an illustrative embodiment.
- Region 402 represents the desirable region and regions 404 and 406 in the graph represent the combinations of the two layout parameters that may be undesirable.
- This relationship between the layout parameters enables determining an amount of retargeting for one or more layout parameters given the values of one or more layout parameters in a set of parameters.
- Graph 400 may be produced, used, or implied by the computations implemented in an equation based retargeting application, such as application 318 in FIG. 3 .
- the equation based retargeting application determines a polynomial equation that determines a retargeting value according to graph 400 such that undesirable layout parameter combinations from region 404 and 406 are moved to the desirable region 402 .
- graph 400 is plotted as a two-dimensional graph using two example layout parameters, viz, spacing and width of components in a layout.
- Graph 400 is generated from experimentation or simulation using an example layout.
- an example layout having similar component densities, composition, scale, and complexity as a design to be manufactured may be used to produce graph 400 .
- the retargeting relationship may allow determining a retargeting of the width by a retargeting value which is determined by an equation which is a function of width and spacing.
- the example relationship between the width and the spacing parameters can be represented as two dimensional contours or graph where the X and Y axes are width and spacing values.
- a retargeting value “R” gives the amount of retargeting needed for a given parameter such that after retargeting, the relationship of layout parameters comes within the desirable contours or regions.
- an embodiment does not require that the actual design having the actual shapes that are to be manufactured be used for producing the graph and the corresponding equation.
- An example layout may be used to determine the polynomial retargeting equation. The equation can then be converted into computational instructions and used to retarget shapes in actual production layouts.
- a simulation using an example layout generates points representing corresponding values of the set of layout parameters being plotted.
- the simulation may be executed for generating any number of such points. For example, in depicted graph 400 , certain points are shown at which the simulation is performed. Each point corresponds to a particular combination of width and spacing.
- the desirable combinations of the width and spacing parameters are noted as the discrete desirable points in the relationship between the width parameter and the spacing parameter.
- desirable combination of the width and spacing parameter values may lie in region 402 . Points lying in regions 404 and 406 may represent undesirable combinations of the width and spacing values.
- a set of such desirable points may be obtained through sufficient simulation, the set including two or more points, if required, a set of undesirable points may also be obtained in a similar manner.
- Point 408 is an example member of such a set of desirable points in example graph 400 .
- the size of the set of discrete desirable points may be any size suitable for a particular implementation and may be achieved through suitable number of simulations within the scope of the invention. For example, a two dimensional contour for retargeting based on just two parameters may require fewer points to generate as compared to an 8-dimension surface that connects the desirable 8-tuples in an 8-dimension graph.
- Region 402 may be a desirable relationship contour or region in the space of graph 400 .
- region 402 may be more than one region in graph 400 , forming a set of desirable relationship contours.
- Desirable relationship contour 402 is one or more continuous curve, either open or closed, that represents the desirable relationships between the example width and spacing parameters.
- contour 402 may take an n-dimensional form within the scope of the invention.
- Equation 410 represents the equation that, for any point in graph 400 , such as point 412 , answers the question—which parameter should be retargeted by what retargeting value such that the point moves within one of desirable relationship contour 402 .
- the value “R” provided by the equation for given values of W and S for a given point 412 in graph 400 represents the retargeting of that point such that the point falls on or within (one or more of) desirable relationship contour 402 .
- Example equation 410 is a polynomial function of two variables only as an example.
- equation 410 may be a polynomial equation in n variables within the scope of the invention.
- the retargeting value for any point in graph 400 can be determined. If a point is already within a desirable relationship contour, the equation returns a retargeting value that is below a threshold. For example, R may be zero or a negligible value. On the other hand, if a point is not on or within a desirable relationship contour, the equation returns a value of R that is above a threshold.
- the equation can then be implemented in an equation based retargeting application.
- the retargeting application accepts a design including a set of target shapes.
- the retargeting application determines whether for a shape in the design, a parameter or a combination of parameters that participates in the equation is outside the desirable relationship contours.
- the retargeting application determines a retargeting value R according to the equation.
- the retargeting application can then adjust one or more parameters for that shape, such that the combination of the adjusted values of the set of parameters falls on or within at least one of the desirable relationship contours.
- Process 500 may be implemented in an equation based retargeting application, such as equation based retargeting application 318 in FIG. 3 .
- Process 500 begins by receiving a set of target shapes in a layout (step 502 ).
- Process 500 executes a lithography simulation (step 504 ).
- Process 500 obtains a set of layout parameters (step 506 ).
- the set of layout parameters may be specified prior to the simulation, such as when certain parameters are preferred for retargeting.
- the set of parameters may be an output of the simulation, such as when the simulation indicates which parameters may be effective in retargeting within the specified constraints. Not all the layout parameters in the set of layout parameters may necessarily be used to compute the equation according to an embodiment.
- Process 500 obtains a set of desirable relationships between a subset of the layout parameters (step 508 ).
- Process 500 identifies one or more continuous surface representations or regions that include the discrete desirable relationship points (step 510 ). Desirable relationship contours 402 in FIG. 4 is an example of such one or more continuous surfaces in two dimensions. The continuous surfaces of step 510 may be in any number of dimensions without limitations.
- Process 500 determines an equation that computes a retargeting value for a discrete point in the n dimensional layout space with respect to a continuous surface, such as the desirable region, in the space (step 512 ).
- the retargeting value represents the retargeting of one or more parameters to bring the discrete point on or within at least one of the continuous surfaces.
- Process 500 determines whether additional combinations of the layout parameters have to be examined (step 514 ). If additional combinations of layout parameters have to be examined (“Yes” path of step 514 ), process 500 returns to step 504 . If no additional layout parameter combination has to be plotted (“No” path of step 514 ), process 500 generates the instructions to implement the equation (step 516 ). In one embodiment, process 500 may generate a set of equations, such as for different combinations of layout parameters. A set of equations is one or more equations. In such a case, process 500 may generate instructions for the set of equations in step 516 . Process 500 ends thereafter.
- FIG. 6 this figure depicts a flowchart of a process of equation based retargeting in accordance with an illustrative embodiment.
- Process 600 may be implemented in an equation based retargeting application, such as equation based retargeting application 318 in FIG. 3 .
- Process 600 begins by receiving a set of target shapes in a layout (step 602 ).
- Process 600 computes a retargeting bias for a target shape using a subset of the equations, such as the set of equations generated in process 500 in FIG. 5 (step 604 ).
- process 600 may repeat step 604 for several iterations.
- Process 600 produces a retargeted shape for the layout and ends thereafter.
- a computer implemented method, apparatus, and computer program product are provided in the illustrative embodiments for equation based retargeting of design layouts.
- one or more shapes in a given design layout can be retargeted more accurately as compared to a rule based retargeting method while incurring less cost as compared to a model based retargeting method.
- the retargeted shapes can be made available to designers for verification before masks are produced from the retargeted layout.
- the invention can take the form of an entirely software embodiment, or an embodiment containing both hardware and software elements.
- the invention is implemented in software or program code, which includes but is not limited to firmware, resident software, and microcode.
- the invention can take the form of a computer program product accessible from a computer-usable or computer-readable medium providing program code for use by or in connection with a computer or any instruction execution system.
- a computer-usable or computer-readable medium can be any tangible apparatus that can contain, store, communicate, propagate, or transport the program for use by or in connection with the instruction execution system, apparatus, or device.
- the medium can be an electronic, magnetic, optical, electromagnetic, infrared, or semiconductor system (or apparatus or device) or a propagation medium.
- Examples of a computer-readable medium include a semiconductor or solid state memory, magnetic tape, a removable computer diskette, a random access memory (RAM), a read-only memory (ROM), a rigid magnetic disk, and an optical disk.
- Current examples of optical disks include compact disk-read only memory (CD-ROM), compact disk-read/write (CD-R/W) and DVD.
- a computer storage medium may contain or store a computer-readable program code such that when the computer-readable program code is executed on a computer, the execution of this computer-readable program code causes the computer to transmit another computer-readable program code over a communications link.
- This communications link may use a medium that is, for example without limitation, physical or wireless.
- a data processing system suitable for storing and/or executing program code will include at least one processor coupled directly or indirectly to memory elements through a system bus.
- the memory elements can include local memory employed during actual execution of the program code, bulk storage media, and cache memories, which provide temporary storage of at least some program code in order to reduce the number of times code must be retrieved from bulk storage media during execution.
- a data processing system may act as a server data processing system or a client data processing system.
- Server and client data processing systems may include data storage media that are computer usable, such as being computer readable.
- a data storage medium associated with a server data processing system may contain computer usable code.
- a client data processing system may download that computer usable code, such as for storing on a data storage medium associated with the client data processing system, or for using in the client data processing system.
- the server data processing system may similarly upload computer usable code from the client data processing system.
- the computer usable code resulting from a computer usable program product embodiment of the illustrative embodiments may be uploaded or downloaded using server and client data processing systems in this manner.
- I/O devices including but not limited to keyboards, displays, pointing devices, etc.
- I/O controllers can be coupled to the system either directly or through intervening I/O controllers.
Landscapes
- Physics & Mathematics (AREA)
- Engineering & Computer Science (AREA)
- General Physics & Mathematics (AREA)
- Computer Hardware Design (AREA)
- Theoretical Computer Science (AREA)
- Evolutionary Computation (AREA)
- Geometry (AREA)
- General Engineering & Computer Science (AREA)
- Design And Manufacture Of Integrated Circuits (AREA)
Abstract
Description
- 1. Field of the Invention
- The present invention relates generally to an improved integrated circuit design system, and in particular, to a method for modifying an integrated circuit design for manufacture. Still more particularly, the present invention relates to a method, system, and computer usable program code for equation based retargeting of design layouts.
- 2. Description of the Related Art
- Modern day electronics include components that use integrated circuits (ICs). Integrated circuits are electronic circuits formed using Silicon as a substrate and by adding impurities to form solid-state electronic devices, such as transistors, diodes, and resistors. Commonly known as a “chip”, an integrated circuit is generally encased in hard plastic. The components in modern day electronics generally appear to be rectangular black plastic pellets with connector pins protruding from the plastic encasement.
- Circuit designers use a variety of software tools to design and test electronic circuits that accomplish an intended task. For example, a digital circuit may be designed to accept digital inputs, perform some computation, and produce a digital output. An analog circuit may be designed to accept analog signals, manipulate the analog signals, such as my amplifying, filtering, or mixing the signals, and produce an analog or digital output. Generally, any type of circuit can be designed as an IC.
- Once a design layout, also referred to simply as a layout, has been finalized for an IC, the design is converted into a set of masks for lithography. A set of masks for lithography is one or more masks for lithography. During manufacture, a Silicon wafer is exposed to light or radiation through a set of masks to form microscopic components of the IC.
- A layout includes shapes that the designer selects and positions to achieve a design objective. The objective is to have the shape—the target shape—appear on the wafer as designed. However, the shapes may not appear exactly as designed when manufactured on the wafer through photolithography. For example, a rectangular shape with sharp corners may appear as a rectangular shape with rounded corners on the wafer.
- The illustrative embodiments provide a method, system, and computer usable program product for equation based retargeting of design layout. In an application executing in a data processing system, an embodiment determines a set of desirable combination of values of a set of layout parameters of the design layout. The embodiment determines a desirable region including the set of the desirable combination of values. The embodiment computes an equation to determine a retargeting value for a first combination of values of the set of layout parameters with respect to the desirable region. The embodiment generates instructions to adjust a value in the first combination to generate a second combination of values of the set of layout parameters such that the second combination falls in the desirable region. The embodiment retargets a shape in the design layout to form a retargeted shape such that the retargeted shape uses the second combination of values of the set of layout parameters. An embodiment may manufacture the IC using the retargeted shape.
- The novel features believed characteristic of the invention are set forth in the appended claims. The invention itself; however, as well as a preferred mode of use, further objectives and advantages thereof, will best be understood by reference to the following detailed description of an illustrative embodiment when read in conjunction with the accompanying drawings, wherein:
-
FIG. 1 depicts a block diagram of an IC design process in which the illustrative embodiments may be implemented; -
FIG. 2 depicts a block diagram of a data processing system in which illustrative embodiments may be implemented; -
FIG. 3 depicts a block diagram of an IC design process including equation based retargeting in accordance with an illustrative embodiment; -
FIG. 4 depicts a graph of a continuous relationship between two example layout parameters in accordance with an illustrative embodiment; -
FIG. 5 depicts a flowchart of a process of equation based retargeting in accordance with an illustrative embodiment; and -
FIG. 6 depicts a flowchart of a process of equation based retargeting in accordance with an illustrative embodiment. - A layout of an IC has to conform to certain design rules. For example, a design rule may specify that a component cannot exceed a specified size, or be within a specified distance of another specified component. A layout that conforms to all the applicable design rules is called a design rule clean layout.
- At manufacturing, however, a design rule clean layout may not be producible on a wafer for a variety of reasons. For example, light may diffuse to cause a sharp corner of a shape in a mask to appear rounded on the wafer. To correct for manufacturing idiosyncrasies, optical distortion, distance limitations, and other manufacturing considerations the shapes in a layout may be adjusted. Presently, a process called mask optimization, which may include optical proximity correction (OPC), is utilized to make changes to a mask so that the mask can compensate for manufacturing limitations.
- Conventionally, the shaped provided by a designer have been used as the shapes for lithography. However, the invention recognizes that with the ever-reducing size of IC components and the increasing number of components per unit area, the designer provided shapes are becoming increasingly difficult to reproduce on wafer.
- The illustrative embodiments used to describe the invention address and solve these and other problems related to printing shapes of a layout in photolithography. The illustrative embodiments provide a method, computer usable program product, and an apparatus for equation based retargeting of design layouts.
- An adjustment to achieve a new target shape that corresponds to the original target shape but has comparatively better printability on a wafer is called retargeting. Retargeting modifies the shapes provided by the designer to generate new target shapes that have improved printability.
- Retargeting according to an embodiment is different from mask optimization. Present mask optimization process changes the mask for manufacturability and not the target layout. Retargeting according to an embodiment changes the shapes that are used to produce the mask.
- The invention recognizes that some techniques for retargeting presently exist but such techniques are fraught with other problems. For example, a rule based retargeting method employs simple one or two dimensional retargeting rules to modify shapes that are known to cause difficulties at the manufacturing stage. For example, a rule based retargeting method may include a retargeting rule that for a given pitch and width of a component M1, bias the metal shapes by x nanometers. Another example rule in rule based retargeting may be that if a notch is of size y nanometers, fill the notch by z nanometers.
- The invention recognizes that rule based retargeting suffers from several limitations. For example, all possible poor manufacturability conditions have to be known a priori to create corresponding retargeting rules. However, the invention recognizes that such knowledge is not always available and therefore the rules created are limited in the conditions they can correct, leaving certain layout conditions uncorrected.
- The invention further recognizes that a rule has to be created for each enumerated condition requiring retargeting. The set of rules can become extremely large and complex. The large and complex set of rules is not easy to implement, manage, change, or correct for errors.
- Furthermore, certain conditions cannot effectively be converted into rules. Such conditions either go unaddressed in a rule based retargeting method, or an inadequately addressed by bucketing with other conditions. Bucketing is the process of applying a set, or bucket, of rules to a set of conditions as a whole. Accordingly, some conditions are better addressed by a bucket of rules than other conditions addressed by the same bucket of rules. Application of the rules is choppy and not continuous over the range of conditions that may require retargeting. Moreover, rules are inadequate where retargeting value depends on more than two layout parameters. Typical rules are one or two dimensional and can not cover the multi-dimensional layout space.
- Another existing retargeting technique is called model based retargeting. Model based retargeting retargets shapes during mask optimization iterations. In other words, the retargeting operation is included with the mask optimization operation so that the retargeting is done as a part of the iterations of the mask optimization process.
- The invention recognizes that mask optimization itself is a computationally intensive process. Including retargeting steps in the mask optimization process causes the mask optimization process to consume even more time and computing resources.
- Furthermore, the results of retargeting in model based retargeting are not predictable in advance. The retargeting results from mask optimization iterations cannot be made available to the designer in advance. Accordingly, a designer cannot evaluate whether or not a retargeted shape is acceptable within other design considerations.
- An embodiment of the invention provides a middle path between the rule based retargeting approach and a model based retargeting approach. An embodiment improves coverage of retargeting over rule based retargeting, while reducing the complexity of retargeting over the model based retargeting. An embodiment improves the accuracy of retargeting over the rule based retargeting method while imposing less runtime overhead as compared to the model based retargeting method.
- The examples in this disclosure are used only for the clarity of the description and are not limiting on the illustrative embodiments. Additional operations, actions, tasks, activities, and manipulations will be conceivable from this disclosure and the same are contemplated within the scope of the illustrative embodiments.
- The illustrative embodiments are described using specific code, data structures, designs, layouts, schematics, and tools only as examples and are not limiting on the illustrative embodiments. The illustrative embodiments may be implemented with respect to other similarly purposed code, data structures, designs, layouts, schematics, and tools within the scope of the invention.
- Furthermore, the illustrative embodiments may be described in some instances using particular systems, applications, or architectures only as an example for the clarity of the description. The illustrative embodiments may be used in conjunction with other comparable or similarly purposed systems, applications, or architectures.
- Any advantages listed herein are only examples and are not intended to be limiting on the illustrative embodiments. Additional or different advantages may be realized by specific illustrative embodiments. Furthermore, a particular illustrative embodiment may have some, all, or none of the advantages listed above.
- With reference to
FIG. 1 , this figure depicts a block diagram of an IC design process in which the illustrative embodiments may be implemented.Process 100 can be loosely divided into three stages, namely,design stage 102,mask optimization stage 104 where, for example mask optimization may be performed, andmanufacturing stage 106. -
Chip design application 108 may be a software application usable for creating shapes in a design layout.Application 108 may acceptdesign specification 110 as an input, which may specify a goal to be accomplished by the design layout. Design rules 112 may be a set of design rules. - A set of rules is one or more rules. A set of design rules is one or more design rules.
Rules 112 may or may not include rules for rule based retargeting. - Using
specification 110 and a subset ofdesign rules 112,application 108 may producedesign 114.Design 114 may include a set of shapes—the set of target shapes. A set of shapes is one or more shapes. A set of target shapes is one or more target shapes. -
Design 114 including a set of target shapes is provided to mask optimization (OPC)stage 104.Mask optimization application 116 may be a software application configured to generate a set of masks suitable formanufacturing design 114 on wafer. -
Application 116 may execute any number of mask optimization iterations to optimize or modify one or more mask shapes.Application 116 may or may not include instructions for model based retargeting.Application 116 provides a set of mask shapes, or masks, tomanufacturing stage 106.Masks 118 is such a set of masks. -
Chip manufacturing system 120 usesmasks 118 to produce one or more patterns on a wafer. The patterns so produced accomplish the objectives specified inspecification 110. A shape created on the wafer may be retargeted and may not be similar to the corresponding target shape indesign 114. - With reference to
FIG. 2 , this figure depicts a block diagram of a data processing system in which illustrative embodiments may be implemented.Data processing system 200 is an example of a computer, such asserver 104 orclient 110 inFIG. 1 , in which computer usable program code or instructions implementing the processes may be located for the illustrative embodiments. - In the depicted example,
data processing system 200 employs a hub architecture including North Bridge and memory controller hub (NB/MCH) 202 and south bridge and input/output (I/O) controller hub (SB/ICH) 204.Processing unit 206,main memory 208, andgraphics processor 210 are coupled to north bridge and memory controller hub (NB/MCH) 202.Processing unit 206 may contain one or more processors and may be implemented using one or more heterogeneous processor systems.Graphics processor 210 may be coupled to the NB/MCH through an accelerated graphics port (AGP) in certain implementations. - In the depicted example, local area network (LAN)
adapter 212 is coupled to south bridge and I/O controller hub (SB/ICH) 204.Audio adapter 216, keyboard and mouse adapter 220,modem 222, read only memory (ROM) 224, universal serial bus (USB) andother ports 232, and PCI/PCIe devices 234 are coupled to south bridge and I/O controller hub 204 through bus 238. Hard disk drive (HDD) 226 and CD-ROM 230 are coupled to south bridge and I/O controller hub 204 through bus 240. PCI/PCIe devices may include, for example, Ethernet adapters, add-in cards, and PC cards for notebook computers. PCI uses a card bus controller, while PCIe does not.ROM 224 may be, for example, a flash binary input/output system (BIOS).Hard disk drive 226 and CD-ROM 230 may use, for example, an integrated drive electronics (IDE) or serial advanced technology attachment (SATA) interface. A super I/O (SIO)device 236 may be coupled to south bridge and I/O controller hub (SB/ICH) 204. - An operating system runs on
processing unit 206. The operating system coordinates and provides control of various components withindata processing system 200 inFIG. 2 . The operating system may be a commercially available operating system such as Microsoft° Windows® (Microsoft and Windows are trademarks of Microsoft Corporation in the United States and other countries), or Linux° (Linux is a trademark of Linus Torvalds in the United States and other countries). An object oriented programming system, such as the Java™ programming system, may run in conjunction with the operating system and provides calls to the operating system from Java™ programs or applications executing on data processing system 200 (Java is a trademark of Sun Microsystems, Inc., in the United States and other countries). - Instructions for the operating system, the object-oriented programming system, and applications or programs are located on storage devices, such as
hard disk drive 226, and may be loaded intomain memory 208 for execution by processingunit 206. The processes of the illustrative embodiments may be performed by processingunit 206 using computer implemented instructions, which may be located in a memory, such as, for example,main memory 208, read onlymemory 224, or in one or more peripheral devices. - The hardware and software in
FIGS. 1-2 may vary depending on the implementation. Other internal hardware or peripheral devices, such as flash memory, equivalent non-volatile memory, or optical disk drives and the like, or other comparable software or firmware may be used in addition to or in place of the hardware depicted inFIGS. 1-2 . In addition, the processes of the illustrative embodiments may be applied to a multiprocessor data processing system. - In some illustrative examples,
data processing system 200 may be a personal digital assistant (PDA), which is generally configured with flash memory to provide non-volatile memory for storing operating system files and/or user-generated data. A bus system may comprise one or more buses, such as a system bus, an I/O bus, and a PCI bus. Of course, the bus system may be implemented using any type of communications fabric or architecture that provides for a transfer of data between different components or devices attached to the fabric or architecture. - A communications unit may include one or more devices used to transmit and receive data, such as a modem or a network adapter. A memory may be, for example,
main memory 208 or a cache, such as the cache found in north bridge andmemory controller hub 202. A processing unit may include one or more processors or CPUs. - The depicted examples in
FIGS. 1-2 and above-described examples are not meant to imply architectural limitations. For example,data processing system 200 also may be a tablet computer, laptop computer, or telephone device in addition to taking the form of a PDA. - With reference to
FIG. 3 , this figure depicts a block diagram of an IC design process including equation based retargeting in accordance with an illustrative embodiment.Process 300 can be loosely divided into four stages, namely,design stage 302,retargeting stage 304, mask optimization (OPC) stage 306, andmanufacturing stage 308.Design stage 302, mask optimization stage 306, andmanufacturing stage 308 may be similar todesign stage 102,mask optimization stage 104, andmanufacturing stage 106 respectively inFIG. 1 . -
Chip design application 310 may operate in a manner similar toapplication 108 inFIG. 1 .Specification 312 and design rules 314 may be similar tospecification 110 anddesign rule 112 respectively inFIG. 1 . Target shapes 316 may be similar to target shapes included indesign 114 inFIG. 1 . -
Retargeting stage 304 may include an embodiment of the invention in equation based retargeting application 318. In one embodiment, equation based retargeting application 318 may operate as a distinct step after the design process is complete and before the mask optimization process is executed. - Application 318 outputs a set of retargeted shapes. Retargeted shapes 320 is such a set. Retargeted shapes 320 may include retargeted shapes for some or all of target shapes 316. Retargeted shapes 320 are provided to
mask optimization application 322, which may produce set ofmasks 324 as described inFIG. 1 . -
Retargeting stage 304 is depicted as a distinct stage only for the clarity of the description and is not a limitation on the invention. For example, in one implementation,retargeting stage 304 may be an extension of eitherdesign stage 302 or mask optimization stage 306 within the scope of the invention. For example, in one embodiment, equation based retargeting application 318 may be configured to operate withchip design application 310. In another embodiment, equation based retargeting application 318 may be configured to operate with a mask optimization process, such as inmask optimization application 322. - Equation based retargeting according to an embodiment determines a continuous relationship between an amount of retargeting and a set of layout parameters. A layout parameter is a feature, measurement, limitation, constraint, dimension, specification, or another aspect in the layout. A set of layout parameters is one or more layout parameter.
- Generally, any factor affecting a layout can be used as a layout parameter. For example, any aspect of a layout or a component therein that is alterable during retargeting can be a layout parameter within the scope of the invention. For example, width of components may be an example layout parameter. Spacing between components in the layout may be another example layout parameter.
- A continuous relationship can be plotted as a continuous n-dimensional surface in an n-dimensional graph, where n is the number of layout parameters in the set. In an embodiment, a first continuous relationship may exist between the n parameters, where n may be the number of layout parameters in the set. For example, the relationship may be depicted in an n-dimensional space and desirable relationship contours in the n-dimensional space may identify the desirable relationship values or combinations for the n parameters.
- In one embodiment, retargeting value “R” according to the invention may be an n-tuple where n is the number of layout parameters in the set. In another embodiment the retargeting value may be an (n−x) tuple, (n−x) being the number of parameters to be retargeted in a subset of the set of parameters. A second continuous relationship may exist between the retargeting value such that the retargeting value is depicted in the (n+1)st dimension and the second relationship is capable of being depicted in the n+1 dimensional space. Accordingly, a continuous relationship between retargeting value and a set of layout parameters is a relationship such that for any given values of layout parameters in a set of layout parameters, the relationship equation can provide corresponding desirable values, or retargeting values, for one or more layout parameters in the set.
- A continuous relationship is distinct from a discrete relationship in that a discrete relationship provides corresponding retargeting values at only certain discrete values of layout parameters in the set. Typically, discrete relationships are implemented as rules, which then provide choppy or bucketed coverage for retargeting layout shapes.
- With reference to
FIG. 4 , this figure depicts a graph of a continuous relationship between two example layout parameters in accordance with an illustrative embodiment.Region 402 represents the desirable region andregions FIG. 3 . The equation based retargeting application according to an embodiment determines a polynomial equation that determines a retargeting value according to graph 400 such that undesirable layout parameter combinations fromregion desirable region 402. - Only as a simple example to describe the operation on an embodiment, graph 400 is plotted as a two-dimensional graph using two example layout parameters, viz, spacing and width of components in a layout. Graph 400 is generated from experimentation or simulation using an example layout. For example, an example layout having similar component densities, composition, scale, and complexity as a design to be manufactured may be used to produce graph 400.
- For example, for a given width and spacing in the target shapes, the retargeting relationship may allow determining a retargeting of the width by a retargeting value which is determined by an equation which is a function of width and spacing. As an example, the example relationship between the width and the spacing parameters can be represented as two dimensional contours or graph where the X and Y axes are width and spacing values. A retargeting value “R” according to an embodiment, gives the amount of retargeting needed for a given parameter such that after retargeting, the relationship of layout parameters comes within the desirable contours or regions.
- Note that an embodiment does not require that the actual design having the actual shapes that are to be manufactured be used for producing the graph and the corresponding equation. An example layout may be used to determine the polynomial retargeting equation. The equation can then be converted into computational instructions and used to retarget shapes in actual production layouts.
- In operation, a simulation using an example layout generates points representing corresponding values of the set of layout parameters being plotted. The simulation may be executed for generating any number of such points. For example, in depicted graph 400, certain points are shown at which the simulation is performed. Each point corresponds to a particular combination of width and spacing.
- Of such values, the desirable combinations of the width and spacing parameters are noted as the discrete desirable points in the relationship between the width parameter and the spacing parameter. For example, desirable combination of the width and spacing parameter values may lie in
region 402. Points lying inregions - A set of such desirable points may be obtained through sufficient simulation, the set including two or more points, if required, a set of undesirable points may also be obtained in a similar manner.
Point 408 is an example member of such a set of desirable points in example graph 400. The size of the set of discrete desirable points may be any size suitable for a particular implementation and may be achieved through suitable number of simulations within the scope of the invention. For example, a two dimensional contour for retargeting based on just two parameters may require fewer points to generate as compared to an 8-dimension surface that connects the desirable 8-tuples in an 8-dimension graph. -
Region 402 may be a desirable relationship contour or region in the space of graph 400. In one embodiment,region 402 may be more than one region in graph 400, forming a set of desirable relationship contours.Desirable relationship contour 402 is one or more continuous curve, either open or closed, that represents the desirable relationships between the example width and spacing parameters. In an n-dimensional space, where the desirable relationships between n layout parameters is plotted,contour 402 may take an n-dimensional form within the scope of the invention. - Equation 410 represents the equation that, for any point in graph 400, such as
point 412, answers the question—which parameter should be retargeted by what retargeting value such that the point moves within one ofdesirable relationship contour 402. The value “R” provided by the equation for given values of W and S for a givenpoint 412 in graph 400 represents the retargeting of that point such that the point falls on or within (one or more of)desirable relationship contour 402. - Example equation 410 is a polynomial function of two variables only as an example. For an n-axes plot, equation 410 may be a polynomial equation in n variables within the scope of the invention.
- Once equation 410 is determined, the retargeting value for any point in graph 400 can be determined. If a point is already within a desirable relationship contour, the equation returns a retargeting value that is below a threshold. For example, R may be zero or a negligible value. On the other hand, if a point is not on or within a desirable relationship contour, the equation returns a value of R that is above a threshold.
- The equation can then be implemented in an equation based retargeting application. The retargeting application accepts a design including a set of target shapes. The retargeting application determines whether for a shape in the design, a parameter or a combination of parameters that participates in the equation is outside the desirable relationship contours. The retargeting application then determines a retargeting value R according to the equation. The retargeting application can then adjust one or more parameters for that shape, such that the combination of the adjusted values of the set of parameters falls on or within at least one of the desirable relationship contours.
- With reference to
FIG. 5 , this figure depicts a flowchart of a process of equation based retargeting in accordance with an illustrative embodiment.Process 500 may be implemented in an equation based retargeting application, such as equation based retargeting application 318 inFIG. 3 . -
Process 500 begins by receiving a set of target shapes in a layout (step 502).Process 500 executes a lithography simulation (step 504). -
Process 500 obtains a set of layout parameters (step 506). In one embodiment, the set of layout parameters may be specified prior to the simulation, such as when certain parameters are preferred for retargeting. In another embodiment, the set of parameters may be an output of the simulation, such as when the simulation indicates which parameters may be effective in retargeting within the specified constraints. Not all the layout parameters in the set of layout parameters may necessarily be used to compute the equation according to an embodiment.Process 500 obtains a set of desirable relationships between a subset of the layout parameters (step 508). -
Process 500 identifies one or more continuous surface representations or regions that include the discrete desirable relationship points (step 510).Desirable relationship contours 402 inFIG. 4 is an example of such one or more continuous surfaces in two dimensions. The continuous surfaces ofstep 510 may be in any number of dimensions without limitations. -
Process 500 determines an equation that computes a retargeting value for a discrete point in the n dimensional layout space with respect to a continuous surface, such as the desirable region, in the space (step 512). The retargeting value represents the retargeting of one or more parameters to bring the discrete point on or within at least one of the continuous surfaces. -
Process 500 determines whether additional combinations of the layout parameters have to be examined (step 514). If additional combinations of layout parameters have to be examined (“Yes” path of step 514),process 500 returns to step 504. If no additional layout parameter combination has to be plotted (“No” path of step 514),process 500 generates the instructions to implement the equation (step 516). In one embodiment,process 500 may generate a set of equations, such as for different combinations of layout parameters. A set of equations is one or more equations. In such a case,process 500 may generate instructions for the set of equations in step 516.Process 500 ends thereafter. - With reference to
FIG. 6 , this figure depicts a flowchart of a process of equation based retargeting in accordance with an illustrative embodiment.Process 600 may be implemented in an equation based retargeting application, such as equation based retargeting application 318 inFIG. 3 . -
Process 600 begins by receiving a set of target shapes in a layout (step 602).Process 600 computes a retargeting bias for a target shape using a subset of the equations, such as the set of equations generated inprocess 500 inFIG. 5 (step 604). In one embodiment,process 600 may repeat step 604 for several iterations.Process 600 produces a retargeted shape for the layout and ends thereafter. - The components in the block diagrams, the equations, and the steps in the flowcharts described above are described only as examples. The components, the equations, and the steps have been selected for the clarity of the description and are not limiting on the illustrative embodiments of the invention. For example, a particular implementation may combine, omit, further subdivide, modify, augment, reduce, or implement alternatively, any of the components or steps without departing from the scope of the illustrative embodiments. Furthermore, the steps of the processes described above may be performed in a different order within the scope of the invention.
- Thus, a computer implemented method, apparatus, and computer program product are provided in the illustrative embodiments for equation based retargeting of design layouts. By using one or more illustrative embodiments of the invention, one or more shapes in a given design layout can be retargeted more accurately as compared to a rule based retargeting method while incurring less cost as compared to a model based retargeting method. The retargeted shapes can be made available to designers for verification before masks are produced from the retargeted layout.
- The invention can take the form of an entirely software embodiment, or an embodiment containing both hardware and software elements. In a preferred embodiment, the invention is implemented in software or program code, which includes but is not limited to firmware, resident software, and microcode.
- Furthermore, the invention can take the form of a computer program product accessible from a computer-usable or computer-readable medium providing program code for use by or in connection with a computer or any instruction execution system. For the purposes of this description, a computer-usable or computer-readable medium can be any tangible apparatus that can contain, store, communicate, propagate, or transport the program for use by or in connection with the instruction execution system, apparatus, or device.
- The medium can be an electronic, magnetic, optical, electromagnetic, infrared, or semiconductor system (or apparatus or device) or a propagation medium. Examples of a computer-readable medium include a semiconductor or solid state memory, magnetic tape, a removable computer diskette, a random access memory (RAM), a read-only memory (ROM), a rigid magnetic disk, and an optical disk. Current examples of optical disks include compact disk-read only memory (CD-ROM), compact disk-read/write (CD-R/W) and DVD.
- Further, a computer storage medium may contain or store a computer-readable program code such that when the computer-readable program code is executed on a computer, the execution of this computer-readable program code causes the computer to transmit another computer-readable program code over a communications link. This communications link may use a medium that is, for example without limitation, physical or wireless.
- A data processing system suitable for storing and/or executing program code will include at least one processor coupled directly or indirectly to memory elements through a system bus. The memory elements can include local memory employed during actual execution of the program code, bulk storage media, and cache memories, which provide temporary storage of at least some program code in order to reduce the number of times code must be retrieved from bulk storage media during execution.
- A data processing system may act as a server data processing system or a client data processing system. Server and client data processing systems may include data storage media that are computer usable, such as being computer readable. A data storage medium associated with a server data processing system may contain computer usable code. A client data processing system may download that computer usable code, such as for storing on a data storage medium associated with the client data processing system, or for using in the client data processing system. The server data processing system may similarly upload computer usable code from the client data processing system. The computer usable code resulting from a computer usable program product embodiment of the illustrative embodiments may be uploaded or downloaded using server and client data processing systems in this manner.
- Input/output or I/O devices (including but not limited to keyboards, displays, pointing devices, etc.) can be coupled to the system either directly or through intervening I/O controllers.
- The description of the present invention has been presented for purposes of illustration and description, and is not intended to be exhaustive or limited to the invention in the form disclosed. Many modifications and variations will be apparent to those of ordinary skill in the art. The embodiment was chosen and described in order to explain the principles of the invention, the practical application, and to enable others of ordinary skill in the art to understand the invention for various embodiments with various modifications as are suited to the particular use contemplated.
Claims (20)
Priority Applications (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
US12/782,407 US8347255B2 (en) | 2010-05-18 | 2010-05-18 | Equation based retargeting of design layouts |
Applications Claiming Priority (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
US12/782,407 US8347255B2 (en) | 2010-05-18 | 2010-05-18 | Equation based retargeting of design layouts |
Publications (2)
Publication Number | Publication Date |
---|---|
US20110288671A1 true US20110288671A1 (en) | 2011-11-24 |
US8347255B2 US8347255B2 (en) | 2013-01-01 |
Family
ID=44973134
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
US12/782,407 Expired - Fee Related US8347255B2 (en) | 2010-05-18 | 2010-05-18 | Equation based retargeting of design layouts |
Country Status (1)
Country | Link |
---|---|
US (1) | US8347255B2 (en) |
Cited By (4)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US8612902B1 (en) | 2012-09-27 | 2013-12-17 | International Business Machines Corporation | Retargeting multiple patterned integrated circuit device designs |
US8904314B1 (en) * | 2013-08-05 | 2014-12-02 | Taiwan Semiconductor Manufacturing Company Limited | RC extraction for multiple patterning layout design |
US20150213374A1 (en) * | 2014-01-24 | 2015-07-30 | International Business Machines Corporation | Detecting hotspots using machine learning on diffraction patterns |
US9836570B1 (en) | 2016-06-06 | 2017-12-05 | Globalfoundries Inc. | Semiconductor layout generation |
Families Citing this family (2)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US9898573B2 (en) | 2016-02-10 | 2018-02-20 | Globalfoundries Inc. | Rule and process assumption co-optimization using feature-specific layout-based statistical analyses |
US10885256B1 (en) * | 2020-02-04 | 2021-01-05 | Hong Kong Applied Science and Technology Research Institute Company, Limited | Method and system for integrated circuit (IC) layout migration integrated with layout expertise |
Citations (9)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US7174520B2 (en) * | 2002-06-07 | 2007-02-06 | Praesagus, Inc. | Characterization and verification for integrated circuit designs |
US20090241087A1 (en) * | 2004-03-30 | 2009-09-24 | Youping Zhang | System for simplifying layout processing |
US20100180251A1 (en) * | 2006-02-03 | 2010-07-15 | Brion Technology, Inc. | Method for process window optimized optical proximity correction |
US20100218156A1 (en) * | 2009-02-23 | 2010-08-26 | Christophe Pierrat | System and method for compressed post-opc data |
US20110119642A1 (en) * | 2009-11-17 | 2011-05-19 | International Business Machines Corporation | Simultaneous Photolithographic Mask and Target Optimization |
US20110124193A1 (en) * | 2009-11-25 | 2011-05-26 | Taiwan Semiconductor Manufacturing Company, Ltd. | Customized patterning modulation and optimization |
US20110138342A1 (en) * | 2009-12-03 | 2011-06-09 | International Business Machines Corporation | Retargeting for Electrical Yield Enhancement |
US20110161907A1 (en) * | 2009-12-28 | 2011-06-30 | Taiwan Semiconductor Manufacturing Company, Ltd. | Practical Approach to Layout Migration |
US20110204470A1 (en) * | 2010-02-25 | 2011-08-25 | Taiwan Semicondoctor Manufacturing Company, Ltd. | Method, system, and apparatus for adjusting local and global pattern density of an integrated circuit design |
Family Cites Families (9)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US6189132B1 (en) | 1998-04-09 | 2001-02-13 | International Business Machines Corporation | Design rule correction system and method |
US7272542B1 (en) | 2001-04-30 | 2007-09-18 | Xilinx, Inc. | Method and system for re-targeting integrated circuits |
US6753115B2 (en) | 2001-12-20 | 2004-06-22 | Numerical Technologies, Inc. | Facilitating minimum spacing and/or width control optical proximity correction |
US7448012B1 (en) | 2004-04-21 | 2008-11-04 | Qi-De Qian | Methods and system for improving integrated circuit layout |
US7653892B1 (en) | 2004-08-18 | 2010-01-26 | Cadence Design Systems, Inc. | System and method for implementing image-based design rules |
US7490308B2 (en) | 2006-03-31 | 2009-02-10 | International Business Machines Corporation | Method for implementing overlay-based modification of VLSI design layout |
US7437691B2 (en) | 2006-04-11 | 2008-10-14 | International Business Machines Corporation | VLSI artwork legalization for hierarchical designs with multiple grid constraints |
US20080178140A1 (en) | 2007-01-18 | 2008-07-24 | United Microelectronics Corp. | Method for correcting photomask pattern |
US7739650B2 (en) | 2007-02-09 | 2010-06-15 | Juan Andres Torres Robles | Pre-bias optical proximity correction |
-
2010
- 2010-05-18 US US12/782,407 patent/US8347255B2/en not_active Expired - Fee Related
Patent Citations (9)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US7174520B2 (en) * | 2002-06-07 | 2007-02-06 | Praesagus, Inc. | Characterization and verification for integrated circuit designs |
US20090241087A1 (en) * | 2004-03-30 | 2009-09-24 | Youping Zhang | System for simplifying layout processing |
US20100180251A1 (en) * | 2006-02-03 | 2010-07-15 | Brion Technology, Inc. | Method for process window optimized optical proximity correction |
US20100218156A1 (en) * | 2009-02-23 | 2010-08-26 | Christophe Pierrat | System and method for compressed post-opc data |
US20110119642A1 (en) * | 2009-11-17 | 2011-05-19 | International Business Machines Corporation | Simultaneous Photolithographic Mask and Target Optimization |
US20110124193A1 (en) * | 2009-11-25 | 2011-05-26 | Taiwan Semiconductor Manufacturing Company, Ltd. | Customized patterning modulation and optimization |
US20110138342A1 (en) * | 2009-12-03 | 2011-06-09 | International Business Machines Corporation | Retargeting for Electrical Yield Enhancement |
US20110161907A1 (en) * | 2009-12-28 | 2011-06-30 | Taiwan Semiconductor Manufacturing Company, Ltd. | Practical Approach to Layout Migration |
US20110204470A1 (en) * | 2010-02-25 | 2011-08-25 | Taiwan Semicondoctor Manufacturing Company, Ltd. | Method, system, and apparatus for adjusting local and global pattern density of an integrated circuit design |
Cited By (5)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US8612902B1 (en) | 2012-09-27 | 2013-12-17 | International Business Machines Corporation | Retargeting multiple patterned integrated circuit device designs |
US8904314B1 (en) * | 2013-08-05 | 2014-12-02 | Taiwan Semiconductor Manufacturing Company Limited | RC extraction for multiple patterning layout design |
US20150213374A1 (en) * | 2014-01-24 | 2015-07-30 | International Business Machines Corporation | Detecting hotspots using machine learning on diffraction patterns |
US9626459B2 (en) * | 2014-01-24 | 2017-04-18 | International Business Machines Corporation | Detecting hotspots using machine learning on diffraction patterns |
US9836570B1 (en) | 2016-06-06 | 2017-12-05 | Globalfoundries Inc. | Semiconductor layout generation |
Also Published As
Publication number | Publication date |
---|---|
US8347255B2 (en) | 2013-01-01 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
US20210240907A1 (en) | Method and Apparatus for Integrated Circuit Mask Patterning | |
US10318697B2 (en) | Sub-resolution assist feature implementation for shot generation | |
US8464194B1 (en) | Machine learning approach to correct lithographic hot-spots | |
US8589830B2 (en) | Method and apparatus for enhanced optical proximity correction | |
US8762900B2 (en) | Method for proximity correction | |
US8347255B2 (en) | Equation based retargeting of design layouts | |
CN114326289B (en) | Method, apparatus and storage medium for performing optical proximity correction | |
US8448098B2 (en) | Fracturing continuous photolithography masks | |
US20190131290A1 (en) | Layout modification method for exposure manufacturing process | |
JP2006292941A (en) | Optical proximity effect correction method and apparatus therefor | |
TWI836186B (en) | Method, system, and non-transitory computer readable medium for developing lithographic masks using skeleton representation of layouts | |
US8458631B2 (en) | Cycle time reduction in data preparation | |
CN113779779A (en) | Method, apparatus and computer-readable storage medium for optimizing a mask | |
CN117669473B (en) | Method for model calibration, electronic device and storage medium | |
US10896283B1 (en) | Noise-based optimization for integrated circuit design | |
US20240086601A1 (en) | Method and system to generate performance-data-library associated with standard-cell-library | |
US9639644B1 (en) | Method and apparatus for master-clone optimization during circuit analysis | |
US20070277142A1 (en) | LSI design supporting apparatus and LSI design supporting program used for designing and manufacturing LSI | |
US20220292249A1 (en) | Efficient scheduling of tasks for resolution enhancement technique operations | |
US8683411B2 (en) | Electronic design automation object placement with partially region-constrained objects | |
US12124788B2 (en) | Handling engineering change orders for integrated circuits in a design | |
US20230195992A1 (en) | Handling Engineering Change Orders for Integrated Circuits in a Design | |
US11720015B2 (en) | Mask synthesis using design guided offsets | |
CN118502195A (en) | Light source mask processing method, electronic device and storage medium | |
CN117666276A (en) | Method for mask process correction, electronic device and storage medium |
Legal Events
Date | Code | Title | Description |
---|---|---|---|
AS | Assignment |
Owner name: INTERNATIONAL BUSINESS MACHINES CORPORATION, NEW Y Free format text: ASSIGNMENT OF ASSIGNORS INTEREST;ASSIGNOR:AGARWAL, KANAK BEHARI;REEL/FRAME:024409/0705 Effective date: 20100518 |
|
STCF | Information on status: patent grant |
Free format text: PATENTED CASE |
|
AS | Assignment |
Owner name: GLOBALFOUNDRIES U.S. 2 LLC, NEW YORK Free format text: ASSIGNMENT OF ASSIGNORS INTEREST;ASSIGNOR:INTERNATIONAL BUSINESS MACHINES CORPORATION;REEL/FRAME:036550/0001 Effective date: 20150629 |
|
AS | Assignment |
Owner name: GLOBALFOUNDRIES INC., CAYMAN ISLANDS Free format text: ASSIGNMENT OF ASSIGNORS INTEREST;ASSIGNORS:GLOBALFOUNDRIES U.S. 2 LLC;GLOBALFOUNDRIES U.S. INC.;REEL/FRAME:036779/0001 Effective date: 20150910 |
|
FPAY | Fee payment |
Year of fee payment: 4 |
|
AS | Assignment |
Owner name: WILMINGTON TRUST, NATIONAL ASSOCIATION, DELAWARE Free format text: SECURITY AGREEMENT;ASSIGNOR:GLOBALFOUNDRIES INC.;REEL/FRAME:049490/0001 Effective date: 20181127 |
|
FEPP | Fee payment procedure |
Free format text: MAINTENANCE FEE REMINDER MAILED (ORIGINAL EVENT CODE: REM.); ENTITY STATUS OF PATENT OWNER: LARGE ENTITY |
|
AS | Assignment |
Owner name: GLOBALFOUNDRIES INC., CAYMAN ISLANDS Free format text: RELEASE BY SECURED PARTY;ASSIGNOR:WILMINGTON TRUST, NATIONAL ASSOCIATION;REEL/FRAME:054636/0001 Effective date: 20201117 |
|
LAPS | Lapse for failure to pay maintenance fees |
Free format text: PATENT EXPIRED FOR FAILURE TO PAY MAINTENANCE FEES (ORIGINAL EVENT CODE: EXP.); ENTITY STATUS OF PATENT OWNER: LARGE ENTITY |
|
STCH | Information on status: patent discontinuation |
Free format text: PATENT EXPIRED DUE TO NONPAYMENT OF MAINTENANCE FEES UNDER 37 CFR 1.362 |
|
FP | Lapsed due to failure to pay maintenance fee |
Effective date: 20210101 |
|
AS | Assignment |
Owner name: GLOBALFOUNDRIES U.S. INC., NEW YORK Free format text: RELEASE BY SECURED PARTY;ASSIGNOR:WILMINGTON TRUST, NATIONAL ASSOCIATION;REEL/FRAME:056987/0001 Effective date: 20201117 |