# Introduction to FPGA Design using Quartus

Intel Programmable Solutions Group Larry Landis Senior Manager University Outreach



- Larry Landis University Outreach Senior Manager, Intel Programmable Solutions Group
- 36 years in electronics industry design, sales, marketing, training (Altera 2004)
- Adjunct Lecturer for Digital Electronics Course Santa Clara University



BSEE





**MSEE** 







**Adjunct Lecturer** 



#### Best Practices for Remote Training

- Mute your microphone unless you are speaking
- Be aware if your audio is in the main or your breakout lab room (if that is begin used)
- Don't be shy ... Please ask lots of questions and you can move through lab quickly! If you wait too long on something you are unsure you might have to backtrack steps.

#### Topics

- FPGAs at Intel
- Fundamentals of Digital Electronics
- FPGA Architecture
- Intel<sup>®</sup> Quartus<sup>®</sup> Prime Design Software
- FPGA Design Flow

#### Field Programmable Gate Array (FPGA)

Small













- Flexible, multi-functional reprogrammable silicon
- Custom hardware functionality
- Bare-metal speed and reliability
- Truly parallel in nature

#### Benefits of FPGA Technology

- **Flexibility**
- Time to market
- Performance
- Reliability
- Long-Term Maintenance reprogram if features change or bugs found
- Many different applications 5G, Data Center, Industrial, DSP
- Great for emerging markets where hardware specifications change
- Excellent prototyping vehicle

#### Rise of new markets



#### Look-Up Table (LUT): the foundation



Y=A'B'CD+AB'CD'+A'BCD'+AB'C'D+A'BC'D+A'BCD

#### Logic Array Blocks



 $\times 10$ 

\*Number of inputs and ALMs per LAB vary by product family

### Building the Array



#### How switching fabric is programmed

#### **Row/Column Interconnect Junction**



Programming info stored in a external non-volatile device
Active: programmed automatically at power-on
Passive: Intelligent host (CPU) controls
programming

#### FPGAs "Hardened" features (Cyclone V)



#### Describing FPGAs

- Schematics
- System Integration Tools predefined blocks
- Hardware Description Languages (HDLs)
  - Verilog, VHDL are most popular
- High level languages
  - "HLS"
  - OpenCL
  - Data Parallel C++







#### What is IP (Intellectual Property)

- Complex functions that Intel designs for our customers so they don't have to design it themselves
  - Sometimes IP is free
  - The more complex stuff costs since its expensive to develop and make sure it works
- Examples: Ethernet Controller, PCIe Controller, soft processor, multiplier functions, etc.

#### **Basics of Quartus**

- Intel® Quartus® Prime Design Software is a tool for FPGA, SOC and CPLD design
- Includes synthesis, debug, optimization, verification and simulation
- Takes a description of an FPGA (schematic or HDL) and determines how the lookup tables are programmed



- Many formats to program an FPGA
  - In this class we will use a ".sof" file (SRAM object file)
  - The .sof file is "volatile" and needs to be reprogrammed every time the board is restarted

#### Quartus User Interface

- Quartus Prime Software Main Window
  - Project Navigator shows your project hierarchy, source files, design units, IP and design revisions in your project.
  - *Tasks* window shows the status of the design and can be used to run or re-run parts of the design flow
  - Messages window outputs messages from each process of the run.
  - *Files* window has tabs for the report browser, open design files and any other file opened by the user.
  - *IP Catalog* window is open by default and is used to generate IP functions that are to be used in your design.



#### **Tools Flow**



### New Project Wizard

- 1. Name project
- 2. Set Working Directory & Top-Level Entity
- 3. Add source files
- 4. Select Device
- 5. EDA tool settings





All settings can be modified later. Some steps can be skipped.

The top level entity must match the top level module in your design exactly (case sensitive) in order to avoid a compile error.

### Family & Device Settings



Expand the window so you can see all the fields

Get the part number for your specific device by looking on the chip on your board or the side of the box.

### Pin Planner



# Compile your design

| <b>~</b> | ▲ Compile Design                       | 00:01:59 |
|----------|----------------------------------------|----------|
| <b>*</b> | Analysis & Synthesis                   | 00:00:40 |
| <b>*</b> | → Fitter (Place & Route)               | 00:00:42 |
| <b>*</b> | Assembler (Generate programming files) | 00:00:19 |
| <b>*</b> |                                        | 00:00:18 |

Δ

332012 Synopsys Design Constraints File file not found: 'Lab1.sdc'.



Warnings shown in blue won't prevent your design from compiling or being programmed, but they could indicate possible bugs. This lab does not have any design constraints, so the .sdc file is not needed. You will learn how to create one in the timing analysis workshop.

# Program your FPGA



## Test your design



Live Hardware

### First Lab: Switch to LED



# Next lab: Multiplexer





Truth table



Symbol

The multiplexer can be described by the following Verilog statement:

**assign** 
$$m = (\sim s \& x) | (s \& y);$$

# Knight Rider







### Quartus and Design Tips

- When Quartus Prime Lite first starts for the very first time it might ask you about purchasing a license, select Run Quartus, all licenses are free for this lab.
- If things fail to compile, check your top Level Entity Setting → Setting → Top Level
  Entity and make sure that the module <design> matches your top level entity,
  including case.
- Check the LEDR[0] and LEDR[9] pins carefully in the Knight Rider lab and see if they sequence properly. If not, study the code carefully!
- Sometimes copy and paste from files into Quartus has carriage return formatting errors. If you see run on lines with no carriage return, you need to copy things over line by line, or add the appropriate file to your project. It's better to click on the links and download the files.

# Learning more

- <a href="http://fpgauniversity.intel.com">http://fpgauniversity.intel.com</a> lots of helpful labs and tutorials
- Customer training site (just google Intel FPGA training)
  - In catalog, search on university
- Practice makes perfect!
- Thanks for attending!