In short, VHDL is a computer language used for designing digital circuits.

I use the term “computer language” to distinguish VHDL from other, more common programming languages like Java or C++. But is VHDL a programming language? Yes, it is. It’s a programming language which is of no use when it comes to creating computer programs!

VHDL is an event driven, parallel programming language. While it isn’t suitable for creating programs that can be run by a CPU on a computer, it’s great for creating the actual CPU. It’s a Hardware Description Language, which means that it can be used for the designing digital logic.

Access the Basic VHDL Tutorials series here!

CPU - physical implementation - logical schematic

Consider the above illustration. Inside the CPU chip there are lots and lots of mostly digital electronic circuits (middle). These digital circuits can be shown using a schematic diagram (right). When creating an integrated circuit chip, like the CPU, we have to start by creating the logical circuit diagram to the right.

It’s a fair assumption that such circuit diagrams are created in some kind of schematic editor, but this isn’t how it’s done. The circuits are described in a textual language like VHDL.


Instead of drawing the exact circuits in a schematic editor, we use VHDL to describe the desired behavior of the circuit. The VHDL code can then be converted into an exact schematic in a process called synthesis. The synthesis tool is a software application which takes the VHDL code and tries to find a possible solution to the behavior you have described.

VHDL synthesis

If successful, the output from the synthesizer will be a netlist which in turn can be viewed in a schematic editor.

Place and Route

While the netlist gives an exact logical description of the circuit, it doesn’t say anything about the physical implementation. To derive a precise description of the physical layout, the netlist is run through a process called place and route, or PAR for short. The router will try to allocate the elements from the netlist to physical components on the target device. It also needs to route wires between all the components. It’s a giant puzzle which the router has to solve!

Place and Route

If successful, the output from PAR will be another kind of netlist. This netlist contains placement and routing info, and is specific for the target device type. If the target device is an FPGA, the routed netlist can be converted into a programming file. If the target device is an ASIC, things will be a bit more complicated.

So, What is VHDL?

It’s a sort of programming language which is used for creating digital logic for integrated circuits.

Take the basic VHDL tutorials here >>

Author: Jonas Julian Jensen

I’m from Norway, but I live in Bangkok, Thailand. Before I started VHDLwhiz, I worked as an FPGA engineer in the defense industry. I earned my master’s degree in informatics at the University of Oslo.

Leave a Reply

Your email address will not be published. Required fields are marked *

This site uses Akismet to reduce spam. Learn how your comment data is processed.