

## HWP01

### Hardware Programming

Introduction to digital systems And structured digital design

### **Goal of this course**

# Learn to describe **digital circuits** with **VHDL** and implement them in an **FPGA**.



### Instructors

- Ron Verhagen
- Harry Broeders

VeRon@hr.nl

BroJZ@hr.nl



# Organization

- Compulsory attendance
- HWP01 structure:
  - Lecture
    - Five lectures: Monday: 1.5 hour p/w
  - Lab exercise
    - Full-time:
  - Homework
    - 56.5 hours total
    - Theory from the book
      - "Circuit Design with VHDL" (Third Edition)
      - Volnei A. Pedroni
      - ISBN 978-0-262-04264-2
    - Preparing assignments / writing code
    - Making simulations at home / outside regular class times



Tuesday: 2.5 hours Online p/w

# **Planning: theory**

#### • First week

- Introduction digital systems
- Introduction to FPGAs
- Structured digital Design
- Modeling concepts in VHDL

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

- Fifth week
  - Designing state
    - machines
  - AdvancedVHDL design

- Second week
  - Introduction VHDL
  - Code structure
  - Data types

- Fourth week
  - Introduction to state machines



# Earning your grade

### In the course manual you will find the the following

|        | Action                                                                                                                                                                                       | Completed     |
|--------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------|
| Step 1 | Complete all 5 Labs before starting on your final assignment                                                                                                                                 | Yes           |
| Step 2 | Final Assignment (FA) ingredients:                                                                                                                                                           | % (leerdoel)  |
| 2.1    | Architecture (schematics and drawings) with basic ** functionality                                                                                                                           | 20% (LD1)     |
| 2.2    | VHDL code of all architectural functions and justification in report                                                                                                                         | 40% (LD2,LD3) |
| 2.3    | A functional VHDL Test Bench                                                                                                                                                                 | 20% (LD4)     |
| 2.4    | A working FPGA prototype with the basic**<br>functionality                                                                                                                                   | 20% (LD5)     |
|        | ** basic functionality (complexity) may be<br>expanded to include additional features for a higher<br>grade. This is agreed upon before starting this<br>assignment. Basic functionality = 7 |               |
| HT1    | Retake                                                                                                                                                                                       |               |



### Agenda

- Introduction to digital systems and FPGAs
- Structured digital design
- Modelling concepts in VHDL



# **Computing realization**

- Software programmed processors: software flexibility, fixed instructions and performance is limited
- Application Specific Integrated Circuits (ASIC): expensive, time consuming, best performance.
- **Reconfigurable computing:** high flexibility, good performance and fills the gap between hardware and software. This is the domain of FPGAs.



### Digital Logic: 1980's vs today FPGA





#### HOGESCHOOL ROTTERDAM

#### Field-programmable Gate Array (FPGA)

# **Transistor count for key FPGA families**

| FPGA ÷                                      | Transistor count \$ | Date of introduction \$ | Manufacturer 🔶          | Process + |
|---------------------------------------------|---------------------|-------------------------|-------------------------|-----------|
| Virtex                                      | ~70,000,000         | 1997                    | Xilinx                  |           |
| Virtex-E                                    | ~200,000,000        | 1998                    | Xilinx                  |           |
| Virtex-II                                   | ~350,000,000        | 2000                    | Xilinx                  | 130 nm    |
| Virtex-II PRO                               | ~430,000,000        | 2002                    | Xilinx                  |           |
| Virtex-4                                    | 1,000,000,000       | 2004                    | Xilinx                  | 90 nm     |
| Virtex-5                                    | 1,100,000,000       | 2006                    | Xilinx                  | 65 nm     |
| Stratix IV                                  | 2,500,000,000       | 2008                    | Altera                  | 40 nm     |
| Stratix V                                   | 3,800,000,000       | 2011                    | Altera                  | 28 nm 💙   |
| Arria 10                                    | 5,300,000,000       | 2014                    | Altera                  | 20 nm     |
| Virtex-7                                    | 6,800,000,000       | 2011                    | Xilinx                  | 28 nm     |
| Stratix 10 Family device, 10GX5500/10SX5500 | 17,000,000,000      | 2017                    | Intel (formally Altera) | 14 nm     |
| Virtex-Ultrascale XCVU440                   | 20,000,000,000+     | 2014                    | Xilinx                  | 20 nm     |
| Everest                                     | 50,000,000,000      | 2018                    | Xilinx                  | 7 nm      |

Source: <a href="https://www.napatech.com/road-to-fpga-reconfigurable-computing/">https://www.napatech.com/road-to-fpga-reconfigurable-computing/</a> 2018



# Comparison

### Field-programmable Gate Array (FPGA)

Not only is the performance of FPGAs and other logic devices becoming more formidable, these devices are incorporating functions typically performed by other types of logic, CPUs, GPUs, and DSPs. They're the semiconductor versions of the Swiss Army Knife.

### Microcontrollers vs. FPGA's

| uController                                                                         | FPGA                                                                                                       |
|-------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------|
| Programming languages (C, C++, Assembly)<br>Optimized for general purpose computing | Programming Languages VHDL,<br>Verilog, Open Computing Language;<br>Or use Schematics                      |
| Control over the Software;<br>10's to 100's of cores.                               | Control over the Hardware;<br>Hardware timed execution;<br>millions of progammable digital logic<br>cells. |
| Predefined instruction set and datapath widths                                      | No predefined instruction set or datapath widths                                                           |
| Reprogrammable - unlimited                                                          | Reconfigurable - unlimited                                                                                 |



|                                 | Microcontroller                        | FPGA                                                          | ASIC                                  |
|---------------------------------|----------------------------------------|---------------------------------------------------------------|---------------------------------------|
| Clock speed<br>(frequency)      | Can be very high<br>(Up to 4 GHz)      | Average (up to 0.7 GHz)                                       | Can be very high (several<br>GHz)     |
| Throughput (data per second)    | Limited                                | Can be very high                                              | Highest                               |
| Power<br>consumption            | Low                                    | High                                                          | Low                                   |
| Cost                            | 0.3 \$ ~ 2000 \$                       | 3 \$ ~ 2000 \$                                                | From \$1.000.000 NRE                  |
| HW flexibility<br>(design time) | Low                                    | High                                                          | High                                  |
| HW flexibility (run<br>time)    | Low                                    | High                                                          | Low                                   |
| Peripherals                     | Limited to what IC manufacturers offer | Many, as long as pins<br>and logic elements are<br>available. | Many, as long as physically possible. |
| Behavior                        | Almost exclusively sequential          | Sequential or concurrent                                      | Sequential or concurrent              |
| Potential<br>parallelism        | Low for most single-<br>cores          | High                                                          | High                                  |

# Technology

FPGA's are designed to function like any digital component. In order to support this programability, FPGA-chips contain the following 3 building blocks:





### Technology – Logic Blocks

### A basic logic building block is the Logic Element

XOR

In A

1

In B

0

0

1

Out

0

1

| AND |      |      |     | NAND |      |      |
|-----|------|------|-----|------|------|------|
|     | In A | In B | Out | 200  | In A | In I |
|     | 0    | 0    | 0   | 8    | 0    | 0    |
|     | 1    | 0    | 0   |      | 1    | 0    |
|     | 0    | 1    | 0   | 8    | 0    | 1    |
|     | 1    | 1    | 1   |      | 1    | 1    |

| R |      |     | NOR  | NOR  |     |  |  |
|---|------|-----|------|------|-----|--|--|
| Α | In B | Out | In A | In B | Out |  |  |
| D | 0    | 0   | 0    | 0    | 1   |  |  |
| L | 0    | 1   | 1    | 0    | 0   |  |  |
| D | 1    | 1   | 0    | 1    | 0   |  |  |
| 1 | 1    | 1   | 1    | 1    | 0   |  |  |

In

Synthesis (programmed into the LUT)

| LUT |   |    |        |  |
|-----|---|----|--------|--|
| Α   | В | CF | OUTPUT |  |
| 0   | 0 | Х  | 0      |  |
| 0   | 1 | Х  | 1      |  |
| 1   | 0 | Х  | 1      |  |
| 1   | 1 | Х  | 0      |  |



If we bypass the flip-flop using the multiplexer, what is the function of this Logic Element?



### **Technology - Interconnections**





### THE DE1 DEVELOPMENT BOARD

#### DE1-SoC

- \$377 USD
- Cyclone V SoC FPGA

#### Dual-core ARM Cortex-A9

- 1GB DDR 3 SDRAM, MicroSD
- USB, Triple-speed Ethernet
- ADC, Accelerometer
- LED, Pushbutton

#### FPGA

- 85K Programmable Logic Elements
- 64 MB SDRAM
- DVD-quality audio in/out, Video in/VGA out
- PS/2, IrDA
- 4 debounced pushbuttons, 10 slider switches, 10 red LEDs, six 7-segment displays
- Expansion headers

#### Built-in USB Blaster for FPGA programming





12 © 2014 Altera Corporation-Public

### Agenda

- Introduction to digital systems and FPGAs
- Structured digital design
- Modelling concepts in VHDL



# Structured digital design

- Determine the function you want to perform
  Architecture
- Find a method to implement the function
   Implementation
- Use tools to materialize the method
  - Realization
- Verify your design
  - Simulation and evaluation



### **Example VHDL code**



1. Import the necessary libraries

2. An entity block is the beginning building block of a VHDL design. Each design has only one entity block which describes the interface signals into and out of the design unit.

3. Architecture block defines how the entity operates using Structural or Behavioral Code. This example is using behavioral code.

### **From VHDL to FPGA**









## **Structural decomposition**

- Top-down design: no constraints on the availability of hardware
- Bottom-up design: design is conditioned by what's available (e.g., the number of gates)
- Typical dimensions for the Digital Design Space: speed, chip area (cost), power



### Agenda

- Introduction to digital systems and FPGAs
- Structured digital design
- Modelling concepts in VHDL



# **Simplified VHDL Design Flow**



HR EAS ELE HWP01 WK1 V1.2



# **Modeling concepts in VHDL**

- Two abstract models to describe your design in VHDL
- Behavioral Model:
  - Less specific about how digital function(s) will actually be connected together.
  - Register Transfer level (RTL): synthesizable, has an explicit clock
  - Algorithmic level: (almost always) unsynthesizable, especially when there is no notion of a clock and no delays between internal functions are defined.
- Structural Model:
  - Gate level: oldest digital logic design method. You, the designer, do all the work.
  - Wider use of "portmap"



### **Modeling abstractions**



Figure adapted from VHDL Design Representation and Synthesis.



# From VHDL to FPGA

### 1. Synthesize

- Simulate (Analysis & Elaboration)
- Compiles code into RTL (Register Transfer Level) schematic. Always take a look at this



# From VHDL to FPGA

### 2. Place and Route

- How to configure the FPGA elements to become the functional equivalent of the RTL schematic?
- Find the optimal paths through the FPGA
- Timing analysis



- 3. Generate bitstream
  - Contains the setting of every switch in the FPGA





## **Design verification**

- Check if your realization matches your expectations.
- In VHDL we use test benches to verify the results.
- In this course you will create test benches to verify your designs.
- In (simple) simulations we don't know if the actual design meets timing constraints. We will discuss this later.



### Homework

- Covered today:
  - Introduction to digital design and FPGAs
  - Structured design
  - Modeling concepts in VHDL
- Team up with another student
- Start working on the laboratory
- <u>https://nandland.com/fpga-101/</u>
- <u>https://fpgatutorial.com/vhdl/</u>
- Useful:
  - Chapter 5 "Introduction to VHDL"
  - Chapter 6 "Code Structure and Composition"
- Next week (for reference):
  - Chapter 7 and 8 "Datatypes"
  - Chapter 9 "Operators"
  - Chapter 18 "Introduction to Simulation with Testbenches"



### First week: Lab

- Introductory Assignment 1
  - Getting to know Quartus
  - Getting to know ModelSim
  - Getting to know the DE1 SoC development and Education
    Board



