Udemy
    •  
    •  
    •  
    •  
    •  
    •  
    •  
    •  
Turn what you know into an opportunity and reach millions around the world.
Learn More
Your cart is empty.
Keep shopping
Learn FPGA Design With VHDL (Intel/Altera)
Rating: 4.4 out of 5(654 ratings)
4,654 students

Learn FPGA Design With VHDL (Intel/Altera)

Gain a Solid Foundation in VHDL for FPGA Development with Lots of Examples
Last updated 6/2026
English

What you'll learn

  • We will cover the VHDL language and syntax with lots of example projects
  • Relate VHDL code to hardware implementation
  • Creating FPGA building blocks using VHDL
  • Creating State Machines using VHDL
  • Creating complex FPGA designs from scratch
  • Highlight good design practice & common pitfalls
  • Writing Test Benches in VHDL
  • Simulate & debug FPGA Designs using ModelSim
  • Use the Intel Quartus software to compile and implement projects
  • Use Quartus To Perform Pin Assignments
  • Programming FPGAs using the USB Blaster
  • Using the Quartus Netlist Viewer to view the Hardware Realisation
  • Making sense of the Quartus Fitter Reports
  • Quartus Assignment Editor
  • Quartus Settings, Options & Optimisations
  • Basic Introduction to Quartus Timing Analyser
  • Implement a UART project that communicates over RS232 with a PC
  • Implement a State Machine project
  • Implement a 4 Digit 7-Segment Display to print a Count value
  • Implement a Project to Create A PWM output
  • Implement a Shift Register to Drive LEDs
  • Implement a Project to cover Switch De-bouncing and Synchronisation

Course content

1 section76 lectures25h 34m total length
  • Introduction9:05
  • Development Boards4:38
  • Where to get the FPGA Development Boards0:14
  • Installing Quartus6:47
  • FPGA Fundamentals24:50
  • Signals & Data Types I31:55
  • Signals & Data Types II12:15
  • Constants1:50

    Declare and use constants in VHDL by using the constant keyword with a data type and initial value. Ensure constants remain immutable after declaration and differ from signals.

  • VHDL Operators18:53
  • Structure of a VHDL File9:31
  • Project : Switch And LED (FPGA Explorer Development Board)29:44
  • Project : Switch And LED (Cyclone IV Development Board)25:37
  • The Process Block17:51
  • State Machine Project (FPGA Explorer Development Board)51:18
  • State Machine Project (Cyclone IV Development Board)35:15
  • Component Instantiation9:27
  • Project : Using Quartus IP Wizard To Generate PLL (FPGA Explorer Dev Board)30:11
  • Project : Using Quartus IP Wizard To Generate PLL (Cyclone IV Development Board)33:49
  • Quartus Netlist Viewer & Fitter Reports (For Both Development Boards)38:22
  • Quartus Settings & Options (For Both Development Boards)23:06
  • VHDL Concurrent Statements14:15
  • VHDL Sequential Statements26:56
  • Signal Assignments I14:20

    Explore how signal assignments inside a process implement combinational logic or flip-flops, compare conventional and registered processes, and learn to avoid latches and use flip-flops in FPGA designs.

  • Signal Assignments II13:08
  • How To Generate A PWM9:19
  • Project : PWM LED30:41
  • Variables6:38
  • Functions and Procedures8:10
  • Packages and Libraries8:03
  • Parameterised Components6:36
  • Type Conversions5:59
  • Miscellaneous Topics2:22
  • Tri-State Drivers1:50
  • Comparators3:03
  • Multiplexers4:45
  • Shift Registers10:57
  • Serialisers5:49
  • RAMs & ROMs13:17

    Explore implementing rams and block ram in FPGAs using VHDL; compare register banks with block ram, and cover single-port and dual-port ram designs with generics for data and address widths.

  • Finite State Machines8:28
  • State Machine Practise
  • Good Design Practice I16:07
  • Good Design Practice II8:12
  • Project : LED Shift Register (FPGA Explorer Development Board)55:58
  • Project : LED Shift Register (Cyclone IV Development Board)36:37
  • How To Debounce A Switch Input7:54
  • Project : De-bouncing Asynchronous Input11:47

    Implement a debounced input circuit in VHDL by using a counter and upper and lower thresholds to clean the switch, preventing multi-press shifts in the shift register.

  • Quartus Timing Analyser (For Both Development Boards)31:57
  • Project : Driving An LCD Display (FPGA Explorer Development Board)1:50:56
  • Project : Driving A Seven Segment Display (Cyclone IV Development Board) Part 112:29
  • Project : Driving A Seven Segment Display (Cyclone IV Development Board) Part 259:32

    Learn to design an FPGA circuit with VHDL that counts button presses and displays the count on a seven-segment display, using input synchronization, debouncing, a decoder, and a state machine.

  • Test Benches I6:34

    Test benches drive input to the design under test and verify outputs, while vectors and results are stored in text files and logged with severity levels.

  • Test Benches II5:16
  • Test Benches III4:17
  • UART Block Diagram14:51
  • UART Protocol7:49
  • BaudClkGenerator Block Diagram2:26
  • BaudClkGenerator VHDL35:33

    Discover how to implement a baud clock generator in VHDL for an FPGA, detailing entity, architecture, and a counter-based baud pulse for RS-232 serial data.

  • BaudClkGenerator Test Bench42:16
  • Serialiser Block Diagram1:30
  • Serialiser VHDL17:09

    Learn to implement a VHDL serializer with a shift register, using a generic data width, controlled by load and shift enable signals, with an asynchronous reset and idle default state.

  • Serialiser Test Bench37:39
  • UART Transmitter VHDL22:23
  • UART Transmitter Test Bench29:42
  • Shift Register VHDL17:25
  • Shift Register Test Bench25:41

    Explore compiling and testing a VHDL shift register using a dedicated test bench. Drive a 50 megahertz clock, instantiate with generics and ports, and verify eight-bit data shifts using simulation.

  • Synchroniser VHDL12:52

    Implement a VHDL synchronizer module using two flip-flops to resynchronize an asynchronous receive signal, with a shift-register approach and a configurable reset state via a generic.

  • Synchroniser Test Bench13:44
  • UART Receiver VHDL46:14
  • UART Receiver Test Bench39:46
  • Summary So Far2:50
  • Top Level Module VHDL28:38
  • Top Level Module Test Bench I25:37
  • Top Level Module Test Bench II35:07
  • Quartus Implementation & Conclusion (FPGA Explorer Development Board)43:34
  • Quartus Implementation (Cyclone IV Development Board)37:16
  • Conclusion (Cyclone IV Development Board)17:32
  • Quartus Project and Dev Board Schematics0:03

Requirements

  • Fundamentals of digital electronics & logic gates
  • Knowledge of binary and hexadecimal number systems

Description

Course Audience :

This course is aimed at students & engineers who want to get into the field of FPGA development using VHDL. No prior knowledge in VHDL/FPGA is assumed so we will start from the very basics.

Students should have a basic knowledge of digital electronics including logic gates and flip-flops.


Course Summary :

This course covers the VHDL language in detail. In between lectures, we will complete a number of fun projects (please see below) with increasing complexity to consolidate the knowledge we have gained during the course. We will go through how to write Test Benches and we will implement a number of Test Benches to verify the UART project. We cover the Intel Quartus software in detail and also go through how to simulate Test Benches using using ModelSim.


Projects (Implemented and Tested On the FPGA Explorer Development Board and the Cyclone IV Development Boards):

1. Reading a switch input and driving an LED output.

2. Simple State Machine which reacts to user input and drives a number of LEDs

3. Synchronising and de-bouncing a Switch Input.

4. Generating a PWM output.

5. Designing a Shift Register.

6. 4 Digit Numeric Display for counting the number of push button activations.

7. UART Module & State machine for echoing characters received from a PC over USB or RS232.


Intel Quartus Softare:

1. Creating & Compiling a new project.

2. Performing pin assignments.

3. Basic introduction to Quartus IP Catalogue.

4. Using the USB Blaster to program the FPGA via JTAG.

5. Using the Quartus Net List Viewer to explore the hardware realisation of your design.

6. Making sense of Quartus Fitter Reports to better understand resource allocation.

7. Using the Quartus Assignment Editor.

8. Overview of Quartus settingsoptions and optimisations.

9. Basic introduction to timing analyser, timing constraints and SDC files.


Intel ModelSim Starter Edition Software :

1. Creating a new ModelSim Project.

2. Writing & compiling Test Benches.

3. Running simulations.

4. Using the Waveform viewer to analyse results.


Course Details :

We will start by covering the basics of FPGA hardware. This hardware background is vital and as we learn how to write VHDL, we will also refer back to how our code gets implemented in hardware.

In the second section of the course, we will cover the VHDL language in detail. We will cover all the aspects (Signals & Data types, VHDL Keywords & Operators, Concurrent & Sequential statements, Entity & Architecture, Process Block, Generics, Constants & Variables, Records, Component Instantiation, Procedures & Functions, Packages & Libraries and Type Conversions) that are needed to be able to develop complex and advanced FPGA designs. There will be plenty of simple examples to allow you to learn the VHDL language quickly and enable you to confidently write your own code. We will also look at how most of the VHDL language maps to hardware on the actual device.

With this strong foundation in the language, we will look at how to build fundamental FPGA blocks starting from Tri-State Drivers, Registers, Comparators, Multiplexers, Shift Registers, Serialisers, RAMs & ROMs and Finite State Machines. We will look at how to code all of the above structures and also explore how these are implemented in real hardware in the FPGA.

In the next section, we will look at hierarchical design with VHDL. This design practise is used when creating complex designs having more than one design unit. We will explore this concept from an example to see how design units can be joined together to form a hierarchical design.

In the next section we will explore good FPGA design practise. From my experience most beginners in FPGA design make common mistakes and fall into certain traps. Some of these can lead to issues that are very difficult to debug and fix. The idea behind this section is to make you aware of these common pitfalls and explore ways in which we can circumvent these. We will talk about Latches, Generated Clocks, Clock & Data Gating, Benefits of a Register Rich Design, Benefits of Synchronous Design, Dealing With Asynchronous Inputs, Clock Domain Crossing, Designing for Reuse, Signal Initialisation, Synchronising Reset De-assertion, Routing Clocks & Resets and Using PLLs.

By this stage, we would have covered a lot of the theory and also completed a number of design projects so you should have the knowledge to create your own FPGA designs independently. We will now cover design verification. This section will explore how to write test benches. We will explore aspects of VHDL coding styles for writing test benches. We will discuss how to perform file IO for creating input vectors and to store output results. We will also discuss self-checking test benches to help automate the test process.

In the final section of the course, we will design a UART module controlled by a State machine. We will write VHDL code to implement the UART and state machine from scratch. We will use a hierarchical design approach where we will have a number of design units. We will write test benches for each design unit and perform simulations (using ModelSim) for verification.  We will bring all design units together into our top level VHDL module and do a system level simulation. Next, we will explore how to create & configure a project in Intel Quartus to implement our design on our FPGA development board. We will look at how to do the pin assignments and also very briefly look at applying very basic timing constraints to get our design to pass. We will then test the design on real hardware to make sure our design works as intended.



Who this course is for:

  • Graduate students looking for a career as an RTL engineer or Design Engineer
  • Electronics engineers/hobbyists who want to get into the field of FPGA design
  • Those interested in FPGA development who are looking for an introductory course
  • Anyone about to embark on their first VHDL design project