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.pycontains the test run of the cipher and inverse cipher
- AESfunctions.pycontains the implementation of each of the AES subroutines as well as the Cipher and the Inverse Cipher
- AEStables.pycontains all the AES tables data
- devtests.pycan 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}
}