

International Journal of Advanced Research in Computer and Communication Engineering Vol. 4, Issue 4, April 2015

# Design and Implementation of SPI with Built-In-Self-Test Capability over SPARTAN 2

G.Sai Ram<sup>1</sup>, G.Ravi Chandra<sup>2</sup>, K.mohan rao<sup>3</sup>, G.prameela<sup>4</sup>, B.hemanth Nag<sup>5</sup>

ECE, Lendi Institute of Engineering and Technology, India<sup>1,2,3,4,5</sup>

**Abstract:** The Serial-Peripheral Interface (SPI) protocol is a very essential protocol for connecting between the peripherial devices and microprocessors. As the number of devices in the circuit increased as the advancement of IC technology. So, in order to lessen the product failure self-testability in hardware is demanded a lot in recent times. For the testing of devies we can use self-testability which is called as Built-in-self-test (BIST). BIST is an effective solution to reduce the huge circuit testing cost. This paper represents designing and implementation of SPI protocol with BIST capability over FPGA. An EEPROM and FPGA Spartan 2 are used for the communication testing where the FPGA is master and EEPROM is a Slave. The need of programming for setting up a network with two devices is no longer needed in this proposed system. To accomplish compact, stable and reliable data transmission, the SPI is designed with VHDL language and synthesized on Spartan 2 FPGA.

Keywords: Serial-Peripheral Interface; Embedded built-in-self-test architecture; Verilog HDL; FPGA

## I. INTRODUCTION

SERIAL PHERIPERAL INTERFACE BUS:

The spi bus used n a short distance communication, primarly in embedded systems.spi bus is a synchronous serial communication. This interface was developed by motorola. It is used in sensors,liquid crystal displays, secure digital cards.



SPI devices communicate in full duplex mode using a master slave architecture with a single master. The master device originates the frame for reading and writing. Multiple slave devices are supported through selection with individual slave select (SS) lines.

Sometimes SPI is called a four-wire serial bus, contrasting with three-two and one-wire serial buses. The SPI may be accurately described as a synchronous serial interface,[1] but it is different from the synchoronous serial interface (SSI) protocol, which is also a four-wire synchronous serial communication protocol, but employs differiential signalling and provides only a single simplex communication channel.

II. BUILT-IN-SELF-TEST-CAPABILITY[BIST]

A Built in-self-test or built in test is a mechanism to permits to test itself engineers meeets the basic requirements

- high reliability
- lower repair cycletimes
- or constraints such as:

- limited technician accessibility
- cost of testing during manufacture

The main purpose[citation needed] of BIST is to reduce the complexity, and thereby decrease the cost and reduce reliance upon external (pattern-programmed) test equipment. BIST reduces cost in two ways:

- 1) reduces test-cycle duration
- 2) reduces the complexity of the test/probe setup, by reducing the number of I/O signals that must be driven/examined under tester control.



Bist structure

 Random Pattern Generators (RPG): Random Pattern Generator (RPG) generates random patterns which can beused for the verification of device like SPI. The RPG is a part of the BIST in the verification of the circuits. Many methods have been proposed for the BIST equipment design [6], [9]. To produce bytes to test the circuit the method of a random pattern generator (RPG) is used.

# IJARCCE

International Journal of Advanced Research in Computer and Communication Engineering Vol. 4, Issue 4, April 2015

 Comparator: This is the device which is used to compare two signals i.e received and transmitted bit pattern and then it gives the value of errors.

### B. Spi Structure:



To begin communication, the bus master configures the clock, using a frequency supported by the slave device, typically up to a few MHz. The master then selects the slave device with a logic level 0 on the select line. If a waiting period is required, such as for analog-to-digital conversion, the master must wait for at least that period of time before issuing clock cycles.

During each SPI clock cycle, a full duplex data transmission occurs. The master sends a bit on the MOSI line and the slave reads it, while the slave sends a bit on the MISO line and the master reads it. This sequence is maintained even when only one-directional data transfer is intended.

Every slave on the bus that has not been activated using its chip select line must disregard the input clock and MOSI signals, and must not drive MISO. The master must select only one slave at a time.



A. Circuit Schemantic



pin diagram of spi



top level schemantics of spi with bist module

| Pin              | In/out | description                                    |
|------------------|--------|------------------------------------------------|
| Clk              | In     | Clock generator                                |
| reset_n          | In     | Control bit for<br>normal& <u>bist</u><br>mode |
| Go               | In     | Control bit of the spi                         |
| <u>in_data</u>   | In     | Input data byte of<br>the <u>spi</u>           |
| in_control       | In     | Input control byte<br>of the <u>spi</u>        |
| in_address       | In     | Input status<br>address of the <u>spi</u>      |
| <u>out_data</u>  | out    | Output data byte<br>of the master              |
| sd_counter       | out    | Clock pulse<br>counter for <u>bist</u><br>mode |
| spi_sclk         | out    | Output pin for spi<br>clock                    |
| <u>spi_sdata</u> | out    | Output data bus                                |
| <u>spi_sdi</u>   | in     | Input data bus                                 |

Main spi pin description

#### **B.Simulation Results:**

The timing diagrams are achieved from Testbencher (VeriLogger Pro 6.5). The design is tested in the Xilinx FPGA where it also gave the correct output. In the timing diagram, the 8 bits of outputs are converted here into 2-digits Hexadecimal numbers.

IJARCCE

International Journal of Advanced Research in Computer and Communication Engineering Vol. 4, Issue 4, April 2015

1)Simulation results for BIST module: a)LFSR 8BIT random pattern generator:



Fig3(a): Return loss for Desig

b)comparator module:

| omparator_test.CLK1                  |             |        |
|--------------------------------------|-------------|--------|
| test.in_control1[7:0]                |             | 1      |
| test.in_address1[7:0]                |             | 1      |
| tor_test.in_data1[7:0]               |             | 1      |
| r_test.o <mark>ut_</mark> data1[7:0] | "bx ) 10101 | 100101 |
| test.bit_correct1[0:2]               | 0 ( 5 )     | 0      |
| pr_test.bit_error1[0:2]              | 0)          | 1      |

# 2) Simulation Results NORMAL Mode

| Input type     | Binary   | Hexadecimal |
|----------------|----------|-------------|
| Control byte   | 00010100 | 14          |
| Status address | 00000000 | 00          |
| Data           | 10101010 | AA          |

0.000ps -35.00ns 0ns 10ns 20ns 30ns 40ns 150ns 160ns test to out data[7:0]





# C. FPGA Implementation:

Any logical function can be implemented by the Field Programmable Gate Array (FPGA) and it should also be noted that FPGA design is more cost-effective than that of ASIC Design. They have lots of advantages over microcontrollers, such as greater speed, number of I/O ports and performance.



|                                  | Main SPI Module                                    |                 | SPI                                                | SPI with BIST   |  |
|----------------------------------|----------------------------------------------------|-----------------|----------------------------------------------------|-----------------|--|
| Name                             | Used Blocks                                        | Percentages (%) | Used<br>Blocks                                     | Percentages (%) |  |
| Number of<br>Slices              | 18 out of 192                                      | 9               | 26 out of<br>192                                   | 13              |  |
| Number of<br>Slice Flip<br>Flops | 19 out of 384<br>(FDRE:7<br>FDSE: 12)              | 4               | 34 out of<br>384<br>(FDR: 3<br>FDRE:28<br>FDSE :3) | 8               |  |
| Number of<br>4 input<br>LUTs     | 33 out of 384                                      | 8               | 20 out of<br>384                                   | 5               |  |
| Number of<br>bonded<br>IOBs      | 24 out of 90<br>(IBUF :7<br>OBUF : 16<br>OBUFT: 1) | 26              | 18 out of 90<br>(IBUF : 4<br>OBUF : 14)            | 20              |  |
| Number of<br>GCLKs               | 1 out of 4                                         | 25              | 1 out of 4                                         | 25              |  |

Table VI. TIMING SUMMARY FOR MAIN SPI MODULE



International Journal of Advanced Research in Computer and Communication Engineering Vol. 4, Issue 4, April 2015

| Parameters                                    | Main SPI Module | SPI with BIST |
|-----------------------------------------------|-----------------|---------------|
|                                               | Seconds         | Seconds       |
| Minimum period                                | 7.491ns         | 7.782ns       |
| Minimum input arrival<br>time<br>before clock | 6.981ns         | 4.722ns       |
| Maximum output required<br>time after clock   | 7.913ns         | 6.959ns       |
| Maximum delay                                 | 7.491ns         | 7.782ns       |

#### V. CONCLUSION

In this paper, an FPGA based implementation of SPI with BIST capability is presented. Here all the modules are designed and simulated with Verilog HDL. Then the system is downloaded in the Xilinx Spartan-2 FPGA (XC2S150). This SPI is much more flexible, speedy, low cost, and stable with respect to conventional one. This SPI control bus architecture can enable the industrial fabrication of chip in a way where only a pressing of one switch can test itself. So that, it would save valuable time and cost of testing circuits significantly.

#### REFERENCES

- F. Leens, "An introduction to I<sup>2</sup>C and SPI protocols," IEEE Instrumentation & Measurement Magazine, vol.12, no.1, pp.8-13, February 2009.
- [2] A. K. Oudjida, M. L. Berrandjia, R. Tiar, A. Liacha, K. Tahraoui, "FPGA implementation of I<sup>2</sup>C & SPI protocols: A comparative study," in Proc. 16th IEEE International Conference on Electronics, Circuits, and Systems, pp.507- 510, Dec. 2009.
- [3] N.Q. B. M. Noor and A. Saparon, "FPGA implementation of high speed serial peripheral interface for motion controller," in Proc. 2012 IEEE Symposium on Industrial Electronics and Applications (ISIEA), pp.78-83, Sept. 2012.
- [4] A.N. Gaidhane and M.P. Khorgade, "FPGA Implementation of Serial Peripheral Interface of FlexRay Controller," in Proc. 13th International Conference on Computer Modelling and Simulation (UKSim), pp.128-132, Apr. 2011.
- [5] M. Bushnell and V.D. Agarwal, Essentials of electronic testing for digital, memory and mixed-signal VLSI circuits, Kluwer Academic Publishers, 2000.
- [6] S. Jamuna and V.K. Agrawal, "Implementation of BIST structure using VHDL for VLSI circuits," International Journal of Engineering Science and Technology, vol. 3, no. 6, pp. 5041-5048, June 2011.
- [7] V.K. Agrawal, C.R. Kime, K.K., Saluja, "A tutorial on BIST, part 1: Principles," IEEE Design & Test of Computers, vol. 10, No.1, pp.73-83, March 1993.
- [8] J. Bhasker, Verilog<sup>®</sup> HDL synthesis: a practical primer, Star Galaxy Publishing, 1998.
- [9] M.Y.I. Idris and M. Yaacob, "A VHDL implementation of BIST technique in UART design," in Proc. Conference on Convergent Technologies for the Asia-Pacific Region (TENCON), pp.1450-1454, Oct. 2003.
- [10] S. Saha, M. A. Rahman, A. Thakur, "Design and Implementation of a BIST Embedded High Speed RS-422 Utilized UART over FPGA," in Proc. 2013 Fourth International Conference on Computing, Communication and Networking Technologies (ICCCNT), pp. 1-5, Jul. 2013.
- [11] S. Saha, M. A. Rahman, A. Thakur, "Design and Implementation of a BIST Embedded Inter-Integrated Circuit Bus Protocol over FPGA," in Proc. 2013 International Conference on Electrical Information and Communication Technology (EICT), pp. 1-5, Feb. 2014.