US6611948B1 - Modeling circuit environmental sensitivity of a minimal level sensitive timing abstraction model - Google Patents
Modeling circuit environmental sensitivity of a minimal level sensitive timing abstraction model Download PDFInfo
- Publication number
- US6611948B1 US6611948B1 US09/927,220 US92722001A US6611948B1 US 6611948 B1 US6611948 B1 US 6611948B1 US 92722001 A US92722001 A US 92722001A US 6611948 B1 US6611948 B1 US 6611948B1
- Authority
- US
- United States
- Prior art keywords
- circuit
- input
- port
- output
- output port
- 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.)
- Expired - Lifetime
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/32—Circuit design at the digital level
- G06F30/33—Design verification, e.g. functional simulation or model checking
- G06F30/3308—Design verification, e.g. functional simulation or model checking using simulation
- G06F30/3312—Timing analysis
Definitions
- the technical field relates to timing analysis systems, and, in particular, to static timing analysis of a digital circuit.
- Timing analysis tools are widely used to predict the performance of very large scale integrated (VLSI) designs. Often, timing analysis determines the best path for a designer to pursue or helps to optimize the overall circuit design. In digital circuits, timing considerations can be critical to proper performance. Timing analysis tools may be either static or dynamic.
- DTA Dynamic timing analysis
- circuit simulation approaches to performance analysis are pattern dependent, or stated another way, the possible paths and the delays associated with the paths depend upon a state of a controlling mechanism or machine of the circuit being simulated.
- the result of a DTA depends on the particular test pattern, or vector, applied to the circuit.
- Static timing analysis (STA) tools are also widely used to predict the performance of VLSI designs.
- STA Static timing analysis
- a design engineer applies signal arrival and departure times only at each block input, not at base waveform. Additionally, each signal is assumed to switch independently in each machine cycle, i.e., static timing analyzer is waveform independent and simulates the most critical arrival time at each node in the circuit.
- Timing models used in timing analysis are blocks of computer data that can be used to recreate the timing behavior of an electronic circuit.
- the size of timing models should be as small as possible for a given complexity of circuit, while maintaining the accuracy of the timing model.
- a smaller timing model will not only require less space in a computer memory, but also will be faster for a computer to evaluate.
- timing model accuracy is sacrificed to shrink the timing model and speed its evaluation. This is especially important for large timing models that represent an entire subcircuit of an electronic system.
- a popular technique for shrinking a timing model involves creating port-based timing models as opposed to path-based timing models.
- Port-based timing models analyze an electronic circuit to isolate and maintain only the timing behavior that can be observed at the circuit's connections, often referred to as ports, to surrounding circuits. Any timing behavior of a circuit that is internal to the circuit is discarded, leaving only the information that is essential to verifying the timing behavior of the circuit in the context of surrounding circuits.
- the port-based timing models have been used in both timing simulation and STA. The timing models are accurate, and generally provide good compression of timing model size.
- the electronic circuit is analyzed to determine the longest time for an electronic signal to pass from each input port to each output port. Often the shortest time is determined as well.
- An edge triggered latch in the circuit controlled by a clock signal, acts much like an internal port and is also considered a start point and an end point for electronic signals. At the instant the value of its clock signal changes, the edge triggered latch passes the value of its data signal to its output signal. At other times, the edge triggered latch holds the value of its output signal constant. Analysis is also done to determine the longest time for an electronic signal to pass from each input port to the input signals of each edge triggered latch and from the output signal of each edge triggered latch to each output port.
- the internal latch nodes are abstracted away and only the longest time for an electronic signal to arrive at each given output port is calculated. Often the shortest time is calculated as well. The latest (and often also the earliest) allowed time for signal to arrive at each given input port is also calculated. For circuits with edge triggered latches, these calculations are rather simple. The longest time for a signal to arrive at the output port is the time when the clock signal changes on the edge triggered latch that is connected to the output port by a combinational circuitry, plus the time the signal passes from the latch to the output port. If more edge triggered latches are connected to the output port by a combinational circuitry, the latest signal arrival from all the latches is considered.
- the latest allowed time for the signal to arrive at the input port is the time when the clock signal changes on the edge triggered latch that is connected to the input port by a combinational circuitry, minus the time the signal passes from the input port to the latch, minus the setup time for the latch (due to the physical characteristics of the latch electronic circuitry, the signal value at the latch input must be stable before the clock signal changes).
- the latest time for the signal to arrive at the input port is the minimum from the latest times determined for the individual latches as described above.
- the latch that determines the minimum time is referred to as the most critical latch. PathMill's Black box timing model supports these calculations. However, the calculations become more complicated for circuits that use level triggered latches, and PathMill's Black box cannot accurately model such circuits.
- level triggered latches i.e., transparent latches
- a level triggered latch is controlled by a clock signal.
- the edge triggered latches are active only at the instant the clock signal changes, while the level triggered latches can be active at any time that the clock signal remains at a specified voltage (high or low voltage).
- the level triggered latches in a circuit can time borrow amongst themselves. Time borrowing is possible when the combinational logic between two latches requires more time than the clock phase to compute a stable value. However, if the logic following the second latch requires less than an entire clock phase to compute a stable value, then the value propagated by the first latch need not become stable until some time after the second latch becomes active. The second set of logic will still have enough time to propagate a stable value, even though the calculations did not begin until some time after the latches become active. Time borrowing is an essential technique for latch-based design. High performance or custom designed circuits, such as modern CPUs, rely on level triggered latches to take advantage of the time borrowing that helps reach high clock frequencies. Timing models that do not support time borrowing are inadequate for such designs.
- the level triggered latch latches the input data and holds that value on the output port until the clock transitions again.
- the input data is fed to the level triggered latch via the latch's data pin.
- the output of the latch is available on the latch's output pin.
- the clock signal is connected to the latch using the latch's clock pin.
- the transition between when the latch is transparent and when the latch holds its value is not instantaneous. Therefore, the value on the data pin must be available a certain amount of time before the clock signal transitions to a low voltage. This time is called the setup time. Routines that verify that the data is available early enough to meet the setup time are called setup checks and violations are called setup violations. In addition to the setup time, the data value must remain constant for a certain amount of time after the clock transitions to low. This time is called the hold time. Routines that verify that the data is available long enough to meet the hold time are called hold checks and violations are called hold violations. If a setup or a hold violation occurs, the latch might not contain a valid value. Thus, it is important that timing models accurately represent setup and hold times.
- a signal arriving at the output ports depends on the signal arrival time at the input ports, referred to as stimulus.
- the parameters of the timing model are limited to certain intervals of the arrival times. If the stimulus is outside of the interval, the timing model does not properly represent the circuit and the model needs to be rebuilt each time when the stimulus change.
- the timing model works irrespective of when the signal arrives at the input ports, i.e., always generating correct arrival at the output port.
- PathMill's conventional Black box timing models are port-based and stimulus independent.
- the conventional Black box timing models do not support transparency.
- PathMill's new transparent Black box timing models are port-based with limited support of transparency.
- the new Transparent Black box timing models are stimulus dependent.
- Pathmill's Gray box timing models support transparency and are stimulus independent.
- the Gray box timing models are not port-based.
- the Transparent Black box timing models are significant improvement over the conventional Black box timing models.
- the latest allowed time for the signal to arrive at a given input port i.e., the time before setup violation occurs, is calculated, considering not only the first latch connected to the given input port by a combinational circuitry.
- the second latch or other sequential element that is connected to the first latch by a combinational circuitry is also considered, as well as the third and any successive latch that may be on a transparent path from the given input port.
- the second, third, or other latch on the transparent path from an input port may be more critical than the first latch, i.e., the second, third, or other latch determines the latest time on the input port before the setup violation occurs, employing similar calculation procedure as described earlier for the first latch in the conventional Black box timing model.
- the longest time for an electronic signal to arrive at the output port is calculated, considering not only the last latch connected to the output port by a combinational circuitry, but also the previous latch that is connected to the last latch by a combinational circuitry, as well as any earlier latch that may be on a transparent path to the output port.
- the signal arrival at the output port on a transparent path is correct only for the input port stimulus that was used to build the model.
- the model needs to be rebuilt or the signal arrivals at output ports on transparent paths may be wrong, since the Black box timing model cannot represent the unique clock-controlled connectivity between the input and the output ports on a transparent path.
- the output signal arrival time on the most critical transparent path is hard-coded in the model, which makes the model valid only for a particular input stimulus.
- Timing abstraction models typically require the modeling of circuit environmental sensitivities. A circuit's performance is dependent on the environment within which the circuit is used. Most available STA tools support environmental sensitivity models. PathMill is such a tool. However, using conventional method to model the environmental sensitivities as part of minimal level sensitive timing abstraction models results in inaccuracies.
- Gray box timing models support transparency, are stimulus independent, and require a well-defined analytical model to represent the environmental sensitivity.
- Gray box timing models abstract only combinational circuit elements and retain all sequential elements that are represented by internal clock-controlled nodes connected by time-arcs, i.e., not port-based.
- Gray box timing models For blocks with a large number of latches, Gray box timing models have a large number of internal nodes and time-arcs, resulting in a large number of timing checks to be performed and a large number of paths to be traced in a STA run. All timing checks carried out on a lower level of hierarchy need to be repeated again on higher hierarchy levels, because no sequential nodes are abstracted away when moving from one level of hierarchy to the next level.
- a method for modeling circuit environmental sensitivity for a basic minimal level sensitive timing abstraction model includes extracting a plurality of parameters from a circuit that includes an input port and an output port, creating an echo-circuit that represents the plurality of parameters.
- the echo-circuit is lightweight, can be input into any static timing analysis (STA) tools, and may enable a signal to propagate from the input port to the output port only if the signal arrives at the output port later than a clock signal from a most critical clock element controlling the output port.
- the method further includes adding an input delay arc at the input port and adding an output delay arc at the output port.
- the input delay arc and the output delay arc are capable of reflecting environmental conditions.
- Environmental conditions typically include different external conditions such as input signal switching time and output-capacitive loading for the circuit, that are influenced by the circuitry surrounding the basic timing abstraction model.
- the method for modeling circuit environmental sensitivity involves creation of delay components that allow for modeling the circuit environmental sensitivity factors while maintaining the transparent regions of the circuit. To properly model the environment conditions, zero delay elements may be inserted at the input and output ports of the basic timing abstraction model, producing an improved abstraction model that retains accuracy and efficiency of the basic timing abstraction model.
- FIG. 1 illustrates an exemplary basic minimal level sensitive transparent timing abstraction model of an exemplary circuit block
- FIGS. 2 ( a ) and 2 ( b ) illustrate exemplary input-to-output delay functions reflecting signal transition time at an input and capacitive loading at an output;
- FIG. 3 illustrates an exemplary improved timing abstraction model that accounts for environmental sensitivities
- FIG. 4 is a flow chart illustrating an exemplary method for modeling circuit environmental sensitivity for the exemplary improved timing abstraction model.
- FIG. 5 illustrates exemplary hardware components of a computer that may be used in connection with the improved timing abstraction model for modeling circuit environmental sensitivity.
- a basic minimal level sensitive timing abstraction model provides for a minimal representation of a digital circuit block, in the form of an equivalent circuit or connectivity network, with a minimum number of internal nodes.
- the basic timing abstraction model supports transparency and can be input into general static timing analysis (STA) tools to efficiently perform timing analysis on large circuits that contain the modeled circuit block.
- STA general static timing analysis
- the circuit block represented by the basic timing abstraction model may contain a combination of sequential and combinational elements, as well as one or more blocks that are themselves this type of timing abstraction model.
- the basic timing abstraction model supports multiple levels of hierarchy and limits timing analysis to most critical paths, i.e., a path from an input port to a setup/hold check node, a path from the input port to a dummy latch node that checks for transparency, a transparent path between the input port and an output port, and a path between a most critical clock element and the output port.
- the multiple levels of hierarchy leads to a significant reduction of the number of internal clock-controlled nodes, which in turn results in significant speed-up of STA runs on large circuits and reduced memory and storage space requirements.
- a method and a corresponding apparatus provide for modeling circuit environmental sensitivity for the basic minimal level sensitive timing abstraction model.
- Environmental conditions typically include different external conditions, such as signal transition time at the circuit input and output capacitive loading for the circuit, that are influenced by the circuitry surrounding the basic timing abstraction model.
- the method for modeling circuit environmental sensitivity creates delay components that allow for modeling the circuit environmental sensitivity factors while maintaining the transparent regions of the circuit. Specifically, zero delay elements may be inserted at input and output ports of the basic timing abstraction model, producing an improved timing abstraction model that accounts for environmental sensitivity factors while retaining accuracy and efficiency of the basic timing abstraction model.
- Timing analysis is to simulate signal arrival times at different nodes in a digital circuit to assure proper functionality of the circuit.
- clock-controlled nodes Within the circuit are clock-controlled nodes and nodes that are not controlled by clocks.
- the signal On the clock-controlled nodes, the signal must arrive within a certain time interval relative to the clock. For example, for an edge triggered latch, the signal must arrive at the latch before the active edge of the clock, and for a level triggered latch, the signal must arrive before the closing edge of the clock, i.e., while the latch is open or in an active level. If the signal does not arrive within this timing interval, a violation occurs and the circuit may not function properly.
- Timing analysis is a computer simulation of the digital circuit to simulate arrival times on the clock-controlled nodes and to verify that the signal arrives at the nodes within the allowed time interval.
- a micro chip containing digital circuits may have millions of elements, such as transistors, gates, resistors, and interconnects represented by resistors and capacitors. Simulation and timing analysis on a full chip level is expensive. Accordingly, a common practice is to divide the chip into blocks and conduct timing analysis on each of the blocks individually. The blocks are given the characteristics of the real circuit, by abstracting away unnecessary information from the circuit and characterizing the circuit by a set of useful parameters.
- Port-based timing models involve less timing simulation than path-based timing models.
- the number of nodes scales with the number of ports.
- the number of nodes scales with the number of paths, which is significantly more than the number of ports in a circuit. The more nodes there are, the longer the timing checks take. So the number of nodes determines how fast the timing checks are performed.
- the number of timing checks to be performed i.e., the number of parameters, scales with the number of input ports plus the number of input-to-output port pairs that are connected by transparent paths for at least one input stimulus, which is usually much less than the total number of paths in the circuit.
- the speed-up of STA runs that uses the basic timing abstraction model may be achieved as follows.
- the number of timing checks to be performed in most circuits may be reduced to one check for each input port plus one check for each input-to-output port pair that is connected by a transparent path for at least one input stimulus.
- each timing check may be performed faster in the port-based timing model than in a path-based timing model, because the number of clock controlled internal nodes in the port-based model is small, i.e., in most circuits the number of clock controlled nodes is equal to number of ports.
- this port-based model may be stored in the fast computer memory, i.e., the main memory or the very fast microprocessor cache memory, than in the path-based timing models.
- the fast computer memory i.e., the main memory or the very fast microprocessor cache memory.
- the most relevant transparent paths i.e., paths on which a signal arrives at the output port later than the latest clock signal, are traced to a given output port, reducing the number of paths fed to the adjacent blocks.
- Level triggered latches which support transparency, can be active when any of their clock signals, i.e., clock elements, remain at a high voltage, while edge triggered latches are active only at the instant the clock signals change. Some level triggered latches are active when the clock signals are at low voltage, instead of high voltage, but the processes are the same.
- the basic timing abstraction model has level triggered latches. In the discussion that follows, level triggered latches are transparent when the clock signals are high, but as will be apparent to one skilled in the art, the techniques described also apply to latches that pass values when the clock signals are low. Also, the following paragraphs describe modeling of maximum (long) path STAs, i.e., the paths with the latest signal arrival at input and output ports. As will be apparent to one skilled in the art, the techniques described also apply to minimum (short) path STAs, i.e., the paths with the earliest signal arrival at the input and output ports, except that there are no short transparent paths in the circuit.
- An embodiment of the basic timing abstraction model first extracts a minimal set of characteristics, i.e., parameters, from the modeled circuit in order to simulate timing on the circuit.
- the parameters include: 1) a required time parameter associated with an input port, i.e., the latest time a signal can arrive at the input port before a setup violation would occur in the modeled circuit on some sequential element, i.e., a latch or a domino logic, connected to the input port by a combinational circuitry and/or a circuitry that consists of one or more transparent sequential elements; 2) a valid time parameter associated with an output port, i.e., the latest time the signal from any clock element arrives at the output port; and 3) an input-to-output delay parameter that represents a time delay a signal passes from the input to the output port on a transparent path.
- the basic timing abstraction model creates an echo-circuit that represents the characteristics and can be input into virtually any STA tool.
- the echo-circuit may be a basic timing abstraction model represented in PathMill's Gray box format.
- the first characteristic to be extracted is a setup/hold check time, referred to as a required time, associated with a setup/hold check node at each input port in the basic timing abstraction model. Associating timing checks with the input port do not reduce the universality of the basic timing abstraction model because STA analysis tools support circuits with setup/hold timing checks attached to any node.
- a simulation for maximum paths i.e., the setup check
- a simulation for minimal paths i.e., the hold check
- the minimal path simulation behaves in a similar fashion, except that there are no transparencies in minimal path simulation because there is no input-to-output path.
- the setup check node checks data arrival at the input port with respect to the required time, which is the latest time the data signal can arrive at the input port before any violation would occur in the modeled circuit.
- the setup check node checks if the data signal arrives at the input port early enough so that the most critical clock-controlled node of the modeled circuit, i.e., the most critical latch or other sequential element such as the domino logic, will have no violation.
- the most critical sequential element in the modeled circuit is the sequential element on which the violation occurs with the earliest time arrival at the input port.
- the most critical path is the one that fails first, and the setup check node checks the required time that corresponds to the time when the failure occurs on the most critical sequential element.
- a circuit with three latches may have the most critical as the second latch.
- 800 picoseconds may be required for a signal to propagate from the input port to the second latch, and the signal may be required to be at the second latch at time 1000 picoseconds or earlier. If the signal arrives at the second latch in the modeled circuit at 1000 picoseconds, which is the latest allowed time, there is no violation. On the other hand, if the signal arrives at 1001 picoseconds, a violation occurs. Since 800 picoseconds are required to propagate the signal from the input port to the second latch, the signal must arrive at the input port within 200 picoseconds.
- setup time, SI at an input port I can be expressed as:
- SI min j ⁇ ( SI j ) ( 1 )
- SI j SL j +(Cycle j ⁇ Cycle 0 ) T ⁇ Delay j , (2)
- SI j is the latest time a signal can arrive at the input port I before violation would occur on a sequential element, i.e., latch or domino logic
- L j in the modeled circuit SL j is the latest time signal can arrive at the sequential element L j before setup violation would occur on the sequential element
- Cycle j is the clock cycle count on the sequential element L j
- T is the clock cycle time (the clock period)
- Delay j is the time the signal needs to propagate from the input port I to the sequential element L j .
- the setup times SI j can be obtained, for example, from a Pathmill run with a late stimulus at the input port I and a latch_error_recovery feature turned on.
- the late stimulus is an arbitrarily chosen stimulus, Lstim, that is so late that with a certainty a setup violation will occur on some sequential element in the circuit (usually, Lstim can be any number that is much higher than the clock period T).
- Lstim can be any number that is much higher than the clock period T.
- Slack j is the timing slack on the sequential element L j
- Advance k is the timing adjustment introduced by the latch_error_recovery feature on the sequential element L k that is on the path from the input port I to the sequential element L j .
- the setup times, SI j can be obtained from other commercial STA tools in a similar way.
- the setup times can also be obtained directly from Pathmill's Transparent Black model, if the signal arrival times at output ports are not subjected to any constraints when such model is generated.
- the second characteristic to be extracted is an opening time, referred to as a valid time, associated with a dummy latch node attached to each output port.
- the dummy latch node may be controlled by a derived clock that has an opening edge offset with respect to the opening edge of a clock port.
- the derived clock typically becomes active at the time corresponding to the latest signal arrival from the clock port to the output port in the modeled circuit.
- the dummy latch node compares data signal arrival at the output port with the clock signal arrival of the latest clock at the output port. All paths arriving before the latest clock stop at the dummy latch node, i.e., the paths are not transparent and the clock signal goes to the output port instead. If the data signal arrives after the clock signal, the data signal propagates to the output port.
- the dummy latch node enables comparison of the data signal with the latest clock signal. Accordingly, the data signal may be blocked if the signal arrives earlier than any of the clocks converging to the output port. Comparing the paths with the most critical clock significantly reduces the number of paths that arrive at the output port.
- the valid time, VO, at an output port O can be expressed as:
- VO max j ⁇ ( VO j ) ( 4 )
- VO j DO j ⁇ (Cycle j ⁇ 1) T (5)
- DO j is the signal arrival time at the output port O from clock port C j
- DC j is the signal arrival at a clock port C j
- Delay j is the time the signal needs to propagate from the clock port C j to the output port O
- VO j is the time DO j adjusted to the first clock cycle
- Cycle j is the clock cycle count on the output port O
- T is the clock cycle time (the clock period). Note that the valid time VO calculated from equations (4)-(6) is adjusted to be in the first-clock cycle.
- the offset between the clock port C j and the derived clock controlling the dummy latch node will be set to time VO-DC j .
- the STA tool will determine whether or not the input signal will pass the dummy latch node in the basic timing abstraction model based on the valid time and the cycle count on the path from the input port.
- the clock signal arrival times, DO j and the clock cycle counts, Cycle j can be obtained from any commercial STA tool, such as Pathmill.
- the clock signal arrival times and the clock cycle counts are stimulus independent because the clock signal propagation is independent on input signal arrival times.
- the third characteristic to be extracted is an input-to-output delay, i.e., transparent delay arc.
- the delay exists only if, for some stimulus, the signal propagates transparently between the input port and the output port.
- the dummy latch node opens at the valid time and closes at the latest possible signal arrival time from an input port that has a timing path to the output port. Such time is determined by the required times and the path delays. Accordingly, the dummy latch node/enables a signal to propagate from the input port to the output port only if the signal arrives at the output port later than a clock signal on the most critical clock controlling the dummy latch node. This feature is acceptable for STA tools because STA only deals with the most critical path, i.e., the most critical arrival at any given node.
- the basic timing abstraction model reduces the number of paths fed to the adjacent blocks and speeds-up the STA runs, because, by blocking the number of paths that leave the first block, the total number of paths in the circuit may be decreased significantly.
- the basic timing abstraction model simplifies the output from the timing analysis and shortens designer's time to analyze STA results because only the paths that are important are printed in the report.
- the input-to-output delays can be obtained from any commercial STA tool, such as Pathmill, when the input stimulus is set to the required time, SI, described above. These characteristics, i.e., the required time, the valid time, and the input-to-output delay, may be obtained from STA analysis as discussed above.
- the basic timing abstraction model described above represents each input-to-output transparent path by an equivalent circuit that consists of time-arcs (or connectivity networks) and clock-controlled (dummy latch) nodes to model signal arrivals at the output ports independently on input stimulus.
- the equivalent circuit may be designed such that the tracing of false non-transparent paths is avoided and the reported transparent paths are limited to those critical paths that may be important for the designer.
- the basic timing abstraction model is input-stimulus independent and needs to be rebuilt only when the clock waveforms change.
- FIG. 1 illustrates an exemplary basic minimal level sensitive transparent timing abstraction model 100 of an exemplary circuit block.
- a setup check node 160 is attached to an input port 130 , while a dummy latch node 170 , controlled by a derived clock 110 , is connected to an output port 140 .
- a transparent delay arc 150 is contained between the setup check node 160 and the dummy latch node 170 .
- the transparent delay arc 150 may be represented as an intrinsic transparent delay 250 (shown in FIG. 2) with no external influence.
- the transparent delay arc 150 , the setup check node 160 , and the dummy latch node 170 factors in the basic timing abstraction model 100 may not sufficiently model the environmental sensitivity.
- FIGS. 2 ( a ) and 2 ( b ) illustrate exemplary input-to-output delay functions reflecting signal transition time at a circuit input (input slope) and capacitive loading at a circuit output (output capacitive loading).
- environmental conditions are typically attached to the input-to-output delay component.
- An exemplary improved timing abstraction model 300 (shown in FIG. 3) involves creation of delay components that allow for modeling circuit environment sensitivity factors while maintaining the transparent regions of the circuit.
- Environmental sensitivity typically involves the input slope and the output capacitive loading.
- the performance of a circuit may vary based on the input and output factors. For example, for an input signal switching an inverter, the delay and the rate at which an output switches depend on many factors, such as transistor sizes, supply voltage, threshold voltage, input signal waveform, and output capacitive loading, and other input and output factors. Within minimal level sensitive timing abstractions, most variables are typically fixed. However, the receiving transistors at the input port 130 are sensitive to the input slope and the driving transistors at the output port 140 are sensitive to the output capacitive loading.
- the environmental sensitivity factors may be split into input sensitivity factors, i.e., the input slope, and output sensitivity factors, i.e., the output capacitive loading.
- the input slope represents sensitivity of an input to the environmental conditions.
- Signal rise or fall times at the input port 130 which are variables that typically affect the input-to-output delay, may be calculated.
- the output capacitive loading represents sensitivity of an output to the environmental conditions.
- signal rise or fall times at the output port 140 which also affect the input-to-output delay, may be calculated.
- the input-to-output delay and the signal rise or fall times at the output port 140 are typically sensitive to the input slope and the output capacitive loading.
- the input-to-output delay may be represented in FIG. 2 ( a ) as I DI 251 , which stands for an intrinsic input delay, and in FIG. 2 ( b ) as I D2 252 , which stands for an intrinsic output delay.
- I DI 251 which stands for an intrinsic input delay
- I D2 252 which stands for an intrinsic output delay
- an equation may be generated to reflect the sensitivity of the input-to-output delay to the environmental conditions.
- a linear equation may be generated with a slope K 1 221 or K 2 222 , respectively, to reflect the input slope and the output capacitive loading.
- the input-to-output delay increases linearly with respect to the input slope, as shown in FIG. 2 ( a ), or the output capacitive loading, as shown in FIG. 2 ( b ).
- a characterization tool that allows for the abstraction may be used to generate the input slope or the output capacitive loading in relation to the input-to-output delay. For example, different input slopes may be simulated by measuring the input-to-output delay at five different input slopes and interpolating through a straight line to create a slope that best fits the behavior of the circuit for the five different input slopes. The same may be accomplished for the output capacitive loading, i.e., selecting five different output capacitive loading values, simulating and measuring the input-to-output delays, and creating a straight line. Even though straight line simulation is typically used, the simulation may also result in a higher order polynomial or a multi-dimensional table.
- FIG. 3 illustrates an exemplary improved timing abstraction model 300 that accounts for environmental sensitivities.
- zero delay elements 260 , 270 may be inserted at the input port 130 and the output port 140 of the basic timing abstraction model 100 .
- An input slope sensitivity factor 260 i.e.; an input delay arc, may be added to the intrinsic input delay I DI 251 at the setup check node 160 .
- the inserted input delay arc 260 has a zero delay with an input slope of zero. As the input slope increases (due to the environmental conditions), the input delay arc 260 changes gradually. As a result, the setup check time may change accordingly, accounting for the environmental sensitivity.
- the improved timing abstraction model 300 may also account for the delay adjustment before a setup check is performed at the input port 130 . Only if the setup check passes, the adjusted delay may be added to the intrinsic input delay I DI 251 . As a result, changes in the environmental conditions may be reflected on the input delay arc 260 .
- the improved timing abstraction model 300 may account for delay adjustments after the input-to-output path is determined as transparent, by adding an output capacitive loading sensitivity factor, i.e., an adjusted output delay arc 270 , to the intrinsic output delay I D2 252 . As a result, the environmental conditions may be reflected on the output delay arc 270 .
- an output capacitive loading sensitivity factor i.e., an adjusted output delay arc 270
- a circuit has an input slope of 50 picoseconds, an output capacitive loading of 200 picofarads, and a transparent delay of 800 picoseconds from an input port to the most critical setup check node.
- STA is run on the circuit with input slopes of, for example, 25 picoseconds, 40 picoseconds, 75 picoseconds and 100 picoseconds, delays resulted are, for example, 783 picoseconds, 790 picoseconds, 810 picoseconds and 825 picoseconds, respectively.
- a linear equation may be generated based on the sets of data, where a line representing the equation crosses the y-axis around 760 picoseconds.
- a setup check time of 760 picoseconds may be applied in the improved timing abstraction model 300 , creating an input delay arc 260 .
- the actual input slope may be, for example, 55 picoseconds, which may result in an incremental change of around 45 picoseconds.
- the STA tool may add 45 picoseconds to the total delay up to the input delay (which is 760 picoseconds).
- a transparent delay arc 250 may be calculated. Since the transparent delay depends on the input slope and the output capacitive loading, both the input slope values and the output capacitive loading values may be used for the calculation. Environmental sensitivities are typically based on the first logic gate in the circuit block, therefore the input sensitivity factors for the transparent delay arc 250 are the same as for the input delay arc 260 , and the output sensitivity factors are the same as for the output delay arc 270 .
- the improved timing abstraction model 300 reflects environmental conditions in modeling the circuit.
- FIG. 4 is a flow chart illustrating an exemplary method for modeling circuit environmental sensitivity for the exemplary improved timing abstraction model 300 .
- parameters may be extracted from a circuit that includes sequential elements, such as latches or domino logics, controlled by clock elements, step 410 .
- the parameters to be extracted may include a required time parameter associated with a setup check node, step 412 , a required time parameter associated with a hold check node, step 414 , a valid time parameter associated with a dummy latch node, step 416 , or a transparent delay arc parameter, step 418 .
- an echo-circuit may be created to represent the parameters, step 420 .
- the echo-circuit may enable a signal to propagate from an input port to an output port only if the signal arrives at the output port later than a clock signal from the most critical clock element controlling the output port.
- circuit sensitivity parameters may be extracted. Thereafter, an input delay arc 260 may be added at the input port to reflect environmental conditions, step 440 . Similarly, an output delay arc 270 may be added at the output port to reflect the environmental conditions, step 450 . Finally, a transparent delay arc 250 may be applied to the echo-circuit so that the echo-circuit is capable of reflecting the environmental conditions, step 460 .
- FIG. 5 illustrates exemplary hardware components of a computer 500 that may be used in connection with the improved timing abstraction model 300 for modeling circuit environmental sensitivity.
- the computer 500 includes a connection with a network 518 such as the Internet or other type of computer or telephone networks.
- the computer 500 typically includes a memory 502 , a secondary storage device 512 , a processor 514 , an input device 516 , a display device 5106 and an output device 508 .
- the memory 502 may include random access memory (RAM) or similar types of memory.
- RAM random access memory
- the memory 502 may be connected to the network 518 by a web browser 506 .
- the web browser 506 makes a connection by way of the world wide web (WWW) to other computers, and receives information from the other computers that is displayed on the computer 500 .
- Information displayed on the computer 500 is typically organized into pages that are constructed using specialized language, such as HTML or XML.
- the secondary storage device 512 may include a hard disk drive, floppy disk drive, CD-ROM drive, or other types of non-volatile data storage, and may correspond with various databases or other resources.
- the processor 514 may execute information stored in the memory 502 , the secondary storage 512 , or received from the Internet or other network 518 .
- the input device 516 may include any device for entering data into the computer 500 , such as a keyboard, key pad, cursor-control device, touch-screen (possibly with a stylus), or microphone.
- the display device 510 may include any type of device for presenting visual image, such as, for example, a computer monitor, flat-screen display, or display panel.
- the output device 508 may include any type of device for presenting data in hard copy format, such as a printer, and other types of output devices including speakers or any device for providing data in audio form.
- the computer 500 can possibly include multiple input devices, output devices, and display devices.
- the computer 500 is depicted with various components, one skilled in the art will appreciate that the computer 500 can contain additional or different components.
- aspects of an implementation consistent with the present invention are described as being stored in memory, one skilled in the art will appreciate that these aspects can also be stored on or read from other types of computer program products or computer-readable media, such as secondary storage devices, including hard disks, floppy disks, or CD-ROM; a carrier wave from the Internet or other network; or other forms of RAM or ROM.
- the computer-readable media may include instructions for controlling the computer 500 to perform a particular method. While the method and apparatus for modeling circuit environmental sensitivity of a minimal level sensitive timing abstraction model have been described in connection with an exemplary embodiment, those skilled in the art will understand that many modifications in light of these teachings are possible, and this application is intended to cover any variations thereof.
Landscapes
- Engineering & Computer Science (AREA)
- Computer Hardware Design (AREA)
- Physics & Mathematics (AREA)
- Theoretical Computer Science (AREA)
- Evolutionary Computation (AREA)
- Geometry (AREA)
- General Engineering & Computer Science (AREA)
- General Physics & Mathematics (AREA)
- Design And Manufacture Of Integrated Circuits (AREA)
Abstract
Description
Claims (19)
Priority Applications (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
US09/927,220 US6611948B1 (en) | 2001-08-10 | 2001-08-10 | Modeling circuit environmental sensitivity of a minimal level sensitive timing abstraction model |
Applications Claiming Priority (1)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
US09/927,220 US6611948B1 (en) | 2001-08-10 | 2001-08-10 | Modeling circuit environmental sensitivity of a minimal level sensitive timing abstraction model |
Publications (1)
Publication Number | Publication Date |
---|---|
US6611948B1 true US6611948B1 (en) | 2003-08-26 |
Family
ID=27758077
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
US09/927,220 Expired - Lifetime US6611948B1 (en) | 2001-08-10 | 2001-08-10 | Modeling circuit environmental sensitivity of a minimal level sensitive timing abstraction model |
Country Status (1)
Country | Link |
---|---|
US (1) | US6611948B1 (en) |
Cited By (22)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US20030192020A1 (en) * | 2002-04-05 | 2003-10-09 | Mentor Graphics Corporation | Slack time analysis through latches on a circuit design |
US20030229483A1 (en) * | 2002-06-10 | 2003-12-11 | Mentor Graphics Corporation | Causality based event driven timing analysis engine |
US20040181761A1 (en) * | 2003-03-11 | 2004-09-16 | Renesas Technology Corp. | Circuit simulation for a circuit including transistors |
US20050251767A1 (en) * | 2004-05-07 | 2005-11-10 | Shah Gaurav R | Processing of circuit design data |
US20060059446A1 (en) * | 2004-09-14 | 2006-03-16 | Chen Thomas W | Sensitivity based statistical timing analysis |
US20070226667A1 (en) * | 2006-03-24 | 2007-09-27 | Chadwick Thomas B Jr | Static timing slacks analysis and modification |
US20070226668A1 (en) * | 2006-03-22 | 2007-09-27 | Synopsys, Inc. | Characterizing sequential cells using interdependent setup and hold times, and utilizing the sequential cell characterizations in static timing analysis |
US20070266356A1 (en) * | 2006-05-15 | 2007-11-15 | Taiwan Semiconductor Manufacturing Company, Ltd. | IC Design Flow Enhancement With CMP Simulation |
US20080141201A1 (en) * | 2006-11-15 | 2008-06-12 | Postech Academy-Industry Foundation | Black box timing modeling method and computer system for latch-based subsystem |
US7421675B1 (en) | 2006-01-17 | 2008-09-02 | Xilinx, Inc. | Annotating timing information for a circuit design for increased timing accuracy |
US20080244482A1 (en) * | 2007-03-30 | 2008-10-02 | Taiwan Semiconductor Manufacturing Company, Ltd. | Integrated circuit design usage and sanity verification |
US20080244483A1 (en) * | 2007-03-30 | 2008-10-02 | Taiwan Semiconductor Manufacturing Company, Ltd. | Integrated circuit design usage and sanity verification |
US7451417B1 (en) | 2006-05-12 | 2008-11-11 | Xilinx, Inc. | Timing annotation accuracy through the use of static timing analysis tools |
US7788625B1 (en) * | 2005-04-14 | 2010-08-31 | Xilinx, Inc. | Method and apparatus for precharacterizing systems for use in system level design of integrated circuits |
US7840925B1 (en) | 2008-03-13 | 2010-11-23 | Xilinx, Inc. | Source specific timing checks on synchronous elements using a static timing analysis engine |
US8813004B1 (en) | 2012-11-21 | 2014-08-19 | Cadence Design Systems, Inc. | Analog fault visualization system and method for circuit designs |
US8863050B1 (en) | 2013-03-15 | 2014-10-14 | Cadence Design Systems, Inc. | Efficient single-run method to determine analog fault coverage versus bridge resistance |
US8875077B1 (en) | 2014-02-10 | 2014-10-28 | Cadence Design Systems, Inc. | Fault sensitivity analysis-based cell-aware automated test pattern generation flow |
US8996348B1 (en) | 2012-11-21 | 2015-03-31 | Cadence Design Systems, Inc. | System and method for fault sensitivity analysis of digitally-calibrated-circuit designs |
US9026963B1 (en) * | 2012-11-21 | 2015-05-05 | Cadence Design Systems, Inc. | System and method for fault sensitivity analysis of mixed-signal integrated circuit designs |
US9589096B1 (en) * | 2015-05-19 | 2017-03-07 | Cadence Design Systems, Inc. | Method and apparatus for integrating spice-based timing using sign-off path-based analysis |
WO2024118329A1 (en) * | 2022-12-01 | 2024-06-06 | Synopsys, Inc. | Event-driven tracing in static timing analysis of digital circuit designs |
Citations (7)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US4924430A (en) * | 1988-01-28 | 1990-05-08 | Teradyne, Inc. | Static timing analysis of semiconductor digital circuits |
US5475607A (en) * | 1994-04-12 | 1995-12-12 | International Business Machines Corporation | Method of target generation for multilevel hierarchical circuit designs |
US5812561A (en) * | 1996-09-03 | 1998-09-22 | Motorola, Inc. | Scan based testing of an integrated circuit for compliance with timing specifications |
US6023568A (en) * | 1996-11-15 | 2000-02-08 | Synopsys, Inc. | Extracting accurate and efficient timing models of latch-based designs |
US6173435B1 (en) * | 1998-02-20 | 2001-01-09 | Lsi Logic Corporation | Internal clock handling in synthesis script |
US6185723B1 (en) | 1996-11-27 | 2001-02-06 | International Business Machines Corporation | Method for performing timing analysis of a clock-shaping circuit |
US6430731B1 (en) * | 1999-08-04 | 2002-08-06 | International Business Machines Corporation | Methods and apparatus for performing slew dependent signal bounding for signal timing analysis |
-
2001
- 2001-08-10 US US09/927,220 patent/US6611948B1/en not_active Expired - Lifetime
Patent Citations (7)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US4924430A (en) * | 1988-01-28 | 1990-05-08 | Teradyne, Inc. | Static timing analysis of semiconductor digital circuits |
US5475607A (en) * | 1994-04-12 | 1995-12-12 | International Business Machines Corporation | Method of target generation for multilevel hierarchical circuit designs |
US5812561A (en) * | 1996-09-03 | 1998-09-22 | Motorola, Inc. | Scan based testing of an integrated circuit for compliance with timing specifications |
US6023568A (en) * | 1996-11-15 | 2000-02-08 | Synopsys, Inc. | Extracting accurate and efficient timing models of latch-based designs |
US6185723B1 (en) | 1996-11-27 | 2001-02-06 | International Business Machines Corporation | Method for performing timing analysis of a clock-shaping circuit |
US6173435B1 (en) * | 1998-02-20 | 2001-01-09 | Lsi Logic Corporation | Internal clock handling in synthesis script |
US6430731B1 (en) * | 1999-08-04 | 2002-08-06 | International Business Machines Corporation | Methods and apparatus for performing slew dependent signal bounding for signal timing analysis |
Cited By (31)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US7062734B2 (en) * | 2002-04-05 | 2006-06-13 | Collins Jr Truman Wesley | Slack time analysis through latches on a circuit design |
US20030192020A1 (en) * | 2002-04-05 | 2003-10-09 | Mentor Graphics Corporation | Slack time analysis through latches on a circuit design |
US20030229483A1 (en) * | 2002-06-10 | 2003-12-11 | Mentor Graphics Corporation | Causality based event driven timing analysis engine |
US7239996B2 (en) | 2002-06-10 | 2007-07-03 | Boland Arthur J | Causality based event driven timing analysis engine |
US20040181761A1 (en) * | 2003-03-11 | 2004-09-16 | Renesas Technology Corp. | Circuit simulation for a circuit including transistors |
US20050251767A1 (en) * | 2004-05-07 | 2005-11-10 | Shah Gaurav R | Processing of circuit design data |
US20060059446A1 (en) * | 2004-09-14 | 2006-03-16 | Chen Thomas W | Sensitivity based statistical timing analysis |
US7788625B1 (en) * | 2005-04-14 | 2010-08-31 | Xilinx, Inc. | Method and apparatus for precharacterizing systems for use in system level design of integrated circuits |
US7421675B1 (en) | 2006-01-17 | 2008-09-02 | Xilinx, Inc. | Annotating timing information for a circuit design for increased timing accuracy |
US20070226668A1 (en) * | 2006-03-22 | 2007-09-27 | Synopsys, Inc. | Characterizing sequential cells using interdependent setup and hold times, and utilizing the sequential cell characterizations in static timing analysis |
US7774731B2 (en) | 2006-03-22 | 2010-08-10 | Synopsys, Inc. | Characterizing sequential cells using interdependent setup and hold times, and utilizing the sequential cell characterizations in static timing analysis |
US7506293B2 (en) * | 2006-03-22 | 2009-03-17 | Synopsys, Inc. | Characterizing sequential cells using interdependent setup and hold times, and utilizing the sequential cell characterizations in static timing analysis |
US20080295053A1 (en) * | 2006-03-22 | 2008-11-27 | Synopsys, Inc. | Characterizing Sequential Cells Using Interdependent Setup And Hold Times, And Utilizing The Sequential Cell Characterizations In Static Timing Analysis |
US20070226667A1 (en) * | 2006-03-24 | 2007-09-27 | Chadwick Thomas B Jr | Static timing slacks analysis and modification |
US7451417B1 (en) | 2006-05-12 | 2008-11-11 | Xilinx, Inc. | Timing annotation accuracy through the use of static timing analysis tools |
US8336002B2 (en) * | 2006-05-15 | 2012-12-18 | Taiwan Semiconductor Manufacturing Company, Ltd. | IC design flow enhancement with CMP simulation |
US20070266356A1 (en) * | 2006-05-15 | 2007-11-15 | Taiwan Semiconductor Manufacturing Company, Ltd. | IC Design Flow Enhancement With CMP Simulation |
US7984404B2 (en) * | 2006-11-15 | 2011-07-19 | Postech Academy-Industry Foundation | Black box timing modeling method and computer system for latch-based subsystem |
US20080141201A1 (en) * | 2006-11-15 | 2008-06-12 | Postech Academy-Industry Foundation | Black box timing modeling method and computer system for latch-based subsystem |
US7904844B2 (en) | 2007-03-30 | 2011-03-08 | Taiwan Semiconductor Manufacturing Company, Ltd. | System, method, and computer program product for matching cell layout of an integrated circuit design |
US20080244482A1 (en) * | 2007-03-30 | 2008-10-02 | Taiwan Semiconductor Manufacturing Company, Ltd. | Integrated circuit design usage and sanity verification |
US20080244483A1 (en) * | 2007-03-30 | 2008-10-02 | Taiwan Semiconductor Manufacturing Company, Ltd. | Integrated circuit design usage and sanity verification |
US7788612B2 (en) | 2007-03-30 | 2010-08-31 | Taiwan Semiconductor Manufacturing Company, Ltd. | System, method, and computer program product for matching cell layout of an integrated circuit design |
US7840925B1 (en) | 2008-03-13 | 2010-11-23 | Xilinx, Inc. | Source specific timing checks on synchronous elements using a static timing analysis engine |
US8813004B1 (en) | 2012-11-21 | 2014-08-19 | Cadence Design Systems, Inc. | Analog fault visualization system and method for circuit designs |
US8996348B1 (en) | 2012-11-21 | 2015-03-31 | Cadence Design Systems, Inc. | System and method for fault sensitivity analysis of digitally-calibrated-circuit designs |
US9026963B1 (en) * | 2012-11-21 | 2015-05-05 | Cadence Design Systems, Inc. | System and method for fault sensitivity analysis of mixed-signal integrated circuit designs |
US8863050B1 (en) | 2013-03-15 | 2014-10-14 | Cadence Design Systems, Inc. | Efficient single-run method to determine analog fault coverage versus bridge resistance |
US8875077B1 (en) | 2014-02-10 | 2014-10-28 | Cadence Design Systems, Inc. | Fault sensitivity analysis-based cell-aware automated test pattern generation flow |
US9589096B1 (en) * | 2015-05-19 | 2017-03-07 | Cadence Design Systems, Inc. | Method and apparatus for integrating spice-based timing using sign-off path-based analysis |
WO2024118329A1 (en) * | 2022-12-01 | 2024-06-06 | Synopsys, Inc. | Event-driven tracing in static timing analysis of digital circuit designs |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
US6611948B1 (en) | Modeling circuit environmental sensitivity of a minimal level sensitive timing abstraction model | |
US6604227B1 (en) | Minimal level sensitive timing abstraction model capable of being used in general static timing analysis tools | |
US6996515B1 (en) | Enabling verification of a minimal level sensitive timing abstraction model | |
US7117466B2 (en) | System and method for correlated process pessimism removal for static timing analysis | |
US7383522B2 (en) | Crosstalk-aware timing analysis | |
US8205181B1 (en) | Victim net crosstalk reduction | |
US6615395B1 (en) | Method for handling coupling effects in static timing analysis | |
US6014510A (en) | Method for performing timing analysis of a clock circuit | |
US20090288050A1 (en) | Statistical delay and noise calculation considering cell and interconnect variations | |
US5946475A (en) | Method for performing transistor-level static timing analysis of a logic circuit | |
US6278964B1 (en) | Hot carrier effect simulation for integrated circuits | |
US20070276645A1 (en) | Power modelling in circuit designs | |
US6185723B1 (en) | Method for performing timing analysis of a clock-shaping circuit | |
US6581197B1 (en) | Minimal level sensitive timing representative of a circuit path | |
US6609233B1 (en) | Load sensitivity modeling in a minimal level sensitive timing abstraction model | |
US7251794B2 (en) | Simulation testing of digital logic circuit designs | |
US20080288904A1 (en) | Method for modeling and verifying timing exceptions | |
US20150370955A1 (en) | Method for adjusting a timing derate for static timing analysis | |
US7188327B2 (en) | Method and system for logic-level circuit modeling | |
US6718523B2 (en) | Reduced pessimism clock gating tests for a timing analysis tool | |
US6910194B2 (en) | Systems and methods for timing a linear data path element during signal-timing verification of an integrated circuit design | |
US7885801B2 (en) | Modeling asynchronous behavior from primary inputs and latches | |
US11593543B2 (en) | Glitch power analysis with register transfer level vectors | |
US7325210B2 (en) | Hybrid linear wire model approach to tuning transistor widths of circuits with RC interconnect | |
US20040015338A1 (en) | Method and apparatus for automated signal integrity checking |
Legal Events
Date | Code | Title | Description |
---|---|---|---|
AS | Assignment |
Owner name: HEWLETT-PACKARD COMPANY, COLORADO Free format text: ASSIGNMENT OF ASSIGNORS INTEREST;ASSIGNORS:TYLER, SEAN;FOLTIN, MARTIN;FOUTZ, BRIAN;REEL/FRAME:012445/0860;SIGNING DATES FROM 20010717 TO 20010803 |
|
AS | Assignment |
Owner name: HEWLETT-PACKARD DEVELOPMENT COMPANY, L.P., TEXAS Free format text: ASSIGNMENT OF ASSIGNORS INTEREST;ASSIGNOR:HEWLETT-PACKARD COMPANY;REEL/FRAME:014142/0757 Effective date: 20030605 |
|
STCF | Information on status: patent grant |
Free format text: PATENTED CASE |
|
FPAY | Fee payment |
Year of fee payment: 4 |
|
FPAY | Fee payment |
Year of fee payment: 8 |
|
AS | Assignment |
Owner name: SAMSUNG ELECTRONICS CO., LTD., KOREA, REPUBLIC OF Free format text: ASSIGNMENT OF ASSIGNORS INTEREST;ASSIGNORS:HEWLETT-PACKARD DEVELOPMENT COMPANY, L.P.;HEWLETT-PACKARD COMPANY;REEL/FRAME:026198/0139 Effective date: 20101019 |
|
FPAY | Fee payment |
Year of fee payment: 12 |