Abstract
Introduction
As digital circuits become larger and faster, better analysis tools are required. It means that logic simulators must be able to handle bigger circuitry in a more accurate way. Simulating large circuits is aided by the evolution of computer systems capabilities, and accuracy is improved by providing more realistic delay models.
Currently, there exist accurate delay models for CMOS digital circuits which take account of most modem issues [ l , 2 , 3, 41: low voltage operation, sub-micron and deep sub-micron devices, transition waveforms, etc. Besides these effects, there are also dynamic situations which should be handled by the delay model. The most important dynamic effects are the so-called input collisions [ 5 ] : the gate's behavior when two or more input transitions happen close in time may be quite different from the response to an isolate input transition. Of all these input collisions, there is a special interest in the glitch collisions, which are those that might cause an output glitch. Being able to handle these glitch collisions is important since they are more and more likely to happen in current fast circuits, and it will help us to determine race conditions and truly power conThis work has been sponsored in part by the MCYT under Project TIC sumption due to glitches [6, 7] . This is also strongly related to the modeling of the inertial efSect [8], which determines when a glitch is filtered, and to the triggering of metastable behavior in latches [9, 10, 11, 121. Other authors have deal with the problem of glitches, either partially or not very accurately [5,6, 7, 131. In [14, 15, 16 , 171 a new model denominated Inertial and Degradation Delay Model (IDDM) has been introduced. This model combines the degradation effect of glitches with a new algorithm to handle the inertial effect. When trying to incorporate this model in the current logictiming simulators, as VHDL standard simulator or VER-ILOG, there are many problems difficult to solve since the new proposed approach dealing with degradation and inertial effects significantly affects the simulation algorithm itself. Therefore it is necessary to build a new logic-timing simulation tools based on the new algorithm to include the IDDM.
In this paper we present a new logic-timing simulator called HALOTIS including the IDDM. The work is organized as follows. In the next section we resume the IDDM. In the third section we describe the new simulation algorithm implemented in HALOTIS. As it will be shown, the most interesting aspects of HALOTIS is the novel dealing of stimuli in signals and the simulation algorithm. Results of simulation are presented in fourth section, showing a good agreement with electrical simulation, and CPU time very similar to those from other logic simulators. Lately, we present the most important conclusions of the work.
The IDDM model
Typical models for logic simulation only consider the inertial effect to deal with very narrow pulses. These models show a discontinuous behavior for very similar input conditions. This discontinuity is due to the fact that depending on its width, an input pulse may be in a normal propagation or a filtering (non-propagation) region. However, the change in the behavior of a true gate is not abrupt, rather continuous and gradual. In fact, two limit cases appear in real behavior: one for wide pulses that are propagated normally and another for very narrow pulses that are eliminated, but there is a pulse-width range between them in which pulses are neither eliminated nor propagated normally. Inside this range, the output pulse width is smaller than the corresponding input pulse width. In such a case, the pulse is considered to be degraded.
We showed in [15, 16, 17] that the delay decreases exponentially as pulses are shortened. Full degradation effect insights were studied for the case of CMOS gates and a delay model that takes into account the exponential behavior of the degradation effect was also presented. The main results of this model can be summarized as follows: only two parameters for each type of transition, r and T o , are needed to model the degradation effect, resulting in the following formula:
where t p O is the normal propagation delay, that can be calculated using a conventional delay model [ 1, 21, T is the time elapsed since the last output transition in the gate's output took place, which measures the intemal state of the gate, and r and T o are the degradation parameters which depend on the output load ( CL), the supply voltage ( V p D ) , the input transition time ( rin ) and the position of the input that is changing state ( i ). It has been obtained in [ 151 that this dependence can be expressed as:
where "x" stands for "r" or "f' depending on the sense of the output transition (rise or fall respectively).
Glitch degradation should be combined with inertial effect because, after sucesive degradations, a runt pulse will be eliminated. In [ 141 we have demostrated that the conventional model for inertial effect, defined as an inertial delay, may produce wrong results in a logic simulation. This can be observed in Figure 1 and, as consequence, the accuracy of the simulation decreases. In this work we propose a new treatment for the inertial effect, that together with the DDM model results in the IDDM model: Inertial and Degradation Delay Model.
The basic difference between current models for the inertial effect and the proposed model, lies in the choice of the exact place where pulses are filtered. In classical models, one pulse is rejected at the output of a gate if when propagating through the gate, it does not reach the middle point of the logic swing, meaning that the pulse does not exist for any gate's input connected to this output signal.
However, in our proposal, any output pulse is taken into account, even if it does not reach the middle point of the logic swing. At the inputs of the gates connected to this output, it is decided if this pulse is able to produce a transition in those gates or not. In this way is possible that a small pulse, can be propagated through one or more gates, while cannot be propagated through other different gates connected to the same signal.
With this idea, in [I41 it is provided the model with a new parameter V , that is the voltage threshold associated to the gate input. A pulse in input is only propagated if it crosses the V, value.
It is important to notice that, in order to implement this model in a logic-timing simulator, it is necessary to handle signals with both timing and voltage parameters. For this reason it is not possible to include this model in current logic simulation tools. We have developed a simulator adapted to IDDM which contains a new simulation algorithm as shows next section.
HALOTIS Simulator
As it was previously mentioned, we have developed a new logic timing simulator named HALOTIS. Figure 2 shows the class diagram of HALOTIS, where the relations between the implemented data structures can be seen. The main characteristics of this simulator are the new way to deal with stimuli and a novel simulation algorithm. 
Dealing with stimulis.
To improve simulation accuracy, we distinguish between "transition" and "event". A transition is a signal changing from "0" to "1" or "1" to "0". They are approximated by a linear curve and determined by the rise or fall time (T~) and the instant when the transition begins (to). As gate inputs may have individual input thresholds (V,), a single transition may trigger a gate activation at different voltages, which means different times for a signal that drivers various gate's inputs (Figure 3) . Each time a transition crosses an input threshold, an event is generated. The simulation is performed in terms of events, taking account of individual input thresholds.
Both the transitions and the events are stored in different data structures. The transitions use a list-type structure, storing timing parameters T~ and to where x indicates rise or fall transition type. The events a use queue-type structure, storing only the time instant (E) when the event takes place. Every event is associated to a gate input that is included in the data structure that holds the circuit netlist, and also to the transition that caused the event
Simulation Algorithm
In Figure 4 , it can be seen the basic steps of the proposed simulation algorithm. Every step performs the tasks Figure 4 . Simulation algorithm that are described below. The task of the first step is to get the first event from the event queue, and get all associated data from the class relations. These data are the gate and the gate input where event occurs and the transition that produces it.
In the second step, the output transition is calculated using the DDM directly.
When the output transition is calculated and generated, the algorithm enters a loop where two tasks must be performed. First, it must generate all events associated to this transition and, second, it must evaluate the presence of inertial effect in every gate input. This process begins finding out the associated gate input to the current transition through the relations between the transition class and gate input class. For each gate input, the Ej event is calculated which will be the j-th event associated to this gate input.
Figure 5. 4x4 Multiplier circuit
This event is compared with the previous event in this same input (Ej.,). If the new event takes place after the previous one, it is inserted in the event queue, otherwise, the previous event is removed from the queue.
Simulation Results
Figure S shows a 4x4 bit multiplier circuit, whose simulation results will serve to verify HALOTIS. The circuit has been designed in a 0.6pm CMOS technology. It is observed that HALOTIS-DDM and HSPICE results are very similar, while HALOTIS-CDM results shows much more output transitions than the others. This is due to the exclusion of degradation effect, making the glitches generated in the circuit being propagated to the output. In both HSPICE and HALOTIS-DDM, these glitches are degradated and, finally, rejected from the output. Figure 7 shows the simulation results of the 0x0, FxF, 0x0, FxF, Ox0 multiplication sequence. From the point of A very interesting aspect of the results are concerning the switching activity. Table 1 includes the measurement of the switching activity for HALOTIS-DDM and HALOTIS-CDM. It is very significative that the use of conventional delay models can produce an overestimation in switching activity up to the 40%.
On the other hand, Table 2 includes the CPU times for different kinds of simulation. As expected, HALOTIS is between 2 or 3 orders of magnitude faster than HSPICE.
Another interesting result is that HALOTIS-DDM is faster than HALOTIS-CDM due to the reduced switching activity of the former. Table 2 . CPU time in seconds for simulations.
HALOTIS-HALOTIS-DDM CDM
OxO,7x7,5xA, Ex6. FxF 0x0, FxF, 0x0, FxF, _.. 
Conclusions
Because of the features of Inertial and Degradation Delay Model (IDDM) for CMOS gates, their inclusion in current logic-timing simulators is a very complex task. For this reason, we have developed HALOTIS, a new timinglogic simulation tool. The most relevant aspects of HALO-TIS are the novel way to deal with of stimuli and the simulation algorithm, able to include the IDDM. Thus, HALOTIS can provide high accuracy simulation results, very similar to those provided by electrical simulators as HSPICE, reducing up to three orders of magnitude the CPU simulation time. When comparing to conventionals eventdriven techniques, the results are more accurate when considering the propagation and degradation of glitches and narrow pulses, even spending less simulation time, since HALOTIS contemplates a reduction in the switching activity due to the inclusion of the inertial and degradation effects.
