demonstration.mp4
This project implements the Advanced Encryption Standard (AES) encryption algorithm using Verilog. The design is targeted for the Altera DE1-SoC FPGA board. This project was undertaken as part of the Logic Design course during the first year of our Computer Engineering program.
The AES algorithm is widely used for securing data and is known for its efficiency and security. In this project, we have implemented the 128-bit, 192-bit, and 256-bit versions of AES. The design includes key expansion, the encryption process, and the decryption process.
- AES-128, AES-192, and AES-256 Encryption and Decryption: Implements the core AES algorithm for 128-bit, 192-bit, and 256-bit keys.
- Key Expansion: Dynamically generates the required round keys from the initial key.
- Hardware Implementation: Optimized for running on the Altera DE1-SoC FPGA board.
- Altera DE1-SoC FPGA board
- Quartus Prime software
- ModelSim for simulation
-
Clone the repository
git clone https://github.com/AhmedSobhy01/AES-Verilog.git cd AES-Verilog
-
Open Quartus Prime
- Open Quartus Prime and create a new project.
- Add all the Verilog files from the repository to the project.
-
Compile the Project
- Compile the project in Quartus Prime.
- Ensure there are no errors in the compilation.
-
Program the FPGA
- Connect the DE1-SoC board to your computer.
- Use the Quartus Prime Programmer to upload the compiled design to the FPGA.
-
Open ModelSim
- Load the project files into ModelSim.
-
Run the Simulation
- Perform functional and timing simulations to verify the design.
- Use the provided testbenches to simulate AES encryption and decryption.
Root directory contains all Verilog modules, each module file includes a module for the testbench with the convention {moduleName}_DUT.
- Encrypting Data: Input your plaintext and key to the FPGA design to receive the encrypted ciphertext.
- Decrypting Data: Input the ciphertext and the key to the FPGA design to retrieve the original plaintext.
Ahmed Amr |
Ahmed Sobhy |
Ahmed Waleed |
Anas Ibrahem |
This project is licensed under the MIT License - see License for more information.