Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

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

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.