# APPLICATION AND ARCHITECTURE OF LOW POWER LINEAR FEEDBACK SHIFT REGISTER FOR FAST AUTOMATIC TEST PATTERN GENERATION

Joy Merline C G., Vigneshwar and V. Bharathi

Dept. of Electronics and Communication Engineering Madha Engineering College, Kundrathur, Chennai- 69, Tamil Nadu, India

## ABSTRACT

In this paper, a new test pattern generation methodology is proposed to check the devices or circuits after manufacturing that takes advantage of shared memory multi-core systems which consumes less power and delay. Unlike the other test generation patterns this method generates the test patterns by Low Power LFSR using Gray code generator which consumes less power due to its less switching activity. This methodology is implemented in Half Adder and FIR filter circuits to check their functionality. This method is synthesized and simulated using Xilinx 14.7. The experimental results demonstrate that the proposed methodology achieves less power consumption and delay.

Keywords: ATPG, Low Power LFSR, Gray Code generator, Half Adder and FIR filter.

# **INTRODUCTION**

In existing method to check whether the device or circuit is working properly or not some of the test patterns are applied to the CUT (Circuit Under Test) which are generated by LFSR which uses XOR operation. The block diagram of this methodology is shown below. ATPG is an electronic design automation method/technology used to recognize whether the circuit is fault free or faulty [1]. Toverify the functionality of the circuit/device after manufacturing some test patterns are applied to the CUT. As the technology is shrinking in the IC manufacturing process multiple processing units (cores) are placed on a single chip as well as large amounts of on chip memory but these developments offer high processing power. While previously proposed procedures are very effective [2-4], they are inherently non-parallel and thus, cannot perform automatic parallelization using sophisticated compilers. In [5-7] the fault portioning is focused to increase the fault coverage. After that parallel ATPG has been proposed which uses on-chip multi-core era, but the ATPG components among multiple processing units are placed on the same chip [8-9]. Next various parallel ATPG

methods such as circular pipeline parallel ATPG[10] and GPU based ATPGs[11-12] are came into existence but they are having some disadvantages like same test sets are regenerating each time and limits the speed-up scalability.

In this work we propose a parallel test pattern generationmethodology which uses the sharedmemory multi-core systems geared towards high speed. To generate the pseudo random test patterns Low Power LFSR is used which consumes less power and delay. In Low Power LFSR the patterns are in Gray code by which switching activity less compared to LFSR (Figure 1). The block diagram consists of following blocks such as LFSR, CUT, MISR, TPA, Controller and Memory.

**Linear Feedback Shift Register:** LFSR is used for generating the test patterns by which the functionality of the circuit is verified (Figure 2). It is a shift register whose input bits are operated by the XOR of some bits of the overall shift register value (Figure 3). The initial value which is given to the LFSR is called the seed.

**Circuit under Test:** The Circuit under Test is circuit or device which has to be tested. Buffer circuit is used in this existing method. The output of the Buffer circuit is same as the input (Figure 4).

**Multiple Input Shift Register:** The Multiple Input Shift Register is used in an output section; the existing output of the circuit/device is to be compared with fault free output for detection of error. It contains all D flip- flops whose output is feed backed to the input and then bits willbe shifted. This shifted output patterns are compared with the output patterns of LFSR to check whether circuit is faulty or not. If CUT has any type of error the MISR patterns does not match with the LFSR patterns. This is because if CUT does not work properly it does not give correct output to the MISR, by that the MISR patterns also have some errors (Figure 5).

**Test Pattern Analyzer:** The Test Pattern Analyzer compares the output patterns of LFSR and MISR and gives the output to controller.

Controller: The controller has one input as enable and one output as interrupt. When enable is high then only the whole process of the ATPG is started. If the output patterns of LFSR and output patterns of MISR are not same then the interrupt will be 1 otherwise 0.

Memory: The ATPG system uses the concept of memory multi-core which is used to store

the pseudo random test patterns by the speed of the process increases. The memory multicore is divided into multi-cores i.e., two multi-cores in which the LFSR test patterns are stored in memory. As the number of cores increases the speed also increases.

## **METHODOLOGY**

Now-a-days the desire for the portable devices is increasing enormously. So the Power reduction is necessary to satisfy the demands of the consumer. The test patterns generated using LFSR finds complexity in Power. For the purpose of power reduction the patterns ere generated using Low Power LFSR which uses Gray code rather than binary code. The purpose of choosing gray code is to reduce the power requirements.

In proposed methodology Low Power LFSR is used for the generation of the test patterns using Gray code Generator which consumes less power and delay. The Low power LFSR is similar to the LFSR but the initial seed is converted into Gray code using Gray code generator. After that, rest of the patterns is generated using XOR operation. This method reduces powerconsumption and delay up to 55% and 6% respectively.

Low Power LFSR: In ATPG to verify the functionality of the circuit some of the test patterns are applied to the CUT (Circuit Under Test). ThisLow Power Linear Feedback Shift Register is used to generate the test patterns with less power consumption and delay. Normally LFSR is used to generate the test patterns but they consume high power. So the Low Power LFSR method is proposed to reduce the power consumption and delay.

The LFSR is a shift register whose input bit is a linear function of its previous state. Thus, an LFSR is a shift register whose input bit is operated by the XOR gate and after that the output is feedback to the input. The initial value of the LFSR is called the seed. This LFSR consumes high power. The Low Power LFSR is same as the normal LFSR but it uses gray code generator by which the initial seed is converted from binary code to gray code, after that rest of the patterns are generated using XOR operation. The switching activity in graycode is less compared to the binary code. So the Low Power LFSR consumes less power. Low Power LFSR generated patterns are in Gray code which has less switching activity compared to the binary code. As the switching activity is less, the glitches, noise, power consumption and delay are also less compared to the binary code. The Low Power LFSR block is shown in fig. 6.

357

**Binary to Gray Code Conversion:** It is a very simple process which includes various steps for the conversions. By observing below steps we can get a clear ideaabout this conversion.

Firstly the M.S.B. of the gray code should be exactly equal to the 1<sup>st</sup> bit of that binary number.

Next the  $2^{nd}$  bit of the code is exclusive-or of the  $1^{st}$  and  $2^{nd}$  bits of that binary number, i.e. the result should be 0 when both the bits are same and otherwise the result will be 1.

The 3<sup>rd</sup> bit of that gray code is equal to the exclusive-or of the 2<sup>nd</sup> and 3<sup>rd</sup> bit of that binary number. Like this the process of the Binary to gray code conversion continues. An example of Binary to Gray conversion is shown figure 7. Hence the equivalent gray code of that binary code is 01101. Now see the example where the M.S.B. bit of the binary is 0 so the M.S.B bit for gray code is also 0. Next, the XOR of the 1<sup>st</sup> and 2<sup>nd</sup> bit is 1 because both the bits are different. Again go to the next step where the XOR of 2<sup>nd</sup> and 3<sup>rd</sup> bit is again 1 because they are different. Next, XOR of 3<sup>rd</sup> and 4<sup>th</sup> bit is 0 because both the bits are equal. Finally the XOR of 4<sup>th</sup> and 5<sup>th</sup> bit is 1 because they are different. Like this the gray code conversion of 01001 is 01101. The block diagram of proposed methodology is shown in fig.8.

It is similar to fig. 1 except LPLFSR block. Each block rather than low power LFSR of above methodology are explained in section II. The advantage of Gray code compared to the binary code is it has only one bit which changes for each step that means it has less switching activity so that the power consumption is less. This will be useful in the circuits which are sensitive to the glitches or noise. This proposed methodology reduces power and delay up to 55% and 6% respectively.

# PROPOSED METHOD APPLIED TO HALF ADDER

This proposed method is implemented in Half Adder to verify its functionality. Firstly the Half Adder is designed using verilog code in Xilinx after that its functionality is checked using proposed method. In Low Power LFSR methodology the Half Adder is taken as CUT.

This Half Adder is instantiated into CUT. The CUT takes the output of LFSR as the input and generates the CUT output. If LFSR has 10 bits then first 5 MSB bits are taken as A input and second 5 LSB bits as B input. After getting CUT output as Sum and Carry they are combined as 10 bits which are inputs to the MISR. Next the output patterns MISR are generated. The TPA compares LFSR & MISR patterns and gives the output as interrupt. If the interrupt is generated as '0' then the CUT is faulty circuit, otherwise CUT is fault free circuit. The power consumption and delay both are reduced up to 58% and 8% respectively due to less switching activity in Gray codepatterns.

## PROPOSED METHOD APPLIED TO FIR FILTER

This proposed method is implemented in FIR Filter to verify its functionality. Firstly the Half Adder is designed using verilog code in Xilinx after that its functionality is checked using proposed method. In Low Power LFSR methodology the FIR Filter is taken as CUT. This FIR Filter is instantiated into CUT. The CUT takes the output of LFSR as the input and generates the CUT output. The coefficients for FIR filter are generated using Matlab software. In this paper Low pass filter is used whose order is 5, cut-off frequency is 0.5\*pi and uses blackman window to generate coefficients. The coefficients generated are 0.0000, 0.1083, 0.5000, 0.1081 and 0.0000. These coefficients are used to design Low Pass FIR filter. The power consumption & delay both are reduced due toless switching activity in Gray code patterns.

## **RESULTS AND DISCUSSION**

The proposed method is simulated and synthesized using verilog HDL on Xilinx 14.7. The simulation results are shown below and the synthesis reports are explained in figure 11-16. The synthesized report of proposed method for logic utilization summarized in Table I and figure 17. The comparison between existing and proposed methods is shown in Table II and figure 18. The comparison of Half Adder using existing and proposed methods is shown in Table II. The comparison of FIR filter using existing and proposed methods is shown in Table IV.

## CONCLUSION

In this paper a parallel test pattern methodology for shared memory multi-core environments is proposed using low power LFSR and it is implemented on Half Adder and FIR filter circuits to verify their functionality. This method enhances effective test patterns which are used for testing a device or circuit with less power consumption and delay. The proposed method is simulated and synthesized by using Xilinx 14.7. From the above values we can say that power consumption and delay are successfully reduced by 55% and 6% respectively. The comparison results shows that the proposed design with less power and delay can be good candidate and suitable for design automations with effective testing analysis.





## REFERENCES

- [1] Stavros Hadjitheophanous, Stelios N. Neophytou and Maria K. Michael, "Utilizing shared memory multi-cores to speed up the ATPG process," in Proc. of ETS, pp. 1-6, 2016.
- [2] K. Scheibler, D. Erb and B. Becker, "Improving test pattern generation in presence of unknown values beyond restricted symbolic logic," in Proc. of *ETS*, pp. 1-6, 2015.
- [3] S. Eggersglub, K. Schmitz, R. Krenz-Baath and R. Drechsler, "Optimization-based multiple target test generation for highly compacted test sets," in Proc. of *ETS*, pp. 1-6, 2014.
- [4] J. Wolf, L. Kaufman, R. Klenke, J. H. Aylor, and R. Waxman, "An analysis of fault partitioned parallel test generation," *IEEE Trans. on CAD*, vol. 15, no. 5, pp. 517–534, 1996.
- [5] K-Y. Liao, C-Y. Chang and JC-M Li "A parallel test pattern generation algorithm to meet multiple quality objectives," *IEEE Trans. on CAD*, vol.30, no. 11, pp. 1767-1772, 2011.
- [6] K-W. Yeh, J-L. Huang, H-J. Chao and L-T. Wang "A circular pipeline processing based deterministic parallel test pattern generator," in Proc. of *ITC*, pp. 1-8, 2013.
- [7] JC-Y. Ku, RH-M. Huang, LY-Z. Lin and CH-P. Wen, "Suppressing test inflation in shared-memory parallel Automatic Test Pattern Generation," in Proc. of *ASP-DAC*, pp. 664-669, 2014.
- [8] X. Cai and P. Wohl, "A distributed-multicore hybrid ATPG system," in Proc. of *ITC*, pp. 1-7, 2013.
- [9] X. Cai, P. Wohl and D. Martin "Fault sharing in a copy-on-write based ATPG system," in Proc. of *ITC*, pp. 1-8, 2014.
- [10] E. Schneider, S. Holst, M. A. Kochte, X. Wen, and H.-J. Wunderlich "GPU-accelerated small delay fault simulation," in Proc. of *DATE*, pp. 1174–1179, 2015.
- [11] K-Y. Liao, S-C. Hsu and JC-M. Li "GPU-based N-detect transition fault ATPG," in Proc. of *DAC*, pp. 28, 2013.
- [12] JC-Y. Ku, RH-M. Huang, LY-Z. Lin and CH-P. Wen, "Suppressing test inflation in shared-memory parallel Automatic Test Pattern Generation," in Proc. of *ASP-DAC*, pp. 664-669, 2014.