US20040143531A1 - Synthesizing signal net information from multiple integrated circuit package models - Google Patents
Synthesizing signal net information from multiple integrated circuit package models Download PDFInfo
- Publication number
- US20040143531A1 US20040143531A1 US10/754,939 US75493904A US2004143531A1 US 20040143531 A1 US20040143531 A1 US 20040143531A1 US 75493904 A US75493904 A US 75493904A US 2004143531 A1 US2004143531 A1 US 2004143531A1
- Authority
- US
- United States
- Prior art keywords
- net
- package
- property
- signal
- synthesized
- 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.)
- Abandoned
Links
Images
Classifications
-
- 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
- G06Q—INFORMATION AND COMMUNICATION TECHNOLOGY [ICT] SPECIALLY ADAPTED FOR ADMINISTRATIVE, COMMERCIAL, FINANCIAL, MANAGERIAL OR SUPERVISORY PURPOSES; SYSTEMS OR METHODS SPECIALLY ADAPTED FOR ADMINISTRATIVE, COMMERCIAL, FINANCIAL, MANAGERIAL OR SUPERVISORY PURPOSES, NOT OTHERWISE PROVIDED FOR
- G06Q40/00—Finance; Insurance; Tax strategies; Processing of corporate or income taxes
Definitions
- the present invention relates to integrated circuit package design and, more particularly, to synthesizing information about signal nets from multiple integrated circuit package models.
- Integrated circuits are becoming increasingly large and complex, typically including millions of individual circuit elements such as transistors and logic gates.
- EDA electronic design automation
- Such tools help to manage the complexity of the design task in a variety of ways, such as by allowing ICs to be designed hierarchically, thereby enabling the design to be divided into modules and enabling the design task to be divided among multiple designers in a manner that limits the complexity faced by any one designer.
- HDLs hardware description languages
- a description of a circuit according to an HDL (referred to herein as an “HDL model” of the circuit) may, for example, describe a particular circuit design in terms of the layout of its transistors and interconnects on an IC, or in terms of the logic gates in a digital system. Descriptions of a circuit at different levels of abstraction may be used for different purposes at various stages in the design process. HDL models may be used for testing circuits and circuit designs, as well as for fabricating the circuits themselves.
- VHSIC Very High Speed Integrated Circuits
- EDA tools are typically capable of converting a functional HDL description of a circuit design into a specific circuit implementation.
- the specific circuit implementation may be represented by a “netlist,” which identifies both the elements of the circuit and the interconnections among them.
- a netlist describes the circuit design in terms of nodes and edges. Each node represents a circuit element and each edge represents an interconnection between two circuit elements.
- Netlists may describe circuits at various levels of abstraction.
- a netlist may, for example, describe circuit elements in terms of specific structural components (such as resistors and transistors) or in terms of high-level “cells” that may be decomposed into specific structural components and/or other cells.
- a netlist may, for example, describe the connections between cells in terms of specific cell-to-cell pin connections.
- EDA tools are typically capable of converting a netlist into a physical layout of the circuit.
- the layout process involves both “placement” (assigning specific coordinates in the circuit layout to each cell) and “routing” (wiring or connecting cells together).
- the layout produced thereby defines the specific dimensions and coordinates of the gates, interconnects, contacts, and other elements of the circuit.
- the layout may have multiple layers, corresponding to the layers of the circuit.
- the layout may be used to form a mask, which in turn may be provided to a foundry to fabricate the integrated circuit itself.
- package design refers to the design of substrates (packages) for interconnecting layers of the IC.
- An IC typically includes multiple packages interconnected in layers. Each package, in turn, may include multiple layers. Packages within a single IC may be composed of varying materials having varying electrical properties. Individual signal nets (also referred to herein simply as “nets”) in the IC may be distributed across multiple packages. A package design must ensure that signals in the IC have sufficient power and maintain sufficient signal integrity when passing from one layer of the IC to another.
- signal net (or simply “net”) refers to a collection of conductors that are connected to form a complete circuit connecting at least one output to at least one input.
- APD Advanced Package Designer
- Cadence Design Systems, Inc. of San Jose, Calif.
- APD is a software program which allows the package designer to model the physical, electrical, and thermal characteristics of the package substrate.
- An APD package design database may be provided to a foundry to be used directly as manufacturing input for fabrication of the designed package.
- a package design tool (not shown), such as APD, maintains a plurality of package models 102 a - n , each of which contains information defining a particular package in an IC design.
- the package models 102 a - n may include, for example, information specifying the name, location, and length of each signal trace in each layer of the package models 102 a - n .
- Each of the package models 102 a - n is typically stored in a distinct database file in a computer system.
- Package design tools typically allow a package designer to access and modify only a single one of the package models 102 a - n at a time.
- the package designer must typically use the package design tool to open the database file corresponding to the package model to be modified.
- the package design tool may provide a graphical user interface which displays a two-dimensional or three-dimensional representation of the package model and which allows the package designer to modify the package model.
- Techniques for creating and modifying packages using such package design tools are well-known to those of ordinary skill in the art.
- the package designer must typically close the current package model and use the package design tool to open the other package model.
- Package design tools are typically capable of generating various kinds of reports containing information about the package models 102 a - n .
- One such report is a net length report, which contains information about the package-specific (intra-package) path length of each signal net within a particular one of the package models 102 a - n .
- the net length report indicates the length of that portion of the signal net which runs through the package.
- Such a report is therefore referred to herein as a “package-specific net length report.”
- a net length report generator 104 (which may, for example, be part of the package design tool that was used to design the package models 102 a - n ) generates package-specific net length reports 108 a - n , each of which contains the package-specific path lengths of signal nets within a corresponding one of the package models 102 a - n .
- package-specific net length report 108 a contains the package-specific path lengths of signal nets within package model 102 a.
- the package-specific net length reports 108 a - n may include various kinds of information about the path lengths of signal nets in the package models 102 a - n .
- each of the package-specific net length reports 108 a - n may contain a list of the names of all of the signal nets in the corresponding package model and the path length of each such signal net within the corresponding package model.
- a more detailed report may include information not only about the path length of each signal net within a package, but also information about the length of each signal net within each layer of the package.
- length equalization also referred to as “skew equalization”
- each of the plurality of package models contains information descriptive of a distinct package.
- Such information may include, for example, intra-package path lengths and/or propagation delays of signal nets in the modeled packages.
- Techniques are disclosed for automatically synthesizing such information to produce, for example, aggregate path lengths and/or propagation delays of the signal nets across all of the modeled packages. Such synthesis may be performed even when the package models use mutually inconsistent signal net naming conventions and the modeled packages are composed of different materials.
- Techniques are also disclosed for providing information to the package designer to assist the package designer in improving the design of the package models.
- a method for use in a system which includes a plurality of models of integrated circuit packages.
- the plurality of models include package-specific values of a property (such as signal net path length and/or signal net propagation delay) of a plurality of signal nets in the integrated circuit packages.
- the method includes steps of: (A) selecting a first one of the plurality of signal nets; (B) selecting, from a first one of the plurality of models, a first package-specific value of the property of the first signal net; (C) selecting, from a second one of the plurality of models, a second package-specific value of the property of the first signal net; and (D) applying a synthesis function (such as addition) to the first and second package-specific values to produce a synthesized property value.
- a method for use in a system including a plurality of property values of a plurality of signal nets in an integrated circuit.
- the method includes steps of: (A) identifying a reference value r; and (B) for each property value S in the plurality of property values (e.g., signal net path lengths and/or signal net propagation delays), performing steps of: (1) determining whether property value S differs from reference value r by more than a predetermined amount; and (2) notifying a user of the system if it is determined that the property value S differs from the reference value r by more than the predetermined amount.
- the reference value r may be selected from among the plurality of property values.
- a method for use in a system including a plurality of property values of a plurality of signal nets in an integrated circuit.
- the method comprises steps of: (A) identifying a reference value r; and (B) for each property value S in the plurality of property values, performing steps of: (1) identifying a difference D between property value S and reference value r; and (2) notifying a user of the system of the difference D.
- FIG. 1 is a functional block diagram of a prior art system for generating package-specific net length reports describing the lengths of signal nets within packages of an IC design;
- FIG. 2 is a functional block diagram of a system for synthesizing signal net information from multiple integrated circuit package models according to one embodiment of the present invention
- FIG. 3A is a block diagram of the logical structure of two package-specific net property reports generated by an integrated circuit package design tool
- FIG. 3B is a block diagram of the logical structure of a detailed package-specific net property report generated by an integrated circuit package design tool
- FIG. 4A is a is a block diagram of the logical structure of property synthesis information that is used to synthesize package-specific signal net property information according to one embodiment of the present invention
- FIG. 4B is a block diagram of the logical structure of particular embodiments of package-specific signal net lists and a synthesized signal net list according to one embodiment of the present invention
- FIG. 4C is a block diagram of the logical structure of a package model list according to one embodiment of the present invention.
- FIG. 4D is a block diagram of the logical structure of a synthesized signal net list according to one embodiment of the present invention.
- FIG. 5A is a flowchart of a method that is used by a net property synthesizer to synthesize package-specific net property reports into a synthesized net property report according to one embodiment of the present invention
- FIG. 5B is a flowchart of a method that is used by a net property synthesizer to calculate total propagation delays of signal nets through an integrated circuit according to one embodiment of the present invention
- FIG. 5C is a flowchart of a method that is used by a net property synthesizer to convert a net property value from one unit of measurement into another according to one embodiment of the present invention
- FIG. 5D is a flowchart of a method that is used by a net property synthesizer to map signal net names used in multiple package models according to one embodiment of the present invention
- FIG. 5E is a flowchart of a method that is used by a net property synthesizer to adjust a synthesized net property value according to one embodiment of the present invention
- FIG. 6 is a block diagram of the logical structure of a synthesized signal net property report according to one embodiment of the present invention.
- FIG. 7 is a perspective view of an integrated circuit package having multiple layers and a single signal net
- FIG. 8A is a flowchart of a method a flowchart which is used by a net property synthesizer to determine whether a synthesized net property value deviates from a reference net property value by more than a predetermined maximum deviation according to one embodiment of the present invention.
- FIG. 8B is a flowchart of a method for assisting a user with the task of skew equalization in an integrated circuit package design according to one embodiment of the present invention.
- a system 200 is illustrated for synthesizing signal net information from a plurality of IC package models 202 a - n according to one embodiment of the present invention.
- a particular integrated circuit may include a plurality of interconnected packages arranged in layers.
- each of the package models 202 a - n is a model of a particular IC package in a design for a particular integrated circuit.
- the package models 202 a - n may, for example, be created and maintained using a package design tool, such as the Advanced Package Designer (APD) software described above.
- Package design tools such as APD typically maintain a distinct model (in the form of a database) for each package in the IC design.
- the package design tool includes a net property report generator 204 , which may, for example, be a package-specific net length report generator as described above with respect to FIG. 1.
- the net property report generator 204 generates package-specific net property reports 208 a - n , each of which corresponds to a particular one of the package models 202 a - n .
- the net property report generator 204 extracts the value of a particular property (referred to herein as “the reported property”) of each of the signal nets in the package model, and includes the extracted property values in the corresponding net property report.
- Reported properties may include, for example, the path length or propagation delay of signal nets within a particular package.
- the value of a particular signal net property for a particular package model is referred to herein as a “package-specific property value” or as an “intra-package property value.”
- the package-specific net property report 208 a may, for example, include the package-specific path lengths of the signal nets in package model 202 a.
- a net property synthesizer 212 which synthesizes information contained in the plurality of package-specific net property reports 208 a - n into a single synthesized property report 214 based on property synthesis information 210 . If, for example, the reported property is path length, the synthesized property report 214 may include a list of the synthesized (i.e., total) path lengths of each of one or more of the signal nets through all of the packages modeled by the package models 202 a - n .
- the net property synthesizer 212 includes a net property synthesis function F 216 which the net property synthesizer 212 may use to synthesize the package-specific property values for each signal net into corresponding “synthesized property values” that are stored in the synthesized property report 214 .
- Net property reports having the logical structure illustrated in FIG. 3A may be generated by conventional package design tools, such as APD.
- the package-specific net property reports 208 a and 208 b may, for example, report on the path lengths or propagation delays of particular signal nets within the corresponding packages.
- the package-specific net property report 208 a (which reports on the package model 202 a ) includes a net property value list 304 , which lists the values of the reported property (e.g., path length or propagation delay) for the signal nets within the corresponding package (i.e., the package modeled by package model 202 a ).
- the list 304 includes a plurality of list elements 306 a - m , where m is the number of elements in the list (i.e., the number of signal nets reported on by the report 208 a ).
- Each of the list elements 306 a - m includes a net name field 308 a and a net property value 308 b field.
- the net name field 308 a identifies the name of a particular signal net within the corresponding package
- the net property value field 308 b indicates the value of the reported property for the signal net identified by the net name field 308 a .
- the reported property is signal net path length
- each of the list elements 306 a - m indicates the name of a particular signal net and the path length of that signal net within the corresponding package.
- the package-specific net property report 208 a also includes a property units specifier 302 which specifies the units in which the net property values 308 b are expressed. Path lengths may, for example, be expressed in units of millimeters, mils, or microns in a particular report.
- the property units specifier 302 specifies the units in which the net property values 308 b are expressed so that the net property values 308 b may be interpreted either by a human operator or by the net property synthesizer 212 (FIG. 2), as described in more detail below.
- the package-specific net property report 208 b has the same logical structure as the package-specific net property report 208 a . More specifically, the package-specific net property report 208 b includes a net property value list 312 , which lists the values of the reported property for a plurality of nets within the corresponding package (in this case, the package modeled by package model 202 b ).
- the list 312 includes a plurality of list elements 314 a - m . Each of the list elements 314 a - m includes a net name field 316 a and a net property value 316 b field.
- the lists 304 and 312 in FIG. 3 have the same number of elements (m), this is not a requirement of the present invention. Rather, the lists 304 and 312 may have different numbers of elements.
- the package-specific net property report 208 b also includes a property units specifier 310 which specifies the units in which the net property values 316 b are expressed.
- the net property values 308 b in report 208 a and the net property values 316 b in report 208 b may be expressed in the same or in different units (indicated by the property units specifiers 302 and 310 , respectively).
- the user of the net property report generator 204 specifies the units in which net property values in a particular report should be expressed.
- the package-specific net property reports 208 a - n may, for example, be implemented as text files, elements of which (such as the property units specifier 302 and the property units specifier 310 ) may be implemented as text strings, as will be well-understood by those of ordinary skill in the art.
- the net property synthesizer 212 uses the net property value lists and the property unit specifiers in the package-specific net property reports 208 a - n to generate a synthesized net property value list in the synthesized property report 214 .
- the property synthesis information 210 will be described in more detail.
- the property synthesis information 210 includes information for: (1) identifying the package models 202 a - n from which signal net property values should be synthesized; (2) selecting one or more signal nets within the identified package models 202 a - n for which signal net property values should be synthesized; and (3) specifying the format of the synthesized property report 214 to be generated by the net property synthesizer 212 .
- the property synthesis information 210 includes input parameters 402 and output parameters 404 .
- the input parameters 402 include a package model list 406 and an input signal net list 408 .
- the package model list 406 lists the package models 202 a - n from which signal net property values are to be synthesized by the net property synthesizer 212 .
- the package models 202 a - n may, for example, be a subset of the package models in a complete IC design.
- the package model list 406 may, for example, identify the package models 202 a - n using the filenames of the database files containing the package models 202 a - n or using the filenames of the package-specific net property reports 208 a - n corresponding to the package models 202 a - n .
- the package model list 406 may include additional information about each of the package models 202 a - n , as described in more detail below with respect to FIG. 4C.
- the input signal net list 408 lists the signal nets for which property values are to be synthesized by the net property synthesizer 212 . It may be desirable, for example, to synthesize property values for only certain signal nets, and the input signal net list 408 provides a mechanism for doing so.
- the input signal net list 408 may, for example, identify signal nets using the same net names as the net names 308 a and 316 a used by the package-specific net property reports 208 a - b, respectively (FIG. 3A).
- the output parameters 404 include a synthesized property units selector 410 and a synthesized signal net list 412 .
- the synthesized property units selector 410 specifies the units in which synthesized property values should be expressed in the synthesized property report 214 .
- package-specific property values may be expressed in different units in different ones of the package-specific net property reports 208 a - n .
- the synthesized property units selector 410 may select a unit of measurement that is employed by one or more of the package-specific net property reports 208 a - n or may select a unit of measurement that is not employed by any of the package-specific net property reports 208 a - n.
- the synthesized signal net list 412 lists the names that should be used to identify signal nets in the synthesized property report 214 .
- the synthesized signal net list 412 may, for example, specify the same or different names than those used in the package models 202 a - n .
- the synthesized signal net list 412 may be omitted from the net property synthesis information 210 and the net property synthesizer 212 may name the signal nets in the synthesized net property report 214 using the names provided in the input signal net list 408 .
- a particular signal net may span more than one of the package models 202 a - n , but may have different signal net names in different ones of the package models 202 a - n .
- the net property synthesis information 210 may include a mapping 436 between signal names used in the package-specific net property reports 208 a - n and signal names to be used to identify signal nets in the synthesized net property report 214 .
- the synthesized net property report 214 includes a synthesized net property value list 604 , which lists the synthesized property values generated by the net property synthesizer 212 by synthesizing the package-specific property values contained in the package-specific net property reports 208 a - n.
- the list 604 includes a plurality of list elements 606 a - m, where m is the number of elements in the list (i.e., the number of signal nets synthesized by the net property synthesizer 212 ).
- Each of the list elements 606 a - m includes a synthesized net name field 608 a and a synthesized net property value field.
- the synthesized net name field 608 a identifies a particular signal net N within the package models 202 a - n
- the synthesized net property value field 608 b indicates the synthesized property value produced by the net property synthesizer 212 for signal net N.
- the synthesized net property report 214 also includes a synthesized property units specifier 602 which specifies the units in which the synthesized net property values 608 b are expressed.
- the synthesized property units specifier 602 specifies the same units as are specified by the synthesized property units selector 410 (FIG. 4A).
- the synthesized net property report 214 illustrated in FIG. 6 includes only the single synthesized net property value field 608 b
- the synthesized net property report 214 may include any number of synthesized net property value fields.
- the synthesized net property report 214 may include two synthesized net property value fields, one for storing synthesized signal net path lengths and the other for storing synthesized signal net propagation delays.
- FIG. 5A a flowchart of a method 500 is shown that is used by the net property synthesizer 212 (FIG. 2) to synthesize package-specific property values in the package-specific net property reports 208 a - n into synthesized property values in the synthesized property report 214 according to one embodiment of the present invention.
- the net property synthesizer 212 identifies the package models from which signal net property values are to be synthesized (step 502 ).
- the net property synthesizer 212 may, for example, identify these package models by reading the package model list 406 (FIG. 4A). For purposes of example, assume that the package models identified in step 502 are the package models 202 a - n illustrated in FIG. 2.
- the package models 202 a - n may, for example, be a subset of all of the package models in a particular IC design.
- the net property synthesizer 212 identifies the signal nets from which package-specific property values should be synthesized (step 504 ).
- the net property synthesizer 212 may, for example, identify these signal nets by reading the input signal net list 408 (FIG. 4A).
- the net property synthesizer 212 initializes the synthesized property report 214 (step 506 ). If, for example, the synthesized property report 214 is to be stored in a text file, the net property synthesizer 212 may initialize the synthesized property report 214 by creating and opening an empty text file.
- the net property synthesizer 212 enters a loop over each signal net N in the list of identified signal nets (step 508 ).
- the net property synthesizer 212 synthesizes package-specific property values for the signal net N into a single synthesized property value as follows.
- the net property synthesizer 212 initializes a synthesized property value SN for the signal net N (step 510 ). If, for example, the property to be synthesized is signal net path length, the net property synthesizer 212 may initialize the value of SN to zero.
- all of the package-specific net property reports 208 a - n report on the same property, and therefore the “property to be synthesized” by the net property synthesizer 212 is defined by the property that is reported on by the package-specific net property reports 208 a - n.
- the net property synthesizer 212 enters a loop over each package model P in the identified list of package models (step 512 ).
- the net property synthesizer 212 identifies the package-specific property value V of signal net N in package model P (step 514 ).
- the net property synthesizer 212 may perform this step, for example, by searching through the signal net property list (such as list 304 or 312 in FIG. 3) of package model P for a list element having the same net name as signal net N, and identifying the property value associated with that list element as the property value V.
- the net property synthesizer 212 updates the value of the synthesized property value S N by applying the property synthesis function 216 (FIG. 2) to the existing value of S N and the package-specific property value V (step 516 ).
- the property synthesis function 216 may, for example, be an arithmetic function such as addition or multiplication. If, for example, the property to be synthesized is path length or propagation delay, the property synthesis function 216 may be addition.
- the net property synthesizer 212 repeats steps 514 and 516 for each package model P (step 518 ).
- the effect of the loop represented by steps 512 - 518 is to synthesize all of the package-specific property values V for the signal net N into a single synthesized property value S N using the property synthesis function F. If, for example, the property synthesis function F is addition, the effect of the loop performed in steps 512 - 518 is to produce a synthesized property value S N for signal net N which is the sum of all of the package-specific property values for signal net N.
- Step 520 includes writing the synthesized net name of signal net N to the synthesized property report 214 (FIG. 6).
- the net property synthesizer 212 repeats steps 510 - 520 for each of the identified signal nets N (step 522 ).
- the synthesized property report 214 includes synthesized property values 608 b for all of the signal nets specified by the input signal net list 408 .
- the reports 208 a - n include the package-specific path lengths of signal nets in the package models 202 a - n , and in which the net property synthesizer 212 calculates the total (i.e., synthesized) propagation delays of the signal nets based on: (1) the package-specific path lengths of the signal nets, and (2) the dielectric constants and permeabilities of the layers of the packages.
- step 516 application of the property synthesis function 216 .
- the net property synthesizer 212 calculates the intra-package propagation delay PD of the signal net N using Equation 1:
- L is the intra-package path length of signal net N
- DK is the dielectric constant of the package substrate
- p is the permeability of the package substrate (step 524 ).
- the length L is the package-specific property value V obtained in step 514 of FIG. 5A.
- the net property synthesizer 212 updates the value of the synthesized property value S N , which in this case represents a propagation delay, by adding the value of PD to the current value of S N and assigning the result to S N (step 526 ).
- steps 524 and 526 update the value of S N by calculating the intra-package propagation delay of signal net N through package P and adding this intra-package propagation delay to the total propagation delay S N .
- net property values may be expressed in different units of measurement in different ones of the package-specific net property reports 208 a - n .
- the net property synthesizer 212 converts package-specific net property values in the package-specific net property reports 208 a - n into the units specified by the synthesized property units selector 410 (FIG. 4A) when generating the synthesized net property report 214 .
- the net property synthesizer 212 performs this unit conversion by identifying the property value V of signal net N in package model P (step 514 of FIG. 5A) as follows.
- the net property synthesizer 212 reads the package-specific property value V from the package-specific net property report for package model P (step 528 ).
- the value of V that is read in step 528 is expressed in the units specified by the package-specific net property report's property units specifier (such as the property units specifier 302 in the case of the package-specific net property report illustrated in FIG. 3A).
- the net property synthesizer 212 converts the value of V into the units specified by the synthesized property units selector. 410 (FIG. 4A). This converted value of V is then used by the net property synthesizer 212 in step 516 of the method 500 illustrated in FIG. 5A.
- the net property synthesizer 212 may perform the units conversion in step 530 using techniques that are well-known to those of ordinary skill in the art.
- the net property synthesizer 212 may, for example, include conversion factors for converting among various net property units (such as millimeters, mils, and microns).
- the units conversion of step 530 may then be performed by multiplying the package-specific value of V obtained in step 528 by a conversion factor that is selected based on the package-specific property units of V and the synthesized property units to be obtained.
- signal nets may have different names in different ones of the package models 202 a - n.
- the net property synthesizer 212 To identify the package-specific property value V of a particular signal net N in a package P (FIG. 5A, step 514 ), the net property synthesizer 212 must know which name is used to identify signal net N in package P.
- signal net mapping 436 (FIG.
- 4A provides two mappings to enable to the net property synthesizer 212 to perform this task: (1) a mapping between signal net names in the package models 202 a - n that are used to identify the same signal net; and (2) a mapping between signal net names in the package models 202 a - n and synthesized signal net names to be used in the synthesized property report 214 .
- the signal net mapping 436 is implemented using the input signal net list 408 and the synthesized signal net list 412 .
- the input signal net list 408 includes a plurality of signal net lists 414 a - n , each of which corresponds to a particular one of the package models 202 a - n .
- signal net list 414 a corresponds to package model 202 a
- signal net list 414 b corresponds to package model 202 b
- Each of the signal net lists 414 a - n includes a list of the names that the corresponding package model uses to identify the signal nets to be synthesized by the net property synthesizer 212 .
- Each of the signal net lists 414 a - n includes j elements, where j is less than or equal to the number of signal nets in the package models 202 a - n .
- the signal net lists 414 a - n may identify all or any subset of the signal nets in the package models 202 a - n.
- the plurality of signal net lists 414 a - n provides a mapping among signal net names in the package models 202 a - n (and therefore also provides a mapping among signal net names in the package-specific net property reports 208 a - n ) which refer to the same signal net.
- the kth element of each of the lists 414 a - n refers to the same signal net.
- Signal net name 416 a (in package-specific signal net list 414 a ), signal net name 418 a (in package-specific signal net list 414 b ), and signal net name 420 n (in package-specific signal net list 414 n ) refer to the same signal net N. More specifically, signal net name 416 a is the name that package model 202 a uses to refer to signal net N, signal net name 418 a is the name that package model 202 b uses to refer to signal net N, and so on. As described above, signal net N may have different names in different ones of the package models 202 a - n .
- the package-specific signal net lists 414 a - n therefore provide a mechanism for identifying which signal net names in different ones of the package models 202 a - n refer to the same signal net.
- the net name 416 a would contain the value “signal1”
- the net name 418 a would contain the value “sig1”
- the net name 420 a would contain the value “data_signal1”, thereby indicating that each of these names refers to the same signal net in corresponding ones of the package models 202 a - n.
- the synthesized signal net list 412 provides a list of signal net names 424 a - j to use in the synthesized property report 214 .
- the first name 424 a in the synthesized signal net list 412 is the name to be used for the first signal net in the package-specific signal net lists 414 a - n
- the second name 424 b is the name to be used for the second signal net in the package-specific signal net lists 414 a - n
- the first net name 424 a in the synthesized signal net list 412 is “signal_ 1 ”.
- synthesized net property value that is synthesized from the signal net having the names 416 a (“signal1”), 418 a (“sig1”), and 420 a (“data signal1”) will be given the name “signal — 1” in the synthesized property report 214 .
- the net property synthesizer 212 uses the signal net mapping 436 to identify the value V of signal net N in package model P (step 514 of FIG. 5A) as follows.
- the net property synthesizer 212 identifies the package-specific signal net list for package model P (step 532 ).
- the net property synthesizer 212 may readily perform this step in any of a variety of ways. For example, in one embodiment, in the method 500 illustrated in FIG. 5A the net property synthesizer 212 maintains a counter p through each iteration of the loop performed in steps 512 - 522 .
- the value of p may, for example, be initialized to zero and be incremented at the end of each iteration of the loop.
- the counter p may therefore be used to identify corresponding ones of the package models 202 a - n , the package-specific net property reports 208 a - n , and the package-specific signal net lists 414 a - n .
- the net property synthesizer 212 may therefore identify the package-specific signal net list for package model P (step 532 ) as the pth one of the package-specific signal net lists 414 a - n.
- the net property synthesizer 212 identifies the name of signal net N in the package-specific signal net list identified in step 532 (step 534 ).
- the net property synthesizer 212 may perform this step by, for example, using a counter to count each iteration of the loop performed in steps 508 - 522 of FIG. 5A, and by using this counter as an index into the package-specific signal net list identified in step 532 . If, for example, the identified package-specific signal net list is list 414 a (FIG. 4B), a counter with a value of zero would identify signal net name 416 a.
- the net property synthesizer 212 uses the signal net name identified in step 534 to identify the package-specific property value V in the package-specific property report for package model P (step 536 ).
- the net property synthesizer 212 may, for example, identify the package-specific property report for package model P using the counter p described above. Assume for purposes of example that the identified package-specific property report is report 208 a (FIG. 3A).
- the net property synthesizer 212 may perform step 536 by searching the net names 308 a for the signal net name identified in step 534 and selecting the corresponding net property value 308 b as the value for V. Upon completion of the process illustrated in FIG. 5D, the identified value of V may be used in step 516 of FIG. 5A.
- the package-specific net property reports 208 a - n include property values for each layer in the package models 202 a - n .
- various features of signal nets in multi-layer packages will first be described.
- FIG. 7 an example package 700 having three layers 702 a - c is illustrated. It should be appreciated that the layers 702 a - c are not drawn to scale and that in general only relevant features of the layers 702 a - c are shown for ease of illustration and explanation.
- the three dimensions of the package 700 are illustrated using x, y, and z axes.
- the values provided on the x and y axes in FIG. 7 do not correspond to particular units of measurement (such as millimeters or mils), but rather are generic units provided merely for ease of illustration and explanation.
- layer 702 a will be referred to as the “top” layer of package 700
- layer 702 b as the “middle” layer of package 700
- layer 702 c as the “bottom” layer of package 700
- package 700 has three layers 702 a - c
- in practice packages may have any number of layers.
- the package 700 may be one of multiple packages in an IC (not shown).
- a portion of a signal net is also shown in FIG. 7.
- the signal net is referred to herein by reference numeral 706 and includes segments 706 a - g . Although only one signal net 706 is shown, a typical package may include thousands of signal nets.
- a segment 704 of the signal net 706 connects to the top layer 702 a of the package 700 from a package (not shown) that is above the package 700 in the IC. Segment 704 connects to the package 700 at center 712 a of a pad 710 a on the top layer 702 a of the package 700 .
- the pad 710 a may be one of many pads in a connection (not shown) on the top layer 702 a .
- the signal net 706 includes segment 706 a , which originates at the pad center 712 a and which extends for two units on the x axis.
- the next segment 706 b of the signal net 706 extends for three units on the y axis.
- the signal net 706 therefore has a path length of five units (two units for segment 706 a and three units for segment 706 b ) within top layer 702 a .
- Such a path length will be referred to herein as an “intra-layer path length” and alternatively as a “horizontal path length.”
- the signal net 706 next includes segment 706 c , which extends downward from point 712 b to the middle layer 702 b of the package 700 .
- the length of segment 706 c is equal to the distance H between each layer of the package 700 .
- Such a path length will be referred to herein as a “vertical path length.”
- Simal nets traverse vertical path lengths through vias, which are vertical conductors or conductive paths forming the interconnection between one layer of an IC and another.
- the signal net 706 next includes segments 706 d , 706 e , and 706 f within the middle layer 702 b .
- Signal net 706 next includes a segment 706 g which extends downward to the bottom layer 702 c , where it connects to pad 710 b at point 712 d .
- segment 706 g does not connect to center 712 e of pad 710 b .
- a segment 708 of the signal net 706 extends from the bottom layer 702 c of the package 700 to a package (not shown) below package 700 .
- the aggregate path length of segments 706 a - g is an example of a “synthesized path length” or a “total path length” as those terms are used herein.
- the sum of the path lengths of segments 706 a - g represents the total distance spanned by the signal net 706 within the package 700 .
- the package-specific net property reports 208 a - n include information about the intra-layer path lengths of segments of signals nets in the packages modeled by the package models 202 a - n , respectively.
- the package-specific net property reports 208 a - n may, for example, have the logical structure illustrated in detail in FIG. 3B. Although only the report 208 a is illustrated in FIG. 3B, the other reports 208 a - n may have the same logical structure.
- the package-specific net property report 208 a includes property units specifier 302 , as described above with respect to FIG. 3A.
- the report 208 a in FIG. 3B includes a signal net record list 330 having a plurality of signal net records 320 a - m .
- the signal net record list 330 in FIG. 3B associates net names with more detailed information about the corresponding signal nets.
- signal net record 320 a The logical structure and example contents of record 320 a are illustrated in detail in FIG. 3B. Although the remaining signal net records 320 b - m have the same logical structure as record 320 a , only record 320 a is shown in detail in FIG. 3B for ease of illustration.
- Signal net record 320 a includes a signal net name 326 a which identifies the name of the corresponding signal net in the package model 202 a.
- the signal net record 320 a also includes signal net layer information 328 a which, in this example, provides information about the corresponding signal net in each layer of the package modeled by package model 202 a .
- the signal net layer information 328 a includes a plurality of rows 322 a - d, each of which provides information about the corresponding signal net in a particular one of the package layers. In the example shown in FIG.
- the rows 322 a - d are arranged in an order that corresponds to the order of the package layers, in which the first row 322 a corresponds to pad 710 a at the top layer 702 a of the package 700 , the second row 322 b corresponds to the top layer 702 a of the package 700 , the third row 322 c corresponds to the second layer 702 b of the package 700 , and the fourth row 322 d corresponds to the bottom layer 702 c of the package 700 .
- the signal net layer information 328 a includes a Pin ID column 324 a , an X column 324 b , a Y column 324 c , a Length column 324 D, and a Layer column 324 e .
- a Pin ID column 324 a For each of the rows 322 a - d:
- the Pin ID column 324 a contains a pin identifier (pin ID) of the pin at which the signal net is connected in the corresponding layer of the package;
- the X and Y columns 324 b and 324 c contain the x and y coordinates, respectively, at which the signal net exits from the corresponding layer of the package;
- the Length column 324 d contains the running aggregate horizontal path length of the signal net within the package.
- the Layer column 324 e contains the name of the corresponding layer of the package.
- the signal net record 320 a corresponds to the package 700 illustrated in FIG. 7.
- the value in the Pin ID column 324 a of row 322 a is “U1.DM74,” indicating that the pin identifier of the pad 710 a at which signal net 706 is connected to layer 702 a in package 700 is U1.DM74.
- the prefix U1 has a special meaning, which refers to a connection on package 700 for connecting package 700 to a die.
- the Layer column 324 e is empty for row 322 a .
- the connection U1 may have many thousands of pads, each of which may be used to connect a distinct signal net.
- the suffix DM74 therefore specifies the particular pad 710 a on connection U1 through which signal net 706 is connected to package 700 .
- the X and Y columns 324 b and 324 c for row 322 a indicate that signal net 706 is connected to pad U1.DM74 at coordinates (1.00, 7.00).
- the Length column 324 d specifies a length of 0.00 for row 322 a because signal net 706 has not yet traversed any horizontal distance across any layer of package 700 .
- the values in the X and Y columns 324 b and 324 c indicate that signal net 706 is connected to pad P1.F3 at coordinates (2.85, 2.00), that the name of layer 702 c is “BOTTOM,” and that the running aggregate horizontal length of signal net N through package 700 at layer 702 c is 9.15 units.
- the aggregate horizontal path length of signal net 706 through package 700 is 9.15 units. This aggregate horizontal path length does not, however, take into account the vertical distance(s) spanned by the signal net 706 .
- signal net 706 includes vertical segments 706 c and 706 g , each of which spans the horizontal distance H.
- the aggregate horizontal length 9.15 does not take into account these vertical distances and therefore does not represent the full aggregate path length of signal net 706 through the package 700 .
- signal nets do not always connect to the center of a pad.
- signal net segment 706 g does not connect to the center of pad 710 b .
- the aggregate horizontal distance (9.15) indicated in the package-specific net property report 208 a is based on the assumption that the signal net 706 connects to the center of pad 710 b .
- the aggregate horizontal distances indicated in the package-specific net property reports produced by package design tools such as APD may therefore not be entirely accurate.
- package-specific net property reports produced by conventional package design tools such as APD may not accurately represent the package-specific path length of signals nets within a package.
- FIG. 5E a flow chart of a process is shown that is used by the net property synthesizer 212 to calculate the package-specific path length S N of signal net N in package model P in one embodiment of the present invention.
- the calculation performed by the process illustrated in FIG. 5E takes into account both: (1) the horizontal and vertical distances spanned by the signal net N within package model P, and ( 2 ) the location(s) at which the signal net N connects to pads on the package modeled by package model P.
- the process illustrated in FIG. 5E may therefore calculate package-specific path lengths more accurately than conventional package design tools.
- the process shown in FIG. 5E implements step 514 of FIG. 5A, which identifies the property value V of signal net N in package model P.
- the net property synthesizer 212 identifies the package-specific net property report R that corresponds to package model P using any of the techniques described above (step 540 ). For example, in the case of package model 202 a , the corresponding package-specific net property report R is report 208 a .
- the net property synthesizer 212 assigns to V the package-specific path length for signal net N indicated by report R (step 542 ). For example, in one embodiment the package-specific path length indicated by report 208 a is 9.15 (FIG. 3B).
- the net property synthesizer 212 adjusts the value of V based on the coordinates at which signal net N connects to the final layer of package P (step 544 ).
- the “final layer” of package P refers to the layer from which signal net N exits package P, which may, for example, be either the top or bottom layer of package P, depending on the package design.
- the net property synthesizer 212 adjusts the value of V (step 544 ) as follows.
- L B be the path length for signal net N that is indicated by the last element in the signal net layer information in report R.
- L B is the path length indicated by element 322 d , namely 9.15 (FIG. 3B).
- L B-1 be the path length for signal net N that is indicated by the next-to-last element in the signal net layer information in report R.
- L B ⁇ 1 is the path length indicated by element 322 , namely 9.00 (FIG. 3B).
- M be a scaling factor expressed as a decimal, where 0 ⁇ M ⁇ 1.
- the net property synthesizer 212 may adjust the value of V in step 544 using Equation 2:
- V V ⁇ M ( L B ⁇ L B ⁇ 1 ) Equation 2
- the net property synthesizer 212 subtracts L B ⁇ 1 from L B .
- the resulting difference represents the distance from the coordinates at which signal net N connects to the final (e.g., bottom) layer of package P and the center of the pad on the final layer of package P.
- the net property synthesizer 212 multiplies this difference by the scaling factor M, and then subtracts the scaled difference from the reported package-specific path length to obtain an adjusted package-specific path length which is assigned to V.
- the net property synthesizer 212 adjusts the value of V based on the aggregate length of the vertical segments of signal net N within package P (step 546 ).
- the net property synthesizer 212 may, for example, perform this adjustment by adding the aggregate length of the vertical signal net segments to the value of V. If the distance between package layers is H, and the number of package layers is L, then the net property synthesizer may perform step 546 using Equation 3:
- Equation 3 is based on the assumption, which may be valid in certain package designs, that signal nets only travel in a single direction (such as downward) through package layers. For example, the signal net 706 illustrated in FIG. 7 only travels downward through the package layers 702 a - c . This is not, however, a limitation of the present invention and Equation 3 is provided merely for purposes of example. If, in a particular design, signal nets travel both upwards and downwards through package layers, it may be necessary to adjust the value of V using a technique other than Equation 3, as will be apparent to those of ordinary skill in the art.
- the adjusted value of V may be used in step 516 of FIG. 5A, as described above.
- the package model list 406 has the following logical structure.
- the package model list 406 includes a plurality of list elements 432 a - n , each of which corresponds to a particular one of the package models 202 a - n .
- the package model list 406 includes a Package Model ID column 434 a , a Dielectric column 434 b , a Pads Flag column 434 c , a Pads Factor column 434 d , and a Design Tool ID column 434 e .
- the Package Model ID column 434 a contains a package model identifier (such as a database filename) of the corresponding package model;
- the Dielectric column 434 b contains the dielectric constant of the corresponding package
- the Pads Flag column 434 c contains a binary value which indicates whether the net property synthesizer 212 should perform the synthesized property value adjustment described above with respect to step 544 of FIG. 5E for the corresponding package model;
- Pads Factor column 434 d provides (if applicable) a multiplication factor M (Equation 2) to be used when performing the property value adjustment described above with respect to step 544 of FIG. 5E for the corresponding package model; and
- the Design Tool ID 434 e identifies the package design tool (such as APD) that produced the corresponding package model.
- the net property synthesizer 212 may be capable of synthesizing net property values from package models produced by a plurality of package design tools.
- the package models 202 a - n may include package models produced by more than one package design tool.
- Different package design tools may produce package-specific net property reports having different file formats and containing different information.
- the net property synthesizer 212 may be capable of reading information from package-specific net property reports produced by a plurality of package design tools, and may use the design tool ID 434 e to determine how to read and/or interpret net property values in a particular package-specific net property report.
- the net property synthesizer 212 may, for example, use the design tool ID 434 e during the performance of step 514 (FIG. 5A).
- the net property synthesizer 212 may determine whether any of the synthesized net property values 608 b in the synthesized net property report 214 deviates from a reference net property value by more than a predetermined maximum deviation. The net property synthesizer 212 may alert the user (e.g., the designer of one or more of the package models 202 a - n ) if such a deviation exists.
- This feature may be useful, for example, for determining whether the synthesized propagation delays of signal nets in the package models 202 a - n are equal within the predetermined tolerance. If the synthesized propagation delays of the signal nets are not equal within the predetermined tolerance, the net property synthesizer 212 may alert the user to this fact. The user may take action in response to this alert, such as modifying the design of one or more of the package models 202 a - n to make the synthesized propagation delays of the signal nets match more closely.
- signal nets are typically logically divided into groups. It is typically necessary for all signal nets within a particular signal net group to have the same synthesized propagation delay within a predetermined tolerance, although propagation delays may vary from signal net group to signal net group.
- the signal nets specified by the net property synthesis information 210 are logically divided into signal net groups, and the net property synthesizer 212 determines, for each signal net group, whether the synthesized propagation delays of signal nets in the signal net group are equal within the predetermined tolerance.
- the synthesized signal net list 412 has a logical structure that differs somewhat from that shown in FIG. 4B. As shown in FIG. 4D, the synthesized signal net list 412 includes the same list of signal net names 424 a - j as that shown in FIG. 4B, but the list shown in FIG. 4D is divided into two signal net groups 450 a and 450 b . Although two signal net groups 450 a - b are shown in FIG. 4D, there may be any number of signal net groups.
- each of the signal net groups 450 a - b also includes a reference net name.
- signal net group 450 a includes reference net name 452 a
- signal net group 450 b includes reference net name 452 b .
- the reference net name for a signal net group specifies the name of the signal net whose synthesized property value is to be used by the net property synthesizer 212 as a reference point against which to compare the synthesized property values of all of the signal nets in the signal net group.
- a reference net name may, for example, specify the net name of a strobe signal whose synthesized propagation delay is to be used as a point of reference for all signal nets in a particular signal net group.
- FIG. 8A a flowchart of a method 800 is shown which is used by the net property synthesizer 212 to determine whether any of the synthesized net property values 608 b in the synthesized net property report 214 deviates from a reference net property value by more than a predetermined maximum deviation.
- the method 800 may, for example, be performed after the completion of the method 500 illustrated in FIG. 5A, so that the synthesized net property report 214 may be assumed to exist at the beginning of the method 800 .
- the net property synthesizer 212 enters a loop over each signal net group G in the synthesized net property report 214 (step 802 ).
- the synthesized net property value list 604 is illustrated as a flat list, the synthesized net property value list 604 may alternatively be logically subdivided into groups of net property values corresponding to the signal net groups specified in the synthesized signal net list 412 (FIG. 4D).
- the net property synthesizer 212 identifies a reference value r for group G (step 804 ).
- the net property synthesizer 212 may perform this step by, for example, identifying the reference net name (in the synthesized signal net list 412 ) for group G and using the reference net name as an index into the synthesized net property value list 604 (FIG. 6) to obtain the synthesized net property value of the signal net named by the reference net name.
- the reference value r is the synthesized net property value of the signal net named by group G's reference net name.
- the net property synthesizer 212 enters a loop over each signal net N in the signal net group G (step 806 ).
- the net property synthesizer 212 identifies the synthesized net property value S N of N from the synthesized net property report 214 (step 808 ), and calculates the difference D between the synthesized net property value SN and the reference value r (step 810 ).
- property synthesis information 210 includes a maximum property value deviation D max 438 . If the difference D is greater than D max (step 812 ), the net property synthesizer 212 alerts the user to this fact (step 814 ). In one embodiment, the net property synthesizer 212 performs step 814 as follows. Referring again to FIG. 6, in one embodiment, the synthesized net property value list 604 includes a binary alert flag field 608 c . If the alert flag field 608 c of a particular one of the list elements 606 a - m is set, then the synthesized net property value of the corresponding signal net differs from the appropriate reference value by more than the maximum property value deviation D max 438 .
- the net property synthesizer 212 may therefore perform step 814 of FIG. 8A by setting the alert flag field 608 c of the list element corresponding to signal net N. If the synthesized property value of signal net N does not differ from the reference value r by more than the maximum property value deviation D max 438 , the net property synthesizer 212 may either clear the appropriate alert flag field 608 c or do nothing if the appropriate alert flag field is already cleared.
- the net property synthesizer 212 repeats steps 808 - 814 for each signal net N in signal net group G (step 816 ) and repeats steps 804 - 816 for each signal net group G in the synthesized net property report 214 (step 818 ).
- the user Upon completion of the method 800 , the user has been notified of any signal nets whose synthesized net property values deviate from the appropriate reference values by more than the maximum property value deviation D max 438 .
- the net property synthesizer 212 alerts the user (step 814 ) by setting alert flags in the synthesized net property report 214 , the user may inspect the synthesized net property report 214 upon completion of the method 800 to determine which signal nets, if any, require design modification to bring their synthesized property values into conformance with the synthesized property values of other signal nets in the same signal net group.
- the net property synthesizer 212 assists the user in this task using a method 850 .
- the method 850 may, for example, be performed after or as an integral part of the method 800 illustrated in FIG. 8A.
- the net property synthesizer 212 enters a loop over each signal net group G in the synthesized net property report 214 (step 852 ).
- the net property synthesizer 212 identifies the longest signal net N L in group G (step 854 ) , and identifies the synthesized path length L NL of signal net N L (step 856 ).
- the net property synthesizer 212 enters a loop over each remaining signal net N in the signal net group G (step 858 ).
- the net property synthesizer 212 identifies the synthesized path length L N of signal net N (step 860 ).
- the net property synthesizer 212 calculates the difference D between the longest length L NL and the length L N (step 862 ).
- the difference D represents the amount by which signal net N's synthesized path length L N would need to be increased to equal the synthesized path length L N of signal net N L .
- the net property synthesizer 212 informs the user of the difference D (step 864 ), such as by writing the value of D to the synthesized net property report 214 in a length difference field 608 d (FIG. 6) of the list element corresponding to signal net N.
- the net property synthesizer 212 repeats steps 860 - 864 for each signal net N in signal net group G (step 866 ) and repeats steps 854 - 866 for each signal net group G in the synthesized net property report 214 (step 868 ).
- the user Upon completion of the method 850 , the user has been informed of the distances, if any, by which the synthesized path lengths of signal nets need to be increased in order to equalize the synthesized path lengths. If, for example, the net property synthesizer 212 performs step 864 by writing to the length difference field 608 d in the synthesized net property report 214 , the user may inspect the synthesized net property report 214 upon completion of the method 850 to determine the distance(s) by which signal nets need to be increased in order to equalize synthesized path lengths in the signal net groups.
- the information generated by method 850 may also be provided to an automatic routing tool, which may automatically re-route signal nets in the package models 202 a - n so that the synthesized lengths of signal nets in each signal net group are equal.
- an automatic routing tool may automatically re-route signal nets in the package models 202 a - n so that the synthesized lengths of signal nets in each signal net group are equal. The use of such an automatic routing tool would eliminate the need for the user to perform such re-routing manually.
- Various embodiments of the present invention address these problems by synthesizing property values from multiple package models automatically. Such automated synthesis may be faster and more reliable than manual synthesis.
- the automated synthesis performed by the net property synthesizer 212 may take into account factors such as vertical path length, varying units of measurement, and varying package dielectrics to automate aspects of the synthesis process which are typically performed manually.
- the synthesized net property report 214 may provide synthesized property values in a document that is formatted and organized in a manner that is easy to read and analyze. For example, as described above, the net property synthesizer 212 may divide signal nets into groups and organize the information in the synthesized net property report 214 based on the groups.
- Another advantage of various embodiments of the present invention is the ability to automatically synthesize property values even when the package models 202 a - n use mutually inconsistent signal net naming schemes.
- the signal net mapping 436 may be used to automatically map inconsistent signal names to each other so that property values may be synthesized automatically across packages. Performing such an operation manually is particularly tedious and prone to error.
- the use of the signal net mapping 436 does not require the signal names in existing package models to be changed, and allows package designers to continue to engage in the common practice of using different signal names in different ones of the package models 202 a - n . Rather, inconsistent signal names need only be reconciled in the signal net mapping 436 , the creation of which will typically require less effort than the modification of signal names in the package models 202 a - n.
- Another advantage of various embodiments of the present invention is the ability to synthesize signal net property values across multiple package models, even if the package models have different formats, as in the case when the package models are produced by different package design tools from different vendors.
- the net property synthesizer 212 may perform such synthesis so long as the net property synthesizer 212 can read net property information from the package-specific net property reports 208 a - n (FIG. 2) and process such information as described herein.
- the net property synthesizer 212 synthesizes information provided in the package-specific net property reports 208 a - n , the net property synthesizer 212 need not be capable of directly accessing the package models 202 a - n , which may be represented in proprietary data formats.
- the package-specific net property reports 208 a - n produced by conventional package design tools are typically represented in ASCII text files, from which information may be readily extracted and processed using the techniques described herein.
- Yet another advantage of various embodiments of the present invention is the ability to automatically determine whether synthesized property values (e.g., propagation delays) of signal nets deviate from a reference value by more than a predetermined maximum deviation. Such a determination is required, for example, to perform path length equalization. Making such a determination manually can be tedious, time-consuming, and error-prone, since it typically involves calculating the synthesized property values manually and, manually comparing each of the synthesized property values to the predetermined reference value, and manually determining whether any of the synthesized property values deviates from the predetermined reference value by more than the predetermined maximum deviation. In contrast, as described above with respect to FIG.
- synthesized property values e.g., propagation delays
- various embodiments of the present invention may both perform this task automatically and alert the user to any problematic synthesized property values.
- the net property synthesizer 212 may provide such alerts in the synthesized net property report 214 itself, which the user may readily analyze and use to inform modifications to the package models 202 a - n.
- the net property synthesizer 212 may (as described above with respect to FIG. 8B) assist the package designer in modifying the package design(s) to eliminate the identified problem(s).
- the net property synthesizer 212 may, for example, inform the package designer of the lengths by which signal nets must be increased so that all signal nets in a group have the same aggregate path length. Such a feature eliminates the need for the package designer to manually calculate such length increases, thereby further simplifying the task of the package designer.
- FIGS. 5 A- 5 E may be combined in any combination to perform combinations of the functions illustrated therein.
- FIGS. 5 A- 5 E may be combined in any combination to perform combinations of the functions illustrated therein.
- the process 800 es (FIG. 8A) and 850 (FIG. 8B) may be performed after completion of the process 500 (FIG. 5)
- the processes 500 , 800 , and 850 may be combined into a single process using techniques that are well-known to those of ordinary skill in the art.
- net property synthesizer 212 and the net property synthesis information 210 are illustrated in FIG. 2 as distinct entities, it should be appreciated that they may be combined or further subdivided.
- the net property synthesizer 212 may be hard-coded with information contained in the net property synthesis information 210
- the net property synthesis function 216 may be contained in the net property synthesis information 210 .
- the techniques described above may be implemented, for example, in hardware, software, firmware, or any combination thereof.
- the net property synthesizer 212 may, for example, be implemented as a computer program.
- the techniques described above may be implemented in one or more computer programs executing on a programmable computer including a processor, a storage medium readable by the processor (including, for example, volatile and non-volatile memory and/or storage elements), at least one input device, and at least one output device.
- Program code may be applied to input entered using the input device to perform the functions described and to generate output.
- the output may be provided to one or more output devices.
- Each computer program within the scope of the claims below may be implemented in any programming language, such as assembly language, machine language, a high-level procedural programming language, or an object-oriented programming language.
- the programming language may, for example, be a compiled or interpreted programming language.
- the net property synthesizer 212 is implemented using the Perl programming language.
- Each such computer program may be implemented in a computer program product tangibly embodied in a machine-readable storage device for execution by a computer processor.
- Method steps of the invention may be performed by a computer processor executing a program tangibly embodied on a computer-readable medium to perform functions of the invention by operating on input and generating output.
- Suitable processors include, by way of example, both general and special purpose microprocessors.
- the processor receives instructions and data from a read-only memory and/or a random access memory.
- Storage devices suitable for tangibly embodying computer program instructions include, for example, all forms of non-volatile memory, such as semiconductor memory devices, including EPROM, EEPROM, and flash memory devices; magnetic disks such as internal hard disks and removable disks; magneto-optical disks; and CD-ROMs. Any of the foregoing may be supplemented by, or incorporated in, specially-designed ASICs (application-specific integrated circuits).
- a computer can generally also receive programs and data from a storage medium such as an internal disk (not shown) or a removable disk.
Landscapes
- Engineering & Computer Science (AREA)
- Physics & Mathematics (AREA)
- Theoretical Computer Science (AREA)
- General Physics & Mathematics (AREA)
- Computer Hardware Design (AREA)
- Business, Economics & Management (AREA)
- Geometry (AREA)
- General Engineering & Computer Science (AREA)
- Evolutionary Computation (AREA)
- Accounting & Taxation (AREA)
- Development Economics (AREA)
- Economics (AREA)
- Finance (AREA)
- Marketing (AREA)
- Strategic Management (AREA)
- Technology Law (AREA)
- General Business, Economics & Management (AREA)
- Design And Manufacture Of Integrated Circuits (AREA)
Abstract
Techniques are disclosed for automatically synthesizing information from a plurality of computer-readable integrated circuit package models. In one embodiment, each of the plurality of package models contains information descriptive of a distinct package. Such information may include, for example, intra-package path lengths and/or propagation delays of signal nets in the modeled packages. Techniques are disclosed for automatically synthesizing such information to produce, for example, aggregate path lengths and/or propagation delays of the signal nets across all of the modeled packages. Such synthesis may be performed even when the package models use mutually inconsistent signal net naming conventions and the modeled packages are composed of different materials. Techniques are also disclosed for providing information to the package designer to assist the package designer in improving the design of the package models.
Description
- This application is a divisional application of commonly-owned U.S. patent application Ser. No. 10/179,077, filed on May 13, 2002, entitled “Synthesizing Signal Net Information from Multiple Integrated Circuit Package Models”.
- 1. Field of the Invention
- The present invention relates to integrated circuit package design and, more particularly, to synthesizing information about signal nets from multiple integrated circuit package models.
- 2. Related Art
- Integrated circuits (ICs) are becoming increasingly large and complex, typically including millions of individual circuit elements such as transistors and logic gates. As a result of this increased size and complexity, IC designers are increasingly using electronic design automation (EDA) software tools to assist with IC design. Such tools help to manage the complexity of the design task in a variety of ways, such as by allowing ICs to be designed hierarchically, thereby enabling the design to be divided into modules and enabling the design task to be divided among multiple designers in a manner that limits the complexity faced by any one designer.
- Various hardware description languages (HDLs) have been developed which allow circuit designs to be described at various levels of abstraction. A description of a circuit according to an HDL (referred to herein as an “HDL model” of the circuit) may, for example, describe a particular circuit design in terms of the layout of its transistors and interconnects on an IC, or in terms of the logic gates in a digital system. Descriptions of a circuit at different levels of abstraction may be used for different purposes at various stages in the design process. HDL models may be used for testing circuits and circuit designs, as well as for fabricating the circuits themselves. The two most widely-used HDLs are Verilog and VHDL (Very High Speed Integrated Circuits (VHSIC) Hardware Description Language), both of which have been adopted as standards by the Institute of Electrical and Electronics Engineers (IEEE). VHDL became IEEE Standard 1076 in 1987 and Verilog became IEEE Standard 1364 in 1995.
- EDA tools are typically capable of converting a functional HDL description of a circuit design into a specific circuit implementation. The specific circuit implementation may be represented by a “netlist,” which identifies both the elements of the circuit and the interconnections among them. In general, a netlist describes the circuit design in terms of nodes and edges. Each node represents a circuit element and each edge represents an interconnection between two circuit elements. Netlists may describe circuits at various levels of abstraction. A netlist may, for example, describe circuit elements in terms of specific structural components (such as resistors and transistors) or in terms of high-level “cells” that may be decomposed into specific structural components and/or other cells. A netlist may, for example, describe the connections between cells in terms of specific cell-to-cell pin connections.
- EDA tools are typically capable of converting a netlist into a physical layout of the circuit. The layout process involves both “placement” (assigning specific coordinates in the circuit layout to each cell) and “routing” (wiring or connecting cells together). The layout produced thereby defines the specific dimensions and coordinates of the gates, interconnects, contacts, and other elements of the circuit. The layout may have multiple layers, corresponding to the layers of the circuit. The layout may be used to form a mask, which in turn may be provided to a foundry to fabricate the integrated circuit itself.
- One stage in the process of IC design is package design, which refers to the design of substrates (packages) for interconnecting layers of the IC. An IC typically includes multiple packages interconnected in layers. Each package, in turn, may include multiple layers. Packages within a single IC may be composed of varying materials having varying electrical properties. Individual signal nets (also referred to herein simply as “nets”) in the IC may be distributed across multiple packages. A package design must ensure that signals in the IC have sufficient power and maintain sufficient signal integrity when passing from one layer of the IC to another. As used herein, the term “signal net” (or simply “net”) refers to a collection of conductors that are connected to form a complete circuit connecting at least one output to at least one input.
- As with IC design more generally, various tools exist for automating aspects of IC package design. Such tools typically provide a graphical user interface through which package designers may visually design the IC package in three dimensions. One such tool is Advanced Package Designer (APD), available from Cadence Design Systems, Inc. of San Jose, Calif. APD is a software program which allows the package designer to model the physical, electrical, and thermal characteristics of the package substrate. An APD package design database may be provided to a foundry to be used directly as manufacturing input for fabrication of the designed package.
- Referring to FIG. 1, relevant features of a
conventional system 100 for designing IC packages are illustrated in block diagram form. A package design tool (not shown), such as APD, maintains a plurality of package models 102 a-n, each of which contains information defining a particular package in an IC design. The package models 102 a-n may include, for example, information specifying the name, location, and length of each signal trace in each layer of the package models 102 a-n. Each of the package models 102 a-n is typically stored in a distinct database file in a computer system. - Package design tools typically allow a package designer to access and modify only a single one of the package models102 a-n at a time. To modify a particular one of the package models 102 a-n, the package designer must typically use the package design tool to open the database file corresponding to the package model to be modified. Upon opening one of the package models 102 a-n, the package design tool may provide a graphical user interface which displays a two-dimensional or three-dimensional representation of the package model and which allows the package designer to modify the package model. Techniques for creating and modifying packages using such package design tools are well-known to those of ordinary skill in the art. To modify a different one of the package models 102 a-n, the package designer must typically close the current package model and use the package design tool to open the other package model.
- Package design tools are typically capable of generating various kinds of reports containing information about the package models102 a-n. One such report is a net length report, which contains information about the package-specific (intra-package) path length of each signal net within a particular one of the package models 102 a-n. In other words, for each signal net within a particular package, the net length report indicates the length of that portion of the signal net which runs through the package. Such a report is therefore referred to herein as a “package-specific net length report.”
- For example, as shown in FIG. 1, a net length report generator104 (which may, for example, be part of the package design tool that was used to design the package models 102 a-n) generates package-specific net length reports 108 a-n, each of which contains the package-specific path lengths of signal nets within a corresponding one of the package models 102 a-n. For example, package-specific
net length report 108 a contains the package-specific path lengths of signal nets withinpackage model 102 a. - The package-specific net length reports108 a-n may include various kinds of information about the path lengths of signal nets in the package models 102 a-n. In their simplest form, for example, each of the package-specific net length reports 108 a-n may contain a list of the names of all of the signal nets in the corresponding package model and the path length of each such signal net within the corresponding package model. A more detailed report may include information not only about the path length of each signal net within a package, but also information about the length of each signal net within each layer of the package.
- It is often desirable or necessary to synthesize information about multiple ones of the package models102 a-n. For example, it may be desirable or necessary to calculate the total path lengths of signal nets through all of the package models 102 a-n, or to calculate the total propagation delays of signal nets through all of the package models 102 a-n. Such information synthesis is useful, for example, to perform length equalization (also referred to as “skew equalization”), which involves equalizing the path lengths of multiple signal nets in a group of signal nets. It may also be desirable to ensure that signal nets within particular signal net groups have the same total propagation delay through the IC within a specified tolerance. Conventional package design tools typically are not capable of performing such information synthesis automatically because they operate on only one of the package models 102 a-n at a time. As a result, it typically is necessary for package designers to calculate total signal net path lengths and propagation delays manually, which is a tedious, time-consuming, and error-prone process.
- What is needed, therefore, are improved techniques for synthesizing information about signal nets from multiple package models.
- Techniques are disclosed for automatically synthesizing information from a plurality of computer-readable integrated circuit package models. In one embodiment, each of the plurality of package models contains information descriptive of a distinct package. Such information may include, for example, intra-package path lengths and/or propagation delays of signal nets in the modeled packages. Techniques are disclosed for automatically synthesizing such information to produce, for example, aggregate path lengths and/or propagation delays of the signal nets across all of the modeled packages. Such synthesis may be performed even when the package models use mutually inconsistent signal net naming conventions and the modeled packages are composed of different materials. Techniques are also disclosed for providing information to the package designer to assist the package designer in improving the design of the package models.
- In one aspect of the present invention, a method is provided for use in a system is provided which includes a plurality of models of integrated circuit packages. The plurality of models include package-specific values of a property (such as signal net path length and/or signal net propagation delay) of a plurality of signal nets in the integrated circuit packages. The method includes steps of: (A) selecting a first one of the plurality of signal nets; (B) selecting, from a first one of the plurality of models, a first package-specific value of the property of the first signal net; (C) selecting, from a second one of the plurality of models, a second package-specific value of the property of the first signal net; and (D) applying a synthesis function (such as addition) to the first and second package-specific values to produce a synthesized property value.
- In another aspect of the present invention, a method is provided for use in a system including a plurality of property values of a plurality of signal nets in an integrated circuit. The method includes steps of: (A) identifying a reference value r; and (B) for each property value S in the plurality of property values (e.g., signal net path lengths and/or signal net propagation delays), performing steps of: (1) determining whether property value S differs from reference value r by more than a predetermined amount; and (2) notifying a user of the system if it is determined that the property value S differs from the reference value r by more than the predetermined amount. The reference value r may be selected from among the plurality of property values.
- In yet another aspect of the present invention, a method is provided for use in a system including a plurality of property values of a plurality of signal nets in an integrated circuit. The method comprises steps of: (A) identifying a reference value r; and (B) for each property value S in the plurality of property values, performing steps of: (1) identifying a difference D between property value S and reference value r; and (2) notifying a user of the system of the difference D.
- Other features and advantages of various aspects and embodiments of the present invention will become apparent from the following description and from the claims.
- FIG. 1 is a functional block diagram of a prior art system for generating package-specific net length reports describing the lengths of signal nets within packages of an IC design;
- FIG. 2 is a functional block diagram of a system for synthesizing signal net information from multiple integrated circuit package models according to one embodiment of the present invention;
- FIG. 3A is a block diagram of the logical structure of two package-specific net property reports generated by an integrated circuit package design tool;
- FIG. 3B is a block diagram of the logical structure of a detailed package-specific net property report generated by an integrated circuit package design tool;
- FIG. 4A is a is a block diagram of the logical structure of property synthesis information that is used to synthesize package-specific signal net property information according to one embodiment of the present invention;
- FIG. 4B is a block diagram of the logical structure of particular embodiments of package-specific signal net lists and a synthesized signal net list according to one embodiment of the present invention;
- FIG. 4C is a block diagram of the logical structure of a package model list according to one embodiment of the present invention;
- FIG. 4D is a block diagram of the logical structure of a synthesized signal net list according to one embodiment of the present invention;
- FIG. 5A is a flowchart of a method that is used by a net property synthesizer to synthesize package-specific net property reports into a synthesized net property report according to one embodiment of the present invention;
- FIG. 5B is a flowchart of a method that is used by a net property synthesizer to calculate total propagation delays of signal nets through an integrated circuit according to one embodiment of the present invention;
- FIG. 5C is a flowchart of a method that is used by a net property synthesizer to convert a net property value from one unit of measurement into another according to one embodiment of the present invention;
- FIG. 5D is a flowchart of a method that is used by a net property synthesizer to map signal net names used in multiple package models according to one embodiment of the present invention;
- FIG. 5E is a flowchart of a method that is used by a net property synthesizer to adjust a synthesized net property value according to one embodiment of the present invention;
- FIG. 6 is a block diagram of the logical structure of a synthesized signal net property report according to one embodiment of the present invention;
- FIG. 7 is a perspective view of an integrated circuit package having multiple layers and a single signal net;
- FIG. 8A is a flowchart of a method a flowchart which is used by a net property synthesizer to determine whether a synthesized net property value deviates from a reference net property value by more than a predetermined maximum deviation according to one embodiment of the present invention; and
- FIG. 8B is a flowchart of a method for assisting a user with the task of skew equalization in an integrated circuit package design according to one embodiment of the present invention.
- Referring to FIG. 2, a
system 200 is illustrated for synthesizing signal net information from a plurality of IC package models 202 a-n according to one embodiment of the present invention. As described above, a particular integrated circuit may include a plurality of interconnected packages arranged in layers. In thesystem 200 shown in FIG. 2, each of the package models 202 a-n is a model of a particular IC package in a design for a particular integrated circuit. The package models 202 a-n may, for example, be created and maintained using a package design tool, such as the Advanced Package Designer (APD) software described above. Package design tools such as APD typically maintain a distinct model (in the form of a database) for each package in the IC design. - The package design tool includes a net
property report generator 204, which may, for example, be a package-specific net length report generator as described above with respect to FIG. 1. In general, the netproperty report generator 204 generates package-specific net property reports 208 a-n, each of which corresponds to a particular one of the package models 202 a-n. For each of the package models 202 a-n, the netproperty report generator 204 extracts the value of a particular property (referred to herein as “the reported property”) of each of the signal nets in the package model, and includes the extracted property values in the corresponding net property report. Reported properties may include, for example, the path length or propagation delay of signal nets within a particular package. - The value of a particular signal net property for a particular package model is referred to herein as a “package-specific property value” or as an “intra-package property value.” The package-specific
net property report 208 a may, for example, include the package-specific path lengths of the signal nets inpackage model 202 a. - In one embodiment of the present invention, a
net property synthesizer 212 is provided which synthesizes information contained in the plurality of package-specific net property reports 208 a-n into a singlesynthesized property report 214 based onproperty synthesis information 210. If, for example, the reported property is path length, the synthesizedproperty report 214 may include a list of the synthesized (i.e., total) path lengths of each of one or more of the signal nets through all of the packages modeled by the package models 202 a-n. More specifically, thenet property synthesizer 212 includes a net propertysynthesis function F 216 which thenet property synthesizer 212 may use to synthesize the package-specific property values for each signal net into corresponding “synthesized property values” that are stored in the synthesizedproperty report 214. - Operation of the
system 200 according to various embodiments of the present invention will now be described in more detail. Referring to FIG. 3A, examples of the logical structure of two of the package-specific net property reports 208 a and 208 b are illustrated in more detail. Net property reports having the logical structure illustrated in FIG. 3A may be generated by conventional package design tools, such as APD. The package-specific net property reports 208 a and 208 b may, for example, report on the path lengths or propagation delays of particular signal nets within the corresponding packages. - The package-specific
net property report 208 a (which reports on thepackage model 202 a) includes a netproperty value list 304, which lists the values of the reported property (e.g., path length or propagation delay) for the signal nets within the corresponding package (i.e., the package modeled bypackage model 202 a). Thelist 304 includes a plurality of list elements 306 a-m, where m is the number of elements in the list (i.e., the number of signal nets reported on by thereport 208 a). Each of the list elements 306 a-m includes anet name field 308 a and anet property value 308 b field. In each of the list elements 306 a-m, thenet name field 308 a identifies the name of a particular signal net within the corresponding package, and the netproperty value field 308 b indicates the value of the reported property for the signal net identified by thenet name field 308 a. For example, if the reported property is signal net path length, then each of the list elements 306 a-m indicates the name of a particular signal net and the path length of that signal net within the corresponding package. - The package-specific
net property report 208 a also includes a property units specifier 302 which specifies the units in which thenet property values 308 b are expressed. Path lengths may, for example, be expressed in units of millimeters, mils, or microns in a particular report. The property units specifier 302 specifies the units in which thenet property values 308 b are expressed so that thenet property values 308 b may be interpreted either by a human operator or by the net property synthesizer 212 (FIG. 2), as described in more detail below. - The package-specific
net property report 208 b has the same logical structure as the package-specificnet property report 208 a. More specifically, the package-specificnet property report 208 b includes a netproperty value list 312, which lists the values of the reported property for a plurality of nets within the corresponding package (in this case, the package modeled bypackage model 202 b). Thelist 312 includes a plurality of list elements 314 a-m. Each of the list elements 314 a-m includes anet name field 316 a and anet property value 316 b field. Although thelists lists net property report 208 b also includes a property units specifier 310 which specifies the units in which thenet property values 316 b are expressed. - The
net property values 308 b inreport 208 a and thenet property values 316 b inreport 208 b may be expressed in the same or in different units (indicated by theproperty units specifiers property report generator 204 specifies the units in which net property values in a particular report should be expressed. The package-specific net property reports 208 a-n may, for example, be implemented as text files, elements of which (such as the property units specifier 302 and the property units specifier 310) may be implemented as text strings, as will be well-understood by those of ordinary skill in the art. - As described in more detail below with respect to FIG. 5, the net property synthesizer212 (FIG. 2) uses the net property value lists and the property unit specifiers in the package-specific net property reports 208 a-n to generate a synthesized net property value list in the synthesized
property report 214. Before describing how this operation may be performed, one embodiment of theproperty synthesis information 210 will be described in more detail. - Referring to FIG. 4A, the logical structure of the
property synthesis information 210 is illustrated according to one embodiment of the present invention. In general, theproperty synthesis information 210 includes information for: (1) identifying the package models 202 a-n from which signal net property values should be synthesized; (2) selecting one or more signal nets within the identified package models 202 a-n for which signal net property values should be synthesized; and (3) specifying the format of the synthesizedproperty report 214 to be generated by thenet property synthesizer 212. - More specifically, in one embodiment, the
property synthesis information 210 includesinput parameters 402 andoutput parameters 404. Theinput parameters 402 include apackage model list 406 and an input signalnet list 408. Thepackage model list 406 lists the package models 202 a-n from which signal net property values are to be synthesized by thenet property synthesizer 212. The package models 202 a-n may, for example, be a subset of the package models in a complete IC design. Thepackage model list 406 may, for example, identify the package models 202 a-n using the filenames of the database files containing the package models 202 a-n or using the filenames of the package-specific net property reports 208 a-n corresponding to the package models 202 a-n. Thepackage model list 406 may include additional information about each of the package models 202 a-n, as described in more detail below with respect to FIG. 4C. - The input signal
net list 408 lists the signal nets for which property values are to be synthesized by thenet property synthesizer 212. It may be desirable, for example, to synthesize property values for only certain signal nets, and the input signalnet list 408 provides a mechanism for doing so. The input signalnet list 408 may, for example, identify signal nets using the same net names as thenet names - In one embodiment, the
output parameters 404 include a synthesizedproperty units selector 410 and a synthesized signalnet list 412. The synthesizedproperty units selector 410 specifies the units in which synthesized property values should be expressed in the synthesizedproperty report 214. As described above, package-specific property values may be expressed in different units in different ones of the package-specific net property reports 208 a-n. The synthesizedproperty units selector 410 may select a unit of measurement that is employed by one or more of the package-specific net property reports 208 a-n or may select a unit of measurement that is not employed by any of the package-specific net property reports 208 a-n. - The synthesized signal
net list 412 lists the names that should be used to identify signal nets in the synthesizedproperty report 214. The synthesized signalnet list 412 may, for example, specify the same or different names than those used in the package models 202 a-n. In certain embodiments, such as when all of the package models 202 a-n use the same set of signal net names, the synthesized signalnet list 412 may be omitted from the netproperty synthesis information 210 and thenet property synthesizer 212 may name the signal nets in the synthesizednet property report 214 using the names provided in the input signalnet list 408. - As described in more detail below with respect to FIG. 4B, a particular signal net may span more than one of the package models202 a-n, but may have different signal net names in different ones of the package models 202 a-n. In such a case, the net
property synthesis information 210 may include amapping 436 between signal names used in the package-specific net property reports 208 a-n and signal names to be used to identify signal nets in the synthesizednet property report 214. - Referring to FIG. 6, an example of the logical structure of the synthesized
net property report 214 is illustrated according to one embodiment of the present invention. The synthesizednet property report 214 includes a synthesized netproperty value list 604, which lists the synthesized property values generated by thenet property synthesizer 212 by synthesizing the package-specific property values contained in the package-specific net property reports 208 a-n. Thelist 604 includes a plurality of list elements 606 a-m, where m is the number of elements in the list (i.e., the number of signal nets synthesized by the net property synthesizer 212). Each of the list elements 606 a-m includes a synthesizednet name field 608 a and a synthesized net property value field. In each of the list elements 606 a-m, the synthesizednet name field 608 a identifies a particular signal net N within the package models 202 a-n, and the synthesized netproperty value field 608 b indicates the synthesized property value produced by thenet property synthesizer 212 for signal net N. The synthesizednet property report 214 also includes a synthesized property units specifier 602 which specifies the units in which the synthesizednet property values 608 b are expressed. The synthesized property units specifier 602 specifies the same units as are specified by the synthesized property units selector 410 (FIG. 4A). - Although the embodiment of the synthesized
net property report 214 illustrated in FIG. 6 includes only the single synthesized netproperty value field 608 b, the synthesizednet property report 214 may include any number of synthesized net property value fields. For example, the synthesizednet property report 214 may include two synthesized net property value fields, one for storing synthesized signal net path lengths and the other for storing synthesized signal net propagation delays. - Referring to FIG. 5A, a flowchart of a
method 500 is shown that is used by the net property synthesizer 212 (FIG. 2) to synthesize package-specific property values in the package-specific net property reports 208 a-n into synthesized property values in the synthesizedproperty report 214 according to one embodiment of the present invention. Thenet property synthesizer 212 identifies the package models from which signal net property values are to be synthesized (step 502). Thenet property synthesizer 212 may, for example, identify these package models by reading the package model list 406 (FIG. 4A). For purposes of example, assume that the package models identified instep 502 are the package models 202 a-n illustrated in FIG. 2. The package models 202 a-n may, for example, be a subset of all of the package models in a particular IC design. - The
net property synthesizer 212 identifies the signal nets from which package-specific property values should be synthesized (step 504). Thenet property synthesizer 212 may, for example, identify these signal nets by reading the input signal net list 408 (FIG. 4A). Thenet property synthesizer 212 initializes the synthesized property report 214 (step 506). If, for example, the synthesizedproperty report 214 is to be stored in a text file, thenet property synthesizer 212 may initialize the synthesizedproperty report 214 by creating and opening an empty text file. - The
net property synthesizer 212 enters a loop over each signal net N in the list of identified signal nets (step 508). Thenet property synthesizer 212 synthesizes package-specific property values for the signal net N into a single synthesized property value as follows. Thenet property synthesizer 212 initializes a synthesized property value SN for the signal net N (step 510). If, for example, the property to be synthesized is signal net path length, thenet property synthesizer 212 may initialize the value of SN to zero. In the present example, all of the package-specific net property reports 208 a-n report on the same property, and therefore the “property to be synthesized” by thenet property synthesizer 212 is defined by the property that is reported on by the package-specific net property reports 208 a-n. - The
net property synthesizer 212 enters a loop over each package model P in the identified list of package models (step 512). Thenet property synthesizer 212 identifies the package-specific property value V of signal net N in package model P (step 514). Thenet property synthesizer 212 may perform this step, for example, by searching through the signal net property list (such aslist - The
net property synthesizer 212 updates the value of the synthesized property value SN by applying the property synthesis function 216 (FIG. 2) to the existing value of SN and the package-specific property value V (step 516). In other words, thenet property synthesizer 212 updates the value of SN by applying the formula SN=F(SN, V). Theproperty synthesis function 216 may, for example, be an arithmetic function such as addition or multiplication. If, for example, the property to be synthesized is path length or propagation delay, theproperty synthesis function 216 may be addition. - The
net property synthesizer 212 repeatssteps net property synthesizer 212 writes the synthesized property value SN to the synthesized property report 214 (step 520). Step 520 includes writing the synthesized net name of signal net N to the synthesized property report 214 (FIG. 6). - The
net property synthesizer 212 repeats steps 510-520 for each of the identified signal nets N (step 522). Upon completion of themethod 500, the synthesizedproperty report 214 includes synthesizedproperty values 608 b for all of the signal nets specified by the input signalnet list 408. - Having described the general operation of the
system 200 illustrated in FIG. 2, a particular embodiment will now be described in which the reports 208 a-n include the package-specific path lengths of signal nets in the package models 202 a-n, and in which thenet property synthesizer 212 calculates the total (i.e., synthesized) propagation delays of the signal nets based on: (1) the package-specific path lengths of the signal nets, and (2) the dielectric constants and permeabilities of the layers of the packages. - Different packages are often composed of different materials. As a result, a signal in a particular signal net may travel more quickly through one package than another. To calculate the total propagation delay of such a signal net, it may be necessary to take into account the speed at which signals travel through different packages in the IC.
- For example, referring to FIG. 5B, in one embodiment of the
net property synthesizer 212 calculates total propagation delays by implementing step 516 (application of the property synthesis function 216) as follows. - The
net property synthesizer 212 calculates the intra-package propagation delay PD of the signal net N using Equation 1: - PD=L{square root}{square root over (DK·p)}
Equation 1 - where L is the intra-package path length of signal net N, DK is the dielectric constant of the package substrate, and p is the permeability of the package substrate (step524). The length L is the package-specific property value V obtained in
step 514 of FIG. 5A. - The
net property synthesizer 212 updates the value of the synthesized property value SN, which in this case represents a propagation delay, by adding the value of PD to the current value of SN and assigning the result to SN (step 526). In summary, steps 524 and 526 update the value of SN by calculating the intra-package propagation delay of signal net N through package P and adding this intra-package propagation delay to the total propagation delay SN. - As described above with respect to FIG. 3A, net property values may be expressed in different units of measurement in different ones of the package-specific net property reports208 a-n. In one embodiment, the
net property synthesizer 212 converts package-specific net property values in the package-specific net property reports 208 a-n into the units specified by the synthesized property units selector 410 (FIG. 4A) when generating the synthesizednet property report 214. - Referring to FIG. 5C, for example, in one embodiment of the present invention, the
net property synthesizer 212 performs this unit conversion by identifying the property value V of signal net N in package model P (step 514 of FIG. 5A) as follows. Thenet property synthesizer 212 reads the package-specific property value V from the package-specific net property report for package model P (step 528). The value of V that is read instep 528 is expressed in the units specified by the package-specific net property report's property units specifier (such as the property units specifier 302 in the case of the package-specific net property report illustrated in FIG. 3A). Thenet property synthesizer 212 converts the value of V into the units specified by the synthesized property units selector. 410 (FIG. 4A). This converted value of V is then used by thenet property synthesizer 212 instep 516 of themethod 500 illustrated in FIG. 5A. - The
net property synthesizer 212 may perform the units conversion instep 530 using techniques that are well-known to those of ordinary skill in the art. Thenet property synthesizer 212 may, for example, include conversion factors for converting among various net property units (such as millimeters, mils, and microns). The units conversion ofstep 530 may then be performed by multiplying the package-specific value of V obtained instep 528 by a conversion factor that is selected based on the package-specific property units of V and the synthesized property units to be obtained. - As mentioned above with respect to FIG. 4A, signal nets may have different names in different ones of the package models202 a-n. To identify the package-specific property value V of a particular signal net N in a package P (FIG. 5A, step 514), the
net property synthesizer 212 must know which name is used to identify signal net N in package P. In one embodiment, signal net mapping 436 (FIG. 4A) provides two mappings to enable to thenet property synthesizer 212 to perform this task: (1) a mapping between signal net names in the package models 202 a-n that are used to identify the same signal net; and (2) a mapping between signal net names in the package models 202 a-n and synthesized signal net names to be used in the synthesizedproperty report 214. - For example, referring to FIG. 4B, a particular embodiment of the signal
net mapping 436 is illustrated. In the embodiment illustrated in FIG. 4B, the signalnet mapping 436 is implemented using the input signalnet list 408 and the synthesized signalnet list 412. In the illustrated embodiment, the input signalnet list 408 includes a plurality of signalnet lists 414 a-n, each of which corresponds to a particular one of the package models 202 a-n. For example, signalnet list 414 a corresponds to packagemodel 202 a, signalnet list 414 b corresponds to packagemodel 202 b, and so on. Each of the signalnet lists 414 a-n includes a list of the names that the corresponding package model uses to identify the signal nets to be synthesized by thenet property synthesizer 212. - Each of the signal
net lists 414 a-n includes j elements, where j is less than or equal to the number of signal nets in the package models 202 a-n. In other words, the signalnet lists 414 a-n may identify all or any subset of the signal nets in the package models 202 a-n. - The plurality of signal
net lists 414 a-n provides a mapping among signal net names in the package models 202 a-n (and therefore also provides a mapping among signal net names in the package-specific net property reports 208 a-n) which refer to the same signal net. For any number k (where k≦j), the kth element of each of thelists 414 a-n refers to the same signal net. Consider, for example, the first net name in each of the signalnet lists 414 a-n. Signalnet name 416 a (in package-specific signalnet list 414 a), signalnet name 418 a (in package-specific signalnet list 414 b), and signal net name 420 n (in package-specific signalnet list 414 n) refer to the same signal net N. More specifically, signalnet name 416 a is the name thatpackage model 202 a uses to refer to signal net N, signalnet name 418 a is the name thatpackage model 202 b uses to refer to signal net N, and so on. As described above, signal net N may have different names in different ones of the package models 202 a-n. The package-specific signalnet lists 414 a-n therefore provide a mechanism for identifying which signal net names in different ones of the package models 202 a-n refer to the same signal net. - Assume, for example, that the name for signal net N is “signal1” in
package model 202 a, “sig1” inpackage model 202 b, and “data_signal1” inpackage model 202 n. Such differences in the names of signal nets across package models are common, particularly when each of the package models 202 a-n is designed by a different designer or team of designers. In this particular example, thenet name 416 a would contain the value “signal1”, thenet name 418 a would contain the value “sig1”, and thenet name 420 a would contain the value “data_signal1”, thereby indicating that each of these names refers to the same signal net in corresponding ones of the package models 202 a-n. - The synthesized signal
net list 412 provides a list of signal net names 424 a-j to use in the synthesizedproperty report 214. Thefirst name 424 a in the synthesized signalnet list 412 is the name to be used for the first signal net in the package-specific signalnet lists 414 a-n, thesecond name 424 b is the name to be used for the second signal net in the package-specific signalnet lists 414 a-n, and so on. Assume for purposes of example that the firstnet name 424 a in the synthesized signalnet list 412 is “signal_1”. In this case the synthesized net property value that is synthesized from the signal net having thenames 416 a (“signal1”), 418 a (“sig1”), and 420 a (“data signal1”) will be given the name “signal —1” in the synthesizedproperty report 214. - For example, referring to FIG. 5D, in one embodiment of the present invention, the
net property synthesizer 212 uses the signalnet mapping 436 to identify the value V of signal net N in package model P (step 514 of FIG. 5A) as follows. Thenet property synthesizer 212 identifies the package-specific signal net list for package model P (step 532). Thenet property synthesizer 212 may readily perform this step in any of a variety of ways. For example, in one embodiment, in themethod 500 illustrated in FIG. 5A thenet property synthesizer 212 maintains a counter p through each iteration of the loop performed in steps 512-522. The value of p may, for example, be initialized to zero and be incremented at the end of each iteration of the loop. The counter p may therefore be used to identify corresponding ones of the package models 202 a-n, the package-specific net property reports 208 a-n, and the package-specific signalnet lists 414 a-n. For example, the value p=0 may identify thepackage model 202 a, the package-specificnet property report 208 a, and the package-specific signalnet list 414 a. Thenet property synthesizer 212 may therefore identify the package-specific signal net list for package model P (step 532) as the pth one of the package-specific signalnet lists 414 a-n. - The
net property synthesizer 212 identifies the name of signal net N in the package-specific signal net list identified in step 532 (step 534). Thenet property synthesizer 212 may perform this step by, for example, using a counter to count each iteration of the loop performed in steps 508-522 of FIG. 5A, and by using this counter as an index into the package-specific signal net list identified instep 532. If, for example, the identified package-specific signal net list islist 414 a (FIG. 4B), a counter with a value of zero would identify signalnet name 416 a. - The
net property synthesizer 212 uses the signal net name identified instep 534 to identify the package-specific property value V in the package-specific property report for package model P (step 536). Thenet property synthesizer 212 may, for example, identify the package-specific property report for package model P using the counter p described above. Assume for purposes of example that the identified package-specific property report is report 208 a (FIG. 3A). Thenet property synthesizer 212 may performstep 536 by searching thenet names 308 a for the signal net name identified instep 534 and selecting the correspondingnet property value 308 b as the value for V. Upon completion of the process illustrated in FIG. 5D, the identified value of V may be used instep 516 of FIG. 5A. - It should be appreciated from the description above that the process illustrated in FIG. 5D enables the
net property synthesizer 212 to synthesize property values from the package models 202 a-n even when the package models 202 a-n use different names to refer to the same signal nets. - An embodiment of the present invention will now be described in more detail in which the package-specific net property reports208 a-n include property values for each layer in the package models 202 a-n. To clarify the explanation of this embodiment, various features of signal nets in multi-layer packages will first be described.
- Referring to FIG. 7, an
example package 700 having three layers 702 a-c is illustrated. It should be appreciated that the layers 702 a-c are not drawn to scale and that in general only relevant features of the layers 702 a-c are shown for ease of illustration and explanation. The three dimensions of thepackage 700 are illustrated using x, y, and z axes. The values provided on the x and y axes in FIG. 7 do not correspond to particular units of measurement (such as millimeters or mils), but rather are generic units provided merely for ease of illustration and explanation. - For ease of reference,
layer 702 a will be referred to as the “top” layer ofpackage 700,layer 702 b as the “middle” layer ofpackage 700, and layer 702 c as the “bottom” layer ofpackage 700. Althoughpackage 700 has three layers 702 a-c, in practice packages may have any number of layers. Thepackage 700 may be one of multiple packages in an IC (not shown). - A portion of a signal net is also shown in FIG. 7. The signal net is referred to herein by reference numeral706 and includes segments 706 a-g. Although only one signal net 706 is shown, a typical package may include thousands of signal nets. A
segment 704 of the signal net 706 connects to thetop layer 702 a of thepackage 700 from a package (not shown) that is above thepackage 700 in the IC.Segment 704 connects to thepackage 700 atcenter 712 a of apad 710 a on thetop layer 702 a of thepackage 700. Thepad 710 a may be one of many pads in a connection (not shown) on thetop layer 702 a. The signal net 706 includessegment 706 a, which originates at thepad center 712 a and which extends for two units on the x axis. The next segment 706 b of the signal net 706 extends for three units on the y axis. The signal net 706 therefore has a path length of five units (two units forsegment 706 a and three units for segment 706 b) withintop layer 702 a. Such a path length will be referred to herein as an “intra-layer path length” and alternatively as a “horizontal path length.” - The signal net706 next includes
segment 706 c, which extends downward from point 712 b to themiddle layer 702 b of thepackage 700. The length ofsegment 706 c is equal to the distance H between each layer of thepackage 700. Such a path length will be referred to herein as a “vertical path length.”Signal nets traverse vertical path lengths through vias, which are vertical conductors or conductive paths forming the interconnection between one layer of an IC and another. - The signal net706 next includes
segments 706 d, 706 e, and 706 f within themiddle layer 702 b. Signal net 706 next includes asegment 706 g which extends downward to the bottom layer 702 c, where it connects to pad 710 b atpoint 712 d. As will be described in more detail below,segment 706 g does not connect to center 712 e of pad 710 b. Asegment 708 of the signal net 706 extends from the bottom layer 702 c of thepackage 700 to a package (not shown) belowpackage 700. - The aggregate path length of segments706 a-g is an example of a “synthesized path length” or a “total path length” as those terms are used herein. The sum of the path lengths of segments 706 a-g represents the total distance spanned by the signal net 706 within the
package 700. - In one embodiment, the package-specific net property reports208 a-n include information about the intra-layer path lengths of segments of signals nets in the packages modeled by the package models 202 a-n, respectively. The package-specific net property reports 208 a-n may, for example, have the logical structure illustrated in detail in FIG. 3B. Although only the
report 208 a is illustrated in FIG. 3B, the other reports 208 a-n may have the same logical structure. - Referring to FIG. 3B, the package-specific
net property report 208 a includes property units specifier 302, as described above with respect to FIG. 3A. In place of the netproperty value list 304 shown in FIG. 3A, thereport 208 a in FIG. 3B includes a signalnet record list 330 having a plurality of signal net records 320 a-m. Just as the netproperty value list 304 in FIG. 3A associates signalnet names 308 a withnet property values 308 b, the signalnet record list 330 in FIG. 3B associates net names with more detailed information about the corresponding signal nets. - Consider, for example, signal
net record 320 a. The logical structure and example contents ofrecord 320 a are illustrated in detail in FIG. 3B. Although the remainingsignal net records 320 b-m have the same logical structure asrecord 320 a, only record 320 a is shown in detail in FIG. 3B for ease of illustration. Signalnet record 320 a includes a signalnet name 326 a which identifies the name of the corresponding signal net in thepackage model 202 a. - The signal
net record 320 a also includes signalnet layer information 328 a which, in this example, provides information about the corresponding signal net in each layer of the package modeled bypackage model 202 a. The signalnet layer information 328 a includes a plurality of rows 322 a-d, each of which provides information about the corresponding signal net in a particular one of the package layers. In the example shown in FIG. 3B, the rows 322 a-d are arranged in an order that corresponds to the order of the package layers, in which thefirst row 322 a corresponds to pad 710 a at thetop layer 702 a of thepackage 700, thesecond row 322 b corresponds to thetop layer 702 a of thepackage 700, the third row 322 c corresponds to thesecond layer 702 b of thepackage 700, and thefourth row 322 d corresponds to the bottom layer 702 c of thepackage 700. - The signal
net layer information 328 a includes aPin ID column 324 a, anX column 324 b, a Y column 324 c, a Length column 324D, and aLayer column 324 e. For each of the rows 322 a-d: - (1) the
Pin ID column 324 a contains a pin identifier (pin ID) of the pin at which the signal net is connected in the corresponding layer of the package; - (2) the X and
Y columns 324 b and 324 c contain the x and y coordinates, respectively, at which the signal net exits from the corresponding layer of the package; - (3) the
Length column 324 d contains the running aggregate horizontal path length of the signal net within the package; and - (4) the
Layer column 324 e contains the name of the corresponding layer of the package. - Assume, for example, that the signal
net record 320 a corresponds to thepackage 700 illustrated in FIG. 7. Now consider thefirst row 322 a of the signalnet layer information 328 a which, which provides information about signal net 706 in thetop layer 702 a ofpackage 700. The value in thePin ID column 324 a ofrow 322 a is “U1.DM74,” indicating that the pin identifier of thepad 710 a at which signal net 706 is connected to layer 702 a inpackage 700 is U1.DM74. According to the naming convention used in this particular embodiment, the prefix U1 has a special meaning, which refers to a connection onpackage 700 for connectingpackage 700 to a die. As a result, theLayer column 324 e is empty forrow 322 a. The connection U1 may have many thousands of pads, each of which may be used to connect a distinct signal net. The suffix DM74 therefore specifies theparticular pad 710 a on connection U1 through which signal net 706 is connected to package 700. The X andY columns 324 b and 324 c forrow 322 a indicate that signal net 706 is connected to pad U1.DM74 at coordinates (1.00, 7.00). TheLength column 324 d specifies a length of 0.00 forrow 322 a because signal net 706 has not yet traversed any horizontal distance across any layer ofpackage 700. - Consider next the
second row 322 b, which provides information about signal net 706 inlayer 702 a of thepackage 700. The value in thePin ID column 324 a ofrow 322 b is “VIA,” indicating that signal net 706 exits fromlayer 702 a ofpackage 700 through a via (not shown). The remaining values inrow 322 b indicate that signal net 706 is connected to the via at coordinates (3.00, 4.00), that the name oflayer 702 a is “TOP” (indicating that it is the top layer of package 700), and that the running aggregate horizontal path length of signal net 706 throughpackage 700 is 5.00 units (because the combined horizontal path length ofsegments 706 a and 706 b inlayer 702 a is 5.00 units). - Consider next the third row322 c, which provides information about signal net 706 in
layer 702 b ofpackage 700. The value in thePin ID column 324 a of row 322 c is “VIA,” indicating that signal net 706 exits fromlayer 702 b ofpackage 700 through a via (not shown). The remaining values in row 322 c indicate that signal net 706 is connected to the via at coordinates (3.00, 4.00), that the name oflayer 702 b is “SIG-1”, and that the running aggregate horizontal path length of signal net 706 throughpackage 700 is 9.00 (5.00 units inlayer 702 a plus 4.0 units inlayer 702 b). - Now consider the
last row 322 d of signalnet layer information 328 a, which provides information about signal net 706 in the final (bottom) layer 702 c ofpackage 700. The value in thePin ID column 324 a ofrow 322 d is “P1.F3”. According to the naming convention used in this embodiment, the prefix P1 refers to a connection (not shown) frompackage 700 to a motherboard. The suffix F3 refers to pad 710 b on connection P1. The pin ID P1.F3 therefore refers to the specific pad 710 b on layer 702 c through which signal net 706 is connected. The values in the X andY columns 324 b and 324 c indicate that signal net 706 is connected to pad P1.F3 at coordinates (2.85, 2.00), that the name of layer 702 c is “BOTTOM,” and that the running aggregate horizontal length of signal net N throughpackage 700 at layer 702 c is 9.15 units. - Since layer702 c is the bottom layer in the
package 700, the aggregate horizontal path length of signal net 706 throughpackage 700 is 9.15 units. This aggregate horizontal path length does not, however, take into account the vertical distance(s) spanned by the signal net 706. For example, referring again to FIG. 7, signal net 706 includesvertical segments package 700. - Furthermore, signal nets do not always connect to the center of a pad. For example, as shown in FIG. 7, signal
net segment 706 g does not connect to the center of pad 710 b. The aggregate horizontal distance (9.15) indicated in the package-specificnet property report 208 a, however, is based on the assumption that the signal net 706 connects to the center of pad 710 b. The aggregate horizontal distances indicated in the package-specific net property reports produced by package design tools such as APD may therefore not be entirely accurate. - For both of the reasons just described, package-specific net property reports produced by conventional package design tools such as APD may not accurately represent the package-specific path length of signals nets within a package.
- Referring to FIG. 5E, a flow chart of a process is shown that is used by the
net property synthesizer 212 to calculate the package-specific path length SN of signal net N in package model P in one embodiment of the present invention. The calculation performed by the process illustrated in FIG. 5E takes into account both: (1) the horizontal and vertical distances spanned by the signal net N within package model P, and (2) the location(s) at which the signal net N connects to pads on the package modeled by package model P. The process illustrated in FIG. 5E may therefore calculate package-specific path lengths more accurately than conventional package design tools. - The process shown in FIG. 5E implements
step 514 of FIG. 5A, which identifies the property value V of signal net N in package model P. As shown in FIG. 5E, thenet property synthesizer 212 identifies the package-specific net property report R that corresponds to package model P using any of the techniques described above (step 540). For example, in the case ofpackage model 202 a, the corresponding package-specific net property report R is report 208 a. Thenet property synthesizer 212 assigns to V the package-specific path length for signal net N indicated by report R (step 542). For example, in one embodiment the package-specific path length indicated byreport 208 a is 9.15 (FIG. 3B). - The
net property synthesizer 212 adjusts the value of V based on the coordinates at which signal net N connects to the final layer of package P (step 544). The “final layer” of package P refers to the layer from which signal net N exits package P, which may, for example, be either the top or bottom layer of package P, depending on the package design. - In one embodiment, the
net property synthesizer 212 adjusts the value of V (step 544) as follows. Let LB be the path length for signal net N that is indicated by the last element in the signal net layer information in report R. For example, in the case of package-specificnet property report 208 a, LB is the path length indicated byelement 322 d, namely 9.15 (FIG. 3B). Let LB-1 be the path length for signal net N that is indicated by the next-to-last element in the signal net layer information in report R. For example, in the case of package-specificnet property report 208 a, LB−1 is the path length indicated by element 322, namely 9.00 (FIG. 3B). Let M be a scaling factor expressed as a decimal, where 0<M≦1. Thenet property synthesizer 212 may adjust the value of V instep 544 using Equation 2: - V=V−M(L B −L B−1)
Equation 2 - In other words, the
net property synthesizer 212 subtracts LB−1 from LB. The resulting difference represents the distance from the coordinates at which signal net N connects to the final (e.g., bottom) layer of package P and the center of the pad on the final layer of package P. Thenet property synthesizer 212 multiplies this difference by the scaling factor M, and then subtracts the scaled difference from the reported package-specific path length to obtain an adjusted package-specific path length which is assigned to V. - The
net property synthesizer 212 adjusts the value of V based on the aggregate length of the vertical segments of signal net N within package P (step 546). Thenet property synthesizer 212 may, for example, perform this adjustment by adding the aggregate length of the vertical signal net segments to the value of V. If the distance between package layers is H, and the number of package layers is L, then the net property synthesizer may perform step 546 using Equation 3: - V=V+H(L−1)
Equation 3 - For example, if the number of package layers L is three, then there are two (L−1) vertical gaps between layers, so the height H of each vertical gap is multiplied by two (L−1), and the product is added to V to produce a synthesized path length which reflects the vertical distances spanned by signal net N.
-
Equation 3 is based on the assumption, which may be valid in certain package designs, that signal nets only travel in a single direction (such as downward) through package layers. For example, the signal net 706 illustrated in FIG. 7 only travels downward through the package layers 702 a-c. This is not, however, a limitation of the present invention andEquation 3 is provided merely for purposes of example. If, in a particular design, signal nets travel both upwards and downwards through package layers, it may be necessary to adjust the value of V using a technique other thanEquation 3, as will be apparent to those of ordinary skill in the art. - After the value of V is adjusted in
step 546 of FIG. 7, the adjusted value of V may be used instep 516 of FIG. 5A, as described above. - Referring to FIG. 4C, in one embodiment of the present invention, the
package model list 406 has the following logical structure. Thepackage model list 406 includes a plurality of list elements 432 a-n, each of which corresponds to a particular one of the package models 202 a-n. Thepackage model list 406 includes a PackageModel ID column 434 a, aDielectric column 434 b, a Pads Flag column 434 c, aPads Factor column 434 d, and a DesignTool ID column 434 e. For each of the list elements 432 a-n: - (1) the Package
Model ID column 434 a contains a package model identifier (such as a database filename) of the corresponding package model; - (2) the
Dielectric column 434 b contains the dielectric constant of the corresponding package; - (3) the Pads Flag column434 c contains a binary value which indicates whether the
net property synthesizer 212 should perform the synthesized property value adjustment described above with respect to step 544 of FIG. 5E for the corresponding package model; - (4) the
Pads Factor column 434 d provides (if applicable) a multiplication factor M (Equation 2) to be used when performing the property value adjustment described above with respect to step 544 of FIG. 5E for the corresponding package model; and - (5) the
Design Tool ID 434 e identifies the package design tool (such as APD) that produced the corresponding package model. - The
net property synthesizer 212 may be capable of synthesizing net property values from package models produced by a plurality of package design tools. For example, the package models 202 a-n may include package models produced by more than one package design tool. Different package design tools may produce package-specific net property reports having different file formats and containing different information. Thenet property synthesizer 212 may be capable of reading information from package-specific net property reports produced by a plurality of package design tools, and may use thedesign tool ID 434 e to determine how to read and/or interpret net property values in a particular package-specific net property report. Thenet property synthesizer 212 may, for example, use thedesign tool ID 434 e during the performance of step 514 (FIG. 5A). Those of ordinary skill in the art will appreciate how to process information from package-specific net property reports of varying formats based on the description provided herein. - Techniques described herein may be further employed to determine whether one or more of the synthesized net property values in the synthesized
net property report 214 are equal within a predetermined tolerance. In particular, thenet property synthesizer 212 may determine whether any of the synthesizednet property values 608 b in the synthesizednet property report 214 deviates from a reference net property value by more than a predetermined maximum deviation. Thenet property synthesizer 212 may alert the user (e.g., the designer of one or more of the package models 202 a-n) if such a deviation exists. This feature may be useful, for example, for determining whether the synthesized propagation delays of signal nets in the package models 202 a-n are equal within the predetermined tolerance. If the synthesized propagation delays of the signal nets are not equal within the predetermined tolerance, thenet property synthesizer 212 may alert the user to this fact. The user may take action in response to this alert, such as modifying the design of one or more of the package models 202 a-n to make the synthesized propagation delays of the signal nets match more closely. - In a particular package design, signal nets are typically logically divided into groups. It is typically necessary for all signal nets within a particular signal net group to have the same synthesized propagation delay within a predetermined tolerance, although propagation delays may vary from signal net group to signal net group. In one embodiment of the present invention, the signal nets specified by the net
property synthesis information 210 are logically divided into signal net groups, and thenet property synthesizer 212 determines, for each signal net group, whether the synthesized propagation delays of signal nets in the signal net group are equal within the predetermined tolerance. - Referring to FIG. 4D, in one embodiment the synthesized signal
net list 412 has a logical structure that differs somewhat from that shown in FIG. 4B. As shown in FIG. 4D, the synthesized signalnet list 412 includes the same list of signal net names 424 a-j as that shown in FIG. 4B, but the list shown in FIG. 4D is divided into two signalnet groups - In one embodiment, each of the signal net groups450 a-b also includes a reference net name. For example, signal
net group 450 a includes referencenet name 452 a and signalnet group 450 b includes referencenet name 452 b. The reference net name for a signal net group specifies the name of the signal net whose synthesized property value is to be used by thenet property synthesizer 212 as a reference point against which to compare the synthesized property values of all of the signal nets in the signal net group. A reference net name may, for example, specify the net name of a strobe signal whose synthesized propagation delay is to be used as a point of reference for all signal nets in a particular signal net group. - Referring to FIG. 8A, a flowchart of a
method 800 is shown which is used by thenet property synthesizer 212 to determine whether any of the synthesizednet property values 608 b in the synthesizednet property report 214 deviates from a reference net property value by more than a predetermined maximum deviation. Themethod 800 may, for example, be performed after the completion of themethod 500 illustrated in FIG. 5A, so that the synthesizednet property report 214 may be assumed to exist at the beginning of themethod 800. - Referring to FIG. 8A, the
net property synthesizer 212 enters a loop over each signal net group G in the synthesized net property report 214 (step 802). Although in FIG. 6 the synthesized netproperty value list 604 is illustrated as a flat list, the synthesized netproperty value list 604 may alternatively be logically subdivided into groups of net property values corresponding to the signal net groups specified in the synthesized signal net list 412 (FIG. 4D). - The
net property synthesizer 212 identifies a reference value r for group G (step 804). Thenet property synthesizer 212 may perform this step by, for example, identifying the reference net name (in the synthesized signal net list 412) for group G and using the reference net name as an index into the synthesized net property value list 604 (FIG. 6) to obtain the synthesized net property value of the signal net named by the reference net name. In other words, the reference value r is the synthesized net property value of the signal net named by group G's reference net name. - The
net property synthesizer 212 enters a loop over each signal net N in the signal net group G (step 806). Thenet property synthesizer 212 identifies the synthesized net property value SN of N from the synthesized net property report 214 (step 808), and calculates the difference D between the synthesized net property value SN and the reference value r (step 810). - In one embodiment,
property synthesis information 210 includes a maximum propertyvalue deviation D max 438. If the difference D is greater than Dmax (step 812), thenet property synthesizer 212 alerts the user to this fact (step 814). In one embodiment, thenet property synthesizer 212 performsstep 814 as follows. Referring again to FIG. 6, in one embodiment, the synthesized netproperty value list 604 includes a binary alert flag field 608 c. If the alert flag field 608 c of a particular one of the list elements 606 a-m is set, then the synthesized net property value of the corresponding signal net differs from the appropriate reference value by more than the maximum propertyvalue deviation D max 438. Thenet property synthesizer 212 may therefore performstep 814 of FIG. 8A by setting the alert flag field 608 c of the list element corresponding to signal net N. If the synthesized property value of signal net N does not differ from the reference value r by more than the maximum propertyvalue deviation D max 438, thenet property synthesizer 212 may either clear the appropriate alert flag field 608 c or do nothing if the appropriate alert flag field is already cleared. - The
net property synthesizer 212 repeats steps 808-814 for each signal net N in signal net group G (step 816) and repeats steps 804-816 for each signal net group G in the synthesized net property report 214 (step 818). Upon completion of themethod 800, the user has been notified of any signal nets whose synthesized net property values deviate from the appropriate reference values by more than the maximum propertyvalue deviation D max 438. If, for example, thenet property synthesizer 212 alerts the user (step 814) by setting alert flags in the synthesizednet property report 214, the user may inspect the synthesizednet property report 214 upon completion of themethod 800 to determine which signal nets, if any, require design modification to bring their synthesized property values into conformance with the synthesized property values of other signal nets in the same signal net group. - It may be possible to equalize the propagation delays of signal nets in a signal net group by equalizing the aggregate (synthesized) path lengths of the signal nets in the signal net group. One way to perform such length equalization is by identifying the longest signal net in the signal net group and increasing the path lengths of the remaining signal nets in the signal net group so that they have the same length as the longest signal net. Referring to FIG. 8B, in one embodiment the
net property synthesizer 212 assists the user in this task using amethod 850. Themethod 850 may, for example, be performed after or as an integral part of themethod 800 illustrated in FIG. 8A. - Referring to FIG. 8B, the
net property synthesizer 212 enters a loop over each signal net group G in the synthesized net property report 214 (step 852). Thenet property synthesizer 212 identifies the longest signal net NL in group G (step 854) , and identifies the synthesized path length LNL of signal net NL (step 856). Thenet property synthesizer 212 enters a loop over each remaining signal net N in the signal net group G (step 858). Thenet property synthesizer 212 identifies the synthesized path length LN of signal net N (step 860). - The
net property synthesizer 212 calculates the difference D between the longest length LNL and the length LN (step 862). The difference D represents the amount by which signal net N's synthesized path length LN would need to be increased to equal the synthesized path length LN of signal net NL. Thenet property synthesizer 212 informs the user of the difference D (step 864), such as by writing the value of D to the synthesizednet property report 214 in alength difference field 608 d (FIG. 6) of the list element corresponding to signal net N. Thenet property synthesizer 212 repeats steps 860-864 for each signal net N in signal net group G (step 866) and repeats steps 854-866 for each signal net group G in the synthesized net property report 214 (step 868). - Upon completion of the
method 850, the user has been informed of the distances, if any, by which the synthesized path lengths of signal nets need to be increased in order to equalize the synthesized path lengths. If, for example, thenet property synthesizer 212 performsstep 864 by writing to thelength difference field 608d in the synthesizednet property report 214, the user may inspect the synthesizednet property report 214 upon completion of themethod 850 to determine the distance(s) by which signal nets need to be increased in order to equalize synthesized path lengths in the signal net groups. The information generated bymethod 850 may also be provided to an automatic routing tool, which may automatically re-route signal nets in the package models 202 a-n so that the synthesized lengths of signal nets in each signal net group are equal. The use of such an automatic routing tool would eliminate the need for the user to perform such re-routing manually. - Among the advantages of the invention are one or more of the following.
- Conventional package design tools maintain a distinct package model for each package in the design. As a result, no single source of information synthesizes information about all packages in the design. For example, no one of the package models102 a-n contains information about the total length of a signal net through all of the packages modeled by the package models 102 a-n. As a result, it is typically necessary for package designers to calculate total path lengths and other synthesized property values manually, which is a tedious, time-consuming, and error-prone task. Calculating synthesized propagation delays and determining whether the propagation delays of all signal nets in a particular signal group are sufficiently similar is particularly difficult to perform manually due to the large number of operations that must be performed to make such a determination.
- Various embodiments of the present invention address these problems by synthesizing property values from multiple package models automatically. Such automated synthesis may be faster and more reliable than manual synthesis. In particular, the automated synthesis performed by the
net property synthesizer 212 may take into account factors such as vertical path length, varying units of measurement, and varying package dielectrics to automate aspects of the synthesis process which are typically performed manually. Furthermore, the synthesizednet property report 214 may provide synthesized property values in a document that is formatted and organized in a manner that is easy to read and analyze. For example, as described above, thenet property synthesizer 212 may divide signal nets into groups and organize the information in the synthesizednet property report 214 based on the groups. - Another advantage of various embodiments of the present invention is the ability to automatically synthesize property values even when the package models202 a-n use mutually inconsistent signal net naming schemes. As described above with respect to FIG. 4B, the signal
net mapping 436 may be used to automatically map inconsistent signal names to each other so that property values may be synthesized automatically across packages. Performing such an operation manually is particularly tedious and prone to error. The use of the signalnet mapping 436 does not require the signal names in existing package models to be changed, and allows package designers to continue to engage in the common practice of using different signal names in different ones of the package models 202 a-n. Rather, inconsistent signal names need only be reconciled in the signalnet mapping 436, the creation of which will typically require less effort than the modification of signal names in the package models 202 a-n. - Another advantage of various embodiments of the present invention is the ability to synthesize signal net property values across multiple package models, even if the package models have different formats, as in the case when the package models are produced by different package design tools from different vendors. The
net property synthesizer 212 may perform such synthesis so long as thenet property synthesizer 212 can read net property information from the package-specific net property reports 208 a-n (FIG. 2) and process such information as described herein. Furthermore, because thenet property synthesizer 212 synthesizes information provided in the package-specific net property reports 208 a-n, thenet property synthesizer 212 need not be capable of directly accessing the package models 202 a-n, which may be represented in proprietary data formats. In contrast, the package-specific net property reports 208 a-n produced by conventional package design tools are typically represented in ASCII text files, from which information may be readily extracted and processed using the techniques described herein. - Yet another advantage of various embodiments of the present invention is the ability to automatically determine whether synthesized property values (e.g., propagation delays) of signal nets deviate from a reference value by more than a predetermined maximum deviation. Such a determination is required, for example, to perform path length equalization. Making such a determination manually can be tedious, time-consuming, and error-prone, since it typically involves calculating the synthesized property values manually and, manually comparing each of the synthesized property values to the predetermined reference value, and manually determining whether any of the synthesized property values deviates from the predetermined reference value by more than the predetermined maximum deviation. In contrast, as described above with respect to FIG. 8A, various embodiments of the present invention may both perform this task automatically and alert the user to any problematic synthesized property values. In particular, the
net property synthesizer 212 may provide such alerts in the synthesizednet property report 214 itself, which the user may readily analyze and use to inform modifications to the package models 202 a-n. - In addition to alerting the package designer to problematic synthesized property values, the
net property synthesizer 212 may (as described above with respect to FIG. 8B) assist the package designer in modifying the package design(s) to eliminate the identified problem(s). Thenet property synthesizer 212 may, for example, inform the package designer of the lengths by which signal nets must be increased so that all signal nets in a group have the same aggregate path length. Such a feature eliminates the need for the package designer to manually calculate such length increases, thereby further simplifying the task of the package designer. - It is to be understood that although the invention has been described above in terms of particular embodiments, the foregoing embodiments are provided as illustrative only, and do not limit or define the scope of the invention. Various other embodiments, including but not limited to the following, are also within the scope of the claims.
- The various techniques disclosed herein may be combined and/or separated in various ways, as will be apparent to those of ordinary skill in the art. For example, the processes illustrated in FIGS.5A-5E may be combined in any combination to perform combinations of the functions illustrated therein. As another example, although the
process 800 es (FIG. 8A) and 850 (FIG. 8B) may be performed after completion of the process 500 (FIG. 5), theprocesses - Although the drawings illustrate various data structures as having particular logical structures, these are provided merely for purposes of example and do not constitute limitations of the present invention. Rather, alternative data structures for representing equivalent information and for performing equivalent functions will be apparent to those of ordinary skill in the art. Furthermore, although various data structures (such as the package-specific net property reports, the net
property synthesis information 210, and the synthesized net property report 214) are described as being implementable as text files, this is not a limitation of the present invention. Rather, such data structures may be implemented as binary files, database files, or using any appropriate computer-readable format. - Furthermore, although the
net property synthesizer 212 and the netproperty synthesis information 210 are illustrated in FIG. 2 as distinct entities, it should be appreciated that they may be combined or further subdivided. For example, thenet property synthesizer 212 may be hard-coded with information contained in the netproperty synthesis information 210, and the netproperty synthesis function 216 may be contained in the netproperty synthesis information 210. - Although the techniques herein are described in the context of IC package design, the present invention is not limited to use in this context. Rather, the techniques disclosed herein may be applied in other contexts, such as on-die routing.
- Elements and components described herein may be further divided into additional components or joined together to form fewer components for performing the same functions.
- The techniques described above may be implemented, for example, in hardware, software, firmware, or any combination thereof. The
net property synthesizer 212 may, for example, be implemented as a computer program. The techniques described above may be implemented in one or more computer programs executing on a programmable computer including a processor, a storage medium readable by the processor (including, for example, volatile and non-volatile memory and/or storage elements), at least one input device, and at least one output device. Program code may be applied to input entered using the input device to perform the functions described and to generate output. The output may be provided to one or more output devices. - Each computer program within the scope of the claims below may be implemented in any programming language, such as assembly language, machine language, a high-level procedural programming language, or an object-oriented programming language. The programming language may, for example, be a compiled or interpreted programming language. In one embodiment, the
net property synthesizer 212 is implemented using the Perl programming language. - Each such computer program may be implemented in a computer program product tangibly embodied in a machine-readable storage device for execution by a computer processor. Method steps of the invention may be performed by a computer processor executing a program tangibly embodied on a computer-readable medium to perform functions of the invention by operating on input and generating output. Suitable processors include, by way of example, both general and special purpose microprocessors. Generally, the processor receives instructions and data from a read-only memory and/or a random access memory. Storage devices suitable for tangibly embodying computer program instructions include, for example, all forms of non-volatile memory, such as semiconductor memory devices, including EPROM, EEPROM, and flash memory devices; magnetic disks such as internal hard disks and removable disks; magneto-optical disks; and CD-ROMs. Any of the foregoing may be supplemented by, or incorporated in, specially-designed ASICs (application-specific integrated circuits). A computer can generally also receive programs and data from a storage medium such as an internal disk (not shown) or a removable disk. These elements will also be found in a conventional desktop or workstation computer as well as other computers suitable for executing computer programs implementing the methods described herein, which may be used in conjunction with any digital print engine or marking engine, display monitor, or other raster output device capable of producing color or gray scale pixels on paper, film, display screen, or other output medium.
Claims (20)
1. In a system including a plurality of property values of a plurality of signal nets in an integrated circuit, a computer-implemented method comprising steps of:
(A) identifying a reference value r; and
(B) for each property value S in the plurality of property values, performing steps of:
(1) determining whether property value S differs from reference value r by more than a predetermined amount; and
(2) notifying a user of the system if it is determined that the property value S differs from the reference value r by more than the predetermined amount.
2. The method of claim 1 , wherein the step (A) comprises a step of selecting the reference value r from among the plurality of property values.
3. The method of claim 1 , wherein the step (B)(2) comprises a step of notifying the user of the difference between property value S and reference value r.
4. The method of claim 1 , wherein the plurality of property values comprises a plurality of path lengths of the plurality of signal nets.
5. The method of claim 1 , wherein the plurality of property values comprises a plurality of propagation delays of the plurality of signal nets.
6. In a system including a plurality of property values of a plurality of signal nets in an integrated circuit, a computer-implemented method comprising steps of:
(A) identifying a reference value r; and
(B) for each property value S in the plurality of property values, performing steps of:
(1) identifying a difference D between property value S and reference value r; and
(2) notifying a user of the system of the difference D.
7. The method of claim 6 , wherein the step (A) comprises a step of selecting the reference value r from among the plurality of property values.
8. The method of claim 6 , wherein the step (A) comprises a step of selecting the maximum of the plurality of property values as the reference value r.
9. The method of claim 6 , wherein the plurality of property values comprises a plurality of path lengths of the plurality of signal nets.
10. The method of claim 6 , wherein the plurality of property values comprises a plurality of propagation delays of the plurality of signal nets.
11. A system comprising:
a computer-readable medium tangibly embodying a plurality of property values of a plurality of signal nets in an integrated circuit; and
a net property synthesizer comprising:
means for identifying a reference value r; and
for each property value S in the plurality of property values:
means for determining whether property value S differs from reference value r by more than a predetermined amount; and
means for notifying a user of the system if it is determined that the property value S differs from the reference value r by more than the predetermined amount.
12. The system of claim 11 , wherein the means for identifying the reference value r comprises means for selecting the reference value r from among the plurality of property values.
13. The system of claim 11 , wherein the means for notifying the user comprises means for notifying the user of the difference between property value S and reference value r.
14. The system of claim 11 , wherein the plurality of property values comprises a plurality of path lengths of the plurality of signal nets.
15. The system of claim 11 , wherein the plurality of property values comprises a plurality of propagation delays of the plurality of signal nets.
16. A system comprising:
a computer-readable medium tangibly embodying a plurality of property values of a plurality of signal nets in an integrated circuit; and
a net property synthesizer comprising:
means for identifying a reference value r; and
for each property value S in the plurality of property values:
means for identifying a difference D between property value S and reference value r; and
means for notifying a user of the system of the difference D.
17. The system of claim 16 , wherein the means for identifying the reference value r comprises means for selecting the reference value r from among the plurality of property values.
18. The system of claim 16 , wherein the means for identifying the reference value r comprises means for selecting the maximum of the plurality of property values as the reference value r.
19. The system of claim 16 , wherein the plurality of property values comprises a plurality of path lengths of the plurality of signal nets.
20. The system of claim 16 , wherein the plurality of property values comprises a plurality of propagation delays of the plurality of signal nets.
Priority Applications (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
US10/754,939 US20040143531A1 (en) | 2002-05-13 | 2004-01-09 | Synthesizing signal net information from multiple integrated circuit package models |
Applications Claiming Priority (2)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
US10/179,077 US6711730B2 (en) | 2002-05-13 | 2002-05-13 | Synthesizing signal net information from multiple integrated circuit package models |
US10/754,939 US20040143531A1 (en) | 2002-05-13 | 2004-01-09 | Synthesizing signal net information from multiple integrated circuit package models |
Related Parent Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
US10/179,077 Division US6711730B2 (en) | 2002-05-13 | 2002-05-13 | Synthesizing signal net information from multiple integrated circuit package models |
Publications (1)
Publication Number | Publication Date |
---|---|
US20040143531A1 true US20040143531A1 (en) | 2004-07-22 |
Family
ID=29400862
Family Applications (2)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
US10/179,077 Expired - Fee Related US6711730B2 (en) | 2002-05-13 | 2002-05-13 | Synthesizing signal net information from multiple integrated circuit package models |
US10/754,939 Abandoned US20040143531A1 (en) | 2002-05-13 | 2004-01-09 | Synthesizing signal net information from multiple integrated circuit package models |
Family Applications Before (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
US10/179,077 Expired - Fee Related US6711730B2 (en) | 2002-05-13 | 2002-05-13 | Synthesizing signal net information from multiple integrated circuit package models |
Country Status (2)
Country | Link |
---|---|
US (2) | US6711730B2 (en) |
JP (1) | JP2003330993A (en) |
Families Citing this family (16)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US6922822B2 (en) * | 2002-07-19 | 2005-07-26 | Hewlett-Packard Development Company, L.P. | Verifying proximity of ground vias to signal vias in an integrated circuit |
US7219322B2 (en) * | 2004-04-27 | 2007-05-15 | Hewlett-Packard Development Company, L.P. | Multiple propagation speeds of signals in layered circuit apparatus |
US20060076547A1 (en) * | 2004-09-24 | 2006-04-13 | Mentor Graphics Corp. | Three-dimensional viewing and editing of microcircuit design |
US7472368B2 (en) * | 2005-03-24 | 2008-12-30 | International Business Machines Corporation | Method for implementing vertically coupled noise control through a mesh plane in an electronic package design |
US7243314B2 (en) * | 2005-04-14 | 2007-07-10 | Inventec Corporation | Window operation interface for graphically revising electrical constraint set and method of using the same |
US7437690B2 (en) * | 2005-10-13 | 2008-10-14 | International Business Machines Corporation | Method for predicate-based compositional minimization in a verification environment |
US8849943B2 (en) * | 2005-12-19 | 2014-09-30 | Palo Alto Research Center Incorporated | Using multi-resolution visual codes to facilitate information browsing in the physical world |
US20070168372A1 (en) * | 2006-01-17 | 2007-07-19 | Baumgartner Jason R | Method and system for predicate selection in bit-level compositional transformations |
US7519938B1 (en) * | 2006-10-05 | 2009-04-14 | Xilinx, Inc. | Strategies for generating an implementation of an electronic design |
CA2786220C (en) * | 2011-08-18 | 2020-02-18 | Valydate Inc. | Validation of circuit definitions |
US8612913B1 (en) * | 2012-12-21 | 2013-12-17 | Synopsys, Inc. | Automated approach to planning critical signals and busses |
EP3230810B1 (en) * | 2015-04-24 | 2021-09-29 | Hewlett-Packard Development Company, L.P. | Method for setting printing properties of a three-dimensional object for additive manufacturing process |
JP6787045B2 (en) * | 2016-10-31 | 2020-11-18 | 富士通株式会社 | Verification support program, verification support method, and information processing device |
US10565342B1 (en) * | 2018-01-30 | 2020-02-18 | Cadence Design Systems, Inc. | Electronic circuit design editor with overlay of layout and schematic design features |
US10726176B1 (en) * | 2019-05-15 | 2020-07-28 | Bqr Reliability Engineering Ltd. | Method and apparatus for designing electrical and electronic circuits |
CN117171833B (en) * | 2023-11-03 | 2024-02-02 | 商飞软件有限公司 | Signal logic diagram design system |
Citations (44)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US5349659A (en) * | 1992-01-23 | 1994-09-20 | Cadence Design Systems, Inc. | Hierarchical ordering of logical elements in the canonical mapping of net lists |
US5383132A (en) * | 1991-10-30 | 1995-01-17 | Mitsubishi Denki Kabushiki Kaisha | Design verification device |
US5396435A (en) * | 1993-02-10 | 1995-03-07 | Vlsi Technology, Inc. | Automated circuit design system and method for reducing critical path delay times |
US5426591A (en) * | 1994-01-28 | 1995-06-20 | Vlsi Technology, Inc. | Apparatus and method for improving the timing performance of a circuit |
US5510998A (en) * | 1994-06-13 | 1996-04-23 | Cadence Design Systems, Inc. | System and method for generating component models |
US5559718A (en) * | 1994-04-28 | 1996-09-24 | Cadence Design Systems, Inc. | System and method for model-based verification of local design rules |
US5590049A (en) * | 1994-09-07 | 1996-12-31 | Cadence Design Systems, Inc. | Method and system for user programmable design verification for printed circuit boards and multichip modules |
US5608645A (en) * | 1994-03-17 | 1997-03-04 | Vlsi Technology, Inc. | Method of finding a critical path in a circuit by considering the clock skew |
US5726902A (en) * | 1995-06-07 | 1998-03-10 | Vlsi Technology, Inc. | Method and apparatus for characterizing timing behavior of datapaths for integrated circuit design and fabrication |
US5825658A (en) * | 1995-09-14 | 1998-10-20 | Vlsi Technology, Inc. | Method and a system for specifying and automatically analyzing multiple clock timing constraints in a VLSI circuit |
US5880967A (en) * | 1995-05-01 | 1999-03-09 | Synopsys, Inc. | Minimization of circuit delay and power through transistor sizing |
US5896300A (en) * | 1996-08-30 | 1999-04-20 | Avant| Corporation | Methods, apparatus and computer program products for performing post-layout verification of microelectronic circuits by filtering timing error bounds for layout critical nets |
US5956257A (en) * | 1993-03-31 | 1999-09-21 | Vlsi Technology, Inc. | Automated optimization of hierarchical netlists |
US6093214A (en) * | 1998-02-26 | 2000-07-25 | Lsi Logic Corporation | Standard cell integrated circuit layout definition having functionally uncommitted base cells |
US6182258B1 (en) * | 1997-06-03 | 2001-01-30 | Verisity Ltd. | Method and apparatus for test generation during circuit design |
US6189131B1 (en) * | 1998-01-14 | 2001-02-13 | Lsi Logic Corporation | Method of selecting and synthesizing metal interconnect wires in integrated circuits |
US6212666B1 (en) * | 1996-11-04 | 2001-04-03 | Synopsys, Inc. | Graphic representation of circuit analysis for circuit design and timing performance evaluation |
US6230301B1 (en) * | 1996-06-10 | 2001-05-08 | Micron Technology, Inc. | Method and system for creating a netlist allowing current measurement through a subcircuit |
US6233724B1 (en) * | 1998-10-30 | 2001-05-15 | Micron Technology, Inc. | Circuit synthesis time budgeting based upon wireload information |
US6247163B1 (en) * | 1998-10-13 | 2001-06-12 | Cadence Design Systems, Inc. | Method and system of latch mapping for combinational equivalence checking |
US6253361B1 (en) * | 1999-04-21 | 2001-06-26 | Magma Design Automation, Inc. | Generalized theory of logical effort for look-up table based delay models using capacitance ratio |
US20010005898A1 (en) * | 1999-12-22 | 2001-06-28 | Miyuki Yamamoto | Timing verifying system in which waveform slew is considered |
US6263483B1 (en) * | 1998-02-20 | 2001-07-17 | Lsi Logic Corporation | Method of accessing the generic netlist created by synopsys design compilier |
US20010010090A1 (en) * | 1998-02-11 | 2001-07-26 | Boyle Douglas B. | Method for design optimization using logical and physical information |
US20010016933A1 (en) * | 1998-09-30 | 2001-08-23 | Cadence Design Systems, Inc. | Block based design methodology |
US6282693B1 (en) * | 1998-12-16 | 2001-08-28 | Synopsys, Inc. | Non-linear optimization system and method for wire length and density within an automatic electronic circuit placer |
US6289491B1 (en) * | 1998-02-20 | 2001-09-11 | Lsi Logic Corporation | Netlist analysis tool by degree of conformity |
US6301693B1 (en) * | 1998-12-16 | 2001-10-09 | Synopsys, Inc. | Non-linear optimization system and method for wire length and delay optimization for an automatic electric circuit placer |
US6301578B1 (en) * | 1998-01-29 | 2001-10-09 | Cadence Design Systems, Inc. | Method of compressing integrated circuit simulation data |
US6308299B1 (en) * | 1998-07-17 | 2001-10-23 | Cadence Design Systems, Inc. | Method and system for combinational verification having tight integration of verification techniques |
US20010034873A1 (en) * | 2000-02-29 | 2001-10-25 | Cadence Design Systems, Inc. | Device level layout optimization in electronic design automation |
US6311318B1 (en) * | 1999-07-13 | 2001-10-30 | Vlsi Technology, Inc. | Design for test area optimization algorithm |
US6324675B1 (en) * | 1998-12-18 | 2001-11-27 | Synopsys, Inc. | Efficient iterative, gridless, cost-based fine router for computer controlled integrated circuit design |
US6327692B1 (en) * | 1997-11-17 | 2001-12-04 | Micron Technology, Inc. | Inter-module buffer determination methodology for ASIC synthesis |
US20010052107A1 (en) * | 2000-06-13 | 2001-12-13 | Mentor Graphics Corporation | Integrated verification and manufacturability tool |
US6336206B1 (en) * | 1999-09-27 | 2002-01-01 | Synopsys, Inc. | Method and apparatus for structural input/output matching for design verification |
US20020004931A1 (en) * | 2000-03-10 | 2002-01-10 | Stralen Nick Andrew Van | Tool and method for improving the quality of board design and modeling |
US6502224B2 (en) * | 2001-04-12 | 2002-12-31 | International Business Machines Corporation | Method and apparatus for synthesizing levelized logic |
US6567971B1 (en) * | 2001-12-20 | 2003-05-20 | Logicvision, Inc. | Circuit synthesis method using technology parameters extracting circuit |
US20030110462A1 (en) * | 2001-12-07 | 2003-06-12 | International Business Machines Corporation | Method for reducing design effect of wearout mechanisms on signal skew in integrated circuit design |
US6631508B1 (en) * | 2000-06-07 | 2003-10-07 | Xilinx, Inc. | Method and apparatus for developing and placing a circuit design |
US6637018B1 (en) * | 1999-10-29 | 2003-10-21 | Cadence Design Systems, Inc. | Mixed signal synthesis behavioral models and use in circuit design optimization |
US6651228B1 (en) * | 2000-05-08 | 2003-11-18 | Real Intent, Inc. | Intent-driven functional verification of digital designs |
US6925622B2 (en) * | 2002-09-30 | 2005-08-02 | Freescale Semiconductor, Inc. | System and method for correlated clock networks |
Family Cites Families (1)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US5995730A (en) | 1997-05-23 | 1999-11-30 | Lsi Logic Corporation | Method for generating format-independent electronic circuit representations |
-
2002
- 2002-05-13 US US10/179,077 patent/US6711730B2/en not_active Expired - Fee Related
-
2003
- 2003-04-09 JP JP2003104748A patent/JP2003330993A/en not_active Withdrawn
-
2004
- 2004-01-09 US US10/754,939 patent/US20040143531A1/en not_active Abandoned
Patent Citations (46)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US5383132A (en) * | 1991-10-30 | 1995-01-17 | Mitsubishi Denki Kabushiki Kaisha | Design verification device |
US5349659A (en) * | 1992-01-23 | 1994-09-20 | Cadence Design Systems, Inc. | Hierarchical ordering of logical elements in the canonical mapping of net lists |
US5396435A (en) * | 1993-02-10 | 1995-03-07 | Vlsi Technology, Inc. | Automated circuit design system and method for reducing critical path delay times |
US5956257A (en) * | 1993-03-31 | 1999-09-21 | Vlsi Technology, Inc. | Automated optimization of hierarchical netlists |
US5426591A (en) * | 1994-01-28 | 1995-06-20 | Vlsi Technology, Inc. | Apparatus and method for improving the timing performance of a circuit |
US5608645A (en) * | 1994-03-17 | 1997-03-04 | Vlsi Technology, Inc. | Method of finding a critical path in a circuit by considering the clock skew |
US5559718A (en) * | 1994-04-28 | 1996-09-24 | Cadence Design Systems, Inc. | System and method for model-based verification of local design rules |
US5510998A (en) * | 1994-06-13 | 1996-04-23 | Cadence Design Systems, Inc. | System and method for generating component models |
US5590049A (en) * | 1994-09-07 | 1996-12-31 | Cadence Design Systems, Inc. | Method and system for user programmable design verification for printed circuit boards and multichip modules |
US5880967A (en) * | 1995-05-01 | 1999-03-09 | Synopsys, Inc. | Minimization of circuit delay and power through transistor sizing |
US5726902A (en) * | 1995-06-07 | 1998-03-10 | Vlsi Technology, Inc. | Method and apparatus for characterizing timing behavior of datapaths for integrated circuit design and fabrication |
US5825658A (en) * | 1995-09-14 | 1998-10-20 | Vlsi Technology, Inc. | Method and a system for specifying and automatically analyzing multiple clock timing constraints in a VLSI circuit |
US6230301B1 (en) * | 1996-06-10 | 2001-05-08 | Micron Technology, Inc. | Method and system for creating a netlist allowing current measurement through a subcircuit |
US5896300A (en) * | 1996-08-30 | 1999-04-20 | Avant| Corporation | Methods, apparatus and computer program products for performing post-layout verification of microelectronic circuits by filtering timing error bounds for layout critical nets |
US6212666B1 (en) * | 1996-11-04 | 2001-04-03 | Synopsys, Inc. | Graphic representation of circuit analysis for circuit design and timing performance evaluation |
US6182258B1 (en) * | 1997-06-03 | 2001-01-30 | Verisity Ltd. | Method and apparatus for test generation during circuit design |
US6327692B1 (en) * | 1997-11-17 | 2001-12-04 | Micron Technology, Inc. | Inter-module buffer determination methodology for ASIC synthesis |
US6189131B1 (en) * | 1998-01-14 | 2001-02-13 | Lsi Logic Corporation | Method of selecting and synthesizing metal interconnect wires in integrated circuits |
US6301578B1 (en) * | 1998-01-29 | 2001-10-09 | Cadence Design Systems, Inc. | Method of compressing integrated circuit simulation data |
US20010010090A1 (en) * | 1998-02-11 | 2001-07-26 | Boyle Douglas B. | Method for design optimization using logical and physical information |
US6263483B1 (en) * | 1998-02-20 | 2001-07-17 | Lsi Logic Corporation | Method of accessing the generic netlist created by synopsys design compilier |
US6289491B1 (en) * | 1998-02-20 | 2001-09-11 | Lsi Logic Corporation | Netlist analysis tool by degree of conformity |
US6093214A (en) * | 1998-02-26 | 2000-07-25 | Lsi Logic Corporation | Standard cell integrated circuit layout definition having functionally uncommitted base cells |
US6308299B1 (en) * | 1998-07-17 | 2001-10-23 | Cadence Design Systems, Inc. | Method and system for combinational verification having tight integration of verification techniques |
US20010016933A1 (en) * | 1998-09-30 | 2001-08-23 | Cadence Design Systems, Inc. | Block based design methodology |
US6247163B1 (en) * | 1998-10-13 | 2001-06-12 | Cadence Design Systems, Inc. | Method and system of latch mapping for combinational equivalence checking |
US6647541B2 (en) * | 1998-10-30 | 2003-11-11 | Sun Microsystems, Inc. | Circuit synthesis time budgeting based upon wireload information |
US6233724B1 (en) * | 1998-10-30 | 2001-05-15 | Micron Technology, Inc. | Circuit synthesis time budgeting based upon wireload information |
US20010032331A1 (en) * | 1998-10-30 | 2001-10-18 | Laberge Paul A. | Circuit synthesis time budgeting based upon wireload information |
US6282693B1 (en) * | 1998-12-16 | 2001-08-28 | Synopsys, Inc. | Non-linear optimization system and method for wire length and density within an automatic electronic circuit placer |
US6301693B1 (en) * | 1998-12-16 | 2001-10-09 | Synopsys, Inc. | Non-linear optimization system and method for wire length and delay optimization for an automatic electric circuit placer |
US6324675B1 (en) * | 1998-12-18 | 2001-11-27 | Synopsys, Inc. | Efficient iterative, gridless, cost-based fine router for computer controlled integrated circuit design |
US6253361B1 (en) * | 1999-04-21 | 2001-06-26 | Magma Design Automation, Inc. | Generalized theory of logical effort for look-up table based delay models using capacitance ratio |
US6311318B1 (en) * | 1999-07-13 | 2001-10-30 | Vlsi Technology, Inc. | Design for test area optimization algorithm |
US6336206B1 (en) * | 1999-09-27 | 2002-01-01 | Synopsys, Inc. | Method and apparatus for structural input/output matching for design verification |
US6637018B1 (en) * | 1999-10-29 | 2003-10-21 | Cadence Design Systems, Inc. | Mixed signal synthesis behavioral models and use in circuit design optimization |
US20010005898A1 (en) * | 1999-12-22 | 2001-06-28 | Miyuki Yamamoto | Timing verifying system in which waveform slew is considered |
US20010034873A1 (en) * | 2000-02-29 | 2001-10-25 | Cadence Design Systems, Inc. | Device level layout optimization in electronic design automation |
US20020004931A1 (en) * | 2000-03-10 | 2002-01-10 | Stralen Nick Andrew Van | Tool and method for improving the quality of board design and modeling |
US6651228B1 (en) * | 2000-05-08 | 2003-11-18 | Real Intent, Inc. | Intent-driven functional verification of digital designs |
US6631508B1 (en) * | 2000-06-07 | 2003-10-07 | Xilinx, Inc. | Method and apparatus for developing and placing a circuit design |
US20010052107A1 (en) * | 2000-06-13 | 2001-12-13 | Mentor Graphics Corporation | Integrated verification and manufacturability tool |
US6502224B2 (en) * | 2001-04-12 | 2002-12-31 | International Business Machines Corporation | Method and apparatus for synthesizing levelized logic |
US20030110462A1 (en) * | 2001-12-07 | 2003-06-12 | International Business Machines Corporation | Method for reducing design effect of wearout mechanisms on signal skew in integrated circuit design |
US6567971B1 (en) * | 2001-12-20 | 2003-05-20 | Logicvision, Inc. | Circuit synthesis method using technology parameters extracting circuit |
US6925622B2 (en) * | 2002-09-30 | 2005-08-02 | Freescale Semiconductor, Inc. | System and method for correlated clock networks |
Also Published As
Publication number | Publication date |
---|---|
US20030212980A1 (en) | 2003-11-13 |
JP2003330993A (en) | 2003-11-21 |
US6711730B2 (en) | 2004-03-23 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
US6711730B2 (en) | Synthesizing signal net information from multiple integrated circuit package models | |
US6769102B2 (en) | Verifying proximity of ground metal to signal traces in an integrated circuit | |
US6216252B1 (en) | Method and system for creating, validating, and scaling structural description of electronic device | |
US5572436A (en) | Method and system for creating and validating low level description of electronic design | |
US5870308A (en) | Method and system for creating and validating low-level description of electronic design | |
US6240542B1 (en) | Poly routing for chip interconnects with minimal impact on chip performance | |
US5557531A (en) | Method and system for creating and validating low level structural description of electronic design from higher level, behavior-oriented description, including estimating power dissipation of physical implementation | |
US7398497B2 (en) | Electronic circuit designing method apparatus for designing an electronic circuit, and storage medium for storing an electronic circuit designing method | |
US7168041B1 (en) | Method and apparatus for table and HDL based design entry | |
US5541849A (en) | Method and system for creating and validating low level description of electronic design from higher level, behavior-oriented description, including estimation and comparison of timing parameters | |
US8650516B2 (en) | Methods and systems for computer aided design of 3D integrated circuits | |
US5838583A (en) | Optimized placement and routing of datapaths | |
US6922822B2 (en) | Verifying proximity of ground vias to signal vias in an integrated circuit | |
US7788076B2 (en) | Interference analysis method, interference analysis device, interference analysis program and recording medium with interference analysis program recorded thereon | |
JP2002222230A (en) | Unnecessary radiation optimizing method and unnecessary radiation analyzing method | |
US6810506B1 (en) | Methodology for stitching reduced-order models of interconnects together | |
US5187784A (en) | Integrated circuit placement method using netlist and predetermined ordering constraints to produce a human readable integrated circuit schematic diagram | |
JP3005538B1 (en) | LSI design system by model creation of functional block and LSI design method | |
US7290224B2 (en) | Guided capture, creation, and seamless integration with scalable complexity of a clock specification into a design flow of an integrated circuit | |
US6820048B1 (en) | 4 point derating scheme for propagation delay and setup/hold time computation | |
US7110929B1 (en) | System and method of providing additional circuit analysis using simulation templates | |
US6484297B1 (en) | 4K derating scheme for propagation delay and setup/hold time computation | |
US6807657B2 (en) | Inter-signal proximity verification in an integrated circuit | |
US10402526B2 (en) | Integrated system of PDN implementation and digital co-synthesis | |
US6502230B1 (en) | Circuit modeling |
Legal Events
Date | Code | Title | Description |
---|---|---|---|
STCB | Information on status: application discontinuation |
Free format text: ABANDONED -- FAILURE TO RESPOND TO AN OFFICE ACTION |