Skip to content

NB071/Verilog-projects

Folders and files

NameName
Last commit message
Last commit date

Latest commit

f2d5e64 ยท Dec 26, 2024

History

31 Commits
Dec 24, 2024
Dec 26, 2024
Dec 25, 2024
Dec 26, 2024

Repository files navigation

Verilog Logo

Passion Projects in Verilog

GitHub Issues License GitHub Stars

About the Repository

This repository is a collection of my passion projects in Verilog, inspired by my university course EECS 2021, where I discovered how fascinating Verilog is to learn. Its ability to design hardware through code, simulate complex systems, and create modular, reusable components sparked my interest.

For now, this repository contains a Digital Clock, but I plan to add more exciting projects soon!


Projects (More to Be Added)

1. Digital Clock โฐ

  • Description:
    • A digital clock that tracks hours, minutes, and seconds.
    • Configurable to work with any clock frequency.
    • Designed with modularity in mind, using separate modules for clock division and timekeeping.
  • Key Features:
    • Modular design with a ClockDivider module.
    • Converts time into Binary Coded Decimal (BCD) for display purposes.
    • Includes a testbench to verify functionality.

2. Traffic Light ๐Ÿšฆ

  • Description:
    • A traffic light controller implemented as a Finite State Machine (FSM).
    • The system transitions between RED, YELLOW, and GREEN lights based on configurable timer inputs.
    • Designed to handle both normal and error states, with error detection for invalid timer configurations.
  • Key Features:
    • Configurable timer for each light state using an 18-bit input.
    • Supports error detection for invalid timer configurations (e.g., zero-duration states).
    • Includes FSM pause/resume functionality based on the enable signal.
    • Provides a testbench to simulate various scenarios, including valid and invalid configurations, light transitions, and error recovery.
    • The FSM design ensures proper timing and smooth light transitions.

File Structure

.
โ”œโ”€โ”€ DigitalClock/              # Directory containing Verilog files
โ”‚   โ”œโ”€โ”€ DigitalClock.v         # Digital clock module
โ”‚   โ”œโ”€โ”€ ClockDivider.v         # Clock divider module
โ”‚   โ”œโ”€โ”€ clock_testbench.v      # Testbench for verifying the digital clock
|   โ”œโ”€โ”€ README.md  
โ”œโ”€โ”€ TrafficLight/              # Directory containing Verilog files for the traffic light system
โ”‚   โ”œโ”€โ”€ TrafficLightFSM.v      # Traffic light FSM module
โ”‚   โ”œโ”€โ”€ TrafficLightFSM_tb.v   # Testbench for verifying the traffic light FSM functionality
|   โ”œโ”€โ”€ README.md  
โ”œโ”€โ”€ .gitignore                 # Git configuration to exclude unnecessary files
โ”œโ”€โ”€ README.md 

Usage (ex. for DigitalClock)

  1. Clone the repository:
git clone https://github.com/NB071/Verilog-projects.git
  1. Navigate to the project directory:
cd Verilog-projects/DigitalClock
  1. Compile the Verilog code using iverilog:
iverilog -o DigitalClock_testbench.vvp clock_testbench.v DigitalClock.v ClockDivider.v
  1. Run the compiled file using vvp:
vvp DigitalClock_testbench.vvp
  1. Observe the simulation output in the terminal.

Future Plans

  • ๐Ÿงฎ Digital Calculator: Exploring arithmetic logic and modular design.
  • TBD: Iโ€™m always brainstorming new ideas to expand this repository!

Acknowledgments

  • Inspired by my coursework in EECS 2021 at York University.
  • Thanks to my professors and peers for fostering my interest in digital design! ๐Ÿ™Œ

Stay tuned for more projects! ๐Ÿš€

About

Passion Projects in verilog

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published