DECOUPLING CAPACITANCE ESTIMATION AND INSERTION FLOW FOR ASIC DESIGNS
A method for estimating decoupling capacitance during an ASIC design flow is disclosed. The method includes precharacterizing a set of power grid structures to model their respective noise behaviors, and storing the respective noise behaviors as noise factors in a table. During the ASIC design flow for a current design that includes at least one of the precharacterized power grid structures, the corresponding noise factor from the table is used to calculate decoupling capacitance for the current design.
[0001] The present invention relates to estimating decoupling capacitance, and more particularly to a decoupling capacitance estimation and insertion flow for ASIC designs.
BACKGROUND OF THE INVENTION[0002] In deep sub-micron ASIC design, with decreasing supply voltages and noise margin, and higher clock speeds, core noise is one of the most significant signal integrity problems facing a chip designer. Core noise, or instantaneous voltage drop, is due to a large demand for current across a chip in a short period of time. Instantaneous voltage drop has been linked to the following problems in integrated circuits; high performance clock jitter (cycle-to-cycle), clock skew balanced delay chain matching and clock balancing, tight hold time margin paths and scan shift chain, and jitter sensitive I/O interfaces, such as DDR and source synchronous. Instantaneous voltage drop (IVD) can also cause functional failures if not addressed properly in the design phase.
[0003] One of the most effective ways to reduce power supply noise is to increase on-chip decoupling capacitance (dcap) by adding decoupling capacitors to the circuit layout. Decoupling capacitors can be designed into the layout before or after the design is complete. Although adding decoupling capacitors is an effective method for combating IVD, the current method for estimating and adding decoupling capacitors to a chip design has disadvantages.
[0004] One disadvantage is that an integrated package level and chip level power bus model with switching and timing information is needed to accurately analyze such voltage variations over time. The current static analysis methodology relies on average power calculations to analyze and design the power distribution. There is a deficiency in the current voltage drop analysis flow in that it only takes into account the average voltage drop. Peak currents may occur between four and five times the average current estimated by conventional analysis, resulting in short duration peak voltage drops between four and five times on the chip over what was predicted, not including the package and board voltage drop. Therefore, the number of decoupling capacitors that will be placed on the chip may not be adequate to handle the underestimation of the peak voltage drops.
[0005] Another disadvantage is that if the number of decoupling capacitors is initially underestimated by the voltage drop simulation, and more must be added after the chip design is complete, then the chip may no longer have an adequate amount of area to place the additional decoupling capacitors.
[0006] A further deficiency with the current dynamic spice-like voltage drop simulation is that it is slow and time-consuming. Once a chip design nears completion, further testing and analysis are performed, followed by refinements to the design, including the decoupling capacitors. With each iteration, the voltage drop simulation increases the time for that cycle to complete. With some designs, use of the simulation is not feasible in the overall ASIC design flow because of the slow turn-around time of the simulation and a limited capacity to handle large designs.
[0007] Accordingly, what is needed is an improved method for estimating the decoupling capacitance required for an ASIC design. The present invention addresses such a need.
SUMMARY OF THE INVENTION[0008] The present invention provides a method for estimating decoupling capacitance during an ASIC design flow. The method includes precharacterizing a set of power grid structures to model their respective noise behaviors, and storing the respective noise behaviors as noise factors in a table. During the design flow for a current design that includes at least one of the precharacterized power grid structures, the corresponding noise factor from the table is used to calculate decoupling capacitance for the current design.
[0009] According to the present invention, components that are commonly used in ASIC designs are precharacterized for future use in a table look-up approach, thereby eliminating the need to perform these steps during the actual design flow, and therefore reducing the time to perform the decoupling capacitance estimation.
BRIEF DESCRIPTION OF THE DRAWINGS[0010] FIG. 1 is a flow chart illustrating a decoupling capacitance estimation and insertion flow in ASIC design for core noise avoidance in accordance with one preferred embodiment of the present invention.
[0011] FIG. 2 is a flow chart illustrating a power characterization process in further detail.
[0012] FIG. 3 is a diagram illustrating post processing on a waveform output by the simulation to obtain the peak current parameters.
DETAILED DESCRIPTION[0013] The present invention relates to a decoupling capacitance estimation and insertion flow for ASIC designs. The following description is presented to enable one of ordinary skill in the art to make and use the invention and is provided in the context of a patent application and its requirements. Various modifications to the preferred embodiments and the generic principles and features described herein will be readily apparent to those skilled in the art. Thus, the present invention is not intended to be limited to the embodiments shown but is to be accorded the widest scope consistent with the principles and features described herein.
[0014] The present invention provides a decoupling capacitance estimation and insertion flow during ASIC design for core noise avoidance. In a preferred embodiment, the decoupling capacitance estimation and insertion flow is implemented as a software tool, or set of tools, that is executed by a conventional PC, workstation, or server. One part of the tool is run prior to ASIC design flow in which a set of off-the-shelf power grid and package structures are precharacterized to model their noise behavior, which is represented as a noise factor and stored in noise factor table. When architecting a new ASIC design, a designer selects which of the off-the-shelf power grid and package structures will comprise the design. During the ASIC design flow for the new design, the decoupling capacitance tool is used to calculate decoupling capacitance for the design using the prestored noise factors corresponding to the selected structures in the design. Based on the estimated decoupling capacitance, an appropriate area in the design is reserved for insertion of the required decoupling capacitors.
[0015] In accordance with one aspect of the present invention, the noise factor, on which the estimate of the decoupling capacitance for the current design is based, is calculated for each off-the-shelf power grid and package, such that a table lookup approach can be used to retrieve the corresponding noise factors during the decoupling capacitance calculation for a current design. By precharacterizing components of ASIC designs and using a table look-up approach, the present invention eliminates the need to perform these steps during the actual design flow using spice simulation, and therefore reduces the time to perform decoupling capacitance estimation. In addition, the decoupling capacitance estimation tool accounts for the decoupling capacitance area overhead upfront during chip size estimation and ensures that the chip always includes sufficient area required to place the decoupling capacitance cells.
[0016] FIG. 1 is a flow chart illustrating a decoupling capacitance estimation and insertion flow in ASIC design for core noise avoidance in accordance with one preferred embodiment of the present invention. The process includes two stages, a precharacterization stage 12, which is independent of a particular chip design, and a decoupling capacitance estimation stage 14, which is performed during the ASIC design flow of a particular chip design. The precharacterization stage 12 assumes the existence of off-the-shelf structures, including different types of power grids, packages, memories, and logic cells that can be used to design a custom chip. The set of off-the-shelf power grid and package structures are then precharacterized in step 16 to model their noise behavior, which is represented as a noise factor 18. The noise factors 18 are then stored in noise factor table in step 20.
[0017] In a preferred embodiment, the noise factors 18 are determined by performing resistance, capacitance, and inductance (RCL) modeling for the power grids and packages and spice decks are built and simulated with different combinations of processes, layer stacks, peak current values, peak width values, and time-to-peak values as inputs. The results are then stored in the noise factor table.
[0018] The precharacterization stage 12 also includes characterizing each of the memory and logic structures in step 22 to obtain a corresponding set of peak current parameters 24. The peak current parameters 24 are necessary for calculating the decoupling capacitance during ASIC design flow, described below. Each set of peak current parameters 24 are then stored in a peak current table in step 26. In alternative embodiments, the peak current parameters 24 may also be stored in the noise factor table or in a generic memory database. The calculation of the peak current parameters is explained further below.
[0019] The decoupling capacitance stage 14 occurs after a new chip has been designed using some combination of the off-the-shelf power structures. The process begins in step 30 by inputting technical data for the current design to the decoupling capacitance estimation tool. In step 32, the estimation tool looks up the noise factors and peak current parameters corresponding to the particular power grid, package, memory, and logic cell structures used in the current chip design. In step 34, the decoupling capacitance and the required decoupling capacitance area are calculated using the noise factors and peak current parameters.
[0020] In step 36, the size of the memory and hard macros used in the current design is increased by the amount of decoupling capacitance area required (preferably, by bloating their FRAM views). Thus, once the de-coupling capacitance values are available, the memory frame views are bloated to reserve areas for the de-coupling insertion later in the design flow. This way, when a memory or hardmac is moved around a little bit in the chip physical stage, the reserved dcap area will move along with the memory or hardmac. This ensures that the dcap is always close to the memory or hardmac, in other words, close to the high peak current source, increasing the de-coupling capacitor's effectiveness of reducing core noise.
[0021] After bloating the memory, the normal ASIC process flow continues with floor-planning 40, power routing 42, critical logic placement 44, standard cell placement 46, clock 48, and routing 50 steps. Finally, in step 52, the required number of decoupling capacitors are placed in the decoupling capacitance area of the enlarged memory or hardmac.
[0022] Referring now to FIG. 2, a flow chart illustrating the power characterization process corresponding to step 22 of FIG. 1 is shown in further detail. The process begins by simulating the power consumed by the memory structure in step 50 using a power estimation tool. As is well known to one of ordinary skill in the art, a power estimator is a function that returns an estimated value for the power consumed by a functional block when given some relevant input specifications. An example of a commercially available power estimation tool is PowerMill by Synopsis, Inc. In a preferred embodiment, the memory is simulated at three process corners and worst case input vectors. An example set of initial process corners used as input may include the following:
[0023] Largest IVD: 1.26V, −40 C., SNSP.
[0024] Lowest IVD: 1.08V, 115 C., WNWP.
[0025] Normal IVD: 1.2V, 25 C., NOM.
[0026] A ramp time of 0.20 ns, rail-to-rail, may be used for all stimuli, and a 32× standard load may be used for all output loads for this analysis. The output of the simulation is a waveform of the current flowing out of a power source.
[0027] FIG. 3 is a diagram illustrating post processing on a waveform output by the simulation to obtain the peak current parameters. For a specific memory configuration that is being characterized, T is defined as a minimum cycle time of the memory. A time window of 0.5 T, (0.25 T on both left and right side of the maximum peak) may be used to find the total charge within the maximum peak of the current. The variable Tpk corresponds to the time-to-peak value, and the variable Ipeak corresponds to the peak current value.
[0028] Referring again to FIG. 2, according to one aspect of the present invention, the output results of the power estimation tool are post-processed in step 52 to obtain a set of peak current parameters 54. In a preferred embodiment, the set of peak current parameters 54 may include the following: a total charge of peak current, maximum peak current, time-to-peak, peak window, and the total intrinsic capacitance. In step 56, the peak current parameters 54, which include the intrinsic capacitance are stored a memory database or other type of table.
[0029] Note, the power estimation tool simulations include device and interconnect capacitance, but do not include the memory intrinsic capacitance (n-well, non-switching circuits capacitance, and power mesh capacitance). According to another aspect of the present invention, the post-processing step calculates the intrinsic capacitance as follows.
[0030] The total intrinsic capacitance for a specific memory instance is expressed in pF. This parameter may include four main components: Nwell capacitance (Cnw), non-switching capacitance (Cns), metal grid capacitance, and internal decoupling capacitance. Cnw (n-well capacitance) is based on Nwell area.
Cnw=(Nwell area)*(Nwell capacitance parameter F/um**2),
where
Nwell area=N-well-parameter*memory-size
[0031] The N-well-parameter is a number to denote the ratio of n-well area to the memory size.
[0032] The Cns may be calculated as:
Cns=[P/(1−A)]/[VDD*2*freq*A],
[0033] where P=average power, A=internal memory switching activity, VDD=power supply voltage, and freq=operating frequency. A value for the total instrinsic capacitance can be obtained by extraction:
Ctotal=Cnw+Cns+Cm+Cdcap,
[0034] where Cm is the metal grid capacitance and Cdcap is the internal decoupling capacitance.
[0035] An alternative to calculating the intrinsic capacitance is to model the memory and determine these values directly through tables based on actual Hspice simulation results.
[0036] Referring again to FIG. 1, step 34 describes the process for performing a decoupling capacitance calculation. The decoupling capacitance may be calculated as:
Cdec=n×Q/(&Dgr;Vlim)
[0037] where delta_Vlim=may be 10% of vdd, and Q is the current peak charge.
[0038] The number of decoupling capacitors that need to be added to the current design, Cdcap, may be calculated as:
Cdec−(Cn-well+Cns+Cpm)
[0039] where Cn-well is the n-well capacitance characterized for each cells, Cns is the non-switching circuit capacitance, and Cpm is the power mesh capacitance.
[0040] A fast-turn-around decoupling capacitance estimation and insertion flow in ASIC design for core noise avoidance has been disclosed. The present invention has been described in accordance with the embodiments shown, and one of ordinary skill in the art will readily recognize that there could be variations to the embodiments, and any variations would be within the spirit and scope of the present invention. Accordingly, many modifications may be made by one of ordinary skill in the art without departing from the spirit and scope of the appended claims.
Claims
1 A method for estimating decoupling capacitance during a design flow, the method comprising the steps of:
- (a) precharacterizing a set of power grid structures to model their respective noise behaviors;
- (b) storing the respective noise behaviors as noise factors in a table; and
- (c) during the ASIC design flow for a current design that includes at least one of the power grid structures, using the corresponding noise factor from the table to calculate decoupling capacitance for the current design.
2 The method of claim 1 wherein step (c) further includes the step of: using the calculated decoupling capacitance to determine decoupling capacitance area overhead, and reserving that amount of area in the current design for placement of decoupling capacitors.
3 The method of claim 2 wherein step (a) further includes a step of: precharacterizing a set of package structures.
4 The method of claim 3 wherein step (a) further includes a step of: characterizing a set of memory and logic structures to obtain a set of peak current parameters for each of the memory and logic structures.
5 The method of claim 4 wherein step (c) further includes the step of: calculating the decoupling capacitance: using the noise factors and peak current parameters corresponding to the power grid structures, package structures, and memory and logic structures in the current design.
6 The method of claim 5 wherein the peak current parameters include a total charge of peak current, maximum peak current, time-to-peak, peak window, and a total intrinsic capacitance.
7 The method of claim 6 wherein the total intrinsic capacitance is calculated using Nwell capacitance, non-switching capacitance, metal grid capacitance, and internal decoupling capacitance.
8 The method of claim 1 wherein step (a) further includes the step of: determining the noise factors by performing resistance, capacitance, and inductance (RCL) modeling for the power grids and packages using different processes, layer stacks, peak current values, peak with values, and time-to-peak values as inputs.
9 The method of claim 1 wherein step (c) further includes the step of: calculating the decoupling capacitance by, Cdec=noise factor×Q/(&Dgr;Vlim).
10 The method of claim 2 wherein step (c) further includes the step of: calculating a number of decoupling capacitors that need to be added to the current design by, Cdcap=Cdec−(Cn-well+Cns+Cpm).
11 A method for estimating decoupling capacitance during a design flow, the method comprising the steps of:
- (a) modeling a set of power grid structures to obtain respective noise factors for each;
- (b) storing the noise factors in a first table;
- (c) characterizing a set of memory, and logic structures to obtain respective sets of peak current parameters;
- (d) storing the peak current parameters in a second table;
- (e) for a design that includes any combination of the power, package, memory, and logic structures, looking up the corresponding noise factors and peak current parameters from the first and second tables; and
- (f) using the noise factors and peak current parameters retrieved from the tables to calculate decoupling capacitance and a number of required decoupling capacitors for the design.
12 The method of claim 11 wherein step (f) further includes the step of: calculating the decoupling capacitance by, Cdec=noise factor×Q/(&Dgr;Vlim).
13 The method of claim 12 wherein step (f) further includes the step of: calculating a number of decoupling capacitors that need to be added to the current design by, Cdcap=Cdec−(Cn-well+Cns+Cpm).
14 The method of claim 13 wherein step (f) further includes the step of: determining decoupling capacitance area overhead, and reserving that amount of area in the current design for placement of the decoupling capacitors.
15 The method of claim 14 wherein the peak current parameters include a total charge of peak current, maximum peak current, time-to-peak, peak window, and a total intrinsic capacitance.
16 The method of claim 15 wherein the total intrinsic capacitance is calculated using Nwell capacitance, non-switching capacitance, metal grid capacitance, and internal decoupling capacitance.
17 The method of claim 16 wherein step (a) further includes the step of: determining the noise factors by performing resistance, capacitance, and inductance (RCL) modeling for the power grids and packages using different processes, layer stacks, peak current values, peak with values, and time-to-peak values as inputs.
18 A computer readable medium containing program instructions for estimating decoupling capacitance during a design flow, the instructions for:
- (a) precharacterizing a set of power grid structures to model their respective noise behaviors;
- (b) storing the respective noise behaviors as noise factors in a table; and
- (c) during the ASIC design flow for a current design that includes at least one of the power grid structures, using the corresponding noise factor from the table to calculate decoupling capacitance for the current design.
19 The computer readable medium of claim 18 wherein instruction (c) further includes the instruction of: using the calculated decoupling capacitance to determine decoupling capacitance area overhead, and reserving that amount of area in the current design for placement of decoupling capacitors.
20 The computer readable medium of claim 19 wherein instruction (a) further includes the instruction of: precharacterizing a set of package structures.
21 The computer readable medium of claim 20 wherein instruction (a) further includes the instruction of: characterizing a set of memory and logic structures to obtain a set of peak current parameters for each of the memory and logic structures.
22 The computer readable medium of claim 21 wherein instruction (c) further includes the instruction of: calculating the decoupling capacitance using the noise factors and peak current parameters corresponding to the power grid structures, package structures, and memory and logic structures in the current design.
23 The computer readable medium of claim 22 wherein the peak current parameters include a total charge of peak current, maximum peak current, time-to-peak, peak window, and a total intrinsic capacitance.
24 The computer readable medium of claim 23 wherein the total intrinsic capacitance is calculated using Nwell capacitance, non-switching capacitance, metal grid capacitance, and internal decoupling capacitance.
25 The computer readable medium of claim 18 wherein instruction (a) further includes the instruction of: determining the noise factors by performing resistance, capacitance, and inductance (RCL) modeling for the power grids and packages using different processes, layer stacks, peak current values, peak with values, and time-to-peak values as inputs.
26 The computer readable medium of claim 18 wherein instruction (c) further includes the instruction of: calculating the decoupling capacitance by, Cdec=noise factor×Q/(&Dgr;Vlim).
27 The computer readable medium of clam 26 wherein step (c) further includes the step of: calculating the decoupling capacitance by, Cdec=noise factor×Q/(&Dgr;Vlim).
Type: Application
Filed: Apr 3, 2003
Publication Date: Oct 7, 2004
Inventors: Lihui Cao (San Jose, CA), Prasad Subbarao (San Jose, CA), David Gradin (Boring, OR), Maad Al-Dabagh (San Jose, CA), Weidan Li (San Jose, CA)
Application Number: 10407065
International Classification: G06F017/50; G06F009/45;