



IN APPLIED SCIENCE & ENGINEERING TECHNOLOGY

Volume: 7 Issue: IV Month of publication: April 2019

DOI: https://doi.org/10.22214/ijraset.2019.4449

www.ijraset.com

Call: 🕥 08813907089 🔰 E-mail ID: ijraset@gmail.com



# FPGA based High Speed CRC Encoder and Decoder

Shraddha Datir<sup>1</sup>, Dr. R. D. Ghongade<sup>2</sup>, Dr. C. J. Shelke<sup>3</sup> <sup>1</sup>ME Student, HOD, E&TC, PRPCEM, AMRAVATI, <sup>3</sup>(HOD, IT, PRPCET, AMRAVATI)

Abstract: Cyclic redundancy check (CRC) technique is one of the most efficient error detection method, which used to detect single and burst errors. CRC method adds redundancy bits to the original data. The reminder of division between original message and selected polynomial is represents redundancy bit. At the receiver side, the received data can be recognized as valid or not. Generally speaking, (CRCs) are used to detect errors from noise in digital data transmission. The technique is also sometimes applied to data storage devices, such as a disk drive. They also have been turned to verify the integrity of files in a system in order to prevent tampering and suggested as a possible algorithm for manipulation detection codes .A Cyclic Redundancy Check (CRC) is the remainder or residue of binary division of a potentially long message, by a CRC polynomial. Per packet operation is necessary for IP protocol, design a new efficient technique using FPGA in case of CRC .This approach is memory efficient and operate at high speed, since most of method currently employed based on look up table consume more time ,more space and also there will be a ROM which stores the look up table. This paper presents high speed CRC encoder and decoder using FIELD PROGRAMMABLE GATE ARRAY, to increase throughput pipeline method is used. Also reduced time required to transmission, which improved speed of communication.

Keywords: CRC Encoder, CRC Decoder, XOR, Encryption, Decryption, FPGA, serial CRC, parallel CRC, etc

#### I. INTRODUCTION

The need of a communication system depends on how it deals with the noise that may interfere with the data to be transmitted. Noise generally is encountered in the channel phase of a communication system which could be transmission lines, optical fibers, space, air etc. The coding theory is an important tool for encoding a given message, decoding and correcting the received message. Cyclic codes are one such tool that can be used both for encoding and decoding of the information represented in the form of binary numbers. Cyclic Codes were first studied in 1957 by Prange. After that they became an important part of the coding theory. The evolving world of telecommunications needs high reliability and improved speed in communications. Reliability in information storage and transmission is provided by coding techniques. Information is generally coded in bit streams and transmitted over the communication medium, channel. The communication media is tending to errors because of noise present in the analog part of the channel. Therefore errors have to be detected and corrected while decoding. CRC is an error-detecting code designed to detect sudden changes to computer data, and mostly used in digital networks and storage devices example is hard disk drives. Blocks of data entering these systems get a short check value attached, derived from the remainder of a polynomial division of their contents; on further regain the calculation is repeated, and appropriate action can be taken against presumed data corruption if the check values do not match. The CRC was invented by W. Wesley Peterson in 1961. CRC is an error detecting code that is widely used to detect corruption in blocks of data that have been transmitted or stored. The basic idea of CRC is binary division which is different from other error detection method which is based on parity check. The CRC depends on reminder of division at transmitter (CRC encoder) which it is added to original data and transmitted. There are two main point of CRC should be taken in the hardware design .The first thing is reminder and redundancy zero at encoder is equal to each other, and less than the divisor bits by one bits. Second one is that the received data is divided by the same divisor which used at transmitter. At the receiver (CRC) decoder the incoming information bits is divided by the generator polynomial, then the reminder of division is lead to knowing if data unit is correct or corrupted if the string of bits arrives without error, the CRC decoder checkers get a zero reminder, if it has been corrupted during transmission the division reminder is not equal to zero. Two main types of CRC's are Serial CRC generation and Parallel CRC generation Usually, the hardware implementation of CRC computations is based on the linear feedback shift registers (LFSRs), which handle the data in a serial way. Stills, the serial calculation of the CRC codes cannot give a high throughput. Hence, to over that defect we can use Parallel CRC generation.



International Journal for Research in Applied Science & Engineering Technology (IJRASET) ISSN: 2321-9653; IC Value: 45.98; SJ Impact Factor: 6.887 Volume 7 Issue IV, Apr 2019- Available at www.ijraset.com

- 1) Serial CRC Generation: Here CRC checking is done serially. The data input will be single (binary) and every clock pulse the data input will be one. There will some delay present between the consecutive data inputs and the output will be zero if the data will be encoded with same CRC value otherwise it shows non-zero value. The data is serially processed; the polynomial is XOR with the data input, that will be given to the D flip-flop (output same as the input) final CRC is generated as serially.
- 2) Parallel CRC Generation: Every modern communication protocol uses one or more error-detection algorithms. CRC is by far the most popular. CRC properties are interpreted by the generator polynomial length and coefficients. The protocol specification usually explains CRC in hex or polynomial notation. Parallel CRC calculation can significantly increases the throughput of CRC calculation.

Polynomial can be obtained by using method which state Each value is considered as a coefficient of a particular term which is an exponent of x. The rightmost bit is considered as the 0<sup>th</sup>, next is one another is  $2^{nd}$  and so on For Example 1011 would be a mean polynomial of [(1\*x0)+(1\*x1)+(0\*x2)+(1\*x3)]=x3+x+1.

Consider n bit message being transmitted, and k is a number of data bits, According to CRC theory a particular polynomial has to be chosen that is called as divisor polynomial. The message is treated as dividend and divisor polynomial used to divide message, By using polynomial reminder is generated modulo2 method is used for division, as shown in fig2



Fig1- Generation of generator polynomial.

As shown in above fig the data bits appended with reminder is received as the data-word. The data-word is divided by same generator polynomial to generate another polynomial. If polynomial generate 0 then received bit is error free otherwise it contain error. The complete process is partitioned in two parts 'Encoder' and 'Decoder' all process which related to transmission of Data-word is carried out in encoder and checking operation is related with decoder. For this reason CRC encoder is known as CRC generator, and CRC decoder is known as CRC checker.

#### II. CRC DECODER CIRCUIT DESIGN

In decoder section we are going to describe error correcting capability of circuit, at output that is decoder side data which is transmitted in encoder section is collected as output of decoder, which having capability of error detection.

#### A. Ease of Use

- 1) CRC Encoder: To transmit data securely on communication channel with high speed design using FPGA. The encoder generates an n-bit check sequence number from the given input k- bit information first step of encoder is dividing number of bits by generator, If there is zero reminder then no error detected, and if nonzero reminder then error detected, CRC generally stop process when error detected. But in our algorithm we continue division up to we get error trapped, or continue up to no error message not receive.
- 2) CRC Decoder: To receive transmit data at receiver side without any error decoder is used as a receiver. Decoder process is little bit similar to encoder, where encoder and decoder both depend on division logic. First step of decoder also same as encoder that is it divide received checksum by generator number. If reminder output is zero then error trapped in parity bits, In CRC we continue our process up to we don't get error in FCS bits or received message there is no error.

To increase speed and throughput we used pipeline method. To implement high speed CRC encoder and decoder pipeline method is used which reduce time to complete process. The basic idea of pipeline is divide a whole process in sequence of steps. Rather than



### International Journal for Research in Applied Science & Engineering Technology (IJRASET) ISSN: 2321-9653; IC Value: 45.98; SJ Impact Factor: 6.887

Volume 7 Issue IV, Apr 2019- Available at www.ijraset.com

process each steps sequentially its divided in number of steps and each step get executed when previous one has to be completed. That means if seven number of steps are in one process then at initial stage step one will started before going first stage to exit condition second will be at its initial stage, and same when second steps complete its 50% of process then third steps also came in initial condition and so on up to seven stage . That means it automatically reduce time required to complete process which increase throughout and speed of algorithm.

For analysis Quartus2 software is used and for simulation Modelim is used, and for programming VHDL language is used. For analysis following steps are used .The very first step is VHDL coding to implement encoder and decoder based on FPGA programming which required to build a circuit is done in VHDL language. Another that is second step is simulation, Modelsim is used or simulation process, simulation s done to check working behavior and verification. Third step is synthesis using CAD tools by using Xillings. Which used to convert VHDL code into RTL schematic, next step is Translate and Map .Next one is place and route. Which translate code resources to FPGA resources .Place and route decide if interaction is establish if mapping is possible to FPGA .Then in next step generate programming file. And last one is download bit stream to FPGA.



Fig 2: Flow chart design process on FPGA

1) CRC Encoder And Decoder Circuit Design: In this section we are going to describe hardware design for CRC encoder and decoder .with error correction capability.

#### B. Abbreviations and Acronyms

Previous research is contained only serial and parallel implementation. which was depend n look up tables and division method of generator polynomial. But speed of algorithm was not too much high. To improve speed we used pipeline method which added more speed and accuracy. Also there were limits of error detection and correction capability of encoder which was updated up to 64 bits, but this algorithm is suitable for infinite number of bits.

Fig.4. shows logical view of decoder and output of decoder is shown in fig3. Input bits of encoder 011111000.



## International Journal for Research in Applied Science & Engineering Technology (IJRASET)

ISSN: 2321-9653; IC Value: 45.98; SJ Impact Factor: 6.887 Volume 7 Issue IV, Apr 2019- Available at www.ijraset.com



Fig3: Output of CRC Decoder

📌 🗄 💡 0 8 0 4 0 8 0 4 0



Fig4: Logical view of encoder

#### C. Authors and Affiliations

T. V. Ramabadran and S. S. Gaitonde. [1] presented "A tutorial on CRC computations" presented in the paper. presented in the paper. The code has been verified for all possible lengths of message polynomial and generator polynomial calculation of remainder or redundant bits at the transmitter and checking the errors at the receiver is presented in the paper. The code has been verified for all possible lengths of message polynomial and generator polynomial. The CRC-4 to CRC-32 is successfully implemented.

Shukla S. nd Bergmann N. W., [2] presented "Single bit error correction implementation in CRC-16 on FPGA . presented an efficient algorithm for parallel computation of the CRC in data transmission. Using CRC style checksums (cyclic redundancy check) is a simple and powerful method for detecting transmission error in data communication system. It is well suited for high speed serial transmission equipment, because it can be implemented on chip with a shift register and same XOR gates at nearly no cost. However, for some purposes it is necessary to implement a CRC calculation of the serial transmission chip, e.g., in additional error detection isrequired. The hardware implementation has been used to improve the computation speed.

W.W.Peterson and D.T.Brown, G.Albertengo and R.Sisto, [3] presented "Parallel CRC Generation". Parallel implementation is adopted which does not takes much time. CRC gives trade of between flexibility, performance and cost Generation for has been taken further than those enabled by tradition heterogeneous architectures based on microprocessor, DSP. CRC is very useful for error detection during data transmission. Having a look on the "CRC error detection method", we can prefer that the method identifies the error correctly. Thus the "Parallel CRC generation and checking" is more efficient than the "Serial CRC generation", it gives us the efficient.



International Journal for Research in Applied Science & Engineering Technology (IJRASET)

ISSN: 2321-9653; IC Value: 45.98; SJ Impact Factor: 6.887 Volume 7 Issue IV, Apr 2019- Available at www.ijraset.com

Castagnoli, G.: Brauer, s; Harrmnn,[4] presented a method "Optimization of cyclic Redundancy- check Codes with 24 and 32 parity Bits". his brief lays out FPGA implementation of encoder and decoder for Golay codes. Golay codes are error detection and correction codes and it corrects errors in the receiving end in the received data to reduce retransmission events. Encoding algorithm for both the binary Golay code (G23) and extended binary Golay code (G24) implementation based on cyclic redundancy check encoding method. Decoding architecture for G24 (24, 12, 8) based on an error detection and correction method and here correction up to four errors is possible in the data .Synthesis and Simulation results obtained in Xilinx.

Sprachmann m [5] presented a technique of "Automatic generation of parallel CRC circuits," Design and Test of Computers, which states that a Technique to model the error detection circuitry of CAN protocol in VHDL is described. The referred paper describes error circuitry in case of 'no error' our contribution – after reviewing the paper we designed error controlling circuitry for CAN bus in case of error.

#### **III.CONCLUSION**

The high speed design of CRC encoder and decoder algorithm implemented successfully time result without pipeline is shown in fig 5. Time result with pipeline for Xillings sparten 3E starter board is shown in Fig 6, which proves that with pipeline algorithm become faster, which achieved high speed and greater throughput.

```
Timing Summary:

Speed Grade: -4

Minimum period: No path found

Minimum input arrival time before clock: No path found

Maximum output required time after clock: No path found

Maximum combinational path delay: 15.341ns
```

Fig5: Time analysis report without pipeline.

| Timing Summary:<br>                                                                                                                                                                                                 |
|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Minimum period: 5.948ns (Maximum Frequency: 168.124MHz)<br>Minimum input arrival time before clock: 5.485ns<br>Maximum output required time after clock: 4.620ns<br>Maximum combinational path delay: No path found |
| Timing Detail:                                                                                                                                                                                                      |
| All values displayed in nanoseconds (ns)                                                                                                                                                                            |

Fig6: Time analysis report with pipeline.

From above mentioned report throughput and frequency can be calculated. Frequency and throughput of both methods that is with pipeline and without pipeline are shown in below table.

- A. Equations
- *1*) To calculate Frequency F = 1/T (Where T= time)
- 2) Throughput= (Number of bits\*maximum Frequency) ÷ Number of Clock Cycle

| specification                   | Without pipeline | With pipeline |
|---------------------------------|------------------|---------------|
| Time                            | 15.34ns          | 5.48ns        |
| Frequency                       | 66Mhz            | 182Mhz        |
| Power                           | 0.081w           | 0.81w         |
| Throughput (for 24 clock cycle) | 22 Mbps          | 60.66Mbps     |

#### **IV.ACKNOWLEDGMENT**

It is our utmost duty and desire to express acknowledgement to the various torchbearers, who have rendered valuable guidance during the preparation of our project. First of all, we extend our deepest gratitude to our revered HOD. Dr. Mr. R.D. Ghongade (HOD of electronics and Telecommunication Department) without whose support; our project could not have been transformed into present form. And provide immense support and guidance. We are beholden for guiding us at every step in the project. His/her has most honestly guided us throughout; never leaving us unanswered for any of our doubts. It was his/her constant persuasion, encouragement, inspiration and able guidance that helped us in completing our project successfully.





[1]

# ISSN: 2321-9653; IC Value: 45.98; SJ Impact Factor: 6.887

Volume 7 Issue IV, Apr 2019- Available at www.ijraset.com

#### REFERENCES

- T. V. Ramabadran and S. S. Gaitonde. "A tutorial on CRC computations". IEEE Micro, Vol. 8, No. 4, 1988, pp. 62-75.
- [2] Shukla S. nd Bergmann N. W., "Single bit error correction implementation in CRC-16 on FPGA"1n: IEEE International conference on Field programmable technology. Brisbane ,Australia 2004
- [3] W.W.Peterson and D.T.Brown, "Cyclic code for Error detection", Proc.IRE.jan1961.[3]G.Albertengo and R.Sisto, "Parallel CRCGeneration", IEEE Micro, Oct. 1990
- [4] R.Lee,, cyclic code Redundency,"Digital Design July 1977.
- [5] A.Perez, "Byte-wise CRC Calculations", IEEE Micro, June 1983.
- [6] A.S. Tanenbaum, "Computer Networks", Prentice Hall,1981.
- [7] T.V. Rambadran and S. S. Gaitonde, 'A Tutorial onCRC Computations', IEEE Micro, Aug. 1988.
- [8] K.V. GANESH, D. SRI HARI, and M. HEMA," Design and synthesis of Field Programmable CRC Circuit Architecture", International General of Engineering Research and applications, ISSSN22489622, volume1, Issue, Nov-dec2011.
- [9] Programmable Gate Arrays, ACM press New York, NY, USA, 1999
- [10] G.Campobello M. Russo, and G.Patane, "Parallel CRC Realization", IEEE trans comput., vol52, no10.
- [11] M.J.Smith, "Application specific Integrated Circuits", Addision- Wesley Longman, jan 1988
- [12] C.Borrelli,"IEEE 802.3 Cyclic redundancy Check", application note: virtex -II Family,XAPP209,Xilinx,Inc,March23,2001
- [13] Castagnoli, G.: Brauer,s;Harrmnn,M.(june1993) "Optimization of cyclic Redundancy- check Codes with 24 and 32 parity Bits". IEEE Transactions on communication 41(6):883.doi:10.1109/26.231911.
- [14] Sprachmann m, "Automatic generation of parallel CRC circuits," Design and Test of Computers, IEEE May 2001.











45.98



IMPACT FACTOR: 7.129







# INTERNATIONAL JOURNAL FOR RESEARCH

IN APPLIED SCIENCE & ENGINEERING TECHNOLOGY

Call : 08813907089 🕓 (24\*7 Support on Whatsapp)