Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/ahmedsobhy01/aes-verilog
An implementation of the Advanced Encryption Standard (AES) encryption algorithm using Verilog supporting AES-128, AES-192, and AES-256 encryption/decryption
https://github.com/ahmedsobhy01/aes-verilog
aes aes-128 aes-192 aes-256 altera decryption encryption fpga verilog
Last synced: 7 days ago
JSON representation
An implementation of the Advanced Encryption Standard (AES) encryption algorithm using Verilog supporting AES-128, AES-192, and AES-256 encryption/decryption
- Host: GitHub
- URL: https://github.com/ahmedsobhy01/aes-verilog
- Owner: AhmedSobhy01
- License: mit
- Created: 2024-04-20T14:56:59.000Z (9 months ago)
- Default Branch: main
- Last Pushed: 2024-07-22T21:06:46.000Z (5 months ago)
- Last Synced: 2024-11-07T04:13:42.067Z (about 2 months ago)
- Topics: aes, aes-128, aes-192, aes-256, altera, decryption, encryption, fpga, verilog
- Language: Verilog
- Homepage:
- Size: 93.8 KB
- Stars: 7
- Watchers: 2
- Forks: 1
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
#
AES Encryption using Verilog on FPGA
https://github.com/user-attachments/assets/89a8f95d-6bfe-42bc-836b-53730abd24ab
## 📝 Project Description
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.
## ✨ Features
- **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.## 🚀 Getting Started
### Prerequisites
- Altera DE1-SoC FPGA board
- Quartus Prime software
- ModelSim for simulation### Installation
1. **Clone the repository**
```bash
git clone https://github.com/AhmedSobhy01/AES-Verilog.git
cd AES-Verilog
```2. **Open Quartus Prime**
- Open Quartus Prime and create a new project.
- Add all the Verilog files from the repository to the project.3. **Compile the Project**
- Compile the project in Quartus Prime.
- Ensure there are no errors in the compilation.4. **Program the FPGA**
- Connect the DE1-SoC board to your computer.
- Use the Quartus Prime Programmer to upload the compiled design to the FPGA.### Running the Simulation
1. **Open ModelSim**
- Load the project files into ModelSim.
2. **Run the Simulation**
- Perform functional and timing simulations to verify the design.
- Use the provided testbenches to simulate AES encryption and decryption.## 📁 Project Structure
Root directory contains all Verilog modules, each module file includes a module for the testbench with the convention {moduleName}\_DUT.
## 🛠️ Usage
- **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.## 👥 Collaborators
Ahmed Amr
Ahmed Sobhy
Ahmed Waleed
Anas Ibrahem
## 📜 License
This project is licensed under the MIT License - see [License](LICENSE) for more information.