An analysis of aliasing in built-in self test procedure by Barus, Jasa
Calhoun: The NPS Institutional Archive
Theses and Dissertations Thesis Collection
1991-06
An analysis of aliasing in built-in self test procedure
Barus, Jasa
Monterey, California. Naval Postgraduate School
http://hdl.handle.net/10945/27945

















AN ANALYSIS OF ALIASING IN




Thesis Advisor: Chyan Yang





SECURITY CLASSIFICATION OF THIS PAGE
REPORT DOCUMENTATION PAGE Form ApprovedOMB Mo 0704-0188
1a REPORT SECURITY CLASSIFICATION
UNCLASSIFIED
lb RESTRICTIVE MARKINGS
2a SECURITY CLASSIFICATION AUTHORITY
2b DECLASSIFICATION /DOWNGRADING SCHEDULE
3 DISTRIBUTION/AVAILABILITY OF REPORT
public release; distribution is unlimited
4 PERFORMING ORGANIZATION REPORT NUMBER(S) 5 MONITORING ORGANIZATION REPORT NUMBER(S;




7a NAME OF MONITORING ORGANIZATION
Naval Postgradute School
6c. ADDRESS (City, State, and ZIP Code)
Monterey, California 93943-5000
7b ADDRESS (City, State, and ZIP Code)
Monterey, California 93943-5000




9 PROCUREMENT INSTRUMENT IDENTIFICATION NUMBER









11. TITLE (Include Security Classification)
An Analysis of Aliasing in Built-in Self Test Procedure
12 PERSONAL AUTHOR(S)
Jasa Barus











18 SUBJECT TERMS (Continue on reverse if necessary and identify by block number)
Built-in Test; Aliasing Probabibility ; Test Architec
ture
19 ABSTRACT (Continue on reverse if necessary and identify by block number)
This thesis investigates aliasing probability in Built-in Self Test (BIST) procedure,
in which a Linear Feedback Shift Register (LFSR) is used as pseudo-random pattern
generator, with a full adder as Circuit Under Test (CUT). The Signature Analyzer
implements a Multiple Input Signature Register (MISR) as a test response compressor.
20 DISTRIBUTION /AVAILABILITY OF ABSTRACT
D3 UNCLASSIFIED/UNLIMITED SAME AS RPT DTIC USERS
21 ABSTRACT SECURITY CLASSIFICATION
UNCLASSIFIED
22a NAME OF RESPONSIBLE INDIVIDUAL
Prof. Chyan Yang




DD Form 1473, JUN 86 Previous editions are obsolete
S/N 0102-LF-014-6603
i
SECURITY CLASSIFICATION OF THIS PAGE
Unclassified
Approved for public release; distribution is unlimited
An Analysis of Aliasing in Built-in Self Test Procedure
by
Jasa Barus
Captain, Indonesian Air Force
B.S., Padjadjaran University, Indonesia, 1977
Submitted in partial fulfillment of the
requirements for the degree of





This thesis investigates aliasing probability in Built-in Self Test (BIST) proce-
dures, in which a Linear Feedback Shift Register (LFSR) is used as a pseudo-random
pattern generator, with a full-adder as a circuit-under-test (CUT). The Signature





II. BUILT-IN TEST BACKGROUND 4
A. TEST GENERATION AND VERIFICATION 4
B. DESIGN FOR TESTABILITY 8
C. SIGNATURE ANALYSIS 12
1. Signature Analysis 14
2. Advantage 14
3. Disadvantage 15
III. ALIASING IN MISR 16
1. Aliasing Probability 16
2. Notation and Definition 17
3. Aliasing and Markov Process 19
IV. A TEST SYSTEM ARCHITECTURE 21
A. SYSTEM ARCHITECTURE 21
1. Linear Feedback Shift Register as a Test Pattern Generator . . 21
2. Full Adder as a Circuit Under Test 23
3. Multiple Input Signature Register as a Compressor 23
B. GENERATOR 25
C. TEST CIRCUIT 25
D. EXPERIMENTAL SET-UP 26
E. EXPERIMENTAL EVALUATION 28
V. CONCLUSIONS 36
APPENDIX A - PROGRAMS FOR THESIS PROJECT 37
iv
APPENDIX B - NETWORK DESCRIPTION FILES 48
LIST OF REFERENCES 68
INITIAL DISTRIBUTION LIST 70
LIST OF TABLES
4.1 ALIASING PROBABILITY WITH DIFFERENT INITIAL STATES
OF LFSR ON 2-BIT ADDER 29
4.2 EXPECTED VALUE OF SUM FOR GOOD CUT 31
4.3 THE VALUE OF SUM FOR DIFFERENT S-A-FAULTS 32
4.4 ALIASING PROBABILITY IN 5 STAGE MISR WITH DIFFER-
ENT INITIAL STATES 34
4.5 ALIASING PROBABILITY IN 9 STAGE MISR WITH DIFFER-
ENT INITIAL STATES 34
VI
LIST OF FIGURES
2.1 Fault Free AND Gate 9
2.2 Faulty AND Gate 9
2.3 The Complete Test Generation and Observation Arrangement .... 12
2.4 MISR 13
3.1 Experimental Set-up for Signature Analysis 17
3.2 Transition Diagram of the Markov Process for LFSR Implementing
x
2 + x + 1 20
4.1 LFSR Described by Polynomial x 4 + x + \ 22
4.2 Full Adder 24
4.3 Experimental Set-up 27
4.4 The Flow to Generate LFSR, Full-Adder, MISR and the Combination
of all Circuits into One Module 27
4.5 One Bit Full Adder with s-a-fault 30
4.6 The Aliasing Probability in s-a-0 Fault 30
4.7 The Aliasing Probability in s-a-1 Fault 31
4.8 The Aliasing Probability in s-a-1 Fault Using 5 Stages MISR 33
4.9 The Aliasing Probability in s-a-0 Faults Using 5 Stages MISR .... 33




I would like to express my gratitude to my advisor, Professor Chyan Yang and
my second reader, Herschel H. Loomis, Jr., for their guidance and assistance. And,




Advances in semiconductor manufacturing technology permit increased com-
plexity of VLSI circuits, and therefore increase the difficulty of testing devices, in
particular, those aspects of chip testing such as cost, time, and test data volume.
One approach to alleviate testing problems to reduce both cost of test gen-
eration and test time is to incorporate built-in self test (BIST) circuitry into the
circuit-under-test during the initial design. A BIST circuit requires that the test
pattern generation and output response evaluation are incorporated into the circuit
under test. In this technique, test patterns are applied internally to the circuit un-
der test (CUT) and their output responses are evaluated without the use of external
test equipment. There are three methods to generate test patterns [Ref. 1]:
• Manual Generation - The test patterns are written by a design or test engineer
with regard to the fault coverage.
• Pseudo-random Pattern Generation - Pseudo-random test patterns are gener-
ated by hardware built into the test equipment or actually embedded in the
CUT or by a software algorithm.
• Algorithmic Test Generation - A computer program is used to generate the
test patterns, and also deals with fault coverage.
The method used in BIST for evaluating response is most frequently performed
by signature analysis. [Ref. 2]
The most popular approach used for BIST today is pseudo-random pattern
generation. Pseudo-random patterns are usually generated by a linear feedback shift
1
register (LFSR) and are applied to the circuit under test. The output responses from
the circuit under test are then compressed through multiple-input shift register
(MISR) to form a signature. By analyzing the signature, it can be determined
whether a circuit under test is faulty or not. Because test patterns are generated
by a built-in random pattern generator, the time consuming effort of test pattern
generation can be removed from the design cycle by using a BIST circuit. Since
signature analysis compresses response data and compares the signature only once,
the difficulty of analysis and storage of huge amounts of test response data can be
avoided. Furthermore, BIST has another important advantage in that the circuit
under test is fed with random test patterns at the functional clock rate. This
advantage allows high speed testing to be performed using internal test equipment
built in the circuit under test.
In designing a built-in self test circuit, the following factors need to be consid-
ered [Ref. 3]:
• Performance Degradation - The maximum operating frequency may be re-
duced because of the additional propagation delay caused by the self- test cir-
cuit.
• Overhead - The added self-testing circuitry will increase the chip area, and
this will increase the manufacturing cost. Therefore, the overhead should be
kept as small as possible.
• Fault Coverage - The ratio between the number of faults detected by using the
set of test-pattern given is also an indicator of the quality of the test. A cov-
erage between 90% to 95% is desired for satisfactory performance. Basically,
fault coverage depends on the effectiveness of the input sequences.
• Testing of the Added Circuitry - The circuit which added to the chip also
should be tested.
• Test Application Time - This will affect the final cost.
The test pattern is selected based on the above factors. If a complicated
pattern or exhaustive pattern set is selected, the fault coverage could be increased,
but circuitry will then become more complex and require more difficult testing
parameters. The overhead will increase and more test time may be necessary. If a
simple test pattern or subset of exhaustive pattern set is selected, the added circuitry
can be easily tested. This results in lower overhead and shorter test time, but lower
fault coverage. The major problem of this BIST technique is the possibility that
correct and faulty circuits give the same signature, known as aliasing errors. These
errors depend on the structure of compressor, the structure of CUT, the type of
fault and the test patterns [Ref. 4].
The main purpose of this study is to set guidelines and to evaluate testing
strategies used for BIST. In Chapter II, we investigate the testing concepts used
in BIST and annotate their advantages and disadvantages. In Chapter III, aliasing
probability is discussed. Chapter IV presents testing requirements and tools used
in this thesis. Conclusions are given in the last chapter.
II. BUILT-IN TEST BACKGROUND
A. TEST GENERATION AND VERIFICATION
Test generation is used to generate a sequence of input test vectors to verify the
correctness of the circuit. Test verification measures the effectiveness of a given set
of test vectors. A complete set of test vectors may guarantee a 100% fault coverage
but may not be practical to execute when the size of test vectors is high. All of
these considerations should be taken into account when designing a test strategy.
As mentioned in Abadir and Regubati [Ref. 5], test generation should consist of
three main activities:
• A good descriptive model should be selected for a system under consideration
to determine the behavior of the system in all possible combination modes of
operation.
• A fault model must be developed in order to describe the types of faults
identified during test generation. The important factor in selecting a fault
model is to maximize the percentage of faults covered by the model and to
minimize the test cost associated with the use of the model. Usually, a good
fault model is found as a result of a trade-ofF between these two parameters.
• The most essential part of the BIST process is to generate a test sequence to
detect all the faults in the fault model. Two major problems occur when gen-
erating a test sequence. To detect a certain fault in a digital circuit, the fault
must be excited, e.g., a certain test sequence must be applied that will force a
faulty value to appear at the fault location. The test must be sensitive to the
fault, e.g., the effect of the fault must be propagated through the network to
an observable output.
The fault must be able to be located following its detection. The strategy of
testing can be changed depending on whether the requirement to detect the fault
only, or to detect and locate the fault. The manual generation of test patterns is
a difficult, time consuming task even for moderate circuits. The challenge of fault
simulation and test verification has received a lot of attention, while the task of
test generation has been partially overlooked. Fault simulation has been the goal
of test generation, yielding a quantitative measure of test effectiveness. In other
words, a test sequence is considered good if it can detect a high percentage of the
possible faults in the circuit under test. Fault simulation should be able to predict
how a circuit will operate, therefore, the simulation program must be comprehensive
enough to detect it. The fault model and test pattern generation are reviewed below:
• Fault Simulation and Fault Model
Two major sources of failures occurring in integrated circuits are defects in the
manufacturing process and component wearout. The frequency of occurrences
and the relative importance of a fault depends on the circuit type and the
manufacturing technology used. By using any given physical fault mechanism
in a circuit, it is possible to determine its effect on the logical behavior of the
circuit. There are several advantages in using logical fault models rather than
physical fault models [Ref. 6]:
— Once a logical fault model adequately reflects the physical failure modes
of a circuit, the fault analysis becomes a logical problem.
- It is possible to construct logical fault models that are applicable to
many different technologies. In this case, fault analysis becomes relatively
technology-independent. The computer programs can then be written for
fault simulation and test generation without losing their usefulness when
changes in technology occur.
- By using a logical fault model, it is possible to perform a test for faults
in cases when the effect on circuit behavior is not clear.
— A logical fault model often covers a large number of different physical
faults, resulting in a substantial decrease in the complexity of fault anal-
ysis. There are five classes of logical faults [Ref. 7]:
* Input stuck-at faults - When each of the input lines may be stuck-at-0
or stuck- at- 1.
* Output stuck-at faults - When any number of output lines may be
stuck; each line may be stuck-at-0 or stuck- at- 1.
* Input bridgings - When any two input lines may be bridged. Bridging
(short circuit) faults have become increasingly important for VLSI
devices.
* Output bridgings - All bridgings between any number of output lines.
* Feedback bridgings - Bridgings between one input and one output
line.
A commonly used fault model is the stuck-at model. A faulty gate input in
a circuit is modeled as a stuck-at-0 (s-a-0) or stuck-at-1 (s-a-1). When a certain
number of test vectors are applied to the CUT, the percentage of fault coverage
depends on the number of s-a-0 or s-a-1 faults detected by the test patterns.
The stuck-at model does not take into account all possible defects, but acts
as a global type of model. This model assumes that a logical gate input or output
is fixed to either a logic or a logic 1. For example, the pattern applied to the
fault-free AND gate in Figure 2.1 has an output of 0, since the A input is on the
A input and 1 on the B input. But the pattern in Figures 2.2 shows an output
equal to 1, since the A input is perceived as a 1 even though a is applied to that
input. Therefore, the pattern shown in Figure 2.2 is a test for the A input (s-a-1),
because the good machine responds differently from the faulty machine [Ref. 8].
Some techniques are available to reduce the complexity of fault simulation, but it is
still a time consuming and expensive task. Testing of a sequential machine is more
difficult than with a combinational machine as the output of a sequential machine
depends on both the present input but also on the internal state of the machine.
One problem in Complementary Metal Oxide Silicon (CMOS) using this model
is that a number of faults could change a combinational network into a sequential
network. If this occurs, the combinational patterns are no longer effective in testing
the circuit. As mentioned previously, single stuck-at fault test sets seem to provide
acceptable levels of fault coverage for devices fabricated with current technology.
The major problem in developing test sets for multiple fault detection is the large
number of possible faults. For example, it is easy to verify that 10 nodes in a circuit
may have 20 single stuck-at faults, 180 double faults, 960 triple faults, and 59,048
possible stuck-at patterns [Ref. 9]. For VLSI circuits containing in excess of 10,000
nodes, explicit test generation for anything other than single faults is impractical.
In summary, fault simulation in VLSI circuit verification has some difficulties.
Increasing circuit complexity will increase the time consumption for the simulation
of all gate-level faults. However, consideration of only single-stuck faults may be
inadequate. Multiple faults, non-stuck faults and suspended temporarily at intervals
type faults are important but difficult to investigate [Ref. 10].
A commonly used test pattern generation is the D-Algorithm, developed by
Paul Roth [Ref. 11], is widely used to generate a test vector for a given fault.
This method is usually used with gate-level circuit models and stuck faults. This
algorithm attempts to construct a sensitized path over which an error signal can
propagate from the fault location to an observable primary output line. Using a
backtracking approach based on the circuit structure, the D-Algorithm searches the
space of possible test patterns for the given fault. This method, in its most general
form, can always find a test vector that can sensitize a single fault. In the case where
the fault is undetectable, it can prove that no test pattern exists. The D-Algorithm is
particularly well-suited to test generation for circuits designed using Level Sensitive
Scan Design (LSSD). A large number of practical test generation programs and
algorithms are based on the D-Algorithm [Ref. 6]. In Goel and Rosales [Ref. 11], a
new algorithm called PODEM is described in an attempt to reduce the backtracking
of the D-Algorithm [Ref. 1]. In the PODEM algorithm, the path from an output
node to a primary input is traced and branching decisions are made heuristically
at each step of backtrack. After reaching the primary input, a simulator checks if
the initial objective function has been achieved. If not, the algorithm will repeat
until the target fault is sensitized. For moderately large circuits, PODEM is proved
very effective. With the vast increase in circuit density, the ability to generate
test patterns automatically and to conduct fault simulation with these patterns
has decreased. Therefore, some manufacturers skip these difficult approaches and
accept the risks of shipping a defective product. One approach, called Design for
Testability, is used to reduce the cost of testing [Ref. 8].
B. DESIGN FOR TESTABILITY
Design for testability (DFT) is motivated by the need to reduce the costs of
testing. The main test considerations are difficulty of test generation, test sequence
length, test application cost, fault coverage and fault resolution. The costs involve
AB





Figure 2.2: Faulty AND Gate
the computer time required to generation the test pattern, the personnel to write
the test pattern program and to test the equipment [Ref. 6]. The DFT objective is
to design circuits from the outset to limit in magnitude the test generation efforts
and test verification [Ref. 12]. Testability relies on two concepts, controllability and
observability. Controllability is the ability to set and reset every node internal to
the circuit. Observability is the ability to observe (either directly or indirectly) the
state of any node in the circuit.
Three basic approaches to DFT are ad-hoc testing, a structured design ap-
proach, and built-in self testing. For the purpose of this thesis, the built-in self
testing is the method of concentration. Different techniques in built-in self testing
are described below [Ref. 13].
• Concurrent Built-in Logic Block Observers (CBILBO)
CBILBO offers many distinct features for both test application and response
analysis. First, the test length is the shortest among several BIST methods
studied. Thus, this scheme is suited to test large sequential machines. Sec-
ond, as test generation and signature analysis are separated, the proposed
approach generates exhaustive or pseudo-exhaustive tests for the circuit un-
der test. Thus, no test pattern generation program is necessary. Third, fault
simulation may not be needed. Fourth, the control sequence is very simple
as opposed to other BIST methods. Finally, on-line checking is possible. The
main disadvantage of this proposed method is that the hardware cost is higher
than other methods.
• Built-in Logic Block Observation (BILBO)
The BIST approach using BILBO is used to test sequential machines. In this
method, the signature data collected from the previous tests must be used as
10
the pattern for the next test. BILBO has a slightly lower hardware cost than
the CBILBO approach, however, it results in lower fault coverage. To obtain
a higher fault coverage, a detailed circuit analysis or fault simulation would
be needed.
• Scan BIST
The scan BIST approach is suited to test circuits where a scan path is employed
and is therefore recommended for scan- based designs, although the test length
is longer than the CBILBO or BILBO approach.
• Checking Experiment
The BIST approach using checking experiments have the longest testing time.
Since the testing time increases exponentially with the number of internal
states, it has comparable fault coverage and hardware overhead as other pre-
viously mentioned methods. These BIST schemes are not attractive to test
sequential machines. However, function-dependent checking experiment meth-
ods remain attractive, as lower hardware overhead can be obtained as com-
pared to other BIST methods.
BIST approaches have been applied either partially or fully to commercial mi-
croprocessors and gate arrays, although focusing on DC functional testing. Current
BIST techniques have difficulty achieving high fault coverage for sequential circuits
due to randomness of test patterns and aliasing probability, etc. The focus here is on
the BILBO approach. This technique combines the Scan Path and LSSD concepts
with Signature Analysis [Ref. 14]. The complete test generation and observation
arrangement can be implemented as shown in Figure 2.3 [Ref. 12]. The BILBO









Figure 2.3: The Complete Test Generation and Observation Arrangement
patterns, which will be applied to the combinational circuitry. The BILBO register
on the right is used as the signature analyzer. After a certain number of patterns are
applied, the signature generated by the signature analyzer will be compared against
the reference data [Refs. 8, 12]. In LSSD or other structure design techniques, a
considerable volume of test data is required with the shifting in and out. Using the
BILBO technique, the test data volume may be reduced by a factor of 100 for every
100 test patterns.
C. SIGNATURE ANALYSIS
A test response compression method is used to solve the problem of analyz-
ing and storing the large amount of data required for collecting responses. In this
method, response data R will be compacted to form f{R), including the fault infor-
mation.
The signature analysis technique was introduced in 1977 by Hewlett-Packard
[Ref. 15]. This technique should be used when it is not feasible to compare test
results with reference data. If the reference data is available at the same rate
and synchronized with the data being tested, there is no advantage in using this














itself. For example, microprocessor based boards stimulate themselves using the
intelligence of the processors driven by the memory on the board. The signature
and its collection algorithm should meet four qualitative guidelines [Ref. 11]:
• The algorithm must be simple enough to be implemented as part of the built-in
test network.
• The implementation must be fast enough to prevent it being a limiting factor
during test time.
• In order to minimize the reference-signature storage volume, the algorithm
must provide logarithmic compression of the output response data.
• The compression method must not lose information, especially if a fault is
indicated by a wrong response from the CUT.
13
1. Signature Analysis
The integral part of the Signature Analysis is the Linear Feedback Shift
Register (LFSR) or Multiple Input Signature Register (MISR) (See Figure 2.4).
Basically, LFSR is built up of latch, with feedback connections. A polynomial
of degree n relates to an n-stage LFSR. The output of the last stage and some
intermediate stages are fedback to the first stage via XOR-gates. The first and the
last stage are at the rightmost and leftmost bit positions respectively, if the register
shifts from right to left. The input from the CUT also feeds to the first stage via
XOR-gate. In general, for any response data stream of length greater than 4, the
probability of missing a faulty response when using an n-bit signature analyzer is




where m is the number of stages. As most practical circuits have many outputs,
a MISR is used to form a signature of the CUT. The MISR circuit is currently
considered to be the most efficient means of producing a signature of a multiple-bit
data stream [Ref. 16]. The MISR is basically similar to LFSR, the main difference
being the XOR placed between each stage in MISR and the output of the CUT.
The output of CUT will feed into each stage via these XOR gates.
2. Advantage
The major advantage derived by this approach is that the number of bits




The major disadvantage of this approach is the difficulty to drive any
information from the signature beyond a yes/no decision. It is difficult enough to
investigate failure from the failing signature. Consequently, a failure in one node will
cause failures to be observed at any other nodes [Ref. 18]. One problem when using
signature analysis is that the volume of information contained in the signature is
less than the volume of information contained in the actual data [Ref. 18]. Another
problem using signature analysis is aliasing error, discussed in Chapter III.
15
III. ALIASING IN MISR
Using the signature analysis techniques for testing circuits, considerable amount
of attention has been paid to the aliasing problem: the result found in the signature
analysis register is correct, however, the Circuit Under Test is in fact faulty. We
restrict our discussion for combinational CUT.
Figure 3.1 shows an example of the experimental set-up for signature analysis.
The CUT is supplied with a set of test patterns that is generated by a LFSR. The
output of the CUT goes into the multiple input signature register (MISR) which is
used as a compressor. Since the CUT is combinational, one does not have to deal
with the initialization of the CUT. In addition, test patterns from LFSR are applied
to the CUT synchronously. Therefore, the first pattern is applied to CUT after
a certain time has passed such that the results are available at the output of the
circuit and available at the input of the MISR. The MISR will change to a new value
and wait for the next value from the CUT. Before starting a test, we must initialize
the LFSR and MISR. When all the test patterns have been applied, the contents of
the MISR form the signature that is compared to a reference value. Following this
comparison, the determination is made whether the circuit response is faulty or not.
1. Aliasing Probability
The problem of aliasing is generally characterized as a probability. The
most widely accepted measure is the probability of aliasing in MISR. It is generally
assumed that the probability of error in each bit is p, i.e., equally likely, and all of
the inputs are independent. Under this assumption, as developed in the previous




Figure 3.1: Experimental Set-up for Signature Analysis
independent of the efFect of the fault on the output of the CUT. The probability
of aliasing depends only on the number of stages of the MISR. Therefore, in order
to reduce the probability of aliasing, the length of the MISR must be increased.
For instance, adding one stage to the MISR reduces the probability of aliasing by a
factor of 2. Unfortunately, the "equally likely" assumption on bit error probability
seems unreasonable for a practical circuit [Ref. 19].
2. Notation and Definition
As mentioned above, the k available outputs of the CUT are connected
to the k MISR inputs. If MISR has more inputs than CUT outputs, the remaining
free MISR inputs will be assumed to be connected to a dummy CUT output [Ref.
20]. The operation of the MISR of length k can be described in matrix notation.
The state of the register can be represented by a column vector:
17
Y(t) = [yi (t),y2(t),--,yk(t)]
T
-
and the CUT outputs can be represented by a column vector:





The next state of the register is calculated by multiplying the current state vector
by the next state matrix, C, and adding the current input to the product. Note






V yk {t) I \ ° ° °
Equation 3.3 can be rewritten as,






( x x {t) \
x2 (t)
\ x k (t) )
(3.3)
Y{t) = C-Y(t- 1)©A'(0 (3.4)
The autonomous behavior of the register is described by Equation 3.4 by setting all
input bits in Equation 3.2 to zero
*i(t) = *aM = ••• = **(*) = 0- (3.5)
In the event of a fault in the CUT, the present output vector can always be repre-
sented as the linear superposition of the correct-circuit sequence,
G(t) = [g 1 (t),g2 (t),---,gk (t)f (3.6)
and an error sequence,

















In case the fault is not detected in CUT, the
ei (t) = e 2 (t) = = e k (t) = (3.10)
After n clock cycles, the state of the MISR can be computed by applying iteratively
Equations 3.4 and 3.9. It has been shown that x(t) consists of bitwise modulo-2
sum of the fault free circuit outputs with the assumption that the register is in the
initial state [Ref. 20]. Consequently, an aliasing event occurs if the error sequence
is applied and if there is at least one nonzero element in the error sequence to cause
the MISR to return to an initial state.
3. Aliasing and Markov Process
William and Dahne [Ref. 19] stated that a Markov process is very similar
to that of a sequential machine. This means that a Markov process can be defined in
terms of state transitions. If the input sequence to the signature register is random,
the transition is done with the probabilities of the respective input symbol. When
this process occurs, the transition diagram for the Markov process has the same
behavior as the operation of the signature register with random signals at the input
is obtained (See Figure 3.2). Based on the facts above, the calculation is made that









Figure 3.2: Transition Diagram of the Markov Process for LFSR Imple-
menting x 2 -\- x -\- 1.
In the next chapter, we will investigate the aliasing probability by discussing
the results of an experimental work.
20
IV. A TEST SYSTEM ARCHITECTURE
A. SYSTEM ARCHITECTURE
The purpose of this section is to investigate the aliasing probability in BIST by
using MISR as a compressor. To illustrate the function, some circuits were connected
as one overall chip. The Linear Feedback Shift Register (LFSR) is used as a test
pattern generator, the Full Adder is used to represent Circuit Under Test (CUT)
and finally, the Multiple Input Signature Analysis (MISR) is used as a compressor to
reduce the cost of testing. We now explain each circuit in the next three subsections.
1. Linear Feedback Shift Register as a Test Pattern Generator
The most popular hardware pseudorandom sequence generator is the Lin-
ear Feedback Shift Register [Ref. 21]. The binary sequence at cell i is generally con-
sidered to display attributes of pseudorandom binary sequence. The basic structure
of LFSR consists of the shift register comprised of a number of stages, with feedback
connections based upon the primitive polynomials used. Primitive polynomials are
used as a base structure because they can generate maximum length sequences. For
instance, a maximum length sequence generator with ??-stages can deliver 2n — 1
distinct n bit long patterns except the zero pattern. Since we have to connect out-
puts of LFSR to inputs of CUT, the number of stages of the LFSR depends on
the number of inputs of CUT. Therefore, the degree of primitive polynomials used
depends on the number of CUT input. For instance, a 4-bit adder requires 8 stages
of LFSR, or primitive polynomials of a degree of 8. Some unique properties of LFSR
that implements a primitive polynomial are listed below [Ref. 21]:
• Staggering Relationship among successive outputs
21
inpul
msf(4 < - ms(f3^- msff2<--Uor2j^— msffl^-4,
k j
Figure 4.1: LFSR Described by Polynomial x 4 + x + 1
If the contents of the stages are used directly as pattern outputs, then the
bit-streams obtainable from the stages will contain basically the same bit-
sequence, but the bit pattern will be staggered by i cycle in each stage relative
to the one on its left.
• Cyclic Periodicity
The pattern generated will continue through 2 n — 1 cycles, and after that, the
content of stages will become the starting pattern and the sequence will repeat
periodically.
• Exclusion of all pattern
The LFSR should not be initialized with all 0, because in this case the feedback
is always 0. The contents of the stage will remain in all shift cycles and the
LFSR can not generate any nonzero pattern.
• Superposition Effects
22
This is a very important property of LFSR which occurs from the influence
of the individual seedbits in a LFSR. The sequence pattern generated by the
LFSR using one initial value is seen to correspond, cycle for cycle, to the XOR
(module-2-add) sum of the patterns in the other sequence pattern that uses
two different initial values.
2. Full Adder as a Circuit Under Test
A Full Adder is a three input, two output combinational circuit that adds
two 1 bit binary numbers. The Full Adder circuit is shown in Figure 4.2. To build
an adder for 4 bit words, the full adder is replicated four times. In the experimental
4-bit Full Adder used, the carry out of one bit was used as the carry into its left
neighbor. The carry into the right most bit is wired to 0. Adders that do not
have this ripply carry delay, and hence are faster, also exist. An example of a 1 bit
full-adder is shown in Figure 4.2. [Ref. 22]
3. Multiple Input Signature Register as a Compressor
The structure of MISR generated is basically similar to an LFSR. The
only difference is that the input stream for each stage feeds through an XOR gate.
Therefore, the number of stages is equal to the number of input XOR gates. In each
test cycle, the output of each stage will be XORed with a bit of an input stream
and shifted to the next stage to the left. The feedback configuration is based on the
primitive polynomials used, and also must be XORed with an input stream. Two
general structures can be considered for implementing MISR: external XOR and
internal XOR [Ref. 20]. We are concerned in this thesis only with the internal OR
structure due to its economical implementation [Ref. 23]. As in LFSR, the structure
of MISR also depends on the output of the CUT. For instance, using a CUT with






Figure 4.2: Full Adder
SUM
24
are required. If the CUT has fewer outputs than k, the remaining free MISR inputs
will be assumed to be connected to dummy CUT outputs, i.e., constantly [Ref.
4]. Both the state of the MISR and the CUT output can then be represented by
vectors of k bits.
B. GENERATOR
Software provided by NW Laboratory for Integrated Systems [Ref. 24] was
used to simulate the network. The network description file for LFSR, MISR, and
Full Adder (CUT) was created by using subroutines written in "C". The program
listing may be found in Appendix A. Three generators were created:
• GLFSR - to generate a network description file for Linear Feedback Register
for a given primitive polynomial [Ref. 23].
• GADD - to generate a network description file for a ripple carry adder.
• GMISR - to generate a network description file for Multiple Input Signature
Register for any primitive polynomials.
The network description file may be found in Appendix B.
C. TEST CIRCUIT
Finally, the GTEST combines LFSR, adder, and MISR into one module and
generates a connection description file. Besides, the GTEST can simulate the entire
module. CAD tools used in GTEST include the following:
• NETLIST - creates a flattened netlist representation from an hierarchical rep-
resentation;
• PRESIM - creates a binary circuit representation from the flat circuit repre-
sentation;
25
• GEN_TIME - converts a simple timing file in a RNL compatible format;
• RNL - Runs the simulation.
The pattern generator GLFSR, the compressor GMISR, and the CUT will
be combined to form a network description file created by GLFSR, GMISR and
GADD. This description file is converted to an intermediate file by using NETLIST
command. Another conversion occurs when producing a binary file suitable for use
in RNL and is done by the PRESIM command. RNL requires a file that contains a
sequence of RNL commands. At the very least, this command file should load one
or more libraries of standard functions and should read in the binary description of
the circuit created by PRESIM. The command file should also contain command
and definitions of LISP function [Ref. 24].
D. EXPERIMENTAL SET-UP
To demonstrate BIST circuitry, a 4 bit full-adder is used as a Circuit Under
Test (CUT). As each adder has two inputs, an 8 stage LFSR is needed. This would
feed 8 outputs into the CUT. The primitive polynomial used to generate the LFSR
is x
8 + x6 + x5 + x3 + 1. As a 4 bit full-adder has 5 outputs, 4 sums and 1 carryout,
a 5 stage MISR is needed. The MISR can be described by the primitive polynomial
x
5 + x 2 + 1. Examples for 2 and 8 bit full-adders will also be shown. Figure 4.3
shows the experimental set-up.
Before starting the experiment, an initial value for the LFSR must be given.
The LFSR generates test patterns that feed into the CUT. Outputs of the good CUT
feed into the MISR and generate signatures to be used as reference data. Next, we
create a faulty CUT with stuck-at-0 by connecting one node in the last bit of the
full-adder to the GND. Figure 4.4 depicts flowcharts of the generation of LFSR,









Figure 4.3: Experimental Set-up
Run GLFSF Run GADD
| 1
,
/ Input lor /
/Ueg S pol eq /
/ Gel user /
/ Inpul In' /


























Figure 4.4: The Flow to Generate LFSR, Full-Adder, MISR and the
Combination of all Circuits into One Module
27
The derived signature will be compared with reference data to investigate the
possibility of aliasing. To observe aliasing in different fault locations, the node is
connected with Vdd, named stuck-at-1, and the signature compared with the refer-
ence data. The experiment repeats with a different error by changing the connection
of the node. An example of this is to connect the node of the first bit full-adder
with GND and Vdd, respectively.
E. EXPERIMENTAL EVALUATION
To investigate the probability of aliasing, a set of simulations were performed
on three different CUTs with different polynomials of LFSR and MISR. The first
experiment uses a 2 bit full-adder as the CUT. In this experiment, the LFSR is
described by the polynomial x 4 + x-f 1, and the MISR is described by the polynomial,
i 3 + i + 1. Table 4.1 shows the aliasing probability for s-a-0 and s-a-1 faults with
different initial states of LFSR. The aliasing probability is calculated by dividing the
undetected occurrances with the total number of test vectors applied to the CUT.
In our experiments, we always use 2" — 1 test vectors for an n-input adder since
the largest adder under test is 8 bits, i.e., with a total of 16 inputs. The location of
the stuck-at fault is at the input of the OR gate as shown in Figure 4.5. This OR
gate is the LSB of the adder. The value for the SUM is equal in the cases of s-a-0,
s-a-1, and fault free circuits. The only difference is the value of the carry-out for the
s-a-1 circuit, which is less than the carry-out value of s-a-0 and fault free circuits.
Therefore, a circuit with a s-a-0 fault will produce test patterns almost equal to
that of the fault free circuit but causes aliasing of a s-a-0 fault to be greater than
in a s-a-1 fault. Table 4.1 also shows that the possibility of aliasing is the same for
different initial states and that aliasing probability in an s-a-0 fault is greater than
with a s-a-1 fault. The second experiment uses a 4 bit full-adder as CUT, with the
28
TABLE 4.1: ALIASING PROBABILITY WITH DIFFERENT INITIAL
STATES OF LFSR ON 2-BIT ADDER







LFSR described by the polynomial xg + x6 + x 5
-f x
3 + 1, and the MISR described
by the polynomial, x 5 + x 2
-f 1. An interesting case of aliasing was found in this
experiment that showed the potential for the aliasing probability to be 1. Figure 4.6
shows that Pa i = 1 for s-a-0 fault and for s-a-1 Pa i — 0.01667 (Figure 4.7), where the
position of the stuck-at fault is at the input of the XOR gate in LSB that produces
SUM. Table 4.2 shows the expected value of SUM for good CUT using two different
values of carry-in. Table 4.3 shows the value of SUM for two different faults.
By comparing Tables 4.2 and 4.3, the result shows that if the carry-in in the
good circuit equals 0, the SUM will be equal for both the good and bad CUT.
However, if the carry-in in the good CUT equals 1, then the aliasing probability in
s-a-1 fault equals 1. This is shown in Figure 4.8. For s-a-0, Pa i = 0.0333, as shown











Figure 4.5: One Bit Full Adder with s-a-fault














-AljLxLsJL^vg Ln__MJL S R_,_w jjji . 6 6 /
Figure 4.7: The Aliasing Probability in s-a-1 Fault
TABLE 4.2: EXPECTED VALUE OF SUM FOR GOOD CUT




1 1 1 1 1
31
TABLE 4.3: THE VALUE OF SUM FOR DIFFERENT S-A-FAULTS
Node x Node x




1 1 1 1 1
changed to the input of AND gate. Table 4.4 shows the aliasing in s-a-0 and s-a-1
faults for different initial states of LFSR.
Table 4.4 demonstrates that the actual aliasing probabilities are greater than
the aliasing probability calculated given by the formula in Section 3.3. For example,
if a 5 stage MISR is used, then the aliasing probability is calculated as Pa i = ^ =
0.03125 instead of 0.0333. As in previous experiments, the aliasing in s-a-1 faults is
less than aliasing in s-a-0 faults.
The third experiment uses an S bit full-adder as CUT. The LFSR is described




2 + 1 and the MISR is described by the polynomial
x
9 + x 4 + 1. Table 4.5 shows the aliasing in s-a-0 and s-a-1 faults for four different
initial states of LFSR.
Table 4.5 shows that almost all of the probability of aliasing, either in the
s-a-0 fault or in the s-a-1 fault, is equal to 0. These results are close to the aliasing
probability as calculated by the formula. For example, with a 9 stage MISR, the
32





Alia sing in MIS R with PA : 0.03333
1 2 30 40
Test Length
5
Figure 4.9: The Aliasing Probability in s-a-0 Faults Using 5 Stages MISR
33
TABLE 4.4: ALIASING PROBABILITY IN 5 STAGE MISR WITH
DIFFERENT INITIAL STATES






TABLE 4.5: ALIASING PROBABILITY IN 9 STAGE MISR WITH
DIFFERENT INITIAL STATES







Figure 4.10: Aliasing Probability in 9 Stages MISR
aliasing probability is 2~ 9 or 0.0019. Figure 4.10 shows a similar signature for good
and bad CUT. The only difference is that the good circuit has higher pattern values
than the circuit with the s-a-0 fault. By observing the aliasing in cases described
above, it is demonstrated that the aliasing in s-a-1 faults is smaller than aliasing
in s-a-0 faults. Also shown is that with increasing numbers of stages of MISR, the
aliasing probability will decrease as stated [Ref. 19].
35
V. CONCLUSIONS
The testing of an integrated circuit chip is as important as its design. If the
chip designed is to be used in a network, it is essential to verifty that it performs
the intended function. This testing requirement must be considered during the
design phase. One approach used in this thesis is the Built-in Self Test (BIST),
where a Linear Feedback Shift Register (LFSR) is used as a pseudorandom sequence
generator. An LFSR may generate 2 n — 1 test patterns into a circuit under test
(CUT).
Several experiments were performed using a full adder as the cut with a MISR
as a compressor. The set of programs were written to stimulate the LFSR, MISR
and full-adder (CUT) for different polynomials according to the width of the adder.
Several experiments have been performed to investigate the aliasing probability in
MISR by using different polynomials of LFSR, MISR, and different sizes of full-
adder. By using the Markov process approach, it was proven that the probability
of aliasing in n stage of MISR is approximated by 2_n [Ref. 19] . The aliasing
observed in the experimentation process closely replicated the formula. In order to
get accurate aliasing probability, an experiment having length 2m — 1 must be tested,
where m is the number of stages of LFSR. For example, using 16 stages of LFSR
required a 65535 test length to use all the test patterns generated by the LFSR.
By observing all of the aliasing probabilities for different circuits, the experiments
allowed us to conclude that the aliasing probability in s-a-1 fault is not always the
same as that in a s-a-0 fault. A second conclusion is that if the number of stages of
MISR is increased, the aliasing will be reduced as expected and the value of aliasing
in either s-a-0 or s-a-1 is greater than the aliasing probability calculated.
36
APPENDIX A
Programs For Thesis Project












char f ilebase[fname_len] , memory [40]
;
char f b [fname_len]
;
char f c[fname_len]
char f s [fname_len]





printf ("\n\tEnter file name : ");
scanf C'/.s" ,f ilebase) ;




printf ("\n\tEnter number of bits : ")
;
scanf ( M,/.d",&N) ;
/*























fprintf (fid, "invin'/.dl invin'/,d2 invin'/,d3"










fprintf (fid, "norin'/.dl noriny,d2"













fprintf (fid, "xoro'/.dl xoro'/,d2"







fprintf (fid, "xori'/.dll xori*/.dl2 xori*/,d21 xori'/,d22 M






fprintf (fid, "nandout'/.dl nandouty.d2"














fprintf (fid, ") ") ; newline; newline;
for(i=N; i>0; i--)
{
fprintf (fid, M (xor2 xoro'/.dl xori'/.dll xori'/.dl2 )\n",i,i,i);







fprintf (fid, "(cnand nandout'/.dl nandin'/.dll nandin'/,dl2 )\n",i,i,i);













fprintf (fid, "(cinvert invout'/.dl invin'/,dl)\n" ,i,i) ;
fprintf (fid, "(cinvert invout'/,d2 invin'/,d2)\n" , i , i) ;





for (i=N; i>0; i--)
<
fprintf (fid, "(connect a'/,d xori'/.dll)" , i ,i) ; newline;
fprintf (fid, "(connect b'/.d xori'/,dl2) " ,i , i) ; newline;
fprintf (fid, "(connect carin'/.d xori'/,d21)" ,i,i) ; newline;
fprintf (fid, "(connect xoro'/.dl xori'/,d22) "
, i ,i) ; newline;






for (i=N; i>0; i--)
{
fprintf (fid, "(connect a'/.d nandin'/.dll) " , i , i) ; newline;
fprintf(fid, "(connect b'/,d nandin'/,dl2) " , i ,i) ; newline;




for (i=N; i>0; i—
)
{
fprintf (fid, "(connect xoro'/.dl nandin'/,d21)" ,i,i) ; newline;
fprintf (fid, "(connect carin'/,d nandin'/,d22)" ,i ,i) ; newline;
newline;
fprintf (fid, "(connect nandout'/,d2 invin'/,d2)" ,i ,i) ; newline;
}
newline;
for (i=N; i>0; i--)
{
fprintf (fid, "(connect invout'/.dl norin'/.dl) " , i , i) ; newline;
fprintf (fid, "(connect invout'/,d2 norin'/,d2)" , i , i) ; newline;
}
newline;
for (i=N; i>0; i—
)
{
fprintf (fid, "(connect norout'/.d invin'/,d3)"
, i , i) ; newline;




for (i=N; i>=2; i--)
i





CREATE A FLATTENED NETLIST REPRESENTATION AND A BINARY CIRCUIT
REPRESENTATION.
*/
















Multiple Input Signature Register


















char f s [fname_len]






int cO = 1, cl = 1
int c2 = 1 , c3 = 1
int c4 = 1 , c5 = 1
int c6 = 1, c7 = 2;
int c8 = 1 , c9 = 1
int k = 1 , m =1















strcat(f ilebase, " .net")
;
fid= fopen(f ilebase , "w")
;
fprintf (fid, "(load V'lib .net\")\n")
;
fprintf (fid, "(load \"xor2 .net\")\n")
;
fprintf(fid, "(load \"xor3 .net\")\n")
newline
;
fprintf (fid, "("); newline;
fprintf(fid, "node r cl ");
newline; newline;
for(i=l; i<=N; i++) {




for(i=l; i<=N; i++) {




for(i=l; i<=N; i++) {




while (N == 0);
max[N] = 1;
max[0] = 1;
for (i = N-l; i>0; i--)
{
printf ("\n\tX~y.d Enter coef . 1 or : ",i);
scanf 07.d",&max[i]);
if (max[i] != 1)
max[i]=0;
}
printf (" \n\n\tX-'/.d + ",N);
for (i=N-l; i>0; i--)
{
if (max[i] == 1)
printf ("X-/.d + ",i);
}
printf ("l\n");
for (i=N-l; i>0; i--)
{
























fprintf (fid, ") "); newline; newline;













for (i=N-l; i>0; i--)
{
if (max[i] == 1)
{
fprintf (fid, "(connect ffi'/.d xorout3'/,d) " ,N,c2) ; newline;
c2++;
fprintf (fid, "(connect xorin3'/,dl f fo'/,d)" ,c8 ,N-1) ; newline;
fprintf (fid, "(connect xorin3'/.d2 f f o'/.d)" ,c8 ,M) ; newline;







else if (max[i] == 0)
{
fprintf (f id, "(connect ffi'/.d xorout2'/,d) " ,N ,c6) ; newline;
c6++;
fprintf(fid, "(connect xorin2*/,dl f f o'/,d) " ,c9 ,N-1) ; newline;






fprintf(fid, "(connect ffi'/.d xorout2*/,d)" ,c4,c6) ; newline;
fprintf(fid, "(connect xorin2'/,dl ff o'/,d) " ,c9 ,M) ; newline;




CREATE A FLATTENED NETLIST REPRESENTATION AND BINARY CIRCUIT
REPRESENTATION.
*/
sprintf (memory ."netlist '/.s.net '/.s.sim -tcmos-pw" ,fb,fb) ;
system(memory)
;










LFSR, CUT, and MISR.














char f ilebase[fname_len] , memory [40];
char fb[fname_len] , f c [fname_len] , f s [fname_len]
;
char fa[fname_len] , fm[fname_len] , f 1 [fname_len]





printf ("\n\tEnter file name for lfsr : ")
scanf('7.s n ,fl);
printf ("\n\tEnter file name for full adder : ")
scanf 07,s",fa)
;
printf ("\n\tEnter file name for misr : ")
scanf ('7,s",fm);
printf ("\n\tEnter file name for bist : ")



























fid= fopen(f ilebase, "w")
;
fprintf (fid, "(load \"lib.net\")\n")
;
fprintf(fid, "(load \"'/.s .net\")\n" ,f a)
fprintf (fid, "(load V7.s .net\")\n" ,fm)
fprintf(fid, "(load \"7.s .net\")\n" ,f 1)
newline;
for (i=2*N; i>0; i=i-2)
C
fprintf (fid, "(connect ffout'/.d a'/.d)" ,i ,i/2) ; newline;
}
newline;
for (i=2*N-l; i>0; i=i-2)
{




fprintf (fid, "(connect carout'/.d in'/.d)" ,T,M) ; newline;
for (i=M-l; i>0; i--)
{






CREATE A FLATTENED NETLIST REPRESENTAION
.
*/




sprintf (memory ,"presim '/.s.sim '/,s" ,fb,fb) ;
system(memory)
/*






fprintf (f id, "time_range y,d",rr); newline;
fprintf (fid, "carinl 2 10 1 1"); newline;
fprintf (fid, "input OhOhl 12131 4"); newline;
fprintf (fid, "cl 2 1 h 1"); newline;
fprintf (fid, "report 1 0"); newline;
f close(f id)
;








fprintf (fid, "(load \"uwstd.l\")") ; newline;
fprintf (fid, "(load \"uwsim.l\")") ; newline;
fprintf (fid, "(log-file V7.s .rlogV) " ,f s) ; newline;
fprintf (fid, "(read-network V7.s\")" ,f s) ; newline;
fprintf (fid, "(setq incr 100)"); newline;
fprintf (fid, "(sim-init)") ; newline;
fprintf (fid, "(sim-init)"); newline;
fprintf (fid, "(def -report '(\" \" ");
for(i=M; i>0; i--){
fprintf (fid, "ffo'/.d ",i);
}
for(i=N; i>0; i--){
fprintf (fid, "sum'/.d ",i);
}
fprintf (fid, "))"); newline;
fprintf (fid, "(setq lanalyze t)"); newline;
fprintf (fid, "(wr-format)") ; newline;
fprintf (fid, "(load V7.s.timeV*)",fs) ; newline;
fprintf (fid, "exit"); newline;
fclose(f id)
;
sprintf (memory, "rnl y,s.l",fs);
system(memory)
;







lib.net - Library File
(1) CMOS INVERTER
; (2) NODES IN THE NETWORK
(node in out)
; (3) P-CHANNEL
(ptrans in out Vdd 8 8)
; (4) N-CHANNEL
(etrans in GND out 4 8)
; (5) CAPACITANCE
(capacitance out 0.03)
(l)MACRO DEFINITION FOR CMOS LATCH
(2)NAMING THE MACRO AND ITS PARAMETERS
macro latch (out in cl cl-)
(3)DECLARATI0N OF THE NODES LOCAL TO THE LATCH
(local nl)
(4) FIRST CLOCKED CMOS INVERTER
clkinv nl in cl cl-)
(5)UNL0CKED CMOS INVERTER
(cinvert out nl)
(6)SEC0ND CLOCKED CMOS INVERTER
(clkinv nl out cl- cl)
(7)CL0SING PARENTHESIS FOR THE MACRO
)
(l)MACRO DEFINITION FOR CMOS MASTER SLAVE FLIP-FLOP
(2) NAMING THE MACRO AND ITS PARAMETER
(macro msff (out in cl)
48




(latch nl in cl n2)
; (5)SEC0ND LATCH
(latch out nl n2 cl)
; (6)CM0S INVERTER
(cinvert n2 cl)
; (7)CL0SING PARENTHESIS FOR THE MACRO
)
49
XOR2.net - 2 Input XOR Gates
;macro name
(macro xor2 (out il i2)
; local node






(ptrans il- pi Vdd 8 8)
(ptrans i2 out pi 8 8)
(ptrans il p2 Vdd 8 8)
(ptrans i2- out p2 8 8)
;pull down
(etrans il- p3 out 4 8)
(etrans i2- GND p3 4 8)
(etrans il p4 out 4 8)




XOR3.net - 3 Input XOR Gates
;macro name
(macro xor3 (out a b c)
; local node






(ptrans a pi Vdd 8 8)
(ptrans a- p2 Vdd 8 8)
(ptrans a- p3 Vdd 8 8)
(ptrans a p4 Vdd 8 8)
(ptrans b- out pi 8 8)
(ptrans b out p2 8 8)
(ptrans c out p3 8 8)
(ptrans c- out p4 8 8)
;pull down
(etrans a- p5 out 4 8)
(etrans b- p5 p6 4 8)
(etrans c- GND p6 4 8)
(etrans a p7 out 4 8)
(etrans b p7 p8 4 8)































(msff ffoutl ffinl cl)
(msff ffout2 ffin2 cl)
(msff ffout3 ffin3 cl)
(msff ffout4 ffin4 cl)
(msff ffout5 ffin5 cl)
(msff ffout6 ffin6 cl)
(msff ffout7 ffin7 cl)
(msff ffout8 ffin8 cl)
(xor2 xoroutl xorinll xorinl2 )
(xor2 xorout2 xorin21 xorin22 )
(xor2 xorout3 xorin31 xorin32 )
52


















gadd4.net - 4 Bit Fault-Free Full-Adder
(node
a4 b4 carin4 carout4 sum4
a3 b3 carin3 carout3 sum3
a2 b2 carin2 carout2 sum2





















xori411 xori412 xori421 xori422
xori311 xori312 xori321 xori322
xori211 xori212 xori221 xori222






nandin411 nandin412 nandin421 nandin422
nandin311 nandin312 nandin321 nandin322
nandin211 nandin212 nandin221 nandin222
nandinlll nandinll2 nandinl21 nandinl22
)
(xor2 xoro41 xori411 xori412 )
(xor2 xoro42 xori421 xori422 )
(xor2 xoro31 xori311 xori312 )
(xor2 xoro32 xori321 xori322 )
(xor2 xoro21 xori211 xori212 )
(xor2 xoro22 xori221 xori222 )
(xor2 xoroll xorilll xorill2 )
(xor2 xorol2 xoril21 xoril22 )
(cnand nandout41 nandin411 nandin412
(cnand nandout42 nandin421 nandin422
(cnand nandout31 nandin311 nandin312
(cnand nandout32 nandin321 nandin322
(cnand nandout21 nandin211 nandin212
(cnand nandout22 nandin221 nandin222
(cnand nandoutll nandinlll nandinll2
(cnand nandoutl2 nandinl21 nandinl22
(nor norout4 norin41 norin42 )
(nor norout3 norin31 norin32 )
(nor norout2 norin21 norin22 )



















































































a4 b4 carin4 carout4 sum4
a3 b3 carin3 carout3 sum3
a2 b2 carin2 carout2 sum2





















xori411 xori412 xori421 xori422
xori311 xori312 xori321 xori322
xori211 xori212 xori221 xori222






nandin411 nandin412 nandin421 nandin422
nandin311 nandin312 nandin321 nandin322
nandin211 nandin212 nandin221 nandin222
nandinlll nandinll2 nandinl21 nandinl22
)
(xor2 xoro41 xori411 xori412 )
(xor2 xoro42 xori421 xori422 )
(xor2 xoro31 xori311 xori312 )
(xor2 xoro32 xori321 xori322 )
(xor2 xoro21 xori211 xori212 )
(xor2 xoro22 xori221 xori222 )
(xor2 xoroll xorilll xorill2 )
(xor2 xorol2 xoril21 xoril22 )
(cnand nandout41 nandin411 nandin412
(cnand nandout42 nandin421 nandin422
(cnand nandout31 nandin311 nandin312
(cnand nandout32 nandin321 nandin322
(cnand nandout21 nandin211 nandin212
(cnand nandout22 nandin221 nandin222
(cnand nandoutll nandinlll nandinll2
(cnand nandoutl2 nandinl21 nandinl22
(nor norout4 norin41 norin42 )
(nor norout3 norin31 norin32 )
(nor norout2 norin21 norin22 )



















































































a4 b4 carin4 carout4 sum4
a3 b3 carin3 carout3 sum3
a2 b2 carin2 carout2 sum2





















xori411 xori412 xori421 xori422
xori311 xori312 xori321 xori322
xori211 xori212 xori221 xori222






nandin411 nandin412 nandin421 nandin422
nandin311 nandin312 nandin321 nandin322
nandin211 nandin212 nandin221 nandin222
nandinlll nandinll2 nandinl21 nandinl22
)
(xor2 xoro41 xori411 xori412 )
(xor2 xoro42 xori421 xori422 )
(xor2 xoro31 xori311 xori312 )
(xor2 xoro32 xori321 xori322 )
(xor2 xoro21 xori211 xori212 )
(xor2 xoro22 xori221 xori222 )
(xor2 xoroll xorilll xorill2 )
(xor2 xorol2 xoril21 xori.122 )
(cnand nandout41 nandin411 nandin412 )
(cnand naindout42 nandin421 nandin422 )
(cnand nandout31 naLndin311 nandin312 )
(cnand nandout32 nandin321 nandin322 )
(cnamd nandout21 nandin211 nandin212 )
(cnand nandout22 nandin221 nandin222 )
(cnand nandoutll nandinlll nandinll2 )
(cnand nandoutl2 nandinl21 nandinl22 )
(nor norout4 norin41 norin42 )
(nor norout3 norin31 norin32 )
(nor norout2 norin21 norin22 )








































































































xorout31 xorin311 xorin312 xorin313
)
(msff ffol ffil cl)
(msff ffo2 ffi2 cl)
(msff ffo3 ffi3 cl)
(msff ffo4 ffi4 cl)
(msff ffo5 ffi5 cl)
(xor2 xorout21 xorin211 xorin212 )
(xor2 xorout22 xorin221 xorin222 )
(xor2 xorout23 xorin231 xorin232 )
(xor2 xorout24 xorin241 xorin242 )
66



















1. Williams, T. W., VLSI Testing, Elsevier Science Publishers, B.V. (North-
Holland), pp. 29-30, May 198G.
2. Bhaskar, K. S., Signature Analysis: Yet Another Perspective, International
Test Conference, pp. 132-134, November 1982.
3. Zuxi, Sun, "Self-Testing of Embedded RAMs", International Test Confer-
ence, October 1984, pp. 148-156.
4. Damiani, M., Olivio, P.,and Favalli, M., "Aliasing in Signature Analysis Test-
ing With Multiple-Input Shift Register", European Test Conference, April
1989, pp. 346-353.
5. Abadir, M. S v and Regubati, II. K., "LSI Testing Techniques", IEEE Micro,
February 1983, pp. 34-51.
6. Breuer, M. A., and Carlan, A. J., "State of the Art Assessment of Testing
and Testability of LSI/VLSI Circuits", Engineering Group Report, October
1982, pp. 10-11.
7. Karpovsky, M., "Universal Tests Detecting Input/Output Faults in Almost
All Devices", International Test Conference, November 19S2, pp. 52-53.
8. William, T. H., and Parker, K. P., "Design for Testability - A Survey", Pro-
ceedings of the IEEE, Vol. 71, No. 1, January 1983, pp. 98-112.
9. El-Zig, Y. M v and Cloutier, R. J., "Functional Level Test Generation for
Stuck-Open Faults in CMOS VLSI", International Test Conference, October
1981, pp. 536-546.
10. Roth, J. P., "Diagnosis of Automata Failures: A Calculus and A Method",
Journal of Research and Development, Vol. 10, October 1966, pp. 278-291.
11. Bardell, P. II., Built-in Test for VLSI, John Wiley & Sons, August 1987, pp.
10-11.
12. Weste, N.,and Eshraghian, K., Principles of CMOS VLSI Design, A System
Perspective, Addison- Wesley, Reading, Massachusetts, 1985.
13. McCluskey, E. J., and Wang, L. T., "Built-in Self Test for Sequential Ma-
chines", International Test Conference, September 1987, pp. 334-340.
14. Koenemann, B., Mucha, J., and ZvvieholT, G., "Built-in Logic Block Obser-
vation Techniques", International Test Conference, October 1979, pp. 37-41.
68
15. "Signature Analysis", Hewlett-Packard Journal, Vol. 28, No. 9, May 1977.
16. Daehn, W., Williams, T. W., and Wagner, K. D., "Aliasing Errors in Lin-
ear Automata Used as Multiple Input Signature Analyzer", IBM Journal
Research Development, Vol. 34, Nos. 2/3, March/May 1990, pp. 363-364.
17. Hiawiczka, A., "Hybrid Design of Parallel Signature Analyzers", European
Test Conference, April 1989, pp. 354-355.
18. Hassan, S. Z., and McCluskey, E. J., "Pseudo- Exhaustive Testing of Sequen-
tial Machine Using Signature Analysis", International Test Conference, 1984,
pp. 320-326.
19. William, T. W., and Daehn, W., "Aliasing Errors with Primitive and Non-
Primitive Polynomials", International Test Conference, September 1987, pp.
639-640.
20. Hortensius, P. D., McLeod, R. D., and Podaima, B. W., "Cellular Automata
Circuits for Built-in Self Test", IBM Journal Research Development, Vol. 34,
No. 2/3, March/May 1990, pp. 389-392.
21. Tsui, Frank F., LSI/VLSI Testability, McGraw-Hill, New York, 1987, pp.
173-175.
22. Tanenbaum, A. X., Structured Computer Organization, Prentice-Hall, Inc.,
1990, pp. 96-98.
23. Chin, Miao, "A CMOS CRC Divider Generator", Master's Thesis, Naval
Postgraduate School, 1991, pp. 10-12.
24. "VLSI Design Tools Reference Manual, Release 3.2", NW Laboratory for




1. Defense Technical Information Center 2
Cameron Station
Alexandria, VA 22304-6145
2. Library, Code 52 2
Naval Postgraduate School
Monterey, CA 93943-5002
3. Chairman, Code EC 1
Department of Electrical and Computer Engineering
Naval Postgraduate School
Monterey, CA 93943-5000
4. Professor Chyan Yang, Code EC/Ya 2
Department of Electrical and Computer Engineering
Naval Postgraduate School
Monterey, CA 93943-5000
5. Professor Herschel H. Loomis, Jr., Code EC/Lm 1
















Jl: Gatot Subroto 72
Jakarta, Selatan
Indonesia
9. Col. Nav Marajuki
Komplex CURAG INDAH






















c.l An analysis of alias-
ing in built-in self
test procedure.
16 » 16 9
Thesis
B2423463 Barus
c.l An analysis of alias-
ing in built-in self
test procedure.

