# Implementation of Rijindael's Encryption and Decryption Algorithm using FPGA 

Vishakha.M.Gajbhiye ${ }^{1}$, V.G Puranik ${ }^{2}$<br>${ }^{12}$ Department of Electronics\& Telecommunication Engineering, Bhivarabai Sawant Institute of Technology \&Research, pune, India


#### Abstract

Encryption is employed in communications systems to safeguard data being transmitted over a channel from being intercepted and skim by unauthorised parties. This protection is achieved by changing the initial message ( plain text) into associate degree encoded kind (cipher text) that seems to be a random stream of symbol 2 architectures and VLSI implementations of the AES Proposal, Rijndael, are bestowed . These various architectures are operated each for encryption and decryption method. They cut back the specified hardware resources and come through high-speed performance. Their style philosophy is totally totally different. the primary uses feedback logic and reaches a output price adequate to $259 \mathrm{Mbit} / \mathrm{sec}$. It performs expeditiously in applications with low lined space resources. The second design is optimized for high-speed performance exploitation pipelined technique. Its output will reach three. $65 \mathrm{Gbit} / \mathrm{sec}$. The ensuing VLSI circuits come through information rates considerably high, supporting each operation method (encryption/decryption) of Rijndael algorithmic program. they will be applied to on-line encryption/ decryption wants of high speed networking protocols like Asynchronous Transfer Mode (ATM) or Fiber Distributed information Interface (FDDI).


Keywords -- Rijindael's algorithm, AES, DES, FPGA, matlab.

## I. INTRODUCTION

In this article, we have a tendency to square measure attending to concentrate on the Rijndael algorithmic program for the AES. This algorithmic program was submitted by two Belgians: Dr. Vincent Rijmen (pronounced Rye'-mun), a postdoctoral researcher within the EE Department (ESAT) of Katholieke Universiteit Leuven and Dr. JoanDaemen (pronounced Yo'-ahn Dah'- mun) of nucleon World International. A combination of things like security, performance, efficiency, ease of implementation and adaptability contributed to the choice of this algorithmic program because the AES. Specifically, Rijndael seems to perform systematically well in each hardware and software system platforms under a good vary of environments. These embrace economical VLSI and firmware implementations within the hardware and easy writing the code for the algorithmic program in numerous programming languages. This algorithmic program has wonderful key setup time and smart key gracefulness. But, a lot
of significantly, while not sacrificing performance, it conjointly needs less memory for implementation. This fact makes it well matched for restricted-space environments. moreover, the structure of this algorithmic program seems to possess good potential for taking advantage of instruction-level correspondence. The AES is predicted to switch Triple-DES eventually due to its strong cryptologic options. The AES specifies 3 key sizes: 128, 192 and 256 bits. this suggests that, in decimal terms, there square measure about three. $4 \times 1038$ doable 128 -bit keys, $6.2 \times 1057$ possible 192-bit keys, and $1.1 \times$ 1077possible 256-bit keys. compared, DES keys square measure 56 -bits long. This bitlength means there square measure about $7.2 \times 1016$ doable DES keys.Thus, there square measure on the order of 1021times a lot of AES 128-bit keys than DES 56-bit keys. forward that one might build a machine that would recover a DES key in an exceedingly second (i.e. strive $2^{\wedge} 55$ keys per second), itl'd then take that machine about 149 thousand billion (149 trillion) years to crack a 128 -bit AES key. to place that into perspective, the universe is believed to be less than twenty billion years recent. With AES supporting considerably larger key sizes than what DES supports, federal agency believes that this algorithmic program has the potential of remaining secure well on the far side consecutive few decades.

## II. AES ENCRYPTION

The AES algorithm is a symmetric block cipher that can encrypt and decrypt the information. Encryption converts data to an unreadable form which is called as cipher-text. Decryption of the cipher-text converts the data back into its original form, which is called as the plain-text [2]

A variable block length of 128,192 and 256 bits is supported by Rijandael's AES. The following are four different round transformations: ByteSub, ShiftRow, MixColumn and AddRoundkey. The first and last rounds differ from other rounds as there is an additional AddRoundKey transformation at the beginning of the first round and no Mix Coulmns transformation is present in the last round.

## A. Sub Bytes Transformation

The Sub Bytes transformation is a non-linear byte substitution method and operates on each of the state bytes independently. The Sub Bytes transformation is done using a pre calculated substitution table called as S-box. That S-box table is
having 256 numbers (from 0 to 255) and their corresponding resulting values. In this design, we are using a look-up table as shown in Table I. Using Sbox, each byte xy (in hexadecimal) in the matrix is substituted with another byte by looking for the entry in the $x$-row and the $y$-column of the table. This is a more efficient method than directly implements the multiplicative inverse operation followed by affine transformation of the polynomial. This approach is used to avoid complexity of hardware implementation. This process has the advantage of performing the S-box computation in a single clock cycle and thus latency is reduced.


Figure 1. AES encryption structure

1


## B. Shiftrows Transformation

In Shift Rows transformation method, the rows of the state matrix are cyclically left shifted over different offsets. Row 0 is not shifted by any value; row 1 is shifted by one byte to the left; row 2 is shifted by two bytes to the left and row 3 is shifted by three bytes to the left as shown in following figure.


Figure 3. Shift row transformation process

## C. Mixcolumns Transformation

In MixColumns transformation process, the columns of the state are considered as polynomials over GF (28) and multiplied by modulo $\mathrm{x} 4+1$ with a fixed polynomial given by $\mathrm{c}(\mathrm{x})$,

$$
c(x)=\{03\} \times 3+\{01\} \times 2+\{01\} x+\{02\}
$$



Figure 4. Mix columnstransformation

## D. Addround Key Operation

The XOR operation is performed between the state and the round key that it is generated from the main key by the Key Generation method. The matrix of keys is represented by w columns. Add Round Key is used both in the encryption and decryption algorithms. The XOR operation is conducted on byte basis, where the new output byte $S^{\prime} x, y$ is given by $S x, y \square \square K x, y$.

## III. AES DECRYPTION

Decryption method is a reverse of encryption method that is inverse round transformations for determining the initial plaintext of an encrypted cipher-text in reverse order. The round transformation of decryption uses the subsequent four transformations:

Add round Key, Inv mix Columns, Inv Shift Rows, and Inv Sub Bytes.

## A. Add Round Key Operation

Add Round Key is its own inverse function as the XOR function is having its own inverse value. The round keys are selected in reverse order [5]. The description of the other transformations is given below.

## B. Inv Mixcolumn Transformation

In Inv MixColumn transformation process, the columns of the state are considered as polynomials over GF (28) and multiplied by modulo $\mathrm{x} 4+1$ with a fixed polynomial given by $\mathrm{c}(\mathrm{x})^{-1}$,
$c(x)^{-1}=\{0 b\} \times 3+\{0 d\} \times 2+\{09\} x+\{0 e\}$.

## C. INV Shift Rows Transformation

Inv Shift Rows exactly operates as Shift Rows, only in the opposite direction. The first row is not shifted by any value, while the second, third and fourth rows are shifted right by one, two and three bytes respectively.

## D. INV SUB Bytes Transformation

The Inv Sub Bytes transformation is done using a once-pre calculated substitution table called as Inv S-box able. Inv S-box table is having 256
numbers (from 0 to 255) and their corresponding values. Inv S-box is presented in following Table II.


## IV. FIGURES AND TABLES

 MAIN RTL

## V. CONCLUSION

Thus with the help of matlab and FPGA Rijindael's encryption and decryption algorithm will be implemented. The performance of the system will be calculated by using performance counter. We can also increase the performance of the system by introducing the custom hardware. The combined design using hardware and software is known as Codesign. As the design can also reduces number of gate required by using Xilinx,

## ACKNOWLEDGMENT

I would like to express my gratitude \& sincere thanks to my guide Prof.v.g puranik , of Electronics and Telecommunication Engineering, for his constant motivation and support during the course of my work.

We would like to thank to Dr. Y.S.Angal,
HOD, Electronics and Telecommunication

Engineering, Pune for his support and providing us the facilities.

## RESULT

AES Text encryption and decryption Result using 128 bits key.

Input message: hi how are you.
Encrypted message: $£ 5 \mathrm{Y}$ î̈•-_p» $\varnothing$ «1h $=\mid$ Q» ${ }^{[P C ̧ c} \square_{k}\left[\mathrm{Ní} \emptyset_{i} \bigcirc \mathrm{OU}\right.$

Decrypted message: hi how are you.

## REFERENCES

[1] Dr. Tariq Jamil, "The Rijindael Algorithm" Department of Electrical and Computer Engineering, Sultan Qaboos University (Oman). 0278-6648/04 2004 IEEE
[2] Shunwen Xiao, Yajun Chen, PengLuo, "The Optimized Design of Rijindael Algorithm Based on SOPC", College of Physics and Electronic information China West Normal University, Nanchong, China, 978-0-7695-3922-5/09 2009 IEEE
[3] Andre Luis PescoAlcalde, MarcioSilveiraOrtmann, Samir Ahmad Mussa, "NIOS II Processor Implemented in FPGA: An Application on Control of a PFC Converter" Federal University of Santa Catarina (UFSC), Department of Electrical Engineering (EEL), Power Electronics Institute (INEP), 978-1-4244-1668-4/08 2008, IEEE
[4] Meghana A. Hasamnis, Shri Ramdeobaba college of Engg and Management, S. S. Limaye, Jhulelal Institite og Technology, "Custome Hardware Interface using NIOS II Processor through GPIO", department of Electronics Engg., Nagpur, India, 978-1-4577-2119-9/12/ 2011 IEEE
[5] Madhav M. Deshpande, Meghana A. Hasamnis, "Design of Encryption System using NIOS II Processor", Electronics Department, R.C.O.E.M, Nagpur University, International Journal of Computer Applications, Volume 68- No. 21, April 2013
[6] N. Sklavos and O. Koufopavlou, Member IEEE, "Architectures and VLSI Implementations of the AESProposal Rijindael", Electrical and Computer Engineering Department, University of Patras, Greece, 0018-9340/02 2002 IEEE
[7] R. Sever, N. Ismailoglu, M. Askar, Y.C. Tekmen, "A High Speed ASIC Implementation of the Rijindael's Algorithm," 2004 IEEE International Symposium on Circuits and Systems, May 2004, Vancouver, Canada
[8] Refik Sever, A. NeslinIsmailoglu, Yusuf C. Tekmen, Murat Askar, BurakOkcan, "A High Speed FPGA Implementation of the Rijindael Algorithm", Ankara, Turkey, Proceedings of the EUROMICRO Systems on Digital System Design (DSD’04) 0-7695-2203-3/04 IEEE

