

# Hardware Programming HWP01

capturing a FPGA design with VHDL

# **Planning: theory**

- First week
  - Introduction digital systems
  - Structured digital Design
  - RTL

- Second week
  - Introduction VHDL
  - Code structure and data types
  - Design verification

Third week

- Combinational versus sequential design
- Concurrent and sequential code
- Signals and variables

Fourth week – Introduction to state machines

Fifth week

•

- Designing state machines
- Advanced
   VHDL design



#### Agenda

- Discussion of previous week
- Combinational versus sequential design
- Concurrent and sequential code
- Signals versus variables





#### Agenda

- Discussion of previous week
- Combinational versus sequential design
- Concurrent and sequential code
- Signals versus variables

## Combinational and sequential logic (1/2)

• Combinational: **no** memory



- The output is a function only of the current inputs.
- In any implementation there is a *propagation delay* For this course, we don't consider the propagation delay.



## Combinational and sequential logic (2/2)

• Sequential logic:



- The output of sequential logic, is ...
- ... a function of a *sequence* of operations ...
- ... on current and/or *previous inputs*.
- Advantages?



### **Combinational vs. sequential logic example**





#### **Combinational or sequential?**

- Multiplexer vs. Synchronized Multiplexer?
- Timer?
- Encoder (for example binary to 7-seg display)?
- Comparators?
- Adder?
- Multiplier?
- ALU?
- CPU?
- Register?



#### Agenda

- Discussion of previous week
- Combinational versus sequential design
- Concurrent and sequential code
- Signals versus variables



#### **Concurrent Code**

- concurrent code is intended only for combinational circuits.
  - often used for structural descriptions of a circuit.
- outputs activated asynchronously, at any time.
- statements for concurrent code:
  - when ... else
  - with ... select
  - generate
- can be placed outside **process**, **function** and **procedure**



## WITH/SELECT

- with ... select is used very often
- read: depending on sel, y becomes a when sel is 00, y becomes b when sel is 01, etc...
- note the usage of the others keyword here to cover all possibilities



```
architecture mux2 of mux is
begin
  with sel select
  y <= a when "00", -- use "," not ";"
        b when "01",
        c when "10",
        d when others;
end mux2;</pre>
```



### WHEN/ELSE



- Read: when sel is equal to "00", y obtains the value of a, else when sel is equal to "01", y obtains the value of b, etc...
- Cover all combinations
- Let the synthesizer do the K-map for us!
- Lijkt op een priority encoder



#### Difference





#### **Synchronized Multiplexer**

```
library ieee;
use ieee.std logic 1164.all;
entity synced mux is
  port (a, b, c, d, clk: in std logic;
         sel : in std logic vector (1 downto 0);
         y : out std logic);
end gated mux;
architecture behavioral of synced mux is
       signal x: std logic;
begin
       with sel select
               x <= a when "00", -- use "," not ";"</pre>
                                                         DFF
               b when "01",
               c when "10",
                                               MUX
                                                   Х
                                                         DQ
               d when others;
process (clk)
begin
                                                   clk-
       if rising edge(clk) then
       y \leq x;
end process
end architecture
                                           sel(1..0)
```



#### **Sequential Code**

- statements for sequential code:
  - if
  - wait
  - loop
  - case
- sequential code can be used to design both sequential and combinational circuits
- code within a process, function or procedure is sequential.



#### **Sequential Code**

- process is a sequential section, located in the architecture
- note that multiple processes are allowed. they are concurrent to each other.
- support for the following *sequential* statements:
  - if
  - wait
  - loop
  - case
  - with (since 2008)
  - when (since 2008)



#### **Sequential Code Circuit Examples**





#### **Multiplexer with sequential code**



- A process has a sensitivity list
- The outputs of the process get updated if the value of an object in the list changes

```
library ieee;
use ieee.std logic 1164.all;
entity seq code mux is
  port (a, b, c, d: in std logic;
                          std logic vector (1 downto 0);
                    : in
         sel
                    : out std logic);
         V
end seq code mux;
architecture seq code impl of seq code mux is
begin
         process(sel,a,b,c,d)
         begin
                   if
                         sel = "00" then
                       v \leq a;
                   elsif sel = "01" then
                       y \leq b;
                   elsif sel = "10" then
                       y \leq c;
                   else
                       y \leq d;
                   end if:
         end process;
end seq code impl;
```



#### **Multiplexer with CASE**

```
library ieee;
use ieee.std logic 1164.all;
                             _____
entity seq code mux is
  port (a, b, c, d: in std logic;
         sel : in std logic vector (1 downto 0);
        y : out std logic);
end seq code mux;
architecture seq code impl of seq code mux is
begin
         process(sel,a,b,c,d)
         begin
                  case sel is
                           when "00" =>
                                   y <= a;
                           when "01" =>
                                    y \leq b;
                           when "10" =>
                                    v \leq c;
                           when others =>
                                    y \leq d;
                  end case;
         end process;
end seq code impl;
```



#### Difference





#### **D** Flip-Flop



```
library ieee;
use ieee.std_logic_1164.all;
entity dff example is
  port (
            clk: in std logic;
            d,r: in std logic;
            q : out std logic
         );
end dff example;
architecture dff implementation of dff example is
begin
    process(clk, r )
    begin
        if r = '1' then
            q <= '0';
        elsif rising edge(clk) then
            q \leq d;
        end if;
    end process;
end dff implementation;
```



#### **Technology Map of DFF**

Sequential circuits can only be written with sequential code





#### **Up/down counter**

```
library ieee;
use ieee.std logic_1164.all;
use ieee.numeric_std.all;
entity updown is
         generic (
                   counter_width : integer := 31
         );
         port (
                   clk
                                      : in std ulogic;
                   rst
                                      : in std_ulogic;
                   up_ndown : in std_ulogic;
                   count_out: out std_ulogic_vector(counter_width downto 0)
         );
end updown;
```



#### **Up/down counter**

```
architecture arch of updown is
          variable count : unsigned(counter_width downto 0);
begin
          process(clk)
          begin
                    if rising_edge(clk) then
                              if rst = '1' then
                                        count <= (others => '0');
                              else
                                        if up_ndown = '1' then
                                                  count <= count + 1;</pre>
                                        else
                                                  count <= count - 1;</pre>
                                        end if;
                              end if;
                    end if;
          end process;
```

count\_out <= std\_ulogic\_vector(count);</pre>

#### end arch;

| ✓ /updown/dk          | 0          |   |   |   |     |   |   |   |    |   |   |   |   |   |   |   |    |    |
|-----------------------|------------|---|---|---|-----|---|---|---|----|---|---|---|---|---|---|---|----|----|
| 🔷 /updown/rst         | 0          |   |   |   |     |   |   |   |    |   |   |   |   |   |   |   |    |    |
| 🁍 /updown/up_ndown    | 0          |   |   |   |     |   |   |   |    | 1 |   |   |   |   |   |   |    |    |
| 💶 🛧 /updown/count_out | 8589934591 | Х | 0 | Ľ | 1   | 2 | 3 | 4 | (5 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | (8 |    |
| 💶 - 🔷 /updown/count   | 8589934591 | Х | 0 | Ľ | 1   | 2 | 3 | 4 | (5 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | (8 | 3. |
|                       |            |   |   |   | 2.6 |   |   |   |    |   |   |   |   |   |   |   |    |    |

#### WAIT

- In a **process** you can use the **wait** keyword
- A process CANNOT have both a sensitivity list and wait statements
- Three types:
  - wait until condition
  - wait on sig1, sig2, ..., sign (sensitivity list)
  - wait for time
- wait for cannot be synthesized; only for simulation and test benches



#### **D Flip-Flop with WAIT**





#### **Loops in VHDL**

- for and while loops
- for ... loop repeats until the upperbound is reached
- static bounds; use constants to specify the upper bound of your loop

```
process(sel)
...
begin
for i in 0 to 5 loop
    x <= i;
end loop;
end process;</pre>
```



#### **Loops in VHDL**

- while ... loop is similar in structure as the for ... loop
- see page 161 of your book for some examples with loops

```
process(sel)
...
begin
while i<10 loop
...do something...
end loop;
end process;</pre>
```



#### Agenda

- Discussion of previous week
- Combinational versus sequential design
- Concurrent and sequential code
- Signals versus variables



#### Signals versus variables

#### SIGNAL

- Is eigenlijk een verbinding of draadje
- Bedoeld om data over te brengen tussen verschillende blokken zoals concurrent statements en processen

#### • VARIABLE

- Is meer een abstracte waarde
- Het wordt gebruikt om iets te onthouden binnen een process



#### Signals versus variables

#### • **SIGNAL** properties:

- Can ONLY be declared outside a process but can be used within a process
- Within sequential code the signal is not 'updated immediately' (at the end of the process)
- Only a *single* assignment is allowed to a signal in the whole code (multiple assignments in processes are fine, but only the last one will be effective!)

#### • VARIABLE properties:

- Can ONLY be declared inside a process
- Is 'updated immediately' and can be used in the next line of code
- Multiple assignments are not a problem



#### **Summary**

- Combinational versus sequential design: no memory versus memory.
- In VHDL we can model combinational circuits with sequential statements
- Remember the differences between signals and variables



#### Homework

- Covered today:
  - Discussion of previous week
  - Combinatorial versus sequential design
  - Concurrent and sequential design
  - Signals versus variables
- Next week:
  - Chapter 12 (13) 'Sequential Code'
    - ! Chapter 12.9 'SIGNAL and VARIABLE'
  - Chapter 14.3 14.5 'FUNCTION and PROCEDURE'

