

# VHDL

Very High Speed Integrated Circuit  
Hardware Description Language

# Introduction to VHDL

- VHDL is a language that is used to describe the behavior of digital circuit designs
- VHDL provides everything that is necessary in order to describe any digital circuit
- VHDL design can be simulated and translated into a form suitable for hardware implementation
- Hierarchical use of VHDL designs permits the rapid creation of complex digital circuit designs

# Terminology (1)

- Simulation is the prediction of the behavior of a design
  - VHDL provides many features suitable for the simulation of digital circuit designs
  - Functional simulation approximates the behavior of a hardware design by assuming that all outputs change at the same tie
  - Timing simulation predicts the exact behavior of a hardware design
- Synthesis is the translation of a design into a netlist file that describes the structure of a hardware design
  - **VHDL was not designed for the purpose of synthesis**

# Terminology (2)

- Field-Programmable Gate Arrays (FPGAs) are programmable logic devices that permit the rapid prototyping of a digital circuit design
  - Configuring a device allows the FPGA to implement virtually any digital circuit design
  - VHDL designs may be created for the purpose fo generation a bitstream file to configure of a device
- Application-Specific Integrated Circuits (ASICs) are custom integrated circuits designed to implement a specific application
  - VHDL designs may be created for the purpose of generating the detailed layout files necessary to fabricate an ASIC

# VHDL is a hardware-design language

1. When you are working with VHDL, you are ***not programming***, you are “***designing hardware***”.
2. Your VHDL code should reflect this fact. It means that unless you are inside certain constructs, your code lines will be ***executed almost all at once***.
3. If your VHDL code appears too similar to code of a higher-level computer language, it is probably ***bad VHDL code***.  
**This is vitally important.**

# Have a general concept of what your hardware should look like

1. Although VHDL is vastly powerful, if you do not understand basic digital constructs, you will probably be ***unable to generate efficient digital circuits.***
2. Digital design is similar to higher-level language programming in that even the most complicated programming at any level can be broken down into some simple programming constructs. There is a strong analogy to digital design in that even the most complicated digital circuits can be described in terms of basic digital constructs.
3. In other words, if you are not able to roughly envision the digital circuit you are trying to model in terms of basic digital circuits, you will probably ***misuse VHDL***, thus angering the VHDL gods. VHDL is cool, but it is not as magical as it initially appears to be.

# Starting Point of VHDL

- VHDL is not case sensitive
  - ABCD, AbCd, abcd are the same
- VHDL is not sensitive to white space (spaces and tabs)
  - “ab or c” is equal to “ab or c”
- Comments in VHDL begin with the symbol “--”
  - The VHDL synthesizer ignores anything after the two dashes and up to the end of the line in which the dashes appear.
- VHDL is relatively lax (寬鬆) on its requirement for using parentheses
- VHDL statement is terminated with a semicolon (“;”)

# Identifiers (names)

- Identifiers can be as long as you want
- Identifiers can only contain a combination of letters (A-Z and a-z), digits (0-9) and the underscore character (“\_”)
- Identifiers must start with an alphabetic character (A-Z and a-z)
- Identifiers must not end with an underscore (“\_” ) and must never have two consecutive underscores (“\_\_” )

# Reserved Words (1)

---

|              |          |         |           |            |
|--------------|----------|---------|-----------|------------|
| abs          | downto   | library | postponed | srl        |
| access       | else     | linkage | procedure | subtype    |
| after        | elsif    | literal | process   | then       |
| alias        | end      | loop    | pure      | to         |
| all          | entity   | map     | range     | transport  |
| and          | exit     | mod     | record    | type       |
| architecture | file     | nand    | register  | unaffected |
| array        | for      | new     | reject    | units      |
| assert       | function | next    | rem       | until      |
| attribute    | generate | nor     | report    | use        |

# Reserved Words (2)

begin

block

body

buffer

bus

case

component

configuration

constant

disconnect

generic

group

guarded

if

impure

in

inertial

inout

is

label

not

null

of

on

open

or

others

out

package

port

return

rol

ror

select

severity

signal

shared

sla

sll

sra

variable

wait

when

while

with

xnor

xor

# VHDL Example

$$f = (x_1 \bar{x}_2) + (\bar{x}_1 x_2)$$

```
LIBRARY ieee; -- predefined commonly used items
```

```
USE ieee.std_logic_1164.all; -- individual package
```

```
ENTITY light IS
```

```
  PORT ( x1, x2 : IN STD_LOGIC;  
         f : OUT STD_LOGIC );
```

```
END light;
```

```
ARCHITECTURE LogicFunction OF light IS
```

```
BEGIN
```

```
  f <= (x1 AND NOT x2) OR (NOT x1 AND x2);
```

```
END LogicFunction;
```



| x <sub>1</sub> | x <sub>2</sub> | f |
|----------------|----------------|---|
| 0              | 0              | 0 |
| 0              | 1              | 1 |
| 1              | 0              | 1 |
| 1              | 1              | 0 |

# Library

- Libraries provide a set of packages, components, and functions that simplify the task of designing hardware
- Packages provide a collection of related data types and subprograms
- The following is an example of the use of the *ieee* library and its *std\_logic\_1164* package:

```
LIBRARY ieee  
USE ieee.std_logic_1164.all;
```

# Entities

- An entity is a specification of the design's external interface
- Entry declarations specify the following:
  1. Then name of the entity
  2. A set of generic declarations specifying instance-specific parameters



```
entity my_entity is
port(
    port_name_1 : in    std_logic ;
    port_name_2 : out   std_logic;
    port_name_3 : inout std_logic ); --do not forget the semicolon
end my_entity; -- do not forget this semicolon either
```

```
entity mux4 is
port ( a_data      : in      std_logic_vector(0 to 7);
       b_data      : in      std_logic_vector(0 to 7);
       c_data      : in      std_logic_vector(0 to 7);
       d_data      : in      std_logic_vector(0 to 7);
       sel1,sel0   : in      std_logic;
       data_out    : out     std_logic_vector(7 downto 0));
end mux4;
```



# Architecture

- a specification of the design's internal implementation
- can be written by means of three modeling techniques plus any combination of these three. There is the **data-flow model**, the **behavioral model**, the **structural model** and the **hybrid models**.

```
ARCHITECTURE architecture_name OF entity_name IS
BEGIN
    -- Insert VHDL statements to assign outputs to
    -- each of the output signals defined in the
    -- entity declaration.
END architecture_name;
```

# Signal and Variable

## Signal

- Signal
  - represent wires and storage elements
  - may only be defined inside architectures
  - associated with a data type
  - have attributes
- signal sig\_1 : std\_logic;
  - sig\_1 <= A;

## Variable

- Variable
  - represent storage elements
  - used to store local information
  - may only be defined inside process
  - associated with a data type
  - have attributes
- variable var\_1 : integer;
  - var\_1 := 34;

**VHDL is a strongly-typed language**

# Synthesis vs Simulation

- All synthesizable designs can be simulated
- Not all simulation designs can be synthesized
- Consider the following VHDL code:

```
LIBRARY ieee;
USE ieee.std_logic_1164.ALL;

ENTITY simple_buffer IS
    PORT ( din      : IN      std_logic;
           dout     : OUT      std_logic );
END simple_buffer;

ARCHITECTURE behaviourall OF simple_buffer IS
BEGIN
    dout <= din AFTER 10 ns;
END behaviourall;
```

# Synthesis vs Simulation

- The input din is assigned to dout after 10ns
  - Can this represent a real-world system? **YES**
  - Can this be implemented in a device? **PERHAPS**
  - Can this be implemented in all devices? **NO**
- This architecture can be simulated but not synthesized
- Some VHDLdesign entry tools only permit the use of synthesizable keywords
- Most tools understand a synthesizable subset of VHDL93

# Logic Operators

- Logical operators supported by VHDL
  - **AND, OR, NAND, NOR, XOR, XNOR, NOT**
- Relational operators
  - = (equal), /= (not equal), < (less than), > (greater than), <= (less than or equal to), >= (greater than or equal to)
- Mathematical operators
  - + (addition), - (subtraction), \* (multiplication), / (division), **ABS** (absolute value), **MOD** (modulus), **REM** (remainder), \*\* (exponent)
- VHDL also supports the overloading of existing operators and the creation of new operators using functions
  - Different library may provide different operators

# Assignment Statements

```
SIGNAL a, b, c          : std_logic;  
SIGNAL avec, bvec, cvec : std_logic_vector(7 DOWNTO 0);
```

-- Concurrent Signal Assignment Statements

-- NOTE: Both a and avec are produced concurrently

```
a      <= b AND c;  
avec   <= bvec OR cvec;
```

-- Alternatively, signals may be assigned constants

```
a      <= '0';  
b      <= '1';  
c      <= 'Z';  
avec   <= "00111010";           -- Assigns 0x3A to avec  
bvec   <= X"3A";              -- Assigns 0x3A to bvec
```

# Assignment Statements

```
SIGNAL a, b, c, d          :std_logic;
SIGNAL avec                :std_logic_vector(1 DOWNTO 0);
SIGNAL bvec                :std_logic_vector(2 DOWNTO 0);

-- Conditional Assignment Statement
-- NOTE: This implements a tree structure of logic gates
a <=      '0'      WHEN avec = "00" ELSE
                  b      WHEN avec = "11" ELSE
                  c      WHEN d = '1' ELSE
                  '1';

-- Selected Signal Assignment Statement
-- NOTE: Selected signal assignments also work
--       with vectors
WITH a SELECT
      avec <=  "01010101"      WHEN '1',
                                bvec      WHEN OTHERS;

-- Selected Signal Assignment Statement
-- NOTE: The selection values must be constants
bvec <= d & avec;
WITH bvec SELECT
      a <=      '0'      WHEN "000",
                          b      WHEN "011",
                          c      WHEN "1--",
                          '1'      WHEN OTHERS;
```

-- Some tools won't synthesize '-' properly

# EDA PLAYGROUND

EDA Playground lets you type in and run HDL code (using a selection of free and commercial simulators and synthesizers). It's great for learning HDLs, it's great for testing out unfamiliar things and it's great for sharing code.

# EDA Playground account

- <https://www.edaplayground.com/home>
- sign in / log in
  - You can start typing straight away. But to run your code, you'll need to sign or log in. Logging in with a Google account gives you access to all non-commercial simulators and some commercial simulators.
  - To run commercial simulators, you need to register and log in with a username and password. Registration is free, and only pre-approved email's will have access to the commercial simulators.
  - To prevent your validation from being disabled, please supply your company or institution email address. Access will not be granted to freely available email addresses (eg gmail, 126, etc.).
  - You may use your um email account to do registration.

**playground**

New Run Save Resources ▾ Community ▾ Help ▾ Playgrounds ▾ Profile ▾

Brought to you by **DOULOS**  
Doulos does not endorse training material from other suppliers on EDA Playground.

▶ Languages & Libraries

▶ Tools & Simulators ?

▼ Examples

- using EDA Playground
- VHDL
- Verilog/SystemVerilog
- UVM
- EasierUVM
- SVAUnit
- SVUnit
- VUnit (Verilog/SV)
- VUnit (VHDL)
- TL-Verilog
- e + Verilog
- Python + Verilog
- Python Only
- C++/SystemC

211

**testbench.sv** +

```
1 // Code your testbench here
2 // or browse Examples
3
```

**design.sv** +

```
1 // Code your design here
2
```

Hidden menus? Try zooming out (CTRL+mouse wheel) X

**Add more VHDL files (filename.vhd) to your design**

**Test Bench Code here**

**Design Code here**

Log Share

Add a title to help you find your playground

Public (anyone with the link can view) ▾

Save

B I H | “ “ | ☰ ☱ | ?

A short description will be helpful for you to remember your playground's details

The screenshot shows the EDA Playground web-based development environment. It features a split-screen code editor with two tabs: 'testbench.sv' on the left and 'design.sv' on the right. Both tabs have a placeholder line of code: '1 // Code your [tab name] here'. Below the tabs are standard file operations: 'New', 'Run', 'Save', 'Resources', 'Community', 'Help', 'Playgrounds', and 'Profile'. On the left, there's a sidebar with sections for 'Languages & Libraries' (Languages like VHDL, Verilog, UVM, etc.), 'Tools & Simulators', and 'Examples' (including Python and C++). The main workspace has a large red callout text 'Add more VHDL files (filename.vhd) to your design' pointing to the '+' icon in the 'design.sv' tab. At the bottom, there are buttons for 'Log' and 'Share', a title input field, a visibility dropdown set to 'Public', and a 'Save' button. A toolbar at the bottom provides basic text editing functions like bold, italic, and heading. A note at the bottom encourages adding a short description for the playground.

The screenshot shows the EDA playground interface. At the top, there is a navigation bar with 'New', 'Run', and 'Save\*' buttons. Below the navigation bar, the text 'Brought to you by DOULOS' is displayed, followed by a note that Doulos does not endorse training material from other suppliers. On the left side, there is a sidebar titled 'Languages & Libraries' which includes sections for 'Testbench + Design' (set to 'VHDL'), 'Libraries' (with options for 'None', 'OVL', and 'OSVVM'), 'Top entity' (set to 'for simulation ONLY'), and 'Tools & Simulators' (with options for 'Select...', 'Open EPWave after run' checked, 'Show output file after run', and 'Download files after run'). In the main workspace, a file named 'testbench.vhd' is open, containing the following VHDL code:

```
1 -- Code your testbench here
2 Library IEEE;
3 use IEEE.std_logic_1164.all;
```

1. Select VHDL here

2. type your top entity name here  
(the test bench entity name)

3. Select GHDL here

4. Check this option

# EDA Playground Help

- Quick Start
  - Log in. Click the Log in button (top right) Then either
    - click on Google or Facebook or
    - register by clicking on ‘Register for a full account’ (which enables all the simulators on EDA Playground)
  - Select your language from the Testbench + Design menu.
  - Select your simulator from the Tools & Simulators menu. Using certain simulators will require you to supply additional identification information.
  - Type in your code in the testbench and design windows.
  - Click Run.
- Tutorial
  - <http://eda-playground.readthedocs.io/en/latest/tutorial.html>

# EXAMPLE IN EDA PLAYGROUND

3 to 8 decoder

# design.vhd

```
library IEEE;
use IEEE.STD_LOGIC_1164.ALL;

entity decoder3to8 is
Port (a : in STD_LOGIC_VECTOR (2 downto 0);
      y : out STD_LOGIC_VECTOR (7 downto 0));
end decoder3to8;
```

```
architecture Behavioral of decoder3to8 is
begin
  with a select
    y <=  "00000001" when "000",
           "00000010" when "001",
           "00000100" when "010",
           "00001000" when "011",
           "00010000" when "100",
           "00100000" when "101",
           "01000000" when "110",
           "10000000" when "111",
           "00000000" when others;
end Behavioral;
```

# testbench.vhd

```
library IEEE;
use IEEE.STD_LOGIC_1164.ALL;

entity decoder3to8_TB is
end decoder3to8_TB;

architecture Behavioral of decoder3to8_TB is
    component decoder3to8
        Port ( a : in STD_LOGIC_VECTOR (2 downto 0);
                y : out STD_LOGIC_VECTOR (7 downto 0));
    end component;
    signal a : std_logic_vector (2 downto 0);
    signal y : std_logic_vector (7 downto 0);
begin
    UUT: decoder3to8 port map(a=>a, y=>y);
```

```
process is
begin
    a <= "000";
    wait for 10 ns;
    a <= "001";
    wait for 10 ns;
    a <= "010";
    wait for 10 ns;
    a <= "011";
    wait for 10 ns;
    a <= "100";
    wait for 10 ns;
    a <= "101";
    wait for 10 ns;
    a <= "110";
    wait for 10 ns;
    a <= "111";
    wait for 10 ns;
    wait;
end process;
end Behavioral;
```

# Save and “RUN” your design

The screenshot shows the EDA Playground interface with two main code editors and a terminal window.

**Left Editor (testbench.vhd):**

```
library IEEE;
use IEEE.STD_LOGIC_1164.ALL;

entity decoder3to8_TB is
end decoder3to8_TB;

architecture Behavioral of decoder3to8_TB is
component decoder3to8
    Port ( a : in STD_LOGIC_VECTOR (2 downto 0);
           y : out STD_LOGIC_VECTOR (7 downto 0));
end component;
signal a : std_logic_vector (2 downto 0);
signal y : std_logic_vector (7 downto 0);
begin
    UUT: decoder3to8 port map(a=>a, y=>y);
    process is
    begin
        a <= "000";
        wait for 10 ns;
        a <= "001";
        wait for 10 ns;
        a <= "100";
        wait for 10 ns;
        a <= "101";
        wait for 10 ns;
        a <= "110";
        wait for 10 ns;
        a <= "111";
        wait for 10 ns;
        a <= "010";
        wait for 10 ns;
        a <= "011";
    end;
```

**Right Editor (design.vhd):**

```
library IEEE;
use IEEE.STD_LOGIC_1164.ALL;

entity decoder3to8 is
Port ( a : in STD_LOGIC_VECTOR (2 downto 0);
       y : out STD_LOGIC_VECTOR (7 downto 0));
end decoder3to8;

architecture Behavioral of decoder3to8 is
begin
    with a select
        y <=  "00000001" when "000",
              "00000010" when "001",
              "00000010" when "010",
              "00001000" when "011",
              "00010000" when "100",
              "00100000" when "101",
              "01000000" when "110",
              "10000000" when "111",
              "00000000" when others;
end Behavioral;
```

**Terminal Log:**

```
[2024-09-11 02:44:39 UTC] ghdl -i design.vhd testbench.vhd && ghdl -m decoder3to8_TB && ghdl -r decoder3to8_TB --vcd=dump.vcd
analyze testbench.vhd
analyze design.vhd
elaborate decoder3to8_tb
Finding VCD file...
./dump.vcd
[2024-09-11 02:44:40 UTC] Opening EPWave...
```

**Page Footer:**

8-Sep-25  
using EDA Playground  
VHDL

ECEN1011

30

# Simulation result



Brought to you by DOULOS