# An Efficient Transparent Test Scheme for Embedded Word-Oriented Memories

Jin-Fu Li, Tsu-Wei Tseng, and Chin-Long Wey Advanced Reliable Systems (ARES) Laboratory Department of Electrical Engineering National Central University Jungli, Taiwan 320, R.O.C.

#### Abstract

Memory cores are usually the densest portion with the smallest feature size in system-on-chip (SOC) designs. The reliability of memory cores thus has heavy impact on the reliability of SOCs. Transparent test is one of useful technique for improving the reliability of memories during life time. This paper presents a systematic algorithm used for transforming a bit-oriented march test into a transparent word-oriented march test. The transformed transparent march test has shorter test complexity compared with that proposed in the previous works [12, 13]. For example, if a memory with 32-bit words is tested with March C-, time complexity of the transparent word-oriented test transformed by the proposed scheme is only about 56% or 19% time complexity of the transparent word-oriented test converted by the scheme reported in [12] or [13], respectively.

## 1 Introduction

Shrinking transistor size makes the reliability issue become a major challenge of system-on-chip (SOC) designs. Nowadays SOCs usually consists of many memory cores, which are usually the densest portion with the smallest feature size. Thus the reliability of memory cores has heavy impact on the reliability of SOCs. Reliability enhancement techniques for memory cores during life time thus is imperative. Conventional memory BIST (off-line BIST) is a promising approach for embedded memory testing and diagnosis [1, 7, 10, 16], which is helpful for improving the yield of memories during manufacturing phase. However, off-line BISTs cannot be used for testing memories during life time. Thus efficient reliability enhancement techniques for memories should be developed. Online and transparent (periodic) testing are two widely used methodologies for ensuring correct operation of memories during life time.

Concept of transparent testing, which leaves the original contents of the circuit under test unchanged after the testing is completed, has been used for the application of memory testing [3, 6, 8, 9, 11–13, 17–19]. One major advantage of transparent testing is that it can ensure the reliability of

storage data during a life-time operation. On the other hand, transparent testing provides better fault coverage than non-transparent testing for unmodeled faults. Thus, unmodeled faults not detected by the manufacturing testing will be discovered at an early stage of the product life [12].

Several transparent test schemes have been reported in [3, 6, 8, 9, 11–13, 17–19]. These schemes transform the march tests, which have been widely used to test random access memories, into transparent march tests. In [11, 12], a systematic approach for transforming a march test into a transparent march test is presented. The transformation rules consist of two phases-generation of transparent march test and generation of signature prediction test. In [3, 8, 17], the method from [11] is applied to the tests for detecting pattern-sensitive faults and single V-coupling faults described in [2]. Later a symmetric transparent test methodology is proposed in [18]. In this methodology, if the transformed transparent test is not symmetric, then an additional state is added to make it be symmetric. This causes that the final content of the signature analyzer (e.g., MISR) is zero if no faults exist in the memory under test. Thus this methodology can reduce the test time by removing the signature prediction test. Automatic generation of symmetric transparent march tests is also proposed in [19]. However, the transparent tests described above all have the problem of aliasing.

Recently, transparent test schemes without the aliasing problem have been reported in [9, 13]. In [9], a transparent test approach using dynamic power supply current (DPSC) is presented. Instead of generating a signature, the DPSC transparent testing detects the RAM faults by using a current sensor. A transparent online memory test (TOMT) reported in [13] has been developed for online testing of word-oriented memories with parity or Hamming protection. TOMT introduces the concept of concurrent error detection and correction to eliminate the requirement of signature generation and to avoid the interference of normal system operation. So far, however, all the transparent tests for word-oriented memory are not time efficiency. For example, the transparent test scheme reported in [11, 12] performs the bit-oriented operations to all the bits of each word. Another example, TOMT also executes bit-wise manipulations in word-oriented memory testing. Therefore, short transparent tests for word-oriented memories need to be developed. Moreover, shorter test time can reduce the probability of interference of normal system operation, since transparent tests usually are executed in idle state of systems.

This paper presents an efficient transparent test scheme for word-oriented memories. A systematic algorithm is used for transforming a bit-oriented march test into a transparent word-oriented march test. Consider an  $N \times B$ -bit memory and a bit-oriented march test with P Read/Write operations in which there are Q Read operations. Time complexity of the transparent word-oriented march test converted by the proposed algorithm is  $(P+5\log_2 B)N$ . Also, time complexity of the corresponding signature prediction test is  $(Q+2\log_2 B)N$ . The transformed transparent march test has shorter test time compared with that proposed in previous works. For example, if a memory with 32-bit words is tested with March C-, the time complexity of the transparent test transformed by the proposed scheme is only about 56% or 19% time complexity of the transparent test converted by the scheme reported in [12] or [13].

The rest of this paper is organized as follows. Section 2 reviews typical functional RAM faults and defines the notation for representing algorithms. Section 3 describes the transformation rules for conventional transparent march tests. Section 4 introduces the proposed transformation algorithm for transparent word-oriented march tests. Section 5 shows the fault coverage analysis of the transparent word-oriented march tests transformed by the proposed transformation algorithm. Section 6 concludes this paper.

## 2 Fault Model and Notation

In this section we present the widely used fault models of RAMs, which consist of stuck-at faults, transition faults, and coupling faults [4,5,14]. More detail behaviors of these faults are described as follows.

- 1. Stuck-at fault (SAF)—the defective cell permanently contains a 0, i.e., SAF(0), or a 1, i.e., SAF(1), and cannot be changed.
- 2. Transition fault (TF)—the defective cell fails to undergo a 0 to 1 transition or a 1 to 0 transition.
- 3. Coupling fault (CF)—the status of a cell (called coupling cell) affects the content of the other cell (called coupled cell). CFs can be divided into three types: state CF (CFst)—the coupled cell is forced to 0 or 1 only if the coupling cell contains 0 or 1; idempotent CF (CFid)—the content of victim is forced to 0 or 1 if the aggressor undergoes a 0 to 1 transition or a 1 to 0 transition; inversion CF (CFin)—the content of victim is inverted if the aggressor undergoes a 0 to 1 transition or a 1 to 0 transition. In word-oriented memories, CFs can further be divided into intra-word and inter-word

CFs. Intra-word CFs are defined as that the coupled and coupling cells of the CFs are within a word; interword CFs are defined as that the coupled and coupling cells of the CFs are located at different words.

Subsequently, notation for algorithm representation is described. In an algorithm description, D denotes the initial content of a cell or a word for bit-oriented or word-oriented memories, respectively;  $D_a$  is the data  $D \oplus a$ , where  $\oplus$  denotes bit-wise XOR operation, where D and a have the same data width;  $\uparrow (\Downarrow)$  represents the ascending (descending) address sequence;  $\updownarrow$  denotes either ascending or descending address sequence. wX denotes write X operation to an addressed memory cell (word). rX denotes read operation from an addressed memory cell (word) and X is expected. In an nontransparent march test, the X is a specific data for Write operation. On the other hand, the  $X=D_a$  for Write operation in a transparent march test.

#### **3** Conventional Transparent March Tests

March tests (algorithms) are widely used for memory fault detection and diagnosis due to their linear time complexity with respect to the memory size. A march test consists of a finite sequence of march elements. Each march element contains a finite number of Read/Write operations to all cells (words) according to a prespecified address sequence of bit-oriented (word-oriented) memories.

Performing march tests changes initial contents of the memory under test. Thus march tests cannot be used to test the memories in power-up status, i.e., march tests cannot directly be used for online test. Online tests can be divided into concurrent and nonconcurrent online tests. Concurrent online memory testing usually introduces error detection and correction techniques to preserve the data integrity of the memory under test. Nonconcurrent online memory testing usually uses transparent tests to detect the faults and to preserve the data integrity by writing back the read data when the memory under test is in idle state. Thus transparent march tests could be used for periodic online memory testing. This allows restoring memory content after transparent march test procedure.

A conventional bit-oriented march test can be converted into a bit-oriented transparent march test by the following transformation rules [11, 12]:

**Step 1:** If the first test operation of a march element is a Write one, add a Read operation at the beginning of the march element. Subsequently, if a march test consists of an initialization march element and if the march element is useless for fault activation, then remove the march element from the march test.

**Step 2:** Replace all r0 or r1 operations with  $rD_a$  or  $rD_{\bar{a}}$ , respectively. Also, replace all w0 or w1 operations with  $wD_a$  or  $wD_{\bar{a}}$  operations, respectively, where a=0.

**Step 3:** If the content in memory cells are the inverse of their initial data after the last Write operation, then insert

two additional Read and Write operations in the end of the march test. The additional two operations perform Read operation on each memory cell followed by a Write operation with the data which is the inverse of the read data.

**Step 4:** Remove all the Write operations from the transparent march test, which is converted according to Step 1 to Step 3, to obtain the signature prediction algorithm.

For example, consider the classical March C- test [14]: { $\prodef{main}$  (w0);  $\prodef{main}$  (r0, w1);  $\prodef{main}$  (r1, w0);  $\prodef{main}$  (r0)};  $\prodef{main}$  (r0);  $\prodef{main}$  (r0);  $\prodef{main}$  (r0)}. The March C- test can be transformed into a transparent test (TMarch C-) with the transformation rules shown above. Thus TMarch C- is { $\prodef{main}$  (rD<sub>a</sub>, wD<sub>a</sub>);  $\prodef{main}$  (rD<sub>a</sub>, wD<sub>a</sub>);  $\prodef{main}$  (rD<sub>a</sub>, wD<sub>a</sub>);  $\prodef{main}$  (rD<sub>a</sub>, wD<sub>a</sub>);  $\prodef{main}$  (rD<sub>a</sub>, wD<sub>a</sub>); with a=0. The fault coverage of TMarch C- is the same as that of March C-, which is shown in [11, 12]. Also, the signature prediction algorithm of TMarch C- is { $\prodef{main}$  (rD<sub>a</sub>);  $\prodef{main}$  (rD<sub>a</sub>); (rD

Similarly, a conventional word-oriented march test can be transformed into a transparent word-oriented march test with applying the transformation rules to all the bits of each word. A conventional word-oriented march test can be obtained by running the corresponding bit-oriented march test with different data backgrounds (a Read or Write operation for a word-oriented memory involves reading or writing an entire word of data, called data background [4]). For example, if March C- is used to test a memory with 4-bit words, the word-oriented March C- test will be: {( (wX);(rX, wX); (rX, wX); (rX, wX); (rX, wX); (rX, wX);(rX)} for  $X = \{0000, 0101, 0011\}$ . Thus the test consists of the following three parts:

- T1:{(w0000);  $\uparrow$  (r0000, w1111);  $\uparrow$  (r1111, w0000);  $\Downarrow$  (r0000, w1111);  $\Downarrow$  (r1111, w0000);  $\updownarrow$  (r0000)};
- $\begin{array}{c} \mathbf{T2:} \{ \Uparrow \ w0101; \ \Uparrow \ (r0101, w1010); \ \Uparrow \ (r1010, w0101); \ \Downarrow \\ (r0101, w1010); \ \Downarrow \ (r1010, w0101); \ \Uparrow \ (r0101) \}; \end{array}$
- T3:{  $w0011; \uparrow (r0011, w1100); \uparrow (r1100, w0011); \downarrow (r0011, w1100); \downarrow (r1100, w0011); \downarrow (r0011); }; (r0011);$

This test can be transformed into a transparent test with executing the transformation rules shown above on each bit of a word [12], and the transparent test can be otained as follows:

 $T1':\{ (rD_{a_0}, wD_{\bar{a}_0}); \ (rD_{\bar{a}_0}, wD_{a_0}); \ (rD_{a_0}, wD_{\bar{a}_0}); \ (rD_{\bar{a}_0}, wD_{a_0}); \ (rD_{\bar{a}_0}, wD_{a_0}); \ (rD_{\bar{a}_1}, wD_{a_0}); \ (rD_{\bar{a}_1}, wD_{\bar{a}_1}); \ (rD_{\bar{a}_1}, wD$ 

$$T2':\{ (wD_{a_2}); (rD_{a_2}, wD_{\bar{a}_2}); (rD_{\bar{a}_2}, wD_{\bar{a}_2}); (rD_{\bar{a}_2},$$

T4':{
$$(wD_{a_0})$$
};

where  $a_0 = \{0000\}$ ,  $a_1 = \{0101\}$ , and  $a_2 = \{0011\}$ . Note that the additional T4' test is used for restoring the initial data of the memory under test.

## 4 Proposed Transparent March Tests

The transparent test approach presented in this paper is applied in idle state of systems. Reducing the test time thus is very important for avoiding the interrupt of testing. As discussed in Sec. 3, however, a transparent word-oriented march test are directly obtained by repeatly executing the corresponding bit-oriented march test on each bit of a word. This transformation does not generate an efficient transparent word-oriented march test. In this section we propose a transformation algorithm for transforming a bit-oriented march test into a time-efficiency transparent word-oriented march test.

The proposed transparent word-oriented march transformation algorithm (TWM\_TA) is described in Algorithm 1. When a bit-oriented march test (BMarch) is given, TWM\_TA first replaces w0 or w1 of the BMarch with w0or  $w\mathbf{1}$ , where **0** and **1** denote the all-0 and all-1 data backgrounds. Also, the new march test with solid data backgrounds is called SMarch. If the last operation of SMarch is a Write operation, then added a Read operation in the end of SMarch. Subsequently, TWM\_TA transforms the SMarch into a transparent SMarch (TSMarch) with the transformation rules for bit-oriented march tests (described in Sec. 3) by regarding the SMarch as a bit-oriented march test. When the SMarch is executed, if the expected data for the last Write operation of every word is equal to the inverse of the initial data of the word, then added an additional transparent test ATMarch={ $(wD_{a_i}, wD_{\bar{a}_i}, rD_{\bar{a}_i}, wD_{a_i}, rD_{a_i});$  $(wD_{\bar{a}_0})$ . On the contrary, if the expected data for the last Write operation of every word is equal to the initial data of the word, then added an additional transparent test ATMarch= { $\ (wD_{a_i}, wD_{\overline{a}_i}, rD_{\overline{a}_i}, wD_{a_i}, rD_{a_i});$  $(wD_{a_0})$ . Note that the  $a_i$  in ATMarch is a *B*-bit binary data and  $a_i = \sum_{j=0}^{B-1} x_j 2^j$ , where  $x_j = 1$  or  $x_j = 0$  if  $\lfloor j/i \rfloor$  is even or odd for  $i = 1, 2, ..., \lceil \log_2 B \rceil$ , for a memory with Bbit words.

For example, if a memory with 8-bit words is tested, then three data patterns need to be applied to ATMarch, i.e.,  $i=\{1, 2, 3\}$ . According to the description above, the ATMarch must be executed with the following  $a_i$ ,  $a_1=\{01010101\}$  since  $\lfloor j/i \rfloor = \{7,6,5,4,3,2,1,0\}$  for i=1;  $a_2=\{00110011\}$  since  $\lfloor j/i \rfloor = \{3,3,2,2,1,1,0,0\}$  for i=2;  $a_3=\{00001111\}$  since  $\lfloor j/i \rfloor = \{1,1,1,1,0,0,0,0\}$  for i=3. Thus ATMarch= $\{ \mathcal{l}(wD_{a_1}, wD_{\overline{a}_1}, rD_{\overline{a}_1}, wD_{a_1}, rD_{\overline{a}_3}, wD_{\overline{a}_3}, rD_{\overline{a}_2}, rD_{\overline{a}_2}, wD_{a_2}, rD_{\overline{a}_2} \}$ . Assume that the content of the word is  $D=\{d_7d_6d_5d_4d_3d_2d_1d_0\}$  after the TSMarch is performed. Table 1 shows the content of the word when the first three march elements of ATMarch are executed.

An example is given to explain the proposed transparent march test scheme further. Consider a bit-oriented March U [15] :{(w0); (r0, w1, r1, w0); (r0, w1); (r1, w0, r0, w1); (r1, w0)}. The March U is first transformed into a test with solid backgrounds, called SMarch U.

## Algorithm 1 TWM\_TA

Require: BMarch—a given bit-oriented march test TBMarch: the transparent BMarch converted from BMarch 0 or 1: all-0 data or all-1 data SMarch: BMarch with solid data backgrounds (all-0 or all-1) TSMarch: the corresponding transparent test of SMarch ATMarch: an added transparent march test TWMarch: transparent word-oriented march test Word[*j*]: the content of the *j*th word  $a_i$ : a *B*-bit binary data and  $a_i = \sum_{j=0}^{B-1} x_j 2^j$ , where  $x_j = 1$ or  $x_j = 0$  if  $\lfloor j/i \rfloor$  is even or odd for  $i = 1, 2, \ldots, \lceil \log_2 B \rceil$ , for a memory with B-bit words.  $a_0$ : a all-0 data if BMarch =  $\{\emptyset\}$  then Abort while BMarch  $\neq \{\emptyset\}$  do for all Test Operations of BMarch do Replace w0 or w1 with w0 or w1, respectively Replace r0 or r1 with r0 or r1, respectively if The last operation of SMarch is a Write operation then Added a Read operation in the end of SMarch Transform SMarch into TSMarch according to the transformation rules described in Sec. 3 [11, 12] else Transform SMarch into TSMarch according to the transformation rules described in Sec. 3 [11, 12] if Word[j] $\neq$ the initial content after executing the TSMarch then

 $\begin{array}{l} \text{ATMarch}= \{ \Uparrow \ (wD_{a_i}, wD_{\bar{a}_i}, rD_{\bar{a}_i}, wD_{a_i}, rD_{a_i}); \ \Uparrow \\ (wD_{a_0}) \} \end{array}$ 

$$\begin{array}{l} \text{ATMarch}=\{ \Uparrow \ (wD_{a_i}, wD_{\bar{a}_i}, rD_{\bar{a}_i}, wD_{a_i}, rD_{a_i}); \ \Uparrow \\ (wD_{\bar{a}_0}) \} \end{array}$$

Return TWMarch={TSMarch; ATMarch}

Return Signature prediction test by removing the Write operations in TWMarch

Then SMarch U is { $\uparrow w0$ ;  $\uparrow (r0, w1, r1, w0)$ ;  $\uparrow (r0, w1)$ ;  $\Downarrow$  (r1, w0, r0, w1);  $\Downarrow$  (r1, w0)}. Because the last operation of SMarch U is a Write operation, an additional Read operation  $(\uparrow (r0))$  is added in the end of the SMarch U. Assume that a memory with 8-bit words is tested. According to the transformation rules described in [11, 12], TSMach U will be  $\{ \uparrow (rD_{a_0}, wD_{\bar{a}_0}, r_{D_{\bar{a}_0}}, wD_{a_0}); \uparrow (rD_{a_0}, wD_{\bar{a}_0}); \}$  $\begin{array}{l} \Downarrow \quad (rD_{\bar{a}_0}, wD_{a_0}, rD_{a_0}, wD_{\bar{a}_0}); \quad \Downarrow \quad (rD_{\bar{a}_0}, wD_{a_0}); \quad \Uparrow \\ (rD_{a_0}) \}, \text{ where } a_0 = \{00000000\}. \quad \text{After TSMarch is ex-} \end{array}$ cuted, the content of each word is equal to the initial content of the word. Therefore, the added ATMarch is  $\{ (wD_{a_1}, wD_{\bar{a}_1}, rD_{\bar{a}_1}, wD_{a_1}, rD_{a_1}); (wD_{a_2}, wD_{\bar{a}_2}, wD_{\bar{a}_2$  $rD_{\bar{a}_2}, wD_{a_2}, rD_{a_2}$ ;  $(wD_{a_3}, wD_{\bar{a}_3}, rD_{\bar{a}_3}, wD_{a_3}, rD_{a_3})$ ;  $a_1 = \{00001111\}$ . The complexity of the transformed transparent word-oriented March U is 29N for testing a memory with 8-bit words. Also, time complexity of the corresponding signature prediction algorithm is 14N, which can be obtained by removing the Write operations. Formal analysis of time complexity of the proposed transparent test scheme will be discussed in Sec. 5.

Table 1: The content of the word when the first three march elements of ATMarch are executed.

| of minutell die executed.    |                                                   |  |  |  |  |  |
|------------------------------|---------------------------------------------------|--|--|--|--|--|
| Test operations              | $d_7 d_6 d_5 d_4 d_3 d_2 d_1 d_0$                 |  |  |  |  |  |
| $wD_{a_1}$                   | $d_7 ar{d_6} d_5 ar{d_4} d_3 ar{d_2} d_1 ar{d_0}$ |  |  |  |  |  |
| $wD_{ar{a}_1}, rD_{ar{a}_1}$ | $ar{d}_7 d_6 ar{d}_5 d_4 ar{d}_3 d_2 ar{d}_1 d_0$ |  |  |  |  |  |
| $wD_{a_1}, rD_{a_1}$         | $d_7 ar{d_6} d_5 ar{d_4} d_3 ar{d_2} d_1 ar{d_0}$ |  |  |  |  |  |
| $w D_{a_2}$                  | $d_7d_6ar{d}_5ar{d}_4d_3d_2ar{d}_1ar{d}_0$        |  |  |  |  |  |
| $wD_{ar{a}_2}, rD_{ar{a}_2}$ | $ar{d_7}ar{d_6}d_5d_4ar{d_3}ar{d_2}d_1d_0$        |  |  |  |  |  |
| $wD_{a_2}, rD_{a_2}$         | $d_7d_6ar{d}_5ar{d}_4d_3d_2ar{d}_1ar{d}_0$        |  |  |  |  |  |
| $w D_{a_3}$                  | $d_7d_6d_5d_4ar{d}_3ar{d}_2ar{d}_1ar{d}_0$        |  |  |  |  |  |
| $wD_{ar{a}_3}, rD_{ar{a}_3}$ | $ar{d_7}ar{d_6}ar{d_5}ar{d_4}d_3d_2d_1d_0$        |  |  |  |  |  |
| $wD_{a_3}, rD_{a_3}$         | $d_7d_6d_5d_4ar{d}_3ar{d}_2ar{d}_1ar{d}_0$        |  |  |  |  |  |

#### 5 Fault Coverage Analysis and Comparison

The fault coverage analysis of the transparent wordoriented march tests transformed with the proposed TWM\_TA is discussed. Fault coverage of the faults described in Sec. 2 are considered. For a given bit-oriented march test, we will show that the fault coverage of the transparent word-oriented march test transformed with TWM\_TA is the same as the fault coverage of the corresponding word-oriented march test. Apparently, if a bitoriented march test can detect the SAFs and TFs, the corresponding transformed transparent march test by TWM\_TA also can detect the SAFs and TFs, since the TSMarch is obtained with transforming the bit-oriented march test directly.

Subsequently, the fault coverage analysis of CFs is discussed. Figure 1(a) shows all possible fault-free states of any two arbitrary cells in a bit-oriented memory. Assume that the state of the two cells is  $(D_i D_j)$  after the initialization march element of a march test. Also, let i be the lower address and j be the higher one without loss of generality. If a bit-oriented march test can detect 100% CFs (CFin, CFid, and CFst), then test operations of the march test must excite any two arbitrary cells to undergo all the states as shown in Fig. 1(a). For example, the March C- has been shown that it can detect 100% CFs [14]. If the March C- is executed in  $(D_i D_i)$ , the two cells undergo all the states with the sequence 1,2,3,...,18. The TWM\_TA first transforms a BMarch into a corresponding SMarch. Apparently, the SMarch also can detect 100% inter-word CFs if the BMarch can detect 100% CFs. Thus the  $(D_i D_i)$  of Fig. 1 can be replaced with any two arbitrary words. Also, SMarch can undergo the states with the sequence which is the same as that of BMarch. Therefore, TSMarch also can detect 100% inter-word CFs, since fault coverage of TS-Mach is unchanged after the transformation rules reported in [12] are executed.

In a word-oriented memory, all bits of a word perform the Read or Write operation concurrently. Figure 1(b) shows all possible fault-free states of any two bits within a word. A word-oriented march test which can cover 100% intra-word CFs (CFid, CFin, and CFst) makes any two bits within a word undergo the following state conditions:  $(d_i \rightarrow \overline{d}_i; d_j)$ ,  $(d_i \rightarrow \overline{d}_i; \overline{d}_j)$ ,  $(\overline{d}_i \rightarrow d_i; d_j)$ , and  $(\bar{d}_i \rightarrow d_i; \bar{d}_j)$ , where  $(x \rightarrow \bar{x}; y)$  denotes a Write operation writing the data  $(\bar{x}y)$  into two bits within a word and the original data of the two bits is (xy), and subsequently a Read operation reads the expected data  $(\bar{x}y)$ . As Fig. 1(a) shows, if the  $D_i$  and  $D_j$  is replaced with two arbitrary words, then the two state conditions,  $(d_i \rightarrow d_i; d_i)$ and  $(d_i \rightarrow d_i; d_i)$ , can be checked when the SMarch is executed. Finally, the non-transparent part of ATMarch is AMarch={ $(wa_1, w\bar{a}_1, r\bar{a}_1, wa_1, ra_1)$ } for  $a_1 = \{01\}$ is executed, where a memory with two-bit words is assumed without loss of generality. Assume that the memory state is all-0 when the SMarch is completed. That is, the AMarch executes the following operations for each word:  $\{(wd_i\bar{d}_j,w\bar{d}_id_j,r\bar{d}_id_j,wd_i\bar{d}_j,rd_i\bar{d}_j)\}$ . The state condition  $(d_i \rightarrow \bar{d}_i; d_j)$  is checked when the  $r\bar{d}_i d_j$  is executed; and the condition  $(\bar{d}_i \rightarrow d_i; \bar{d}_i)$  is also checked when the  $rd_i \bar{d}_i$  is performed. Therefore, the four state conditions for intra-word CFs detection are checked when SMarch and AMarch are performed if the corresponding bit-oriented march test can detect 100% CFs. According to the test coverage theorem in [12], we conclude that the transformed transparent wordoriented march test (TWMarch=TSMarch+ATMarch) can preserve the same fault coverage of inter-word and intraword CFs of the corresponding nontransparent wordoriented march test (SMarch+AMarch).



Figure 1: (a) All states of two arbitrary words when TS-March is executed. (b) All states of two arbitrary bits within a word.

In the sequel, we analyze time complexity of the transparent word-oriented march tests converted by the

TWM\_TA and compare the time complexity with other transparent test schemes. Consider an  $N \times B$ -bit memory and a bit-oriented march (BMarch) test with P Read/Write operations in which there are Q Read operations. Without loss of generality, we assume that BMarch has an initialization Write operation, the first operation is Read operation in each march element, and the last operation is a Read operation. Also, we assume that B is power of 2. As Algorithm 1 shows, time complexity of the transparent word-oriented march test (TCM) transformed with TWM\_TA with respect to the bit-oriented march test can be calculated as follows:

$$TCM = (P + 5\log_2 B)N$$

Also, time complexity of the corresponding signature prediction test (TCP) can be expressed as follows:

$$\mathsf{TCP} = (Q + 2\log_2 B)N.$$

We compare the proposed transparent march tests with the transparent march tests reported in [12, 13], since the two works also discuss the word-oriented transparent tests. As described in Sec. 3, the transparent test scheme reported in [12] transforms the bit-oriented march tests into transparent word-oriented march tests with executing the transformation in each bit of a word. Therefore, the TCM and TCP of the transparent word oriented march test converted with the scheme reported in [12] can be calculated as

$$TCM = P(\log_2 B + 1)N.$$
  
$$TCP = Q(\log_2 B + 1)N.$$

The TCM of the transparent online march test (TOMT) reported in [13] is (4 + 8B)N. TOMT is a online test which does not need the signature prediction test, i.e., TCP=0. Table 2 summarizes the comparison of TCM and TCP for the three transparent test schemes discussed above.

Table 2: Comparison of different transparent test schemes.

|               | TCM                  | TCP                  |
|---------------|----------------------|----------------------|
| Scheme 1 [12] | $P(\log_2 B + 1)N$   | $Q(\log_2 B + 1)N$   |
| Scheme 2 [13] | (4 + 8B)N            | No                   |
| This work     | $(P+5{\rm log}_2B)N$ | $(Q+2{\rm log}_2B)N$ |

As Table 2 shows, the proposed transparent wordoriented test scheme has better time complexity compared with Scheme 1 [12]. Also, the proposed scheme has shorter time compared with Scheme 2 [13] for most cases. For example, if March C- is transformed into a transparent wordoriented March C- for testing an  $N \times 32$ -bit memory, then test complexity (TCP+TCM) of Scheme 1 [12], Scheme 2 [13], and the proposed scheme is 90N, 260N, and 50N, respectively. That is, time complexity of the transparent word-oriented test transformed by the proposed scheme is only about 56% or 19% time complexity of the transparent word-oriented test converted by Scheme 1 or Scheme 2, respectively. Table 3 summarizes the test complexity of the three schemes for a memory with respect to different word sizes and test algorithms. As the table shows, the transparent test scheme proposed in this paper has smaller time complexity compared with the other two works. Furthermore, time complexity of the proposed transparent test scheme is only slightly related to the bit-oriented test. However, time complexity of the transparent test scheme reported in [12] is heavily related to the bit-oriented test.

|   | Test  | Word Size | [12] | [13]  | This work |
|---|-------|-----------|------|-------|-----------|
| ſ |       | 16 bits   | 75N  | 132N  | 43N       |
|   | March | 32 bits   | 90N  | 260N  | 50N       |
|   | C-    | 64 bits   | 105N | 516N  | 57N       |
|   |       | 128 bits  | 120N | 1028N | 64N       |
| Ī |       | 16 bits   | 95N  | 132N  | 47N       |
|   | March | 32 bits   | 114N | 260N  | 54N       |
|   | U     | 64 bits   | 133N | 516N  | 61N       |
|   |       | 128 bits  | 152N | 1028N | 68N       |

Table 3: Comparison of time complexity for different word sizes.

## 6 Conclusions

This paper presents a systematic algorithm for transforming a bit-oriented march test into a transparent wordoriented march test. We have also shown that fault coverage of the transformed transparent word-oriented march test is the same as that of the corresponding nontransparent word-oriented march test. Consider an  $N \times B$ -bit memory and a bit-oriented march test with P Read/Write operations in which there are Q Read operations. Time complexity of the transparent word-oriented march test converted by the proposed algorithm is  $(P+5\log_2 B)N$ . Also, time complexity of the corresponding signature prediction test is  $(Q+2\log_2 B)N$ . The transformed transparent march test has shorter test time compared with that proposed in previous works. For example, if a memory with 32-bit words is tested with March C-, the time complexity of the transparent test transformed by the proposed scheme is only about 56% or 19% time complexity of the transparent test converted by the scheme [12] or [13]. Moreover, compared with the scheme [12], time complexity of the proposed transparent test scheme is slightly related to the corresponding bit-oriented march tests.

## Acknowledgement

This work was supported in part by the National Science Council, R.O.C., under Contract NSC 92-2218-E-008-005.

#### References

 P. Camurati, P. Prinetto, M. S. Reorda, S. Barbagallo, A. Burri, and D. Medina. Industrial BIST of embedded RAMs. *IEEE Design & Test of Computers*, 12(3):86–95, Fall 1995.

- [2] B. F. Cockburn. Deterministic tests for detecting single Vcoupling faults in RAMs. J. Electronic Testing: Theory and Application, 5:91–113, Feb. 1994.
- [3] B. F. Cockburn and Y.-F. N. Sat. A transparent built-in selftest scheme for detecting single V-coupling faults in RAMs. In Proc. IEEE Int. Workshop on Memory Technology, Design and Testing (MTDT), pages 119–124, 1994.
- [4] R. Dekker, F. Beenker, and L. Thijssen. Fault modeling and test algorithm development for static random access memories. In *Proc. Int. Test Conf. (ITC)*, pages 343–352, 1988.
- [5] R. Dekker, F. Beenker, and L. Thijssen. A realistic fault model and test algorithm for static random access memories. *IEEE Trans. Computer-Aided Design of Integrated Circuits* and Systems, 9(6):567–572, June 1990.
- [6] S. Demidenko, A. J. van de Goor, S. Henderson, and P. Knoppers. Simulation and development of short transparent tests for RAM. In *IEEE Asian Test Symp. (ATS)*, pages 164–169, 2001.
- [7] C.-T. Huang, J.-R. Huang, C.-F. Wu, C.-W. Wu, and T.-Y. Chang. A programmable BIST core for embedded DRAM. *IEEE Design & Test of Computers*, 16(1):59–70, Jan.-Mar. 1999.
- [8] M. Karpovski and V. Yarmolik. Transparent memory BIST. In Proc. IEEE Int. Workshop on Memory Technology, Design and Testing (MTDT), pages 106–111, 1994.
- [9] H.-S. Kim and S. Kang. DPSC SRAM transparent test algorithm. In *IEEE Asian Test Symp. (ATS)*, pages 145–150, 2002.
- [10] J.-F. Li, R.-S. Tzeng, and C.-W. Wu. Diagnostic data compression techniques for embedded memories with built-in self-test. *J. Electronic Testing: Theory and Application*, 18(4-5):515–527, Aug.-Oct. 2002.
- [11] M. Nicolaidis. Transparent BIST for RAMs. In Proc. Int. Test Conf. (ITC), pages 598–607, 1992.
- [12] M. Nicolaidis. Theory of transparent BIST for RAMs. *IEEE Trans. Computers*, 45(10):1141–1156, Oct. 1996.
- [13] K. Thaller and A. Steininger. A transparent online memory test for simultaneous detection of functional faults and soft errors in memories. *IEEE Trans. Reliability*, 52(4):413–422, Dec. 2003.
- [14] A. J. van de Goor. Using march tests to test SRAMs. *IEEE Design & Test of Computers*, 10(1):8–14, Mar. 1993.
- [15] A. J. van de Goor and G. N. Gaydadjiev. March U: a test for unlinked memory faults. *IEE Proc.-Circuits Devices Syst.*, 144(3):155–160, June 1997.
- [16] C.-W. Wang, C.-F. Wu, J.-F. Li, C.-W. Wu, T. Teng, K. Chiu, and H.-P. Lin. A built-in self-test and self-diagnosis scheme for embedded SRAM. *J. Electronic Testing: Theory and Application*, 18(6):637–647, Dec. 2002.
- [17] V. Yarmolik and M. Karpovski. Transparent memory testing for pattern-sensitive faults. In *Proc. Int. Test Conf. (ITC)*, pages 860–869, 1994.
- [18] V. N. Yarmolik and S. ellebrand. Symmetric transparent BIST for RAMs. In *Proc. Design, Automation and Test in Europe (DATE)*, pages 702–707, 1999.
- [19] A. P. Zankovich, V. N. Yarmolik, and B. Sokol. Automatic generation of symmetric transparent March memory tests. In *Proc. IEEE Int. CAD systems in Microelectronics*, pages 226–229, 2003.