VHDL Testability Analysis based on Fault Clustering and Implicit Fault Injection

F.S.Bietti  F.Ferrandi  F.Fummi  D.Sciuto
Dip. di Elettronica e Informazione
Politecnico di Milano, 20133 Milano, ITALY

Abstract
Testability analysis of VHDL sequential models is the main topic of this paper. We investigate the possibility to obtain information about the testability of a sequential VHDL description before its actual synthesis. The analysis is based on an implicit fault model that injects faults into a BDD based description extracted from the VHDL representation. Such an injection is related to the original VHDL representation thus allowing the identification of potential testability problems before RTL and logic synthesis. Fault injection is performed efficiently by exploiting the concept of fault clustering, that is, the possibility of grouping faults and analyzing them concurrently. The proposed methodology is applied to benchmarks for efficiency evaluation and to a real VHDL description.

1 Introduction

Algorithms concerning the testing field are based on models which abstract the behavior of physical defects. Such models include fault models, error models or failure models depending on the abstraction level to which they refer [1]. The use of models sensibly reduces the complexity of all testing algorithms since it decreases the number of different entities which must be manipulated. For instance, some defects can correspond to few faults which may or may not produce a single error. Functional fault models belong to this class and they have been used for two main purposes:

- The identification of testability problems in order to avoid the RTL and logic synthesis of specifications which show testability problems independently of their actual synthesis [16, 15, 11].
- The generation of fault independent test patterns which allow the detection of the majority of gate level faults and which preserve this property even considering different implementations of the same circuit [4, 5, 12].

However, the complexity of testing problems remain high even restricting the attention to single fault or error. For instance, by adopting the well known single stuck-at fault model [1] or single transition fault model [5]. There is thus the need of using implicit techniques, based on binary decision diagrams (BDDs) [3], to analyze complex descriptions that cannot be explicitly managed by using state transition tables or graphs [4, 5, 12, 15]. Moreover, hardware description languages (e.g., VHDL or Verilog) are widely used for the specification and automatic synthesis of a device, thus a useful testability measure must be related to a HDL description of a device. We oriented this paper to the analysis of sequential VHDL descriptions.

This paper analyzes the problem of testability analysis by starting from the test pattern generation approach presented in [8]. Testability measure is based on the actual fault coverage obtained by generating test sequences based on a functional fault model that is related to gate-level (stuck-at) faults. The aim is the prediction of the actual stuck-at fault coverage before RTL and logic synthesis. For this purpose, fault clustering can be used to reduce the number of analyzed errors by discarding errors which have equivalent behaviors in order to identify a subset of the total number of modeled errors which ensures a prediction of the stuck-at fault coverage close to the estimation obtained by considering all errors. The proposed functional fault model improves the previous work [8] on the following aspects:

- Concurrent analysis of groups of faults (clustering) has been implemented to make the testability analysis more efficient.
- Some relations between functional faults and VHDL faults have been identified to improve the accuracy of the obtained testability measure.
- The set of analyzed functional faults has been oriented to the RTL and logic synthesis tools, since adopted synthesis algorithms sensibly impact on the testability of the generated circuits.

The rest of the paper is organized as follows. Section 2 presents the basic models adopted in this paper and in particular the translation algorithm which is able to convert a VHDL representation into the equivalent BDD based description. Section 3 is devoted to the description of the adopted functional fault model based on BDDs and of the identified relations between VHDL faults, functional faults and stuck-at faults. The last section presents some experimental results on the efficiency of faults clustering and some preliminary results on the effectiveness of the proposed functional fault model for the prediction of stuck-at fault coverage.

0-8186-8408-7/98 $10.00 © 1998 IEEE

237
2 Basic Models

This section introduces the basic concepts to describe the VHDL-level fault model used in this paper to implement the proposed testability estimator. The model is based on a BDD representation of the behavior of each device. Thus, we first introduce the BDD based description of an FSM, then the technique to extract the BDD representation from a VHDL description at the register-transfer (RT) level.

2.1 Basic Definitions

Let us restrict our attention to sequential circuits representing medium and large size controllers. Let a FSM $M$ be the 5-tuple

$$M = (X, Z, S, S^0, R)$$

where $X$ is the input alphabet, $Z$ is the output alphabet, $S$ is the finite set of states, $S^0$ is the reset state, and $R \subseteq S \times X \times S \times Z$ is the global relation. We have that the characteristic function $R(x, z, s, t) = 1$ if and only if, under input $x \in X$, the FSM makes a transition from present state $s \in S$ to next state $t \in S$ outputting $z \in Z$. We represent this characteristic function by using a BDD based description. A FSM can be represented by a state transition graph (STG), whose vertices are elements of $S$ and edges are labeled with pairs $(x, z) \in X \times Z$. Input symbols $X$ are coded by $I$ input variables $i_1, \ldots, i_f$ and output symbols $Z$ are coded by $O$ variables $o_1, \ldots, o_o$.

Let $M_f$ be the FSM representing the behavior of $M$ affected by fault $f$. The method for generating $M_f$ depends on the abstraction level of fault $f$ and it is described in the next section.

A test sequence for fault $f$ is a sequence of input vectors such that, when applied to machines $M$ and $M_f$ (both started in their reset states), produces two different output vectors for $M$ and $M_f$. By concurrently traversing both $M$ and $M_f$ starting from their reset states, it is possible to generate (if any) a test sequence.

2.2 VHDL to BDD Translation

We propose here to obtain the global relation of the analyzed circuit through direct translation of a VHDL source code. There are three main reasons advising the direct translation of VHDL into BDDs to perform testability analysis.

- Testability information becomes available before RTL synthesis. The designer can evaluate the testability problems concerning the specification of VHDL entities, before their RTL synthesis. It is fundamental to modify for testability a design from the early stages of its specification.
- VHDL synthesis tools infer some memory elements during RTL synthesis that are not concerned with the actual behavior. Such memory elements increase the number of states of the implemented controller and also the complexity of the corresponding BDD representation. For instance, let us consider the simple VHDL code reported in Figure 1, describing the behavior of a synchronous controller when it is in state p0. The output signals end_master, valid_pol and start_r are assigned into a synchronous process, thus they must be connected to flip-flops. Moreover, end_master is not assigned in the ELSE branch of the condition, thus it requires a default value to be synthesized. Consequently, the synthesis tool inserts a muxed-flip-flop onto such an output port. It is evident that the implemented FSM has higher number of states with respect to the specification, and most of them are equivalent. Thus, the global relation extracted from the implementation would have an unnecessarily high number of state variables.
- Unspecified transitions are not included in the global relation. During the extraction of the global relation of a sequential control from its implementation, even transitions outgoing from unspecified states are included. In fact, all combinations of input and present state variables are implicitly taken into account to identify the FSM's transitions. On the contrary, the global relation of a controller includes only specified transitions if it is directly constructed from a VHDL specification. A lower number of transitions usually implies a smaller BDD.

![Figure 1: VHDL Description of a Part of a Controller.](image-url)

The technique we propose to translate a VHDL description specifying a controller into the corresponding relation represented as a BDD starts by analyzing the VHDL architecture associated with the entity of the FSM. Two types of analysis are performed. First, a state identification is carried out. In fact, considering the execution flow of the sequential process, a signal or variable belongs to the state of the FSM when it is read before any write or initialization instruction. When the VHDL description considers both the FSM and the associated data-path also the data-path registers are considered as state variable in the global relation. After state identification, the global relation is computed. The style of the finite state machine considered presents a process with a conditional structure. Details about the translations of VHDL into BDDs can be found in [2].

3 Fault Model

The adopted functional fault model is based on the modification of the global relation $R(x, z, s, t)$ representing the functional description of the circuit, directly extracted from its VHDL description.
To reduce the number of modeled faults, only faults on essential primes are considered. This simplification extremely reduces the computation time for the reasons described in the next section. Therefore, the number $L_\delta$ of faults that will be considered is $L_\delta = k_x + p_e + 2n$.

The faulty global relation, $R_F$, is then determined based on the set of essential primes $p_e$ and on the previously described three classes of faults. The following three different strategies for fault insertion are applied in relation to the type of fault:

- **SA-1 faults on all literals of each essential prime in $p_e$**
  Let $ip(x_1, \ldots, x_t, s_1, \ldots, s_m) \in p_e$ be an essential prime, and $b_i : b_i = x_i | b_i = s_i$. 
  \[ \forall b_i : ip(x, s)_b \neq ip(x, s)_b' \] 
  (i.e., $ip(x, s)$ depends on $b_i$) then the faulty prime $ip_F(x, s) = ip(x, s)_b'$. 
  and the faulty relation $R_{f_r}(x, s) = R_{f}(x, s) - \bar{ip(x, s)} + ip_F(x, s)$ (i.e., the fault-free essential prime is replaced by the corresponding faulty prime).

- **SA-0 faults on one literal of each essential prime in $p_e$**
  Let $b_i : b_i = x_i | b_i = s_i$. 
  \[ \exists b_i : ip(x, s)_b \neq ip(x, s)_b' \] 
  and the faulty prime $ip_F(x, s) = ip(x, s)_b'$. 
  and the faulty relation $R_{f_r}(x, s) = R_{f}(x, s) - \bar{ip(x, s)} + ip_F(x, s)$.

- **SA-0 and SA-1 faults on all input variables**
  Let $b_i : b_i = x_i | b_i = s_i$. 
  \[ \forall b_i : R_{f}(x, s)_b \neq R_{f}(x, s)_b' \] 
  then the faulty relation $R_{f_r}(x, s) = R_{f}(x, s)_b'$ for SA-0 fault and $R_{f_r}(x, s) = R_{f}(x, s)_b'$ for SA-1 fault.

Finally, the global faulty relation, $R_F(x, z, s, t)$, is reconstructed by composing all computed faulty relation $R_{f_r}(x, s)$.

### 3.2 Functional Fault Clustering

Even if the proposed functional fault model deals with essential primes only, their explicit generation is a CPU intensive task for medium and large size controllers. Thus, a fast implicit method is necessary and we adopted the algorithm described in [7]. However, this approach becomes extremely long if the generation of all implicants would be necessary for the identification of essential primes. Fortunately, the use of zero-suppressed BDD (ZDD [10]) allows the implicit generation of essential primes without the enumeration of all implicants. Furthermore, the number of essential primes is usually small. Thus, after their implicit generation, essential primes can be explicitly enumerated by recursively visiting the ZDD graph. Moreover, to further speed up the process, a cluster of faulty primes can be extracted and inserted into the global relation in one step.

Fault clustering is possible by simply adding $f$ variables to the faulty global relation $(R_F(x, z, s, t, f))$.
the logic sharing of a typical multi-level implementation and produces a set of functional faults more related to stuck-at faults.

3.3.3 Don’t care functionalities

A fault must be activated to be detected and the fault effect must be propagated to a primary output. A justification sequence must exist allowing to reach the activation state of the fault. Faults which cannot be activated are untestable and they are also called \textit{sequentially-non-excitables} faults [6]. All faults which can be activated from unreachable states only belong to this group. The \textit{don't care} functionality of a circuit represents the set of behaviors which cannot be activated since they require to start from unreachable states. The gate-level description of a device must ideally not include logic implementing \textit{don’t care} functionalities only, since it is a waste. However, commercial VHDL synthesizers (Mentor and Synopsys) are able to identify unreachable states only if they are \textit{explicitly} enumerated (e.g., the states of a controller), but they are not able to identify unreachable states concerning \textit{implicit states}.

![Figure 4: VHDL Description with implicit and explicit states.](image)

For instance, let us consider the small part of VHDL code reported in Figure 4. Variable \texttt{state} represents the actual state of the FSM and it is explicitly enumerated. It can assume 24 different values labeled by names (e.g., \texttt{iteration}). On the contrary, variable \texttt{counter} is defined as an integer subset from 0 to \texttt{MAX-1} and it represents an implicit counter, that counts from 0 to \texttt{MAX-1} and returns to 0 when the reset signal (not shown in Figure 4) is asserted. After states coding, there are 8 unused state codes (32 - 24 = 8) corresponding to the \textit{don't care} part of the specification. Such states are recognized by the synthesizer and during RTL synthesis no logic is generated based on such states, that is, next-state and output functions are described at the RT level only for the explicitly enumerated states. For this reason, it is extremely likely that unused state codes are not necessary to detect faults and do not generate \textit{sequentially-non-excitables} faults. On the contrary, the behavior of the circuit concerning implicit states (as the \texttt{counter} of this example) if specified for all state values even if some states are actually unreachable. For instance, the RTL synthesis instantiates a counter, for the \texttt{counter} variable of this example, that...
is able to perform a transition from state MAX to state MAX even if the so specified VHDL description does not allow this transition. Thus, it is extremely likely that this description will produce sequentially non-oculating faults.

The adopted functional fault model considers the previously described situations by distinguishing between explicit and implicit states. The translation of VHDL to BDDs identifies also a set of explicit states and the set of unused state codes, thus partitioning present-state variables (s) into:

- explicit state variables, s_e,
- implicit state variables, s_i.

A functional fault is not considered if the corresponding faulty function R_F(x, z, s, t, f) differs from the fault-free function for transitions outgoing from explicit unused state codes only. This is equivalent to avoiding the consideration of stuck-at faults on gates which are not included into the synthesized gate-level description of the device. On the contrary, functional faults affecting transitions outgoing from unreachable implicit state variables (s_i) are considered since commercial RTL and logic synthesis tools are not able to identify unreachable implicit states. Untested faults activated from such states are likely included into the synthesized gate-level description thus decreasing the testability of such circuits. In conclusion, the proposed functional fault model is able to identify potentially untestable faults before the actual synthesis.

Table 2: Effectiveness of faults clustering.

<table>
<thead>
<tr>
<th>FF</th>
<th>CPU</th>
<th>BDD</th>
<th>FF</th>
<th>CPU</th>
<th>BDD</th>
<th>FF</th>
<th>CPU</th>
<th>BDD</th>
<th>FF</th>
<th>CPU</th>
<th>BDD</th>
<th>FF</th>
<th>CPU</th>
<th>BDD</th>
</tr>
</thead>
<tbody>
<tr>
<td>bbase</td>
<td>0.9</td>
<td>0.63</td>
<td>0.72</td>
<td>0.48</td>
<td>0.57</td>
<td>0.33</td>
<td>0.66</td>
<td>0.27</td>
<td>0.91</td>
<td>0.33</td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>cse</td>
<td>0.87</td>
<td>0.54</td>
<td>0.82</td>
<td>0.23</td>
<td>1.33</td>
<td>0.16</td>
<td>1.1</td>
<td>0.13</td>
<td>0.89</td>
<td>0.15</td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>dk14</td>
<td>0.24</td>
<td>0.21</td>
<td>0.47</td>
<td>0.18</td>
<td>0.54</td>
<td>0.15</td>
<td>0.5</td>
<td>0.12</td>
<td>0.54</td>
<td>0.14</td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>dk16</td>
<td>0.89</td>
<td>0.12</td>
<td>0.96</td>
<td>0.12</td>
<td>0.94</td>
<td>0.11</td>
<td>0.99</td>
<td>0.08</td>
<td>0.9</td>
<td>0.08</td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>dk27</td>
<td>0.63</td>
<td>0.54</td>
<td>0.74</td>
<td>0.12</td>
<td>0.75</td>
<td>0.12</td>
<td>0.84</td>
<td>0.15</td>
<td>0.89</td>
<td>0.18</td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>dk512</td>
<td>0.36</td>
<td>0.12</td>
<td>0.3</td>
<td>0.12</td>
<td>0.24</td>
<td>0.13</td>
<td>0.58</td>
<td>0.13</td>
<td>0.47</td>
<td>0.17</td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>ex1</td>
<td>1.23</td>
<td>0.54</td>
<td>1.01</td>
<td>0.44</td>
<td>0.43</td>
<td>0.31</td>
<td>0.55</td>
<td>0.3</td>
<td>0.57</td>
<td>0.25</td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>ex2</td>
<td>0.53</td>
<td>0.32</td>
<td>0.36</td>
<td>0.4</td>
<td>0.46</td>
<td>0.35</td>
<td>0.49</td>
<td>0.36</td>
<td>0.45</td>
<td>0.55</td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>ex5</td>
<td>0.98</td>
<td>1.82</td>
<td>0.87</td>
<td>1.33</td>
<td>1.02</td>
<td>1.49</td>
<td>0.82</td>
<td>1.47</td>
<td>0.82</td>
<td>1.57</td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>fmaster</td>
<td>0.44</td>
<td>0.16</td>
<td>0.28</td>
<td>0.11</td>
<td>0.36</td>
<td>0.1</td>
<td>0.42</td>
<td>0.08</td>
<td>0.39</td>
<td>0.08</td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>f_math</td>
<td>0.65</td>
<td>0.26</td>
<td>0.75</td>
<td>0.4</td>
<td>0.69</td>
<td>0.12</td>
<td>0.74</td>
<td>0.11</td>
<td>0.46</td>
<td>0.07</td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>f_sync</td>
<td>0.38</td>
<td>0.43</td>
<td>0.41</td>
<td>0.28</td>
<td>0.5</td>
<td>0.27</td>
<td>0.43</td>
<td>0.36</td>
<td>0.44</td>
<td>0.46</td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>opus</td>
<td>0.11</td>
<td>0.87</td>
<td>0.52</td>
<td>0.7</td>
<td>0.49</td>
<td>0.54</td>
<td>0.65</td>
<td>0.51</td>
<td>0.63</td>
<td>0.46</td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>planet</td>
<td>0.25</td>
<td>0.26</td>
<td>0.15</td>
<td>0.16</td>
<td>0.75</td>
<td>0.07</td>
<td>0.91</td>
<td>0.05</td>
<td>1.09</td>
<td>0.05</td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>pma</td>
<td>0.26</td>
<td>0.27</td>
<td>0.33</td>
<td>0.07</td>
<td>0.52</td>
<td>0.08</td>
<td>0.64</td>
<td>0.07</td>
<td>0.97</td>
<td>0.07</td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>s1</td>
<td>0.47</td>
<td>0.14</td>
<td>0.61</td>
<td>0.16</td>
<td>0.22</td>
<td>0.2</td>
<td>1.02</td>
<td>1.12</td>
<td>1.27</td>
<td>0.1</td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>s188</td>
<td>0.76</td>
<td>0.18</td>
<td>0.33</td>
<td>0.17</td>
<td>0.31</td>
<td>0.1</td>
<td>0.79</td>
<td>0.17</td>
<td>0.32</td>
<td>0.09</td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>s194</td>
<td>0.27</td>
<td>0.19</td>
<td>0.3</td>
<td>0.2</td>
<td>0.3</td>
<td>0.16</td>
<td>0.25</td>
<td>0.13</td>
<td>0.36</td>
<td>0.1</td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>s27</td>
<td>0.5</td>
<td>0.4</td>
<td>0.46</td>
<td>0.54</td>
<td>0.38</td>
<td>0.59</td>
<td>0.54</td>
<td>0.54</td>
<td>0.46</td>
<td>0.55</td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>s298</td>
<td>0.18</td>
<td>0.21</td>
<td>0.11</td>
<td>0.11</td>
<td>0.29</td>
<td>0.08</td>
<td>0.11</td>
<td>0.08</td>
<td>0.14</td>
<td>0.05</td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td>s10</td>
<td>0.24</td>
<td>0.29</td>
<td>0.87</td>
<td>0.11</td>
<td>0.86</td>
<td>0.09</td>
<td>1.21</td>
<td>0.08</td>
<td>1.31</td>
<td>0.08</td>
<td></td>
<td></td>
<td></td>
<td></td>
</tr>
</tbody>
</table>

Table 3: VHDL description examined

<table>
<thead>
<tr>
<th>name</th>
<th>VHDL Lines</th>
<th>#In</th>
<th>#Out</th>
<th>#F.P.</th>
<th>#Gates</th>
</tr>
</thead>
<tbody>
<tr>
<td>TX</td>
<td>335</td>
<td>10</td>
<td>16</td>
<td>210</td>
<td></td>
</tr>
</tbody>
</table>

The current implementation is composed of more than 120K code lines. Preliminary experiments have been carried out on academic controllers (MCNC benchmarks) and on industrial VHDL circuits.

First of all we investigated the impact of the fault clustering strategy on test pattern generation. Results are reported in Table 2. Two performance indices are reported for increasing cluster size (FV, added faulty variables): the total CPU time and total memory occupation (# BDD nodes). Such values are normalized to the application of the TPG algorithm to a cluster composed by an unique fault. The concurrent analysis of faults is an attractive strategy since it sensibly decreases the required CPU time up to more than 40% on average. Moreover, the total memory occupation decreases, since the same BDD structures are shared between faults. Moreover, it is possible to observe that there is a limit in the number of faults included in a cluster after that the TPG performance begins to decrease. For this class of circuits this limit seems to be between 4 and 6 faulty variables (FV), that is between 16 and 64 concurrently analyzed faults.

Moreover, the gate-level fault simulation of functional test sequences generates, in all examined cases, the full stuck-at fault coverage. Such a result is really promising.

Table 3: VHDL description examined

About testability measure, we examined an industrial controller part of a telecom device. Its characteristics are reported in Table 3 as number of VHDL instructions, input and output bits, flip-flops (#F.P.) and gates (#Gates). The total number of flip-flops is partitioned into 6 flip-flops used to represent the actual state of the controller and 10 flip-flops representing implicit states. The gate-level implementation of
the circuit has been obtained by using Mentor Auto-
logic.

Results reported in Table 4 compare the testability measure obtained by applying a structural fault model (Structural) and two different functional fault models. Fault coverage (#F.C.) for the Structural fault model is expressed as number of tested stuck-at faults, while fault coverage for the functional fault models is expressed as number of tested errors. The second func-
tional fault model (Functional-Exp.) differs from the first one (Functional) since it considers all criteria re-
ported in Section 3.3.

<table>
<thead>
<tr>
<th>fault-model</th>
<th># Faults</th>
<th># Untested Faults</th>
<th># F.C.</th>
</tr>
</thead>
<tbody>
<tr>
<td>Functional</td>
<td>487</td>
<td>95</td>
<td>60.3%</td>
</tr>
<tr>
<td>Functional-Exp.</td>
<td>413</td>
<td>21</td>
<td>94.9%</td>
</tr>
<tr>
<td>Structural</td>
<td>502</td>
<td>74</td>
<td>95.5%</td>
</tr>
</tbody>
</table>

Table 4: Effectiveness of the testability measure

The relevant results concern the testability estimation obtained with the second functional fault model. This measure is higher than the estimation obtained by using the first functional fault model, and it is really close to the structural testability level. Note also that the simulation of functional test sequences on the gate-level representation of the circuit reaches the same fault coverage (95.6%) achieved by directly generating test sequences for stuck-at faults. On the contrary, random test generation applied at the gate level does not cover more than 65% of stuck-at faults.

5 Concluding Remarks

This paper has described a methodology for testability estimation of VHDL descriptions of sequential controllers. The overall methodology is based on binary decision diagrams that allow the analysis of complex descriptions and extend methodologies based on manipulation of state transition graphs. The deterministic sequential test generation algorithm is able to analyze large sets of faults by injecting groups of single faults in the BDD-based description. As shown in the experimental results, section fault clustering sensibly reduces analysis time. Moreover, the fault model presented in [8] is here improved by taking into account faults on non-essential primes, faults on shared logic and on don't care functionalities. Such a further classification allows high correlation between testability of RT and logic level descriptions. Therefore, testability problems can be eventually identified and removed before synthesis. Experimental results have shown the effectiveness of the fault clustering approach and the high correlation between testability estimation at the functional and logic level.

Future work concerns the further improvement of the proposed fault model and of the BDD based algo-
rithms. Moreover, we will apply our approach to a large set of industrial examples in order to further evaluate the effectiveness of this approach.

References


