Abstract-Field Programmable Gate Arrays (FP-GAS) are an increasingly popular choice for fast prototyping and for products whose time to market is relatively short. Testing FPGAs before programming them is thus becoming a major concern to the manufacturers as well as the users. In this paper we propose a universal test for the interconnects of typical dynamic reconfigurable FPGAs. The proposed test configurations and corresponding test patterns for the Xilinx XC6200 FPGAs are shown to cover all interconnect faults. In our test, the total number of test configurations is only 7, which is independent of the FPGA size. The test time for XC6216 is less than 5ms.
I. INTRODUCTION
With the advent of deep-submicron VLSI technology, system-on-a-chip is no longer a dream. However, as the integration density and design complexity of system chips keep increasing, the time required for design verification is becoming extremely long. Field Programmable Gate Arrays (FPGAs) thus are receiving a growing attention.
They provide a good hardware prototyping and emulation platform, resulting in short turn-around time for product development. They also can be used in first-generation products that need to get into the market soon.
A typical FPGA consists of an array of function units and interconnect channels/matrices. The function units and interconnect switches are programmable, i.e., they can be configured to perform different logic functions. For a RAM-based FPGA, the configuration data (normally generated by software tools) is downloaded to its control memory before it can be used as a chip designed to the specified function. The FPGAs can be reprogrammed for virtually unlimited times.
There are many FPGA architectures developed in the past for different applications. A look-up table (LUT) based FPGA contains several look-up tables in a function unit, which is also called a configurable logic block (CLB).
It normally uses surrounding segmented wiring channels and switch matrices for interconnect. LUT-based FPGAs are widely used for hardware prototyping because of its flexible function and interconnect Configuration; e.g., Xil-
Cheng-Wen Wu
Dept. of Electrical Engineering National Tsing Hua University Hsinchu, Taiwan 300 e-mail cww@ee.nthu.edu.tw inx XC4000-series [l] and Altera FLEXlOK-series [2] . On the other hand, with a hierarchical architecture, dynamic reconfigurable FPGAs employ multiplexers in both function and interconnect configuration; e.g., Xilinx XC6200-series [3] . Unlike the LUT-based FPGAs which must complete their configuration in one pass and can not be partially reconfigured, the configuration memory of a dynamic reconfigurable FPGA can be changed partially. A section of the device can be reconfigured without disturbing circuits already configured in other sections. The enhanced programmability is dedicated for custom computing [4] , so they are also called reconfigurable processing units (RPUs [6] . It is universal because it has nothing to do with the target circuit. Note that a universal test still requires different test configurations (TCs) and their corresponding test patterns (TPs). T C generation is a very time-consuming process; moreover, TC downloading occupies most of the testing time, i.e., time(TC)>>time(TP) for each TC. To speed up the universal testing process, we must reduce the number of TCs while still able to cover all programmable resources of the FPGA, i.e., function units and interconnects.
Methodologies for testing interconnects in LUT-based FPGAs have been proposed in . Also, the problem of testing function units in dynamic reconfigurable FP-GAS is addressed in [lo] . In this paper, we focus on testing interconnects in dynamic reconfigurable FPGAs. The next section gives an overview of the FPGA architecture. The basic cell (BC) implements simple functions iind provides basic interconnects between neighboring cells. As illustrated in Fig. 2 , a BC consists of a function unit and several routing multiplexers. The logic functions of the BC are generated by the function unit. The funct,ion unit can be configured to implement any two-input gate, a 2:l multiplexer, constant 0 or 1, single input functions (buffer or inverter), or any of these in addition to a D-type flip-flop. Note that the implicit select lines of the multiplexers are controlled by bit-values of the configuration memory.
FAULT MODEL AND TEST STRATEGY
Multiplexer is the elementary component of XC6200. As illustrated in Fig. 2 , testing the interconnects is tan- A multiplexer is a group of switches which pass one of the inputs to the output according to the configuration of switches: the switch for the selected input is on and all others are off. The multiplexers (switches) are actually controlled by the configuration data. Therefore, we consider the multiplexer as configurable switches (see Fig. 3 ). Exactly one switch is on at any time. Two assumptions for multiplexer switches are as follows: When a switch is always on regardless of the configuration, it is a stuck-on switch; similarly, a stuck-off switch is always off. Note that a test that detects stuck-on/off faults of a multiplexer also detects stuck-at faults of its 1/0 wires.
Theorem 1 A test which detects all switch stuck-on/o$ faults of a multiplexer also detects its 1/0 s t u c k a t faults.
Proof: The test which detects a switch stuck-off fault must exercise a transition on its data path. Obviously it can also detect stuck-at faults on the corresponding data input and output. A stuck-at fault on a configuration (control) input results in multiple stuck-off faults. For example, in Fig. 3 , a stuck-at-0 on q, results in stuck-off faults on s1 and s3. Therefore, stuck-at faults on configuration inputs are covered by the test for stuck-off faults. It is obvious that M P activates any switch stuck-on and stuck-off fault, and the fault effect can be observed from the output Y . For example, when c = 0, MP; and MP: together activate the stuck-off fault of SO, since if the switch is always off then it will fail to pass at least one of the values 0 and 1. Additionally, MP: activates the stuckon faults of all switches except SO, because each of these faults results in a faulty output value (i.e., 1) according to the second assumption of the multiplexer model. Note that when wired-AND logic is assumed instead of wired-OR, M P still activates all switch stuck-on and stuck-off faults, where the stuck-on faults are activated by M P 1 instead of M P o .
Bridging (short) faults on input nets of the multiplexer are also covered by M P o if the fault behavior is equivalent to wired-OR logic, or by MP' if wired-AND is assumed.
IV. TESTING BASIC INTERCONNECTS
Basic interconnects are implemented by four four-input multiplexers in the basic cell, as shown in Fig. 4 . Parallel testing of these multiplexers is achieved by three TCs, as shown in Fig. 5 . In the figure, we show only a 2 x 2 array for clarity. It can be directly extended to any N x N array and tested with the same approach. Orthogonal +45" Diagonal -45" Diagonal The test pattern is denoted as T P = ( t s , LE, tN, t w ) , where t s is the two-bit south-bound test sequence, tE the east-bound test sequence, tN the north-bound test sequence, and t w the west-bound test sequence, respectively. According to the test strategy presented in the previous section, applying M P o and MP' to multiplexers in parallel is our goal. For the orthogonal test configuration, we apply the two-pattern tests TP: = (01,10,10,01) and TP: = (10,01,01,10) to achieve this goal. Note that F is the output of the function unit which is not shown for simplicity. By proper hierarchical routing and configuration of the function unit as a buffer or an inverter, the required value of F in each cell can be assigned. As a result, TP; and TP: deliver M P 1 or M P o to all cells in parallel with two sets of F values as shown in Figs. 6 and 7, respectively. In these figures we show symbolic maps on the right, where the triangles represent the multiplexers at the corresponding locations in the cells. In: side each triangle, there is a circle if M P o is applied to the corresponding multiplexer, and a cross ( X ) if MP' is applied instead. Combining these maps we see that M P is successfully applied to each and every multiplexer. Similarly, the +45O diagonal TC is TCd+ = ( E , S , W, N ) , and its two-pattern tests are TI$+ = (OO, OO, 11, ll) and TPj+ = (11,11,00,00). For the -45" diagonal TC, TCd-= ( W , N , E , S ) , the two-pattern tests are TP;-= (00,11,11,00) and TPj-= (11,00,00,11).
All stuck-on and stuck-off faults of the basic interconnect switches are covered except the stuck-off faults of the F switches. Testing the F switches requires four configurations: TCF,, TCp,, TCF,, and TCF,, where, e.g., TCF, is illustrated in Fig. 8 . It is clear that if w receives (01) then the F switch stuck-off fault in MW is detected. The other three F switch stuck-off faults are covered in a similar way. In any of the orthogonal, 2 diagonal, and 4 F configurations, fault effects are propagated in the respective directions to the primary outputs, so given their corresponding test patterns, the 7 TCs test all stuck-on and stuck-off faults in M s , M E , M N , and M w . By Thm. 1, all multiplexer 1/0 stuck-at faults are covered. The test M P also covers bridging faults between data inputs lines. Bridging faults between adjacent interconnect wires are detected by the orthogonal TC and the corresponding patterns, which guarantees that adjacent wires carry complementary values during test. In summary, the basic interconnects are fully tested by 7 TCs.
V. CONCLUSIONS
We have proposed a universal test for basic interconnects of Xilinx dynamic reconfigurable FPGAs. We started from testing the elementary components (the multiplexers) by the test pattern M P , which covers all stuckon and stuck-off faults of the multiplexer switches, stuckat faults of the multiplexer I/Os, and shorts between the data inputs. A universal test for the basic interconnects of the Xilinx XC6200-family FPGAs have been proposed.
The test contains 7 TCs-1 orthogonal, 2 diagonal, and
