# MAX1000 RTL Simulation Lab



Software and hardware requirements to complete all exercises

Software Requirements: Quartus® Prime Lite or Standard Edition version 18.0 or 18.1

ModelSim – Intel FPGA Starter Edition 10.5b

Hardware Requirements: ARROW MAX1000 Board

### 1. Introduction

This tutorial provides comprehensive information to help you understand how to simulate your FPGA design in the ModelSim – Intel FPGA Editor simulator. Design simulation verifies your design before programming.

Lab Notes: Many of the names that the lab asks you to choose for files, components, and other objects in this exercise must be spelled exactly as directed. This nomenclature is necessary because the pre-written software application includes variables that use the names of the hardware peripherals. Naming the components differently can cause errors. There are also other similar dependencies within the project that require you to enter the correct names.

### 2. Getting Started

The first objective is to ensure that you have all the necessary hardware items and software installed so that the lab can be completed successfully. Below is a list of items required to complete this lab:

- MAX1000 Board (10M08SAU169C8G)
- USB Cable
- Lab files: RTL\_Simulation\_lab\_template: Template files are required to complete the lab. Includes: rtl\_simulation\_lab.vhd, rtl\_simulation\_lab\_tb.vhd
- Quartus Prime 18.0 Lite was used for this lab. Previous/newer versions should work (If no Quartus Prime is installed, refer to MAX1000 User Guide for instructions)
- ModelSim Intel FPGA Starter Edition 10.5b was used for this lab. Previous/newer versions should work (If no Quartus Prime is installed, refer to MAX1000 User Guide for instructions)
- Installed Arrow USB Drivers (If not, refer to MAX1000 User Guide for instructions)
- Personal computer or laptop running 64-bit Linux / Windows 7 or later with at least an Intel i3 core (or equivalent), 4GB RAM and 12 GB of free hard disk space
- A desire to learn!

# wow

### 3. Design Flow

The Quartus Prime design software provides a complete, multiplatform design environment that easily adapts to your specific design needs. It is a comprehensive environment for system-on-a-programmable-chip (SOPC) design. The Quartus Prime software includes solutions for all phases of FPGA and CPLD design.

The standard FPGA design flow starts with design entry using schematics or hardware description language (HDL), such as Verilog HDL or VHDL. In this step, you create the digital circuit that is implemented inside the FPGA. The flow then proceeds through compilation, simulation, programming, and verification in the FPGA hardware.



The above diagram shows the typical design flow for the system design.

The ModelSim supports HDL design simulation at register transfer (RTL) and gate levels. You can use the Quartus Prime NativeLink feature to integrate your ModelSim simulator within the Quartus design flow and streamline simulation processing steps.

Because MAX10 devices do not support the gate level simulation, this tutorial only demonstrates the functional, RTL simulation and does not cover the gate level simulation.

### 4. Project with MAX1000

### 4.1 Quartus Prime project

#### 4.1.1 Create a new Quartus Prime project

- 4.1.1.1 If not already open, from the Start menu or the Desktop, open the Quartus Prime 18.0 Lite software.
- 4.1.1.2 Create a new project using the New Project Wizard: **File** → **New Project Wizard**.

| New Project Wizard                                                                                                                                                                                                                                                     | × |
|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|
| Introduction                                                                                                                                                                                                                                                           |   |
| The New Project Wizard helps you create a new project and preliminary project settings, including the following:                                                                                                                                                       |   |
| <ul> <li>Project name and directory</li> <li>Name of the top-level design entity</li> <li>Project files and libraries</li> <li>Target device family and device</li> </ul>                                                                                              |   |
| • EDA tool settings<br>You can change the settings for an existing project and specify additional project-wide settings with the Settings command<br>(Assignments menu). You can use the various pages of the Settings dialog box to add functionality to the project. |   |
|                                                                                                                                                                                                                                                                        |   |
|                                                                                                                                                                                                                                                                        |   |
|                                                                                                                                                                                                                                                                        |   |
|                                                                                                                                                                                                                                                                        |   |
| Don't show me this introduction again                                                                                                                                                                                                                                  |   |
| < Back Next > Finish Cancel Help                                                                                                                                                                                                                                       | , |

#### 4.1.1.3 Click Next.

4.1.1.4 Configure the New Project Wizard directory, name and top-level entity information:

- Enter a directory in which you will store your Quartus project files for this design, for example, C:/MAX1000/RTL\_Simulation\_lab
- Specify the name of the project: rtl\_simulation\_lab
- Specify the name of the top-level entity: rtl\_simulation\_lab



| 🕥 New Project Wizard                                                                      | ×                                                                |
|-------------------------------------------------------------------------------------------|------------------------------------------------------------------|
| Directory, Name, Top-Level Entity                                                         |                                                                  |
| What is the working directory for this project?                                           |                                                                  |
| C:/MAX1000/RTL_Simulation_lab                                                             |                                                                  |
| What is the name of this project?                                                         |                                                                  |
| rtl_simulation_lab                                                                        |                                                                  |
| What is the name of the top-level design entity for this project name in the design file. | t? This name is case sensitive and must exactly match the entity |
| rtl_simulation_lab                                                                        |                                                                  |
| Use Existing Project Settings                                                             |                                                                  |
|                                                                                           |                                                                  |
|                                                                                           |                                                                  |
|                                                                                           |                                                                  |
|                                                                                           |                                                                  |
|                                                                                           |                                                                  |
|                                                                                           |                                                                  |
|                                                                                           |                                                                  |
|                                                                                           |                                                                  |
|                                                                                           |                                                                  |
| <                                                                                         | Back Next > Finish Cancel Help                                   |
|                                                                                           |                                                                  |

#### 4.1.1.5 Click Next.

4.1.1.6 On the Project Type page, select **"Empty project"** and click **Next**.

|                                                                                                                                                                                                  | _ |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|
| New Project Wizard                                                                                                                                                                               |   |
| Project Type                                                                                                                                                                                     |   |
| Select the type of project to create.                                                                                                                                                            |   |
| Empty project                                                                                                                                                                                    |   |
| Create new project by specifying project files and libraries, target device family and device, and EDA tool settings.                                                                            |   |
| O Project template                                                                                                                                                                               |   |
| Create a project from an existing design template. You can choose from design templates installed with the Quartus Prim<br>software, or download design templates from the <u>Design Store</u> . | 2 |
|                                                                                                                                                                                                  |   |
|                                                                                                                                                                                                  |   |
|                                                                                                                                                                                                  |   |
|                                                                                                                                                                                                  |   |
|                                                                                                                                                                                                  |   |
|                                                                                                                                                                                                  |   |
|                                                                                                                                                                                                  |   |
|                                                                                                                                                                                                  |   |
|                                                                                                                                                                                                  |   |
|                                                                                                                                                                                                  |   |
|                                                                                                                                                                                                  |   |
|                                                                                                                                                                                                  |   |
| < Back Next > Finish Cancel Help                                                                                                                                                                 |   |
| < Back Next > Finish Cancel Help                                                                                                                                                                 |   |

# WUW

- 4.1.1.7 On the Add Files page, add source files to the project by clicking on the button and browse into the lab files folder where you will locate the provided design files and add:
  - rtl\_simulation\_lab\_tb.vhd
  - rtl\_simulation\_lab.vhd

| 🔇 New Project Wizard                                                                                                                                                                                          | ×                                  |
|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------|
| Add Files<br>Select the design files you want to include in the project. Click Add All to add all design files in the project dire<br>project.<br>Note: you can always add design files to the project later. | ctory to the                       |
| File name:                                                                                                                                                                                                    | Add                                |
| File Name     Type     Library     Design Entry/Synthesis Tool     HDL Version       rtl_simulation_lab_tb.vhd     VHDL File     Default       rtl_simulation_lab.vhd     VHDL File     Default               | Remove<br>Up<br>Down<br>Properties |
| Specify the path names of any non-default libraries. User Libraries                                                                                                                                           |                                    |
| < Back Next > Finish Cance                                                                                                                                                                                    | el Help                            |

#### 4.1.1.8 Click Next.

4.1.1.9 Specify Family and Device Settings. Use pull-down menus to select MAX10 family or enter the part number in the Name Filter text box. The part number is **10M08SAU169C8G**.

| h the Ins   | mpilation.<br>stall Devices com<br>are in which you |                            | is supp                                                    | orted, refer                                                                                                              | r to the <u>Device Support List</u> webp                |
|-------------|-----------------------------------------------------|----------------------------|------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------|
| h the Ins   | tall Devices com                                    | r target device            | is supp                                                    | orted, refer                                                                                                              |                                                         |
| ne softwa   | are in which you                                    |                            |                                                            | -                                                                                                                         |                                                         |
|             | •                                                   | Show in 'Ava               | ailable                                                    | devices' list                                                                                                             |                                                         |
|             | •                                                   |                            |                                                            |                                                                                                                           |                                                         |
|             |                                                     | Package:                   |                                                            | UFBGA                                                                                                                     |                                                         |
|             | •                                                   | Pin count: 169             |                                                            |                                                                                                                           |                                                         |
|             |                                                     | Core speed                 | eed grade: 8                                               |                                                                                                                           |                                                         |
|             |                                                     | Name filter:               | r: 10M08SAU169C8G                                          |                                                                                                                           |                                                         |
| vices' list |                                                     | Show advanced devices      |                                                            |                                                                                                                           |                                                         |
|             |                                                     |                            |                                                            |                                                                                                                           |                                                         |
|             |                                                     |                            |                                                            |                                                                                                                           |                                                         |
| LES         | Total I/Os                                          | GPIOs                      | Mer                                                        | nory Bits                                                                                                                 | Embedded multiplier 9-bit e                             |
| 8064        | 130                                                 | 130                        | 38707                                                      | 2                                                                                                                         | 48                                                      |
| 8064        | 130                                                 | 130                        | 38707                                                      | 2                                                                                                                         | 48                                                      |
|             | 1                                                   |                            |                                                            |                                                                                                                           | 10                                                      |
|             | <b>LEs</b><br>3064                                  | LEs Total I/Os<br>3064 130 | Name filter:<br>Show ad<br>LEs Total I/Os GPIOs<br>130 130 | Ilst     Name filter:       Image: Show advanced       ILEs     Total I/Os       GPIOs     Men       3064     130     130 | LEs Total I/Os GPIOs Memory Bits<br>3064 130 130 387072 |

MAX1000 RTL Simulation Lab

#### 4.1.1.10 Click Next.

4.1.1.11 On the EDA Tool Settings select **ModelSim-Altera** from the pull-down menu for the Simulation tool and select VHDL as format.

| DA tools:        |                   |               |                                                              |  |
|------------------|-------------------|---------------|--------------------------------------------------------------|--|
| Tool Type        | Tool Name         | Format(s)     | Run Tool Automatically                                       |  |
| Design Entry/Syn | <none> •</none>   | <none></none> | Run this tool automatically to synthesize the current design |  |
| Simulation       | ModelSim-Altera 🔹 | VHDL          | Run gate-level simulation automatically after compilation    |  |
| Board-Level      | Timing            | <none></none> | •                                                            |  |
|                  | Symbol            | <none></none> | •                                                            |  |
|                  | Signal Integrity  | <none></none> | •                                                            |  |
|                  | Boundary Scan     | <none></none> | 7                                                            |  |
|                  |                   |               |                                                              |  |
|                  |                   |               |                                                              |  |
|                  |                   |               |                                                              |  |
|                  |                   |               |                                                              |  |
|                  |                   |               |                                                              |  |
|                  |                   |               |                                                              |  |
|                  |                   |               |                                                              |  |

4.1.1.12 Click Finish.

### 4.2 Design entry

**Overview:** In this module you will setup the environment for simulation and add missing component to your design.

#### 4.2.1 Add PLL to the Quartus project

4.2.1.1 From the IP Catalog panel on the left side, expand the menus for the **Basic Functions** → **Clocks; PLLs and Resets** → **PLL** and double click on **ALTPLL**.

If the IP catalog is not visible, then right click on the toolbar and select IP catalog.



4.2.1.2 On the Save IP Variation window, enter the following information.

- IP variation file name: <project\_directory>/PLL
- IP variation file type: VHDL



4.2.1.3 Click **OK**.

MAX1000 RTL Simulation Lab

# WUW

4.2.1.4 Under General/Modes tab (page 1 of 12) of PLL MegaWizard change the frequency of clock input to **12 MHz.** This source is provided by the internal oscillator in the MAX10 FPGA.

| × MegaWizard Plug-In Manager [page 1 of 12]                                                                        | ? ×                                                                                                                                                                                                                                                                                                                                                          |
|--------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                                                                                                                    | About Documentation                                                                                                                                                                                                                                                                                                                                          |
| Parameter         PLL         Output         F           Settings         Reconfiguration         Clocks         F | EDA 5 Summary                                                                                                                                                                                                                                                                                                                                                |
| General/Modes                                                                                                      | S > Clock switchover >                                                                                                                                                                                                                                                                                                                                       |
|                                                                                                                    | Currently selected device family: MAX 10                                                                                                                                                                                                                                                                                                                     |
| PLL                                                                                                                | Match project/default                                                                                                                                                                                                                                                                                                                                        |
| inclk0<br>areset<br>Operation Mode: Normal<br>Citi Ratio Ph (dg) DC (%)<br>co 1/1 0.00 50.00<br>MAX 10             | Able to implement the requested PLL  General  Which device speed grade will you be using? Use military temperature range devices only  What is the frequency of the inck0 input? Set up PLL in LVDS mode Data rate: Not Available 	Mbps  PLL Type Which PLL type will you be using? Fast PLL Enhanced PLL ® Select the PLL type automatically Operation Mode |
|                                                                                                                    | How will the PLL outputs be generated?                                                                                                                                                                                                                                                                                                                       |

- 4.2.1.5 Click Next.
- 4.2.1.6 Under Input/Lock tab (page 2 of 12) uncheck 'areset' input and locked output option.



MAX1000 RTL Simulation Lab

- 4.2.1.7 Click Next until you reach the Output Clocks tab (page 6 of 12).
- 4.2.1.8 Under the clk c0 tab (page 6 of 12) select "Enter output clock parameters" and set Clock division factor to **80**. Leave the rest as default.

| 🌂 MegaWizard Plug-In Manager [page 6 of 12]                                                                               |                                                                                                                                                                                                                                                                                                                                                                                                                                                      | ? ×                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|---------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| altpll                                                                                                                    |                                                                                                                                                                                                                                                                                                                                                                                                                                                      | <u>About</u> <u>Documentation</u>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| Parameter     2 PLL     3 Output       Settings     Clocks       Ck c0     ck c1     ck c2     ck c3                      | EDA 5 Summary                                                                                                                                                                                                                                                                                                                                                                                                                                        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| PLL<br>Incik0 Trequency: 12:000 MHz<br>Operation Mode: Normal<br>Clk Ratio Ph (dg) DC (%)<br>c0 1780 0:00 50:00<br>MAX 10 | CO - Core/External Output (<br>Able to implement the requested PLL<br>Use this clock<br>Clock Tap Settings<br>○ Enter output clock frequency:<br>④ Enter output clock parameters:<br>Clock multiplication factor<br>Clock division factor<br>Clock division factor<br>Clock division factor<br>Clock division factor<br>Clock duty cycle (%)<br>Note: The displayed internal settings of<br>the PLL is recommended for use by<br>advanced users only | Requested Settings       Actual Settings         100.00000000       HIZ         100.00000000       HIZ         100.0000000       HIZ         100.000000       HIZ         100.000000       HIZ         100.000000       HIZ         100.000000       HIZ         100.000000       HIZ         100.000000       HIZ         100.0000000       HIZ         100.0000000       HIZ         100.00000000       HIZ         100.000000000       HIZ         100.0000000000000000000000000000000000 |
| -                                                                                                                         |                                                                                                                                                                                                                                                                                                                                                                                                                                                      | Cancel < Back Next > Enish                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |

- 4.2.1.9 Click **Finish.** This will take you to the Summary tab (page 12 of 12). Click **Finish** again to close ALTPLL MegaWizard Manager.
- 4.2.1.10 In the pop-up Quartus Prime IP Files accept all defaults and click Yes.

| 🕥 Quartus Prime IP Files                                                                                                                                                                                                     | ×  |
|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----|
| When you create an Intel IP variation, a Quartus Prime IP File is<br>generated. Quartus Prime IP Files are used to represent the Intel IP in<br>your design. Do you want to add the Quartus Prime IP File to the<br>project? | 1  |
| C:\MAX1000\RTL_Simulation_lab\PLL.qip                                                                                                                                                                                        |    |
|                                                                                                                                                                                                                              |    |
| Automatically add Quartus Prime IP Files to all projects                                                                                                                                                                     |    |
| (Note: Turning on this option permanently suppresses this dialog bo                                                                                                                                                          | х. |
| You can change this setting in the Options dialog box)                                                                                                                                                                       |    |
| Yes No Help                                                                                                                                                                                                                  |    |

4.2.1.11 In the Project Navigator select Files.



4.2.1.12 Right click on rtl\_simulation\_lab.vhd and select **Set as Top-Level Entity** to be sure that this file will be the top-level entity.



#### 4.2.1.13 Open rtl\_simulation\_lab.vhd file.

This VHDL code is ready to simulate and the PLL module is already added. It describes a simple 8 bits up-counter circuit that operates on the PLL output clock.

#### 4.2.1.14 Open rtl\_simulation\_lab\_tb.vhd file.

This testbench is used for testing the design. Because our design only needs a clock, it only generates 12MHz input clock signal for the top-level entity.

### 4.2.2 Set simulation environment

- 4.2.2.1 Open the **Options** window from **Tools**  $\rightarrow$  **Options**.
- 4.2.2.2 Under 'General' select **EDA Tool Options** category.

| General                                                                                                                                                                                                                                  | EDA Tool Options                                                                                                                                                                                  |  |
|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| General EDA Tool Options Fonts Headers & Footers Settings Internet Connectivity Notifications Libraries IP Catalog Search Location Design Templates License Setup Preferred Text Editor Processing Tocity Settings Messages Colors Fonts | EDA Tool Options         Specify the directory that contains the tool executable for each third-party EDA tool:         EDA Tool       Directory Containing Tool Executable         Precision Syn |  |
|                                                                                                                                                                                                                                          |                                                                                                                                                                                                   |  |

- 4.2.2.4 Click **OK**.
- 4.2.2.5 Open Settings window from Assignments  $\rightarrow$  Settings.
- 4.2.2.6 Under EDA Tool Settings select Simulation category.

# WUW

4.2.2.7 Under NativeLink settings choose Compile test bench and click Test Benches...

| Settings - rtl_simulation_lab                                                                                                                                                                                                                                                                                                                                                                                                                                                            | - 🗆 X                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Category:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | Device/Board                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| Category:<br>General<br>Files<br>Libraries<br>IP Catalog Search Locations<br>Design Templates<br>Operating Settings and Conditions<br>Voltage<br>Temperature<br>Compilation Process Settings<br>Incremental Compilation<br>EDA Tool Settings<br>Design Entry/Synthesis<br>Simulation<br>Board-Level<br>Compiler Settings<br>VHDL Input<br>Default Parameters<br>Timing Analyzer<br>Assembler<br>Design Assistant<br>Signal Tap Logic Analyzer<br>Logic Analyzer Settings<br>SSN Analyzer | Simulation         Specify options for generating output files for use with other EDA tools.         Tool name:       ModelSim-Altera         Run gate-level simulation automatically after compilation         EDA Netlist Writer settings         Format for output netlist:       VHDL         Image:       Time scale:       100 us         Output directory:       ismulation/modelsim       Image:         Image:       Image:       Image:         Options for Power Estimation       Image:       Image:         Design instance name:       Image:       Image:         More EDA Netlist Writer Settings       Image:       Image:         NativeLink settings       Image:       Image:         Image:       Image:       Image:       Image:         More EDA Netlist Writer Settings       Image:       Image:       Image:         More EDA Netlist Writer Settings       Image:       Image:       Image:         Output to set up simulation:       Image:       Image:       Image:         Output to set up simulation:       Image:       Image:       Image:         More NativeLink Settings       Image:       Image:       Image:         More NativeLink Settings       Image:       Image: |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | W Buy Software OK Cancel Apply Help                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |

4.2.2.8 In the Test Benches window click New...

| sting test be | ench settings: |                 |         |                    | New  |
|---------------|----------------|-----------------|---------|--------------------|------|
| Name          | op Level Modul | Design Instance | Run For | Test Bench File(s) | Edit |
|               |                |                 |         |                    | Dele |
|               |                |                 |         |                    |      |
|               |                |                 |         |                    |      |

4.2.2.9 In the New Test Bench Settings window add the following:

- Test bench name: rtl\_simulation\_lab\_tb
- Top level module in test bench: rtl\_simulation\_lab\_tb
- Check 'Use test bench to perform VHDL timing simulation'
- Design instance name in test bench: **toplevel**
- Choose **End simulation at** and set it to **2 ms**

| 🖌 Edit Test Bench Settings                                  | × |  |  |  |  |  |  |  |  |
|-------------------------------------------------------------|---|--|--|--|--|--|--|--|--|
| Edit test bench settings for the selected test bench.       |   |  |  |  |  |  |  |  |  |
| Test bench name: rtl_simulation_lab_tb                      |   |  |  |  |  |  |  |  |  |
| Top level module in test bench: rtl_simulation_lab_tb       |   |  |  |  |  |  |  |  |  |
| $\boxdot$ Use test bench to perform VHDL timing simulation  |   |  |  |  |  |  |  |  |  |
| Design instance name in test bench: toplevel                |   |  |  |  |  |  |  |  |  |
| Simulation period                                           |   |  |  |  |  |  |  |  |  |
| $\bigcirc$ Run simulation until all vector stimuli are used |   |  |  |  |  |  |  |  |  |
| ● End simulation at: 2 ms ▼                                 |   |  |  |  |  |  |  |  |  |
| Test bench and simulation files                             |   |  |  |  |  |  |  |  |  |
| File name: Add                                              |   |  |  |  |  |  |  |  |  |
| File Name Library HDL Version Remove                        | 2 |  |  |  |  |  |  |  |  |
| Up                                                          |   |  |  |  |  |  |  |  |  |
| Down                                                        |   |  |  |  |  |  |  |  |  |
| Properties                                                  | 5 |  |  |  |  |  |  |  |  |
| OK Cancel Help                                              |   |  |  |  |  |  |  |  |  |

- 4.2.2.10 Under 'Test bench simulation files' click on button to browse into the lab files folder and add **rtl\_simulation\_lab\_tb.vhd**.
- 4.2.2.11 Click Add.

| est bench name: rtl_simula                                                                         | tion_lab_tb       |          |               |  |  |  |  |  |
|----------------------------------------------------------------------------------------------------|-------------------|----------|---------------|--|--|--|--|--|
| op level module in test bench: rtl_simulation_lab_tb                                               |                   |          |               |  |  |  |  |  |
| Ouse test bench to perform                                                                         | VHDL timing sin   | nulation |               |  |  |  |  |  |
| Design instance name in t                                                                          | est bench: topl   | evel     |               |  |  |  |  |  |
| Simulation period O Run simulation until all  End simulation at: 2                                 | vector stimuli ar | re used  |               |  |  |  |  |  |
| O Run simulation until all                                                                         |                   | ms 🔻     | Add           |  |  |  |  |  |
| Run simulation until all     End simulation at: 2 Test bench and simulation f File name: File Name | files<br>Library  | ms       | Add<br>Remove |  |  |  |  |  |
| Run simulation until all     End simulation at: 2 Test bench and simulation file name:             | files<br>Library  |          |               |  |  |  |  |  |

4.2.2.12 Click OK.

4.2.2.13 In the Test Benches window click **OK**.

4.2.2.14 In the Settings window click **Apply** and **OK**.

| MAX1000                   |
|---------------------------|
| <b>RTL Simulation Lab</b> |
| WDW                       |

### 4.3 Simulation

### 4.3.1 Analysis and Synthesis

4.3.1.1 Run Analysis and Synthesis by clicking on <sup>k</sup> button on the toolbars, or **Processing** → **Start** → **Analysis and Synthesis**.

There should be no errors. If there are errors, they should be fixed before continuing. If there are no errors the compilation task windows should look like this:



#### 4.3.2 Run simulator

4.3.2.1 Start simulation by opening **Tools**  $\rightarrow$  **Run Simulation Tool**  $\rightarrow$  **RTL Simulation**.

The ModelSim – Intel FPGA STARTER EDITION will open and start to load and simulate the project. At this point should be no errors in the message window. If there are, please refer again to the previous steps to resolve it.



| ile Edit View Compile Simula<br>🗃 • 🎓 🖬 🗇 🚳 🕴 🕺 🎕 🎕 🖇                                                                                                                                                                                           |                                                                                                                                 | 1 0 10 11 ALL                                               |                | 2 🕱 🛛 🖳         | <b>* ** *</b>   5 | 100 ps         | •) ni ni n    | 3 <b>33 co</b> 1 | <u>ଆ</u> ଆ ଏ | 1 1 2      |             | 2.2        | 44 ±        | T Thresh    | old         | 00 🛊 1.     | < ? x          | - ( Li     | yout Simu    | late        | •           |           |
|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------|----------------|-----------------|-------------------|----------------|---------------|------------------|--------------|------------|-------------|------------|-------------|-------------|-------------|-------------|----------------|------------|--------------|-------------|-------------|-----------|
| ColumnLayout Default                                                                                                                                                                                                                            |                                                                                                                                 | <u>-</u>                                                    |                |                 | 222               | ****           |               | <b>-€-</b> ≩•1   | Search:      | · [] ·     |             | ♥ 館蔵       | j<br>#5   6 | ରେ ଭା 🔉     | 128         |             |                |            |              |             |             | _         |
| sim - Default + @ ×                                                                                                                                                                                                                             | 🚑 Objects : 🕬 🖬 🗙                                                                                                               | Wave - Default                                              | . 11           | 100 - 501 - 14- | <u> </u> ] — — …  |                | ji .          |                  |              |            | 1000        |            | * []        |             |             | 1.1.2 384 3 | 861 I 1999 - 4 |            | J            |             |             | +         |
| Instance                                                                                                                                                                                                                                        | ▼Name 12 ■ Now 21 ▶                                                                                                             | <b>\$</b> 1-                                                | Ns             | gs -            |                   |                |               |                  |              |            |             |            |             |             |             |             |                |            |              |             |             |           |
| Ti Januaron ak to<br>tophone<br>tophone<br>texto<br>texto<br>rtc.pop_lif4<br>ates_devc_inter<br>ates_devc_inter<br>ates_devc_inter<br>ates_devc_inter<br>ates_devc_inter<br>rt_plack                                                            | € ακ<br>€ ια                                                                                                                    | <ul> <li>Attanation_1</li> <li>D ≤ /Attanation_1</li> </ul> |                |                 |                   |                |               |                  |              |            |             |            |             |             |             |             |                |            |              |             |             |           |
|                                                                                                                                                                                                                                                 |                                                                                                                                 | All No                                                      | w 0.00000 t    | 5 00 us0.000    | 05 us 0.0001 u    | s 0.00015 us 0 | 0.0002 us 0.0 | 0025 us 0.00     | 03 us 0.001  | 35 us 0.00 | 04 us 0.000 | 45 us 0.00 | 05 us 0.0   | 0055 us 0.0 | 006 us 0.00 | 065 us 0.00 | 97 us 0.00     | 075 us 0.0 | 008 us 0.000 | 085 us 0.00 | 09 us 0.001 | 95 us 0.0 |
|                                                                                                                                                                                                                                                 |                                                                                                                                 | Gel Curso                                                   | 1 0.00000 L    |                 | 5                 |                |               |                  |              |            |             |            |             |             |             |             |                |            |              |             |             | _         |
| 🖪 Memory List 🛛 🛺 sim 🗐 💶                                                                                                                                                                                                                       |                                                                                                                                 | <                                                           | <u> </u>       | ) I             | _                 | _              | _             | _                | _            |            | _           | _          | _           | _           | _           | _           | _              | _          |              | _           | _           | •         |
| Transcript<br>Loading altera mf.altpll                                                                                                                                                                                                          | (babayion)                                                                                                                      |                                                             |                |                 |                   |                |               |                  | _            | _          |             | _          | _           | _           |             |             | _              | _          |              |             | _           | ±         |
| Loading alters mf.mf.org<br>Loading alters mf.mf.oda<br>Loading alters mf.mf.oda<br>** Warning: Design size<br>Expect performance to be<br>add wave *<br>view structure<br>.main_pane.structure.int<br>view signals<br>.main pane.objects.inter | <pre>loneiii_pl1(vital_pl mn_ontr(behave) scale_ontr(behave) of 12275 statements adversely affected. erior.cs.body.struct</pre> | exceeds ModelSim-                                           | intel FPGA Sta | rter Editio     | on recommen       | ded capaci     | τγ.           |                  |              |            |             |            |             |             |             |             |                |            |              |             |             |           |
| run 500 ms<br>** Note: MAX 10 PLL lock<br>Time: 375001 ps Iter                                                                                                                                                                                  | ed to incoming clock<br>ation: 3 Instance:                                                                                      | /rtl_simulation_l                                           | b_tb/toplevel  | /clock/altg     | pll_compone       | nt/CYCLONE     | III_ALTPL     | L/H5             |              |            |             |            |             |             |             |             |                |            |              |             |             |           |

4.3.2.2 Click on the **Wave** window and click on the simulation. When it finished, it will automatically refresh the Wave window and the time counter will stop on the left bottom corner.

| Marrie Dama | Dallar 0 |  |
|-------------|----------|--|
| Now: 2 ms   | Deita: 0 |  |

4.3.2.3 Use the Zoom equation of the specific points of the waveform.



- 4.3.2.4 Right click on **/rtl\_simulation\_lab\_tb/LED** and select **Radix** → **Hexadecimal** to change the value display.
- 4.3.2.5 Expand the **/rtl\_simulation\_lab\_tb/LED** by clicking on 🖃 icon next to it.



4.3.2.6 Add PLL output clock by clicking **toplevel** in the Sim window on the left side of display. Drag and drop **iCLK** to the Wave window.

| sim - Default ==================================== | Objects = INSU 1 A A X     Nov 2 A A X     CLX     CLX     CLX     CLX     CLX     CLX     CLX     CLX     CLX | Wave - Default           ↓ /ft_simulation_lab_tb//CLK           ↓ /ft_simulation_lab_tb/LED           ↓ (f)           ↓ (f) |
|----------------------------------------------------|----------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <ul> <li>Memory List × 🔊 sim × 🕩</li> </ul>        | 4                                                                                                              | Now    Image: Cursor 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |

- 4.3.2.7 On the menu go to Simulate  $\rightarrow$  Restart...
- 4.3.2.8 In the Restart popup window check everything and click **OK**.

| Restart X           |
|---------------------|
| Keep:               |
| List Format         |
| ✓ Wave Format       |
| Breakpoints         |
| Logged Signals      |
| Virtual Definitions |
| Assertions          |
| Cover Directives    |
| ATV Format          |
|                     |
| OK Cancel           |

4.3.2.9 Set 500  $\mu s$  for the run length in the button toolbar and click on  $\fbox$  button to run simulation.

| ] |    | · <u> </u>   |             | l Et Et 🕱 🤹   🛅 🕥 🚸             |
|---|----|--------------|-------------|---------------------------------|
| : | 노는 | <b>`</b> € ⊅ | ERun Length | ] <b>3+ - →€ - 3-</b>   Search: |

4.3.2.10 When the simulation finished, it should show the following waveform:

| Wave - Default                                                                              | Msgs         |     |     |        |     |     |      |     |         |      |      |     |       |     |    |      |    |      |    |     |      |     |     | + |
|---------------------------------------------------------------------------------------------|--------------|-----|-----|--------|-----|-----|------|-----|---------|------|------|-----|-------|-----|----|------|----|------|----|-----|------|-----|-----|---|
| <ul> <li>/rtl_simulation_lab_tb/CLK</li> <li>/rtl_simulation_lab_tb/toplevel/iCL</li> </ul> | 1            |     |     |        |     |     |      |     |         |      |      |     |       |     |    |      | _  |      |    |     |      |     |     |   |
| /rtl_simulation_lab_tb/LED                                                                  | 48           | 135 | 36  | 37 .38 | (39 | 13A | ).3B | 13C | 3D      | ).3E | ).3F | (40 | (41 ) | 42  | 43 | (44) | 45 | 46 [ | 47 | (48 | 49   | .4A | (4B |   |
|                                                                                             | 0            |     |     |        |     |     |      |     |         |      |      | _   |       |     |    |      |    |      |    |     |      |     |     |   |
|                                                                                             | 0<br>0       |     |     |        |     |     |      |     |         |      |      | -   |       |     |    |      |    |      |    |     |      |     |     |   |
| - 🕹 (3)<br>- 🕹 (2)                                                                          | 1            |     |     |        |     |     |      |     |         |      |      | 1   |       |     |    |      |    |      |    |     |      |     |     |   |
|                                                                                             | 1            |     |     |        |     |     |      |     |         |      |      |     |       |     |    |      |    |      |    |     |      |     |     |   |
| (U)                                                                                         | _ 1          | -   |     |        |     |     |      |     |         |      |      |     |       |     |    |      |    |      |    |     |      |     |     |   |
|                                                                                             |              |     |     |        |     |     |      |     |         |      |      |     |       |     |    |      |    |      |    |     |      |     |     |   |
|                                                                                             |              |     |     |        |     |     |      |     |         |      |      |     |       |     |    |      |    |      |    |     |      |     |     |   |
|                                                                                             |              |     |     |        |     |     |      |     |         |      |      |     |       |     |    |      |    |      |    |     |      |     |     |   |
|                                                                                             |              |     |     |        |     |     |      |     |         |      |      |     |       |     |    |      |    |      |    |     |      |     |     |   |
|                                                                                             |              |     |     |        |     |     |      |     |         |      |      |     |       |     |    |      |    |      |    |     |      |     |     |   |
|                                                                                             |              |     |     |        |     |     |      |     |         |      |      |     |       |     |    |      |    |      |    |     |      |     |     |   |
|                                                                                             |              |     |     |        |     |     |      |     |         |      |      |     |       |     |    |      |    |      |    |     |      |     |     |   |
|                                                                                             |              |     |     |        |     |     |      |     |         |      |      |     |       |     |    |      |    |      |    |     |      |     |     |   |
| I · No                                                                                      |              |     | 360 | us     |     |     |      | 4   | 00 us ' |      |      |     | 1.1   | 440 | us | 1.1  |    |      |    | 48  | 0 us |     |     |   |
| Cursor                                                                                      | 1 0.00000 us |     |     |        |     |     |      |     |         |      |      |     |       |     |    |      |    |      |    |     |      |     |     |   |

- 4.3.2.11 Add a second cursor by clicking on 💾 button in the toolbar.
- 4.3.2.12 Zoom in into the waveform, and measure 1 CLK period by the cursors. You can easily adjust the cursors to the edge by these buttons on the toolbar:



4.3.2.13 Verify that 1 CLK period is 12 MHz.



4.3.2.14 Repeat the 4.3.2.12 point with 1 iCLK period.

MAX1000 RTL Simulation Lab

4.3.2.15 Verify that 1 iCLK period is 150 kHz.

| 📰 Wave - Default 🚃                    |              |     |       |        |            |     |           |                             |        |             |
|---------------------------------------|--------------|-----|-------|--------|------------|-----|-----------|-----------------------------|--------|-------------|
|                                       | Msgs         |     |       |        |            |     |           |                             |        |             |
| <pre>/rtl_simulation_lab_tb/CLK</pre> | 0            |     |       | hannan |            |     |           | ใกการกระกระกระกระกระกระกระก |        |             |
| /rtl_simulation_lab_tb/toplevel/iCLK  | 0            |     |       |        |            |     |           |                             |        |             |
|                                       | 02           | 01  |       |        |            |     | <u>02</u> |                             |        | <u>) 03</u> |
|                                       | 0            |     |       |        |            |     |           |                             |        |             |
| -◆ (6)<br>-◆ (5)                      | 0            |     |       |        |            |     |           |                             |        |             |
| (3)                                   | 0            |     |       |        |            |     |           |                             |        |             |
|                                       | 0            |     |       |        |            |     |           |                             |        |             |
|                                       | 0            |     |       |        |            |     |           |                             |        |             |
|                                       | 1            |     |       |        |            |     |           |                             |        |             |
| ▶                                     | 0            |     |       |        |            |     |           |                             |        |             |
|                                       |              |     |       |        |            |     |           |                             |        |             |
|                                       |              |     |       |        |            |     |           |                             |        |             |
|                                       |              |     |       |        |            |     |           |                             |        |             |
|                                       |              |     |       |        |            |     |           |                             |        |             |
|                                       |              |     |       |        |            |     |           |                             |        |             |
|                                       |              |     |       |        |            |     |           |                             |        |             |
|                                       |              |     |       |        |            |     |           |                             |        |             |
|                                       |              |     |       |        |            |     |           |                             |        |             |
|                                       |              |     |       |        |            |     |           |                             |        |             |
|                                       |              |     |       |        |            |     |           |                             |        |             |
|                                       |              |     |       |        |            |     |           |                             |        |             |
|                                       |              |     |       |        |            |     |           |                             |        |             |
| A R ON                                | 500 us       | 1 1 |       | '      | us i i i i |     |           | us i i i i                  | 12     | us          |
| ⊖ Cursor 1                            | 3.375025 us  |     | 3.375 |        |            | -14 | 9.999 KHz |                             | 12     |             |
| € ≁⊖ Cursor 2                         | 10.041745 us |     |       |        |            |     |           | 10.041                      | 745 us |             |
|                                       | <u>ا</u>     | •   |       |        |            |     |           |                             |        |             |

4.3.2.16 Close ModelSim.

### 4.3.3 Modification of the design

4.3.3.1 Open rtl\_simulation\_lab.vhd file in Quartus.

4.3.3.2 Change line 42 to:

```
signal iCNT : std_logic_vector(15 downto 0) := (others => '0');
```

4.3.3.3 Change line 66 (LED <= iCNT;) to:

LED <= iLED;</pre>

4.3.3.4 Add these codes after line 42:

```
signal iDIR : std_logic := '1';
signal iLED : std_logic_vector(7 downto 0) := x"01";
```

# wow

4.3.3.5 Add these codes after line 65 (after the end line of 'counter : process'):

```
leds : process(iCNT(0))
begin
    if(iCNT(0) = '1' and iCNT(0)'event) then
        if(iDIR = '1') then
            iLED <= iLED(6 downto 0) & '0';
            if(iLED = x"40") then
                iDIR <= '0';
            end if;
        else
            iLED <= '0' & iLED(7 downto 1);
            if(iLED = x"02") then
                iDIR <= '1';
            end if;
        end if;
    end if;
end if;
end if;</pre>
```

**Notes:** Because the simulation would take a very long time, we will use iCNT(0) for the process sensitivity in simulation to check this code functionality and will change it to iCNT(15) for the board configuration.

4.3.3.6 Save your design by clicking on  $\square$  button or **File**  $\rightarrow$  **Save**.

4.3.3.7 Repeat the Analysis and Synthesis and simulation process from 4.3.1.1 point. After the simulation the waveform should look as follow:



4.3.3.8 When you finish with the simulation, close ModelSim.

4.3.3.9 Open rtl\_simulation\_lab.vhd file in Quartus.

4.3.3.10 Change every iCNT(0) to **iCNT(15)** from line 68 to line 70 (the first 3 line of 'leds : process').

This modification only changes the clock source, no other effect on the function.

4.3.3.11 Save your design by clicking on button or File → Save.
 MAX1000 Page | 20
 RTL Simulation Lab

www.arrow.com January 2019

### 4.4 Compile design

#### 4.4.1 Analysis and Synthesis

4.4.1.1 Run Analysis and Synthesis by clicking on <sup>k</sup> button on the toolbars, or **Processing** → **Start** → **Analysis and Synthesis**.

There should be no errors. If there are errors, they should be fixed before continuing. If there are no errors the compilation task windows should look like this:



#### 4.4.2 Pin Assignments

4.4.2.1 Open **Pin Planner** by clicking on <sup>4</sup> button on the toolbars, or **Assignments** → **Pin Planner**.



MAX1000 RTL Simulation Lab

#### 4.4.2.2 In the bottom table, type **PIN\_H6** in Location column of the clk\_clk.

| Node Name                 | Direction | Location | I/O Bank | VREF Group | I/O Standard    | Reserved | Jurrent Strengt | Slew Rate   | Differential Pair | trict Preservation |
|---------------------------|-----------|----------|----------|------------|-----------------|----------|-----------------|-------------|-------------------|--------------------|
| ELK                       | Input     | PIN_H6   | 2        | B2_N0      | 2.5 V (default) |          | 12mA (default)  |             |                   |                    |
| Ӵ LED[7]                  | Output    |          |          |            | 2.5 V (default) |          | 12mA (default)  | 2 (default) |                   |                    |
| 🚢 LED[6]                  | Output    |          |          |            | 2.5 V (default) |          | 12mA (default)  | 2 (default) |                   |                    |
| 4 LED[5]                  | Output    |          |          |            | 2.5 V (default) |          | 12mA (default)  | 2 (default) |                   |                    |
| LED[4]                    | Output    |          |          |            | 2.5 V (default) |          | 12mA (default)  | 2 (default) |                   |                    |
| Ӵ LED[3]                  | Output    |          |          |            | 2.5 V (default) |          | 12mA (default)  | 2 (default) |                   |                    |
| LED[2]                    | Output    |          |          |            | 2.5 V (default) |          | 12mA (default)  | 2 (default) |                   |                    |
| 🚢 LED[1]                  | Output    |          |          |            | 2.5 V (default) |          | 12mA (default)  | 2 (default) |                   |                    |
| Ӵ LED[0]                  | Output    |          |          |            | 2.5 V (default) |          | 12mA (default)  | 2 (default) |                   |                    |
| < <new node="">&gt;</new> |           |          |          |            |                 |          |                 |             |                   |                    |

#### 4.4.2.3 Repeat the previous step with the following assignments:

| Node Name | Pin Location |
|-----------|--------------|
| LED[7]    | PIN_D8       |
| LED[6]    | PIN_C10      |
| LED[5]    | PIN_C9       |
| LED[4]    | PIN_B10      |
| LED[3]    | PIN_A10      |
| LED[2]    | PIN_A11      |
| LED[1]    | PIN_A9       |
| LED[0]    | PIN_A8       |

| Node Name                 | Direction | Location | I/O Bank | VREF Group | I/O Standard    | Reserved | Jurrent Strength | Slew Rate   | Differential Pair | trict Preservatio |
|---------------------------|-----------|----------|----------|------------|-----------------|----------|------------------|-------------|-------------------|-------------------|
| 🖳 CLK                     | Input     | PIN_H6   | 2        | B2_N0      | 2.5 V (default) |          | 12mA (default)   |             |                   |                   |
| <sup>44</sup> LED[7]      | Output    | PIN_D8   | 8        | B8_N0      | 2.5 V (default) |          | 12mA (default)   | 2 (default) |                   |                   |
| 2 LED[6]                  | Output    | PIN_C10  | 8        | B8_N0      | 2.5 V (default) |          | 12mA (default)   | 2 (default) |                   |                   |
| <sup>945</sup> LED[5]     | Output    | PIN_C9   | 8        | B8_N0      | 2.5 V (default) |          | 12mA (default)   | 2 (default) |                   |                   |
| LED[4]                    | Output    | PIN_B10  | 8        | B8_N0      | 2.5 V (default) |          | 12mA (default)   | 2 (default) |                   |                   |
| LED[3]                    | Output    | PIN_A10  | 8        | B8_N0      | 2.5 V (default) |          | 12mA (default)   | 2 (default) |                   |                   |
| 21 LED[2]                 | Output    | PIN_A11  | 8        | B8_N0      | 2.5 V (default) |          | 12mA (default)   | 2 (default) |                   |                   |
| LED[1]                    | Output    | PIN_A9   | 8        | B8_N0      | 2.5 V (default) |          | 12mA (default)   | 2 (default) |                   |                   |
| LED[0]                    | Output    | PIN_A8   | 8        | B8_N0      | 2.5 V (default) |          | 12mA (default)   | 2 (default) |                   |                   |
| < <new node="">&gt;</new> |           |          |          |            |                 |          |                  |             |                   |                   |

### 4.4.2.4 Double click in the I/O Standard column for any pins to open a drop-down list and change the 2.5V (default) to the **3.3-V LVTTL** for each pin.

| Node Name                 | Direction | Location | I/O Bank | VREF Group | I/O Standard | Reserved | Jurrent Strength | Slew Rate   | Differential Pair | trict Preservatio |
|---------------------------|-----------|----------|----------|------------|--------------|----------|------------------|-------------|-------------------|-------------------|
| ELK                       | Input     | PIN_H6   | 2        | B2_N0      | 3.3-V LVTTL  |          | 8mA (default)    |             |                   |                   |
| Ӵ LED[7]                  | Output    | PIN_D8   | 8        | B8_N0      | 3.3-V LVTTL  |          | 8mA (default)    | 2 (default) |                   |                   |
| 🚢 LED[6]                  | Output    | PIN_C10  | 8        | B8_N0      | 3.3-V LVTTL  |          | 8mA (default)    | 2 (default) |                   |                   |
| LED[5]                    | Output    | PIN_C9   | 8        | B8_N0      | 3.3-V LVTTL  |          | 8mA (default)    | 2 (default) |                   |                   |
| LED[4]                    | Output    | PIN_B10  | 8        | B8_N0      | 3.3-V LVTTL  |          | 8mA (default)    | 2 (default) |                   |                   |
| 🝟 LED[3]                  | Output    | PIN_A10  | 8        | B8_N0      | 3.3-V LVTTL  |          | 8mA (default)    | 2 (default) |                   |                   |
| LED[2]                    | Output    | PIN_A11  | 8        | B8_N0      | 3.3-V LVTTL  |          | 8mA (default)    | 2 (default) |                   |                   |
| 🝟 LED[1]                  | Output    | PIN_A9   | 8        | B8_N0      | 3.3-V LVTTL  |          | 8mA (default)    | 2 (default) |                   |                   |
| Ӵ LED[0]                  | Output    | PIN_A8   | 8        | B8_N0      | 3.3-V LVTTL  |          | 8mA (default)    | 2 (default) |                   |                   |
| < <new node="">&gt;</new> |           |          |          |            |              |          |                  |             |                   |                   |

4.4.2.5 Close the Pin Planner, the settings are automatically saved.

### 4.4.3 Compiling the Design

4.4.3.1 Start Compilation by clicking on ► button on the toolbars, or **Processing** → Start Compilation.

There should be no errors. If there are errors, they should be fixed before re-compilating. The 100% in the lower right corner or a green checkmark next to the Compile Design in the Compilation task window indicates that the compilation was successful.

| ile Edit View Project Assignments Proc              | essing Tools Window Help                            |                                                          |                                                                                                                                                                                                            | Search altera.com                   |
|-----------------------------------------------------|-----------------------------------------------------|----------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------|
| D To C rtt_simulation                               |                                                     | ◎ ► ► ₭ ↔ ◎ ↑ ቃ 🗃                                        |                                                                                                                                                                                                            |                                     |
| oject Navigator À Hierarchy 🔹 🤉 🖪 🛪                 | -                                                   | ation_lab.vhd                                            | Compilation Report - rtl_simulation_lab                                                                                                                                                                    | IP Catalog                          |
| Entity:Instance                                     |                                                     | Flow Summary                                             |                                                                                                                                                                                                            | < ×                                 |
| MAX 10: 10M08SAU169C8G                              | Elow Summary                                        | < <filter>&gt;</filter>                                  |                                                                                                                                                                                                            | 🚽 👻 🛤 Installed IP                  |
| 📅 rtl_simulation_lab 🚈                              | Flow Settings                                       | Flow Status                                              | Successful - Wed Jan 16 10:12:59 2019                                                                                                                                                                      | Y Project Directory                 |
|                                                     |                                                     | Quartus Prime Version                                    | 18.0.0 Build 614 04/24/2018 SJ Lite Edition                                                                                                                                                                | No Selection Available              |
|                                                     | Flow Elapsed Time                                   | Revision Name                                            | rtl_simulation_lab                                                                                                                                                                                         | ~ Library                           |
|                                                     | Flow OS Summary                                     | Top-level Entity Name                                    | rtl_simulation_lab                                                                                                                                                                                         | > Basic Functions                   |
|                                                     | Flow Log                                            | Family                                                   | MAX 10                                                                                                                                                                                                     | > DSP                               |
|                                                     | Analysis & Synthesis                                | Device                                                   | 10M085AU169C8G                                                                                                                                                                                             | > Interface Protocols               |
|                                                     | > Fitter                                            | Timing Models                                            | Final                                                                                                                                                                                                      | > Memory Interfaces and Controllers |
|                                                     | > Assembler                                         | Total logic elements                                     | 28 / 8,064 ( < 1 % )                                                                                                                                                                                       | > Processors and Peripherals        |
| >                                                   | Power Analyzer                                      | Total registers                                          | 25                                                                                                                                                                                                         | > University Program                |
| sks Compilation • = 🛛 🗗 ×                           | Timing Analyzer                                     | Total pins                                               | 9 / 130 (7 %)                                                                                                                                                                                              | Search for Partner IP               |
| Task                                                | > EDA Netlist Writer                                | Total virtual pins                                       | 0                                                                                                                                                                                                          |                                     |
|                                                     | Flow Messages                                       | Total memory bits                                        | 0/387,072(0%)                                                                                                                                                                                              |                                     |
| <ul> <li>P complie beagn</li> </ul>                 | Flow Suppressed Message                             | Embedded Multiplier 9-bit elements                       |                                                                                                                                                                                                            |                                     |
| Analysis & Synthesis                                |                                                     | Total PLLs                                               | 1/1(100%)                                                                                                                                                                                                  |                                     |
| Fitter (Place & Route)                              |                                                     | UFM blocks                                               | 0/1(0%)                                                                                                                                                                                                    |                                     |
| Assembler (Generate programmin)                     |                                                     | ADC blocks                                               | 0/1(0%)                                                                                                                                                                                                    |                                     |
| Timing Analysis                                     |                                                     |                                                          |                                                                                                                                                                                                            |                                     |
| EDA Netlist Writer                                  |                                                     |                                                          |                                                                                                                                                                                                            |                                     |
| Edit Settings                                       |                                                     |                                                          |                                                                                                                                                                                                            |                                     |
| Program Device (Open Programmer)                    |                                                     |                                                          |                                                                                                                                                                                                            |                                     |
|                                                     |                                                     |                                                          |                                                                                                                                                                                                            |                                     |
| >                                                   | < >>                                                |                                                          |                                                                                                                                                                                                            | + Add                               |
| All 🔕 🔬 👗 📐 🔽 < <filter>&gt;</filter>               |                                                     | 💏 Find 💏 Find Next                                       |                                                                                                                                                                                                            |                                     |
| Type ID Message                                     |                                                     |                                                          |                                                                                                                                                                                                            |                                     |
|                                                     | ime EDA Netlist Writer                              | ******************************                           |                                                                                                                                                                                                            |                                     |
|                                                     |                                                     | s=offwrite settings fil                                  | es=off rtl_simulation_lab -c rtl_simulation_lab                                                                                                                                                            |                                     |
| 18236 Number of processo<br>10905 Generated the EDA | rs has not been specifi-<br>functional simulation n | ed which may cause overloa<br>etlist because it is the o | ding on shared machines. Set the global assignment NUM_PARALLEL_PROCESSORS in your QSF to an a<br>nly supported netlist type for this device.<br>ulation_lab/simulation/modelsim/" for EDA simulation tool | uppropriate value for best perfo    |
| > Quartus Prime EDA                                 | Netlist Writer was succ                             | essful. O errors, 2 warnir                               | 105                                                                                                                                                                                                        |                                     |
|                                                     |                                                     | sful. O errors, 24 warning                               |                                                                                                                                                                                                            |                                     |
| o <                                                 |                                                     |                                                          |                                                                                                                                                                                                            |                                     |
|                                                     |                                                     |                                                          |                                                                                                                                                                                                            |                                     |

### 4.4.4 Configuration

4.4.4.1 Connect your MAX1000 board to your PC using an USB cable. Since the Arrow USB Blaster should be already installed, the Window's Device Manager should display the following entries are highlighted in red (port number may differ depending on your PC):

| ~ | Ports (COM & LPT)                                               |
|---|-----------------------------------------------------------------|
|   | ISB Serial Port (COM4)                                          |
| > | S Print queues                                                  |
| > | S Printers                                                      |
| > | Processors                                                      |
| > | 💕 Software components                                           |
| > | Software devices                                                |
| > | Sound, video and game controllers                               |
| > | Storage controllers                                             |
| > | Notes System devices                                            |
| ~ | 🛩 Universal Serial Bus controllers                              |
|   | 🛹 Generic SuperSpeed USB Hub                                    |
|   | 🐲 Generic USB Hub                                               |
|   | 🛩 Generic USB Hub                                               |
|   | 🛩 Intel(R) USB 3.0 eXtensible Host Controller - 1.0 (Microsoft) |
|   | Intel(R) USB 3.1 eXtensible Host Controller - 1.10 (Microsoft)  |
|   | 🛩 USB Composite Device                                          |
|   | 🛩 USB Composite Device                                          |
|   | SB Root Hub (USB 3.0)                                           |
|   | JUSB Root Hub (USB 3.0)                                         |
|   | 🛹 USB Serial Converter A                                        |
|   | 🛩 USB Serial Converter B                                        |
|   |                                                                 |
|   | Page   23                                                       |
|   |                                                                 |
|   |                                                                 |

MAX1000 RTL Simulation Lab www.arrow.com January 2019

4.4.4.2 Open the Quartus Prime Programmer from **Tools** → **Programmer** or double click on Program Device (Open Programmer) from the Task window.

| -                    | /MAX1000/RTL_Simulation |                  | on_lab - rtl_simu | lation_lab - [r | tl_simulation_        | lab.cdf]* |                 |         |                 | s     | earch alte   | era.com | × |
|----------------------|-------------------------|------------------|-------------------|-----------------|-----------------------|-----------|-----------------|---------|-----------------|-------|--------------|---------|---|
| 🚖 Hardware Setu      | p No Hardware           |                  |                   |                 | Mode: JTAC            | 5         |                 | •       | Progress:       |       |              |         |   |
| Enable real-time     | ISP to allow backgrour  | id programming w | hen available     |                 |                       |           |                 |         |                 |       |              |         |   |
| ▶ <sup>™</sup> Start | File                    | Device           | Checksum          | Usercode        | Program/<br>Configure | Verify    | Blank-<br>Check | Examine | Security<br>Bit | Erase | ISP<br>CLAMP |         |   |
| <sup>⊒‰</sup> Stop   |                         |                  |                   |                 | compare               |           | check           |         | Div             |       | CLAIN        |         |   |
| Auto Detect          |                         |                  |                   |                 |                       |           |                 |         |                 |       |              |         |   |
| × Delete             |                         |                  |                   |                 |                       |           |                 |         |                 |       |              |         |   |
| Add File             |                         |                  |                   |                 |                       |           |                 |         |                 |       |              |         |   |
| Change File          |                         |                  |                   |                 |                       |           |                 |         |                 |       |              |         |   |
| Add Device           |                         |                  |                   |                 |                       |           |                 |         |                 |       |              |         |   |
| 1 <sup>1</sup> Up    |                         |                  |                   |                 |                       |           |                 |         |                 |       |              |         |   |
| <sup>1™</sup> Down   |                         |                  |                   |                 |                       |           |                 |         |                 |       |              |         |   |
|                      |                         |                  |                   |                 |                       |           |                 |         |                 |       |              |         |   |
|                      |                         |                  |                   |                 |                       |           |                 |         |                 |       |              |         |   |
|                      |                         |                  |                   |                 |                       |           |                 |         |                 |       |              |         |   |
|                      |                         |                  |                   |                 |                       |           |                 |         |                 |       |              |         |   |
|                      |                         |                  |                   |                 |                       |           |                 |         |                 |       |              |         |   |
|                      |                         |                  |                   |                 |                       |           |                 |         |                 |       |              |         |   |

4.4.4.3 Click **Hardware Setup...** and double click **Arrow-USB-Blaster** entry in the Hardware Setup tab. The Currently selected hardware should now show Arrow-USB-Blaster [USB0] (depending on your PC, the USB port number may variant).

| Hardware Settings J                                 | TAG Settings    |               |                                    |
|-----------------------------------------------------|-----------------|---------------|------------------------------------|
| Select a programming ha<br>ardware setup applies o  |                 |               | ng devices. This programming<br>w. |
| Currently selected hardw<br>Available hardware iter |                 | laster [USB0] |                                    |
| Hardware<br>Arrow-USB-Blaster                       | Server<br>Local | Port<br>USB0  | Add Hardware<br>Remove Hardware    |

4.4.4.4 Click Close.

4.4.4.5 Make sure the hardware setup is Arrow-USB-Blaster [USB0] and the mode is JTAG. Click **Auto Detect**.

|                                  | 'MAX1000/RTL_Simulation |        | n_lab - rtl_simu        | lation_lab - [r | tl_simulation_        | lab.cdf]* |                 |         |                 |       | _<br>Search al | L<br>tera.com | × |
|----------------------------------|-------------------------|--------|-------------------------|-----------------|-----------------------|-----------|-----------------|---------|-----------------|-------|----------------|---------------|---|
|                                  | Arrow-USB-Blaster       |        | Mode: JTAG    Progress: |                 |                       |           |                 | 5:      |                 |       |                |               |   |
| Enable real-time                 | ISP to allow backgroun  |        |                         |                 | 1                     |           |                 |         | 1               |       |                |               |   |
| <sup>▶¹</sup> <sup>1</sup> Start | File                    | Device | Checksum                | Usercode        | Program/<br>Configure | Verify    | Blank-<br>Check | Examine | Security<br>Bit | Erase | ISP<br>CLAMP   |               |   |
| ilib Stop                        |                         |        |                         |                 |                       |           |                 |         |                 |       |                |               |   |
| Auto Detect                      |                         |        |                         |                 |                       |           |                 |         |                 |       |                |               |   |
| Add File                         |                         |        |                         |                 |                       |           |                 |         |                 |       |                |               |   |
| Change File                      |                         |        |                         |                 |                       |           |                 |         |                 |       |                |               |   |
| 🕒 Save File                      |                         |        |                         |                 |                       |           |                 |         |                 |       |                |               |   |
| r Add Device                     |                         |        |                         |                 |                       |           |                 |         |                 |       |                |               |   |
| 1 <sup>11</sup> Up               |                         |        |                         |                 |                       |           |                 |         |                 |       |                |               |   |
| <sup>∥∿</sup> b Down             |                         |        |                         |                 |                       |           |                 |         |                 |       |                |               |   |
|                                  |                         |        |                         |                 |                       |           |                 |         |                 |       |                |               |   |
|                                  |                         |        |                         |                 |                       |           |                 |         |                 |       |                |               |   |
|                                  |                         |        |                         |                 |                       |           |                 |         |                 |       |                |               |   |
|                                  |                         |        |                         |                 |                       |           |                 |         |                 |       |                |               |   |
|                                  |                         |        |                         |                 |                       |           |                 |         |                 |       |                |               |   |
| L                                |                         |        |                         |                 |                       |           |                 |         |                 |       |                |               |   |

- 4.4.4.6 If the configuration has been added by default, you can skip the following steps and continue with the 4.4.4.11 point.
- 4.4.4.7 Select **10M08SA** device and click **OK** in the pop-up window.



- 4.4.4.8 Double click <none> or click Change File... to choose the programming file.
- 4.4.4.9 Navigate to <project\_directory>/output\_files/ and select the simple\_nios\_lab.sof file.
- 4.4.4.10 Click **Open**.

4.4.4.11 Make sure the Programmer shows the correct file and the correct part in the JTAG chain and check the Program/Configure checkbox.

| _                                                     | :/MAX1000/RTL_Simulation_lab/rtl_sim<br>Processing Tools Window Hel |                    | nulation_lab - | p - [rtl_simulation_lab.cdf]* |                       |           |                 |         |                 |       |              | ×<br>]• |
|-------------------------------------------------------|---------------------------------------------------------------------|--------------------|----------------|-------------------------------|-----------------------|-----------|-----------------|---------|-----------------|-------|--------------|---------|
| 🔔 Hardware Setu                                       | p Arrow-USB-Blaster [USB0]                                          |                    |                | Mode: JT                      | •                     | Progress: |                 |         |                 |       |              |         |
| Enable real-time                                      | ISP to allow background programm                                    | ing when available |                |                               |                       |           |                 |         |                 |       |              |         |
| M Start                                               | File                                                                | Device             | Checksum       | Usercode                      | Program/<br>Configure | Verify    | Blank-<br>Check | Examine | Security<br>Bit | Erase | ISP<br>CLAMP |         |
| <sup>≣</sup> <sup>™</sup> Stop                        | output_files/rtl_simulation_lab.sof                                 | 10M08SAU169        | 000851A7       | 000851A7                      |                       |           |                 |         |                 |       |              |         |
| 🍓 Auto Detect                                         |                                                                     |                    |                |                               |                       |           |                 |         |                 |       |              |         |
| × Delete                                              |                                                                     |                    |                |                               |                       |           |                 |         |                 |       |              |         |
| Add File                                              |                                                                     |                    |                |                               |                       |           |                 |         |                 |       |              |         |
| Change File                                           |                                                                     |                    |                |                               |                       |           |                 |         |                 |       |              |         |
| P Save File<br>P Add Device<br>P Up<br>P Up<br>P Down |                                                                     |                    |                |                               |                       |           |                 |         |                 |       |              |         |

4.4.4.12 Click **Start** to program the board. When the configuration is complete, the Progress bar should show 100% (Successful).

| Progress | : 100% (Successful) |
|----------|---------------------|
|----------|---------------------|

#### 4.4.5 Testing the design

4.4.5.1 Verify that the LEDs on MAX1000 board toggles in the order shown by the simulation.

### CONGRATULATIONS! YOU HAVE SUCCESSFULLY COMPLETED THE RTL SIMULATION LAB!

### 5 Revision History

| Version | Change Log      | Date of Change |
|---------|-----------------|----------------|
| V1.0    | Initial Version | 16/01/2019     |

### 6 Legal Disclaimer

#### **ARROW ELECTRONICS**

#### **EVALUATION BOARD LICENSE AGREEMENT**

By using this evaluation board or kit (together with all related software, firmware, components, and documentation provided by Arrow, "Evaluation Board"), You ("You") are agreeing to be bound by the terms and conditions of this Evaluation Board License Agreement ("Agreement"). Do not use the Evaluation Board until You have read and agreed to this Agreement. Your use of the Evaluation Board constitutes Your acceptance of this Agreement.

#### PURPOSE

The purpose of this evaluation board is solely intended for evaluation purposes. Any use of the Board beyond these purposes is on your own risk. Furthermore, according the applicable law, the offering Arrow entity explicitly does not warrant, guarantee or provide any remedies to you with regard to the board.

#### LICENSE

Arrow grants You a non-exclusive, limited right to use the enclosed Evaluation Board offering limited features only for Your evaluation and testing purposes in a research and development setting. Usage in a live environment is prohibited. The Evaluation Board shall not be, in any case, directly or indirectly assembled as a part in any production of Yours as it is solely developed to serve evaluation purposes and has no direct function and is not a finished product.

#### **EVALUATION BOARD STATUS**

The Evaluation Board offers limited features allowing You only to evaluate and test purposes. The Evaluation Board is not intended for consumer or household use. You are not authorized to use the Evaluation Board in any production system, and it may not be offered for sale or lease, or sold, leased or otherwise distributed for commercial purposes.

#### **OWNERSHIP AND COPYRIGHT**

Title to the Evaluation Board remains with Arrow and/or its licensors. This Agreement does not involve any transfer of intellectual property rights ("IPR) for evaluation board. You may not remove any copyright or other proprietary rights notices without prior written authorization from Arrow or it licensors.

#### **RESTRICTIONS AND WARNINGS**

Before You handle or use the Evaluation Board, You shall comply with all such warnings and other instructions and employ reasonable safety precautions in using the Evaluation Board. Failure to do so may result in death, personal injury, or property damage.

You shall not use the Evaluation Board in any safety critical or functional safety testing, including but not limited to testing of life supporting, military or nuclear applications. Arrow expressly disclaims any responsibility for such usage which shall be made at Your sole risk.

#### WARRANTY

Arrow warrants that it has the right to provide the evaluation board to you. This warranty is provided by Arrow in lieu of all other warranties, written or oral, statutory, express or implied, including any warranty as to merchantability, non-infringement, fitness for any particular purpose, or uninterrupted or error-free operation, all of which are expressly disclaimed. The evaluation board is provided "as is" without any other rights or warranties, directly or indirectly.

You warrant to Arrow that the evaluation board is used only by electronics experts who understand the dangers of handling and using such items, you assume all responsibility and liability for any improper or unsafe handling or use of the evaluation board by you, your employees, affiliates, contractors, and designees.

# wow

#### LIMITATION OF LIABILITIES

In no event shall Arrow be liable to you, whether in contract, tort (including negligence), strict liability, or any other legal theory, for any direct, indirect, special, consequential, incidental, punitive, or exemplary damages with respect to any matters relating to this agreement. In no event shall arrow's liability arising out of this agreement in the aggregate exceed the amount paid by you under this agreement for the purchase of the evaluation board.

#### IDENTIFICATION

You shall, at Your expense, defend Arrow and its Affiliates and Licensors against a claim or action brought by a third party for infringement or misappropriation of any patent, copyright, trade secret or other intellectual property right of a third party to the extent resulting from (1) Your combination of the Evaluation Board with any other component, system, software, or firmware, (2) Your modification of the Evaluation Board, or (3) Your use of the Evaluation Board in a manner not permitted under this Agreement. You shall indemnify Arrow and its Affiliates and Licensors against and pay any resulting costs and damages finally awarded against Arrow and its Affiliates and Licensors or agreed to in any settlement, provided that You have sole control of the defense and settlement of the claim or action, and Arrow cooperates in the defense and furnishes all related evidence under its control at Your expense. Arrow will be entitled to participate in the defense of such claim or action and to employ counsel at its own expense.

#### RECYCLING

The Evaluation Board is not to be disposed as an urban waste. At the end of its life cycle, differentiated waste collection must be followed, as stated in the directive 2002/96/EC. In all the countries belonging to the European Union (EU Dir. 2002/96/EC) and those following differentiated recycling, the Evaluation Board is subject to differentiated recycling at the end of its life cycle, therefore: It is forbidden to dispose the Evaluation Board as an undifferentiated waste or with other domestic wastes. Consult the local authorities for more information on the proper disposal channels. An incorrect Evaluation Board disposal may cause damage to the environment and is punishable by the law.