Flexible AES 128, 192, and 256 implementations in Python, C++, Vivado HLS, Chisel and PyRTL, and Verilog
- provide a Python and C/C++ implementation - OK
- provide a Vivado HLS implementation - OK
- provide a Chisel implementation - OK
- provide a rocket-chip RoCC accelerator - starting
- provide custom RISC-V instructions - to do
- provide a PyRTL implementation - started
- propose a dual-clock acceleration - to do
- provide a Verilog implementation - OK
script.py
contains the test run of the cipher and inverse cipherAESfunctions.py
contains the implementation of each of the AES subroutines as well as the Cipher and the Inverse CipherAEStables.py
contains all the AES tables datadevtests.py
can be used as a further scratch-test area- this is a functional implementation of AES (TODO: OOP version)
- fully parametrizable for all AES versions (128, 192, 256) and other parameters
- tested in Sublime Text on Windows 10 with Python 3.6 (64-bit)
- supports AES 128, 192 and 256 by allocating memory to accomodate all versions
- tested in Microsoft Visual Studio
The Verilog implementation provided here is the same exact implementation from Altera's Advanced Synthesis Cookbook, only with the stratixii_lcell_comb
replaced with a bitwise XOR (^
in Verilog).
What's a Creel? YouTube channel has some great videos on explaining and implementing AES
- https://www.youtube.com/user/WhatsACreel/videos
- https://www.youtube.com/playlist?list=PLIBpkBrhT5aBeH_7sSxJAM3XgoCd7nSXS
Link to the AES standard
Altera's Advanced Synthesis Cookbook includes an AES 128/256 implementation
- https://www.altera.com/content/dam/altera-www/global/en_US/pdfs/literature/manual/stx_cookbook.pdf
- https://www.altera.com/literature/manual/cookbook.zip
University of Virginia ECE Wiki FPGA tutorials
- http://venividiwiki.ee.virginia.edu/mediawiki/index.php/Xilinx
- http://venividiwiki.ee.virginia.edu/mediawiki/index.php/Altera
- http://venividiwiki.ee.virginia.edu/mediawiki/index.php/ToolsXilinxLabsRTLHLSAES
This work resulted in the folowwing publications:
@article{guo2022agile,
title={Agile-AES: Implementation of configurable AES primitive with agile design approach},
author={Guo, Xinfei and El-Hadedy, Mohamed and Mosanu, Sergiu and Wei, Xiangdong and Skadron, Kevin and Stan, Mircea R},
journal={Integration},
year={2022},
publisher={Elsevier}
}
@inproceedings{mosanu2019flexi,
title={Flexi-AES: A Highly-Parameterizable Cipher for a Wide Range of Design Constraints},
author={Mosanu, Sergiu and Guo, Xinfei and El-Hadedy, Mohamed and Anghel, Lorena and Stan, Mircea},
booktitle={2019 IEEE 27th Annual International Symposium on Field-Programmable Custom Computing Machines (FCCM)},
pages={338--338},
year={2019},
organization={IEEE}
}