University of Kentucky

UKnowledge
Electrical and Computer Engineering Faculty
Patents

Electrical and Computer Engineering

12-14-1999

Method for Testing Field Programmable Gate Arrays
Charles E. Stroud
University of Kentucky

Miron Abramovici

Follow this and additional works at: https://uknowledge.uky.edu/ece_patents
Part of the Electrical and Computer Engineering Commons

Right click to open a feedback form in a new tab to let us know how this document benefits you.
Recommended Citation
Stroud, Charles E. and Abramovici, Miron, "Method for Testing Field Programmable Gate Arrays" (1999).
Electrical and Computer Engineering Faculty Patents. 10.
https://uknowledge.uky.edu/ece_patents/10

This Patent is brought to you for free and open access by the Electrical and Computer Engineering at UKnowledge.
It has been accepted for inclusion in Electrical and Computer Engineering Faculty Patents by an authorized
administrator of UKnowledge. For more information, please contact UKnowledge@lsv.uky.edu.

US006003150A

United States Patent [19]

[11]

Patent Number:

Stroud et al.

[45]

Date of Patent:

[54]

METHOD FOR TESTING FIELD

5,090,015

2/1992 Dabbish et al. ..................... .. 371/22.5

5,107,208

4/1992

Lee ............... ..

. 324/158 R

5,179,561

1/1993

IZaWa et al.

..... .. 371/52

5,260,946
5,278,841
5,347,519
5,361,264

[73] Assignees: Lucent Technologies Inc., Murray Hill,

5,430,734

N.J.; University of Kentucky Research

5,475,624

Foundation, Lexington, Ky.
[21] Appl. No.: 08/974,799
Filed:

11/1993 Nunally

. 371/22.1

1/1994 Myers .................................. .. 371/20.6
9/1994 Cooke et al. ........................ .. 371/22.2
11/1994

Lewis .... ..

371/22.5

7/1995 Gilson .
12/1995

371/22.2

West ...... ..

364/578

5,488,612

1/1996 Heybruck

371/22.2

5,508,636

4/1996 Mange et al.

326/38

Primary Examiner—Robert W. Beausoliel, Jr.
Assistant Examiner—Nadeem Iqbal
Attorney, Agent, or Firm—King and Schickli

Nov. 20, 1997
Related US. Application Data

[63]

Dec. 14, 1999

PROGRAMMABLE GATE ARRAYS

[75] Inventors: Charles E. Stroud, Lexington, Ky.;
Miron Abramovici, Murray Hill, NJ.

[22]

6,003,150

[57]

Continuation of application No. 08/595,729, Feb. 2, 1996,

ABSTRACT

abandoned‘

A method of testing ?eld programmable gate arrays
(FPGAs) includes the step of con?guring programmable

[51]
[52]

Int. Cl.6 .................................................... .. G06F 11/00
US. Cl. ..................................... .. 714/725; 395/500.17

logic blocks of the FPGAS for Completing a built-in self-test.
This is followed by the steps of initiating the built-in

[58]

Field of Search

371/222 22 33

self-test, generating test patterns With the programmable

371
22 6 25 ,1 2'7 2?
395/183_06 ‘18,307’ 183:6 560,05 ‘50017’
500 18. 364/4188 489’ 580. 3,2 4/765. ’714/725’

logic blocks and analyzing a resulting response to produce
a pass/fail indication With the programmable logic blocks.
More speci?cally, the con?guring step includes establishing

' ’

7,27 7,33 7,35 30 27’. 365/201’
’

[56]

’

’

’

a ?rst group of programmable logic blocks as test pattern

’

generators and output response analyzers and a second

References Cited

Us PATENT DOCUMENTS
Re 34 445 11/1993 Hayes et al

group of programmable logic blocks as blocks under test.
The blocks under test are then repeatedly recongifured in
order to completely test each block under test in all possible
modes of operation. The programming of the ?rst and

371/21 1

44147669 11/1983 Heckelmanet'alf...................... 371/4'9

Second groups of Programmable logic blocks is then

4:757:503

reversed and the testing of each neW block under test is then

7/1988 Hayes et a1_ _______ __

__ 371/21

4,817,093

3/1989 Jacobs et al.

5,051,996
5,081,297

9/1991 Bergeson et al.
.. 371/22.4
1/1992 Lebel et al. ........................... .. 395/325

371/25

Completed.
15 Claims, 1 Drawing Sheet

/ 22

O outputs

I

BUT \
m outputs

.

L
LUT

to n BUTs :
.
m inputs

18

BUT

FF

\

\

/

\
24

,

26
.

0

:O

O

. \ 20
O

24

18

22

. /
\

BUT I
m outputs

TPG
C TPGS

IK

r
O outputs

/

ORA 1

20

Q

to n BUTs :

-

m mp“ t S

BUT

C groups of n BUTs

'71
20

T

/

/

—

(
LUT

0/ #vpurs

20

ORA

O

FF

group s of n ORAs

r

26

6,003,150
1

2
A need is therefore identi?ed for an improved approach

METHOD FOR TESTING FIELD
PROGRAMMABLE GATE ARRAYS

This is a continuation of application Ser. No. 08/595,729,
?led Feb. 2, 1996, noW abandoned.

for completing diagnostic testing of FPGAs.
SUMMARY OF THE INVENTION
5

TECHNICAL FIELD

The present invention relates generally to the ?eld of
testing of integrated circuit devices and, more particularly, to
a method of diagnostic testing applicable to ?eld program
mable gate arrays.

art.

Another object of the present invention is to provide a
10

advantageously alloWing off-line testing at both the manu
15

logic blocks interconnected by programmable routing
resources and programmable I/O cells. Programming of
these logic blocks, routing resources and I/O cells is selec
tively completed to make the necessary interconnections that
establish a con?guration thereof to provide desired system
operation/function for a particular circuit application.
Of course, it is desirable to complete diagnostic testing of
all types of integrated circuits including FPGAs in order to

check the functionality of the various programmable logic

20

25

blocks, routing resources and I/O cells of the FPGAs. Since

system operating times for a given system function.
Yet another object of the present invention is to provide a
BIST approach for testing FPGAs alloWing both manufac
turing and ?eld level testing of digital systems that is

particularly advantageous; providing high fault coverage
testing at the system operating frequency. Accordingly,
run time advantageously results in the reduction in the mean

30

netWork, delay faults, etc.).
In past diagnostic testing approaches, special test transis

built-in test circuitry and signi?cant delay penalties in the
operating speed of the FPGAs result.

and the need to provide separate test circuitry on the FPGA
is eliminated. Advantageously, this reduces area overhead
alloWing the use of smaller FPGAs With substantially faster

development is simpli?ed. The reduction in the diagnostic

thereof is complicated by the need to cover all possible
modes of operation and even many non-classical fault

tors and circuits have been added to each FPGA integrated
circuit. These additional test transistors and circuits increase
the complexity and space requirements or “area overhead”
of the FPGAs. In fact, the siZe of the FPGAs is typically
increased betWeen 10—30% in order to accommodate the

Yet another object of the present invention is to provide a

simple and improved method of testing FPGAs Wherein the
FPGAs are temporarily programmed for built-in self-testing

diagnostic run time is reduced and diagnostic softWare

FPGAs are programmable, hoWever, the diagnostic testing

models (faults effecting the programmable interconnect

method of testing FPGAs that exploits the reprogrammabil
ity of the FPGAs to create built-in self-test (BIST) logic

facturing and system levels.

BACKGROUND OF THE INVENTION

A ?eld programmable gate array (FPGA) is a type of
integrated circuit consisting of an array of programmable

Accordingly, it is a primary object of the present invention
to provide a method of testing FPGAs overcoming the
above-described limitations and disadvantages of the prior

time necessary to repair the system being tested. This

effectively functions to increase system availability and,
therefore, overall system productivity. Of course, the reduc

35

tions in the time necessary to develop the diagnostic code
also advantageously result in reduced development cost and
system overhead.
Additional objects, advantages and other novel features of
the invention Will be set forth in part in the description that
folloWs and in part Will become apparent to those skilled in

40

With the practice of the invention. The objects and advan
tages of the invention may be realiZed and obtained by

the art upon examination of the folloWing or may be learned

It should further be noted that in current state of the art

testing procedures, tests are generated manually by con?g

means of the instrumentalities and combinations particularly

uring the FPGAs into several application circuits. The

pointed out in the appended claims.

FPGAs so con?gured are then exercised With test vectors

developed speci?cally for each application circuit. Since

To achieve the foregoing and other objects, and in accor
45

these circuits all share the same set of faults, FPGAs are
rejected even if a fault is detected in only one of their
circuits.

dance With the purposes of the present invention as
described herein, a neW and improved method is provided
for testing FPGAs. The method may be broadly de?ned as

including the steps of con?guring the programmable logic

While this is an effective testing procedure, it does suffer
from a number of draWbacks. For example, since all the
application circuits must be simulated to complete testing
for stuck-at faults, fault simulation in accordance With this

blocks of an FPGA for completing a built-in self-test,

procedure is very expensive. Additionally, the tests require

produce a pass/fail indication. Advantageously, the present
method is applicable to any in-circuit reprogrammable

initiating the built-in self-test, generating test patterns With
the programmable logic blocks and analyZing the resulting
response With the programmable logic blocks in order to

a signi?cant amount of time to complete and relatively

sophisticated and expensive automatic test equipment (ATE)

55

system. Further, all tests are performed at normal operating

Further, it should be appreciated that the FPGA manufac

frequencies, thus providing at-speed testing to detect any
delay faults While signi?cantly reducing the diagnostic test

turing tests presently utiliZed are not reusable for board and

system-level testing. Hence, additional developmental effort
is required in order to complete a testing procedure at the
system-level. The state of the art approach to system-level
testing of FPGAs focuses upon the development of off-line
system diagnostic routines to test the FPGAs in the system
mode of operation. The development of these routines is
costly and time consuming. This, of course, is another
signi?cant draWback to state of the art FPGA diagnostic

testing.

FPGA, such as SRAM-based FPGAs. It is also applicable to

all levels of testing including Wafer, package, board and

must be utiliZed.

60

times over those possible With prior art approaches.

More speci?cally describing the invention, the con?gur
ing step includes establishing a ?rst group of programmable
logic blocks in an FPGA as test pattern generators and output
65

response analyZers. The con?guring step also includes the
step of establishing a second group of programmable logic
blocks in the same FPGA as blocks under test. By repeatedly

recon?guring each block under test, each block under test is

6,003,150
3

4

completely tested in all possible modes of operation. Pseu
doexhaustive testing is used to provide maximum fault
coverage totally independent of the intended system func

type knoWn in the art is utiliZed for Wafer/package testing.
Typically a CPU or maintenance processor of a type also

knoWn in the art is utiliZed for board/system testing. More
speci?cally, the test controller interacts With the FPGAs to
be tested to con?gure the FPGA logic. This is done by
retrieving a BIST con?guration from the con?guration stor
age of the test controller and loading it into the FPGAs.

tion of the FPGAs.

This is folloWed by the step of reversing the programming
of the ?rst and second groups of programmable logic blocks
so that the ?rst group is established as blocks under test and

the second group is established as test pattern generators and

output response analyZers. Then folloWs the step of repeat
edly recon?guring each block under test in the ?rst group of

In accordance With the con?guring scheme, the method

FPGAs in order to test each such block completely in all

includes the steps of establishing a ?rst group of program
mable logic blocks as test pattern generators and output

possible modes of operation. Since every programmable
logic block is individually tested, the present diagnostic

response analyZers. Further, the method includes the step of
establishing a second group of programmable logic blocks

10

testing method advantageously provides in-system location
of defective devices. Such diagnostic resolution is not
alWays possible With state of the art test systems. This, of

15

haustive testing. Accordingly, every subcircuit of the FPGA
is tested With exhaustive patterns. This results in maximal

course, functions to reduce repair time as Well as repair costs

by enabling one to repair or replace only those components
that are actually defective.

Still other objects of the present invention Will become
apparent to those skilled in this art from the folloWing
description Wherein there is shoWn and described a preferred
embodiment of this invention, simply by Way of illustration

20

of one of the modes best suited to carry out the invention. As

it Will be realiZed, the invention is capable of other different

25

embodiments and its several details are capable of modi?

cation in various, obvious aspects all Without departing from

fault coverage Without the explicit fault model assumptions
and fault simulations that must necessarily be developed
With prior art testing approaches. Of course, many FPGAs
contain RAM modules for Which exhaustive testing is
impractical. For these modules, the test controller utiliZes
standardiZed state of the art RAM test sequences Which are

knoWn to be exhaustive for the fault models speci?c to
RAMs.
Reference is noW made to FIG. 1 shoWing a program

the invention. Accordingly, the draWings and descriptions

mable logic block, generally designated by reference

Will be regarded as illustrative in nature and not as restric
30

tive.

as blocks under test. Once the programmable logic blocks
are fully con?gured in the tWo groups, the test controller
initiates the BIST. The test strategy relies upon pseudoex

numeral 10. The programmable logic block 10 comprises a
memory block 12, a ?ip-?op block 14 and a combinational

BRIEF DESCRIPTION OF THE DRAWINGS

The accompanying draWing incorporated in and forming
a part of the speci?cation, illustrates several aspects of the
present invention and together With the description serves to

35

may be con?gured as RAMs or combination look-up tables

explain the principles of the invention. In the draWing:

(LUTs). The ?ip ?ops in the ?ip ?op block 14 may also be
con?gured as latches although other programming options
With synchronous and asynchronous Set and Reset, Clock

FIG. 1 is a schematical block diagram shoWing the
structure of a typical programmable logic block of a ?eld

programmable gate array (FPGA); and

40

FIG. 2 is a schematical block diagram illustrating a FPGA

structure temporarily programmed for diagnostic testing in
accordance With the method of the present invention.
Reference Will noW be made in detail to the present

structure are easy to control and observe. This simpli?es the

pseudoexhaustive testing of the cell.
Advantageously, the present testing method is particularly
adapted to perform output response analysis by means of

DETAILED DESCRIPTION OF THE
INVENTION

The method of the present invention for diagnostic testing

direct comparison. Such an approach is dif?cult to utiliZe in
most prior art BIST applications because of the expense
involved in storing the reference response or in generating it

of FPGAs Will noW be described in detail. The method may
be described as a sequence of test phases each phase

pass/fail indication. This analyZing step is also completed
With the programmable logic blocks of the FPGA being

Enable, etc. could be provided. Usually, the output block or
cell 16 contains multiplexers (MUX) to connect different
signal lines to the output of the programmable logic block
10. Usually this cell has no feed back loops and the ?ip ?ops
can be directly accessed by by-passing the LUT (as shoWn

by the dashed line in draWing FIG. 1). Advantageously, the
inputs and outputs of every subcircuit in this type of simple

preferred embodiment of the invention, an example of Which
is illustrated in the accompanying draWing.

consisting of a series of simple steps. The ?rst of these steps
is the con?guring of the programmable logic blocks of an
FPGA for completing a built-in self-test (BIST). Next is the
initiating of the BIST. This step is then folloWed by gener
ating test patterns With the programmable logic blocks. Next
is the analyZing of the resulting response to produce a

output logic block 16. Such a structure is, for example,
featured in the AT&T ORCAprogrammable function unit, in
the Xilinx XC4000 con?gurable logic block and the in
ALTERA FLEX 8000 logic element. The memory block 12

55

from a copy of the circuit under test. In accordance With the

present method, hoWever, the circuits under test are identical
programmable logic blocks 10 and all that is needed is to
create the output response analyZers to compare their out

puts.
60

Unlike signature-based compression circuits used in most
other BIST applications, comparator-based output response

tested. Lastly, the method may include the step of reading

analyZers do not suffer from the aliasing problem that occurs

the test results.

When some faulty circuits produce the good circuit signa

As should be appreciated, the con?guring, initiating and
reading steps are all performed by a test controller such as

65

ture. Essentially, as long as the programmable logic blocks
under test 20 being compared by the same output response

automatic test equipment (ATE), a central processing unit

analyZer do not fail in the same Way at the same time, no

(CPU) or a maintenance processor. Typically an ATE of a

aliasing is encountered With the comparison-based approach

6,003,150
5

6

of the present invention. While it should be appreciated that

are compared by O groups of n output response analyZers 22

if the blocks under test 20 are fed by the same faulty test

With each output response analyZer monitoring C outputs
and the ith group of output response analyZers receiving the

pattern generator the applied test Will be incomplete and a
faulty programmable logic block under test may escape

ith output from n BUTs.

detection, this problem may be avoided by con?guring the

For example in the ORCA programmable logic block

logic so that the different test pattern generators feed the
blocks under test 20 being compared by the same output
response analyZer. Further, all test pattern generators must

there are tWo independent look up tables With each of those

look up tables having 5 inputs. Of course, the feedback
connection from the ?ip ?op occupies one of these inputs

be synchroniZed to generate the same test pattern at the same

time.

and, accordingly, C must be set to be equal to 4. Since each
10

Based upon the above described approach, the con?gur
ing step outlined above includes establishing a ?rst group of
programmable logic blocks 10 as exhaustive test pattern
generators 18 and comparison-based output response ana

lyZers 22. Additionally, the con?guring step includes estab

exhaustive test patterns is also 18. Since there are f=4 ?ip

?ops in the programmable logic block, ?ve programmable
logic blocks are required for an exhaustive test pattern
15

lishing a second group of programmable logic blocks 10 as
blocks under test (BUTs) 20. Further, the method includes
the steps of repeatedly recon?guring each BUT 20 in order
to test each BUT in all modes of operation. Accordingly, a
test session may be de?ned as a sequence of test phases or 20

con?gurations that completely tests the BUTs 20. Once the
BUTs 20 have been exhaustively tested the roles of the
programmable logic blocks 10 are changed, that is: the
programming of the ?rst and second groups of program
mable logic blocks 10 is reversed so that the ?rst group is

Of course, an important goal of the testing strategy is to
minimiZe the number of test sessions and thereby minimiZe
the testing time and effectively reduce testing cost. An FPGA

25

FPGAs have been found to be completely tested in tWo test
sessions. It should be appreciated, hoWever, that some of the
smaller FPGAs require three test sessions.

FPGA Architectural Parameters
30
Parameter

Resource

ORCA

XILINX
4000

ALTERA
8000

C

Comparisons/

4

3

4

5

5

3

LUT

O

Outputs/

L

PLB
LUTs/PLB

2

2

1

m

FFs/TPG =

18

12

1O

4

2

1

35

Inputs/PLB
f

FFs/PLB

40

The folloWing examples are presented to further illustrate
the present invention:

m-bit counter. Of course, When the memory block 12 is
con?gured as RAM, the test pattern generators 18 Work as

p-bit state machines (Wherein p>m) in order to generate

Would be required for the test pattern generator used for
RAM mode testing. Further, it should be appreciated that
there are O=5 outputs from each programmable logic block
that must be compared by the output response analyZers 22.
This data is summariZed in the folloWing table and com
pared to the XILINX 4000 and ALTERA FLEX 8000 Series

TABLE 1

con?gured for a test session is illustrated in FIG. 2. The test
pattern generators 18 Work as binary counters in order to

supply exhaustive test patterns to the m-input BUTs 20 in
most of the test con?gurations. Since the programmable
logic block 10 has more inputs than outputs, several pro
grammable logic blocks are required to construct a single

generator. In contrast only four programmable logic blocks

FPGAs. Using this approach, most commercially available

established as BUTs 20 and the second group is established

as test pattern generators 18 and output response analyZers
22. It should therefore be appreciated that at least tWo test
sessions are required to test all of the programmable logic
blocks 10. Advantageously, it should be noted that all the
BUTs 20 are tested in parallel With this approach.
Accordingly, the BIST run time is not dependent on the siZe
of the FPGA.

programmable logic block has m=18 inputs, the number of
?ip ?ops required for a test pattern generator to generate

EXAMPLE 1
45

standard RAM test sequences.

FPGAs Were programmed for the normal functions

intended for the FPGAs during system operation. Program
ming of the FPGAs Was accomplished by doWnloading the
con?guration databits (Which con?gured the FPGAs for the
intended system functions) from hard disk storage media

As noted above, different test pattern generators 18 must
be used to feed the BUTs 20. Thus the number of test pattern

generators 18 required for the BIST is equal to C Where C

represents the number of programmable logic block outputs
that may be compressed by a single response analyZer 22.
Each output response analyZer 22 comprises a look up table
24 for comparing the corresponding output from the C BUTs

under the direction of a microprocessor of a central process
ing unit. System diagnostics Were then run to test the system
for faults. Using the same mechanism as that used to

and a ?ip ?op 26 to record the ?rst mismatch. As shoWn in
FIG. 2 the feedback from the ?ip ?op 26 is output to an input
of the look up table 24. Thus, a mismatch disables further

each BIST con?guration Was doWnloaded into the FPGAs in
turn. Since the BIST con?gurations are generic, the same

doWnload the intended system functions into the FPGAs,
55

con?guration is loaded into all FPGAs regardless of the
intended system function.
Once con?gured, the operation of the BIST functions

comparisons by the output response analyZer 22 once the
?rst error is recorded.

As also illustrated in FIG. 2, several output response
analyZers 22 may be implemented in the same program
mable logic block 10 depending upon the number of inde

60

ing and, upon completion of the BIST sequence, the results

pendent look up tables 24 in the programmable logic block.
The look up tables 24 are considered to be independent if
their set of inputs are disjoint in at least one programmable
logic block con?guration. Each one of the C test pattern
generators 18 drives a group of n BUTs. Each BUT has

m-inputs and O-outputs. The C><n><O outputs from the BUTs

programmed by the FPGAs Was initiated into the same
controlling function as that Which controlled the doWnload

65

of the BIST Was retrieved from the FPGAs by the controller
for determination of the fault free/faulty or pass/fail status of
each FPGA under the given BIST sequence. The next BIST
con?guration Was then doWnloaded, initiated and results
Were retrieved. The process Was continued until all BIST

con?gurations Were doWnloaded and executed.

6,003,150
8

7
Any failing BIST sequence produced by a given FPGA
indicated the existence of one or more faults in that FPGA.

TABLE 2

At that point in time, any printed circuit board containing a
faulty FPGA Was replaced and repaired or, if suf?cient

PLB Fault Simulation Results

diagnostic information Was obtained from the BIST
sequence to facilitate the identi?cation and location of the
fault in the FPGA, the intended system function for that
FPGA Was remapped onto the FPGA so that the faulty
circuitry Was not used in the system function. Following

testing and necessary repair, the intended system functions

Number of Faults Detected
Phase
No.
1
2
3
4
5
6
7
8
9

10

Were reloaded into the FPGAs. This Was done via the

doWnloading mechanism and the system Was brought back
into service.
EXAMPLE 2

15

A similar approach to that disclosed in Example 1 Was
used to simulate FPGAmanufacturing tests Where the device
level test machine controlled the doWnloading of the BIST
sequence, initiated the BIST sequence and then retrieved the
BIST results. In our research laboratory, We utiliZed a PC

20

running commercial FPGA vendor softWare for converting a

digital design de?ned by the designer to the con?guration
bits needed to program the FPGA for the intended system
function (We used a traf?c light controller as an example

system function). The con?guration data Was doWnloaded

25

via a standard PC port and cable to a printed circuit board

MUX

Total

Fault
Coverage

0
0
0
0
234
72
60
40
34

54
30
28
25
25
33
30
15
6

1511
1601
1645
1675
1934
2039
2129
2184
2224

67.9%
72.0%
74.0%
75.3%
87.0%
91.7%
95.7%
98.2%
100%

As should be appreciated from revieWing Table 2, the ?rst
4 phases provided a complete test for the look up tables
While the folloWing 5 phases detected all the faults in the ?ip
?ops. Of course, all 9 phases Were required to detect all the
faults in the output multiplexor. The 9 con?gurations may be
described in terms of the modes set for each of the three
modules. An ORCA output uses a 9-to-1 multiplexor to
select any one of the 4 look up table outputs or 4 ?ip-?op
outputs as Well as the carry out from the look up tables in the

dedicated look-ahead-carry circuitry available in the more
recent FPGA look up table architectures). This 9-to-1 mul

?gurations in the same manner as a system function With the
30

tiplexor establishes the number of con?gurations (9) needed
to completely test the output multiplexor block.
There Were 4 distinct modes of operation for the ORCA
look up tables. These Were RAM, fast adder, look up

(We used the AT &T ORCA development system—ODS), the
BIST con?gurations Were doWnloaded into the FPGA in
order to test the FPGA on the printed circuit board.

1457
60
16
5
0
0
0
0
0

FFs

fast adder mode of operation (a mode of operation With

containing a FPGA (AT&T optimiZed recon?gurable cell
array—ORCA—2C Series). We designated the BIST con
exception being that the intended function in this case Was
a self-test of the FPGA circuitry. Once the BIST con?gura
tion data had been obtained via the FPGA vendor softWare

LUTs

35

table-based logic functions of 5 variables and look up
table-based logic functions of 4 variables. These 4 modes of
operation Were tested during the ?rst 4 phases of the
programmable logic block BIST as summariZed in Table 3.

EXAMPLE 3
TABLE 3

In this example, the con?gurations needed for a complete
BIST session are described and results regarding fault
coverage, test-time and memory requirements are presented.

PLB BIST Con?gurations

40

FF Latch Modes and Options

While pseudoexhaustive testing does not require fault
simulation, We used the fault simulator to evaluate the fault

coverage contained in the different phases of the BIST
session in accordance With the method of the present inven
tion. First We developed a complete gate-level model for the

FF

45

ORCA programmable logic block, including the program
mable logic block con?guration BIST Which Was repre
sented as a primary input Whose values Were “frozen” during
each phase. This alloWed us to also simulate the stuck-at

FF/
Latch

Set/
Reset

Clock

Clock
Enable

Data
Select

LUT
Mode

PLB
Pins

1

—

2

—

—

—

—

—

RAM

13

—

—

—

—

Fast

14

Adder
50

faults effecting the con?guration BISTS. The exhaustive
testing of each of the three modules (look up tables, ?ip ?ops
and output multiplexor) Were used to determine undetectable
faults (3 faults in the look up tables and 4 faults in the ?ip
?ops) Which Were removed from the fault list. A total of
2224 collapsed stuck-at-gate-level faults Were left in the

Phase
No.

55

programmable logic block, consisting of 1538 faults in the

3

—

—

—

—

—

5 —Var.

4

—

—

—

—

—

4-Var.

14

5

FF

Async

Fall

Active

LUT

4-Var.

13

Set

Edge

LoW

Output

6

FF

Async

Rise

Active

PLB

4-Var.

13

Reset

Edge

High

Input

Sync
Set
Sync

Active
LoW
Active

Active
LoW
Active

LUT
Output
PLB

4-Var.

13

4-Var.

13

Reset

High

High

Input

Rise

Active

Dyn.

4-Var.

13

Edge

LoW

Select

7

Latch

8

Latch

9

look up tables, 440 faults in the ?ip ?ops and 246 faults in

FF

—

14

the output multiplexor.
During the RAM mode con?guration the test pattern

A total of 9 con?gurations Were developed to completely
test each programmable logic block. These 9 phases Which
comprised a complete programmable logic block BIST

generators Were con?gured to generate a standard RAM test

sequence While the test pattern generators for all the other
phases Were con?gured as binary counters. Once the look up

session are described in more detail beloW. The fault simu
lation results are summariZed in Table 2 in terms of the

number of neW faults detected in each phase for each of the
3 modules, a cumulative number of total faults detected and
the obtained fault coverage.

65

tables had been tested in the RAM mode, the remaining
BIST phases relied on chessboard patterns stored in the look
up tables to insure all possible patterns at the look up table

outputs.

6,003,150
9

10

The ?ip ?op module had a number of optional modes of

gestion near the perimeter of the array Where many output

operation, including: (1) choice of ?ip ?op or latch, (2)
choice of active clock edge (or level for latches), (3) optional

response analyZer outputs Would otherWise be for routing
resources in order to reach the BS chain.

clock enable With choice of active level, (4) choice of preset
or clear, (5) synchronous or asynchronous preset/clear acti
vation With choice of active level and (6) selection of data

In summary, numerous bene?ts result from employing the

mable logic block inputs. The number of possible combi

concepts of the present invention. As should be appreciated,
and noted from the above description, the present method
takes advantage of the reprogrammability of the FPGAs,
recon?guring the FPGAs to test themselves only during

nations of these options Was too large to be considered.
HoWever, We determined from fault simulating the gate

testability hardWare in the design of the FPGA. Accordingly,

from the look up table output or directly from the program

level programmable logic block model that ?ve con?gura
tions are suf?cient to completely test the ?ip ?op module.
These are the last 5 phases summariZed in Table 3.
It Was also found that the ORCA could be put through
pseudoexhaustive testing in only tWo test sessions. Atotal of
18 con?gurations Was all that Was required to completely

off-line testing. As a result, there is no need to provide
10

In addition, hardWare design and diagnostic softWare
15

test all the programmable logic blocks. These 18 con?gu
rations compare favorably With the 32 con?gurations cur
rently used for a state of the art ORCA manufacturing test.

Unlike the BIST run-time, the con?guration memory

20

requirements and the con?guration doWnload time depended

the programming interface of the FPGA that is associated
25

With the programmable logic blocks. The exception is the
programming read-back circuitry that may be tested by
simply reading back each con?guration after it has been
programmed. Advantageously, the BIST con?gurations also
tests a large portion of the programmable interconnection

30

netWork.

needed to be restored after board or system test. DoWnload
time for the ORCA 1 C Series FPGAs varies from 2—35

msec at a 10 MHZ clock rate. This results in approximately

1 second of testing time required to completely test all the

programmable logic blocks. Of course, if these requirements
are too restrictive for system level testing, the test time could

be reduced by removing some con?gurations Which detect

35

very feW neW faults or Which represent modes of operation

not used in the system for Which the FPGA being tested is

applied.
40

the routing of all test pattern generator outputs to BUTs and
all BUT outputs to output response analyZers. This problem
Was relatively easily overcame, hoWever, by alloWing a
small deviation from the principal of pseudoexhaustive

testing. That is, for every con?guration, instead of applying

in the art to utiliZe the invention in various embodiments and
45

With various modi?cations as are suited to the particular use

contemplated. All such modi?cations and variations are
Within the scope of the invention as determined by the

appended claims When interpreted in accordance With the
breadth to Which they are fairly, legally and equitably

actually used in that phase.

the FPGA even though additional logic resources are

a series arrangement leading to an output response analyZer.
The embodiment Was chosen and described to provide the

best illustration of the principles of the invention and its
practical application to thereby enable one of ordinary skill

exhaustive patterns to all the inputs and observing all the
outputs of a BUT, exhaustive patterns Were only applied to
those inputs and observed only from those outputs that Were
Further, it should be noted that the output response
analyZer results must be brought out of the FPGA for
determining the faulty fault-free status of the FPGA. The
boundary scan (BS) circuitry in the I/O buffers offers the
best approach for this task. In some FPGAS, hoWever, When
all output response analyZer outputs are routed to the BS
chain, the routing resources in the perimeter of the FPGA
become exhausted. It Was found, hoWever, that by ORing the
output results from the output response analyZers into feWer
bits, the BIST con?gurations may be successfully routed in

The foregoing description of a preferred embodiment of
the invention has been presented for purposes of illustration
and description. It is not intended to be exhaustive or to limit
the invention to the precise form disclosed. Obvious modi
?cations or variations are possible in light of the above
teachings. For example, the FPGA under test could be
con?gured to act as an interactive logic array Whereby
blocks under test are connected to other blocks under test in

During testing it Was found that in some instances, the
routing resources of the FPGA Were not suf?cient to alloW

system level testing. Advantageously, loWer-cost automatic
package level testing. Further, it should be appreciated that
the BIST con?gurations developed also test the portion of

(the AT&T 1C09), approximately 16 Kbytes of storage Were

msec per con?guration depending upon the type of interface
betWeen the con?guration storage media and the FPGA. The
execution time for the BIST sequence is approximately 15

development intervals may be reduced since the FPGA BIST
approach is generic and is applicable to all the SRAM based
FPGAs in the system. Since the test sequences are generic
and they are the function of the FPGA architecture and not
a function of What is programmed into the FPGA, this
technique may also be used for manufacturing test from
Wafer level through package and board level to unit and
test equipment may be utiliZed for purposes of device and

on the siZe of the FPGA. For the largest 1 C Series ORCA

needed per con?guration. This means about 160 Kbytes for
the 9 BIST con?gurations and the “normal” con?guration

all logic resources in the FPGA are available for system

functionality.

entitled.
We claim:
1. A method of testing a ?eld programmable gate array

including a plurality of programmable logic blocks, com
prising the steps of:
55

con?guring said programmable logic blocks for complet
ing a built-in self-test;

initiating said built-in self-test;
generating identical test patterns With said programmable

logic blocks;
60

applying said test patterns to equivalently con?gured

programmable logic blocks; and

required for the OR logic. One disadvantage of this approach
Was that some fault diagnostic capability With respect to

comparing outputs of said equivalently con?gured pro

identifying a particular faulty programmable logic block Was
lost. The advantage, hoWever, Was that the programmable

grammable logic blocks in order to produce a pass/fail
indication for each of said equivalently con?gured
programmable logic blocks under test.
2. The method set forth in claim 1, Wherein said con?g

logic blocks implementing the OR logic could be placed
near the output response analyZers from Which they receive

input signals. This advantageously reduced the routing con

65

uring includes establishing a ?rst group of said program

6,003,150
11

12
applying said test patterns to said equivalently con?gured
programmable logic blocks under test;

mable logic blocks as test pattern generators and output

response analyzers.
3. The method set forth in claim 2, Wherein said con?g
uring further includes establishing a second group of said
programmable logic blocks as blocks under test.
4. The method set forth in claim 3, including repeatedly
recon?guring each block under test in order to test each
block under test completely in all possible modes of opera
tion.
5. The method set forth in claim 4, including reversing
programming of said ?rst and second groups of said pro
grammable logic blocks so that said ?rst group is established

comparing outputs of said programmable logic blocks
under test; and
generating a test result indication for said equivalently

con?gured programmable logic blocks under test.

10

11. The method of testing a ?eld programmable gate array
set forth in claim 10, Wherein said con?guring step further
includes establishing a ?rst group of said programmable
logic blocks as a test pattern generator and an output

response analyZer and a second group of said programmable
logic blocks as said blocks under test.
12. The method of testing a ?eld programmable gate array

as blocks under test and said second group is established as

test pattern generators and output response analyZers.
6. The method set forth in claim 5, including repeatedly

set forth in claim 11, including repeatedly recon?guring

recon?guring each block under test in order to test each

each block under test in order to test each block under test

block under test completely in all possible modes of opera

completely in all possible modes of operation.

tion folloWing reversing programming of said ?rst and
second group of programmable logic blocks.
7. The method set
reading results of said
8. The method set
reading results of said

forth in claim 1, further including
built-in self-test.
forth in claim 6, further including
built-in self-test.
9. The method set forth in claim 1, Wherein said test
patterns being generated are exhaustive.
10. A method of testing a ?eld programmable gate array

13. The method of testing a ?eld programmable gate array
20

blocks so that said ?rst group is established as blocks under
test and said second group is established as a test pattern
25

logic blocks;

set forth in claim 13, including repeatedly recon?guring

completely in all possible modes of operation folloWing
reversing programming of said ?rst and second groups of

con?guring said programmable logic blocks for complet
ing a built-in self-test as tWo equivalently con?gured

generator and an output response analyZer.
14. The method of testing a ?eld programmable gate array
each block under test in order to test each block under test

including a plurality of programmable logic blocks, com
prising the steps of:

programmable logic blocks under test;
initiating said built-in self-test;
generating identical test patterns With said programmable

set forth in claim 11, including reversing programming of
said ?rst and second groups of said programmable logic

30

programmable logic blocks.
15. The method of testing a ?eld programmable gate array
set forth in claim 10, Wherein said test patterns being
generated are exhaustive.
*

*

*

*

*

