Testing of Embedded System: Version 2 EE IIT, Kharagpur 1
Testing of Embedded System: Version 2 EE IIT, Kharagpur 1
8
Testing of Embedded
System
Version 2 EE IIT, Kharagpur 1
Lesson
41
Boundary Scan Methods
and Standards
Version 2 EE IIT, Kharagpur 2
Instructional Objectives
After going through this lesson the student would be able to
The Std. 1149.1, usually referred to as the digital boundary scan, is the one that has been used
widely. It can be divided into two parts: 1149.1a, or the digital Boundary Scan Standard, and
1149.1b, or the Boundary Scan Description Language (BSDL) [1,6]. Std. 1149.1 defines the chip
level test architecture for digital circuits, and Std. 1149.1b is a hardware description language
used to describe boundary scan architecture. The 1149.2 defines the extended digital series
interface in the chip level. It has merged with 1149.1 group. The 1149.3 defines the direct access
interface in contrast to 1149.2. Unfortunately this work has been discontinued. 1149.4 IEEE
Standard deals with Mixed-Signal Test Bus [4]. This standard extends the test structure defined
in IEEE Std. 1149.1 to allow testing and measurement of mixed-signal circuits. The standard
describes the architecture and the means of control and access to analog and digital test data.
The Std.1149.5 defines the bus protocol at the module level. By combining this level and
Std.1149.1a one can easily carry out the testing of a PC board.
1149.6 IEEE Standard for Boundary-Scan Testing of Advanced Digital Networks is released in
2002. This standard augments 1149.1 for the testing of conventional digital networks and 1149.4
for analog networks. The 1149.6 standard defines boundary-scan structures and methods
Internal Register
Identification Register
1 Instruction Register
TMS
TAP
TCK Controller
1
TRST* (optional)
Fig. 41.2 Main Elements of a IEEE 1149.1 Device Architecture
The test access ports (TAP), which define the bus protocol of boundary scan, are the additional
I/O pins needed for each chip employing Std.1149.1a. The TAP controller is a 16-state final state
machine that controls each step of the operations of boundary scan. Each instruction to be carried
out by the boundary scan architecture is stored in the Instruction Register. The various control
signals associated with the instruction are then provided by a decoder. Several Test Data
Registers are used to stored test data or some system related information such as the chip ID,
company name, etc.
Data In
0 Data Out
(PI) Capture Update
Hold Cell 1 (PO)
Scan Cell
0
D Q D Q
1
Clk Clk
C
U
Scan in ShiftDR ClockDR UpdateDR
S
(SI)
Chip 4
Chip 3
TMS TMS
TCK
TMS
Serial test interconnect System interconnect
The advantage of this configuration is that only two pins on the PCB/MCM are needed for
boundary scan data register support. The disadvantage is very long shifting sequences to deliver
test patterns to each component, and to shift out test responses. This leads to expensive time on
the external tester. As shown in Figure 41.5 [1], the single scan chain is broken into two parallel
boundary scan chains, which share a common test clock (TCK). The extra pin overhead is one
more pin. As there are two boundary scan chains, so the test patterns are half as long and test
time is roughly halved. Here both chains share common TDI and TDO pins, so when the top two
chips are being shifted, the bottom two chips must be disabled so that they do not drive their
TDO lines. The opposite must hold true when the bottom two chips are being tested.
TCK
TDI
TMS ClockDR
TCK ShiftDR
TRST* UpdateDR
16-state FSM Reset*
TAP Controller Select
(Moore machine)
ClockIR
ShiftIR
UpdateIR
Enable
Figure 41.6 shows a top-level view of TAP Controller. TMS and TCK (and the optional TRST*)
go to a 16-state finite-state machine controller, which produces the various control signals. These
signals include dedicated signals to the Instruction register (ClockIR, ShiftIR, UpdateIR) and
generic signals to all data registers (ClockDR, ShiftDR, UpdateDR). The data register that
actually responds is the one enabled by the conditional control signals generated at the parallel
outputs of the Instruction register, according to the particular instruction.
The other signals, Reset, Select and Enable are distributed as follows:
• Reset is distributed to the Instruction register and to the target Data Register
• Select is distributed to the output multiplexer
• Enable is distributed to the output driver amplifier
It must be noted that the Standard uses the term Data Register to mean any target register except
the Instruction register
0 0
Shift_DR 0 Shift_IR 0
1 1
1 1
Exit_DR Exit1_IR
0 0
Pause_DR 0 Pause_IR 0
1 1
0 0
Exit2_DR Exit2_IR
1 1
Update_DR Update_IR
1 0 1 0
Figure 41.7 shows the 16-state state table for the TAP controller. The value on the state transition
arcs is the value of TMS. A state transition occurs on the positive edge of TCK and the controller
output values change on the negative edge of TCK. The 16 states can be divided into three parts.
The first part contains the reset and idle states, the second and third parts control the operations
of the data and instruction registers, respectively. Since the only difference between the second
and the third parts are on the registers they deal with, in the following only the states in the first
and second parts are described. Similar description on the second part can be applied to the third
part.
1. Test-Logic-Reset: In this state, the boundary scan circuitry is disabled and the system is in
its normal function. Whenever a Reset* signal is applied to the BS circuit, it also goes back
to this state. One should also notice that whatever state the TAP controller is at, it will goes
back to this state if 5 consecutive 1's are applied through TMS to the TAP controller.
2. Run-Test/Idle: This is a state at which the boundary scan circuitry is waiting for some test
operations such as BIST operations to complete. One typical example is that if a BIST
operation requires 216 cycles to complete, then after setting up the initial condition for the
BIST operation, the TAP controller will go back to this state and wait for 216 cycles before it
starts to shift out the test results.
3. Select-DR-Scan: This is a temporary state to allow the test data sequence for the selected
test-data register to be initiated.
0
D Q To TDO
From TDI
ShiftDR Clk
ClockDR
Instruction Register
DR select and control signals routed to selected target register
Decode Logic
Hold register
(Holds current instruction)
TAP 0 1
Controller IR Control Higher order bits:
current instruction, status bits, informal ident,
results of a power-up self test, …
Fig. 41.9 Instruction register
TDI TDI
TCK TCK #N
TMS #N TMS
TDO TDO
(a) (b)
Fig. 41.10 BUS master for chips with BS: (a) star structure, (b) ring structure
Test Connector
2 3 4 5
TDI TCK TMS TDO
(a)
(b)
Fig. 41.12 Example to illustrate BSDL (a) core logic (b) after BS insertion
By providing access to the scan chain I/Os, the need for physical test points on the board is
eliminated or greatly reduced, leading to significant savings as a result of simpler board layouts,
less costly test fixtures, reduced time on in-circuit test systems, increased use of standard
interfaces, and faster time-to-market. In addition to board testing, boundary-scan allows
programming almost all types of CPLDs and flash memories, regardless of size or package type,
on the board, after PCB assembly. In-system programming saves money and improves
throughput by reducing device handling, simplifying inventory management, and integrating the
programming steps into the board production line.
9. Conclusion
Board level testing has become more complex with the increasing use of fine pitch, high pin
count devices. However with the use of boundary scan the implementation of board level testing
is done more efficiently and at lower cost. This standard provides a unique opportunity to
simplify the design debug and test processes by enabling a simple and standard means of
automatically creating and applying tests at the device, board, and system levels. Boundary scan
is the only solution for MCMs and limited-access SMT/ML boards. The standard supports
external testing with an ATE. The IEEE 1532-2000 In-System Configuration (ISC) standard
makes use of 1149.1 boundary-scan structures within the CPLD and FPGA devices.
[1] IEEE-SA Standards Board, 3 Park Avenue, New York, NY 10016-5997, USA, “IEEE
Standard Test Access Port and Boundary-Scan Architecture”, IEEE Std 1149.1-2002,
(Revision of IEEE Std 1149.1-1990), http://grouper.ieee.org/groups/1149/1or
http://standards.ieee.org/catalog/
[2] Parker, “The boundary-scan handbook: analog and digital”, Kluwer Academic Press,
1998 (2nd Edition).
[3] M. L. Bushnell and V. D Agarwal, “Essentials of Electronic Testing” Kluwer academic
Publishers, Norwell, MA, 2000.
[4] IEEE 1149.4 Mixed-Signal Test Bus Standard web site:
http://grouper.ieee.org/groups/1149/4
[5] IEEE 1532 In-System Configuration Standard web site:
http://grouper.ieee.org/groups/1532/
[6] Agilent Technologies BSDL verification service:
http://www.agilent.com/see/bsdl_service
Problems
1. What is Boundary Scan? What is the motivation of boundary scan?
2. How boundary scan technique differs from so-called bed-of-nails techniques?
3. What are the different device packaging styles?
4. What is JTAG?
5. Give an overview of the boundary scan family i.e., 1149.
6. Show boundary scan architecture and describe functions of its elements.
7. Show the basic cell of a boundary-scan register. Describe different modes of its
operation.
8. A board is composed of 100 chips with 100 pins each. The length of the total scan chain
is 10,000 bits. Find a possible testing strategy to reduce the scan chain length.
9. What is TAP controller? What are the main functions of TAP controller?
10. Describe a serial boundary scan chain and its operation. What are its disadvantages and
discuss a strategy to overcome these.
11. Discuss different instruction sets and their functions.
12. Considering a board populated by IEEE 1149.1-compliant devices (a "pure" boundary-
scan board), summarize a board-test strategy.
13. What is the goal of the infrastructure test? Is the infrastructure test mandatory or
optional? Which are the main steps of an infrastructure test?
14. Consider the example depicted in the following figure.
TDI
A C E
B IC1 IC2 F
D
This circuit has two primary inputs, two primary outputs and two nets that connect the ICs one to
the other. There is only 1 TAP, which connects the TDI and TDO of both ICs. Prepare a test plan
for this circuit.
15. Consider a board composed of 100 40-pin Boundary-Scan devices, 2,000 interconnects,
an 8-bit Instruction Register per device, a 32-bit Identification Register per device, and a
10 MHz test application rate. Compute the test time to execute a test session.
16. What is BSDL. What are the different BSDL files?