The IEEE 1149.1 std defines mandatory and
optional instructions, respectively addressing (or selecting) the mandatory and optional
data registers shown in the BS architecture depicted in figure 1.
Figure 1: The BS
architecture at IC level.
The mandatory instructions are those
guaranteeing the basic objectives underlying the development of the BS test technology and
may be briefly described as follows:
The EXTEST instruction selects
the BS register and imposes the (external) test mode in each BS cell, decoupling the IC
core logic from the pins. The configuration shown in figure 2 for a BS cell will however
enable internal tests to be carried out as well, since the BS cells associated to input
pins may be used to apply test vectors and the BS cells associated to output pins used to
capture the responses. The EXTEST instruction has a pre-defined code of all-0s.
Figure 2: Typical BS cell configuration.
- The SAMPLE / PRELOAD instruction also selects
the BS register, but the BS cells are now in transparent mode. The main objective of this
instruction is to enable a first vector to be shifted in before the internal logic
is decoupled from the pins (while the BS cell output latches are not loaded with
meaningful data, it may be necessary to prevent their initial value to appear on the
parallel output of the cell). This instruction does not have a pre-defined
code.
- The BYPASS instruction selects the bypass
register and enables a 1-bit data path through those ICs which do not play a role in the
current test operation. This instruction has an all-1 code and is automatically
loaded into the instruction register on reset (the BS register will in this case have its
cells in transparent mode, meaning that at power-up all BS ICs will start to perform their
normal functions).
A number of optional BS instructions
are possible with the objective of supporting other test operations or the optional data
registers shown in figure 1. The description of these instructions will be present in the
device datasheet, but the IEEE 1149.1 std defines a few possible instructions, including
the following:
- The IDCODE selects the identification register
and enables access to a unique 32-bit code identifying the device
manufacturer, the part
number and the version number.
- User-programmable components may also support
an USERCODE instruction that selects the same 32-bit identification
register, now with the
objective of enabling access to a user-programmable identification code.
- The RUNBIST instruction is used to enter a
self-test mode that leaves the test result in the data register selected by this
instruction (a dedicated user test data register will normally be used for this
purpose).
None of the optional instructions have
pre-defined codes. The optional instructions to support are naturally left to the
discretion of the designer and it is possible that a BS component supporting several
optional instructions does not support those referred above (such as is the case with the
SCOPE octals manufactured by Texas Instruments).
|