1 / 37

Final presentation Encryption/Decryption on embedded system

Final presentation Encryption/Decryption on embedded system. Winter 2013 Part A. Supervisor : Ina Rivkin students : Chen P onchek Liel Shoshan. motivation.

anila
Download Presentation

Final presentation Encryption/Decryption on embedded system

An Image/Link below is provided (as is) to download presentation Download Policy: Content on the Website is provided to you AS IS for your information and personal use and may not be sold / licensed / shared on other websites without getting consent from its author. Content is provided to you AS IS for your information and personal use only. Download presentation by click this link. While downloading, if for some reason you are not able to download a presentation, the publisher may have deleted the file from their server. During download, if you can't get a presentation, the file might be deleted by the publisher.

E N D

Presentation Transcript


  1. Final presentationEncryption/Decryption on embedded system Winter 2013 Part A Supervisor: Ina Rivkin students: Chen Ponchek Liel Shoshan

  2. motivation • Now days, there are many portable storage systems with large memories which contains valuable data (such as disk on key, tablets, etc.) • Therefore there is a concrete need for portable cryptography systems which are suitable for such devices. • In our project, we will aspire to provide a suitablesystem which will answer this need.

  3. Project Goal • main goal: • Implementation of data cryptography embedded system using AES algorithm and finding the suitable architecture for portable system.

  4. Project Specifications • Implementing on a ZyncSoPC by Xilinx. • Suitable for portable systems(Disk-on-Key, tablets, etc.) - low power system. • Transparent system (while storing/loading files) - The cryptography system won’t create traffic bottle necks. • Finding the best architecture – according to the requirements above: • Profiling AES algorithm. • Finding the balance between using the ARM processor and using the FPGA (the hardware accelerator needs more power).

  5. AES algorithm • Advanced Encryption Standard, also known as “Rijndael”, is a block cipher. • The cipher is iterative, quick and comfortable to implement both by software and hardware, and it doesn’t have high memory requirements. • Most of the AES calculations are made through 10 rounds. • In each state the data block is described as a 2D, 4X4 array of bytes. • In each round a “Round Key” is created by the key-expansion process. • Each round consists of 4 steps: • SubBytes • ShiftRows • MixColumns • AddRoundKey

  6. System Block diagram PS PL Decrypted data DDR Zynq Encrypted data RS232 BRAM UART ZEDBOARD

  7. Zedboard Block Diagram

  8. System Block Diagramproject part A PS PL Zynq Decrypted data DDR Encrypted data AES in software BRAM RS232 UART ZEDBOARD Implementation of AES algorithm on ARM and code optimization.

  9. Software Engineering • Each step is implemented as a separate function. • Each function is independent of the other functions. • The program can encrypt and decrypt the data.

  10. Software Engineering • The input data will be entered by the user via PuTTYterminal. • The program’s output is the data after encryption and the encrypted data after decryption.

  11. Encryption Process

  12. Development stages XPS/EDK- Configuring the ARM system: • Creation of the ARM processor interface to the RS-232 UART. • Addition of the Bram and Bram Controller IP and connection to the AXI Interconnect.

  13. Development stages PlanAhead • Creation of the Top level entity in VHDL code. • Generation of the Bitstream. • Exporting hardware to SDK.

  14. Development stages SDK - • Generating the software platform project: • Creating Board Support package (BSP). • Selection of memory – DDR vs. Bram. • Test in Hardware: • Downloading the application to the ARM processor. • Running and profiling the application.

  15. ProfilingBram vs. DDREncryption and decryption of 10x16 Bytes 111.54 ms 2.754 ms

  16. Software optimization #1 • The MixColumns and InvMixColumns functions takes around 65%-70% of the whole process execution time. • Improving them will significantly reduce the delay time.

  17. Software optimization #1 • We will implement the MixColumns function using LUTs instead of arithmetic commands and if/else statements. • Should speed up the calculations.

  18. MixColumnsinitial implementation

  19. MixColumns improved implementation

  20. ProfilingBram vs. DDRWith an improvedMixColumns implementation 88.06 ms 2.626 ms

  21. Software optimization #1 • Bram : • The total execution time decreased from 111.5 msec to 88 msec. • Decreasing in 21%. • DDR : • The total execution time decreased from 2.754 msec to 2.626 msec. • Decreasing in 5%.

  22. Software optimization #2 • We will implement the MixColumns and the InvMixColumns functions using LUTs and without using for loops. • Should speed up even more the calculations.

  23. MixColumns optimized implementation

  24. InvMixColumns optimized implementation

  25. ProfilingBram vs. DDRWith an improvedMixColumns implementation With an optimized MixColumns and MixColumns implementation 1.145 ms 47.427 ms

  26. Software optimization #2 • Bram : • The total execution time decreased from 111.5 msec to 47.427 msec. • Decreasing in 57%. • DDR : • The total execution time decreased from 2.754 msec to 1.145 msec. • Decreasing in 58%.

  27. Hardware optimization The ARM processor clock: • At first, we used the default clock rate, whichwas 160MHz. • We will now set the clock rate to 225MHz (the maximum clock rate).

  28. ProfilingBram vs. DDR With higher clock rate (160MHz  225MHz) 0.819 ms 34.798 ms

  29. Hardware optimization • Bram : • The total execution time decreased from 111.5 msec to 34.8 msec. • Decreasing in 69%. • DDR : • The total execution time decreased from 2.754 msec to 0.82 msec. • Decreasing in 70%.

  30. Optimizations Execution’s time improvement

  31. Optimizations Execution’s speed improvement

  32. Execution’s speed improvement • Every optimization that we have made has decreased the total time and improved the speed. • The most significant improve was attributed by the 2nd SW optimization. • Both DDR and Bram speeds were eventually increased by 3 times and more.

  33. Bram vs. DDR • In every optimization : running the application from BRAM wassignificantly slower then running from DDR. • This is due to: • DDR has it own dedicated Bus. • The DDR clock rate is 550 MHZ, when BRAM clock rate is 160 MHZ. • DDR works on both rising and falling edge.

  34. Transmission rate • The typical maximum data rate in USB is 1.5 MB/s (The typical rates are around 0.5MB/s.) • The encryption rate we were able to achieve at the end is 323 KB/s  1.5 times slower. • Conclusion: An hardware accelerator is needed.

  35. Project Specifications • Implementing on a ZyncSoPC by Xilinx. • Suitable for portable systems(Disk-on-Key, tablets, etc.) - low power system. • Finding the best architecture – according to the requirements above: • Profiling AES algorithm.

  36. Demonstration

More Related