# Department of Computer Science # Faulty Behavior of Asynchronous Storage Elements Waleed K. Al-Assadi, Ding Lu, Anura P. Jayasumana, Yashwant K. Malaiya, and Carol Q. Tong Technical Report CS-93-117 September 6, 1993 # Colorado State University # Faulty Behavior of Asynchronous Storage Elements\* Waleed K. Al-Assadi, Ding Lu Anura P. Jayasumana, Yashwant K Malaiya †, and Carol Q. Tong Department of Electrical Engineering † Computer Science Department Colorado State University Fort Collins, CO 80523 #### Abstract It is often assumed that the faults in storage elements (SEs) can be modeled as output/input stuck-at-faults of the element. They are implicitly considered equivalent to the stuck-at faults in the combinational logic surrounding the SE cells. A more accurate higher level fault model for elementary SEs used in asynchronous circuits \_\_\_\_\_\_\_ is presented. This model offers better representation of the physical failures. It is shown that the stuck-at model may be adequate if only modest fault coverage is desired. The enhanced model includes some common fault behaviors of SEs that are not covered by the the stuck-at model. These include data-feed-through behaviors that cause the SE to be combinational. Fault models for complex SE cells can be obtained without a significant loss of information about the structure of the circuit. <sup>\*</sup>This work was supported partly by a SDIO/IST funded project monitored by ONR. ### 1 Introduction Exactional fault modeling is an effective approach to handle the complexities of large digital circuits. A functional fault model hides the complex fault behavior and presents a way of considerably simplifying test generation [1], [2]. Higher level fault models are easier to use because they represent the fault behavior independent of detailed lower level description. However it has been shown in some situations that a simple functional model may not adequately represent a significant fraction of failures. When this is the case, tests based on such a model may not be significantly better than random testing. If the fault model is adequate, a functional test set will test for most faults, while at the same time considerably reducing the test generation effort. Afault model can be termed adequate if it explicitly covers (i.e. coverage is guaranteed for) a major fraction, say x%, of all likely faults [2]. The number x cannot be obtained by using any fundamental considerations, but would be based on a reasonable convention. The faults not explicitly covered may or may not be tested if the test vectors are obtained using a fault model. Thus a fault model with lowexplicit coverage is likely to be inadequate. Agood strategy is to obtain a functional fault model for logic blocks derived from the the physical structure of the circuit. This requires that accurate fault models for primitive blocks, such as elementary storage elements (SEs) be considered. Although test considerations at the low level can be computationally complex, an accurate fault model for complex logic blocks inferred from the physical structure of the circuit can reduce the test generation and fault simulation efforts significantly. The elementary SEs are the basic primitives in complex logic blocks like registers, finite-state machines, and static memory blocks. This paper examines the major transistor-level faults for two elementary SEs used basically in asynchronous circuits. The behavior of each cell under the above faults is analyzed to evaluate possible functional fault models. Results for elementary SE cells are extended to characterize complex SE cells. In section 2, the minimal stuck-at model and the proposed enhanced model are described. SE cells are examined in section 3 for all possible transistor-level faults to seek a fault model with high fault coverage. # 2 Fault Modeling of Elementary SE Cells The niminal (stuck-at) fault nodel assumes that internal faults in the SEs can be nodeled as stuck-at-0/1 at the inputs or the outputs of the SEs. We examine below the effectiveness of the niminal fault nodel in representing physical failures. The results reveal the need for a more accurate fault nodel to better represent the physical failures at the transistor level of an elementary SE To examine a SEccell, in general, an input sequence is required rather than a single input vector. Let $T=\{t_1,\ldots,t\}$ be the set of all possible input combinations and $R(s,t_i)$ be the response of the cell to the input vector $t_i$ applied to the cell when the cell is at state s. The behavior of each cell under all possible transistor faults is examined for all input combinations and previous states. Analtival red logic representation is used to better represent voltage levels that are not exactly logic 1 (hard 1) or logic 0 (hard 0) [3 ]. Here high level (H) corresponds to both 'hard 1' and 'soft 1', and low level (L) corresponds to both 'hard 0' and 'soft 0' [4]. Afault that causes the SE output to be L(H) for all $t_i \in T$ , regardless the state of the SE, can be nodeled as stuck-at-0/(1). Under some faults the output of the faulty cell cannot make a high to low(low to high) transition, and the corresponding behavior is represented by $H \to L$ (LM). Such faults generally appear as stuck-at-1(stuck-at-0). However, some faulty behaviors of the SE cell do not manifest as stuck-at-0/1. Such faults cause the SE cell to become dat a - f e e d - t h r o ugh as defined in [2]. **Definition 1:** Afaulty SE cell is said to be dat a-feed-through when its behavior becomes containational such that Rs, t i) = f(y) for each t $i \in \mathcal{T}$ , where y is the data part of t i. For example, for a NAND pair latch, y is a double element vector corresponding to A and B. Some recent papers address the detection of several physical failures in CMOS synchronous latch cells [2], [4-[7]. Acomprehensive faults model for such latches is presented in [2]. The proposed enhanced fault model is presented. It was observed that data-feed-through faults cause a race-ahead condition in sequential circuits, i.e. the circuit reaches a state one clock period too early [8]. In this paper, we investigate the enhanced fault model for SEs that are used in building asynchronous circuits. The enhanced model includes faults that cause data-feed-through and problem of non-retention of logic level behaviors as well as the stuck-at faults. Such faults can be detected by nonitoring logical levels. Hence they are termed logically testable. # 3 Detailed Examinations of the Elementary SE Cells In this section, a detailed examination of two different elementary asynchronous SEs is presented. Fach cell is examined for all possible transistor faults. Results obtained analytically based on a multivalued algebra have been verified by SPICE Agood functional fault model is sought such that the functional behavior of faulty SE cells can be adequately described. Both the minimal and the enhanced fault models are examined for the effectiveness in representing the functional faults. Because of the transistor sizing and technology used, '0' dominates if two nodes are bridged. All possible bridging faults between nodes in the same well are considered. We use (x, y) to indicate a bridging fault between nodes xand y. Bridging faults between internal nodes of different wells are not included because the probability of having such faults is very small. Analysis assumes that a bridging fault corresponds to a hard short. The analysis shows that many stuck-on and bridging faults change the conductance path between V $_{dd}$ and $V_{ss}$ nodes. This suggests that nonitoring the supply current $(I_{DIQ})$ , which can be many orders of magnitude higher in the presence of such faults, can be used for testing such faults. In the presence of stuck-open faults, a SEcell could turn from that ic to dynamic under some input vectors. This means that the logic value of the output of the cell is maintained due to the charge stored in the capacitance associated with the output node. This state may last only for a short time due to the leakage of the charge. However, at normal clock rates such faults can be detected only if they manifest as delay faults. Faulty behavior of two SE cells are summarized next. # 3.1 The NAND pair latch The cell is shown in Figure 1. Asingle-rail output is considered here and the output is observed at Q1. Similar but somewhat more complicated results for double-rail case can be obtained. In fault free cell, vector AB = 11 causes both Q1 and Q2 nodes to retain their previous logical values and the cell remains static, while vector AB = 00 is to be avoided because it causes race problem in the cell. However, only vectors $AB = \{1, 10\}$ make the cell in the transparent phase, i.e. can derive the cell to a known logic values. Figure 1: The NAND-pair cell Table 1 shows the faulty behavior of the cell for stuck-open/on faults. The results show that some of these faults cause enhancement in the supply current (I $D_{0}$ ) because a direct path between $V_{dd}$ and $V_{ss}$ under some test vectors is established. Consider stuck-open fault in transistors n1 or n2 or both. When vector AB=01 is applied, a direct path between Vand $V_{ss}$ is formed. The same observation is applied for stuck-open fault in transistor n3 or n4 or in both when vector AB = 10 is applied. The results show that only two stuck-open faults showfault free behavior. Consider stuck-open fault in p3. This fault causes the cell to exhibit dynamic behavior when vector AB = 11 is applied and the cell is initialized to logic 1. Due to this fault, node Q1 cannot keep its logical value of 1 indefinitely since the only vay to refresh node Q1 if this vector applied is through transistor p3. Stuck-open fault in transistor p2 causes similar change when the same vector applied and the cell initialized to logic 0. These two fault are considered undetectable if tests are applied at normal rate. However, if tests are applied much slower than normal rate, which is unusual in testing, then when vector AB = 11 is applied, then the node Q1 capacitance can discharge to bring node Q1 to logic 0. This method of detection may also be unreliable because the voltage on floating nodes may settle down at an inderminate value rather than at logic 0. Hence dd | Lable I: | Haulty behavior of | the NAND par | r latch under | stuck-open/on faults | |----------|--------------------|--------------|---------------|----------------------| | | | | | | | Transistor | Stuck-open | | | Stuck- on | | | |------------|----------------|----------------|-------------------|----------------|----------------|---------------------| | | Q1 | Q2 | Model | Q1 | Q2 | Model | | p1 | H≁L | L≁H | stuck-at | $\overline{A}$ | H≁L | data-feed-through | | p2 | fault- fred | fault- fred | | $\overline{A}$ | H≠L | data- feed- through | | р3 | fault- fred | fault- fred | | H≁L | $\overline{B}$ | s tuck- at | | p4 | L≁H | H≁L | stuck-at | H≁L | $\overline{B}$ | s tuck- at | | n1 | $\overline{A}$ | H≁L | data-feed-through | $\overline{B}$ | B | data- feed- through | | n2 | $\overline{A}$ | H≁L | data-feed-through | H≁L | L≁H | s tuck- at | | n3 | H≁L | $\overline{B}$ | stuck-at | $\overline{A}$ | A | data- feed- through | | n4 | H≁L | $\overline{B}$ | stuck- at | L≁H | H≁L | s tuck- at | †: The cell turns into dynamic under vector AB = 11 Testing the cell for bridging faults reveal the importance of the multivalued algebra. The results are given in Table 2. The indeterminate value is observed when both nodes Q1 and Q2 are shorted. This fault can cause charge sharing if vector AB=11 is applied. Such a behavior can only be detected by observing the supply current I BQ. Bridging fault between nodes 7 and 6 shows stuck-at behavior depending on the initial conditions. Therefore this fault is modeled as stuck-at regardless of the logical values at nodes Q1 and Q2. Similarly bridging fault between input nodes A and B has consequences assuming 0 dominance. If input vector AB=01 is the initialization vector, then Q1 is always at logic high B and A and A and A are vector A and A are vector A and A and A are vector A and A and A are vector A and A and A are vector A and A are vector A and A and A are vector A and A and A are vector A and A and A are vector A and A are vector A and A are vector A and A are vector A and A are vector A and A and A are vector A and A are vector A and A and A are vector ve Tables 1 and 2 shows that only 18 faults out of 38 faults (i.e. 47%) are modeled as stuck-at and 17 faults (i.e. 45%) turn the cell combinational. Therefore the enhanced fault model would cover 92% of the logically testable faults. Testing this latch using robust tests is not trivial, because test patterns depend on both combination of primary inputs (Aand B) and also on the state variables, which are not directly controllable and dependent on change of primary inputs. Consider stuck-open fault in transistor p4. In general to test for a stuck-open fault, a two-pattern test, the initialization pattern and the test pattern are required. To test for this fault, node Q1 has to be initialized to logic 0 by applying AQ2 = 11. Q2 however is a function of A and Q1 and can be driven to 1 by raking either B = 0 or Q1=0. For this fault, only possible way is to nake B = 0 always. Therefore to ensure the robustly of the test, a 3-pattern test; $AB = \{0, 11, 01\}$ instead of a two-pattern test is required. This shows the the test is not trivial robust because we have to take into consideration the state variables or outputs of the latch into consideration. Table 2: Faulty behavior of the NAND pair latch under possible bridging faults | Bridging fault | Logical behavior | | Model | |---------------------------------------------------------------------------------|-------------------------------|-------------------------------|-------------------| | | Q1 | Q2 | | | (1,5) | H | $\overline{B}$ | | | (1,5) (1,3), (6,0), (4,7), | H≁L | L≁H | | | $ \begin{array}{c c} (2,7) \\ (6,7), (2,3) \\ (7,0), (1,2), (5,6) \end{array} $ | H≁L | $\overline{B}$ | s tuck- at | | (6,7),(2,3) | | | | | (7,0), (1,2), (5,6) | L≁H | H≁L | | | (2,5) | A | $\overline{A} + \overline{B}$ | | | (3,0), (3,6) | $\overline{A}$ | H≁L | | | (2,4),(3,7) | $\overline{A}$ | A | data-feed-through | | (5,7) | $\overline{A}$ | $A+\overline{B}$ | | | (1,4) | $\overline{A}$ | H | | | (4,6), (3,5), (2,6) | В | $\overline{B}$ | | | (3,4) | $\overline{A} + \overline{B}$ | В | | | (4,5) | Indeter minate | Indeterminate | parametric | #### 3.2 The C-element The C-element shown in Figure 2 is the storage element used in self-timed asynchronous circuits. Such circuits like a pipeline interconnection circuit that controls data transfers between computation blocks, which is basically a half or full handshake circuit [9 ], [10]. This is a dynamic cell because there is no feedback in the cell and the output is observed at node C. Its logic function can be described by the Boolean equation C = AB + AC '+BC', where C is the present state and C ' is the previous state. Hence only two vectors $AB = \{1,00\}$ make the cell in the transparent phase, while vectors $AB = \{1,10\}$ make the cell latch its previous value. Figure 2: The C-element The cell is examined to verify the effectiveness of the stuck-at model. It was observed that this model can not cover all the possible physical defects within the element. Actually, most of the defects within the cell like transistor stuck-on, transistor stuck-open and bridging between internal nodes have some other faulty behavior which can not be interpreted by the stuck-at fault model. The results given in Table 3 show that some faults cause the cell to exhibit a behavior change in the latch phase, while still functioning properly in the transparent phase. Condi - $tional\ no-retention$ of $logic\ 1/0\ (CNR-1/0)$ behaviors are observed. The definition is given below [2]: **Defition 2:** Consider a SE cell in the state Q = 1 in the transparent phase, the cell exhibits conditional non-retention (CNR-1) behavior if the cell fails the latch logic 1 and instead Q turns to logic 0, i.e. $R(1, t_{-i}) = 0$ , where $t_{-i}$ is an input vector such that $t_{-i} \in A$ atch phase vectors. (CNR-0) is defined similarly. As an example, consider stuck-on fault in transistor pl. If the cell is at logic 1 and vector AB=10 is applied, then the cell is unable to latchlogic 1 as in the fault free case, but this vector will turn the cell to logic 0. therefore the behavior is modeled as CNR-1. The tables shows also that the cell become combinational under several faults, and therefore they are modeled as data-feed-through. Some faults cause the cell to be parametric, where the logical value of the cell is indeterminate and logical testing cannot be used. Such faults can only be detected by monitoring the supply current $(I m_{\overline{Q}})$ , which in the presence of the fault is many orders higher than the fault free current. This enhancement in I $m_{\overline{Q}}$ is due to the forming of conducting paths between V and $V_{ss}$ under some faults. Table 3: Faulty behavior of the C-element | | Fault | logical Behavior | Model | |-------------|-------------------|--------------------|-----------------------------| | Bridging: | (3,4),(1,7),(5,0) | stuck-at-1 | | | Bridging: | (2,6),(7,0) | stuck-at-0 | | | Stuck-open: | p1, p2, n3 | | | | Bridging: | (1,2),(1,3),(2,4) | H≁L | $\operatorname{stuc}$ k- at | | Stuck-open: | p3, n1, n2 | L≁H | | | Bridging: | (2,0),(3,0),(3,6) | | | | Stuck-on: | p1, p2 | | | | Bridging: | (1,4),(4,5) | CNR-1 | | | Stuck-on: | n1, n2 | | CNR | | Bridging: | (5,6),(6,0) | CNR-0 | | | Bridging: | (2,3) | C = AB | | | | | | | | Bridging: | (2,5) | $C = \overline{A}$ | | | | | | | | Bridging: | (3,5) | $C = \overline{B}$ | data-feed-through | | Bridging: | (2,7) | C = A | | | Bridging: | (3,7) | C = B | | | Stuck-on: | p3, n3 | indeter minate | parametric | | Bridging: | (5,7) | | | Table 3 shows that among 33 possible defects within the C-element, only 17 (i.e. 52%) can be nodeled by the stuck-at fault model, while the enhanced model covers 13 faults more (i.e. 91%). This means that 100% of the logically testable faults are covered by the enhanced fault model, while only 3 faults can be tested by monitoring the supply current I ## 4 Conclusion The effectiveness of the minimal fault model for two basic SFs used in asynchronous circuits is evaluated. The enhanced fault model for the two cells is proposed, which provides higher explicit fault coverage compared to the minimal fault model. Higher level functional fault models for complex circuits using the two cells considered in this paper as primitives can be inferred from the proposed model, with higher fault coverage. This allows the testing of lowlevel failures that cannot be characterized as stuck-at-0/1 at the functional level without the need to consider the physical implementation of the circuit. Thus the advantages of functional testing is retained with a higher coverage of lowlevel failures. Test generation could be based on the change in the state-transition graph of the complex circuit due to such faults. This can be used to enhance the existing testing techniques for self-timed and asynchronous sequential circuits based on the changes in state transition graph which at present only consider stuck-at faults only. # References - W.K. A-Assadi, Y. K. Malaiya and A.P. Jayasurana, "Use of Storage Elements as Primitives for Modeling Faults in Sequential Circuits," Proc. 6th. Int. Conf. on VLSI Design, pp. 118-123, January 1993. - [2] W.K. A-Assadi, Y. K. Malaiya and A.P. Jayasumana, "Faulty Behavior of Storage Elements and its Effects on Sequential Circuits," To Appear in IEEE Transaction on VLSI Systems. - [3] P. Banerjee and J. A. Abraham, "AMultivalued Algebra for Modeling Physical Failures in MOS VISI Circuits," *IEEE Transaction on Computer-Aided Design*, vol. CAD-4, no. 3, pp. 312-321, July 1985. - [4] M. K. Reddy and S. M. Reddy, "Detecting FET Stuck-Open Faults in CMOS Latches and Flipflops," *IEEE Design and Test*, pp. 17-26, October 1986. - [5] D. L. Liu and E. J. McCluskey, "ACMOS Cell Library Design for Testability," VLSI Systems Design, pp. 58-65, May 4, 1987. - [6] R Anglada and R Rubio, "Functional Fault Models for Sequential Circuits," Research Report DEE-3, Electronic Engineering Department, Polytechnical University of Catalunya, Barcelona 1987. - [7] K. J. Lee and M. A Breuer, "A Universal Test Sequence or CMOS Scan Registers," Proc. IEEE CustomIntegrated Circuits Conf. pp. 28.5.1-28.5.4., 1990. - [8] W.K. A-Assadi, Y. K. Malaiya, and A.P. Jayasumana, "Detection of Feed-Through Faults in CMOS Storage Elements," Proc. NASA Symposium on VLSI Design, pp. 7.2.1-7.2.5, October 1992. - [9] T. H-Y. Meng, R. W.Brodersen and D. G. Messerschrift, "Automatic synthesis of Asynchronous Circuits from Hgh-Level Specifications", IEEE Trans. Computer-Aided Design, vol.8, pp. 1185-1205, 1989. - [10] P. A Beerel and T. H-Y. Meng, "Semi-Modularity and Self-Diagnostic Asynchronous Control Circuits", Advanced Research in VLSI (MITpress 1991), pp. 118-132.