

# [Periodic waveform used to synchronise the operation engineering essay](https://assignbuster.com/periodic-waveform-used-to-synchronise-the-operation-engineering-essay/)

[Engineering](https://assignbuster.com/essay-subjects/engineering/)

The main task of this coursework is to design hardware in VHDL to execute both encryption and decryption of data using Tiny Encryption Algorithm. Altera Quartus 12. 1 is used as main tool for system development and CodeLight is used as an environment to run the C code to check the correctness of the system. Designed implementation of the system is supposed to be able to carry out 16 rounds of encryption and decryption for word lengths 4, 8 and 16 bits. Modular design approach is used to implement the system, that is, components that are used in complete system are built and tested before further use.

## 2. Introduction

## 2. 1 Coursework Aims

Design TEA hardware in VHDLDevelop VHDL skills

## 2. 2 Coursework Objectives

Produce components that are used in final system implementationProduce the design that is capable of carrying a single round of encryption and decryption for word lengths 4, 8 and 16 bits. Produce a design that is capable of carrying 16 rounds of encryption and decryption.

## 3. System Implementation

## 3. 1 System Architecture

The system has 6 inputs and one output. The detailed description of all of them is summarised in Table 1 below. NoNameType(Input/Output)Bus width (bits)Description1clkInput1Periodic waveform used to synchronise the operation of the system. 2RoundsInput6Determines a number of rounds of encryption (used when a single component does multiple rounds)3Data\_inInput64Either encrypted or decrypted data input port. If the word length is less than 64 bits, the appropriate number of MSBs are not used. 4keyInput128The 128 bit key is split into 4 32 bit long keys that are used for encryption and decryption. k0-[31.. 0], k1-[63.. 32], k2-[95.. 64], k3-[127.. 96]. 5word\_lengthInput2Defines the word length of the data:" 00"-4 bit," 01"- 8 bit, " 10" - 16 bit, " 11"- 64 bit. 6encrypt\_decryptInput2Defines whether the encryption or decryption is executed: '0' for decryption and '1' for encryption. 7Data\_outOutput64Either encrypted or decrypted data output port.

## Table 1: Input/Output Description

Two ways of implementing TEA hardware are presented and compared. First implementation is using one TEA component to perform one or more rounds of encryption. This is achieved by feeding the output of the system back to input port and performing multiple rounds of encryption or decryption. This approach does not provide an excellent data throughput, that is, only one set of data can be either encrypted or decrypted at a time. However, the overall complexity is reduced greatly. The other implementation includes 16 separate TEA components (each performing one round of encryption and decryption) and 16 registers between them. This approach takes more time to get first result after 16 rounds, compared to a single component doing 16 rounds. However using this approach multiple words of data can be encrypted and decrypted simultaneously. TEA hardware consists of the following components: xor\_3 executes xor logical operation on 3 inputs. splitter splits the input data in halves depending on the word length for example if the input is 16 bit long, then the splitter splits the data into two 8 bit words. Implemented using " case" statement. shift\_4\_left shifts 4 bits left. shift\_5\_right shits 5 bits right. The " case" is used to shift different word length data correctly. key\_splitter splits 128 bit key into four 32 bit keys. data\_merger puts together two halves of data. adder\_subtractor adds or subtracts data.

## 3. 2 Simulation results

To make waveforms readable, some of the are split in half

## 3. 2. 1 xor\_3

The output from the XOR gate is HIGH when both inputs are different. The same applies to 3 input xor gate. To demonstrate the correctness of this component all bits are set either to '1' or '0'.

## 3. 2. 2 splitter

It can be seen on the simulation result below, that the random data is split in halves.

## 3. 2. 3 shift\_4\_left

One hexadecimal number represents 4 bits, therefore it can be seen that random data is shifted one symbol to the left.

## 3. 2. 4 shift\_5\_right

If the word length of the data to be encrypted or decrypted is 4, 8 or 16 bits, it means that when split, it will be 2, 4 or 16 bits long. In first case bits [1.. 0] will set to 0, in second case bits [3.. 0] will set to 0 and finally bits [7.. 3] will be set to zero.

## 3. 2. 5 key\_splitter

The simulation results below proves that key splitter's correct operation. The component splits the keys depending on encryption and decryption input.

## 3. 2. 6 data\_merger

The simulation results below demonstrate the correct operation of the components that is respopnsible for merging encrypted and decrypted data.

## 3. 2. 7 adder\_subtractor

This component is performing as expected, unless the output value exceeds . The y is the output, x defines whether addition or subtraction is done

## 3. 2. 8 TEA

The simulation results below demonstrate one round of encryption and decryption for 64 bit word. The 4, 8 and 16 bit words are manipulated in similar manner. The only difference is that instead of encrypting all 64 bits, for example only 8 bits [7.. 0] are encrypted or decrypted. It takes approximately 65 ns to obtain the resultThe next simulation shows the same component with minor modifications performing 16 rounds encryption and decryption. It takes approximately 515 ns to obtain the result of encryption and decryption. Only one set of data can be manipulated at a time! Finally, to improve the throughput, the component that includes 16 TEA components is implemented. Each component performs one round of encryption/decryption. Registers are put between each TEA component to enable the pipelining. Thus, after first set of data has been fed in, 30 ns later next set of data can be fed in and so on. The first result is ready in 660 ns, which is slightly longer than a single component performing 16 rounds, however the second result is ready 15 ns later of the first result. All results have been compared to the output of the C program that implements the Tiny Encryption Algorithm. It proves that the system is working correctly. All simulation were targeted to Cyclone II device family and the shortest clock period that produces reliable results is 30 ns for the first implementation and 20 ns for the second.

## 4. Conclusion

Both proposed systems are capable of encrypting and decrypting data of different length (4, 8, 16 and 64 bits). Both systems are synchronous. The first option is easy to implement and it is flexible, because it has Rounds input that defines the number of encryption decryption cycles. Changing this input, the system is capable of carry out different number of rounds. However the throughput is very low: 1 result in 515 ns. The second proposed system has far better throughput because of the pipelining, however it is more complex and it is not very flexible. Single TEA component consists of 7 major components: xor\_3, splitter, shift\_4\_left, shift\_5\_right, data\_ merger, key\_splitter and adder\_subtractor. All subsystems were simulated to ensure their correct functionality. Overall, this coursework has been very challenging, however the understanding of digital electronics, knowledge of VHDL and Altera software have improved significantly.

## Appendix - VHDL code

tea16library ieee; use ieee. std\_logic\_1164. all; entity tea16 IS PORT

## (

encrypt\_decrypt: IN std\_LOGIC; word\_length: IN Std\_Logic\_vector(1 downto 0); key: IN Std\_Logic\_Vector(127 downto 0); clk : IN std\_logic; dataInput : IN std\_logic\_vector (63 downto 0); dataOutput : OUT std\_logic\_vector (63 downto 0)

## );

end tea16; ARCHITECTURE structural of tea16 ISCOMPONENT reg PORT

## (

clk: IN std\_logic; d : IN std\_logic\_vector(63 downto 0); q: OUT std\_logic\_vector(63 downto 0)

## );

END COMPONENT reg; COMPONENT tea\_com PORT

## (

sum\_input: IN Std\_LOGIC\_VECTOR(31 downto 0); clk : IN Std\_Logic; Rounds: IN Std\_Logic\_Vector(6 downto 0); Data : IN Std\_Logic\_Vector(63 downto 0); key: IN Std\_Logic\_Vector(127 downto 0); word\_length: IN Std\_Logic\_vector(1 downto 0); encrypt\_decrypt: IN Std\_Logic; Encrypted\_data: OUT Std\_Logic\_Vector (63 downto 0)

## );

END COMPONENT tea\_com; SIGNAL Data1 : Std\_Logic\_Vector(63 downto 0); SIGNAL out1, out2, out3, out4, out5, out6, out7, out8: Std\_Logic\_Vector (63 downto 0); SIGNAL out9, out10, out11, out12, out13, out14, out15, out16: Std\_Logic\_Vector (63 downto 0); SIGNAL out17, out18, out19, out20, out21, out22, out23, out24: Std\_Logic\_Vector (63 downto 0); SIGNAL out25, out26, out27, out28, out29, out30, out31, out32: Std\_Logic\_Vector (63 downto 0); SIGNAL sum1, sum2, sum3, sum4, sum5, sum6, sum7: Std\_Logic\_Vector(31 downto 0); SIGNAL sum8, sum9, sum10, sum11, sum12, sum13, sum14, sum15, sum16 : Std\_Logic\_Vector(31 downto 0); CONSTANT numberOfRounds: Std\_Logic\_Vector(6 downto 0) := " 0000001"; SIGNAL k: Std\_Logic\_Vector(127 downto 0); SIGNAL wl: Std\_Logic\_vector(1 downto 0); SIGNAL ed: std\_LOGIC; BEGINtea\_com\_1: tea\_comport map (sum1, clk, numberOfRounds, Data1, k, wl, ed, out1); reg1: regport map (clk, out1, out2); tea\_com\_2: tea\_comport map (sum2, clk, numberOfRounds, out2, k, wl, ed, out3); reg2: regport map (clk, out3, out4); tea\_com\_3: tea\_comport map (sum3, clk, numberOfRounds, out4, k, wl, ed, out5); reg3: regport map (clk, out5, out6); tea\_com\_4: tea\_comport map (sum4, clk, numberOfRounds, out6, k, wl, ed, out7); reg4: regport map (clk, out7, out8); tea\_com\_5: tea\_comport map (sum5, clk, numberOfRounds, out8, k, wl, ed, out9); reg5: regport map (clk, out9, out10); tea\_com\_6: tea\_comport map (sum6, clk, numberOfRounds, out10, k, wl, ed, out11); reg6: regport map (clk, out11, out12); tea\_com\_7: tea\_comport map (sum7, clk, numberOfRounds, out12, k, wl, ed, out13); reg7: regport map (clk, out13, out14); tea\_com\_8: tea\_comport map (sum8, clk, numberOfRounds, out14, k, wl, ed, out15); reg8: regport map (clk, out15, out16); tea\_com\_9: tea\_comport map (sum9, clk, numberOfRounds, out16, k, wl, ed, out17); reg9: regport map (clk, out17, out18); tea\_com\_10: tea\_comport map (sum10, clk, numberOfRounds, out18, k, wl, ed, out19); reg10: regport map (clk, out19, out20); tea\_com\_11: tea\_comport map (sum11, clk, numberOfRounds, out20, k, wl, ed, out21); reg11: regport map (clk, out21, out22); tea\_com\_12: tea\_comport map (sum12, clk, numberOfRounds, out22, k, wl, ed, out23); reg12: regport map (clk, out23, out24); tea\_com\_13: tea\_comport map (sum13, clk, numberOfRounds, out24, k, wl, ed, out25); reg13: regport map (clk, out25, out26); tea\_com\_14: tea\_comport map (sum14, clk, numberOfRounds, out26, k, wl, ed, out27); reg14: regport map (clk, out27, out28); tea\_com\_15: tea\_comport map (sum15, clk, numberOfRounds, out28, k, wl, ed, out29); reg15: regport map (clk, out29, out30); tea\_com\_16: tea\_comport map (sum16, clk, numberOfRounds, out30, k, wl, ed, out31); reg16: regport map (clk, out31, dataOutput); PROCESS (clk)BEGINcase(encrypt\_decrypt) iswhen '1' => Data1 <= dataInput; k <= key; wl <= word\_length; ed <= encrypt\_decrypt; sum1 <= X" 00000000"; sum2 <= X" 9e3779b9"; sum3 <= X" 3c6ef372"; sum4 <= X" daa66d2b"; sum5 <= X" 78dde6e4"; sum6 <= X" 1715609d"; sum7 <= X" b54cda56"; sum8 <= X" 5384540f"; sum9 <= X" f1bbcdc8"; sum10 <= X" 8ff34781"; sum11 <= X" 2e2ac13a"; sum12 <= X" cc623af3"; sum13 <= X" 6a99b4ac"; sum14 <= X" 08d12e65"; sum15 <= X" a708a81e"; sum16 <= X" 454021d7"; when '0' => Data1 <= dataInput; k <= key; wl <= word\_length; ed <= encrypt\_decrypt; sum1 <= X" 3c6ef372"; sum2 <= X" daa66d2b"; sum3 <= X" 78dde6e4"; sum4 <= X" 1715609d"; sum5 <= X" b54cda56"; sum6 <= X" 5384540f"; sum7 <= X" f1bbcdc8"; sum8 <= X" 8ff34781"; sum9 <= X" 2e2ac13a"; sum10 <= X" cc623af3"; sum11 <= X" 6a99b4ac"; sum12 <= X" 08d12e65"; sum13 <= X" a708a81e"; sum14 <= X" 454021d7"; sum15 <= X" e3779b90"; sum16 <= X" 81af1549"; end case; END PROCESS; END structural; reglibrary ieee; use ieee. std\_logic\_1164. all; ENTITY reg IS PORT

## (

clk: IN std\_logic; d : IN std\_logic\_vector(63 downto 0); q: OUT std\_logic\_vector(63 downto 0)

## );

END reg; ARCHITECTURE structural OF reg ISBEGIN-- Register with active-high ClockPROCESSBEGINWAIT UNTIL clk = '1'; q <= d; END PROCESS; END structural; tea\_comLIBRARY ieee; USE ieee. std\_logic\_1164. all; USE ieee. std\_logic\_unsigned. all; USE ieee. numeric\_std. all; ENTITY tea\_com IS PORT

## (

sum\_input: IN Std\_LOGIC\_VECTOR(31 downto 0); clk : IN Std\_Logic; Rounds: IN Std\_Logic\_Vector(6 downto 0); Data : IN Std\_Logic\_Vector(63 downto 0); key: IN Std\_Logic\_Vector(127 downto 0); word\_length: IN Std\_Logic\_vector(1 downto 0); encrypt\_decrypt: IN Std\_Logic; dataOutput: BUFFER Std\_Logic\_Vector (63 downto 0)

## );

END tea\_com; ARCHITECTURE structural OF tea\_com ISCOMPONENT xor\_3 PORT

## (

A: IN Std\_Logic\_Vector(31 downto 0); B: IN Std\_Logic\_Vector(31 downto 0); C: IN Std\_Logic\_Vector(31 downto 0); Y: OUT Std\_Logic\_Vector(31 downto 0)

## );

END COMPONENT xor\_3; COMPONENT splitter PORT

## (

data\_input: IN Std\_Logic\_Vector(63 downto 0); wordLength: IN Std\_Logic\_Vector(1 downto 0); encrypt\_decrypt: IN Std\_Logic; data\_left: OUT Std\_Logic\_Vector(31 downto 0); data\_right: OUT Std\_Logic\_Vector(31 downto 0)

## );

END COMPONENT splitter; COMPONENT shift\_5\_right PORT

## (

data\_in: IN Std\_Logic\_Vector(31 downto 0); word\_length: IN Std\_Logic\_Vector(1 downto 0); data\_out: OUT Std\_Logic\_Vector(31 downto 0)

## );

END COMPONENT shift\_5\_right; COMPONENT shift\_4\_left PORT

## (

data\_in : IN STD\_LOGIC\_VECTOR(31 downto 0); data\_out: OUT STD\_LOGIC\_VECTOR(31 downto 0)

## );

END COMPONENT shift\_4\_left; COMPONENT key\_splitter PORT

## (

key: IN Std\_Logic\_Vector(127 downto 0); encrypt\_decrypt: IN Std\_Logic; K0: OUT Std\_Logic\_Vector(31 downto 0); K1: OUT Std\_Logic\_Vector(31 downto 0); K2: OUT Std\_Logic\_Vector(31 downto 0); K3: OUT Std\_Logic\_Vector(31 downto 0)

## );

END COMPONENT key\_splitter; COMPONENT data\_merger PORT

## (

data\_left: IN Std\_Logic\_Vector(31 downto 0); data\_right: IN Std\_Logic\_Vector(31 downto 0); word\_length: IN Std\_Logic\_vector(1 downto 0); encrypt\_decrypt: IN Std\_Logic; output: OUT Std\_Logic\_Vector(63 downto 0)

## );

END COMPONENT data\_merger; COMPONENT adder\_subtractor PORT

## (

a: IN Std\_Logic\_Vector(31 downto 0); b: IN Std\_Logic\_Vector(31 downto 0); x: IN Std\_logic; y: OUT Std\_Logic\_Vector(31 downto 0)

## );

END COMPONENT adder\_subtractor; CONSTANT delta : Std\_Logic\_Vector(31 downto 0) := X" 9e3779b9"; SIGNAL keySignal: Std\_Logic\_Vector(127 downto 0); SIGNAL dataSignal: Std\_Logic\_Vector(63 downto 0); SIGNAL sumSignal, sumSignal1, K0, K1, K2, K3: Std\_Logic\_Vector(31 downto 0); SIGNAL wl: Std\_Logic\_vector(1 downto 0); SIGNAL ed : Std\_Logic; SIGNAL a0, a1, a2, a3, a4, a5, a6, a7: Std\_Logic\_Vector(31 downto 0); SIGNAL b0, b1, b2, b3, b4, b5, b6, b7, sum: Std\_Logic\_Vector(31 downto 0); BEGINc0 : key\_splitterport map (keySignal, ed, K0, K1, K2, K3); c1 : splitter port map (dataSignal, wl, ed, a0, b0); c2 : shift\_4\_left port map (b0, b1); c3 : shift\_5\_right port map (b0, wl, b2); c4 : adder\_subtractor port map (K0, b1, '1', b3); c5 : adder\_subtractor port map (sumSignal, delta, ed, sumSignal1); c6 : adder\_subtractor port map (sumSignal1, b0, '1', b4); c7 : adder\_subtractor port map (K1, b2, '1', b5); c8 : xor\_3 port map (b3, b4, b5, b6); c9 : adder\_subtractor port map (a0, b6, ed, a1); c10: shift\_4\_left port map (a1, a2); c11: shift\_5\_right port map (a1, wl, a3); c12: adder\_subtractor port map (K2, a2, '1', a4); c13: adder\_subtractor port map (sumSignal1, a1, '1', a5); c14: adder\_subtractor port map (K3, a3, '1', a6); c15: xor\_3 port map (a4, a5, a6, a7); c16: adder\_subtractor port map (b0, a7, ed, b7); c17: data\_mergerport map (a1, b7, wl, ed, dataOutput); PROCESS(clk, word\_length)VARIABLE i, variable\_1, variable\_2, variable\_3 : INTEGER := 0; BEGINif (clk'event and clk = '1') thencase (encrypt\_decrypt) iswhen '1' => case (i) iswhen 0 => sum <= sum\_input; when 1 => dataSignal <= Data; sumSignal <= sum; keySignal <= key; wl <= word\_length; ed <= encrypt\_decrypt; when others => dataSignal <= dataOutput; sumSignal <= sumSignal1; end case; i := i + 1; if (i = Rounds + 1) theni := 1; end if; when '0' => case (i) iswhen 0 => variable\_1 := conv\_integer(delta); variable\_2 := conv\_integer(Rounds+1); variable\_3:= variable\_2\*variable\_1; sum <= STD\_LOGIC\_VECTOR(TO\_UNSIGNED(variable\_3, 32)); when 1 => dataSignal <= Data; sumSignal <= sum; keySignal <= key; wl <= word\_length; ed <= encrypt\_decrypt; when others => dataSignal <= dataOutput; sumSignal <= sumSignal1; end case; i := i + 1; if (i = Rounds + 1) theni:= 1; end if; end case; end if; END PROCESS; END structural;