1. Field of the Invention
The present invention relates to a delay calculation method for calculating delay time of, for example, each macrocell with transistors.
2. Description of the Background Art
For timing verification of semiconductor integrated circuits (SOC: System on Chip) equipped with large-scale systems, delay time in each instance must be calculated with accuracy. One of well-known high-precision delay calculation methods is that using circuit simulations such as SPICE. In circuit simulations, the analysis of operating points of each device is made on matrix calculation. This calculation is conducted at each lapse of a very short time to obtain a voltage value at every node. In this technique, a huge matrix must be analyzed for the analysis of operation at a certain time, so an increase in the number of devices will markedly increase the amount of calculation. Further, the necessity of conducting matrix calculation at each lapse of a very short time makes impossible to conduct an analysis within a realistic time, for semiconductor integrated circuits which include an extremely large number of devices such as large-scale SOCs. To solve this problem, another delay calculation method using a delay calculator has been employed.
The delay calculator previously adds an input waveform generating circuit and an output load respectively to the input and output of every macrocell (logic circuit) that can cause a delay, and it conduct circuit simulations (SPICE) using a plurality of kinds (usually 10 to 100) of input waveforms and output load capacitances. At this time, every input waveform is replaced and represented as time (a Tslew value) required for transition from low to high state (or high to low state).
From simulation results obtained here, parameters which are necessary for calculating delay time as a function of the Tslew value and the output load capacitance are extracted and stored in a delay-parameter database. This is done for each path when each macrocell has a plurality of different changing paths.
Using the delay-parameter database created in this way, the delay calculator performs delay calculations on a SOC. First, delay time in the instance where the Tslew value is set by default or by the designer is calculated using the delay-parameter database. For delay calculation, information on the output load is necessary, and it can be produced in advance from layout results obtained with a layout extractor. By so doing, delay time and an output waveform in that instance can be determined. Since the Tslew value to be inputted in the following instance can be determined from the output waveform, the delay time and the output waveform for the following instance can be determined using this Tslew value. This operation is performed for all instances, whereby any delay time in the SOC can be calculated.
For example, Japanese Patent Application Laid-open No. 2002-123568 has disclosed one of the delay calculation methods for calculating delay time only from Tslew values and output load information.
However, in real SOCs, depending on the topology of a circuit or RC network to be configured, there are various shapes of input waveforms that differ from the one used to create the delay-parameter database. That is, there exist a lot of input waveforms that have the same Tslew value but have different waveform shapes.
In conventional delay calculation methods, delay time is calculated only from Tslew values and output load information. Thus, in the case where the output load capacitance is the same and each input waveform has the same Tslew value, the same delay time is calculated for different shapes of input waveforms.
Consequently, the results of delay calculations in conventional delay calculation methods have a margin of error of around 8 percent even if parameters are optimized somehow. At present, SOCs become faster, so a margin of error in delay calculation must be kept at 5 percent at most. From this, the 8-percent inherent margin of error has made circuit design difficult.
It is an object of the present invention to provide a delay calculation method for calculating delay time with a small margin of error.
The present invention is intended for a delay calculation method for a logic circuit including a MOS transistor, the transistor being modeled using a resistance element whose resistance value is fixed and a power supply whose voltage varies with time. A shape of a voltage waveform of the power supply is determined according to input waveform information that determines the shape of an input waveform inputted to the logic circuit.
Since the shape of the voltage waveform of the power supply which models the transistor is determined according to parameters that determine the shape of the input waveform, delay time can be calculated with a small margin of error.
These and other objects, features, aspects and advantages of the present invention will become more apparent from the following detailed description of the present invention when taken in conjunction with the accompanying drawings.
Like conventional delay calculation methods, a delay calculation method according to a preferred embodiment of the present invention inputs a Tslew value of an input waveform, delay parameters for calculating delay time as a function of the Tslew value and an output load capacitance, and output load information. The delay calculation method of this preferred embodiment further inputs input waveform information that gives the shapes of input waveforms. The method then outputs a delay time, the following input waveform, and the Tslew value of the following input waveform.
As shown in
The load component 8 includes the RC distributed constant circuit 7 corresponding to the interconnect line 3, and an input pin capacitor Cg. The RC distributed constant circuit 7 has its one end connected to the source model 6 and its other end connected to one end of the input pin capacitor Cg. The other end of the input pin capacitor Cg is grounded.
Next, as shown in
According to the present invention, the power supply 4 of the above-configured source model 6 is designed to have time dependency (hereinafter, the magnitude of voltage at the power supply 4 is indicated by E(t)). Then, a model (referred to as an “E(t) model”) that represents transistor operation when an input waveform is received is constructed. That is, the E(t) model is a model that determines the shape of the waveform of E(t) (hereinafter referred to as the “E(t) waveform”) so that the output current i(t) of the source model 6 flowing to the load model 9 reproduces the waveform of the drain current Ids of the transistors forming the inverter 1. Thus, the shape of the E(t) waveform is determined by taking into account the waveform of the drain current Ids of the transistors.
Now, the waveform of the drain current Ids will be described. The following description is for the case where the input waveform (input signal) that transitions from high to low is inputted from the input terminal A1. The shape of the input waveform is assumed to linearly change from high (potential Vdd) to low (potential of 0 V).
At this time, the potential of the output terminal Y1 of the inverter 1 transitions from low to high, because the PMOS transistor P1 of the inverter 1 transitions from off to on and thereby the output load is charged.
As shown in
The current waveform is described in more detail below. In the initial state, the gate voltage Vgs of the PMOS transistor P1 is 0 V, and since the output load is not charged, the drain voltage Vds equals Vdd.
First, we describe the case where the output load capacitance is large, i.e., where the degree of decrease in the drain voltage Vds with the charging of the output load is smaller than the degree of change in the gate voltage Vgs. As the input signal given to the input terminal A1 of the inverter 1 transitions from high to low, the gate voltage Vgs increases and the drain current Ids starts to flow through the PMOS transistor P1.
The magnitude of the drain current Ids increases with increasing gate voltage Vgs. Also, the drain voltage Vds drops from Vdd with the charging of the output load with the drain current Ids. Since the larger the output load capacitance the smaller the degree of decrease in the drain voltage Vds, the PMOS transistor P1 goes into its saturation region when the gate voltage Vgs reaches Vdd (region I). Region I is hereinafter also referred to as the “saturation region with varying gate voltage” or “first region where current changes with varying gate voltage”.
Then, the drain voltage Vds decreases gradually with the charging of the output load, whereby the drain current Ids decreases gradually while the magnitude of the gate voltage Vgs is constant (region II). Region II is hereinafter also referred to as the “saturation region with fixed gate voltage” or “second region where current decreases gradually while the gate voltage is constant”.
Then, when the output load is further charged and the drain voltage Vds decreases to a certain degree, the PMOS transistor P1 goes into its linear region where the drain current Ids decreases linearly. When the charging of the output load is complete, the drain voltage Vds becomes 0 V and the drain current Ids stops flowing (region III). Region III is hereinafter also referred to as the “linear region” or “third region where current decreases while the gate voltage is constant”.
As above described, when the output load capacitance is large, the current waveform is as shown by the first pattern in
Next, we describe the case where the output load capacitance is small, i.e., where the degree of decrease in the drain voltage Vds with the charging of the output load is greater than the degree of change in the gate voltage Vgs. When the output load capacitance is somewhat small, region II will disappear. For example, consider the case where, when the gate voltage Vgs reaches Vdd, the output load is charged to a certain extent and the transistor goes into its linear region. In this case, the drain current Ids increases toward region III as shown in
When the output load capacitance becomes further smaller, the transistor moves from region I to region III before the gate voltage Vgs reaches Vdd. The second pattern shown in
Next, we discuss the E(t) waveform that reproduces the current waveform described above. Firstly discussed is the first pattern of the current waveform. On the line of the first pattern, region III is a linear region where the current flowing is determined by the time constant of a circuit, so that E(t)=E(=Vdd). Since the source model 6 represents transistor operation by E(t) and the value of the resistor 5, and current in region III decreases linearly with decreasing drain voltage Vds, a current waveform that decreases linearly with time can be reproduced when E(t)=E.
In regions I and II, different waveforms of E(t) are applied. For respective regions I and II, E(t) is represented by different functions of time (however, both the functions are continuous at a point of time corresponding to regions I and II). In this preferred embodiment, for ease of calculation, regions I and II are represented by continuous straight lines with different inclinations as shown in
More specifically, region I corresponds to a region where the drain current Ids increases rapidly. To represent this drain current Ids in the source model 6, region I is brought into correspondence with a straight line with a high degree of inclination with respect to time.
Region II corresponds to a region where the drain current Ids degreases gradually while the magnitude of the gate voltage Vgs is constant at Vdd. To reproduce this gradually decreasing drain current Ids in the source model 6, region II must be brought into correspondence with a straight line indicating that voltage increases with time because the voltage applied to one end of the resistor 5 increases with the charging of the output load capacitance. If voltage is constant with respect to time, the rate of decrease in the drain current Ids becomes too high.
The time when E(t) starts to increase does not necessarily coincide with time t=0. The PMOS transistor P1 has a threshold voltage Vth, and current starts to flow when the input waveform meets and exceeds the threshold voltage Vth. Thus, E(t) starts to increase when the input waveform meets and exceeds the threshold voltage Vth. This duration of time is referred to as a fixed delay t0. Assuming that the time when the input waveform has finished its transition to 0 or Vdd is the Tslew value, the fixed delay t0 can be represented as a function of the Tslew value and can be approximated for example by the equation: t0(Tslew)=K10+K20·Tslewα. In this case, K10, K20, α are delay parameters which are stored in the delay-parameter database as function information concerning an input slew rate that determines the fixed delay t0.
According to this preferred embodiment, as shown in
In the case of the second pattern, region II does not exist. In this case, assuming that Δt2=0 and V1=E, the E(t) waveform is such that region I directly moves to region III (
When using the E(t) waveform shown in
If functions ƒ and α are defined as:
a model waveform of V2(t) can be expressed as follows:
when Δt1=0,
and when Δt2=0,
and when Δt1≠0 and Δt2≠0,
The procedures for determining the values Δt1, V1, and Δt2 are described below. Looking at the shifts of operating points of the transistor shown in
The Ids-Vds characteristic curve where Vgs=Vdd is modeled as shown in
The source model 6 charges and discharges the output load through the resistor 5 (with the resistance Rs). Thus, the Ids-Vds characteristics of region III must be expressed by Ids=Vds/Rs. The saturation current at the boundary point between region II and region III is represented by the current parameter I1, and the saturation current where Vds=Vdd is represented by the current parameter I0.
For this E(t) model, since the saturation current at the boundary point between region II and region III is represented by I1, a region where Vds≦Rs·I1 is referred to as the linear region, and a region where Vds>Rs·I1 as the saturation region. Further, by separately defining the saturation current where Vds=Vdd as I0, the saturation current in region II is represented by I0 and I1 as later described, to express the characteristics that the drain current Ids decreases gradually with decreasing drain voltage Vds (or with increasing output terminal voltage V2) in the saturation region.
The values of Δt1, V1, and Δt2 are described using parameters Rs, I0, and I1 which has previously been extracted. Also, as shown in
Next, a concrete calculation method for determining the shape of the E(t) waveform is described.
<1. Determination of Δt1>
Firstly, Δt1 is determined. For determination of Δt1, initial values, Δt1=Tslew−t0, V1=E, and Δt2=0, are given. This is equivalent to assuming that E(t) takes the shape as shown in
At this time, when t=Tslew, the PMOS transistor P1 is at the boundary point between its saturation and linear regions. As previously described, the current in this condition is registered as I1 in the delay-parameter database.
In the description of
However, as shown in
Now, two points Va and Vb of potential are selected which determine the inclination of the actual input waveform. At a time when a linear waveform which passes through these two points meets the power supply voltage Vdd (or the ground potential GND when the input waveform transitions from low to high), the rate of the amount of deviation of the linear waveform from the actual input waveform to the power supply voltage Vdd (this rate is hereinafter referred to as “TinDrop”) is measured to form an exponential waveform (with a time constant TinTau) which passes through the point of deviation (the point on the linear waveform at time Tslew) and a higher one of the potential points used to determine the inclination of the input waveform (e.g., Va in the example of
As shown by way of example in
Using the equation of V2(t) when Δt2=0, the following equation holds true for E(t) where t=Tslew.
E(Tslew)=V2(Tslew)+dI1Rs=E (7)
However, the fact is that the initial values (Δt1=Tslew−t0, V1=E, and Δt2=0) are not always a solution that satisfies equation (7). Thus, the result can be E(Tslew)>E or E(Tslew)<E.
First, the case where E(Tslew)≧E indicates that t≦Tslew, where t is the time when the saturation region with varying gate voltage Vgs (region I) transitions to the linear region (region III). More specifically, the case where E(Tslew)>E indicates that the value of the term, V2(Tslew)+d·I1·Rs, of equation (7) is large. Thus, in order to satisfy equation (7), the current value at the boundary between region I and region III must be reduced to below I1. Referring to
For the E(t) model, E(t0+Δt1)=E when t=t0+Δt1, the time corresponding to the boundary point between region I and region III. Thus, the following equation holds true:
V2(t0+Δt1)+Rsi(t0+Δt1)=E (8)
Since we assume that this is the second pattern where Δt2=0, V2(t0+Δt1) can be expressed, using equation (4), as follows:
Here, i(t0+Δt1) is the current in the saturation region. The current i(t) is considered as follows: (1) In the simplest transistor model, the drain current in the saturation region is i∞(Vgs−Vth)2, and it is i∞t2 when Vgs is approximately expressed as a linear equation; (2) taking the fixed delay t0 into account, t must be t0 and i must be 0; and (3) using linear approximation, Vgs=Vdd when t=Tslew, showing the Ids-Vds characteristics of
The current i(t0+Δt1) can be expressed by this equation. Substituting equations (9) and (10) in equation (8) yields the following relation:
Further, substituting equation (9) for V2(t0+Δt1) and changing the expression yields the following equation (12):
This equation has one solution when Δt1>0.
Next, when E(Tslew)<E, the saturation current I1 must be increased conversely, and transistor operation transitions from the saturation region with varying gate voltage Vgs (region I) to the saturation region with fixed gate voltage Vgs (Vgs=E) (region II) and then to the linear region (region III). That is, the case corresponds to the first pattern of the current waveform shown in
From the fact that Vgs=E at the boundary point between regions I and II and when considering the initial setting, E(t) reaches this boundary point when Tslew=t0+Δt1. When E(t) is expressed as shown in
As another exception when solving equation (12), there is the case where Δt1=Tslew−t0≦0. This case is understood to mean that Vgs=Vdd already when output current starts to flow, because it takes time to cause the flow of output current. The model in this state is considered to instantaneously move to the Ids-Vds characteristic curve where Vgs=Vdd. Thus, region I does not exist, and the model starts from region II. That is, Δt1=0.
In summary, Δt1 is as follows: (1) In the first case where Tslew−t0≦0, Δt1=0; (2) In the second case where E(Tslew)≧E, since t=t0+Δt1≦Tslew, Δt1≦Tslew−t0 and Δt1 satisfies the following equation:
and (3) In the third case where E(Tslew)<E, Δt1=Tslew−t0.
<2. Determination of V1>
For V1, the following equation also holds true:
V2(t0+Δt1)+Rsi(t0+Δt1)=V1 (14)
This equation is used for determining V1.
In the first case where Δt1=0, Vgs=Vdd already when t=t0. Thus, i(t0) is on the Ids-Vds characteristic curve of
From the above description, it is found that V2(t0+Δt1) is in the following range: 0<V2(t0+Δt1)<E−Rs·I1. Thus, the operating point of the transistor is in the position shown in
However, equation (15) is the equation obtained when the duration of time Δt2 corresponds to the “saturation region with fixed gate voltage”, and the gate voltage Vgs is fixed at Vdd.
The actual input waveform, as shown in
To reflect this error in the calculations of V1 and Δt2 which is to be described later, the mean gate voltage
Here, when Δt2=0,
Using this mean gate voltage
Here, the correction factor x can be expressed by the following equation:
Substituting xI0 and xI1 respectively for I0 and I1 and using equation (15) for i(t0+Δt1), we find the value of V1 that satisfies the following equation:
Further using equation (5), V2(t0+Δt1) can be expressed as:
From equations (18) and (19), V1 can be expressed as:
<3. Determination of Δt2>
Since the second case corresponds to the second pattern, Δt2=0. In the first and third cases, even at the boundary between regions II and III, the following equation holds:
Et(t0+Δt1+Δt2)=V2(t0+Δt1+Δt2)+xRsI1=E (21)
Region II is the saturation region where Vgs=Vdd, and at the boundary between regions II and III, i(t0+Δt1+Δt2)=x·I1. As the equation for determining V2(t0+Δt1+Δt2), equation (3) (in the first case) or equation (5) (in the third case) is used as in the other cases. Then, the value of Δt2 is determined to satisfy equation (21).
From the above description, we summarize the equations for the values of Δt1, V1, and Δt2 as follows. In the first case where Tslew−t0≦0, Δt1=0, V1=RsI0, and Δt2 satisfies the equation: V2(t0+Δt1+Δt2)+xRs·I1=E. In the second case where 0<Δt1≦Tslew−t0, Δt1 satisfies:
and V1=E and Δt2=0.
In the third case where Δt1>Tslew−t0, Δt1=Tslew−t0, V1 can be expressed as:
and Δt2 satisfies the equation: V2(t0+Δt1+Δt2)+Rs×I1=E.
This solution remain unchanged regardless of the rise and fall of the waveform.
Next, the delay calculation method will be described with reference to a flowchart.
In step S2, E(Tslew) is calculated from equation (7). When E(Tslew)≧E, the process goes to step S3 where E(t0+Δt1) is calculated from equation (11). This calculation is repeated with different values of Δt1 until E(t0+Δt1)=E, thereby to determine the value of Δt1 that satisfies E(t0+Δt1)=E. Since the case where E(Tslew)≧E corresponds to the second pattern, the E(t) waveform is as shown in
When E(Tslew)<E, the process goes to step S4, where the mean gate voltage
The process then goes to step S5, where the calculation is repeated with different values of Δt2 until equation (21) holds true. Thereby, the value of Δt2 that satisfies equation (21) is determined.
Since the case where E(Tslew)<E corresponds to the first pattern, the E(t) waveform can be determined by determining the values of V1, Δt1, and Δt2.
In step S6, the shape of the E(t) waveform is determined using the values of V1, Δt1, and Δt2 obtained in the above steps.
By determining the shape of the E(t) waveform in this way, the waveform of the output terminal voltage V2(t) of each macrocell can be obtained. In step S7, the waveform of the output terminal potential V2(t) is calculated using E(t). In the case where interconnection is implemented as an RC network, the potential waveform at the end of the interconnection can also be obtained by analyzing a time response at the end of the interconnection when V2(t) is applied to the output terminal of each cell. In step S8, a delay value and information on the following input waveform are calculated from the potential waveform at each node.
As shown in
In
In
From the above, it is found that the delay calculation method according to the preferred embodiment of the present invention allows accurate calculations of output waveforms by adopting input waveform information that gives the shapes of input waveforms. Since output waveforms can be calculated with accuracy, if a time difference between input and output waveforms is measured with, for example, 50% of Vdd, delay values can be calculated with a small margin of error.
The present invention appropriately divides, depending on load conditions, the case where the E(t) waveform can be determined by only Tslew and the case where the E(t) waveform cannot be determined by only Tslew. In the latter case, parameters are corrected using a difference in the mean gate voltage
Also, using the technique for calculating the correction factor x for parameter correction causes virtually no increase in calculation time when compared with that in conventional delay calculation methods.
While the delay calculation method according to the preferred embodiment of the present invention employs a voltage source model that represents transistor operation by determining the E(t) waveform of the power supply, this method is also applicable to other delay calculation methods such as that employing a current source model. In the case of the current source model, instead of determining the E(t) waveform, a current source is set so as to directly output current waveforms as shown in
While the invention has been shown and described in detail, the foregoing description is in all aspects illustrative and not restrictive. It is therefore understood that numerous modifications and variations can be devised without departing from the scope of the invention.
Number | Date | Country | Kind |
---|---|---|---|
2004-207191 | Jul 2004 | JP | national |
Number | Name | Date | Kind |
---|---|---|---|
6629299 | Iwanishi | Sep 2003 | B1 |
6750676 | Honda | Jun 2004 | B1 |
7126408 | Zerbe | Oct 2006 | B2 |
7225418 | Shimazaki et al. | May 2007 | B2 |
20050278671 | Verghese et al. | Dec 2005 | A1 |
Number | Date | Country |
---|---|---|
2002-123568 | Apr 2002 | JP |
Number | Date | Country | |
---|---|---|---|
20060015278 A1 | Jan 2006 | US |