Generating Tests for Delay Faults in Nonscan Circuits by Agrawal, Prathima et al.
University of Nebraska - Lincoln
DigitalCommons@University of Nebraska - Lincoln
CSE Journal Articles Computer Science and Engineering, Department of
1993
Generating Tests for Delay Faults in Nonscan
Circuits
Prathima Agrawal
AT&T Bell Laboratories
Vishwani D. Agrawal
AT&T Bell Laboratories
Sharad C. Seth
University of Nebraska - Lincoln, seth@cse.unl.edu
Follow this and additional works at: http://digitalcommons.unl.edu/csearticles
Part of the Computer Sciences Commons
This Article is brought to you for free and open access by the Computer Science and Engineering, Department of at DigitalCommons@University of
Nebraska - Lincoln. It has been accepted for inclusion in CSE Journal Articles by an authorized administrator of DigitalCommons@University of
Nebraska - Lincoln.
Agrawal, Prathima; Agrawal, Vishwani D.; and Seth, Sharad C., "Generating Tests for Delay Faults in Nonscan Circuits" (1993). CSE
Journal Articles. 31.
http://digitalcommons.unl.edu/csearticles/31
D E L A Y  F A U L T  T E S T S  
Generating Tests b r  Delay 
Faults in Nonscan Circuits 
MO- WORK REPOmD on delay 
testing is applicable only to the scan 
type of circuits. This restricted prob- 
lem is, of course, more tractable 
than delay testing of general s e  
quential circuits. But a large num- 
ber of VU1 circuits are still designed 
without scan, and they must be test- 
ed for delay faults by means of func- 
tional test vectors supplied by the 
designer. The quality and complete 
ness of such vectors remain 
questionable. Although researchers 
have reported some results on de- 
lay testing for nonscan circuits,’ 
work on test generation algorithms 
is needed. In this article, we prc- 
pose a delay test method for syn- 
chronous circuits without scan. 
Even a properly designed circuit 
can have timing problems due to 
physical faults or variations in p r o  
cess parameters. In the literature, r e  
searchers have used two models to 
account for such effects: the gate 
delay model and the path delay 
model. The gate delay model holds 
that a delay fault exists when a gate’s 
delay exceeds its nominal value by 
more than a preset threshold value. 
An earlier version of this article was presented 
at the fihh International Conference on VU1 De- 
sign, Bangalore, India, January 1992. 
PRATHIMA AGRAWAL 
VlSHWANl D. AGRAWAL 
AT&T Bell Laboratories 
SHARAD C. SETH 
University of Nebraska 
at Lincoln 
This new mehod allows any 
sequential-circuit test gene 
program to produce path 
tests for nonscan circuits. To 
given path, the authors a q  
the netlist mod$ of the circuit 
a logic Mock in which testing 
certain single stuck-at fauh 
equivalent to testing For a 
delay fault. The test sequen 
the stuck-at fault performs a 
necessary delay fault test fun 
initialization, path activation, 
fault propagation. The a 
present results on bench 
nonscan and scan/hold 
testing. 
Gate delay faults require delay simula- 
tion, unless one assumes that a faulty gate 
has only large deviations from the nomi- 
nal value (the gross-delay model). 
The path delay model holds that 
any circuit path (between clocked 
storage elements) with a total delay 
exceeding the clock interval is faulty. 
For our method, we use a path delay 
model similar to one given by 
Malaiya and Narayanaswamy? A 
path can originate at a primary input 
or a flipflop and terminate at either a 
primary output or a flipflop. A delay 
fault will cause the propagation time 
of a signal (either a rising or a falling 
transition) through the path to ex- 
ceed the clock period. In general, a 
test for a path delay fault has three 
phases: initialization, path activation, 
and propagation. Each phase con- 
tains one or more input vectors. 
The activation phase consists of 
two vectors that initiate a signal tran- 
sition at the path’s origin and propa- 
gate it to the path’s end. Concepts of 
path testing in combinational and 
scan-based circuits are applicable to 
this phase. Two schools of thought 
exist, based on the way the path is 
activated. In the fully transitional 
path (FIT’) approach? both vectors 
sensitize the entire path at each gate. 
In the alternative approach, 
which we use in our method, only the 
second vector fully sensitizes the path. 
The first vector, however, sensitizes the 
path through gates that must propagate 
20 0740-7475/93/0300-0020503.00 0 1993 IEEE IEEE DESIGN & TEST OF COMPUTERS 
doi: 10.1109/54.199801  
noncontrolling values (such as 0 through 
an OR gate) along the path. The advan- 
tage of this approach is that it sets fewer 
signals than the FI" approach, and, as a 
result, some paths with no FTP tests can 
also be activated. Smith4 and Lin and 
Reddy specify the required signal states. 
Test robustness-that is, test validity for 
arbitrary delayrequires that certain sig 
nals remain unchanged during the two 
vectors of the path activation phase. No 
static hazard should be produced on 
these signals. Static hazard refers to a 
glitch, or pulse, in a steady signal. The 
position and width of this pulse may d e  
pend on the actual delays in the circuit. 
We refer to the robustness of path activa- 
tion by the two activation vectors as com- 
binational robustness.6 
The initialization phase, which pre- 
cedes path activation, sets the flipflops 
suitably for the other phases. The final 
phase, propagation, sensitizes a path 
from the tested path's destination flipflop 
to a primary output. One can make the 
initialization and propagation phases in- 
dependent of circuit delays by slowing 
down the system clock. Chattejee and 
d'Abreu7 have recently reported on their 
use of a slow clock in delay testing, a 
technique Malaiya and Narayanaswamy2 
suggested earlier. The path activation 
phase, which involves two vectors, a p  
plies the first vector with a slow clock. 
The second vector, however, must use 
the rated clock. Consequently, even flip 
flops other than the destination flipflop 
can have faulty values at the end of the 
activation phase if several faulty paths are 
simultaneously activated. To make the 
test sequentially robust, one must impose 
added restrictions on flipflopstates.6 
Delay fault test generation methods for 
nonscan sequential circuits have been 
presented by Chakrabotty, Agrawal, and 
Bushnell: and, with the R P  approach. 
by Devadas.* 
Delay faults in a nonscan circuit 
1- - ,.-.-,.h..,.--..- --,...-- &:-I  -:..-..:* 
X -  
Propogation Initialization Path activation 
4 vectors vectors * vectors * 
"1+1 'It2 'It3 V" 
Ck - 
s2 
7- + l f l t l f  
l 
Ck Ck Ck Ck 
t Rated 
clock Slow clock 
Figure 1. Testing of a path delay fault in a nonscan circuit. 
consist of primary inputs, primary out- 
puts, and flipflops. A common clocksig 
nal of a given frequency (or period) 
synchronizes all flipflops. Proper opera- 
tion requires that any signal changes at 
the combinational logic inputs that will 
propagate to the outputs must do so 
within the clock period. Our fault mod- 
el consists of single paths between the 
inputs and outputs of the combination- 
al logic. Of course, only sensitizable 
paths can be tested for delay faults. 
For each path, we have two potential 
faults-one based on the time that a ris- 
ing transition takes to propagate through 
the path and the other on that of a falling 
transition. In general, a path originating 
and ending at flipflops requires addi- 
tional steps (and greater effort) in test 
generation than one that starts at a pri- 
mary input or terminates at a primary 
output. Hence, without loss of generali- 
ty, we will restrict the discussion to paths 
between flip-flops. 
In this path delay fault model, testing 
reauires an initialization of the circuit to 
a state in which a transition can be prop 
agated through the path and the 
resulting transition captured in the desti- 
nation flipflop. If the delay fault is 
present in the circuit-that is, if the path 
delay exceeds the clock period-the 
state of the destination latch will be in- --..-,.A Th- &--+ +h-- ,,I,,.- th;.- .-t.-tn 
1- Ck 
t- 
'1 on 
m Ck 
Slow clock 
Figure 1 illustrates the major phases 
and assumptions of the testing proce 
dure. An array of duplicated combina- 
tional blocks (C) represents the circuit's 
operation on application of the test s e  
quence (uo through 03. The primary in- 
puts are applied from the top, and the 
primary outputs appear beneath the 
combinational logic blocks. Present- 
state inputs are shown entering from the 
left, and nextstate signals appear on the 
right. (Figure 1 does not show flip-flops 
on the state lines.) We apply the clock 
(Ck) that transfers the nextstate signals 
to the presentstate input of the next 
block just before we apply the primary 
inputs. Thus, applying the state inputs si 
and the primary inputs U ,  to C produces 
the primary outputs oi and the nextstate 
signals si+]. By activating Ck, we latch the 
signals si+l into the flipflops. 
Initialization sequence. The vec- 
tors uo through U ,  form the initialization 
sequence. The state inputs prior to the 
application of u0 are don't care (x). 
Some circuits have a clear input, which 
sets all flipflops into the 0 state. In such 
cases, o0 may apply the clear signal. For 
a circuit without a clearsignal, On, 01, . . ., 
U ,  will bring the circuit to a known state. 
At the end of the initialization sequence, 
all flipflops are set in states required by 
tho  nq+h q p t ; . r q t ; n n  ~ r n ~ t n * r  Tn n n r i r v o  
111 d >yl lL l l lu l luu> ,  > C ~ U C I I L I ~ I  L I I L U I L ,  LUIICLL. I I I C  L C ~ L  L I I C I I  iiiahc:3 ~ 1 1 1 3  a a L c  1 L I I C  paui a u i v a i i u i i  v c u u i a .  I W  G I I J U I L  
the combinational logic boundaries I observable at a primary output. 1 that the circuit initializes irrespective of 
MARCH 1993 21 
D E L A Y  F A U L T  T E S T S  
signal value Vi+ 1 vi+2 requirement 
I 
Table 1. Signal values for path activation. 
any delay faults, we run the clock at a 
slower rate. 
Path activation vectors. The two 
consecutive inputs to the combination- 
al logic, (ui+lv Si+]> and (ui+2$ si+2)> setspe 
cific input states for the gates on the path 
under test. These vectors are the path 
activation vectors. We specify the com- 
bination of signal values during the a p  
plication of these two vectors as shown 
in Table 1. The signals U0 and U1 speci- 
fy  the state only for uiS2. The signals SO 
and S1 specify steady value for both vec- 
tors without a static hazard. R and F are 
hazard-free transitions. XX indicates the 
values for both vectors are don’t care. 
The off-path signals follow those given 
by Lin and  redd^.^ The outputs of gates 
on the path assume rising and falling val- 
ues. As the transition propagates along 
the path, i t  can have dynamic hazards. 
The off-path signals feeding gates on 
the path assume values among UO, U1, 
SO, and S1. During the second vector, 
ujC2, the off-path signals must sensitize 
the path. However, during the first vec- 
tor, ui+l, the off-path signals remain in the 
don’tcare state if the path signal applies 
the controlling value (0 for AND and 
NAND, 1 for OR and NOR). These condi- 
tions are the same as given by Lin and 
Reddy, but they differ from those re- 
quired for FTP testing. In our case, ui+2 
fully sensitizes the entire path (solid ar- 
row in shaded C block in Figure l), but 
unlike UP testing, ui+] may not sensitize 
the entire path (dashed arrow in shaded 
C block). 
The application of ui+2 precedes the 
application of the rated clock period to 
the flipflops. If the signal amving at the 
destination flipflop is a rising transition, 
the correct value latched in this flipflop 
will be 1. Whenever the path delay ex- 
ceeds the rated clock period, the 
latched value will be 0. Thus, we denote 
the destination flipflop’s state by D, 
which has the same meaning as in the D 
alg~rithrn.~ That is, D denotes a 1 in the 
fault-free circuit and a 0 in the faulty cir- 
cuit. Similarly, for a falling transition ar- 
riving at the destination flip-flop, the 
state is D. 
Certain inputs to gates along the path 
under test have the values SO and S1. 
The signals on these lines must be free 
from static hazard during path activa- 
tion, To satisfy this requirement, all 
steady values (SO and Sl) must be im- 
plied by identical signal assignments for 
both path activation vectors at the com- 
binational logic inputs. We will discuss 
methods to generate such vectors later. 
Propagation vectors. In Figure 1, 
all vectors except ui+2 are applied at a 
slow clock rate. Thus, we can treat all 
other time frames as fault-free. The 
propagation vectors, u ~ + ~ ,  . . . , propagate 
the destination flipflop’s state to an ob- 
servable output. In the time frame i+2, 
however, delays can also affect the 
states of other flip-flops. Thus, any flip- 
flops whose states are changed by the 
application of uk2 can potentially as- 
sume values that depend on delays. 
Even flip-flops whose states do not 
change can have incorrect values due 
to delays and static hazards. An ideal 
test, therefore, requires propagation 
vectors to observe the D or state of 
the destination flipflop when all other 
flip-flops are uninitialized (set to x ) .~  
Testsso derived will work irrespective 
of any delay or timing situations that oc- 
cur in the circuit. This is a pessimistic 
approach that we can easily implement. 
However, we make a simplifying, single- 
delay-fault assumption: While testing a 
path, we assume all other paths have sig- 
nificantly smaller delays, and we 
assume all flipflops other than the desti- 
nation are in correct states at the start of 
the propagation phase. This assumption 
makes the tests sequentially nonrobusL6 
Our single-delay-fault assumption is 
similar in spirit to the singlestuck-at-fault 
assumption. One may argue that due to 
the correlation of delays along shared 
paths, our assumption is not justified. 
For example, the paths terminating at 
two flip-flops may contain several com- 
mon gates with large delays, in which 
case both flip-flops can have incorrect 
states. However, similar conditions can 
and do exist among stuck-at faults in fab 
ricated chips, and the viability of the 
single-fault model must rest on the un- 
likelihood of multiple-fault masking. 
We can pose the problem of delay 
fault masking as follows: When we gen- 
erate the propagation sequence to dif- 
ferentiate between true and faulty states 
at unit Hamming distance, what are the 
chances that this sequence will fail to 
differentiate faulty states at a greater 
Hamming distance from the true state? 
Moreover, one should remember that 
the purpose of the test is detection, not 
diagnosis. 
Further analysis has shown that this 
optimistic assumption may, in fact, be 
quite realistic in certain multipath acti- 
vation situations.I0 
22 IEEE DESIGN & TEST OF COMPUTERS 
Path search algorithm 
We generate paths from sources to 
destinations one at a time, using a depth- 
first search algorithm." The source of a 
path can be either a primary input or a 
flipflop output; its destination can be ei- 
ther a primary output or a flipflop input. 
The path generation algorithm searches 
consecutively for all paths from one 
source before moving on to the next 
source. To generate a new path, the al- 
gorithm first tries an extension of the last 
generated path. If such an extension is 
possible, the search continues until 
reaching a destination. If no extension is 
possible, the algorithm backtracks to the 
last unused fan-out and resumes the 
search from there. Should the backtrack 
reach a source and not find an unused 
fan-out, the search for paths from the 
next source starts. 
By preprocessing the circuit structure 
and storing appropriate information at 
each node, we can adapt the basic algo- 
rithm to generate paths in decreasing 
order of path lengths (or delays). We 
can also adapt it to generate a sample of 
paths by randomizing the next choice in 
the forward search procedure. 
In our implementation of the algo- 
rithm, we used a preprocessing step to 
count the number of paths from any 
gate to all destinations. With this infor- 
mation, the algorithm sorts the fan-out 
list of each gate output in decreasing 
path count order. We obtained excel- 
lent results for the sequentialcircuit 
benchmarks, on a Silicon Graphics (SGI 
340) computer." For example, it took 
322 CPU seconds to generate 244,854 
paths in circuit s9234. 
Test generation model 
Given a path and a transition, we cre- 
ate a modified circuit in which a test for 
a specified single stuck-at fault will d e  
tect the delay fault. We define thisstuck- 
at fault as follows: 
1. The stuck-at fault must be activated 
only when the two path activation 
Figure 2. Test generation model for a falling transition at destination 
vectors have been applied to the 
combinational logic. Since the cir- 
cuit is sequential, initialization vec- 
tors, if necessary, precede the path 
activation vectors. 
2. Once the stuck-at fault is activated, 
its effect in the form of D or D is in- 
jected into the path's destination 
flip-flop. This happens at the second 
path activation vector (u!+~ in Figure 
1). Prior to its activation, the stuck- 
at fault must not interfere with the 
circuit's normal operation. vectors. 
3. After the fault effect is stored in the 
destination flip-flop, the stuck-at 
fault must allow the fault-free func- 
tion of the circuit during the propa- 
gation phase. 
ments for gates along the path during 
the activation vectors u,+~ and 0,+2 are 
captured by the gates ANDl and AND2. 
The output of ANDl feeds flip-flop FF1, 
whose output feeds AND2. The output 
of AND2 is inverted to generate signal 
AND2N, on which we introduce astuck- 
at-1 fault. The flipflop FFl is initialized to 
0 state and is controlled by the circuit's 
system clock, Ck. Clearly, the fault 
AND2N s-a-1 will be activated on4ywhen 
the path is activated by two consecutive 
At that time the state of the signal 
AND2N will be D. The AND gate AND4 
and the OR gate TERM insert this Dstate 
into the destination flip-flop FFD under 
the control of a finite-state machine 
(FSM, within dotted lines in Figure 2). 
The type of gate we use for TERM d e  
pends on the type of transition arriving 
at the destination e. The gate should sen- 
sitize the path between AND4 and FFD 
during the second path activation vector 
u,+~.  Since e has a falling transition, we 
Figure 2 shows how we implement 
the above functions. To test the path ace 
(shown in bold lines), which lies be- 
tween two flip-flops, FFS and FFD, we 
insert a modeling block as shown with- 
in the dashed lines. The signal require- 
MARCH 1993 23 
D E L A Y  F A U L T  T E S T S  
use an OR gate for TERM. 
During initialization, the path can be 
activated one or more times. Because of 
the slow clock, however, the fault effect 
must not enter the destination flip-flop 
FFD. Holding flip-flop FF2 in a 1 state 
during initialization ensures this. At the 
end of the initialization phase, the test 
generator clears FF2 to a 0 state. This 
procedure guarantees that the AND4 
gate’s output, as forced by the FSM, re- 
mains 0 before and after fault activation 
to provide continuity through the gate 
TERM. The procedure also ensures that 
the circuit function remains normal. 
In the path activation phase, the FSM 
produces a 1 output to inject a D into 
FFD only when the path is activated and 
010 010 
Figure 3. FSM state diagram. 
AND2 turns to 1. Subsequently, the FSM 
settles into a 1 state with a 0 output and 
remains in that state throughout the 
propagation phase. Figure 3 presents the 
FSM state diagram. Asshown in Figure 2, 
the FSM is implemented with the single 
flipflop FE?, which is clocked by Ck. 
When a rising transition arrives at the 
destination flip-flop FFD, we insert the 
AND gate TERM in the path to inject a D 
in the flip-flop. As explained earlier, 
TERM must sensitize the path for the 
fault effect to enter FFD during the sec- 
ond path activation vector u ~ + ~ .  Thiscon- 
struction is shown in Figure 4. 
Hazard elimination for robust 
tests. We can incorporate the test gener- 
ation model just described into any se- 
quentialcircuit test generator program 
for stuck-at faults by modifying the 
netlist according to the path under con- 
sideration. However, robust test genera- 
tion may require special effort. 
The presence of hazards on steady 
Figure 4. Test generation model for a rising transition at destination. 
24 
signals SO and S1 can invalidate a delay 
test. In general, test generator programs 
do not attempt to relate the signal values 
that occur in two different time frames. 
The vectors are not guaranteed to prc- 
duce hazard-free signals. Therefore, SO 
and S1 signals require special consider- 
ation. 
Notice that the steadysignal require- 
ment must be imposed only on the two 
path activation vectors u,+~ and u ~ + ~ .  We 
feed all steady signals to an AND gate to 
generate a steadysignal function, SS. 
We feed the S1 signals directly and the 
SO signals in their complemented form 
to the AND gate. The test generator must 
then ensure that 1) both u, ,~  and uj+2 are 
contained in the Same prime-implicant 
cube of the function SS, and 2) no static 
hazard is produced by the application of 
these two vectors at the signal SS. Re- 
quirement 1 appears to be enough for 
hazard-free tests, but the following ex- 
ample shows that is not true. 
Example. Suppose the path shown in 
bold in Figure 5 is to be activated for a 
falling transition at its input. The figure 
shows the ANDl, AND2, and AND gates 
for the example path. The ON set of a sig- 
nal is the set of all primary input vectors 
that set the signal to 1. Similarly, the vec- 
tors in the OFF set imply a 0 on the sig- 
nal. One can easily verify that the only 
cube of SS that has non-null intersec- 
tions with the ON sets of both ANDl and 
AND2 gatesisx=l,j=l, and b=l. Howev- 
er, that does not provide a robust test for 
the fault considered because signal D 
(and hence SS) can have a static hazard 
due to the transition on input a. 
The example points out the need to 
restrict the candidate cubes of SS to 
those that do not produce any static haz- 
ard at SS. A practical procedure would 
be to first generate the ON set of SS by 
means of a Podem-like line justification 
procedure.12 By definition, the ON set 
contains all the cubes (with 0, 1, or X 
specified in each bit position) that set SS 
to 1. I f  1’s and 0’s in a cube are identified 
IEEE DESIGN & TEST OF COMPUTERS 
with Sl’s and SO’S, respectively, the re- 
sulting value at the line SS will be S1. 
Thus, we get a potential path activation 
vector pair (ui+,, ui+2), which we could 
supply to thesequential test generator. If 
the test generator does not succeed in 
augmenting this vector pair with the 
necessary initialization and propagation 
vectors, it backtracks to generate the 
next cube in the ON set of SS. 
The procedure just outlined does not 
represent a complete robust-test genera- 
tion algorithm because a cube generated 
by the line justification procedure may be 
overspecified, imposing unnecessary 
constraints on the initialization and prop 
agation phases. To overcome this prob- 
lem, we can use a simulation-based 
approach to generate all prime cubes 
that contain the cube generated by line 
justification. The maximalcompaction 
method suggested by Pomeranz and 
ReddyI3 is adaptable for this purpose. 
To adapt the test generation proce- 
dure to the regularclock testing mode, 
we do not use a slow clock, and we can 
activate the path under test several times 
during the test sequence. We model this 
situation by eliminating the FSM from 
the circuits of Figures 2 and 4. Thus, the 
output of AND2N, with an s-a-1 fault, 
feeds directly into an input of TERM. 
Implementation and results 
The implementation of our path de- 
lay test generation method combines 
the path search algorithm and circuit 
modification discussed in the preceding 
two sections and asequentialcircuit test 
generator. We used Steed,I2 a test gen- 
eration algorithm that generates ON sets 
and OFF sets for each combinational 
logic output. It then generates a test vec- 
tor for the given single stuck-at fault, us- 
ing a combinational test generator. 
Starting in the given initial state, Steed 
generates an initialization sequence to 
precede the test vector. If the test vector 
has produced the fault effect at the des- 
tination flip-flop of the path under test, 
Steed adds a propagation sequence to 
MARCH 1993 
Y C 
Figure 5. Circuit in robust-test example. 
propagate the fault effect to a primary 
output. Although we could use any se- 
quentialcircuit test generator, Steed a p  
pears to be ideal because it  assumes the 
circuit to be fault-free in the initialization 
and propagation phases. This assump 
tion is valid in our case due to the slow- 
ing of the clock. 
We developed a prototype system 
that generates delay tests for two faults 
(with rising and falling transitions, r e  
spectively) on each path. The system 
consists of three programs: a path gener- 
ator, a stuck-at-fault model builder, and 
the Steed test generator. The path gener- 
ator places all paths in the form of signal 
arrays in a file. The model builder reads 
a path, builds two models for the rising 
and falling transition faults, specifies the 
single stuck-at fault for each transition, 
and calls Steed twice. We use a modi- 
fied version of Steed, which generates 
tests only for specified faults. We run 
Steed without fault simulation because, 
as explained earlier, the fault-free time 
frame assumption is valid for delay 
faults. The test generator produces vec- 
tor sequences for any detectable faults. 
Then, the model builder prepares mod- 
els for the next path in the file and calls 
the test generator. The three programs 
run in a Unix shell environment. We did 
not implement the robustness condition 
in the prototype system. 
Table 2 (next page) lists results ob- 
tained with the prototype system’ on 
most of the sequentialcircuit bench- 
marks. The prototype effectively gener- 
ates delay tests, but its implementation is 
not particularly efficient. Although all 
the system programs use somewhat sim- 
ilar data structures, they repeatedly ac- 
cess data from the disk. We have not 
included disk I/O time in the measured 
run times given in Table 2. However, our 
shell-based implementation degrades 
response time drastically for large cir- 
cuits. Another difficulty is the test gener- 
ator‘s slow response due to page faults, 
especially for large circuits. 
The total number of faults is twice that 
of the total number of paths. Our proto- 
type assumed circuits to have a global 
clear input to initially set all flipflops into 
the 0 state. This initial state was used by 
the test generator. The reported CPU 
times, on the Sun Sparc2 workstation, 
do not include path generation time, 
which was relatively small. Also not in- 
cluded is the time required by Steed’s 
ON set and OFF set generation, which 
our prototype repeated for each fault. In 
two circuits, s1196 and s1238, which 
contained larger numbers of paths, we 
25 
D E L A Y  F A U L T  T E S T S  
Table 2. Path delay test generation in nonscan mode. 
Circuit No. of Coverage Test Gen. CPU seconds AV. vectors 
name faults (“4 Total Per fault per fault 
s27 
s208 
s298 
s344 
s349 
s382 
s400 
s420 
s444 
56 
290 
462 
71 0 
730 
800 
896 
738 
1,070 
s510 738 
s526 820 
s526n 81 6 
s820 984 
5.953 2,266 
s l  196 4,000* 
s1238 4,000* 
s1488 1,924 
s1494 1,952 
*Portio/ set of faults 
’ s832 1,012 
37.5 
16.6 
20.8 
25.9 
25.2 
1.3 
1.1 
6.4 
5.6 
23.4 
3.8 
3.8 
37.4 
36.4 
40.2 
51 .O 
41.5 
37.5 
37.0 
analyzed only 4,000 faults each. Al- 
though not always so, the test generation 
time generally increases with the num- 
ber of vectors. However, the average 
number of vectors per fault is not a func- 
tion of circuit size but may depend on 
the circuit’s sequential complexity. 
Our prototype implementation seri- 
ously limited the capability to process 
very large circuits. For example, for the 
circuit s9234, which has very few sensi- 
tizable paths, Steed required nearly 4 1 
seconds per fault. The first 1,500 path 
delay faults in the list produced no test. 
For s5378, one 13-gate path was tested 
by just two vectors for the rising transi- 
tion and by three vectors for the falling 
transition. However, the test generation 
time was 150 seconds per fault. We pro- 
cessed a very small fraction of paths for 
these two circuits (thus, they are not list- 
ed in Table 2). 
In Table 2, coverage ranges from a 
low of 1.1% in s400 to a high of 51.0% in 
2.2 
18.8 
150.4 
1,155.9 
1,168.1 
34,962.6 
42,278.0 
334.0 
14,209.6 
1 13.6 
42,521.2 
42,564.4 
2,952.0 
3,162.6 
1,287.7 
48,355.3 
2 8,050.5 
901.3 
928.8 
. 
0.039 3 
0.065 8 
0.326 21 
1.628 5 
1.600 5 
43.703 33 
47.1 85 33 
0.453 9 
13.280 55 
0.154 24 
51.855 62 
52.1 62 62 
2.91 7 9 
3.1 25 9 
0.568 11 
12.090 3 
7.01 3 3 
0.469 15 
0.476 15 
sl196. As mentioned earlier, our proto- 
type does not include hazard elimina- 
tion for robust tests. For some faults, 
hazard-free tests may not exist. Thus, the 
coverage of robust tests will be even 
lower. A low path coverage, however, 
may not be a serious concern if we use 
delay tests with stuck-at fault tests. This is 
because our delay tests can cover all 
sensitizable paths, resulting in better test- 
ing in situations requiring speed sorting 
of VU1 devices. 
Scan circuit testing. We can easily 
apply our test generation method to cir- 
cuits with scan design. There are two 
methods of delay testing of scan hard- 
ware. Since all flipflops are controllable 
and observable through the scan regis- 
ter, we can test a path delay fault with 
just two vectors, ul  and u2. However, we 
also must specify the corresponding flip- 
flop states s1 and s2 for each vector. 
The first method uses the normal scan 
’ register for scan-in and scan-out of flip 
flop states.I4 In this case, s2 must be gen- 
erated either by the combinational 
circuit when u1 is applied with the flip 
flops initialized to state sl, or by a single 
bit shift of the scan register. To generate 
tests, we first implement the scan register. 
The test generation model circuit will 
contain only the gates ANDl, AND2, and 
the flipflop FFI, initialized to 0. We make 
the output of AND2 a new primary output 
on which a stuck-at4 fault is tested. 
The test generator then uses the scan 
register to set the circuit to any desired 
state sl. It also controls the mode control 
input. Thus, it generates the vectors with 
either the functional mode or the scan 
mode, whichever is convenient. No 
propagation sequence is generated b e  
cause the stuck-at fault is now on a pri- 
mary output. We can obtain robust tests 
by imposing the steadysignal condition 
discussed earlier. 
In the second method, a modified 
scan design includes a hold latch be- 
tween each flip-flop and the combina- 
tional logic.* The hold latch operates in 
two modes: transparent and hold. All 
hold latches are controlled by a com- 
mon hold clock primary input, which 
keeps them in the transparent mode 
during normal operation. Again, a path 
delay test consists of two vectors, u l  and 
u2, and their corresponding states, s1 and 
s2. First we scan in s1 and load it into the 
hold latches by changing the hold clock 
from transparent to hold mode. Then we 
apply u1 to the primary inputs. Next we 
scan s2 into the scan shift register. We 
apply u2 to the primary inputs while the 
hold clock changes all hold latches to 
transparent mode. We then set the cir- 
cuit in normal mode and, one clock pe- 
riod later, apply Ck to capture the fault 
effect in the destination flipflop. Ascan- 
out follows. 
To generate delay tests, we make all 
flipflop outputs @resent states) primary 
inputs and all flipflop inputs (next 
states) primary outputs. The modeled 
circuit again contains ANDl, AND2, and 
26 IEEE DESIGN & TEST OF COMPUTERS 
FF1 initialized to 0. We also make the 
output of AND2 a primary output, on 
which we introduce a stuck-at4 fault. 
For robust tests, the steadysignal condi- 
tion must be imposed. 
Table 3 summarizes test generation 
results obtained for the scan/hold meth- 
od. As we expected, the coverages are 
higher than those for the nonscan cir- 
cuits given in Table 2. We generated 
only two vectors for each testable path. 
CPU time for test generation is also more 
manageable. However, the two largest 
circuits again posed problems for the 
test generator. It analyzed only 1,474 
faults in s5378 and 92 faults in s9234. 
These faults were not randomly selected 
but were taken from the beginning of 
the path file. Thus, the coverage shown 
for these two circuits may not be correct. 
For the scan/hold method, we imple- 
mented the hazard elimination part of 
our algorithm. In Table 3, the coverage 
labeled “Robust” is the percentage of 
path faults for which robust tests were 
found. The “Total” coverage additional- 
ly includes the paths for which only non- 
robust tests were found. The total 
coverage is comparable to results report- 
ed by other resear~hers.’~ 
Table 3 shows that for several circuits 
we found robust tests for most sensitiz- 
able paths, pointing to the usefulness of a 
robust-test generator that can select the 
proper test when several possible tests 
exist. However, this result holds true only 
for scan/hold circuits. We would expect 
a lower robust coverage for nonscan and 
normal scan circuits, which we plan to 
investigate in the future. 
OUR TEST GENERATION METHOD allows 
any sequentialcircuit test generator to 
produce path delay tests for nonscan cir- 
cuits. In addition, the method’s general- 
ity permits easy application to the 
simpler cases of scan and scan/hold cir- 
cuits. Our hazard avoidance procedure, 
To simplify the problem of path delay 
test generation, we used a single-faulty- 
path model. Although the singlefault 
model is popular in stuck-at-fault testing, 
its use in delay testing needs further 
analysis and experience. 
A direct application of our technique 
is path delay fault simulation. For each 
critical path, we add the modeling block 
with a stuck-at fault. Then a concurrent 
fault simulation with any given vector 
sequence determines the path delay 
fault coverage. Another application in- 
volves currently popular static path ana- 
lyzers, which generate superfluous data 
on failing paths whose delay cannot 
cause an incorrect output. We call these 
sequentially false paths. Application of 
our test generation method to dynamic 
timing analysis eliminates such paths 
from consideration.I6 
Acknowledgments 
We thank D. Bhattacharya for the exam- 
ple in Figure 5 .  Sharad C. Seth acknowledg- 
es consulting support from AT&T Bell 
Laboratories. 
References 
1. I. Deol, C. Mallipeddi, and T. Ramakrish- 
nan, “Amdahl Chip Delay Test System,” 
Proc. Int’l Con[ Computer Design, IEEE 
Computer Society Press, Los Alamitos, 
Calif., 1991, pp. 20@205. 
2. Y.K. Malaiya and R. Narayanaswamy, 
“Modeling and Testing for Timing Faults 
in Synchronous Sequential Circuits,” 
IEEE Design & Test of Computers, Vol. 1, 
3. C.T. Glover and M.R. Mercer, “A Method 
of Delay Fault Test Generation,” Proc. 
25th Design Automation Conl, IEEE CS 
Press, 1988, pp. 9@95. 
NO. 4, NOV. 1984, pp. 62-74. 
Table 3. Path delay test generation in scan/hold mode. 
Circuit No. of Covemqe 0 Test qen. CPU seconds 1 
I name faults Robust Total ~ 0 t a 1  Perfault ~ 
, 
s27 
s208 
s298 
s349 
s382 
, s400 
’ s420 
~ s510 
~ s526 
s526n 
s820 
s832 
s953 
sl196 
sl238 
sl488 
sl494 
s5378 
s9234 
56 
290 
462 
71 0 
730 
800 
896 
738 
1,070 
738 
820 
816 
984 
1,012 
2,266 
4,000* 
4,000* 
1,924 
1,952 
1,474’ 
92’ 
89.3 
100.0 
74.7 
90.6 
88.1 
88.0 
80.7 
100.0 
67.6 
99.3 
85.5 
85.7 
99.3 
97.7 
99.6 
56.0 
45.5 
99.1 
98.2 
39.8 
48.9 
89.3 
100.0 
76.2 
90.6 
88.1 
88.0 
80.7 
100.0 
67.6 
100.0 
86.3 
86.5 
100.0 
98.4 
100.0 
59.9 
45.8 
99.6 
98.7 
67.8 
69.6 
0.1 4 
1.15 
2.07 
4.45 
4.35 
4.53 
5.31 
13.87 
6.15 
3.80 
4.52 
3.91 
4.90 
5.54 
14.44 
27.01 
27.21 
9.37 
4.90 
5,190.10 
3.04 
0.0024 
0.0040 
0.0045 
0.0063 
0.0060 
0.0057 
0.0059 
0.01 88 
0.0058 
0.0050 
0.0055 
0.0048 
0.0050 
0.0083 
0.0060 
0.0068 
0.0670 
0.0049 
0.0025 
3.521 0 
0.0330 
when fully implemented, wili allow gen- ~ *Partial set of foults 
eration of robust tests. 1 1  
MARCH 1993 27 
D E L A Y  F A U L T  T E S T S  
4. G.L. Smith, “Model for Delay Faults 
Based Upon Paths,” Proc. Int ’I Test Cont: , 
IEEE CS Press, 1985, pp. 342-349. 
5. C.J. Lin and S.M. Reddy, “On Delay Fault 
Testing in Logic Circuits,” IEEE Trans. 
CAD, Vol. CAM, No. 9, Sept. 1987, pp. 
694-70 1. 
6. T.J. Chakraborty, V.D. Agrawal, and M.L. 
Bushnell, “Delay Fault Models and Test 
Generation for Random Logic Sequen- 
tial Circuits,” Proc. 29th Design Automa- 
tion C o d ,  IEEE CS Press, 1992, pp. 
1651 72. 
7. A. Chattejee and M. A. d’Abreu, “Syn- 
drome-Based Functional Delay Fault 
Location in Linear Digital Data-Flow 
Graphs,” Proc. Int’l Con[ Computer De- 
sign, IEEE CS Press, 1991, pp. 212-215. 
8. S. Devadas, “Delay Test Generation for 
Synchronous Sequential Circuits,” Roc. 
Int’l Test C o d ,  IEEE CS Press, 1989, pp. 
9. J.P. Roth, W.G. Bouricius, and P.R. 
Schneider, “Programmed Algorithms to 
Compute Tests and to Detect and Distin- 
guish Between Failures in Logic Cir- 
cuits,” IEEE Trans. Electronic Computers, 
580. 
10. S. Bose, P. Agrawal, and V.D. Agrawal, 
“A Path Delay Fault Simulator for Se- 
quential Circuits,” Proc. Sixth Int’l Cont: 
VU1 Design, IEEE CS Press, 1993, pp. 
269-274. 
11. P. Agrawal, V.D. Agrawal, and S.C. Seth, 
“A New Method for Generating Tests for 
Delay Faults in Non-Scan Circuits,” Roc. 
Fifth Int’l Cont: VU1 Design, IEEE CS 
Press, 1992, pp. 4-1 1. 
12. A. Ghosh, S. Devadas, andA.R. Newton, 
“Test Generation and Verification for 
Highly Sequential Circuits,” IEEE Trans. 
CAD, Vol. 10, No. 5, May 1991, pp. 652- 
667. 
13. 1. Pomeranz and S.M. Reddy, “Compact- 
est: A Method to Generate Compact Test 
Sets for Combinational Circuits,” Proc. 
Int’l Test C o d ,  IEEE CS Press, 1991, pp. 
14. V.D. Agrawal, S.K. Jain, and D.M. Sing- 
er, “Automation in Design for Testabili- 
144-1 52. 
Vol. EC-16, NO. 10, Oct. 1967, pp. 567- 
194-203. 
ty,” Proc. Custom Integrated Circuits 
C o d ,  IEEE, Piscataway, N.J., 1984, pp. 
159-1 63. 
15. K.T. Cheng, S. Devadas, and K. Keutzer, 
“Robust Delay Fault Test Generation 
and Synthesis for Testability Under a 
Standard Scan Design Methodology,” 
Proc. 28th Design Automution C o d ,  
IEEE CS Press, 1991, pp. 80-86. 
16. P. Agrawal, V.D. Agrawal, and S.C. Seth, 
“DynaTAPP: Dynamic Timing Analysis 
With Partial Path Activation in Sequen- 
tial Circuits,” Proc. EURODAC, IEEE CS 
Press, 1992, pp. 138-141. 
Computing Research Department at AT&T 
Bell Laboratories. Her interests include com- 
puter architecture, parallel algorithms, and 
VLSl simulation and testing. She received 
her PhD from the University of Southern Cal- 
ifornia. She is a fellow of the IEEE and the 
Institution of Electronics and Telecommuni- 
cation Engineers (India). She is a member of 
the IEEE Computer Society. 
and neural network algorithms. He has co- 
authored three books. A former editor-in- 
chief of IEEE Design & Test of Computers, 
Agrawal presently serves as editor-inchief of 
the Journal of Electronic Testing: Theory and 
Applications. He received his PhD from the 
University of Illinois at Urbana-Champaign. 
He is a fellow of the IEEE and a member of 
the IEEE Computer Society, the ACM, and 
the VLSI Society of India. He has served on 
the IEEE CS Board of Governors. 
science and engineering at the University of 
Nebraska at Lincoln. He has held visiting 
positions at the Indian Institute of Technolo- 
gy, Kanpur, India, and at AT&T Bell Labora- 
tories. His research interests include digital 
testing and parallel algorithms for comput- 
er-aided design. He coauthored Test Gener- 
ation for VU1 Chips (IEEE Computer Society 
Press). He hasserved on the editorial boards 
of IEEE Transactions on Computer Aided De- 
sign, IEEE Design & Test of Computers, and 
the Journal of Electronic Testing: Theory and 
Applications. Seth received his PhD from the 
University of Illinois at Urbana-Champaign. 
He is a senior member of the IEEE, a mem- 
ber of the IEEE Computer Society, and a 
member of the ACM. 
Vishwani D. Agrawal is a distinguished 
member of the technical staff at AT&T Bell 
Laboratories and a visiting professor of elec- 
Send correspondence about this article to 
Vishwani D. Agrawal, AT&T Bell Laboratories, 
cnn i d  -..- &-:- A..- D--- c)r n7c RA..-.-., trical and computer engineering at Rutgers 
University. His interests include VLSI testing 
uuu I V I U U I I L ~ I I I  five., nuuiii o-.-fiu, ivruiiay 
Hill, NJ 07974; email: va@research.att.com. 
28 IEEE DESIGN & TEST OF COMPUTERS 
