Information
-
Patent Grant
-
6028440
-
Patent Number
6,028,440
-
Date Filed
Friday, March 20, 199826 years ago
-
Date Issued
Tuesday, February 22, 200024 years ago
-
Inventors
-
Original Assignees
-
Examiners
- Ballato; Josie
- Kobert; Russell M.
-
CPC
-
US Classifications
Field of Search
US
- 324 1581
- 324 765
- 395 50002
- 395 50005
- 395 50006
- 395 50009
- 395 50039
-
International Classifications
-
Abstract
The present invention provides an analytical solution for voltage drop and current density calculation based on design-specific current consumption. The new technique calculates voltage drop and current density at all desired points of the power supply mesh. One application of the method is power mesh sizing by scaling the mesh resistance by the ratio between allowed voltage drop budget and the maximum of the calculated voltage drop. The designer can easily obtain the maximum allowed resistance of a uniform mesh which meets exactly the voltage drop budget, taking into account the design-specific spatial distribution of current consumption. Since the computational cost of the new methodology is negligible, e.g. as compared to prior art methods of analysis, this invention is suitable for implementation embedded in an RTL floorplan tool for fast, interactive tradeoff between floorplan location and voltage drop.
Description
BACKGROUND OF THE INVENTION
1. Field of the Invention
The present invention is in the field of semiconductor integrated circuit design and, more specifically, pertains to methodologies and design tools for ensuring power integrity in VLSI integrated circuit designs.
2. General Background
An ASIC may have dozens of separate circuit blocks or cores arranged on the chip and interconnected to form a system to meet specific needs. Many such blocks are well defined in advance and made available to the designer "off the shelf" in libraries provided by the ASIC vendor. Other blocks or cores may be licensed from third parties, e.g. a RISC core or DRAM block, while typically additional circuitry is custom designed by the ASIC customer for its specific application. The complete system design, including the power mesh (described below), must provide appropriate voltages to all of these circuit elements.
While ASIC design processes vary from one project to another, they often begin by defining the system at a relatively high level of abstraction, which may be an RTL (register-transfer level) description, for example. Such a description is independent of any specific circuit technology. Even at this level, the designer begins a preliminary layout or "floorplan" of the chip, and forms early estimates of gate count, chip size, power dissipation, pin count, etc. As the system becomes more specifically defined, usually in an HDL like Verilog, more precise estimates of various parameters become available. However, inaccuracies in early estimates can severely impact project budget and schedules. For example, extensive resources expended in simulation and analysis of simulation results can be wasted if the designer is forced to "back up" to revise floorplan or packaging estimates.
One essential requirement of a chip design is that adequate power be provided to all of the circuitry on the chip. The power supply requirements must take into account gate count, clock speeds, switching times, simultaneous switching noise, etc. to ensure proper operation of the system. However, while power supplied to the chip must be adequate it also must be minimized. Power dissipation and related thermal considerations severely limit the power consumption of a chip. These issues are ever more critical as circuit densities, e.g. as reflected in gate count, as well as clock speeds, continue to increase.
Large scale integrated circuits typically have a uniform power/ground distribution "mesh" for distributing power to the various circuits formed on the common substrate or "chip". The uniform power/ground mesh (or simply "power mesh") includes a "power ring"--a low-resistance conductor formed around the periphery of the chip core. Typically several bonding wires connect the power ring to one or more assigned external pins. Inside the power ring, a first series of wires are formed spaced apart in parallel and traversing the ring, for example in the x-direction, while a second series of wires are similarly formed in the y-direction (normal to the x-direction). Generally the first wires are formed in a first metallization layer, while the second (perpendicular) wires are formed in a second metallization layer. Vias with negligible resistance are formed at each intersection between the wires so as to interconnect the metallization layers, thus completing the power mesh. FIG. 1 is a circuit model of a small uniform power/ground distribution network for illustration.
In prior art, the designer obtains or generates a circuit model of the power mesh. A circuit simulation tool, e.g. SPICE, or a general purpose matrix solver is used to analyze the power mesh circuit model. The designer must determine the spatial distribution of voltage drop--sometimes called voltage mapping--as well as lateral current densities of the power supply mesh, in response to the specific current consumption requirements of every circuit element of the design. The prior art methodology (described in greater detail later) applies discrete equations for power integrity analysis. In order to solve the voltage V(x,y) for large mesh sizes, e.g. 0.ltoreq.x.ltoreq.100, 0.ltoreq.y.ltoreq.100, inversion of a matrix with 100*100=10,000 unknowns is necessary. This operation can be very expensive in runtime and therefore prohibitive in RTL floorplanning. As noted above, however, improved estimates of power mesh early in the design process can improve overall design and reduce design cycle time.
It is therefore an object of the present invention to provide efficient estimation of power integrity early in the ASIC design cycle.
A further object of the invention is to provide power integrity information to support optimization and design tradeoffs in the ASIC design process.
Another object of the invention is a practical method of obtaining useful power mesh voltage and lateral current estimates for large power meshes.
Yet another object of the invention is to apply a continuous model of the power mesh to speed up computation in power integrity analysis.
A still further object of the invention is to improve integration of power integrity analysis into the design flow, by reducing runtime, obviating dependency on external software, and reducing memory requirements.
Yet another object of the invention is to provide useful estimates of voltage drop and current densities in an RTL floorplan of an ASIC.
A still further object of the invention is to reduce power integrity analysis response time so as to enable fast, interactive tradeoff between floorplan location and voltage drop at the RTL floorplanning stage.
SUMMARY OF THE INVENTION
In view of the foregoing background discussion, one aspect of the present invention includes a method of estimating voltage drop and current density in a power mesh that is independent of the mesh size. According to the invention, the network (circuit elements together with the power mesh) is modeled as a space-continuous structure with distributed resistivity, composed of differential squares. This approach simplifies the power integrity analysis to a problem of manageable size and runtime.
According to another aspect of the invention, a method of estimating voltage drop at selected locations on an ASIC chip includes: obtaining machine readable data defining a preliminary floorplan of the ASIC design, the floorplan defining the sizes and locations of a plurality of functional blocks of rectangular shape. Next the process calls for determining a respective total current demand of each of the functional blocks of the chip. (Methods are known in prior art for estimating total current for a block.) And then, assuming a constant current draw by each of the functional blocks equal to the corresponding total current demand of each of the functional blocks, estimating voltage at selected locations on the ASIC chip as a function of current using two-dimensional spatial Fourier analysis.
More specifically, the new methodology--by modeling the net as a space-continuous structure with distributed resistivity and composed of differential squares--allows simplification of the analysis to computations that are strictly linear with the number of floorplan blocks and the number of points in the voltage drop map required to be calculated. Unless one desires to calculate the voltage drop for each net, the calculation complexity is not even dependent on the number of nets in the power supply mesh. Moreover, the new calculations can be carried out at selectable levels of precision. Thus, the designer can control the computation complexity and hence the runtime as appropriate. In general, this new approach provides fast run time so as to allow interactive power mesh estimation at the floorplanning stage, thereby reducing design cycle time in most cases. Interactive floorplanning lends itself to more efficient implementations, by supporting trading off floorplan vis a vis local voltage drop.
This process can be carried out, according to the invention, at the RTL level--before detailed design and layout. According to the invention, the necessary input is design-specific spatial current consumption, as opposed to global technology data (typically current per gate per megahertz). A computer implementation of the invention can be deployed in connection with a floorplanning tool for efficient, interactive design.
Thus one aspect of the invention is a fast and efficient method of calculating the spatial distribution of voltage drop and lateral current density of a uniform power supply mesh, when a design-specific current consumption distribution is given.
The input is physical information at a level of abstraction that makes it suitable for use in pre-layout planning tools, such as RTL floorplanner. Detailed data defining every wire segment and transistor are not required in order to estimate voltage drop. Nonetheless, the input is the design-specific spatial current consumption distribution per floorplan block. This enables design-specific planning and tradeoffs for power integrity. The current consumption for a given block can be estimated from a high level description using commercially available tools. Or, in some cases, the block will correspond to a standard library cell or core, in which case its characteristics, including current demands, are well defined. The methodology of the present invention for power mesh analysis in integrated circuit design obviates the need for general-purpose matrix solvers, which are usually implemented in simulation programs for voltage drop such as SPICE.
We obtain this unique feature of mesh-size independent calculation complexity by modeling the discrete mesh as a continuum. Our method is exactly fitted to this modeling approach. Hence we achieve an efficient solution of a particular electric field problem instead of a less efficient general-purpose solution like SPICE.
One particular application of our method is power mesh wire sizing, by calculating a normalized voltage drop for a normalized wire resistance and then scaling the actual resistance for the actual voltage drop budget. These and other aspects and advantages of the invention will become more apparent in view of the detailed description, beginning with an overview of the drawings.
BRIEF DESCRIPTION OF THE DRAWINGS
FIG. 1 is a prior art circuit model of a uniform power/ground distribution network of a semiconductor integrated circuit.
FIG. 2 is a discrete model of an individual segment of the network of FIG. 1.
FIG. 3 is a differential model of a mesh segment of a semiconductor integrated circuit according to the present invention.
FIG. 4 is a simplified floorplan diagram of a semiconductor integrated circuit illustrating a constant current rectangle corresponding to a selected block of the integrated circuit. These and other aspects and advantages of the invention will become more apparent in view of the following detailed description.
FIG. 5 is a flowchart of a methodology according to the invention for estimating current densities and wire size interactively at a preliminary floorplanning stage of the circuit design.
DETAILED DESCRIPTION OF A PRESENTLY PREFERRED EMBODIMENT OF THE INVENTION
Modeling IC Power Mesh
Referring now to FIG. 1, we first consider a model of a uniform power/ground distribution mesh as a structure which consists of a power ring with negligible resistance, and inside this power ring it has the following elements:
wires in x-direction in uniform distance, width and thickness
wires in y-direction in uniform distance, width, and thickness
vias with negligible resistance at each cross section between wires.
This network can be described by an electrical circuit which has the following parameters:
______________________________________R.sub.x resistance of a row segmentR.sub.y resistance of a column segmentN.sub.row number of rowsN.sub.column number of columns______________________________________
At each wire intersection there is a source drawing current from the mesh, which results in voltage drop and lateral currents as follows:
______________________________________I.sub.z (x,y) current drawn from the mesh (known)V(x,y) voltage drop at cross section (unknown)I.sub.x (x,y) lateral current in x-direction (unknown)I.sub.y (x,y) lateral current in y-direction (unknown)______________________________________
An example of a network with N.sub.row =3and N.sub.column =4 is shown in FIG. 1. The network of FIG. 1 responds to a current demand I.sub.z (x,y) by a voltage drop V(x,y). The boundaries are assumed to be equipotential, i.e. V(0,y)=0, V(5,y)=0, V(x,0)=0, V(x,5)=0.
Prior Art Discrete Analysis for Uniform Mesh
Each segment (x,y) has known resistance R.sub.x and R.sub.y and known current I.sub.z (x,y) drawn from the mesh. We want to know the voltage V(x,y) and the currents I.sub.x (x,y) and I.sub.y (x,y) in x-and y-direction. The discrete methodology is illustrated in FIG. 2.
Kirchoff's law and Ohm's law for an arbitrary mesh segment read as follows: ##EQU1##
Inserting (D2) and (D3) in (D1) yields: ##EQU2##
In order to solve the voltage V(x,y) for large mesh sizes, e.g. 0<x<100, 0<y<100, inversion of a matrix with 100*100=10,000 unknowns is necessary. This operation can be very expensive in runtime and therefore prohibitive in RTL floorplanning as noted above.
New Differential Analysis for Uniform Mesh
In order to address the general problem, we propose an approach, which renders the problem independent of the mesh size. We model the network as a space-continuous structure with distributed resistivity, composed of differential squares with size .DELTA.x*.DELTA.y, where .DELTA.x=.DELTA.y. The thickness of the metal is .DELTA.z. This new model is illustrated in FIG. 3. Using specific resistivity .rho. the resistances in x and y direction can be expressed as follows:
R.sub.x =.sub..rho.x *.DELTA.x/(.DELTA.z*.DELTA.y)
R.sub.y =.sub..rho.y *.DELTA.y/(.DELTA.z*.DELTA.x)
Using current density J, the currents in x, y, and z directions can be expressed as follows: ##EQU3##
From Kirchoff's law we obtain ##EQU4##
For infinitely small .DELTA.x and .DELTA.y we get the following differential equation: ##EQU5##
From Ohm's law we obtain: ##EQU6## which can be rewritten as follows: ##EQU7##
For infinitely small .DELTA.x and .DELTA.y this yields the following differential equations: ##EQU8##
Combining (E1), (E2) and (E3) we obtain: ##EQU9##
This looks like the classical Poisson's equation. It can be solved by developing J.sub.z (x,y) into a 2-dimensional Fourier series.
The boundary conditions in a rectangle of size D.sub.x *D.sub.y are: ##EQU10##
Considering the space 0.ltoreq.x.ltoreq.D.sub.x and 0.ltoreq.y.ltoreq.D.sub.y as half the primitive period of the Fourier series, the boundary conditions are automatically satisfied, if we develop J.sub.z (x,y) only in sine terms.
Developing the Fourier Series
In general, J.sub.z (x,y) can be expressed as product of a scaling factor J.sub.0 and two dimensionless functions f(x) and g(y).
J.sub.z (x,y)=J.sub.0 *f(x)*g(y)
The Fourier series looks as follows: ##EQU11##
The Fourier coefficients C.sub.m and C.sub.n are calculated as follows: ##EQU12##
Since J.sub.z (x,y) is a sum-of-products of sine functions, V(x,y) is necessarily also a sum-of-products of sine functions. We define A.sub.m,n as the voltage coefficient.
Expressing V(x,y) as a Fourier series and differentiating yields: ##EQU13##
We can put this into Poisson's equation: ##EQU14##
Hence we have a closed analytical expression of the voltage as a function of the current, which is developed in Fourier series. ##EQU15##
As in the discrete case, we can define the ratio between p.sub.x and p.sub.y as design parameters and calculate the normalized voltage V(x,y)/p.sub.x ##EQU16##
Then we find p.sub.x in order to meet the voltage drop budget max {V(x,y)}<V.sub.budget. This determines the required wire size.
Solution for Constant Currents in Rectangular Zones
The solution with Fourier development is general, since every well-behaving function can be developed into Fourier series. However, many coefficients may be needed for convergence and accuracy. For practical application to IC design, we can restrict ourselves to current distributions for which the Fourier coefficients are easy to calculate beforehand, and the number of necessary coefficients is limited.
From a floorplan we get definitions of one or more functional blocks of rectangular shape, and from power analysis we get the total current demand of each block. For simplicity we can assume constant current in each rectangular block. If the total current demand within a rectangle bound by x.sub.0, x.sub.1, y.sub.0, y.sub.1 is I.sub.0, the current density J.sub.z (x,y)=J.sub.0 *f(x)*g(y) for each individual rectangular block is given by ##EQU17##
Note that 0<x.sub.0 <x.sub.1 <D.sub.x and 0<y.sub.0 <y.sub.1 <D.sub.y. Each rectangle is inside the power ring.
The Fourier coefficients for determining current densities are the following: ##EQU18##
In the particular case, when the rectangle covers the whole die, i.e. x.sub.0 =0, x.sub.1 =D.sub.x, y.sub.0 =0, y.sub.1 =D.sub.y, the Fourier coefficients are: ##EQU19##
In the general case for constant current in rectangles, the coefficients C.sub.m and C.sub.n scale with 1/m and 1/n, respectively. Therefore, the number of coefficients needed is reasonably small. If we chose m<20 and n<20, we are sure that the error in neglecting higher order coefficients is not larger than 1/20=5%. In other words, this analysis permits the designer to select a desired level of accuracy or "granularity" in calculating current densities, by selecting the number of Fourier coefficients C to be used. Greater precision can be achieved by trading off increased computation cost, as more fully explained later. At least a few coefficients, e.g. M,N>3 are required. We have found M,N=20 provides very good results at modest computation cost. As computer performance continues to improve, it can be expected that use of 100 or more coefficient pairs C.sub.m C.sub.n will provide excellent accuracy at speeds that still support interactive floorplanning without any great delay. Thus the designer is free to experiment with alternative floorplans, and mesh designs, and will immediately see the power integrity effects.
Application of the New Methodology
The new technique is preferably implemented in software, e.g. in the C programming language, and proceeds as follows, with reference now to the reference numbers shown in the flowchart of FIG. 5:
1. Get design parameters: (50)
Die size between boundaries of power ring: D.sub.x, D.sub.y,
number of rows and columns of power mesh: N.sub.row, N.sub.column
ratio between x and y resistivity p.sub.x /p.sub.y
2. Get design constraints: (52)
maximum allowed voltage drop V.sub.budget
maximum allowed current densities J.sub.x,budget and J.sub.y,budget
3. Get rectangular clusters {x.sub.0,cluster,x.sub.1,cluster, y.sub.0,cluster, y.sub.1,cluster }from floorplan (54)
4. Get current consumption .sub.1cluster for each cluster (54)
5. For each cluster,
calculate current densities, as described above (56), using the relationship: ##EQU20## select accuracy level by selecting M and N, and calculate Fourier coefficients C.sub.m for 1.ltoreq.m.ltoreq.M and C.sub.n for 1.ltoreq.n.ltoreq.N (58) ##EQU21##
6. For all Fourier coefficients, i.e. 1.ltoreq.m.ltoreq.M, 1.ltoreq.n.ltoreq.N (M=20, N=20)
calculate Fourier components A.sub.m,n /p.sub.x of normalized voltage drop (60 in FIG. 5), viz: ##EQU22##
For 0<x<D.sub.x, step=D.sub.x /N.sub.row, 0<y<D.sub.y, step=D.sub.y /N.sub.column
calculate the current densities in x and y direction (63): ##EQU23## and then compare to the maximum current density (step 64):
.vertline.J.sub.x (x,y).vertline.>J.sub.x,budget or .vertline.J.sub.y (x,y).vertline.>J.sub.y,budget
If either density exceeds the corresponding limit, the die size is too small. The designer needs to restart with larger die size, redefine the clusters (rectangular blocks), (70) and the process loops via (68) back to determining the current density (56) for the new clusters. The foregoing steps (58) to (64) are repeated as may be necessary.
If the current density is acceptable, we proceed to calculate a normalized voltage drop and determine the maximum voltage drop (74): ##EQU24##
Finally we determine resistivity based on the maximum (V.sub.budget) allowable voltage drop:
p.sub.x =V.sub.budget /max {V(x,y)/p.sub.x }. This determines wire size.
Computational Costs
The storage complexity of this method is as follows. For the current density coefficients {C.sub.m,cluster }+{C.sub.n,cluster }'(M+N)*(number of clusters), where "'" means "proportional to". For the voltage calculation coefficients {A.sub.m,n /P.sub.x }'M*N; and for plotting a "thermal map" of the voltage and branch current distribution, the storage requirements are based on:
{V(x,y)/p.sub.x }+{J.sub.x (x,y)}+{J.sub.y (x,y)}'3*N.sub.row * N.sub.column
The calculation complexity of the present method is characterized as:
{current density}'nb. of clusters
{Fourier coefficients for current density}'(M+N)*nb. of clusters
{V(x,y)/p.sub.x }+{J.sub.x (x,y)}+{J.sub.y (x,y)}'N.sub.row *N.sub.column where the calculation is dominated by sine and cosine operations which can be shared between V, J.sub.x, and J.sub.y. Recall that N.sub.row and N.sub.column are the numbers of wires in the mesh in x and y dimensions, respectively.
The number of storage and calculation operations needed is dominated by the number of rows and columns, which is much larger than the number of Fourier coefficients and clusters. One example of useful values are:
number of clusters=10
number of Fourier coefficients: M=20, N=20, M*M=400
number of rows and columns: N.sub.row =100, N.sub.column =100, ergo N.sub.row *N.sub.column =10,000
To summarize, the present invention provides an analytical solution for voltage drop and current density calculation based on design-specific current consumption. The new technique calculates voltage drop and current density at all desired points of the power supply mesh. One application of the method is power mesh sizing by scaling the mesh resistance by the ratio between allowed voltage drop budget and the maximum of the calculated voltage drop. Thus we obtain the maximum allowed resistance of an uniform mesh which meets exactly the voltage drop budget, taking into account the design-specific spatial distribution of current consumption. Since the computational cost of the new methodology is negligible, e.g. as compared to SPICE analysis, this invention is also suitable to be embedded in a RTL floorplan tool for fast interactive tradeoff between floorplan location and voltage drop.
Having illustrated and described the principles of my invention in a preferred embodiment thereof, it should be readily apparent to those skilled in the art that the invention can be modified in arrangement and detail without departing from such principles. We claim all modifications coming within the spirit and scope of the accompanying claims:
Claims
- 1. A method of checking for power integrity in a preliminary design for a semiconductor integrated circuit having a power mesh including a power ring formed on a semiconductor die and defining a die size within the boundaries of the power ring, the method comprising the steps of:
- defining the power mesh for the integrated circuit;
- selecting applicable power integrity constraints;
- defining a preliminary floorplan of the design in terms of a plurality of rectangular clusters, each cluster corresponding to a functional block of the design and having a predetermined total current consumption;
- calculating a current density for each of the clusters based on its total current consumption;
- selecting a number of coefficients for analyzing power integrity of the design; and
- estimating a normalized voltage drop of the power mesh responsive to the defined floorplan by applying two-dimensional Fourier spatial analysis using the selected number of coefficients.
- 2. A method according to claim 1 wherein the power integrity constraints include a maximum normalized voltage drop and further comprising, comparing the estimated normalized voltage drop of the power mesh to the maximum normalized voltage drop; and modifying the definition of the power mesh or modifying the floorplan if the estimated normalized voltage drop of the power mesh exceeds the maximum normalized voltage drop.
- 3. A method according to claim 1 wherein said defining the power mesh includes selecting x and y dimensions of the integrated circuit die between the boundaries of the power ring, D.sub.x and D.sub.y, and selecting a number of first-dimension wires or rows of the power mesh N.sub.row and selecting a number of second-dimension wires or columns of the power mesh N.sub.column.
- 4. A method according to claim 3 wherein said selecting the number of coefficients includes selecting integer values M and N, where M is the number of Fourier coefficients in the x dimension and N is the number of Fourier coefficients the y direction, for use in estimating power integrity of the design, thereby allowing the designer to trade off storage and calculation complexity relative to desired accuracy in the estimation step.
- 5. A method according to claim 1 wherein said selecting applicable power integrity constraints includes selecting a maximum normalized voltage drop and selecting a maximum allowed current density for each direction in the power mesh, J.sub.x,budget and J.sub.y,budget.
- 6. A method according to claim 5 wherein said defining a floorplan of the design in terms of a plurality of rectangular clusters includes defining each cluster in terms of spatial coordinates of the respective comers of the corresponding rectangle x.sub.0,cluster X.sub.1,cluster y.sub.0,cluster y.sub.1,cluster for each cluster; and wherein said calculating a current density for each of the clusters includes calculating the current density J.sub.cluster according to the formula ##EQU25## where I.sub.cluster is the total current consumption of the corresponding cluster.
- 7. A method according to claim 6 wherein said estimating a normalized voltage drop includes first calculating Fourier coefficients C.sub.m and C.sub.n for 1<m<M and for 1<n<N, respectively, according to the formula: ##EQU26## and repeating said calculation for each of the clusters, thereby determining a total number of C.sub.m coefficients equal to the number of clusters times M, and a total number of C.sub.n coefficients equal to the number of clusters x N.
- 8. A method according to claim 6 wherein said estimating a normalized voltage drop of the power mesh further includes calculating Fourier components A.sub.m,n /p.sub.x of the normalized voltage drop as ##EQU27##
- 9. A method according to claim 8 further comprising calculating current densities in the x and y directions at the selected granularity according to the formulas: and then comparing the calculated current densities to the maximum current densities J.sub.x,budget and J.sub.y,budget.
- 10. A method according to claim 9 and further comprising, if either or both of the calculated current densities exceeds the corresponding maximum current density, increasing the selected die size of the integrated circuit under design, thereby reducing the current densities; and repeating said calculations of current densities using the increased die size so as to confirm that the design meets the specified power integrity constraints.
US Referenced Citations (2)
Number |
Name |
Date |
Kind |
4730160 |
Cusack et al. |
Mar 1988 |
|
5799172 |
Gullapalli et al. |
Aug 1998 |
|