# VHDL Quick Start

Peter J. Ashenden

The University of Adelaide

Abridged by Roozbeh Jafari rjafari@cs.ucla.edu

# **Basic VHDL Concepts**

- Interfaces
- · Behavior
- Structure
- Test Benches
- Analysis, elaboration, simulation
- Synthesis

© 1998, Peter J. Ashenden

VHDL Quick Start

# Modeling Digital Systems

- VHDL is for writing models of a system
- · Reasons for modeling
  - requirements specification
  - documentation
  - testing using simulation
  - formal verification
  - synthesis
- Goal
  - most reliable design process, with minimum cost and time
  - avoid design errors!

© 1998, Peter J. Ashenden

VHDL Quick Start

# **Modeling Interfaces**

- Entity declaration
  - describes the input/output *ports* of a module

```
entity reg4 is
port (d0, d1, d2, d3, en, clk: in bit;
q0, q1, q2, q3: out bit);
end entity reg4;

reserved words

port names
port mode (direction)
punctuation
```

© 1998, Peter J. Ashenden

VHDL Quick Start

#### VHDL-87

• Omit entity at end of entity declaration

```
entity reg4 is

port ( d0, d1, d2, d3, en, clk : in bit;

q0, q1, q2, q3 : out bit );

end reg4;
```

© 1998, Peter J. Ashenden

VHDL Quick Start

5

# **Modeling Behavior**

- Architecture body
  - describes an implementation of an entity
  - may be several per entity
- Behavioral architecture
  - describes the algorithm performed by the module
  - contains
    - process statements, each containing
    - sequential statements, including
    - · signal assignment statements and
    - wait statements

© 1998, Peter J. Ashenden

VHDL Quick Start

# Behavior Example

```
architecture behav of reg4 is
begin
   storage : process is
       variable stored_d0, stored_d1, stored_d2, stored_d3 : bit;
   begin
       if en = '1' and clk = '1' then
          stored_d0 := d0;
          stored_d1 := d1;
          stored d2 := d2:
          stored d3 := d3:
       q0 <= stored_d0 after 5 ns;
       q1 <= stored_d1 after 5 ns;
       q2 <= stored_d2 after 5 ns;
       q3 <= stored_d3 after 5 ns;
       wait on d0, d1, d2, d3, en, clk;
   end process storage;
end architecture behav;
```

© 1998, Peter J. Ashenden

VHDL Quick Start

# VHDL-87

- Omit **architecture** at end of architecture body
- Omit is in process statement header

```
architecture behav of reg4 is begin storage : process ... begin ... end process storage; end behav;
```

© 1998, Peter J. Ashenden

VHDL Quick Start

# **Modeling Structure**

- Structural architecture
  - implements the module as a composition of subsystems
  - contains
    - signal declarations, for internal interconnections
      - the entity ports are also treated as signals
    - component instances
      - instances of previously declared entity/architecture pairs
    - port maps in component instances
      - connect signals to component ports
    - wait statements

© 1998, Peter J. Ashenden

entity d latch is

VHDL Quick Start

9

# 

# Structure Example

First declare D-latch and and-gate entities and architectures

```
end entity d_latch;

architecture basic of d_latch is begin

latch_behavior : process is begin

if clk = '1' then

q <= d after 2 ns;
end if;
wait on clk, d;
end process latch_behavior;
```

port (d, clk: in bit; q: out bit);

```
entity and2 is
   port (a, b: in bit; y: out bit);
end entity and2;

architecture basic of and2 is
begin
   and2_behavior: process is
begin
   y <= a and b after 2 ns;
   wait on a, b;
end process and2_behavior;
end architecture basic;
```

© 1998, Peter J. Ashenden

end architecture basic;

VHDL Quick Start

#### Structure Example

• Now use them to implement a register

```
architecture struct of reg4 is
signal int_clk : bit;
begin
bit0 : entity work.d_latch(basic)
port map ( d0, int_clk, q0 );
bit1 : entity work.d_latch(basic)
port map ( d1, int_clk, q1 );
bit2 : entity work.d_latch(basic)
port map ( d2, int_clk, q2 );
bit3 : entity work.d_latch(basic)
port map ( d3, int_clk, q3 );
gate : entity work.and2(basic)
port map ( en, clk, int_clk );
end architecture struct;
```

© 1998, Peter J. Ashenden

VHDL Quick Start

#### VHDL-87

- Can't directly instantiate entity/architecture pair
- Instead
  - include component declarations in structural architecture body
    - templates for entity declarations
  - instantiate components
  - write a configuration declaration
    - binds entity/architecture pair to each instantiated component

© 1998, Peter J. Ashenden

VHDL Quick Start

13

# Structure Example in VHDL-87

First declare D-latch and and-gate entities and architectures

```
entity d_latch is
                                          entity and2 is
   port (d, clk: in bit; q: out bit);
                                             port (a, b: in bit; y: out bit);
end d latch;
                                          end and2;
architecture basic of d_latch is
                                          architecture basic of and2 is
begin
                                          begin
   latch_behavior : process
                                             and2_behavior: process
   begin
       if clk = '1' then
                                                y <= a and b after 2 ns;
           q <= d after 2 ns;
                                                 wait on a, b;
       end if:
                                             end process and2_behavior;
       wait on clk, d;
                                          end basic;
   end process latch_behavior;
end basic;
```

VHDL Quick Start

. . . .

# Structure Example in VHDL-87

• Declare corresponding components in register architecture body

```
architecture struct of reg4 is
component d_latch
port ( d, clk : in bit; q : out bit );
end component;
component and2
port ( a, b : in bit; y : out bit );
end component;
signal int_clk : bit;
```

© 1998, Peter J. Ashenden

VHDL Quick Start

# Structure Example in VHDL-87

• Now use them to implement the register

```
...

begin

bit0 : d_latch
    port map ( d0, int_clk, q0 );

bit1 : d_latch
    port map ( d1, int_clk, q1 );

bit2 : d_latch
    port map ( d2, int_clk, q2 );

bit3 : d_latch
    port map ( d3, int_clk, q3 );

gate : and2
    port map ( en, clk, int_clk );

end struct;
```

© 1998, Peter J. Ashenden

© 1998, Peter J. Ashenden

VHDL Quick Start

# Structure Example in VHDL-87

• Configure the register model

```
configuration basic_level of reg4 is
for struct
for all : d_latch
    use entity work.d_latch(basic);
end for;
for all : and2
    use entity work.and2(basic)
end for;
end for;
end for;
end basic_level;
```

© 1998, Peter J. Ashenden

VHDL Quick Start

17

#### Mixed Behavior and Structure

- An architecture can contain both behavioral and structural parts
  - process statements and component instances
    - collectively called *concurrent statements*
  - processes can read and assign to signals
- Example: register-transfer-level model
  - data path described structurally
  - control section described behaviorally

© 1998, Peter J. Ashenden

VHDL Quick Start

# Mixed Example multiplier multiplicand shift\_reg control section reg product © 1998, Peter J. Ashenden VHDL Quick Start 19

# Mixed Example

```
entity multiplier is
        port ( clk, reset : in bit;
                multiplicand, multiplier: in integer;
                product : out integer );
    end entity multiplier;
    architecture mixed of mulitplier is
        signal partial_product, full_product : integer;
        signal arith_control, result_en, mult_bit, mult_load : bit;
        arith_unit: entity work.shift_adder(behavior)
            port map ( addend => multiplicand, augend => full_product,
                        sum => partial product,
                        add_control => arith_control );
        result : entity work.reg(behavior)
            port map ( d => partial_product, q => full_product,
                        en => result_en, reset => reset );
© 1998, Peter J. Ashenden
                                      VHDL Quick Start
                                                                            20
```

# Mixed Example

```
...
multiplier_sr: entity work.shift_reg(behavior)
port map ( d => multiplier, q => mult_bit,
load => mult_load, clk => clk );
product <= full_product;
control_section: process is
-- variable declarations for control_section
-- ...
begin
-- sequential statements to assign values to control signals
-- ...
wait on clk, reset;
end process control_section;
end architecture mixed;
```

© 1998, Peter J. Ashenden

VHDL Quick Start

21

23

#### **Test Benches**

- Testing a design by simulation
- Use a test bench model
  - an architecture body that includes an instance of the design under test
  - applies sequences of test values to inputs
  - monitors values on output signals
    - either using simulator
    - or with a process that verifies correct operation

© 1998, Peter J. Ashenden

VHDL Quick Start

22

# Test Bench Example

```
entity test_bench is
      end entity test_bench;
      architecture test_reg4 of test_bench is
          signal d0, d1, d2, d3, en, clk, q0, q1, q2, q3 : bit;
      begin
          dut : entity work.reg4(behav)
              port map ( d0, d1, d2, d3, en, clk, q0, q1, q2, q3 );
          stimulus: process is
              d0 <= '1'; d1 <= '1'; d2 <= '1'; d3 <= '1'; wait for 20 ns;
              en <= '0'; clk <= '0'; wait for 20 ns;
              en <= '1'; wait for 20 ns;
              clk <= '1'; wait for 20 ns;
              d0 \le '0'; d1 \le '0'; d2 \le '0'; d3 \le '0'; wait for 20 ns;
              en <= '0'; wait for 20 ns;
              wait:
          end process stimulus;
      end architecture test_reg4;
                                       VHDL Quick Start
© 1998, Peter J. Ashenden
```

# **Design Processing**

- Analysis
- Elaboration
- Simulation
- Synthesis

© 1998, Peter J. Ashenden

VHDL Quick Start

# Analysis

- Check for syntax and semantic errors
  - syntax: grammar of the language
  - semantics: the meaning of the model
- Analyze each design unit separately
  - entity declaration
  - architecture body
  - **–** ...
  - best if each design unit is in a separate file
- Analyzed design units are placed in a *library* 
  - in an implementation dependent internal form
  - current library is called work

© 1998, Peter J. Ashenden

VHDL Quick Start

25

#### Elaboration

- "Flattening" the design hierarchy
  - create ports
  - create signals and processes within architecture body
  - for each component instance, copy instantiated entity and architecture body
  - repeat recursively
    - bottom out at purely behavioral architecture bodies
- Final result of elaboration
  - flat collection of signal nets and processes

© 1998, Peter J. Ashenden

VHDL Quick Start

26

# Elaboration Example



© 1998, Peter J. Ashenden

VHDL Quick Start

# Elaboration Example



© 1998, Peter J. Ashenden

VHDL Quick Start

#### Simulation

- Execution of the processes in the elaborated model
- Discrete event simulation
  - time advances in discrete steps
  - when signal values change—events
- A processes is sensitive to events on input signals
  - specified in wait statements
  - resumes and schedules new values on output signals
    - schedules transactions
    - event on a signal if new value different from old value

© 1998, Peter J. Ashenden

VHDL Quick Start

29

#### Simulation Algorithm

- Initialization phase
  - each signal is given its initial value
  - simulation time set to 0
  - for each process
    - activate
    - execute until a wait statement, then suspend
      - execution usually involves scheduling transactions on signals for later times

© 1998, Peter J. Ashenden

VHDL Quick Start

# Simulation Algorithm

- Simulation cycle
  - advance simulation time to time of next transaction
  - for each transaction at this time
    - update signal value
      - event if new value is different from old value
  - for each process sensitive to any of these events, or whose "wait for ..." time-out has expired
    - · resume

© 1998, Peter J. Ashenden

• execute until a wait statement, then suspend

VHDL Quick Start

Simulation finishes when there are no further scheduled transactions

2

© 1998, Peter J. Ashenden

VHDL Quick Start

22

Synthesis

- Translates register-transfer-level (RTL) design into gate-level netlist
- Restrictions on coding style for RTL model
- Tool dependent
  - Altera, Xilinx

