An ASIC implementation of the proposed IEEE standard for designing testable circuits by Kiang, Susan Shushien
Lehigh University
Lehigh Preserve
Theses and Dissertations
1990
An ASIC implementation of the proposed IEEE
standard for designing testable circuits
Susan Shushien Kiang
Lehigh University
Follow this and additional works at: https://preserve.lehigh.edu/etd
Part of the Electrical and Computer Engineering Commons
This Thesis is brought to you for free and open access by Lehigh Preserve. It has been accepted for inclusion in Theses and Dissertations by an
authorized administrator of Lehigh Preserve. For more information, please contact preserve@lehigh.edu.
Recommended Citation
Kiang, Susan Shushien, "An ASIC implementation of the proposed IEEE standard for designing testable circuits" (1990). Theses and
Dissertations. 5340.
https://preserve.lehigh.edu/etd/5340
D 
. ' 
' 
.. 
, ••• I 
An ASIC Implementation of the Proposed IEEE Stan(lard 
for Designing Testable Circuits 
by 
Susan Shushi~n Kiang 
A Thesis 
Presented to the Graduate Committee 
of Lehigh University 
in Candidacy for the Degree of 
~ Master of Science 
• 
. ID 
Electrical Engineerlng 
Lehigh University 
June 1990 
•.t 
h - .£ 
' ' , 
This thesis is accepted and approved in partial fulfiliment of the requirements for 
. .. . 
. - . 
. \, 
" . 
the degree of Master of Science in Electrical Engineering. 
.jt '\ 
. ProfeB>r in Charge 
Cbair111an of Department 
. Date b/1+/'10 
J 
II : 
0 
:.--:~ 
~--· '. -
. I 
' 
-, 
) 
I 
" r 
) 
I . ,. 
ACKNOWLEDGEMENTS 
The author would like to express her appreciation to the following people for their 
contributions: 
• 
My advisor, Dr. Frank H. Hielscher, for his advice and suggestions. 
Homayoon Sam for providing the IEEE Standard documents. 
Anup Shanna for generating the TAPDANCE test vectors. 
Pat Kempsey·and C.Y. Chen for their helpful discussions. 
i ,, • My husband, Edward C. Yang, for his encouragement and support. 
i m. 
~ ,, 
' . 
. ;/:-
' 
··-- ···,i 
/.,, .. ·, .· 
V 
TABLE O:F CONTENTS 
Title Page 
Certificate of Approval 
Acknowledgements 
Table of Contents 
,Abstract 
I. Introduction 
II. Discussion of IT AG/IEEE Standard 
III. Implementation 
A. Design Methodology -
B. Test Access Port Controller 
C. Instruction Register 
D. Instructions 
E. Test Data Registers 
F. Outpu~ Multiplexer and Enable 
IV. Verification 
A. Logic Verification 
B. Timing Verification 
C. Fault Simulation 
V. Discussion/Conclusions 
References 
Appendix A 
Appendix B 
VITA 
IV 
l . 
\ 
0 
. 
-,,) 
{ 
Page 
• 
1 
•• 
11 
••• 
111 
• 
lV 
1 
2 
10 
17 
24 
32 
36 
42 
55 
57 
59 
60 
63 
64 
69 
71 . 
91 
93 
/ 
l,l 
' ' 
I 
.c.. 
........ -. . 
If,,), 
ABSTRACT 
The increasing complexity . of integrated circuits and of denser packaging 
technologies, has made it ever more difficult to test these circuits after they have been 
assembled on printed circ~uit boards. The circuit ·board designers in the industry decided to 
resolve the issue by forming groups to develop a standard in order to improve the testability 
~ 
of the integrated circuits. This prompted the formation of the Joint Test Action Group 
(JTAG) and of the IEEE working group P1149.I.1 These groups have since developed a 
' . 
framework for standardized testability of integi:Jl_ted circuits for board level testing, which 
has became IEEE standard P 1149 .1. 
The author followed the IEEE standard, and designed a general framework that can 
be easily implemented into integrated circuits. The design of the framework is documented 
in this paper. It describes the circuit design and the design methodology that the author 
used. The performance and fault coverage of the design are described. This design has 
passed the standard conformance test, TAPDANCE, developed at AT&T Bell 
Laboratories. 2 
/ 
1 
... 
L· INTRODUCTION 
The increasing density and complexity of digital integrated circuits have made 
testing of printed circuit boards as well as of integrated circuits· increasingly difficult. The 
cost of performing functional tests of chips is increasing rapidly, due· to the fact that the 
ratio between the number of devices on a chip to the number of input/output (1/0) pads is 
rising~ and the fact that the automatic test equipment has become very expensive. It seems 
that the o·nly method that can be used to reduce testing cost is to include test logic on each 
chip to facilitate testing. 
.,. 
The most direct way to improve the testability of integrated circuits is to introduce 
test points. Test points are additional circuit inputs and outputs which have been add~ 
. ' \ 
during the design and are used only during the test phase. A major problem with 
incorporating test points in integrated circuit is the limited number of available pins. Thus, 
the cost associated with test points in integrated circuits seems significant ~cause of the 
extra pin overhead. However, for printed circuit boards, the cost of adding test points is 
of ten well justified. 
There are two concepts associated with testability: controllability and 
' 
observability. Controllability refers to the ease of producing a specific internal ~ignal value 
by applying signals to the circuits inputs. Observability refers to the ease with which the 
state of internal signals can be determined at the circuit outputs.3 N~rous techniqu.es 
2 
fl 
) ? . 
[ 
\ 
• 
that can be used to improve controllability and ob~rvability of integrate.d circuit have been . 
proposed. The scan path.structure is the basis to these techniques. The scan path technique 
' 
is;used to achieve total or near total controllability and observability in sequential circuits.3 
In the scan path approach, the flip flops and/or latches are. designed to be able to operate in · 
either parallel load or serial shift mode. In the, normal mode of operation the flip flops and 
latches are configured for parallel load. For test purposes the flip flops are switched to a 
serial shift mode. A scan path consists of placing a multiplexer just ahead of each flip flop 
. ·11 ed . p· J • 1 1s 1 ustrat 1n 1gure . ,, 
Data I Data 2 Data.\' 
Scan in I 
' . 
' ' ' . • 
' ' ' 
MUX MUX 
-
Select ' ' MUX 
' 
' ' 
••• 
' ' 
Register Registe,r Register 
Scan out 
Out 1 Out:? Out.\' 
Figure 1. Scan Path3 
There are many ways the scan path design for testability structure can be 
implemented. The first description of such a sbfUcture was published by M. J. Y. 
Williams. 4 The scan path consists of D type flip flops with multiplexed data inputs. 
Depending on the control of the multiplexer, the data input can be either from 
combinational test logic or from the output· of previous scan path. · A diagram of a 
. ~<: .. 
3 
1 . ! .,, 
,, 
multiplexed data flip flop scan-path architecture is shown in Figure 2. Another tec;hnique 
is IBM's LSSD (Level Sensitive Scan Design). 5 The general structure of·LSSD is basically 
a double latch design for a two-phase latch machine (with the ·frrst la~ch being a two port 
latch). The latches are interconnected in a.scan path structure. A general structure of a . ' 
circuit using a LSSD design is shown in Figure 3. Besides being used in the internal scan 
path, the LSSD type design can be used for an external scan path. A· pair of scan path 
. 
latches are introduced for each 1/0 bonding pad. A general structure of a circuit using scan 
latches on input pins and output pins is shown in Figure 4 . . 
(":)mbintJtiontJI logic 
Xn--: 
-Zm 
._,,l"":"!lr.l"""'-_--Z-, ----v-2 --Y2- Ys Ys 
' 1,20 I T,2D T,20 
SDI _ __., 1,20 1 l,2D -0 - ----1 1,20 
__ soo 
.-----. G 1 J 
I r-~(2 I 
CK----1-----~~ ........ --~ 
T__.., ____ ...,._ _ _ 
a 
SDI is sctJn dtJta input too is scan dtJta output 
Figure 2. Multiplexed Data Flip-Flop Scan-Path Architecture6 
. - ·;.;;-_f?';?•i) {:";;.-"'-
\j 
• 
4 
J 
'(.,' 
\. 
x, 
~2 
-
-
• 
. 
-
SD I 
I CK 
TCK 
CK 2 
Combinational I ogic 
v,. Y1 
L1-1 I \ 
...._ 10 
20 D 
Cl 
,.... C2 
L 2-1 
-10 n 
Cl 
Y2 Y2 
L1-2 
' ' 
-- ID 
20 ~I ~ 
Cl 
,.... C2 
'-2-2 
-10 n 
Cl 
Ys 
L1-s 
10 
20 
Cl 
C2 
L2-s 
10 
--Cl 
z, 
22 
. 
. 
• 
Zm 
Ys 
SDO 
Figure 3. LSSD Double-Latch Design6 
Input bonding pads Output bonding pads 
External scan path 
Combinational 
X1 1 circuits 0 Z1 
X2 I 0 Z2 
~MUX 
SDI N N N 
SDO 
R Internal scan path 
E 
Figure 4. General Structure of Circuit Using--Scan Latches on Input 
Pins and Output Pins6 
5 
\ 
" I • 
Implementing the aforementioned testability methods. onto., the integrated· cireuits 
can definitely improve testability of the.circuits. However, testingof thecompleted,printed 
circuit board can still be extremely difficult. Chips from different manufacturers can reside 
on the same printed circuit board, and different designers or companies prefer different 
methods of implementing testability circuits in their integrated circuits. Because of the 
. problems mentioned above, there is in the' industry rising interest in a unified hierarchical 
test architecture. The interests and needs for such a test architecture is such that a common 
design-for-testability method should be defined.7 
The effort of investigating possible solutions to solve the problem of board level 
testing was started in Philips, Netherlands. The conclusion from this effort was that a real 
~ breakthrough in test methodology can only be realized0 by international cooperation. 
Several companies in Europe were approached. The companies are British Telecom, 
Plessey, Siemens, Thomson CSF, r1·1· Europe, Ericsson, Nixdorf, GEC and Electronik I 
Centralen. The Joint European Test Action Group (JET AG) of Europe was then formed in 
- "'-~-·. ; 
1985. This group was later expanded to include members from North America, and 
;, 
renamed the Joint Test Action Oro.up (JTAG) in 1986. For two years, the JTAG technical 
., 
committee developed numerous proposals for a standardized form of boundary-scan 
architecture. In 1988, the last of these proposals -JTAG version 2.0 - became the technical 
.I,• 
basis of this IEEE Standard. The IT AG subcommittee became the core of the IEEE 
working group Pl 149.1 and developed the IEEE Standard Test Access Port and Boundary- . 
Scan Architecture. 1 The final version of this standard w~ adopted. in February, 1990. ,c 
6. 
··, 
. I 
-
, The standard. defines test logic which can be ·included 'in an integrated circuit to 
provide standardized approaches to: 
( 1) testing the interconnections between integrated circuits once they have been 
assembled onto a printed circuit board or other substrate; 
(2) testing the integrated circuit itself; and 
,, ........ 
(3) observing or modifying circuit activity during the component's normal 
operation. 1 
1 The IEEE Standard is very well documented. The chapters are basically separated 
'by major functional blocks of the test logic. Each chapter describes the functionality of a 
f_J\ : block and specifies the significance of that block. The descriptions are usually very 
detailed. However, there are too few circuit diagrams to support the text, which makes it 
difficult for someone to visualize the circuit and its operation. The author decided to 
implement this IEEE test logic standard, using AT&T's application specific IC (ASIC) 
design approach and software tools, with AT&T' s standard cell design as the target 
technology. 
The IEEE standard is defined such that there is minimum pin overhead for testable 
. 
a circuits. The test logic of a testable circuit is accessed through a Test Access Port (TAP). • f 
The Test Access Port consists of a minimum of 3 input pins (the fourth one is optional) and 
1 output pin. These ports provide control signals to manipulate the testing of the integrated 
.circuit. The Boundary-Scan Architecture allows the inputs-,and·outputs of the integrated 
circuit to be accessed from outside the integrated circuit. The inclusion of these extra 
. ., 
.7 
I 
r .. 
J 
·" ' 
circuits }s to have a minimum impact on th/01 anal operation of the integrated circuit. 
With only 4 (or 5) extra pins and some area penalty, the controllability and observability of 
the integrated circuit can be improved tremendously. It is usual for integftlted circuits from ·· 
several different manufacturers to reside on the ·same board. Abiding to the standard will 
ensure that each integrated circuit can be incorporated successfully into the board-level 
design-for-testability scheme. · 
In this thesis, an implementation of the IEEE JT AG standard is presented. The 
. ' IEEE standard defines both the mandatory and optional dedicated test logic functions. The 
author did not have any specific circuits in mind while designing this framework, and hence 
the design includes most of the optional functions defined in ~.e standard. The optional 
functions that the author did not implemented are: USERCODE function and the power up 
, 
/ 
,:;·•' 
circuit The details of the design are all described in the following chapters~. 
The author has made sure that the design conforms to the standard by using test 
• vectors generated from an AT&T software program called,.TAPDANCE.2 TAPDANCE 
generates test sequences that can be used for detecting design faults for confom1ance to the 
standard. The logic of the 16 state test access port controller is designed by using the Finite 
State Machine (FSM)8 tool contained in Functional Design System (FDS)9 tool. The 
. 
~I 
schematic of the design is entered using SCHEMA.9 The logic simulation~e' timing 
.. 
\./ 
r· 
simulation of the circuit is verified using MOT1S.10,ll The fault coverage is determined 
by using the Fault Simulator (FS1M)12 tool in MOTIS . 
. ··l 8 
\ 
. 
. In Chapter 11,· the basic.description of JTAG/IEEE Standard~s discussed. Chapter 
m describes the circuit imp~ementation of the design. The design methodolog>,1 that the 
author used and tlie test access port controller that was used to control the testing sequences 
is described in Chapter m. The implementation of the Instruction Register (part of the 
~ontrol for testing), the definition of the instructions, the Boundary-Scan implementation 
of the input, output and control circuits and the selection of the ·output signals to the test 
access output port are also described in Chapter ill. In Chapter IV, the verification of th·e 
design is discussed. This includes both the functional and timing verifications. The fault 
simulatiQQ result of the design is also presented. Finally, the discussion and conclusion of 
this paper is presented. 
. ' 
9 
IJ. 
I 
' 
.. 
. 
. 
. 
. IL DISCUSSION OF· JT AG/IEEE-STANDARD 
In this chapter, an overview of the IEEE standard is discussed. The JT AG Test 
Logic Architecture is shown in.Figure 5. There are fourinput pins (one of them is optional) 
and one output pin. Theses pins must be included in order to implement the test logic. 
Other circuits that must also be included are the Controller, Instruction Register, Instruction 
... ,,, 
Decoder, Test Data Registers and Output enable circuits. These circuits are all dedicated 
to the testing functions. Therefore, each integrated circuit which incorporates test features 
compatible with the IEEE standard must include these functions in the design. The general 
• scheme is to minimize the number of additional pins required for testability. This requires 
. 
that the test inputs and outputs occur in serial f onn. 
-The input and output pins of the test logic are all dedicated test access ports. It 
means that they can not share functionality with any of the system or chip input/output pins. 
The Test Access Pon (TAP) consists of a minimum of 4 dedicated pins: Test Clock (TCK), . ~ 
Test Mode Select (TMS), Test Data Input (!DI) and Test Data Output (1DO). The optional 
pin is the Test Reset Pin (TRSTN, TRST active low). The test clock TCK is a broadcast 
signal that applies to all of the integrated circuits on the same board. It is used to make sure 
c--.:'·- . ~· 
that all the test features in the integrated circuits are operated at the. same frequency and 
phase, to achieve synchronized board test operations. The test mode select TMS is also a 
broadcast signal that is used tq control the t~st operation. It is sampled on the ri~ing edge 
of test clock TCK. The test data input pin 1DI provides input data to the scan path, and it 
10 
.Li 
. ·~. 
v, 
is also sann,led on the rising edge of test clock TCK. The serial output data of the scan path 
is output through the test data output pin lDO, and is sampled on the falling edge of TCK. 
The optional pin is the Test Reset Pin TRSTN. It asynchronously resets the test logic when 
a logic low is applied. If the Device Identification Register is present in the circuit, the test 
reset signal TRSTN causes the register to be connected between test data input 1DI and test 
data output IDO. Otherwise, the Bypass Register is selected to be connected between lDI 
and TOO. If test reset TRSTN pin is not included, a power up reset circuit can be designed 
to accomplish the same task. The IEEE standard specifies that the test mode select TMS, 
the test data input TOI and the test reset TRSTN pins should all contain a pull-up resistor. 
This resets the test logic if no input is applied. 
m1 
TR8T 
JTAG 'lest Logic Architecture 
lnatructian cleeoder 
---+-I lnltruction Reg. 
Ree1t 
ClecklR 
ShiftlR 
• ,...___ Upda&elR Select 
--~a,r---------1--------..r 
cr--------t------~---.J 0 
CJ 
Figure 5. The IT AG Test Logic Architecture 
11 
TOO 
r 
The Test Access Port Controller is a 16 state fll1ite .state machine that controls the 
operation of the test logic. It is a dedicated feature that must be implemented in order for 
the test logic to be compatib!e with the standard. The Instruction Register which is also a 
,, 
dedicated test logic consists of shift-register stages. Generu}y, the standard specifies 3 
instructions that must be supported. The number of shift-register in the Instruction Register 
depends on the number of instructions that are needed. For example, if 8 instructions are 
needed, then a 3-stage shift-register is required (23 = 8). If the number of instructions is not 
exactly 2x (x = an integer), then the next larger integer is used. The unused instructions are 
then defaulted to the instruction that selects the Bypass Register. 
The Test Data Register consists of the Bypass Register, the Device Identification 
Register, the Boundary-Scan Register and the self test circuits (if any). The Bypass 
Register and the Boundary Scan Register are mandatory test logic. Both the Instruction and 
Test Data Registers must be parallel shift-register based paths with common inputs tied to 
test data input TOI and common outputs tied to test data output TOO. The test access port 
controller selects the register that connects between test data input TOI and test data output 
TOO. Therefore, at any one time, only one of the registers is connected between TOI and 
TOO. Since there are only one test data input TOI and one test data output TOO, all the 
data are communicated in a serial f 01,mat 
' 
The Bypass Register consists of one shift regis~r. When perfo11ning board level 
• '.,t .. 
testing, if one particular inte~ated circuit on the board is not r~uired to be included on the 
path for testing, then the Bypass Register is selected. 
12 J 
. . 
) 
The Device Identification ·Register is a 32 ·stage shift register. The shift register is_ 
·used to store a 32. bit vendor-defmed- identification code. It can be used to identify the 
,• 
manufacturers of different integrated circuits on the board The Device Identification 
Register is an optional register. Depending on the manufacturer's choice, it does not have 
to be implemented. 
The Boundary-Scan -Register has boundary-scan cell on all tile input and output 
connections of the integrated circuit. A general boundary-scan cell is illustrated in Figure 
6. 
Mode 
Signal in 
ShiFt/Loed• 
--
... 
... 
... 
-
-
.. ~ 
, Seen In 
1Gl i 
T 
1 
Seen out 
.. ~ 
'G 1 c; 
r 
1 
r 
10 10 
-
~ C 1 ~ Cl 
4 ~ 4 ~ 
Clock Clock A 8 
Figure 6. A Boundary-Scan Cell 1 
·, 
,.I 
C.:.-~~ 
--~ 
.. 
Signal 
out 
Depending on the "MODE" signal, the "Signal In" (which can be either an input pin 
or a signal from the chip logic to the output pin) can go directly to "Signal Out". (which can 
. 
.. 
be either an output pin or a signal from- the input pin to the chip logic) or load into the scan, 
· shift register. During normal operation, "Signal In" goes directly to "Signal Outt'. The 
13 
'1 
\ 
,· 
boundary scan cell of each pin is connected in a chain around the border of the chip. The 
"Scan In" of the current boundary scan cell receives input from the "Scan Out" signal of the 
previous boundary scan cell. The "Scan Out" signal of the current boundary scan cell goes 
to the "Scan In" Signal of the next boundary-scan cell. The first boundary scan cell in the 
·, chain on the integrated circuit is connected to the test data input pin TOI of the integrated 
circuit and the last boundary scan cell is connected to the test data output pin TDO of the 
integrated circuit. The same method is applied in the higher hierarchy level, the test data 
input pin TDI of the first integrated circuit on the scan path is connected to the TDI of the 
board and the test data output pin TDO of the last integrated circuit on the scan path is 
connected to the TDO of the board. An example of a boundary scannable board design is 
shown in Figure 7. 
Boundory-scon cell 
Serio! test interconnect 
TDI ........... _ ..... _ 
Serio! 
do to in 
,Do ..._.. ______ _ 
Ser1ol 
doto out 
Systa~ interconnect 
Figure 7. A Boundary Scannable Board Design 1 
14 
i ' . 
. All the inpu~ output, tri-state output and bidirectional pins.are required to include 
boundary scan cells in order to be compatible to the standard The controls for the tri-sta~ 
output and bidirectional pins are required to jnclude boundary scan cell. However, one 
control ·enable boundary scan cell can be used to drive more than one of the tri-state output ,, 
or bidirectional pins. 
The self test circuits can be included as one of the Test Data registers. Linear 
Feedback Shift Registers (LFSR) can be used to generated pseudorandom numbers to the 
integrated circuit and hence self testing of the chip is possible. The input pins can be 
connected to fo11n a LFSR. The outputs can then ~onnected together to fo1m a Multiple j 
In·put Shift Register (MISR) for a signature analysis. 
As mentioned before, either the Instruction Register or one of the Test Data 
_ Registers can be connected between test data input pin TOI and test data output pin TOO. 
The signal that controls this operation is decoded from the test access port controller states. 
The test data output pin TDO is only enabled during two of the controller states, the 
instruction register data shift state and the test data register data shift state: 
A typical sequence of the& operation of the test logic is as follows. The test access 
port controller selects the Instruction, Register through the controls of test mcxle select TMS 
and test clock TCK. The Instruction Register is then the only register that is connected ,, 
between the test data input pin TOI and test data output pin TDO. The input data through 
the test data input pin" TDI controls the sel~tion of the instructions. Once.the data is loaded 
into the shift-register stage of the Instruction Register, it is shil\ed toward test ·data output 
15 
i. 
·1 . 
. I l 
. ' 
'>--- _--l 
pin 1D9 on each· rising edge of test clock TCK; the instruction is then updated on the -
falling edge- of TCI( The three processes mentioned above are all controlled by the test_. 
access port controller states. The instruction does not change until the ~ext time the 
Instruction Register is selected. The instruction then selects one of the Test Data Registers. 
Now the selected Test Data Register is the only register that is connected between the test 
data input pin TOI and test data output-pin 1DO. The data is transmitted to the Test Data 
Register through the test data input pin TOI. The data is shifted and updated the same way 
as in the case for the Instruction Register. Again, these processes are controlled by the test 
access port controller States. Because the controller can only choose either the Instruction 
Register or the Test Data Register at any one time, therefore the movement of the data in 
one register does not have any effect on the other. 
In summary, because ~f the inclusion of the boundary scan cells at the input and 
output, testing_ of the interconnections between integrated circuits on the board becomes 
possible. Since the IEEE Standard is an industry standard, this I EF.E testing scheme applies 
regardless of who the manufacturer is. With only four (or five) extra overhead pips and 
some area penalty, the testability of the board can be improved tremendously. 
16 
Qt 
m .. IMPLEMENTATION 
A. Design Methodology 
The ASIC implementation of this circuit was done using ·AT&T's 0.9 micron CMOS 
/ Standard Cell library. Besides having extensive cell libraries, AT&T also has· a fully 
integrated CAD environment The output from any CAD tool is in the proper fo1m required 
for the input to the next tool in the design cycle. The design flow for this framework circuit, 
with names of the CAD tools in brackets, is illustrated in Figure 8. 
IEEE Standard 
'I , 
logic design(FDS) 
schematic entry(SCHEMA) 
'~ ..----
"i logic simulation(MOTIS) .,....__ 
vector(T APDANCE: ., timing simulation(MOTIS) ": 
; fault simulation(MOTIS) 
~: ," 
Figure 8. The Design ·Flow ' .. ~ 
17 
' / Results 
., 
' 
.. \ 
Most . of the test logic, such as the Instruction -Register, Bypass Register, 
..... 
. 
·-· Identification Register and the Test Data Registers, can be designed without any CAD 
tools. · However, the implementation of the 16 state test access port controller can be 
challenging without a finite state machine logic synthesizer. The 16 state finite state 
machine in this thesis was designed using the FDS9 (functional Design· S)'Stem) tool. This 
is a logic-synthesis system that generates the netlist of designs in tt~ 111s of the standard cells 
I 
I 
available in current CMOS technologies. The primitives can be functional circuits such as 
a finite-state machine, a combinational logic circuit, or standard MSI circuits ·such as an 
adder, counter, decoder, multiplexer, parity generator and universal register. In the case of 
the generation of the finite state machine function, a tool called FSM8 is invoked within the 
FDS tool. The inputs to the FSM tool are the state assignment (or assignments) of each 
state and the interactions between states. The inputs are represented in either a textual or 
graphical specification of a state transition diagiam. However, the graphical specification 
can be accessed more conveniently through SCHEMA9, a graphics editor. An example of 
a graphical specification is shown in Figure 1, Appendix A. The design flow of the FSM 
Synthesizer is shown in Figure 9. 
The synthesis of a finite state machin.e involves a series of transf0111,ations which 
include graphical capture, logic. synthesis, and physical implementation. The portion 
enclosed by the dashed box in figure 9 represents the transfo1,nations involved in logic 
synthesis. The lo~ minimization is done by using either _,a two-level logic minimizer 
· FAC2 and a multi-level logic minimizer MIS/PAGON.13 However, from past expcri.~ 
18 
. 
. 
· these logic optimi7a5 often do not generate circuits of high complexity m- a minimum· · 
implementation. Therefo1e, further human modification of the circuit is usually necessary. 
The outcome of the FSM tool can be represented either as a sche111atic. diagn,111 or as a 
netlist. 
... 
Graphical Capture 
,. 
__________ ., ti,~---------- ... I 
Boolean co Cube 
Translation 
State Assignment 
Logic Minimi1aiion 
------------! ·----49·------
I 
Pbysieal lmplemeaiaiioD (Polycell, PLA. PAL) 
, 
I 
I 
I 
I 
I 
Figure 9. Design Flow of a Finite State Machine Synthesizer9 
AT&T has a general purpose schematic-capture tool, SCHEMA, that is used for 
creating and editing schematic diagram. The SCHEMA tool realizes the function of the 
circuits by connecting the external view of standard cell gates. The exteinal view is a logic 
symbol with input and output names labelled. Sine~ a large part of the frameworlc: design 
does not require elaborate tools for the implementation of the designs, these were done with 
pen and paper and were then entered into the SCHMEA tool. The output from SCHEMA - -\ 
is- in a format that will be accepted by the next tool in the design flow. This can be either a 
netlist or transistor-level descriptions. 
19 
' . 
· The ~ext tool on the design flow is the MOTislO,ll (AN MOS TIMING . 
SIMULATION) tool. MOTIS provides logic, timing and fault analysis for complete chip. 
The input to MOTIS can be either a netlist, an ADYICE circuit description, or a C-language 
description of th~ circuit. ADVICE 14 is AT&T' s version of a SPICE circuit simulator. The 
design flow of the MOTIS simulator is shown in Figure 10. 
netlist 
Compiler 
GSIM/FSIM 
Simulator 
Figure 10. The design flow of the MOTIS Simulator 
GSIM is a version of MOTIS which provides both logic and timing verifications. 
There are basically four modes of simulation: unit delay, tnultiple delay, fast timing and ..... , ... 
full timing. A comparison of tlte simulation accuracy and simulation speed of a transistor 
level circuit description simulated via MOTIS and ADVICE are summarized in Table 1. 
The timing accuracy of the simulation increases as the mode of simulation changes. 
· 'However, the required CPU time increases drastically. Usually,. logic verification is done 
. in unit delay simulation and timing verification is done in full timing simulation. . The 
20 
accurac·y of the full timing simulation is within 5% of the ADVICE14-simulation. The CPU 
. · time needed used for full timing simulation is significantly less ·than that of required for a 
full ADVICE simulation. 
FSIM 12 is the MOTIS fault simulator which provides fault analysis. The fault 
simulation is usually done in the unit delay mode. The inputs to both simulators are the test 
vectors. The simulators generate outputs and the outputs are compared with the expected 
outputs in the test vectors. 
SIMULATION MODE SPEED ACCURACY 
Unit Delay 5000 NIA Multiple Delay 5000 
Fast Timing 1000 
Full Timing 100 within 10% ADVICE 1 100% 
Table 1. Comparison of the MOTIS modes and ADVICE 
Under unit delay, the operating conditions of the circuit are not important. Since 
each gate is assigned a unit delay. The user of the tool assigns a unit time for each gate. \ 
The typical value is O. lns. · For timing simulation, the worst case slow operating conditio~ 
is used in order to guarantee that a circuit can operate at a maximum frequency. The 
. commonly _used worst case slow operating conditions for full timing simulation is assuo~ 
as follows: 
21 
Junction Temperature: 
,
9 Process File: ,. 
Power Supply: 
100°C 
worst case slow processing 
4.5V 
A sunnnary of all the standard cell gates"used in this design is defined.in Table 2. 
The description of the buffers used is defined in Table 3. 
\ 
GATE NAME 
FD1S3AX 
FD1S3BX 
FD1S3DX 
FD1S3GX 
FD1S3IX 
INRB 
ND2 
ND3 
ND4 
NR2 
NR3 
TBUS 
DESCRIPTION 
Positive Edge Triggered 
Positive Edge Triggered, 
Positive Asynchronous Preset 
Positive Edge Triggered, 
Negative Asynchronous Clear 
Positive Edge Triggered, 
Negative ·Asynchronous Preset 
Positive Edge Triggerai, 
Positive Synchronous Clear 
Inverter 
2 input NANO gate 
3 input NANO gate 
4 input NANO gate 
2 input NOR gate 
3 input NOR gate 
Non-Inverting Tri-State Bus Driver 
Table 2. Standard Cell Gate Definition 
I 
22 
.. 
.,. ' I 
Bu/fer types Signal 
BINlOT · TDI, TMS, TCK, 
TRSTN 
BINlOT BSI 
B0N10T BSO 
BOTlOT TDO, BSOEN 
BNlOTlOT B·o 
Description 
Non-inverting, '11'L~Level Input, 
lOns WCS delay@ 5 pf load, 
20K pull up resistor 
Same as above, 
except no pull up resistor 
Non-inverting, 
·1·1·L-Level Output, 
. IOns WCS delay@ 50 pf load 
Non-inverting, 
·1·1·L-Level 3state output, 
lOns WCS delay@ 50pf 
Non-inverting, 
·1·1·L-Level input stage, 
Non-inverting, 'l0IL-Level 3 state 
output stage 
Table 3. Buffer Types 
/" 
In the following sections, the functions and implementations of the dedicated test 
logic will be described These are the Test Access Pon Controller, Instruction Register, 
Instructions, Test Data Register and Output Multiplexer and Enable. 
23 
B. Test Accea Port Controller 
The Test Access Pon Controller is the center piece of the testing scheme. It 
generates signals to control the Instruction Register and the Test Data Registers (Bypass 
Register, Device Identification Register or Boundary-Scan Register). It is a synchronous 
finite state machine with 16 states which co11esponds to changes at the test mode select 
TMS and test clock TCK signals of the controller. Since the output of the controller 
' 
' depends solely on its present state, it is a Moore Circuit 15 It also asynchronously settles 
into one particular state, the ''RESET'' state, if the t~st reset pin 1RSTN signal becomes 
low. Because of the finite state nature of the controller, the sequence of the test mode select 
TMS signal is very important. TMS must be sampled into the con~ller on the rising edge 
· of test clock TCK and decoded by the controller to control the test operations. The state 
diagram of the test access port controller that is defined by the tEF.E Standard is shown in 
Figure 11. The state assignments for each state are also shown in Table 4. 
The Test Access Port Controller is implemented using the Functional Design 
System FDS tools. There are many ways in which a finite state machine can be 
implemented. Since a finite state machine depends on either both previous·and present 
states (Mealy Machine)15 or just 'on the present states (Moore machine)15, the logic 
implementation of a finite state machine is more difficult than the design of combinational 
logic circuits. One way to implement the Test Access Port Controller is to modify the 
-
circuit given in the IEEE standard description. However, the author prefe11cd to try 
AT &T's FDS tools. Functional Design System FDS tool generates states that are decoded 
24 
,· 
.. 
. -t . 
from combinational · 1ogic connected after the state registers. Because the combination 
logic occur after the state registers, the author had some difficulty in ronning unit delay 
•' 
simulations on the circuit that has generated by the FDS tool. The combinational circuits 
tend to generate glitches, and if these happen on · the reset line, they can cause an 
, I 
asynchronous reset of the flip-flops in the registers. Further discussion of this problem will 
be presented in the logic verification section. 
Controller State State Assignment 
Exit2-DR 0 
Exitl-DR 1 
Shift-DR· 2 
Pause-DR 3 
Select-IR-Scan 4 
Update-DR 5 
Capture-DR 6 
Select-DR-Scan 7 
Exit2-IR 8 
Exitl-IR 9 
Shift-IR A 
Pause-IR B 
Run-Test/Idle C 
Update-IR D 
."'v,, ... ,, Capture-IR , E •i • i 
Test-Logic-Reset F 
Table 4. ·state Assignments for Test Access Pon Controller 
"\ 
2S 
0 
0 
0 
0101 
0000 
EXrrl DR 
0001 
0 
I 
I 
0 
I 
EXIT21R 
1000 
Figure 11. The state diagram of the Test Access Port Controller 
26 
OICIO 
I 
• 
• 
• 
. ' 
~- .. 
·- ~··,. 
The .state diagram implementation of the test access port COntroller is shown in · 
.. Figure 1, Appendix A. This finite state machine is synthesized by choosing the MIS-
DAGON logic-optimizer. ··· The output after~ synthesis is the netlist, and the netlist can then 
be captured and displayed as schematic diagrams. The logic-optimizer did not generate 
circuit with minimum logic, and further optimization of the circuits using Kemaugh Map15 
was necessary. The final circuit of the test access port controller is shown in Figure 2 and 
3, Appendix A. The internal view of the 8 blocks, FMNSNEW[0:3] and OUTNEW[0:3], 
are shown in FIGURE [ 4: 11 ], Appendix A. 
The TAP Controller has 16 states and generates 10 output signals to control the test 
logic: Instruction Register, decoding logic, Boundary-Scan Register, Bypass Register, 
·O 
_,,,,,--, 
Device Iafntification Register, Output Multiplexer and Enable. A block diagiam of the test 
access port controller is shown in Figure 12. A description of all the 16 states will be 
discussed in the following paragraphs. The straightforward decoding schemes of the 
controller states are also indicated. The state assignments were given previously in Table 
4, p. 25. 
-
-
II 
21 
31 
·-
-
·-
-
TCK 
1MS 
TRS1N 
.. 
CAPIUREDR 
~ 
SHIFIUR 
UPDATEDR 
RESET 
CAPrUREIR 
SHIFIIR 
UPDATEIR 
·RUN'IFST 
SELECT 
ENABLE 
_l 0 
20 
30 
40 
so 
60 
70 
80 
90 
100 
-
-
-
-· 
-
-
-
-· 
-
-
-
-
-
-
-
-
-
-
-
Figure 12. The block diagram of the Test Access Port Controller 
27 
. ''\' .. 
(l) Test-~gic Reset 
The test access pon controller asynchronously settles into the Test-Logic Reset 
state when the test reset TRSTN signal goes low. This initializes the instruction register to 
the IDCODE instruction (which is discussed later in the Instruction Register section). This 
state disables the operation of the test logic, but docs not affect the normal operation of the 
on-chip system logic. No matter what the original state of the controller may be, after five 
consecutive cycles of the test mode select TMS signal staying high, it enters the Test-Logic 
Reset controller state. The state assignment of Test-Logic Reset is F (see Table 4, p. 25). 
The decoding scheme of signal "RESET" is shown in Figure 3, Appendix A. 
(2) Run-Test/Idle 
The Run-Test/Idle controller state controls the test logic related to BIST or any self-test 
function within the chip. The state assignment of Run-Test/Idle is C. The decoding scheme 
of the signal "RUNTEST" is shown in Figure 3, Appendix A. Although the self-test circuit 
is not included in this design, the availability of this signal will be useful in the event that 
the self test circuitry is needed at a later time. 
(3) Select-DR-Scan 
This is a temporary state in which the instruction decoded in Instruction Register 
does not change from the previous state. The state assignment of this state is 7. 
(4) Select-IR-scan 
This is al~o a temporary state in which the instruction decoded in Instruction 
Register does not change from previous state. The state assignment of this state is 4. 
(5) Capture-DR 
' ,., . !~ 
In this contrQller state, the data at the input of the Test Data Register (either Bypass 
Register, Device Identification Register or Boundary-Scan Register) loads in parallel into 
28 
J . .-~· 
I 
) 
,, 
., 
. 
. the register· depending on die current instruction that is decoded from . the Instruction 
Register (EXTEST, SAMPLE or INTEST, which will.be discussed later in the Instruction 
section). The state assignment of Capture-DR state is 6. The decoding scheme of the signal 
"CAPTUREDR" is shown in Figure 3, Appendix A. 
~ 
(6) Shift-DR 
In this controller state, the current instruction selects the Test Data Register that is 
connected between test data input pin TDI and test data output pin TDO and shifts the data 
one stage towards its serial output on each rising edge of test clock TCK. The state 
assignment of Shift-DR is 2. The decoding scheme of the signal "SHIFIDR" is shown in 
~Figure 3, Appendix A. 
(7) Exitl-DR 
This is a temporary state in which the instruction decoded in the Instruction Register 
does not change from the previous state. The state assignment of this state is 1. 
(8) Pause-DR 
This is a temporary state in which the instruction decoded in the Instruction Register 
does not change from the previous state. The state assignment of this state is 3. 
(9) Exit2-DR 
This is the same as Exitl-DR. It is a temporary state. The state assignment of this 
state is 0. 
(10) Update-DR 
This controller state allows the Test-Data Register to parallel latch the output while 
the dat~_ is shifted in the associated shift-register,path in.response to certain instructions J 
T . 
':~··"•, . (e.g., EX1'EST and INTEST). Data is latched Qnto the parallel output of the selected Test , 
·-·~·· 
Data Register from the shift-register path on the falling edge of test clock TCK in tlus. state. 
29 
i' 
I 
~ 
The state assignment of this state is 5. The decoding scheDle of the signal "UPDATEDR" 
is shown in Figure 3, Appendix A. 
( 11) Capture-IR 
In this controller state, the data at the input of the Instruction Register, which has 
fixed values, are loaded in parallel into the Instruction Register. The values of the fixed 
patter11 are such that the least significant bit (the one closest to test data outpu~ pin 1DO) 
has a fixed value of 1 and the second least significant bit has a fixed value of 0. If there are 
more than 2 shift registers in the Instruction Register, the other registers can have any fixed. 
values. The detail of this operation will be discussed later in the Instruction ;Register 
\ Section. The state assignment of this state is E. The decoding scheme of the signal 
"CAPTUREIR" is shown in Figure 3, Appendix A. 
(12) Shift-IR 
In this controller state, the Instruction Register shifts the data one stage towards its 
serial output on each rising edge of test clock TCK. The state assignment of shift-IR is A. 
The decoding scheme of the signal "SHIFI'IR" is shown in Figure 3, Appendix A. 
(13) Exitl-IR 
This is a temporary state in which the instruction decoded in the Instruction Register 
does not change from the previous state. The state assignment of this state is 9. 
(14) Pause-IR 
This is a temporary state in which the instruction decoded in the Instruction Register 
does not change from the previous state. The state assignment of this state is B. 
(15) Exit2-IR 
This is the same as Exitl-IR. It is a temporary state. The state assignment of this 
state is 8. 
30 
\ 
' . -(16) Update-IR 
This controller state allows the Instruction Register to parallel latch the output from . 
the shift-register path on the falling edge of test clock TCK. Once the new instruction has 
·" I: been latched, it becomes the current instruction. The state assignment of this signal is D. 
The decoding scheme of the signal "UPDATEIR" is shown in Figure 3, Appendix A .. 
Two other signals also come out of the tap access port controller block. They are 
' 
the "SELECT" and "ENABLE" signals.. The "SELECT" signal · selects between the 
Instruction Register and the Test Data Register. The "SELECT" signal is 1 if the 
Instruction Register is selected. The "ENABLE" signal is 1 only during the "SHIFl'IR" and 
"SHIFIDR" states. Therefore, the test data output mo is active only during the Shift-IR 
and Shift-DR states. The circuit implementation of the above signals is also shown in 
Figure 3, Appendix A. 
In summary, the test access port controller changes state ·only in response to: 
( 1) A rising edge of test clock TCK clocks in the newly updated test mode select 
TMS signal, 
(2) A transition to logic O at the test reset TRSTN input 
Therefore, the instruction decoded in the Instruction Register does not change while the test 
access port controller is in one of its 16 states. One exception is when test reset pin TRSTN 
goes low. Then, the controller asynchronously goes into the Test-Logic Reset state; which 
in turn defaults to the IDCODE instruction. 
31 
C. Instruction Register 
The instruction Register allows an instruction to be shifted into the design through 
the test data input TOI, which selects the test to be perfo1111ed (EXTEST, INTEST or 
SAMPLE) and/or the Test Data register (Boundary-Scan Register, Bypass Register or 
Device Identification Register) to be accessed. The inputs to the instruction Register block 
are test clock TCK, test data input 1DI, reset signal RESET, test reset TRSTN, 
CAPTUREIR, SHIFTIR and UPDA TEIR. The outputs from the Instruction Register block 
are BSSEL, BYPASS, IDCODE, INTEST, EXTEST and RUNBIST, control the 
Boundary-Scan Register, Bypass Register, Device Identification Register and BIST circuit. · 
Pin IDO_IR is connected to the output multiplexer that selects one of the serial path to test 
data output TOO. The block diagram of the Instruction Register is shown in Figure 13. 
Test clock TCK, test data input TOI and test reset TRSTN are the designated input test 
access ports. RESET, CAPTUREIR, SHIFl'IR and UPDATEIR are the controller states of 
the test access port controller. There are tr.Jee mandatory instructions that must be 
implemented: BYPASS, EXTEST and SAMPLE. The BYPASS instruction selects the 
Bypass Register, and both the EX'l'EST and SAMPLE instructions select the Boundary-
Scan Register. Three other instructions that are optional are also implemented: INTEST, 
IDCODE and RUNBIST. INTEST selects the Boundary-Scan Register, IDCODE selects 
the Device Identification Register and RUNBIST selects the BIST circuit (if any). Note 
that the SAMPLE instruction does not come out of Instruction Register block, because it 
can be realized by both the INTEST and EX'l'EST instructions. Each of the instructions 
-
will be defined in detail later in this section. The output signal from the Instruction Register 
block, BSSEL, is set to 1 when the Boundary-Scan Register is selected. 
32-
11 TCK BSSEL. 
21 TDl BYPASS 
' 31 30 
• 
·RESET IDCODE 
41 CAPTUREIR INTEST 40 
SHIFI'IR EXTEST 
UPDATEIR RUNBIST 
' 
71 TRSTN TOO IR 70 
-
Figure 13. The block diagram of Instruction Register 
The IEEE s~andard has the following specific-rules for the Instruction Register: 
(1) It must consist of at least 2 shift registers. 
(2) The data shifted into the Instruction Register must be latched such that changes of 
instruction occur only in the UPDA TEIR and RESET controller states. 
(3) The two least significant bits in the shift registers of the Instruction Register must load 
a fixed binary'Ol 'pattem in the CAPTIJREIR controller state. The fixed pattern'!' is 
loaded to the least significant bit of the shift register, which is the one closest to test data 
output pin TOO. The fixed pattern' l' is loaded to the second least significant bit of the shift 
register. 
In this design, 6 different instructions were chosen, and bence a 3 shift, register 
based cell is needed. The instruction opcodes are listed in Table 5. All operations. of the ' 
. 
. I shift register stages ·mu.st occur on the rising edge.of the tcstclockTCK following entry.into 
33 
.. 
)· 
b 
u . 
- a controller state. However, the outputs of the shift registers are latched on the falling edge 
of test clock TCK in the UPDA TEIR controller state. 
OPCODE Instruction Descriptions 
IR2 IR1 IRO 
0 0 0 Select Boundary-Scan Register: EXTEST 
0 0 1 Select Boundary-Scan Register: SAMPLE 
0 1 0 Select Boundary-Sean Register: INTEST 
0 1 1 Sele'ct Boundary-Scan .Register: INTEST 
1 0 0 Select Device Identification Register: IDCODE 
1 0 1 Select BIST Circuitry: RUNBIST 
1 1 0 Select Bypass Register: BYPASS 
1 1 1 Select Bypass Register: BYPASS 
Table 5. Instruction Opcodes 
As stated in rule (2) above, when the test reset TRSTN is applied to the input, the 
latched instruction must change asynchronously with IDCODE instruction. The input to 
the Instruction Register is only applied during the CAPTUREIR and SHIFTIR controller 
states. The parallel output is updated following the UPDA TEIR controller state which 
occurs on the falling edge of the test clock TCK. 
Rule (3) above was implemented as shown in Figure 12, Appendix A., IRO is the least 
significant bit register (closest to test data output TOO), whose output, TDO_IR, is loaded 
with 1 in the CAPTUREIR control state. Both outputs of IRl and IR2 shift registers, ~ 
. 
TDO_IR1 and TDO_IR2 respectively, are loaded with pattern 0. This rule supports the 
fault isolation of the board-level serial test path. 
34 
The preset state instruction register, IR2, ftype: IR_P) is implemented as shown in 
Figure 13, Appendix A. In the CAPTURE]l controller state, the fixed value'O' is being 
' ' 
shifted towan:I test data output pin TDO. In the SH1FI1R controller state, the data from test 
data input pin TDI is being shifted out serially toward test data output pin IDO: The 
parallel output updates only in the UPDATEIR controller state. The test reset TRSTN and 
RESET signals can force the parallel output to be high, which corresponds to the most 
significant bit of the IDCODE opcode. The IDCODE opcode of this test logic circuit is 
. 100. 
The clear state instruction registers, IRl and IRO, (type: IR_C) are implemented as 
shown in Figure 14, Appendix A. The clear state instruction register behaves similar to the 
preset state instruction register, except that the test reset TRSTN and RESET signals can 
force the parallel output to be low. These correspond to the least significant bit and the 
second least significant bit of the IDCODE opcode. 
The implementation of the instruction register is shown in Figure 12, Appendix A. 
The decoding scheme is also included in the figure. In the next chapter, each decoded 
signal will be described. 
3.S 
- ( 
u 
D. Instructions-
This section defines both the mandatory and the optional instructions. The operations 
which occur in response to these instructions are also discussed. Each instruction must 
cause a serial Test Data Register path to be enabled to shift data between t~st data input TOI 
and test data output TOO in the SHIFIDR state. The mandatory instructions are BYPASS, 
SAMPLE and EXTEST. The IDCODE must be provided if the 'Device Identification 
Register is included. The other optional instructions are INTEST and RUNBIST. 
(1) BYPASS 
The BYPASS instruction is the only _instruction which causes the operation of the 
...... , 
Bypass Register. The Bypass Register contains a single shift-register state and is used to 
provide a minimum length serial path between the test data input TOI and test data output 
TOO pins of a component when no test operation of that component is required. The 
BYPASS instruction must select the bypass register to be connected for serial access 
between TOI and TDO in the SHIFl'DR controller state. The mandatory opcode for the 
BYPASS instruction is 111. The decoding scheme of the instruction, BYPASS, is shown. 
in Figure 12, Appendix A. 
(2) SAMPLE 
The SAMPLE instruction selects the Boundary-Scan Register between test data 
input pin TOI and test data output pin TOO. The data flow of the SAMPLE instruction is 
shown in Figure 14 .. 
' The data at the input must be loaded into both the input Boundary-Scan cell and 
output Boundary-Scan cell on the rising edge of the test clock TCK when the instruction 
registei is in the CAPl'UREDR controller state. The data, after capturing are then shifted 
36 
out of the cells in the SHIFl'DR controller state~ The MODE at the output multiplexer in 
both the input and output cell are both 0. The opc(?de of the SAMPLE instruction is 001. 
INPUT CELL 
•. ,,. . SI Nelli 
---· 
SI Cl•••_., .. 
OUTPUT CELL 
Shlttll so 
. ...................... . 
························· 
.:::::::::::on-ch 1 p::::::::::· ........ ---------
............................... ::::::: 
. . . . . . . . ...... . 
·:::::::_., •• ta•·::.·.·.·. • • • • • • l:IJ ,-. •••••• . . . . . . . . . ...... . 
·························· 
. . . . . . . . ...... . 
·······1 1 ....... . .... .. on c······ .. • • • • • • ••••••• ...... . ....... . 
. . . . . . . . . 
······················· 
························ 
······················· 
...................... •.•.•...••............ 
...... . ._.., 
Cl Cl 
•~-------Co11ponent bounder I••-------•~ 
Figure 14. The data flow of the SAMPLE instruction1 
(3) EXTEST 
The EXTEST instruction selects the Boundary-Scan Register between test data input pin 
,, 
{: 
·'.< ,,
,\ TOI and test data output pin TOO. It allows testing of the interconnections between the 
various chips on the board. The data at the input pin must be loaded into the input 
Boundary-Scan cell on the rising edge of the test clock TCK in CAP'I1flIBDR controller 
state. The data loaded into the output Boundary-Scan cell located at system output pins in -
--R controller state should be independent of the operation of the on chip· 
37 
~· 
syste~ . The manda.t<>ry opcode for the EX'IEST instruction is 00(). The MODE at the 
. output multiplexer of the output cell is 1. The MODE of the input cell is chosen to be 0. · 
The data flow while the EXTEST instruction is selected is shown in Figure 15. 
INPUT CELL 
•. , .. so 
I 11 
11 ca .. • '"1'• 1e11 
······················~·· •••••••••••••••••••••••• 
••••••••••••••••••••••••• 
•••••• 
OUTPUT CELL 
ShltlOII so ... 
······o h I ..... 
····· n-c ~···· · -...,...---....---.... ...... ·····..--
······ ...... . ............. 
••••••••• ••••••••• 
••••••• • •••••• 
.......• • t ........ . 
······· " ,. . . .... . ••••••• • •••••• 
·······~ ········· •••••••• •••••••••• 
·::::::. I OQ I A::::::::. 
······ ............ . 
•••••• ••••••• 
••••••• •••••••• 
•••••••••••••••••••••••• 
••••••••••••••••••••••• 
•4-------Co11ponent boundor •••--------~ 
Figure 15. The data flow of the EXTEST instruction 1 
(4) INTEST 
I 
The INTEST instruction selects the Boundary-Scan Register between the test data input pin 
TDI and the test data output pin TDO. It allows testing of the on chip system logic while 
the component is assembled on the board. The data loaded into the input Boundary-Scan 
-cell located at system input pins iit the C 
.. ~·-· R controller state comes from test data 
input pin IDl The ~ta loaded into the out,ut Boundary-Scan celllocated at the system 
output pins in the CAPIUREDR controll., state cQm,es from the operation of the on chip 
38 
/ 
system.· The opcodes for INTEST instruction are 010 and 011. TheMOI>Es at the output · 
i .... 
multiplexer of both the input and· output cells are l. The data flow while the INT.EST .,.,. 
instruction is selected is shown in Figure 16. 
INPUT CELL 
•. , .• . .... 
11 ca..-• .,..,,, .. 
OUTPUT CELL 
•. ,, . • • •• 
························· 
•••••• 
::•:•:•:•:·on-ch l p··:·:•:•:•: . ..._..,..___..,_----41----t ...... . ..... 
...... .-:::::: .............. ::::::. 
........ . ...... . :::::::." •. t .... ·:::::: . . . . . . . . ..... . 
······· ······· 
·························· 
........ . ...... .
. . . . . . · 1 l ....... . 
······ og c···--··· 
·.·::::. :::::::: ••....... 
.........•.....•........ 
..............••.••.•.. 
······················ ••••••••••••••••••••••• 
• 
s1 ca.-• •r,•••• 
•4-------Co,.ponent bounder lea-------•~ 
Figure 16. The data flow of the INTEST instruction 1 
(5) IDCODE 
The IDCODE instruction is the only instruction which causes the operation of the Device 
Identification Register. The Device Identification Register contains 32 shift registers and 
is used to identify chips on the board. The code for the Device Identification Register is 
. 
loaded ipto the 32 shut registers ht the CAPTUREDR controller state. TIK,se da.t.a,an,then. 
39 
. - ·- --· --- -- '.' :._ -: ·-·. _,_,-~·'. .. _. ____ : ·_._ ' -
shifted out toward test data output pin TOO in the SHIFIDR controller state. Neither-the 
" UPDA'l'Bl>R nor the· ·RESET ·controller states affect the operation of the Device 
Identification Register. The opcode for IDCODE instruction is 100. 
(6) RUNBIST 
The RUNBIST instruction causes execution of the self-test circuit inside the chip. 
When the RUNBIST instruction is selected, the Test Data Register into which the results 
of the self test will be loaded must be connected for serial access between test data input 
pin TOI and test data output pin TOO in the SHIFl'DR controller state. The IEEE Standard 
specifies that the self-test mode(s) of oper~tion accessed through the RUNBIST instruction 
must execute only in the Run-Test/Idle Controller State. The Opcode selected for the 
RUNBIST instruction is 101 .. In this design, the RUNBIST signal is provided even though 
no self-test circuit is implemented. 
The controls for the Test Data Register are decoded as shown in .Figure 15, 
Appendix A (BSSEL block). The BYPASS instruction from the Instruction Register block 
controls the Bypass Register. The IDCODE instruction controls the Device Identification 
Register, and BSSEL instruction controls the Boundary-Scan Register. The Bypass 
Register needs only the CAPTUREDR and SHIFl'DR controller states. Therefore, when 
the BYPASS signal is set to high, both the CAPIUREDR and the SHIFl'DR controller 
states become BP _CAPIURE and BP _SHIFl'·respectively. The selector for the Device 
Identification Register is functionally similar to that of the BYPASS state for the Bypass 
, Register. When the IDCODE signal is set to high, both the CAPIUREDR and the 
SHIFI'DR controller states become ID_CAPTURE and ID~SHIFT respectively. The 
, controls for the Boundary-Scan Register are dependent on whether the Boundary-Scan cell 
40 
is an input cell or ·an output cell. If it is··an input cell, the INTEST instruction will··prohibit 
. . . 
&~..,R controller state from accepting inputs from the input Boundary-Scan 
cell. If it is an output eel( the EXTEST instruction will prohibit the C 
controller state from accepting the inputs to the output Boundary-Scan cell. The controls 
to the input cell are BSI_CAPl'URE, BSI_SHIFI' and BSI_UPDA TE. The controls to the 
output cell are BSO_CAPTURE, BSO_SHIFI' and BSO_UPDATE. 
,_. 
\. 
,. 
" 
41 
E. Test Data Registers _ 
r 
The IEEE standard requires at least two Test Data Registers in the test logic, Bypass 
and Boundary-Scan Registers. The implementation of the Device Identification Register 
is optional.· However, all of the above registers are being implemented in this design. An 
implementation of .the Test Data Registers is shown in Figure 17. 
Boundary-Scan Register 
MUX ~TDO BS 
-
Bypass Register -------
Figure 17. An implementation of the Test Data Registers 
The Bypass Register is a single-bit shift register that connected between the test 
' . 
.... ,. . 
data input pin 1DI and test data output pin-IDO to allow test data to flow through one 
IS, 
component with only a single test clock TCK period delay. The Device Identification 
Register is a 32-bit shift register that contains chip specific binary identification code. The 
Boundary-Scan Register allows access to- the inputs and outputs of the component when 
testing its system logic. It_ also allows sampling of signals flowing through the system 
_ inputs and outputs. "' 
42 
., .. J-
-' 
•· , . 
~ i_.'._ :::...:c::: .. ___ '.:~-- - .. ·. 
. "( 
· (1) Bypass Register 
. 
The Bypass Register consists of a single shift-register state. When the Bypass 
Register is selected for inclusion in the serial path between test data input pin TOI and test 
data output pin TOO by the BYPASS instruction (from the Instruction Register block), the 
shift register stage must be set to'O' by the BP_CAPTIJRE signal as shown in Figure 18 . 
. 
It is implemented by using BP _CAPTURE to control the clear signal of the flip-flop. The 
/ 
value at test data input pin 1DI is selected by the BP _SHIFI' signal and shifted out to 
TOO _BP on the rising edge of the test clock TCK. Neither the UPDA TEDR nor RESET 
controller state has an effect on Bypass Register . 
... BP_SHIFI' 
, 
~ TOO_BP ... I D Q , 
... TOI ~ , 
MUX 
~Cleo ~ UC_ 
. 
.. TCK 
FD1S3IX , 
... BP _CAPTURE 
, 
Figure 18. Implementation of Bypass Register 
43 
' 
,I ;- . 
(2) Device Identification.Register 
The Device·. Identification Register allows the manufacturer, part number and o I 
version of a component to be determined through the test access ports. It can be used to · 
identify the manufacturer of the components . on a board. The Device Identification 
Register consists of 32 single-stage shift-register cells. The component must contain a 
vendor-defined identification code containing four fields as illustrated in Figure 19. 
MSB 
31 28 27 
Version 
(ij bi ts) 
Pe,... t 
nur,ber 
(16 bi ts) 
12 11 
Menuf'ecturer 
identity 
(11 bits) 
LSB 
1 0 
1 
Figure 19. Structure of the Device Identification Register1 
The Device Identification Register is constructed from a 32 single-stage shift 
register stage as shown in Figure 16, Appendix A~ A single shift register is shown in Figure 
20. The ID_CAPTURE loads the IDDATA input to be sent to the output mo_ID on the 
rising edge of test clock TCK. The ID _SHIFI' state shifts the data from test data input pin 
ml serially toward test data output pin mo on the rising edge of test clock TCK. Neither 
the UPDA TEDR nor the RESET controller states have an effect on this shift-register. The 
identification code that is chosen for this design is OECE4901 (it does not represent any 
manufacturer) .. The Device Identification loads a' 1' into its least $ignificant bit. When test 
r9set pin TRSTN is set low, a logic' l' is captured and shifted out to test data output pin 
mo. If the device identification register is not implemented, the Bypass Register is 
selected, and a logic'O' is being captured and shifted out to test data output pin:mo. 
r • 
44 
ID_SHIFT 
Tl>O;;..ID Q· ......... ---------~ 
IDDATA 
MUI 
'1' UC_ 
IDI .___ __ 
FD1S3AX 
TCK 
Figure 20. Implementation of a single-Stage Identification Shift Register 
• 
45 
I 
. (3) Boundary-Scan Register 
- . The Boundary-Scan Register allows testing of the circuit exte111al to the component 
as well as within the component. It also allows sampling of data at system pins without 
interfering with the operation of the on-chip system logic. Generally, there are six types of 
' ,, 
Boundary-Scan Register cells: inpu~, output, tri-state output, tri-state output enable, 
bidirectional and enable signal for Bidirectional. The input Boundary-Scan Register cell is 
connected between the system input pin and the on-chip system logic. The output 
\ Boundary-Scan Register cell is connected between the on-chip system logic and the system 
output pin. The tri-state Boundary-Scan Register is connected between the on-chip system 
logic and the system output pin and the enable signal is from the tri-state enable Boundary-
Scan cell. The bidirectional pin can be either an input or output cell, depending on the 
(, 
control from the bidirectional control Boundary-Scan cell. Figure 21 illustrates an example 
·of the placement of Boundary-Scan Register cells from the IEEE Standard. 
Sue&e11 
loalc 
input 
::::.·::::::.· . "".'"':'. -~-. -~-·-· --"""""'· ....... . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 
. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . ................................. 
· · · · · · · · · · · · · · · · · · · · · · · · · · · · · · · · · 1/S . . . . . . . . . . . . . .. . . . . . . . . . .. . . . . . . . . 
............................. ·····~......... ---------------
. . .................................. . 
cell 1/S ....... · .. · . · · · · · · · · · · · · · · · · · · · · · · · · · 
ce 11 ..,__,._ ::·::· ::: : : ::::: ::::::::::: ::: :::: :::::::: ::::::::: ::: :: :::: :'.:::: :: :::l· ::::: 
. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 
· · · · · · · · · · · · · · · · · · · · · · · · · · · · · · · · · · · · · · · · 1/S . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .. . . . . . . . . . . . . . . .. . .. .. . . . . . . . . . . ... . . . . . . . . . . . . . ;. ... ..,.._____,.. 
· · · · · · · · · · · · · · · · · · · · · · · · · · · · · · · · · · · · · · • · ce l 1 .......................................... iw,. . . . . . . . . ............................. ~ .. • • • • o -~ • o o o • o o ' • • • • 0 o o I • o • o • • o o o • • o • • o .....,, • o :-:·:·:·:-:-~-:-:·:·s,,t·e.m:·:·foaic :-:-:-;:,:-:-: . 
·::/::.~·:::. · · · :. :. :. ::. · ::. · · · · · · · · :::0::::. 1/S ..... ,.... .................................... . V . . . . ..... . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . ..._..... ..... .... 
· · · · ... · · · · · · · · · · · · · · · · · · · · · · · · · · · · · · ·"" · · · · oel 1 --....................................... .,..... 
I/S :?\J. ::'. ::  ::  : :::: ::::: ::: :::: ::'.: ::  ::  :::: ::: ::::::::::::::: :: ::  fJ::::} :: : : 
· · · · · · · · · · · · · · · · · · · · · · · · · · · · · · · · · · · · · · · · · · I/S 1 . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .... ee l · · · · · · · · · · · · · · · · · · · · · · · · · · · · · · · · · · · · · · ·. · · .i---1 
-
...- ····································· ····· cell ........................................... . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . ........................................ 
Sv•i• 
2••t•l• 
out,aul 
Suet-.. 
. S•elele 
output 
Syete11 
lalcUreotlonel 
. pin 
Figure 21. Placement of Boun~-Scan Register cells 
46 
The tri-state output enable signal can be used to control mbre than one tri-state· 
output Boundary Scan cell. It is the same for the bidirectional enable signal. In this design, 
all six types of Boundary-Scan cells are implemented' For simplicity, the tri-state output 
enable signal in the design controls only one tri-state output pin, and the bidirectional · 
control signal also controls only one bidirectional pin. The description and operation of · 
each of the Bc;,undary-Scan cells is described below: / 
(a) System Input Pin 
The implementation of the input Boundary-Scan cell is shown in Figure 22 (BSI). 
The BSI is the signal from the system input pin. The BSI_CAPTURE, BSI_SHIFI' and 
BSI_UPDATE are the controller states generated in the BSSEL block (discussed in the 
Instruction Section). The test data input TDI is either from the test data input pin TOI or 
from the test data output 1DO of the previous Boundary-Scan cell. The test data output pin 
TDO connects to the test data input TDI of the next Boundary-Scan cell. The input 
Boundary-Scan cell consists of one shift-register stage with an output latch. When the 
· SAMPLE and EX'l'EST instruction are elected, the shift-register stage loads the data 
presented at the system input pin (BSI) on the rising edge of the test clock TCK in the 
BSI_CAPTURE controlle:r state. If the INTEST instruction is selected, the shift-register 
loads the test data input TOI. 1DI is either from test data input pin 1DI or from the previous 
Boundary-Scan cell. Therefore, the BSI_CAPTURE signal is implemented such that the 
CAPTUREDR controller state is disabled when the INTEST instruction is selected (as 
discussed in the Instruction Section). During both the SAMPLE andEXTESTinstructions, 
the data at the system input pin are input to the on .. chip, system logic ( as shown in Figurel4 
47 
. . 
and 15). During the INTEST instruction, the data that are shifted into the previous 
boundary-scan cell (test data input 1DI) is the input to the on-chip system logic (as shown 
in Figure 16). The data is then latched in the BSI_ UPDATE state on the fa11ing edge of the 
. test clock TCK. The values of the control signal at the Output Multiplexer is summarized 
in Table 6. The control for the Output Multiplexer is then chosen to be the INTEST 
instruction.· 
INTBST 
BSI 
TDI 
.,.___._., ,,......,__--t 
---om "' u:_ 
PD1S3AX 
-------om " UC_ 
PDISJAX 
Figure 22. Implementation of the Input Boundary-Scan Cell 
Instruction 
SAMPLE 
EX1EST 
INTEST 
Control 
0 
0 
1 
Table 6. Output Multiplexer Controls for Input Boundary-Scan cell 
48 
/ 
.,, 
. . . 
,, . 
• J 
TDO 
I'OCHlPi 
• )'°' 
t .. 
(b) System Output Pin 
The implementation of the Output Boundary-Scan cell is shown in Figure 23 (BSO). The 
FRCHIP1 is the signal from the on-chip system logic. The BSO_CAPI'URE, BSO_SHIF'I' 
/ 
and BSO_UPDATE are the controller states generated in the BSSEL block (discussed in 
the Instruction Section). The test data input 1DI comes from the test data output TOO of 
the previous Boundary-Scan cell. The test data output TOO is an output either to the test 
data output pin TOO or to the test data input TOI of the next Boundary-Scan cell. The 
output Boundary-Scan cell consists of one shift-register stage with an output latch. When 
the INTEST and SAMPLE instruction are selected, the shift-register loads the data from 
the on-chip system logic on the rising edge of test clock TCK in the BSO _ CAPTURE state. 
If the EXTEST instruction is selected, the shift-register loads the test data input TOI data. 
Test data input TOI is from previous Boundary-Scan cell. Therefore, the BSO_CAPTURE 
signal is implemented such that the C -R controller is disabled when the 
EXTEST instruction is selected (as discussed in the Instruction Section). During the 
SAMPLE instruction, the input from the on-chip system logic is output to the system output 
pin (as shown in Figure 14). During both the EXTEST and INTEST instructions, the data 
that is shifted out from the previous Boundary-Scan cell (TOI) is output to the system 
output pin (as shown in Figure 15 and 16) on the falling edge of the test clock TCK in the 
BSO_UPDATE state. The values of the control signal at the Output Multiplexer is 
summarized in Table 7. Both of the INTEST and EX1'EST instructions are the control for 
the Output Multiplexer. 
49 
. ' 
·~~ 
FllCHIPI 
mt 
TCI 
" .
Instruction 
SAMPLE 
EX't·EST 
INTEST 
Control 
0 
1 
1 
Table 7. Output Multiplexer Controls for Output Boundary-Scan cell 
Nl2 
,I......_ _ __. 
_ 1111 __ -o« " uc_ 
PD1S3AX 
---m QI UC _ 
PDISSAX 
Figure 23. Implementation of the Output Boundary-Scan cell , 
50 
\ 
. \" 
TDO 
' . 
(c) Tri-State Output System·Pin 
The implementation of the Tri-State Output Boundary-Scan cell is shown in Figure 
24 (BSOEN). FRCHIP2 is the signal from the on-chip system logic. The Tri-State Output /-
Boundary-Scan cell is identical to the Output Boundary-Scan cell. The only difference is 
that the output is connected to a tri-state output buffer, not to a regular output buffer. 
TDO 
NR2 
PRCHIP2 
• • • OUl'fUf 
1111 
(I .. 
uc_ 
tx:_ m .. TOI PDlSJAX 
FDIS3AX 
TCI 
Figure 24. Implementation of the Tri-State Output Boundary-Scan Cell 
51 
() 
\ 
(d) Tri-State Output Enable Boundary-Scan Cell 
The implementatio.,_ of the tri-state output enable cell is shown in Figure 25 
tt' (BSEN). EN is the control signal from the on-chip system logic. The EN control can also 
come directly from outside the chip. The operation of this boundary-scan cell is identical 
to that of the Output Boundary-Scan Cell. Except during the INTEST instruction, the 
designer has the optio~ of implementing the cell differently. The output of the cell can be 
either data from the previo~s cell. (like the Tri-State Output Boundary-Scan Cell) or a value 
of'O', which causes the output state of the· tri-state output pin to be inactive The author 
decided to implement the cell like the Tri-State Output Boundary-Scan Cell. During the 
Test-Logic-Reset controller state, the latched parallel output is reset to'O' which will select 
inactive drive when it connects to the tri-state output pin. The Tri-State Output buffer is 
active only if BSEN is' 1 '. The BSENN signal is the complement of the BSEN signal. 
BN 
1DI ---« QI tx:_ 
PDISSAX 
1111 ti:_ 
---o« .... 
. PDISJDX 
1DO 
Figure 25. Implementation of the Tri-State Output Enable Boundary-Scan Cell 
52 
• 
7 
(e) Bidirectional Boundary-Scan Cell 
The implementation of the bidirectional boundary-scan cell is shown in Figure 26 · 
(BO). The input section of the boundary-scan cell has input from the pin BSBDI and output 
to the on-chip system logic, TOCHIP2. Th~ output section of the boundary-scan cell has 
input from the on-chip system logic, FRCHIP3 and output to the pin, BDBDO. The 
BDSEL signal is from the bidirectional control boundary-scan cell. If BDSEL is 0, this 
Bidirectional Boundary-Scan Cell behaves like an input cell. If BDSEL is 1, it behaves like 
an output cell. The Bidirectional Boundary-Scan Cell must meet the standard, specifies for 
both the Input and Output Boundary-Scan Cell. Because the input and output cells behave 
differently during BD_CAPTURE, the BDSEL will select either the BSI_CAPTURE or 
BSO_CAPTURE depending on the BDSEL value . 
.... 
r 
MBDI r::--,.. 
--
) EXTBST 
ii : IOl:&rl .... 
-
_ BmsL 
y r 
~-
"" ~ r Z· 
-
- v-:,--... J'-... BSBDI , ir; Nl2 PRCDPJ ~ 
- ir: ... FllCHIPJ a IQ."" - y 
-y 1111 
-
' 
DO ... 
-
... a.,o UPDATB 
, 
... BS<l _SHIPT 
-
ID_CAPnllB 
r--J r-,.... r: • 1r: • I ~ - --
• , y - - y . • y 
-
ti:_ 
-
uc_ « QI 
... TDI « QI 
FDISSAX 
... 
PDIS3AX 
... TCS 
~-
r 
IDSBL 7m 
... BSLCAPruBB 
~r: r I . 
.... aso CAPnJRB 
- y -
\ Figure 26. The implementation of the Bidirectional Boundary-Scan Cell 
53 
J 
(t) Bidirectional Boundary-Scan Enable Cell 
The implementation of the bidirectional Boun<b!!y-Scan Enable Cell is showit in 
Figure 27 (BDSEL). The IOSEL input signal is from on-chip system logic. ff IOSEL is 0, 
the control causes the Bidirectional Boundary-Scan Cell to behave like an input cell. If 
IOSEL is 1, the control then causes the Bidirectional Boundary-Scan Cell to behave like an 
output cell. The operation of this cell is identical to that of the Tri-State Output Enable cell. 
During Test-Logic-Reset Controller state (RESET=O), the output of this cell, BDSEL, will 
cause the bidirectional pin to select the input operation. The ST and STN signals are the 
controls of the bidirectional buffers. If the INTEST instruction is selected, it causes the 
bidirectional pin to select the input operation. The output is then in High-Impedance state. 
~-
' 
...._ Sl'N _ zp 
~IND 
-• ~-
,. 
... SI' -
-v ... NDI , 
- INTEST 
~-
". : CAl~l I z;e t>"m -
'IDO_ 
, ,,. 
-
NIU 
--, 
_ BS0_UPDA1. 
. 
, . 
... BSO_SIDPT 
~ BSO_C ffi :B 
~ 
, 
• It°: r-,,..... ~ ...... _ • 1r: -- , • ,r-: I ~ • .. _ IOSBL • 
' ~ 
, y y 1111 Ml: u ti:_ 
IIJI UC_ «ca " ta CIII _ m1 PD1S3DX , 
FDlSlAX 
--,;>- ·, 
.... TCl 
~-
,. Vm ' 
.. u.mr 
, 
Figure 27. The Implementation of the Bidirectional Boundary-Scan Enable Cell 
54 
--~ 
I . 
.. 
' . 
F. Output Multiplexer and Enable 
The Output Multiplexer and Enable logic is implemented as shown in Figure 28 
(TOOMUX). This logic selects one path to be connected between test data input TOI and 
test data output TDO of the chip. For the Test Data Register, BSSEL will be used to select 
TDO_BS signal, BYPASS will be used to select TDO_BP and IDCODE will be used to 
select TDO_ID. As mentioned previously, only one of these three signals can be on at one 
time. The SELECT signal that is generated in the test access port controller will select 
either the Instruction Register or the Test Data Register. The test data output TDO signal 
of the chip is updated on the falling edge of test clock TCK. The ENABLE signal that is 
generated from the test access controller is used to enable the test data output pin TOO. 
TDO is only enabled during two controller states, SHIFl'DR and SHIFl'IR. The signal 
TDO_E is used to control the tri-state circuit of the bidirectional buffer. TDO_EN signal 
is the complement of the TOO _E signal. 
'l'DO 
NDJ 
ND2 ..---------o« .. 
TDO_lR. FDISSAX 
TCI 
TDO_llf 
TDO_B 
Figure 28. The implementation of Output Multiplexer and Enable 
• 
55 
f·· 
.-
. ' 
After designing individual blocks of the framework, the final step is to integrate all 
the blocks together. The final chip level schematic diagram is shown in Figure 17, 
Appendix A. The hierarchical structure of this schematic diagram was made to follow the 
. . . IT AG Test Logic Architecture as shown in Figure 1. The buffers that are used in the design 
are shown in Figure 18, Appendix A. The input, output and bidirectional buffers that are 
. .,J,; 
used in the design are listed in Table 3, p. 23. The schematic diagiam that connects the chip 
level block and the buff er block is shown in Figure 19, Appendix A. 
56 
' ' 
' . . \ 
. r-, 
) 
-r 
IV. VERIFICATION 
After the design of the. test logic has been completed, the next step is to verify the 
functionality of the design. This requires a set of test vectors that is generated independent 
of the design, an AT&T program called TAPDANCE2was used for this purpose. 
TAPDANCE is an algorithm based vector generator that can deter I rtine whether the test 
logic is compatible with the IEEE Standard. After consultation with the person who has 
the TAPDANCE software to generate test vectors, a set of 8041 vectors was generated. 
Two sample pages out of 38 pages of vectors are shown in Figures 1 and 2, Appendix B. 
This list of vectors had to be reformatted to the test vector format that the simulator 
required. 
The netlist of the circuit is generated from SCHEMA using the final chip schematic 
diagram. Both these netlists and the transistor level description of the standard cells are 
inputs to the simulation compilers. The compilation is done using the worst case slow 
conditions. A 0.1 pf routing capacitance per fan out is also included in the compilation. 
Even though the condition is included in the compilation, it has no effect on unit delay 
simulation. Unit delay simulation still gives each gate a unit delay. After compilation, the 
circuit simulator is ready to accept test vectors and starts generating outputs. The sequence 
of the simulation is: logic simulation, timing simulation and fault simulation. 
' The input -wavefor111s of the test mode select TMS and test data input 1DI signals 
'· 
with respect to the test clock TCK is shown in Figure 29. Since both the TMS and 1DI 
... 
signals are clocked on the falling edge of TCK from previous chip or pievious boundary-
57 
_,, 
'i: 
' 
scan cell, the set up and hold tin-c has· to be valid within one clock period. 
Tf1S i 
TDI. 
Figure 29. Input Wavefo1ms of TMS and TOI with respect to TCK 
' 
58 
J ' 
···I· .. 
A. Logic Verification 
Initially, the simulations were done using the unit delay simulation mode in 
MOTIS. As mentioned before, glitches occur during the simulation on the reset line which 
cause the instruction register to e11oneously select the Identification Register during certain 
state transitions of the test access port controller. There is no other way to avoid such 
glitches except to change the design of the contro~Ier. It was decided to keep the test access 
port controller design as designed but to run the simulation in multiple delay mode with a · 
period of 60ns (low speed). Multiple delay computes slower than unit delay, but it is still 
faster than full timing. With multiple delay, capacitance loadings of the gates become 
significant, which reduce the sharpness of the transitions of the signals. There is another 
' I way to reduce glitches while doing logic verification, na~ly to add a large capacitive load 
. " 
to the signal that causes glitches while running multiple delay simulation. The simulator 
compares its output to the expected output of the test vectors. 
~,r 
() 
S9 
-;., ' 
B. Timing Verification 
The timing simulation of the t~st logic circuit is dete1t11ined by running the MOTIS 
/ 
"" full timing simulation. Now, the simulator takes the operating conditions and the 
capacitive loads into account. The number of fan outs and capacitive loads presented by 
the test clock TCK, test mode select TMS, test data input TDI and test reset RSTN pins are 
listed in Table 8. The calculation of the capacitive loads includes the 0.1 pf per fan out of 
a signal. The maximum speed of this design is found to be 19 Mhz. The maximum speed 
of the circuit is basically limited by the propagation delay of the contro~er states from the 
test access port controller. Actually the circuit can perfo1m at higher speed, if both edges 
of the clock are not used. All the input data are clocked on the rising edge of test clock TCK 
and all the outputs are clocked on the falling edge of TCK. The author did not attempt to 
optimize the speed of the circuit Increased drive capability of cenain gates can definitely 
improve the speed. One exat11ple is the test clock TCK signal, which comes right out of the 
input buffer. The BINI OT input buffer is optimized to drive a 5pf load However, the test 
clock TCK signal in this design has a much higher loading capacitance. 
Signal Na111Cs Capacitance(pt) Fanout TCK 16.092 298 
TMS 1.795 16 
IDI 0.987 8 
TRSTN 1.415 16 
Table 8. Loadings of Input Test Access Ports 
60 
) 
/ 
The set up and hold times of the test mode select TMS signal (with respect to test' · 
clock TCK) are also deter11,ined. The wavefOI~ diagrams of both the setup 'and hold ti11,es 
are shown in Figure 30. The set up and hold times are dete111dned by stepping the test mode 
select TMS input across +/- 2ns of the TCK signal. The set up and hold times of test mode 
select TMS are O ns and 1 lns respectively. The actual set up time is less than 0, but it is 
common practice in this case to use O ns instead of negative value as the set up time. The 
set up and hold time of the test data input TOI signal depend on the data shifting operations . 
. 
The TOI signal is an input to the Boundary-Scan Input Cell (BSI), the Bypass Register and 
the Instruction Register. For the Boundary-Scan Input Cell (Figure 22), the BSI_SHIFf 
controls the operation of test data input TOI. For the Bypass Register (Figure 18), the 
BP _SHIFI' controls the operation of test data input TOI. For the Instruction Register 
(Figure 12, Appendix A), the SHIFI'IR instruction from the TAP Controller controls the 
operation of test data input TOI. The propagation delays of the three SHIFI' operation 
mentioned above are different. Since the test vector does not test the INTEST operation, 
the set up and hold time of the test mode select TMS can not be dete1tatined properly. 
Vih TCK - - - _____ .._ 
I 
Signol - -1- - - -
I 
I I 
... .. .. 
Q. ""O 
::, ....... 
~ 0 
Q) L 
"' 
t-
1--
rt-··,, 
~ 
Figure 30. Measuring Set Up and Hold Tune 
61 
Logic 1 
- - Vref · 
Logic 8 
- - Vref 
}• 
The propagation delay of the TDO is al~o dete1mined. · ·The 1DO has a. source/drain 
loading of 4.439pf and an output loading which is assumed to be 50pf. Therefore, the TDO 
signal has to drive a loading of 54.439pf. The waveform diagram in which the propagation 
delay is determined is shown in Figure 31. 
TCK - - -
Signol - - -
Vih 
..... - - ._ .--.-, 
I 
-1- -
I 
I I 
.. . ..
Tprop 
- -
Logic 1 
- - Vref 
Logic 8 
- - Vref 
Figure 31. Wavefo1·111 Diagram of Propagation Delay 
62 
C. Fault Sillllllation 
The fault simulati~s done using the FSIM tool in MOTIS. The number of faults 
that were injected into the fault simulator is 1270. The fault coverage of the design is found 
to be 85%. The author had expected the result to be in the range of 80-90%. The coverage 
of only 85% is due to the fact that TAPDANCE only generates a thorough set of test vectors 
for the test access port controller, the Identification Register and the Bypass Register. As 
for the Boundary-Scan Register, it only tests the EX'l'EST mode. It d<1e.s .. not test the Test 
Data Register under the INTEST and the SAMPLE modes. The Instruction Register 
generates the INTEST control signal and it also generates the RUNBIST signal that is not 
connected to anywhere on the design. In order to improve the fault coverage of this design, 
the following approaches can be followed to improve the fault coverage of this design: 
(1) Write specific tests to test the INTEST and the SAMPLE modes once 
the specific integrated circuit is known. 
(2) Test all the signals from of the Instruction Register block, especially the 
INTEST and RUNBIST signals. 
(I 
V. DISCUSSION/CONCLUSION 
This paper has discussed the problems of board-level testing when the integrated 
circuits do not include any testability features. These problems have been addressed by 
several circuit board manufacturers, principally in North America and in Europe. They 
organized a group to discuss the testability issues on board level testing, and proposed ways 
~ 
to improve testability. However, in order to have the industry reach an agreement on what 
testability features are to be implemented, they have to come up with a standard that 
I\ 
everyone can abide to. After some productive meetings, an IEEE standard of testability 
was proposed and eventually was accepted in February 1990 after issuing 6 draft versions. 
The document from IEEE regarding the standard is very detailed. The document 
describes the functionality of the test logic consisting principally of the Test Access Port 
Controller, Instruction Register, Instructions, Test Data Register, Bypass Register, 
Boundary-Scan Register and the Device Identification Register. Each chapter basically 
describes_ the functionality and standard operation of that particular test logic block. It does 
not show the connectivity between those test logic blocks clearly. The author thought it 
might be a good idea to put the words into design. This way, it becomes easier to \. 
understand and it also shows how all the blocks are connected together. This also helps to 
have a clear picture as how the data flow through the scan path. It can also serve as a 
reference for anyone who has interest in implementing the JT AG Standard test logic in the 
integrated circuit. 
64 
• 
The approach of the framework design basically followed the chapters detailed in 
the standard. The author separates the design into five basic blocks: Test Access Port 
Controller, Instruction Register, Instruction Decoder, Test Data Registers and Output 
Multiplexer. After design, each of the blocks is verified individually. Once all the blocks 
have bern verified, the author then connects all the blocks together.' The verification of the 
\\ t \ ·,, '· 
coniplete design used the test vectors generated by the conf onnance test vector generator, 
TAPDANCE. 
The tools that the auth9r used in the design and verification processes are all AT&T 
CAD tools. The author describes the design methodology and circuit implementing 
procedure in Chapter m. Besides getting the readers familiarize with AT&T CAD tools, 
the author would like the readers to understand the purpose of each CAD tool .. Therefore, 
anyone from any company will have the capability to generate the same results using 
different CAD tools. Since the main focus of this paper is not evaluating the CAD tools 
themselves, the CAD tools that the author chose might not be the most efficient ones. 
The circuit design described in this thesis is not speed optimized, especially the test 
access pon controller. Currently, the states of the test access port controller is decoded 
from combinational logic of the output from the flip-flops. A better finite state machine 
should be implemented such that the states are the outputs of the flip-flops, especially if the 
outputs of the states are used to control asynchronous circuit. There are ways to implement 
fmite state machines in which the output comes directly from a flip-flop. A tool called 
BESTMAP from AT&T Bell Labs is capable of generating this ftnite state machine. The . 
' 
- .. 
outputs from the test access port controller control the operations of the. rest of the te,stlpgic. 
·, ·• J . 
{} 
Therefore, the spec,4 _of the test logic will be improved if the test access port controller 
design is optimized. 
In order to show different ways of implementing boundary-scan circuits on the 
buffers, the author uses four different types of buffers. Namely, the input buffer, output 
buffer, tri-statable output buffer and bidirectional buffer. All theses buffers are 
characterized in the AT&T 0.9 micron Standard Cells Library Data Book. 
The verification of the framework design was done in the following sequence: logic 
simulation, timing simulation and fa ult simulation. The process of logic simulation was not 
smooth. While running unit delay mode, glitches occi on the reset signal. Therefore, 
during some state transitions, the shift registers in the Instruction Register are 
asynchronously reset or preset to select the Device Identification Register to be connected 
between test data input pin TDI and test data output pin TOO. The way the author solved 
this problem is by running the circuit under multipl~ delay mode. Because of the 
significance of capacitance loa_dings now, the rise time and fall time of the signals are not 
as sharp. as before. Therefore, the glitches do not occur on the reset signal anymore. 
The timing simulation was done by running in full timing mode. The process is 
very time consuming. With 8041 vectors, the turnaround time for each run is 
.. approximately 1.5 to 2 days. The drive capability ("drivability") of a few signals in the 
design is not too good. Under worst case conditions, the test logic circuit is only.running 
at 19 Mhz. Since the main focus of this paper is not in designjng a high. speed test logic, 
. 
-
_ the author did not spend too much time to ,try to speed up the opera.ti.on. The set up and hold 
,,. 
. 
. time of the test mode select TMS signal is found··to be Ons and llns respectively. As 
melltioned,t~ore, the set up time is actually a negative value.. Since the set up time is 
usually SJ)CCifi~ as a positive value, therefore the set up plus hold time is I Ins. This kind ' 
. 
. of set up and hold time specifications was due to the longer delay of the clock. In order to 
achieve the set up plus hold time to be approximately lns (the set up+ hold time of a typical 
flip-flops in AT&T 0.9 micron Standard Cells Library), the delay of the test mode select 
TMS signal and the test clock TCK need to be the same. In this design, the test clock TCK 
has a much larger capacitance loadings. Therefore, one good way to improve the set up and 
hold time specifications is to improve the drivability of test clock TCK signal and delay the 
test modeselect TMS signal accordingly. The propagation delay of the test data output 
TOO signal is found to be 29ns. This delay can be improved by replacing the B0T10T 
output buffer with one that has a much higher drivability, for example, BOT06T. 
· However, buffers with higher drivability increase the power dissipation. 
The fault simulation was done by running the FSIM tool in MOTIS. The fault 
coverage is found to be 85%. A listing of ways to improve the fault coverage was 
mentioned in the previous chapter. The main reason why the test vectors generated from 
TAPDANCE did not give a 100% fault coverage is that some of the test logic are chip a 
dependent Without a specific chip in mind, a fault coverage of 100% is impossible. 
For most designers, the major concern of implementing the testability circuits is 
the extra pin counts. The basic features.include additional pins, test clock TCK, test data 
' input TOI, test mode selectTMS and test data output TDO (TRSTN is optional). Besides 
the additional pin counts, the test circuits require increases in chip area and·power. The 
67 
' I . 
. \ 
. 
. additional pins may require the chip designer to use a larger .package which. in turn 
increases the chip space. on the board. the increase in chip space is usually one of the 
objections from the board designers, who do not realize the benefit of having those 
testability features implemented in the chip. As for the chip designer, aside from the 
increase in areas due to the extra features in the chip, the additional grief of having to 
-understand the standard is usually the reason why the chip designer might oppose to the . 
idea of including testability features in the chip. The chip designer does not benefit much 
from implementing the test logic circuits, it is the board level designer who benefits the 
most. Once integrated circuit designers understand the JTAG Standard and can live with 
the extra pin counts and chip area, the board level designer can benefit tremendously. 
Basically, the conclusion is that the board level designers have to convince the integrated 
circuit designers to implement the testability circuit 
68 
0 
~' .. 
,. 
REFERENCES 
1. Standard Test Access Port and Boundary-Scan Architecture, IEEE std. 1149.1/06, Test Technology Techni~al Committee of the IEEE Computer Society, November 22, 1989. 
. 
2. Anton T. Dahbura, M. Umit Uyar and Chi W. Yau, "An Optimal Test Sequence for the IT AG/IEEE Pl 149.1 Test Access Port Controller," in International Test Conference, 1989, pp. 55-62. 
3. Alexander Miczo, Digital Logic Testing and Simulati.on, New York: Harper & Row, Publishers, Inc., 1986. 
4. Williams, M. J. Y. and J.B. Angel, "Enhancing Testability of Logic Scale Integrated Circuit via Test Points and Additional Logic", IEEE Trans. Computer, Jan. 1973, pp. 46-60. 
5. Eichelberger, E. B. and T. W. Williams, "A Logic Design Structure for LSI Testability", Proc. 14th Des. Autom. Con[., New Orleans, La., June, 1977, pp. 462-468. 
6. Edward J. McCluskey,Logic Design Principles with Emphasis on Testable Semicustom Circuits, New Jersey: Prentice-Hall, 1986. 
7. Merra M. Pradhan, Rodham E. Tulloss, Harry Bleeker and Frans P.M. Beenker, 
"Developing a Standard for Boundary-Scan Implementation", International Con/ erence on Computer Design, 1987, pp. 462-466. 
8. Chia-Jeng Tsing, Ajit M. Prabhu, Cedric Li, Zafer Mehmood and Michael M. Tong, " A Versatile Finite State Machine Synthesizer," Proceedings of International Conference on Computer-Aided Design (ICCAD ), November 1986, pp. 206-209. 
9. AT&T 0.9 micron CMOS. Cell Library, "Standard Cells and Function Blocks", 1990. 
10. Basant R. Chawla, Hermann K. Gununel and Paul Kozak, "MOTIS - An MOS Timing Simulator",/EEE Transactions on Circuits and Systems, 1975, pp. 901-910. 
11. Chin Fu Chen and Prasad Subratnaniam, "The Second Generation MOTIS Timing Simulator - An Efficient and Accurate Appl'Oach for General MOS· Circuits", Proceedings of the International Symposium on Circuits and Systems, 1984, pp. 538-542. 
· 
69 
' 
' 
11. Chin Fu Chen and Prasad Subramamam, ''The Second Generation MOTIS Timing 
Simulator - An Efficient and Accurate Approach for General MOS Circuits", 
Proceedings of the International Symposium on Circuits and Systems, 1984, pp. 538-542. 
12. Chi-Yuan Lo, Hao N. Nham and Ajoy K. Bose, "Algorithms for an Advanced Fault 
Simulation System in MOTIS", IEEE Transactions on Computer-Aided design of 
Integrate Circuits and Systems, March 1987, pp. 232-40. 
13. K. Keutaer, "Dagon: Technology Binding and Local Optimization", Proceedings of 
Design Automation Conference, 1987. , 
14. L.W. Nagel, "ADVICE for Circuit Simulation", Proceedings of the 1980/nternational 
Symposium on Circuits and Systems, April 28, 1980. 
15. Samuel C. Lee, Modern Switching Theory and Digital Design. New Jersey: Prentice-
Hall, 1978. , 
' '! \I ,, 
70 
- .. -
APPENDIX A 
LISTofFIGURES: -
Page 
Figure 1. The State Diagram Implementation of the Test Access Port Controller 72 
Figure 2. The Circuit Implementation of the Test Access Port Controller 73 
Figure 3. The Decoding Circuit of the Controller States 74 
Figure 4. The Internal View of Combinational Logic, FMNSNEWO 75 
Figure 5. The Internal View of Combinational Logic, FMNSNEWl 76 
Figure 6. The Internal View of Combinational Logic, FMNSNEW2 77 
Figure 7. The Internal View of Combinational Logic, FMNSNEW3 78 
Figure 8. The Internal View of Combinational Logic, OUTNEWl 79 
Figure 9. The Internal View of Combinational Logic, OUTNEW2 80 
Figure 11. The Internal View of ombinational Logic, OUTNEW 4 
Figure 12. The Implementation of the Instruction Register, IR 
Figure 13. The Preset State Instruction Register, IR_P 
Figure 14. The Clear State Instruction Register, IR_C 
\ 
Figure 15. The lmplemen--Jtion of the Selector Circuit, BSSEL 
Figure 16. The Implementation of the Device Identification Register, ID 
• a • 
Figure 17. The Implementation of the TEEE Standard Testable Circuit, CHIP 
Figure 18. The Input, Output, Tri-State and Bidirectional Buffers, BUFFER 
Figure 19. The Complete Framework Design 
71 
81 
82 
'_) 
83 
84 
85 
86 
87 
88 
89 
90 
! 
• 
1llS 
ITIDLB 
••• TIIS . 
SBJR 
CAPIR 
++ 
SFfDl fTMS 
FSM 
? 
ma 
• 
EXIT2lR 
Figure 1. The State Diagram Implementation of the Test Access Port Controller 
0 1 2 3 4 s 6 7 8 9 
TRSTN 
FSMPSO FSMN PDN FSMPSO FSMPSO OUTI 
1 PSMPSO D Q 
FSMPSO our1 
I FSMPSI 
I 
2 
PSMPSI 
FSMPS2 
FSMPS2 PSMPS3 UC_ FSMPS3 na CK <1' 
FDISJGX 
OlffNEWI 
C TCK 
C FSMPSO 
FSMPSl FSMPSO FSMNS1 Pll4 1 D Q FSMPSI 
FSMPSO Ol/f2 
2 
PSMPSO FSMPS2 D 
PSMPSI 
D 
FSMPS3 
UC_ PSMPS2 na Cl ~ -...J 
FDIS3GX 
w 
OOl'NBW2 
TCK FMNS 
E 
E FSMPSO FSMN 2 FSMPS2 FSMPSO FSMPSO OUT3 OlJl'J PIJ4 
PSMPSO FSMNS2 
1 I D Q 
FSMPSI 
FSMPSJ. 
PSMPS2 FSMPS2 
F 
. F 
PSMPS3 FSMPS3 UC_ na Cl c,4 
Olll'NEW3 FD1SlGX TCK 
G 
G 
FSMPSO FSMNS3 FSMPS3 . FSMPSO FSMPSO OOl'4 Ollf4 Pll4 I 1 
14'SMPSO FSMNS3 D Q 
FSMPSI 1-'SMPSI 
FSMPS2 
AT&T-NOl'IE'l'AllY 
FSMPS2 
FSMPS3 u. .. I 
·--
l~'SMPS3 
T APmlffllOIJ.ER sa 
H 
UC_ 
FD1S3GX • -VEASYNC. ~ET ftiBIIJAllY 211. 19'0 H 
TMS ~ 
--· -
0 EW4 
2S 1 
FDIS3GX TCK 
T APC'lllL. l 
-
"'· l ot:2 
0 l 2 3 4 s 6 7 8 9 ...... Figure 2. The Circuit Implementation of the Test Access Port Conu-oller 
.....J 
~ 
r 
,. 
I 
C 
OUTI 
OUT2 
• 
Ol!l'4 
I 
• 
• 
I 
0 
2 J 
• 7 I I I 
' 
oun 
ll ) 5 ~ .. RESET) ,. 
oun NIM 
,~ ) .... = ~ .. RUMTF.ST) 
NIM 
I our1 
,~ ) 5a ~ .. CAP11JllEIR) 
-our1 NIM 
E ll ) ~Dill Sllll·Tllt) C 
NIM 
OUl'I 
ll ) £)><>NI OUTIN s ~Ntl UPDAlUt > ~ ~ .. NIM 
• 
~NI OUl'JN out'IN ll ) :a ~ .. c.vrtJIUiDll ) ._ 
~--
Ol!l'4N 
OUl'IN fO ;: ll ) ~ .. S .. Fll>ll) I 
fO 
OUl'IN 
ll l) .... s ~. lJIOATliDI ) 
11M , 
liNAILi ~ 
,,-------,• 
-
NIB 
TCI 
"in------oca •- UC_ 
~ ~ _ swll>IS3AX 
...;our;;.;;.;.;1;;.__ ___ ~W----~IHU------~) 
Figure 3. The Decoding Circuit of the Controller States 
2 
• 
ATaT W'UY 
u .. ,__ ....... ,.___ 
I TAl'ClllL.2 
-MAIOt 4. IHI I 
-- -lS J 
-
1na1 l 4 1 I 
• I 
' 
,·----~---··---.----6 
L-----------------------------------------·-·--·· ------------
----·------·-----------
0 
8 
C 
D 
-...J 
VI 
E 
F 
G 
H 
0 
1 2 3 4 . s 6 7 8 9 
-' TMSN ~ 
A FSMPSl 
' I 
fSMPSIN Nm 
A ND2 
I I 
FSMPSO ND2 
ND2 A • 
I I 
ND2 ND2 C 
ND3 FSMNSO D • 
-----------41 
A ND2 I 
ND3 
FSMPSO 
A 
• 1 I I 
C 
-Ml] D 
FSMPSI 
A 
) TMS £)>olNRB ~ 
) FSMPSJ 
~:IN p 
NDl 
FSMPS2 MPS2N I 
ND2 
FSMPSO 
A 
• 
INRB 
) FSMPS3 
~PSMPSlN G 
INRB 
ND2 
AT&T -lll<IIIJBl'AI.Y 
u.. • I d II TMS 
T~CONnOLI.Elt • 
OPTIMl7.l!D IDGIC FOR FMNS0 HUNlUAllY 19, ·- ff 
-
Figure 4. The .Internal View of Combinational Logic, FMNSNEWO -2S 
~·-
I 
-I l . 2 3 4 s 6 1 
9 -·--
". 
0 
A 
8 
C 
D 
E 
F 
G 
H 
0 
1 2 
TMSN 
FSMPSON A 1 
I 
ND2 
FSMPSl 
A 
I 
ND3 
FSMPSJN 
A 
I 
ND3 
FSMPSJN __ .....,, 
------11 
' FSMPSl 
~-....,A 
__ ..... 
------11 
FSMPSON ND2 
FSMPSl 
il"'RCft -~• 
-----11 A 
FSMPS2 
-~• 
ND2 __ .... , 
---~1 
FSMPSO ND2 
3 
• 
A 
I 
ND3 
£">-------1A 
------11 
ND2 
NDZ 
:i-------1A 
----11 
4 
ND2 
ND2 
s 
A 
I 
ND2 
___ .....,, 
___ .....,, 
6 7 I 9 
)TMS ~ 1\ISN 
INRB 
) FSMPSO 
~fSMPSON 
INRB 
) FSMPSl 
~~MPSlN 
) FSMPS2 ~ fSMPS2N A ,Z 
INRB 
) fSMPS3 ~~MPS3N 
----------'A FSMNSI 
1.>---___.· 
---~1 
ND2 ND2 
-------11 
ND2 
ATAT- ...... MY 
U. • I «-
TltPCONDOUJill • 
I 
C 
D 
B 
p 
G 
OPTIM17JU> LOOIC R>ll FMNSI . MiAIIJAaY a 19'0 · H 
Figure 5. The Internal View of Combinational Logic, FMNSNEWl -- -2S I 
-
PMNSNiWl.l I 
I 2 3 4 s 6 7 9 _ .... 
0 
~ 
C 
8 
C 
D 
-..J 
-..J 
E 
F 
G 
H FSMPSO 
0 
) 
TMSN 
FSMPS2N 
FSMPSON 
1 
FSMPSO 
I 
FSMPS2 
FSMPS3N 
FSMPSJN 
FSMPSON 
FSMPSl 
FSMPSON 
I 
FSMPS2N 
TMS 
MPSON 
INRB 
I 
A 
I 
A 
I 
A 
I 
' I 
2 
NDl 
ND2 
NR2 
MPSI 
2 
l 
A 
I 
ND2 
A 
I 
ND2 
NR3 
FSMPS 
INRB 
l 
4 
A 
I 
ND3 
A 
I 
ND2 
INRB 
MPS2N 
INRB 
4 
A 
I 
ND2 
' I 
NDl 
FSMPS3 
s 
6 
> TMS 
A 
I 
NDl 
A 
8 
ND2 
j 
MPSJN 
6 
Figure 6. The Internal View of Combinational Logic, FMNSNEW2 
7 I 9 
~ TMSN A INRB 
I 
C 
' 
FSMNS2 
I 
ND2 D 
E 
,. 
J 
,~--- .. -· F 
G 
ATAT • NOIUll'AllY 
U. • J d-
TAPCONllOIAJI • 
OPl1MllEO LOGIC FORBINS2 IUIUA&Y·20.19'0 H 
-2S 1 
,,,. FMNSNEW2.I 
-I 
7 8 9 ............. 
0 
A 
I 
C 
D 
.....J 
00 
E 
F 
G 
H 
0 
I 2 3 
TMS 
FSMPS2N 
A 
I 
A Nm A 
FSMPS2 I I A ND2 I 
ND3 FSMPSON 
FSMPSO 
I A 
I 
ND3 
FSMPSON 
A 
I 
A 
ND3 I 
FSMPSO 
I A 
I 
TMS 
s· 
ND2 
. . 
/ 
6 7 8 9 
NR2 
A FSMNS3 
---------ti 
ND2 
) FSMPSO ~ m:MPSON 
) FSMPSl ~ FSMPSIN 
VINRB 
/SMPS2 ~ FSMPS2N 
~RB 
) FSMPS3 ~ FSMPS3N 
~RB 
ATAT-llllClflal'A&Y 
U.. • I d 
TAPCONIIOIAM Ill 
A 
I 
c"tc 
D 
E 
, 
G 
OPl1MIZiD I.DOICRMlfMNSJ ll!?fUMYJ0-1.. II Figure 7. The Internal View of Combinational Logic, FMNSNEW3 ••• 
-2S I 
-
AINNW11 
-I 
I 2 3 4 s 6 7 8 9 ill ...... 
o. 
/ 
0 I 2 3 4 s 6 
FSMPSO 
I 
I 
NR2 
A 
I 
C ND2 
NR2 
D 
..-.J 
\0 
FSMPSON NR3 
E 
NR2 
F 
),__F_SM_P_so __ ~ FSMPSON 
~RB 
G 
H 
Figure 8. The Internal View of Combinational Logic, OUTNEWl 
0 I 2 l 4 s 6 
. n 
r 
7 
A 
I 
7 
8 9 
I 
C 
our1 
ND2 D 
.E 
F 
G 
ATAT · '90IU!TMY 
UN plllllt-.118 1 «-
T~CONTltOU.a m 
OPl1Ml7.ED LOGIC R>ll OUTI flillWAllY lt. lttD H 
•• 
I 
-- -2S I 
. -I 9 __ ... 
0 
00 
0 
B 
C 
D 
E 
F 
G 
H 
0 
.0 
1 2 l 4 s 6 
FSMPSO 
• A 
I I 
FSMPSIN ND2 ND2 
• 
I 
FSMPSO Nm 
1 
NDl 
) FSMPSJ ~ FSMPSIN 
INRB 
Figure 9. The Internal View of Combinational Logic, OUTNEW2 
I 2 3 4 6 
7 
OOl'2 
7 
8 9 
A 
I 
C 
D 
E 
p 
G 
ATA;T-~AIY 
UN • I I d-
T~CONl1lOU.St sa 
OP11MIZliD LOO.IC Rlll OUT'l f1181WAAY .,. IMO H 
-- -2S 
9 
I 
-I __ ..... 
/ 
0 I 2 ] 4 s 6 
.. 
) FSMPSt 
~RB 8 
A 
~ I )FSMPS3 ND2 INRB C 
A FSMPSIN 
' 
I 
I 
A ND2 
ND2 I D FSMPSI 
A ND2 
I A 00 
ND2 I ...... 
ND2 E 
FSMPSO 
A 
I 
ND2 A 
I FSMPSIN 
A Nm 
F 
I 
ND2 A 
I G FSMPSl 
.l Nm 
I 
NW. 
H 
Figure 10. The Internal View of Combinational Logic, OUTNEW3 
0 1 2 3 4 s 6 
7 I 9 
A 
FSMPSIN 
I 
FSMPS3N 
C 
D 
Ollf3 
E 
F 
G 
" 
AT&T • f'MJ11181'MY 
U.. • I «• 
TAPCON'l'IOUJill • OPTIMIZED I.DOIC Rlll Olm fll&IIAllY ,, •• ,. B 
-
. OlfflliWl.l 
7 • 
--· -2S I 
-I 
9 -· _., .... 
--~ 
00 
. Iv 
0 
I 
C 
D 
F 
G 
H 
0 
I 2 
FSMPSO 
' I 
ND2 
·· FSMPSON 
A 
I 
f'SMPS2N ND1 
FSMPS2 
FSMPSO 
~----tA 
-------· 
Nm 
">-- ~r:-.----t A 
-------11 
'")a FSMPSO 
) FSMPS2 
) FSMPS3 
I 2 
3 . 
A 
I 
__ , 
_ ..... , 
ND2 
Nm 
~ fSMPSON 
INRB 
E)>o INKB fSMPS2N 
~ fSMPS3N 
INRB 
4 
3 4 
A 
I 
_ ___., 
_ _...., 
s 
ND2 
NDl 
s 
6 
A 
I 
ND2 
6 
Figure 11. The Internal View of Combinational Logic, OUTNEW 4 
7 8 9 
I 
\ 
"• 
C 
0Uf4 
D 
E 
F 
G 
u. .. _ 
TAPCON11lQUBl 
-OP11MIZED LOGIC Rll~4 fiNIJMY It. lM H 
-- -
J 
2S I 
OUIMiW4.I 
-I 
1 9 ...... 
0 
A 
-
-
--
8 ,ss 
.... TDI 
, 
C 
TCK 
.... RESET 
, 
.... CAPl'IJREIR 
, 
SHIFllR 
, 
UPDATEIR 
E 
F 
G 
H 
0 
1 2 3 
IR2 
IR2 
TOI ~,iii-
IR_P 
Nil 
INTEST 
NR2 
-
--
ISS 
TDO_IR2 
4 
CAPDA.TA I I IIO ti -. 
TOI n B rl u, I mo 
IR2 
IRl 
IRO 
6 7 I 
IRI 
IRI 
"'° CAPDA.TA . i m IIO 
~•§ii. TDO_IRl TDI 
IR_C 
' 
. 
IDCODE 
NR3 
RUNBIST 
NR3 
Figure 12. The Implementation of the Instruction Register, IR 
-
9-
A 
. 
IRO 
IRO I 
11)()_11." 
, 
IR_C 
C 
D 
I 
F 
G 
•• 
-*'°'"•• B _ ... -
2S l 
... 
9 •••• 
0 I 
A 
RF.SET I 
UPDATEIR 
C SHifTIR 
D CAPDATA 
E TDI 
F 
G 
H 
0 I 
2 3 4 s . 6 1 8 9 
mo 
I 
C 
MUPDA D ,o 0.__ _ _._ _______ 11_0__.. 
D D 
UC_ Qt 
FD1S3AX 
Figure 13. The Preset State Instruction Register, IR_P 
3 4 s 6 
UC_ 
FD1S3BX 
ATH---Ed.Y 
UIII • k 9 I 
INS11lUCl10N IUiGIS11ll 
I 
F 
G 
-IMIIClt •J. •• Br FDlS38X- +VliASYNC. PllESEI' ---•• -.------. ..... I 
2S I 
IR_P.I 19'1 
7 9 pg 1 .... 
0 I 2 l 4 s 6 
I 
UPDA'IER 
C SHIFDR 
ATE D CAPDATA 
IIJI 
IIJX Qt UC_ 
---
TOI B . 
FDIS3AX 
F 
G WET 
H 
Figure 14. The Clear State Instruction Register, IR_C 
0 l 2 l 4 s 6 
/ 
7 I 9 
TOO 
IIO Qt-------------~ 
UC_ 
<Xa, (JI 
R>IS3DX 
u. 
At'aT· ........ 'l 
.. I 
INS'lllUCDON UOISI * 
FDISlDX- +V£ASYNC. a.&All 
IR_C.I 
7 
•• 
-
2S I 
••• 9 •••• 
I 
C 
D 
B 
F 
G 
B 
V 
00 
°' 
• 1 J 
• 
,. IP_CAPIWE I I 
... 
.. 
• 8P_SIIIFr 
I 
NDI 
( 
III_CAmml 
- ... 
... • 
' 
BSI_SHFI' ' saana 
.taf'11>& 
I 
I 
... 
... 
I I.IM'IIDI 
' I 
__ WDA11l 
lftl11111t 
... 
... 
• 
CAl'na&ll 
l>_CAffllU 
,a 
• StlFIDa ID_SIIFr 
JU 
I Figure 15. The Implementation of the Selector Circuit, BSSEL 
L-----,------,----:1--.----;1---.-~,-f- - i • 
' 
1 
Im 
1 
I 
UO_CAl'IUU 
mo_sa... 
UO_ll'DAlE 
Sii 8CT El a J IYPAII. 
IOI.N>MY-K:Ni a1 mom 
...... s 
-
assa..1 
• 
' 
,. 
I 
( 
• 
I 
• 
• 
-Ml\aal JI. ,,,. I 
- -lS ) 
t 
0 
0 I I I 2 I l I 4 I s I 6 I 7 I I l 
' 
l 
- I 
' & 
- y 1>1, I ,f lD( )1 ::2tJ ... ...., .. , .. 11--- ,~ ,.._ ~ 1>1, 101• _ IDIJ IDIJJ:291 - ID(J I ::2tJ ·-. 1a -
- la '---
·- •• . 'a ID_c.vna I Illa) t 
I ... ID_...,. 
• 
• ID_CVIWI 
, 
• ID_ ..... 
t ID(IJ:121 , ? ID07:2JJ .. 
-
·h--- 1)(14 IJ) WI IJ: 12) ._ IDPl~I ~- 1, --~ IDC272S) .. ~ la ··- ,ia l ~I ID_c.vna l .-0 C ID_CV'l\8 am 
I)_ .... C 
1) ...... 
t ? IDII IDW 
-
VII 
·h--.. -- Ir 190- WIJ 1011 1023 - IUM la 1a ,_ -
--
,i I •. , 
l)_e,.vnaa ID_CAl'1Ula I .... D a.ao ID_ ..... D ID_lltfl 
? IDPJ22J ,t ID( 10:t) 
-
, .. 
_. ID(l4:U) ~ - 1, ... _ (Ilf'll:221 lllfl I 111 11-- ID! IO~J ..-00 1G ~- .. 
....J ,- fia aa 
ID .... ID c.vnaa I Am 
.. _ . 
-· 
'I 
I I 
f ,? .. .,. W(:Zt:»J .. 
1.~ -- .,. 11-~ liDI ID(;U:211 , __ ID(ll:20) -- ,- .. 1a aa' 
ID -CAl"l'UUI aaa IIIUO ID CAl"IW& 
ID_SIIIPI' 
f r"1 1>_1111'1' 
-
, 
I ,f ID(7.IJ ID(lt:171 .. 
1, no- ICll If 171 JDCl:11 ,~ -~ 1)(71) 11)(20:11) 1111 - ~ - .. ~ ,, Q 1'1 I 1'a ID_CAl'IUl.a .-0 IIIUO l)CAl'IUU 
ID 11111'1' 
G m_.....- G f VII ID(l6:U) 
··h-- ,? u» IOI 17:16) 
-
IOI 16 I.SI 1,--- ~ - ns IDI WO AT&T ,.Ol'l&BTA&Y 1Q ~- u.,-•• - .... 1~ 
..al ·- 1'1 lOCOOE. REG&SlHl sa ID CAl"NU uao THE IIXDIJli IS OliCli,t901 
WA&Ot '· 19'0 a>.CAP'IUU I II ID SHll'T 
-- --
l>_Hl'f 
6S I 
--·--1 IU. I 
-
&faf I OP l L-
--- I - I l I I I I T f I s b 7 I 9 
__....... 
0 I l l 4 
' Figure 16. The Implementation of the Device Identification Register, ID 
00 
00 
' 
-
• 
-
C 
-
D 
~ 
E 
-
fl 
-
G 
-
II 
- 1111 
-
. TOl 
~-
~-. 
0 I I 
- .. 
, 
,cs 
_,....,, 
11•1 
ao_..,.. 
IIO_~II 
q 
0 I I 
I 2 I 3 I .... I 5 I 4 I 1 I 
- -
. --. 
~u!n. •" .::: I -, ,-- -- 1• -,II, 1·1 "' 1tl! -· -, 
... 
-~ .. 
-
,.-
. 
- .. 091 l1r: - . 111- - . ·- Ill- -· .. TOOW2_ - - -- ·· ltir-, , --- ---- , 
.1 ' ) : :, 1 lll'ii- .. _ ,1111, -, 
---
,llilii , 
-
.. .... 
• 
• ._.. 
It 
"IUD.ID 
I 
---
-
ffllll -
.. I • 
-
11--I 1'a 
"'"' , 
-~ . 
~ 
=~.l ~ ~ I 
-
111, 'I! 11 r'ia·a •. 1·•1· 
I 
I 
111 -
--
-
• 
~ ... .__ 
~-
....... 
·-
--
,_ 
...., 
uc_ 
,....,. 
,,. ...... 
• ~ -
·-..... 
waMl'llla -·- ·-.... 
~-
. 
-
...... ---
---
ui; 
-
-· 
-
.. 
-
.. 
fAICIIL 
·-I 2 I l t • f I s l Ii I 1 1 
Figure 17. The Implementation of the IEEE Standard Testable Circuit~ CHIP 
I l 
' 
" -
--~ , 
' 
-
I 
• I 
l 
I 
-
-
I 
.. _ 
--, 
C 
I 
JIii 
., 
...,.,_,. 
,,, --
__ ,,, 
:JI --
. 
, 
-I 
-
• 
( 
j 
~ 
E 
! j 
--
f 
..-
I 
' 
-
AT.ttT · .. <WalhTA&Y 
u.,----· I 
-
-
I 
IIA.aOf M.IM I 
-- -6S l 
I 019'.l -I nF I 
I I 
' 
p ..... ! 
() 
, 
l 2 J I 4 I • I 7 I I l 
' 
l 
' 
[>:,or ) IISIPAO I I BSI) "-- [>:,01 • > rm I I TJUn') I PAD 
• 
PAD I 
.. 
[>:,or > nu I I 1IISINT) ._ - I [):. ( PAD I I ) ltO l ISIPAD) C t [>:,or PAD ) 1CI I I ™> ' 
... - PAD _ .... 
., 
~. NC5N 
• 19'1 IJ9'AI) -• - IN!Rf m~ [)C '•v I , , I I TUneff) V IOTIOI' ) 1UTN I PAD ~ 00 4 PAD \0 
- llliN 
., 
I I 
~ -
- ffll 
._ 11>0..JiN 
"' , 
, . 1111) , • 
~. mo 
_ ISIDD snt---.. 
- TDOINT mt-,..,.. TDO _ , 
'•v J , ~ VIOTIOI' I ., v ISIDOPAD_ 
- ST Mm L'D" ... - PAD ., 
/ MDI ' . ISIIOI I ND ..... 
"' 
_ 100_6 
•an• • • , 
-
ATaf PW FAIII' 
u... -- ---
I Figure 18. The Input, Output, Tri-State and Bidirectional Buffers, BUFFER INftrr. Ol111'1/f, ftl-STA'l'B SUSAN 1. IIA,aQ AN> IIIIDaiiCl10NAL 1111 - S AIWL U. 1919 I 
- -3S I 
.. l -· 1.wri '----o----,lr----.-----,.-1----, --·--,---J----i ---, --i----,----,,i-----.·-----r--·-:;-7 _J_-~,r=--~.~--=r,::=:.:...-~. -';;!=:;! 
A 
I 
C 
D 
E 
F 
G 
ff 
0 I 2 3 4 
BSBDI 
BSBDI 
OSI 
Ill 
FRCHIPI 
1-ltOOP2 
AtCHIP3 
IOSFJ.. 
TCl 
mt 
'IMS 
TISTN 
CHIP 
UBOO 
~ 
8SP.NN 
BSO 
~ 
ST 
S'IW 
TOO 
TOOJ! 
TDOJ!N 
TOOUPI 
TOOUP2 
CHIP 
BUFFER 
6 
BSBDO 
BSBDI >-.nnn~--------1 BSBDIPAD BSBD11-----"K"X'I~~~ 
-:all"f"------tBSBOO BSBOOPADL------~~ 
----------11nBN mlL-----~rw:,.-:,.::-
---------tBSf.NN D>BNPADL---------~ 
~----------1BS•AD BS0PADl------.r111nnrr, 
-w'Jll70lll.r------, BSO TCXINT'I------J1111t11K1111r 
--------1BSOl!N TDIINTL--------..c~ 
--..----------1ST mot------..:"T,i;ww~ 
--------------tS1N lltGINTL-----------~ 
">----------1TCl TRSTNINT'--------
h11Pv'\Kl"l'r-----~1DI 
--...i~r------t11>0lNT 
.,....:x,lll'tr"-----1TDO_H 
-------1mo_EN 
>...W!lll~------,TMS 
~--------11UIN 
BUFFER 
Figure 19. The Complete Framework Design 
0 I 2 4 5 6 
7 
7 
8 9 
A 
I 
C 
D 
F 
G 
AT&T NOl'aETA&Y u.,. • I -
TOP VEW Of TIE Rt.AliEWOU SUSAN S. DANO 
DESK'..N APltL l).19'0 H TWOBIOCIS'.OtltABURU .__ -
2S 
TOP.I 
9 
-l OFI 
-~· ...... 
-------
1"1'1'f .. ' -~ .. 0 ... 
GIi tr O 1DD 
'T ::, la 
o ca 
-------------
--------------------
l. IUN d Im 
llN n I 11D 
J. 0001 •1 I llD 
1001 •l I DJI 
l.JlOllOIDJI 
:101 10 I ax 
4. ,101 11 I ISi! 
::01 11 I DJI 
s. 0001 10 • m 
;OOl JrO I ax 
6. 0001 Jrl I lDDI 
!001 II I lDDI 
7 ,001 10 I lCllll 
:o:n •o I ax 
,. 0011 11 t. m 
!Oil :rt :. G:11 
t . oo 1 1 10 :. m 
1 o,: :ro t. :ax 
10. 0001 Xl :.. IXX 
!001 11 L :ax 
ll. 0001 JrO Im 
1001 JrO I 1CD1 
:2. 0001 Jrl I lDDI 
1001 Jr1 I DJ! 
ll. 0001 10 L lCXI: 
1001 JrO I. llD 
:•. 0101 11 :. m 
: 101 11 L m 
1S. 0101 10 I ID 
: 101 •o I m 
'.i. 0111 Jr1 I DJ! 
ti 11 J:l I lDDI 
P . 00 11 JrO I 11D 
:011 H I 11D 
11. 0001 11 I lDDI 
'.001 Jr1 I ID 
lt. 0001 JrO I 11D 
1001 10 I llD 
2 0 . GO 11 Jrl I lllll 
,011 n • m 
21. 0011 •1 • m 
10 11 U J: llD 
11. 0001 •o • m 
1001 •o • m 
2l. l>OOl 10 J: ID 
1001 •o • m 
24. 0011 J:l I lDCII 
1011 n Im 
JS. 0011 11 I. m 
1011 J:1 L DJ: 
2,. 0011 Jrl Im 
1011 n Im 
27. OOll 1:11 ax 
1011 J:l I llD 
JI . 00 11 1:1 t. llD 
1011 U L DJ: 
2,. 0111 •1 t. m 
1111 1:1 L JODI 
lO. 0101 10 I llD 
!101 10 I lDDI 
ll. 0100 110 I m 
llOO 110 I DX 
12. 0101 J:l Im 
1101 11 I m 
ll. 0101 110 I ICIX 
1101 10 I ID! 
14. 0001 11 I az 
!001 11 I llll 
JS. 0101 10 I ICIDI 
1101 10 I ICIDI 
3'. JOO! II I ID 
,001 11 I XU 
l 7 . JO lt 10 I m 
1011 10 I llll 
ll. 0001 11 I IQIJI 
1001 U I 111 
lt. 0011 10 L JCIDI 
1011 IO t. ID 
40. 0011 11 t. ICIJl 
LOil 1:1 t. llD 
U. 0001 10 Lall 
Lall 
t. m 
Lax 
LUX 
L ID 
u. 
u. 
u. 
1001 10 
0001 
1001 
0001 
1001 
oou 
1011 
0011 
1011 
II 
11 
10 
KO 
11 LID 
•1 L ICIX 
IO L DJ! 
UL ID 
4,. 0011 •1 Im 
1011 lll I ID 
n. 0011 U I. ID 
1011 It L llD 
41. ~Oil 11 I. ID 
1011 11 L ID 
O. 0011 n I ID 
1011 It I ax 
,0, ~ll 11 I. IDOi 
1011 ll L ID 
U. 0001 10 I. llD 
lOGI IO L IU 
..... N-NI-
•1t 
.. u 
.... _ 
.... _ 
1.r-
U'•CM 
1r~u• 
!.r~'lll· 
l.r•l11ft 
U'8lllft 
U'Plft 
u••utt 
~c•luft 
Lr8111ft 
l .. Ull1ft 
1r•ll1tt 
1..r•t11ft 
U'81Uft 
1..r•luft 
t.r•llift 
u-•111ft 
l.r•ll1ft 
l.ralllft 
1r•ll1ft 
1.r .. 1tl 
U' .. 1tl 
l.r,..te 
u,...t• 
v•cu 
··--~Ill'· u~u• 
u •111.ift 
ctuUft 
vat11tt 
U8l11tt. 
V8111ft 
U8111ft 
ctnlU.ft 
4rall1ft 
U8111ft 
uall1ft 
&r•lllft 
V8111ft 
ua111tt 
vellltt 
Crltll1ft 
UalUft 
uelllft 
ctnlUft 
velutt 
vall1tt 
Crelllft 
vellltt 
u.&ltl 
VU1t. l 
.,.,...t.. 
v.-t• 
re•t 
NINt 
re•t 
!'9-t 
re•t 
re•t 
.. u 
•1t 
...... 
VNU 
11.r,..Cue 
11.r-,Cu• 
ruuut 
V811.Ut 
Vellllt 
V01ft 
11.ro11t 
uo1tt 
V01ft 
VP1ft 
uelllft 
Vn.Lft 
Velllft 
vell.Lft 
v8"1ft 
vuut 
vuutt 
VP1ft 
Uelllft 
Vill\1ft 
ve111tt 
UeJUrt 
v•IUh 
41r•llltt 
vo1tt 
uell1ft 
VIUUft 
UIIUft 
vellUt 
a.aw I...._ 
IOCDa 
IDQa 
IDCIIIIS 
:oc:cms 
rocaae 
roc::aia 
:XIQIDS 
:oca,c 
:occoc 
:X"ODC 
:ooooa 
,OC'CIDI 
:OCCDI 
rocoas 
r:xxm 
::xxm 
:ocooa 
::x:cac 
!!)C()O& 
!DCCO& 
:l>CICCC 
!DCIOO& 
:oococ 
ll)ax,a 
:1>oaae 
:ocacc 
:ooom 
:ocaca 
txffft 
Uftft 
EXftff 
trftft 
UTlft 
UTlft 
unn 
U'TU! 
EXffft 
Uffff 
Uftff 
Uftft 
Uftft 
U'ftff 
Uffff 
UTlft 
UTlft 
U'ftft 
Uffft 
Uftff 
Uftft 
Uftft 
U'TU! 
UTlft 
Uffft 
Uftft 
U'ftft 
Uftft 
tlffft 
U'TU'T 
Uftft 
ll>=D& 
:ooaoa 
looao& 
roccca 
1oc:oaa 
locca& 
!DCCII:. 
:Q<XID& 
lOCODa 
IIXlallll 
lOCODa 
tDCICIII. 
lDCICIII. 
[Dela 
IDC:Xm 
toc:rx. 
IOCODa 
loam& 
lDCICIII. 
1ocaaa 
llXlallll 
tDClllll& 
lDCICIII. 
IOCODa 
IOCODa 
rocaa 
IDClllD& 
IDCICIN 
roc:caa 
ll>CCIN 
tDCODC 
IOCICIDI 
IOCODa 
lDCIXI& 
:oc:aaa 
IDCIXI& 
IOCU. 
IOCU. 
lDClllD& 
APPENDIXB 
U. •11 n I as 
.01; 11 I .. 
U.)tl;dLID 
:111. ~ .. 
S4. ,tll 11 • -
;H1 •• 1. 11D 
·U. ~11. I 'GI 
1011 lCI Im 
s,. ~11 11 I 11:1 
~IHI ll I ID 
)1. )001 XO I 11:1 
:oat XO I 11D" 
SI. ~11 Kl i 11:1 
:o.i u :. m 
St. X:ll IO !. m 
:011 n 1. ax 
'°· :001 11 I llD 
:OOl J:l I ZD 
61. ~01 d I ID 
:001 10 I ID 
,2. ,001 11 1. m 
:001 11 ::. m 
U. ~ll l'CI I ID 
:~:l J:0 I GI( 
M. )011 II I ax 
:o:: II I llD 
U. ~01 IO I 11:ll 
:001 HI ax 
... 0001 11 l. m 
,001 11 t. Gil 
,~. ,OU IO LID 
::111 n :. m 
M. ,Otl J:1 :. az 
:001 11 :. 11:1 
". :on 1(0 1. m 
:001 ••:. m 
·o. :,001 1(1 :. m 
:001 •1 :. m 
"l. )OH IO I az 
:011 11 Im 
'2. C>Oll 11 I az 
:o ll 11 I 11:1 
01. )Olt :re :. m 
!011 IO :. ID 
·•. 0111 •1:. m 
::!l Xl t. al 
'5. OIOI U & az 
!100 d I az 
''· 01111 J:l I az 
:~01 n Im 
• ., )001 10 I llD 
:001 IO Im 
'I. JlOl 11 I az 
:101 lll I a:I 
19. 3001 IIO I ID 
10111 IO I ax 
IQ. QOU U I ID 
lOH J:I I 11:1 
tl. )001 XO I ID 
:001 U I ID 
12. )011 11 L 11K 
.OU 11 LID 
tl. :)011 It :. 11K 
:011 a LID 
u. ooe1 11 :. m 
:001 11 I. as 
15. JOO! IO:. DX 
1001 10 :. mar 
.,. ~11 11 ~ am: 
:011 11 :. ID 
81 . 3001 It :. llD 
:001 d 1. Gil 
... 0001 11 l. ID 
:001 11 l. 11K 
It. 3011 IO I Gil 
1001 U I ID 
,o, 3001 r1 :. m 
:001 11 :. m 
ti . 3001 a l. ID 
1001 n .. m 
ta. 0001 11 I ID 
:HI U I 11K 
U. 0001 It LID 
:011 ft I. 11:ll 
M. 0011 11 LID 
!011 11 LID 
ti. :,001 d I ID 
1001 10 I 11:1 
M. OOtl II L ax 
!001 11 L 11:1 
tl.301101.ax 
:011 U I. ID 
•• :>001 11 I m 
1001 IU I Gil 
tt. QOtl IO I ID 
!001 IO I ID 
:oo. 3011 11 I Dal 
1011 II I m 
:01. 0001 IO L JQDI 
!001 IO I. ax 
,02. 0001 11 I. llD 
:ooa 11 1. m 
:OJ. 0011 It I ID 
ltll It I GI 
104. otll 11 Im 
1111 11 Im 
:os. 0011 It LID 
lUI It L m 
111:reluft 
U'alllft 
Ualllft 
Velllft 
U81U.ft 
ill'Mlft 
ill'A1tt 
ill'D1ft 
..... ,tt 
CUIUft 
v•Ut 
U81l1tt 
Udllft 
..-1111111: 
Cnll1ft 
&rU1ft 
UU1ft 
v•IUft 
VDlft 
UelUft 
VNltt 
VMlft 
CnltUt 
eru11tt 
CraJ.ft 
Vttlft 
vn1ft 
era111tt 
velllft 
vaUft 
CrMUt 
vuUt 
vaUt 
Crelllft 
Cr8111ft 
VMlt't 
4r81l1ft 
cn.u1 
V.Ul 
~ 
~ Z'9-1"9Nt 
.u 
-it 
·-
--v .c-
VClll'Cate 
Vlllllt't 
vu1tt 
v•1tt 
V81l1ft 
UM1ft 
VMlft 
VMlft 
ru8111ft 
V8111ft 
Veltlft 
V8'11lt 
Uelllft 
&rMlft 
VMlft 
VNlft 
Uelt1ft 
Ud1ft 
VelUft 
vulft 
Vlllllft 
Vllllltt 
'Vftlft 
VMlft 
vault 
vnlft 
CrNlft 
VNlh 
4rell1ft 
VMlft 
CrMJ.ft 
Velllft 
ua,tt 
• ... ,ft 
CrNlft 
... .. lft 
v•uft 
VelUft 
vu1tt 
••1tt 
vu1n 
vu1ft 
VMlft 
uu1n 
vo,n 
CHlllft 
velUft 
--~ ••111 
vam 
v•u.lt 
••lh 
Figure 1. TAPDANCE Generated Test Vectors 
91 
:oaa 
:xiim 
::,a:a 
:oc:aa 
:oc:aa 
~ 
=xi. 
::,era 
:ocom 
::,caa 
:xaa 
:xca 
::,a:a 
:xi:m 
:.>am 
:xi:a 
::,ca. 
:xx:a 
:X'al& 
::,caoa 
::ic:m 
::,oaaa 
::acira 
::,ca 
::x:aa 
:xaa 
::xiaa 
:xiam 
:x,oa 
::,am 
::,cna 
:oa1111 
::x:aa 
:xas 
::x:caa 
:::,aa 
:oaa 
::x::aa 
:xi:a 
::,ems 
:xraa 
:oa:m 
::,am 
:ocam 
::xza 
:t>Caa 
::,cma 
:z,aa 
::,am 
::x::aa 
::x::aa 
:xi:aa 
:oaa 
::,am 
::xx. 
:aa. 
:xaa 
::xxa 
:;,am 
:x,cm 
:oaa 
::xza 
::icra 
:ocma 
::,ca 
:::,caa 
::,caa 
::,cxm 
:.>am 
:xica 
::x1a 
:oa:a 
::xa. 
:xaa 
:x,oa 
:oo.m 
:Daa 
:l)(lla 
:ll(US 
:oa:a 
::,caa 
:oaa 
:aaa 
:oaa 
::xiaa 
::,caa 
:oara 
:ocaa 
:acaa 
:i:,aa 
:oc:aa 
.~ 
:ocma 
:ama 
:Dma 
:ocaa 
:oo:a 
=~ 
:oam 
::x:ma 
n:. ••1 a• aa 
lHl d I ID 
4lJ. ,ee1 11 L ... 
1001 11 Las 
4JJ. ,e11 n i ... 
!011 It l. ... 
414. 3001 11 I as 
,001 11 I ID 
4lS. ,001 10 I lODr 
:001 ro • iaa 
n,. ~Ol: I! I OS 
:,:: 1: 1 m 
431. :lCOl 10 :. all 
,001 IC :. llD 
01. :,001 11 :. Dll 
:OOl 11 lo ID 
Ot. JOll 10 I llD 
1011 10 I IXX 
UO. OCll 11 I ID 
:01: I! I ID 
44!. 0011 10:. llXI 
:1>1: 10 L as 
U2. 000! ll I DJI 
:001 ll I IIXX 
441. 0001 10 I as 
:OCl 10 I :CU 
U4. JOl l Xl I lllJI 
:o:: 11 I rn: 
u5 . oo H ro :. ax 
1011 ro:. a,: 
44,. 0001 11 L IClX 
!001 II :. DZ 
U7. JO ll 10 :. IClX 
!Oll 10 :. as 
UI . JO 11 11 l. as 
:1>11 11 :. as 
44t. 0011 XO~ 1:1'.S 
!011 XO :. ID 
UC. :OO! 11 I DJr 
!001 11 I aJr 
45!. QOOl XO I :aJl 
:001 ro 1 :aJl 
,,2. 0001 11 1. m 
:001 11:. :aJl 
'51. 0101 XO L DJr 
!~Ol XO :.. DX 
,,. . 01 n r: , as 
:1n 11 , m 
u,. n 11 ro I aJr 
! I l l JIO I llXI 
HI. llO! 11 I 11:D 
:~Ol Xl I XD 
,,1. 0001 10, m 
!001 XO I :a:JI 
HI. JOll 11 I lCD 
!011 11 I lCD 
459. 0001 XO I lllDI 
:001 ro I llD 
UO . 00 ll Xl L llD 
:011 11 :. m 
461. ~11 10 L lllDI 
\011 XO :. m 
4,2. 0001 11:. m 
!001 lll L lCD 
461. 0001 XO I aJr 
!001 10 Im 
4'4. 0001 ll I GJI 
!001 1n I XU: 
41$. )001 XO !. IXI 
,001 10 L as 
466. 0101 11 ~ XIX 
llOl Xl %. XD 
U7. Jill 10 I as 
:u1 ro I m 
UI. Hll 11 I Ga 
!111 lll I IIXJI 
ot. ~i: ro I m 
!011 IO & llD 
470. :001 u a m 
lOOl lll I XU: 
n1. 0001 IO I IU 
!001 10 I XU: 
472. GOil 11 I llD 
1011 11 I ID 
4>J. GOil 11 Im 
1011 11 I 11D 
4i4. 0001 10 I Ila 
1001 10 Im 
47S. ~01 10 JI 11D 
1001 10 I Ila 
416. 0011 11 I IIJI 
1011 11 I IIJI 
417. GOll 11 L IIJI 
1011 11 :. ID 
411. ()011 11 I IIJI 
1011 Ill I IIJI 
419. 0011 11 I 111:1 
1011 11 I lCD 
4IO. 0011 11 r. JIU 
1011 II :. ICU 
411. 0101 llO L 11D 
1101 XO I. IIJI 
4tJ. 0111 11 I IIJI 
llll 11 I aa 
Ul. 0011 11 I IU 
1011 11 I aa 
414. 0111 11 I .. 
1111 11 I IU 
••11t 
••Ut 
••1ft 
... lft 
••lit 
•alUft 
Ualllft 
ve11Ut 
VMlft 
Uelllft 
ve111tt 
ue111tt 
Uall1lt 
va111tt 
Uall1ft 
clrell1t~ 
vall1tt 
va111tt 
U•JU.ft 
va111tt 
ua111tt 
v1.111tt 
41'•111ft 
va111tt 
VllHft 
4nll!tt 
:tnJutt 
vallltt 
va111tt 
Ualllft 
vall1ft 
V8'11tt 
v1111tt 
uallltt 
Uall1ft 
U1ll1ft 
U•lllft 
Ualuft 
VIUl1ft 
U11t1ft 
4nll1ft 
vu1ft 
U1ll1ft 
UU1ft 
U•lllft 
U..iel 
U..J.C l 
u,.-,. 
..... ,. 
VH-
v-
u•-a,_ 
U~IU'e 
1r~~ 
i.r•lllft 
L.n111tt 
uall1ft 
UM1ft 
UU1ft 
i.r•ll1ft 
u•lllft 
1ra111tt 
l.r1111lft 
1rall1tt 
uall1ft 
~ralllft 
uallltt 
lrllllft 
lCIUlift 
lrllllft 
lr-ltl 
lr-11:. I 
u-,.-,. u,...,. 
ua-
•-v-.c.~ 
<U'-.C,1Ue 
viuuft 
UIIJuft 
Uu1ft 
<iUIUft 
UIIJllft 
veJUft 
VNift 
&rlUlitll: 
VUlft 
Uellift 
&rellift 
<Ulllift 
Uall1ft 
Uallift 
va1utt 
UallJ.ft 
Uallllft 
UaJU,ft 
vu1ft 
Vllllift 
VIIJllft 
Uallift 
V-ltl 
4'naltl 
.,... ... 
.... l. 
•1t 
.. u 
--
:oc:iaa 
:oc:ma 
mcaa 
ioaaa 
maa 
:aaaa 
=-u,cma 
:DC:lla 
~ 
:oam 
:oa:m 
:oa:m 
:oam 
:oc::a,s 
:ocxxc 
::,aa 
:oa:m 
::x:i:a 
;oc:x,o& 
:XIDCIS 
;:x,oas 
:l)CICCC 
I:>allllC 
:oaxa 
::::,o:a 
;:,am 
::,am 
:Dam 
:Dam 
::>am 
:xca& 
:occa 
::x:iao& 
::,am 
::,am 
::,am 
:t>a. 
:oaxs 
:OCIOOI 
:DCCII& 
!OCICIII& 
:oc:aaa 
:DO* 
:oca111 
l:>CCICS 
:DCICII& 
:oo::IDI 
:oaxi& 
::,am 
::,am 
:,aa 
:oaxi& 
!tlalll& 
:xaa 
:OCODI 
:oa:a 
:occa& 
::,am 
:OCXJII& 
:occa& 
:ocra 
::,am 
:::iaa 
:oaxa 
:occa& 
:cc:icaa 
:occcs 
:cc:icaa 
lCICIIXI& 
U1lft 
lftllft 
Ulftft 
U'l'Ut 
lftUI 
aftft 
an. NU• I -
;on• 1 -
&N. Ml 11 I -
:Hl •1 I -
• .., . .Ol l'.l • -
;,e1 lrl lt -
••· ,eu • • -
:111 • s -
, ... "911 ... -
·.,::DI -
& tc . l:Ol I! I -
:,11 X:. I -
49:. ~1 11 I ... 
::01 :r: • -
,n. ~O! ltl I -
.~01 X~ I -
n1. :~:u :ri ;. ... 
:,en 1: :. .. 
,,. . =cl!l l'O I ... 
:::: d I -
01. :c:n n I IU 
::,1 Xl I -
.. 
-
•M. :~o: 1: :. 
::01 11 :. 
4''· :::: n:. .. 
z::. -
• ~ • 'f 
.... "' 
4M 
-1: I DI 4'9. :1,1 ll I .. 
::,1 11 I ... 
SOC. »:! Zl I -
::o: 11 I -
Sl:. ~OH n:. ... 
~=11 d l -
~:2. ::.001 rt ~ ... 
:u1 ir! :. -
SC). ~01 1. I ... 
::01 11 I -
!:f. )OU U:. .. 
:~11 Q :. -
~~,. )011 n i -
:::: ltO :. .. 
!H. ~H n I -
:,n ff I -
~o~. )Oll n 1 .. 
::iu n 1 -
~~- :,011 n :. -
::111 :ro :. -
s:it. )011 n :. -
::11 n :. aa 
L~. :ion n 1 -
:::1 U I -
~::. :t;~ X! a -
: !:l It I -
s:2. ~H n 1 -
:::: n I -
~:l. :411 H I -
;:n n 1 -
H4. )Ott d I -
:,n II I -
HJ . .:,01~ II I -
::in n 1 -
!~,. 
!P. 
:1.11 fl I 
::u n I 
~" ~ . ~ .... 
~ .. ~ 
••• fl, 
Slt. ~ll. ff I 
:Jll d I 
SN. :llU lit I 
:n: IO I 
... 
... 
... 
-.. 
... 
!2!. )011 1: I l&I 
:~ll 1:1 I ... 
UJ. ~ll IO I .. 
Ulll SI I -
~Jl. )Oll 11 I ... 
::iu 11 :r ... 
H4, OoHl l'O • ... 
:oa1 a• -$U. ~Hl II :r aa 
::101 n • ... 
su. eon 11 • -
:on 11 ir -
!J'. )011 11 • ... 
:,u 11 • -
Ut. 0001 It:. -
lHl n 1. -
!lt. ~11 11 a -
:Oll 11 I -
uo. ~l .. 1. -
::101 n :. ... 
i11~ ot11 a1 l ... 
::iu 11 :. ... 
!l2. ~11 ll I ... 
:on 11 a ... 
!U. 0101 n I -
:lGl n I -Sl• • .lOll 11 I ... 
:cu u .... 
~n. nu 11 1 ... 
:.:.ll 11 I -
!J6. :110 11 I llSI 
:HO 11 I aa 
Sl'. Ql.11 II I ... 
:,:.1 II I ... 
n,. :)Ill 11 a ... 
:~:.:. 11 • m 
• 4 =• 
• 4 -· ~ 
*9&a.ft 
••1ft 
..am 
--th 
eraa1tt 
velutt 
UP.~~ 
U'di.~ 
cre111:.!'t 
Utt!!t 
Uattlt't 
U•!!t 
Ve.1!!.h 
ua1.tT: 
U .. 1h 
Ud!ft 
U'U!.ft 
&rd.!~'t 
va111tt 
craa:..tt 
.... 1ft 
UalU.!'t 
VAJ.ft 
uaa:.h 
Uall:.tt 
cr-.1ft 
v•1tt 
u•1."t 
arata1t't 
Ctllllt't 
UldU!'t 
eraas.tt 
vnllt 
cr•1tt 
Craat..."t 
u•1ft 
VD1ft 
u•1tt 
vatu.ft 
~u: 
..-.J.tl 
~-
. .. :. 
&r-
u~i.r. 
u~....-. 
UMlft 
Uall,.ft 
&t ... lt~ 
CU&.t ... -i 
vn1tt. 
uall.1tt 
Uall>.ft 
UM.I.ft 
UtilUft 
er~ 
vaa1tt 
v.a.i....'l. 
UIIIU.ft 
velUtt 
ve1ntt 
v•~ 
velu.tt. 
etell.ltt 
--~ Ualllltt 
c.r•1n. 
vall.lft 
area~t l 
*-Ul 
.,._ 
. .... 
*'-l.11:l 
Figure 2. TAPDANCE Generated Test Vectors 
92 
=www 
I 
G&H 
W II 
Uiifi 
U!Lii 
UISH 
Uftft 
U!Uf 
Cllftff 
an.n 
cr.'UT 
tr.a'!' 
D'!'Li"!' 
~ 
~ 
~ 
tll'ftr. 
~ 
Uft.r.' 
~ 
~ 
~ 
~ 
11"!'1'-
tr.'Er. 
tr.rft 
t:r.l'..r. 
Uftff 
D!tfl 
tr.UT 
D'tU'i' 
U'iU'i 
U?Ut 
tr.Sr. 
tr.'l.n 
tr.'U! 
aft.ft 
tr:u't 
Cl'ftfl 
tr.ut 
aftft 
trtUT 
t:r.U1' 
tr.UT 
:xma 
::xiiaa 
:xwa 
;xma 
:xcoa 
VITA 
Susan Shushien Kiang was born on April 3, 1964 to Han Sung Kiang and Tan Kuei 
Wu. She received her Bachelor of Science Degree with Highest Distinction in Electrical 
Engineering from Purdue University in 1987. 
She is presently employed as a design engineer by AT&T Bell Laboratories in 
Allentown, Pennsylvania where she had various assignments in VLSI design. 
93 
•· 
