

# FPGA Design for Embedded Systems

## FPGA Softcore Processors and IP Acquisition



# FPGA Softcore Processors and IP Acquisition



## Why learn about Soft Processors and IP?

- Soft Processors have many unique advantages:
  - Flexibility : Hardware vs Software tradeoffs are easy to make
  - No Obsolescence: Infinitely migratable into future FPGA devices
  - Mature tools: Simulators, IDEs, Debuggers, and even Internal Logic Analyzers
  - Customization: Custom instructions and Custom Hardware can easily be added

| Feature                 | Altera Nios II                | ARM Cortex-M1 | Xilinx Microblaze    | Xilinx Picoblaze | Microsemi Core ABC | Microsemi Core8051 | Lattice Mico32 | Lattice Mico8 |
|-------------------------|-------------------------------|---------------|----------------------|------------------|--------------------|--------------------|----------------|---------------|
| Datapath                | 32 bits                       | 32 bits       | 32 bits              | 8 bits           | 8/16/32            | 8 bits             | 32 bits        | 8 bits        |
| Pipeline Stages         | 1-6                           | 3             | 3-5                  | 1                | 1                  | 1                  | 6              | 1             |
| Frequency (MHz)         | 340                           | 200           | 332                  | 240              | 92                 | 52                 | 115            | 52.2          |
| Gate Count              | 26k – 72k                     | 2.6k-4k       | 30k – 60k            | 500 – 2k         | 420-4k             | 3k-5k              | 20k-25k        | 2k-3k         |
| Register File           | 32 gen. + 32 special          | 16            | 32 gen. + 32 special | 16               | 1                  | 32                 | 32             | 16 or 32      |
| Instruction Word        | 32 bits                       | 16/32         | 32 bits              | 18 bits          | 8/16               | 8/16               | 32             | 18            |
| Instruction Cache       | Optional                      | No            | Optional             | No               | No                 | No                 | Option         | No            |
| Hardware Multiply       | Optional                      | Yes           | Optional             | No               | No                 | No                 | Yes            | No            |
| Hardware Floating Point | Optional                      | No            | Optional             | No               | No                 | No                 | No             | No            |
| OS Support              | eCOS, uC/OSII, Linux, uClinix | RTX           | Linux                | --               | --                 | --                 | --             | --            |



# FPGA Softcore Processors and IP Acquisition



Interesting  
Architectures!



# FPGA Softcore Processors and IP Acquisition



Fun Dev Tools!



# FPGA Softcore Processors and IP Acquisition



System Level  
Design!



# FPGA Softcore Processors and IP Acquisition



Customizing!



# FPGA Softcore Processors and IP Acquisition



Nios II Debug - HelloNios2/hello\_world\_small.c - Eclipse

File Edit Source Refactor Navigate Project Nios II Run Window Help

Debug

Embed\_System Nios II Hardware configuration [Nios II Hardware]

Altera CDI GDB Debugger (7/20/20, 12:25 AM) (Suspended)

Thread [1] (Suspended: Breakpoint hit)

1 main() hello\_world\_small.c:85 0x040001b4

<terminated, exit value: 0> nios2-download (7/20/20, 12:25 AM)

nios2-download (7/20/20, 12:25 AM)

nios2-elf-gdb (7/20/20, 12:25 AM)

hello\_world\_small.c

```
#include "sys/alt_stdio.h"

int main()
{
    alt_putstr("Hello from Nios II!\n");

    /* Event loop never exits. */
    while (1);

    return 0;
}
```

Console Nios II Console

Embed\_System Nios II Hardware configuration - cable: USB-Blaster on localhost [USB-0] device ID: 1 instance ID: 1 name: jaguar\_0

Hello from Nios II!

Coding in Eclipse!



# FPGA Softcore Processors and IP Acquisition

Lots of Examples



# Modules in this Course



1. Make Your Own Processor – Softcore Processor Development Flow
2. Writing Software for Softcore Processors
3. IP Acquisition and Integration
4. Introducing ModelSim and Simulation for Verification

# Be Boulder.

© University of Colorado Regents



University of Colorado **Boulder**

© University of Colorado Regents

# FPGA Design for Embedded Systems

## FPGA Softcore Processors and IP Acquisition



# Create a Soft Processor – Series Introduction



- Learn Architecture of a processor
- Build a processor system
- Customize the processor

# Create a Soft Processor



FPGAs offer the flexibility to create and integrate a custom microprocessor into the hardware IP in the system.

- Peripherals, Memories, IO

Software development of soft processors is supported by a flow like discrete microcontroller designs.

- JTAG interface debugging, C compiler

# Create a Soft Processor



Programmable Logic based processor design allows for design trade offs between:

- Discrete Fixed IP
- Software Control
- Custom FPGA Logic

Flexibility increases the design process complexity:

- Software offload verses Hardware effort

# Videos in this module



1. Series Introduction
2. Soft Processor Advantages
3. Soft Processor Development Flows
4. Soft Processor Architectures, Part I
5. Soft Processor Architectures, Part II
6. Nios II Dev: Definitions
7. Nios II Dev: Connections (PD/Qsys Demo)
8. Nios II Dev: Compilation
9. Nios II Dev: Programming
10. Nios II Dev: Customization

# FPGA Design for Embedded Systems

## FPGA Softcore Processors and IP Acquisition



# Soft Processor Advantages

- Flexibility : Hardware vs Software
- Infinitely migratable into future devices
- Mature tools
  - Reference designs, flows, ecosystems



# Soft Processor Advantages



- **Flexibility : Hardware vs Software**
  - Team : C programmers vs HDL programmers
    - Change management : Update C code or HDL
  - Software tasks : Dedicated FPGA Logic
  - Pre-Compile before selecting FPGA
    - Choose based on : Frequency, Size, Price, IO
  - Memory: cache size selectable
- **Infinitely migratable into future FPGA devices**
  - C code, processor configuration
  - Increased performance, lower power, lower cost
  - Move into larger or smaller device, or an ASIC\*
  - Add another core for new features

\*= License required

Copyright © 2020 University of Colorado



# Soft Processor Advantages



- Mature tools and ecosystem
  - Reference designs and flows
  - In system JTAG code trace:
    - Multi (Green Hills), Trace32 (Lauterbach), XMTC (Xilinx)
    - Instruction and Data trace
  - Operating Systems and RTOS :
    - eCos, uClinux, FreeRTOS
  - Software : Simulink/Matlab (Mathworks)
  - In System Nodes : SignalTap, SmartDebug, ChipScope

# Soft Processor Advantages

- Soft Processor type
  - (E) Economy
  - (F) Fast



# Soft Processor Advantages

- Soft Processor type\*: (E) Economy, (F) Fast

|                          | <u>NIOS II (E)</u> | <u>NIOS II (F)</u>    |
|--------------------------|--------------------|-----------------------|
| <b>Pipeline</b>          | <b>1 Stage</b>     | <b>6 Stages</b>       |
| <b>Branch Prediction</b> | <b>None</b>        | <b>Dynamic</b>        |
| <b>HW Multiplication</b> | <b>Software</b>    | <b>1 Cycle HW</b>     |
| <b>Inst/Data cache</b>   | <b>None</b>        | <b>0.5 – 64 Kbyte</b> |
| <b>MMU</b>               | <b>None</b>        | <b>Available</b>      |
| <hr/>                    |                    |                       |
| <b>Area</b>              | <b>540 LEs</b>     | <b>1600 LEs</b>       |
| <b>Freq</b>              | <b>195 MHz</b>     | <b>140 MHz</b>        |
| <b>Perf</b>              | <b>18 MIPS</b>     | <b>145 MIPS</b>       |

\*Intel/Altera Cyclone II Device Comparison

Copyright © 2020 University of Colorado



# Soft Processor Advantages



- Variety of 3<sup>rd</sup> party cores
  - 8051 (Cast)
  - 68000 (Digital Core Design)
  - 80186 (iWave)
- Advantage is software code compatible
  - Discrete device no longer available

# Soft Processor Advantages

- PicoBlaze 8bit (Xilinx, very small area and code)



# Soft Processor Advantages

- Dedicated Bus Structure
  - Intel-Altera NIOS : Avalon
  - Xilinx MicroBlaze : AXI
  - Microchip-Microsemi ARM Cortex-M1 : AHB



# Soft Processor Advantages

- Dedicated and Custom Peripherals addressable through the bus fabric



# • Bus Structure: Xilinx MicroBlaze : AXI



- Bus Structure: Intel-Altera NIOS : Avalon



# Soft Processor Advantages

- Flexibility : Hardware vs Software
- Infinitely migratable into future devices
- Mature tools



# Create a Soft Processor

## FPGA References

<https://www.intel.com/content/www/us/en/products/programmable/processor/nios-ii/benefits.html>

<https://www.intel.com/content/www/us/en/products/programmable/processor/nios-ii/ecosystem.html>

<https://www.xilinx.com/products/intellectual-property/xmtc.html>

<https://www.xilinx.com/products/intellectual-property/nav-embedded/nav-embedded-processors.html>

[https://www.xilinx.com/support/documentation/sw\\_manuals/xilinx2017\\_2/ug984-vivado-microblaze-ref.pdf](https://www.xilinx.com/support/documentation/sw_manuals/xilinx2017_2/ug984-vivado-microblaze-ref.pdf)

“Embedded SoPC Design with NIOS II Processor and Verilog Examples”, Pong P. Chu, pg 231 Table 9.1  
NIOS II Comparison

[https://www.xilinx.com/support/documentation/sw\\_manuals/xilinx2017\\_2/ug984-vivado-microblaze-ref.pdf](https://www.xilinx.com/support/documentation/sw_manuals/xilinx2017_2/ug984-vivado-microblaze-ref.pdf)

[https://www.intel.com/content/dam/www/programmable/us/en/pdfs/literature/manual/mnl\\_avalon\\_spec.pdf](https://www.intel.com/content/dam/www/programmable/us/en/pdfs/literature/manual/mnl_avalon_spec.pdf)



# FPGA Design for Embedded Systems

FPGA Softcore Processors and IP Acquisition



University of Colorado **Boulder**

0:02 / 5:55

Copyright © 2020 University of Colorado



# Soft Processor Flows

- NIOS II System Definition for Component Selection
- Questions for System Design:
  - What computational requirements does the design have?
  - How much bandwidth is needed? DDR3, DDR4?
  - What types of interfaces and how many IO are needed?
  - Is there a multi-threaded application or Operating System?



# Soft Processor Flows

- Based on these questions, one can determine:
  - Faster or smaller processor? Interfaces?
  - Hardware acceleration or off-loading?
    - DMA needed to eliminate processor cycles copying data?
    - Could a custom instruction remove a loop from a DSP algorithm?



# Soft Processor Flows

- NIOS II Platform Designer Flow, formerly called Qsys



# Soft Processor Flows

- NIOS II Platform Designer Flow, formerly called Qsys
- Platform Designer (Qsys) is a system development tool for creating processors, peripherals, and memories.
- Once compiled, the logic cells and flip-flops inside the FPGA are loaded with the processor configuration.
- The design is volatile and is re-programmed at power ON.

- NIOS II Platform Designer Detailed Flow
- hardware design steps
- software design steps
- system design steps, involving both hardware and software

### Nios II System Development Flow



- Board
  - JTAG
  - Clocks
  - IO
  - Power
- FPGA
  - Nios Core
  - Logic



- NIOS II Block Level Design

# Soft Processor Flows

- Signals in Platform Designer
- Clock and reset pins are defined in Platform Designer.
- Each IO that is required for the NIOS system is added.
- Constraints, like clock frequency and reset pin definitions are added.



# Soft Processor Flows

- Software Development in Eclipse
- After generating and compiling the system, the C/C++ code development can begin with the Nios II Software Build Tools for Eclipse.
- Eclipse uses information from the .sopcinfo file
- system.h defines symbols in the hardware
- Executable and Linking Format File (.elf) result of compiling a C/C++
- Hexadecimal (Intel-Format) File (.hex) initialization information for on-chip memories
- Flash memory programming data, boot code



# Soft Processor Flows

- System Configuration definition is needed for Processor Hardware development
- Once the Hardware is defined, the Software will depend on the Hardware definition
- When the Hardware definition is loaded into the Software C/C++ coding can begin



# FPGA Design for Embedded Systems

FPGA Softcore Processors and IP Acquisition



University of Colorado **Boulder**

0:04 / 11:25

Copyright © 2020 University of Colorado



# Overview

- Review of soft processors on the market.
- Describe the architecture of the NIOS II soft core processor.
- Specific components of the core are described in detail.



| Feature                 | Altera Nios II                   | ARM Cortex-M1 | Xilinx Microblaze       | Xilinx Picoblaze | Microsemi Core ABC | Microsemi Core8051 | Lattice Mico32 | Lattice Mico8 |
|-------------------------|----------------------------------|---------------|-------------------------|------------------|--------------------|--------------------|----------------|---------------|
| Datapath                | 32 bits                          | 32 bits       | 32 bits                 | 8 bits           | 8/16/32            | 8 bits             | 32 bits        | 8 bits        |
| Pipeline Stages         | 1-6                              | 3             | 3-5                     | 1                | 1                  | 1                  | 6              | 1             |
| Frequency (MHz)         | 340                              | 200           | 332                     | 240              | 92                 | 52                 | 115            | 52.2          |
| Gate Count              | 26k – 72k                        | 2.6k-4k       | 30k – 60k               | 500 – 2k         | 420-4k             | 3k-5k              | 20k-25k        | 2k-3k         |
| Register File           | 32 gen. +<br>32 special          | 16            | 32 gen. +<br>32 special | 16               | 1                  | 32                 | 32             | 16 or<br>32   |
| Instruction Word        | 32 bits                          | 16/32         | 32 bits                 | 18 bits          | 8/16               | 8/16               | 32             | 18            |
| Instruction Cache       | Optional                         | No            | Optional                | No               | No                 | No                 | Option         | No            |
| Hardware Multiply       | Optional                         | Yes           | Optional                | No               | No                 | No                 | Yes            | No            |
| Hardware Floating Point | Optional                         | No            | Optional                | No               | No                 | No                 | No             | No            |
| OS Support              | eCOS, uC/OSII,<br>Linux, uClinux | RTX           | Linux                   | --               | --                 | --                 | --             | --            |



# Soft Processor Architecture : Part I

- NIOS II Processor Core



# Soft Processor Architecture

- NIOS II Core



- A FPGA based processor system is equivalent to a microcontroller or “computer on a chip” that includes a processor and a combination of peripherals and memory on a single chip.
- A processor system includes:
  - processor core
  - on-chip peripherals and on-chip memory
  - interfaces to off-chip memory
- All processor systems use a consistent instruction set and programming model.



# Soft Processor Architecture

- NIOS II Core Features
  - 32 bit RISC – Reduced Instruction Set Core
  - Full 32-bit instruction set, data path, and address space
  - Quantity 32 general-purpose registers
  - Quantity 32 interrupt sources
  - External interrupt controller for more interrupt sources
  - Single-instruction  $32 \times 32$  multiply and divide producing a 32-bit result
  - Dedicated instructions for computing 64-bit and 128-bit products of multiplication
  - Optional floating-point instructions for single-precision floating-point operations
  - Single-instruction barrel shifter

# Soft Processor Architecture

- NIOS II Core Features
  - Access to on-chip peripherals, and interfaces to off-chip memories and peripherals
  - Hardware-assisted debug module enabling processor start, stop, step, and trace
  - Optional memory management unit (MMU) to support operating systems that require MMUs
  - Optional memory protection unit (MPU)



A man with short, light-colored hair, wearing a white button-down shirt, is speaking. He is positioned on the left side of the frame, with a dark background behind him. He appears to be in the middle of a sentence, with his mouth slightly open.

# Soft Processor Architecture

- NIOS II Core Features
  - Software development environment based on the GNU C/C++ tool chain
  - Integration with FPGA's Signal Tap Embedded Logic Analyzer, enabling real-time analysis of instructions and data along with other signals in the FPGA design
  - Instruction set architecture (ISA) compatible across all processor systems
  - Performance up to 250 DMIPS
  - Optional error correcting code (ECC) support for a subset of processor internal RAM blocks

# Soft Processor Architecture

- NIOS II Processor System

- Internal
- External
- Bus Fabric



# Soft Processor Architecture

- NIOS II ALU
  - Standard
    - Arithmetic
    - Relational  $<$ ,  $>$ ,  $\neq$
    - Logical AND, OR
    - Shift
  - Customizable
    - DSP
    - FIR



# Soft Processor Architecture



- NIOS II ALU
- Hardware implementation or software computation?
  - Applications that rarely perform complex arithmetic, the division instruction can be computed by many cycles in software
  - Removing the divide hardware conserves on-chip resources but increases the execution cycles of division operations.

# Soft Processor Architecture

- NIOS II Core : Register File
  - Quantity thirty-two 32-bit GP integer registers
  - Quantity thirty-two 32-bit control registers
  - Optional : one or more shadow register sets. A shadow register set is a complete set of Nios II general-purpose registers
  - Typical use of shadow register sets is to accelerate context switching
  - Shadow register sets are typically manipulated by an operating system kernel, and are transparent to application code





# Soft Processor Architecture

- NIOS II Core : Reset control

**reset**: global hardware reset signal that forces the processor core to reset immediately

**cpu\_resetrequest**: optional, local reset signal that causes the processor to reset without affecting other components in the system

**debug\_reset\_request**: when the JTAG Debug module is enabled, allows the JTAG debugger to reset the processor

**debugreq**: optional signal that temporarily suspends the processor for debugging purposes

**reset\_req**: optional signal prevents the memory corruption by performing a reset handshake before the processor resets



# Soft Processor Architecture

- NIOS II Core : Exception and Interrupt
  - External interrupt controller (EIC) interface enables a speed up of interrupt handling in a complex system by adding a custom interrupt controller, software configurable
  - EC : a non-vectored exception controller handles all exception types and each exception causes the processor to transfer execution to an exception address
  - IC : 32 level-sensitive interrupt request (IRQ) inputs, irq0 through irq31, providing a unique input for each interrupt source

# Architecture : Summary

- Definition of an FPGA Processor System
- NIOS Core features



# FPGA Design for Embedded Systems

FPGA Softcore Processors and IP Acquisition



University of Colorado **Boulder**

0:08 / 7:58

Copyright © 2020 University of Colorado



# Soft Processor Architecture : Part II

- NIOS II Memory and IO
  - Instruction
  - Data
  - Memory
    - Tightly Coupled
    - External
  - IO
    - External





# Soft Processor Architecture

- NIOS II Core : Memory and IO
  - Memory Mapped :
    - Instruction Memory Mapped master port that connects to instruction memory by system interconnect fabric
    - Instruction cache: Fast cache memory internal to the Nios II core
    - Data master port: A mapped master port that connects to data memory and peripherals via system interconnect fabric
    - Data cache: Fast cache memory internal to the Nios II core
    - Tightly coupled instruction or data memory port interface to fast on-chip memory outside to the Nios II core
  - IO organization varies per FPGA device

# Soft Processor Architecture

- NIOS II Core : Memory and IO
  - Memory Mapping :
    - The architecture supports separate instruction and data buses, classifying it as a Harvard architecture.
    - Both the instruction and data buses are implemented as master ports.
    - The data master port connects components
      - memory
      - peripheral components
    - Instruction master port connects only
      - memory
    - The instruction and data masters have a combined address map and instructions and data are in the same address space



# Soft Processor Architecture

- NIOS II Core : Instruction and Data
  - Instruction Port:
    - Fetches instructions to be executed by the processor. The instruction master port is pipelined, and does not perform any write operations
  - Data Port:
    - Reads data from memory or a peripheral when the processor executes a load instruction
    - Writes data to memory or a peripheral when the processor executes a store instruction
  - Cache and TCMs supported by both I and D



# Soft Processor Architecture

- NIOS II Core : Cache Memory
  - Instruction (optional)
  - Data (optional)
  - Cache memories can improve the average memory access time for processor systems that use slow off-chip memory such as SDRAM for program and data storage
  - Caches are enabled perpetually at run-time, but methods are provided for software to bypass
  - Cache management and cache coherency are handled by software



\*\*Note: If the critical loop of a program is 2 KB, but the size of the instruction cache is 1 KB, an instruction cache does not improve execution speed. In fact, an instruction cache may degrade performance in this situation. Usage of Cache is Application Dependent.



# Soft Processor Architecture

- NIOS II Core : TCM (on-chip, external to core)
- Tightly Coupled Memory
  - Instruction (optional)
  - Data (optional)
  - TCM ports are a separate master port on the processor core.
  - Performance critical code or data is located in a TCM.
  - Compute-intensive digital signal processing (DSP) applications can place data buffers into TCMs for the fastest possible data access
  - Normal address space, the same as other memory addressed devices connected via system interconnect fabric.

Note: The TCM master requires a fixed memory latency of 1 cycle



# Soft Processor Architecture

- NIOS II Core : MMU or (exclusive) MPU
- Memory Management/Protection Unit
- MMU
  - 4 GB of virtual to physical memory 4-KB page and frame size control
  - Translation Lookaside Buffers (TLBs), accelerating address translation
    - TLBs acting as n-way set-associative caches for software page tables



# Soft Processor Architecture

- MPU
  - Read and write access permissions for data regions
  - Execute access permissions for instruction regions



# Soft Processor Architecture

- NIOS II Core : JTAG Debug Module
  - PC to core control
    - Downloading programs to memory
    - Starting and stopping execution
    - Setting breakpoints and watchpoints (break Instruction)
    - Analyzing registers and memory contents
    - Collecting real-time execution trace data
  - The “soft” processor allows you to debug a system in development using a full-featured debug core, and later remove the debug features to conserve logic resources



Note: While the processor has no minimum clock frequency requirements, it is recommended that the design's system clock frequency be at least 4X the JTAG clock frequency

# Soft Processor Architecture

- NIOS II Core : JTAG Debug Module
  - Triggers

| <u>Control</u>   | <u>Bus</u> | <u>Description</u>                             |
|------------------|------------|------------------------------------------------|
| Specific Address | D / I      | When the bus accesses a specific address.      |
| Specific Data    | D          | When a specific data value appears on the bus. |
| Read Cycle       | D          | On a read bus cycle.                           |
| Write Cycle      | D          | On a write bus cycle.                          |
| Armed            | D / I      | After an armed trigger event.                  |
| Range            | D          | On a range of address or data values, or both. |

Note: Off-chip trace buffer requires additional 3<sup>rd</sup> party debug software and hardware :

Imagination Technologies  
Lauterbach



# Architecture : Summary

- Definition of an FPGA Processor System
- NIOS Core features
- Internal and External Memory Support



# FPGA Design for Embedded Systems

## FPGA Softcore Processors and IP Acquisition



# NIOS II Development : Definitions

- Create Example Design : Max10
  - NIOS II and Fabric to components
  - ADC to Bus to IO 7 Segment Display
  - This video is a tool “Overview”, next video is a Demo



Max10 Device :

[https://www.intel.com/content/dam/www/programmable/us/en/pdfs/literature/hb/max-10/ug\\_m10\\_ufm.pdf](https://www.intel.com/content/dam/www/programmable/us/en/pdfs/literature/hb/max-10/ug_m10_ufm.pdf)

Max10 Example :

<https://fpgacloud.intel.com/devstore/platform/16.0.0/Standard/nios-ii-on-die-temperature-sensor-max10-de10-lite/>

# NIOS II Development :

- Max 10 ADC



[https://www.intel.com/content/dam/www/programmable/us/en/pdfs/literature/hb/max-10/ug\\_m10\\_adc.pdf](https://www.intel.com/content/dam/www/programmable/us/en/pdfs/literature/hb/max-10/ug_m10_adc.pdf)

# NIOS II Development :

- Create Example Design : Max10
  - DE10-Lite Development Kit : (used later)
  - ~50k LEs, ADC, 2x20 GPIO

<https://www.terasic.com.tw/>



# NIOS II Development :

- New Project Wizard : Board (tab)
  - DE10-Lite Template
  - IOs pre-defined

New Project Wizard

### Family, Device & Board Settings

Select the board/development kit you want to target for compilation.

Family: MAX 10 Development Kit: Any

Available boards:

|   | Name                           | Version | Family | Device           | Vendor           | LEs   |
|---|--------------------------------|---------|--------|------------------|------------------|-------|
| 1 | Arrow MAX 10 DECA              | 0.9     | MAX 10 | 10M50DAF484C6GES | Arrow            | 49760 |
| 2 | BeMicro MAX 10 FPGA Evaluat... | 1.0     | MAX 10 | 10M08DAF484C8GES | Arrow            | 8064  |
| 3 | MAX 10 DE10 - Lite             | 1.0     | MAX 10 | 10M50DAF484C6GES | Altera           | 49760 |
| 4 | MAX 10 FPGA 10M08 Evaluati...  | 1.0     | MAX 10 | 10M08SAE144C8GES | Altera           | 8064  |
| 5 | MAX 10 FPGA Development Kit    | 1.0     | MAX 10 | 10M50DAF256C7G   | Altera           | 49760 |
| 6 | MAX 10 NEEK                    | 1.0     | MAX 10 | 10M50DAF484I7G   | Terasic          | 49760 |
| 7 | Odyssey MAX 10 FPGA Kit        | 1.0     | MAX 10 | 10M08SAU169C8GES | Macnica Ameri... | 8064  |

Create top-level design file.

Can't find your board? Check the [Design Store](#) for additions and search for baseline under Design Examples.



# NIOS II Development :

- New Project Wizard :
  - Check Device and Board

 New Project Wizard

## Summary

When you click Finish, the project will be created with the following settings:

|                                 |                                      |
|---------------------------------|--------------------------------------|
| Project directory:              | C:\intelFPGA_lite\18.1\NIOS_Coursera |
| Project name:                   | NIOS_C                               |
| Top-level design entity:        | NIOS_C                               |
| Number of files added:          | 0                                    |
| Number of user libraries added: | 0                                    |
| Device assignments:             |                                      |
| Design template:                | n/a                                  |
| Family name:                    | MAX 10                               |
| Device:                         | 10M50DAF484C6GES                     |
| Board:                          | MAX 10 DE10 - Lite                   |



# NIOS II Development :

- Tools (Menu) :
  - Platform Designer
    - Older Versions (Qsys)



# NIOS II Development :

- NIOS II Platform Designer (Formerly Qsys)



# NIOS II Development :

- NIOS II Processor (e) Economy or (f) Fast

The image shows a man in a white shirt speaking in front of a computer screen. The screen displays the Nios II Processor configuration interface. The interface includes a 'Block Diagram' section showing the internal connections of the nios2\_gen2\_0 processor, and a 'Select an Implementation' table comparing Nios II/e and Nios II/f.

**Block Diagram:**

```
graph LR
    subgraph nios2_gen2_0 [nios2_gen2_0]
        clk --- clock
        reset --- reset
        irq --- interrupt
        debug_mem_slave --- avalon
        clock --- avalon
        reset --- avalon
        interrupt --- avalon
        avalon --- data_master
        avalon --- instruction_master
        avalon --- debug_reset_request
        avalon --- custom_instruction_master
        custom_instruction_master --- altera_nios2_gen2
    end
```

**Select an Implementation:**

|           | Nios II/e                        | Nios II/f                                                                                                                                                                                 |
|-----------|----------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Summary   | Resource-optimized 32-bit RISC   | Performance-optimized 32-bit RISC                                                                                                                                                         |
| Features  | JTAG Debug<br>ECC RAM Protection | JTAG Debug<br>Hardware Multiply/Divide<br>Instruction/Data Caches<br>Tightly-Coupled Masters<br>ECC RAM Protection<br>External Interrupt Controller<br>Shadow Register Sets<br>MPU<br>MMU |
| RAM Usage | 2 + Options                      | 2 + Options                                                                                                                                                                               |

The 'Nios II Core' section of the 'Select an Implementation' table has two radio buttons: 'Nios II/e' and 'Nios II/f'. The 'Nios II/f' button is selected and highlighted with a red oval.

# NIOS II Development :

- Add PLL : Double click



## NIOS II Development :

- PLL Wizard : Assign Parameters : input 50MHz



# NIOS II Development :

- PLL Wizard : Output Clock c0 80MHz : NIOS



# NIOS II Development :

- PLL Wizard : Output Clock c1 80MHz : SDRAM



# NIOS II Development :

- PLL Wizard : Output Clock c2 40MHz : Peripherals



# NIOS II Development :

- Platform Designer : altpll\_0 to clk\_in
- Errors are ok



# NIOS II Development :

- Platform Designer : add External clock



# NIOS II Development :

- Platform Designer : add External clock : 10MHz



# NIOS II Development :

- Platform Designer : add PLL for ADC : 10MHz



# NIOS II Development :

- Platform Designer : add PLL for ADC : 10MHz



# NIOS II Development :

- Platform Designer : Connections : hover over



# NIOS II Development :

- Platform Designer : Connections clk\_0 : click
  - clk = inclk\_interface, clk\_reset = inclk\_interface\_reset



## NIOS II Development :

- Platform Designer : Connections clk\_1: click
    - clk = inclk\_interface, clk\_reset = inclk\_interface\_reset
    - Errors gone now



# NIOS II Development :

- Platform Designer :
  - File : Save As core.qsys



# Development : Summary

- NIOS II Platform Designer : System Overview



# FPGA Design for Embedded Systems

## FPGA Softcore Processors and IP Acquisition



# NIOS II Development : Part II

- Platform Designer : add NIOS II



# NIOS II Development :

- NIOS II : JTAG Debug (tab)



# NIOS II Development :

- NIOS II: Caches and Memory (tab)



## NIOS II Development :

- NIOS II : Vectors (tab)



# NIOS II Development :

- Platform Designer :
- Finish : Fix Errors
  - Connect the NIOS clock input to the alt pll c0 output
  - Connect the NIOS reset input to the clk\_0 reset output
- Easy Right? (Click)
- File (menu) : Save



# NIOS II Development :

- Platform Designer : add RAM



# NIOS II Development :

- Platform Designer : add RAM

- Connect the memory clock input to the alt pll c0 clock
- Connect the memory reset1 signal to the clk\_0\_reset output
- Using the Connections column, connect the s1 Avalon Memory Mapped Slave interface of the on-chip RAM to the nios2 instruction\_master and nios2 data\_master
- Set the base address of the on-chip RAM s1 to 0x4000



# NIOS II Development :

- Platform Designer : add Flash



The screenshot shows the configuration window for the On-Chip Flash Intel FPGA IP. The window title is "On-Chip Flash Intel FPGA IP - onchip\_flash\_0".

**Block Diagram** (Left): Shows a block diagram of the "onchip\_flash\_0" component with four pins: clk (clock), nreset (reset), data (avalon), and csr (avalon).

**Parameters** (Top Right):

- Data interface: Parallel
- Read burst mode: Incrementing
- Read burst count: 8

**Configuration Mode** (Middle Right):

- Configuration Scheme: Internal Configuration
- Configuration Mode: Single Uncompressed Image with Memory Initialization (highlighted with a red oval)

**Flash Memory** (Bottom Right): A table showing five sectors:

| Sector ID | Access Mode    | Address Mapping    | Type                              |
|-----------|----------------|--------------------|-----------------------------------|
| 1         | Read and write | 0x00000 - 0x07fff  | UFM                               |
| 2         | Read and write | 0x08000 - 0x0ffff  | UFM                               |
| 3         | Read and write | 0x10000 - 0x6ffff  | CFM (highlighted with a red oval) |
| 4         | Read and write | 0x70000 - 0xb7fff  | CFM                               |
| 5         | Read and write | 0xb8000 - 0x15ffff | CFM                               |

**Clock Source** (Bottom):

- Clock frequency: 80.0 MHz (highlighted with a red oval)

**Notes** (Bottom):

- User is required to provide the clock frequency.
- The on-chip flash megafunction will be run with 80000000.0 Hz clock frequency.



# NIOS II Development :

- Platform Designer : add Flash

- Connect altpll\_0\_c0 as the clock
- Connect the data to both nios2 data\_master and nios2 instruction\_master
- Connect the csr (control and status registers) to the nios2 data\_master only.
- Change the base address of onchip flash data to 0x0020 0000
- Change the base address of onchip flash csr to 0x0040 0000

On-Chip Flash Intel FPGA IP - onchip\_flash\_0

On-Chip Flash Intel FPGA IP  
altera\_onchip\_flash

**Block Diagram**

Show signals

onchip\_flash\_0

clk: clock  
nreset: reset  
data: avalon  
csr: avalon  
altera\_onchip\_flash

**Parameters**

Data interface: Parallel  
Read burst mode: Incrementing  
Read burst count: 8

**Configuration Mode**

Configuration Scheme: Internal Configuration  
Configuration Mode: Single Uncompressed Image with Memory Initialization

**Flash Memory**

| Sector ID | Access Mode    | Address Mapping    | Type |
|-----------|----------------|--------------------|------|
| 1         | Read and write | 0x00000 - 0x07ffff | UFM  |
| 2         | Read and write | 0x08000 - 0x0ffff  | UFM  |
| 3         | Read and write | 0x10000 - 0x6ffff  | CFM  |
| 4         | Read and write | 0x70000 - 0xb7fff  | CFM  |
| 5         | Read and write | 0xb8000 - 0x15ffff | CFM  |

**Clock Source**

Clock frequency: 80.0 MHz

User is required to provide the clock frequency.  
The on-chip flash megafunction will be run with 80000000.0 Hz clock frequency.



# NIOS II Development :

- Platform Designer : Memory and Flash



# NIOS II Development :

- Platform Designer : add A-MM Clock Crossing Bridge

- Address : WORDS
- FIFO :
  - Command 8
  - Response 32
- m0\_clk to the pll\_0 c2 clock
- s0 clk to the pll\_0 c0
- both resets to clk\_0



# NIOS II Development :

- Platform Designer : add Parallel IO



# NIOS II Development :

- Platform Designer : add Slide Switches IO



# NIOS II Development :

- Platform Designer : add Interval Timer



# NIOS II Development :

- Platform Designer : add ADC



# NIOS II Development :

- Platform Designer : add ADC



# NIOS II Development :

- Platform Designer : add JTAG



# NIOS II Development :

- Platform Designer : add JTAG UART



# NIOS II Development :

- Platform Designer : add System ID



# NIOS II Development :

- Platform Designer : add System ID



# NIOS II Development :

- Platform Designer : Global Reset
  - System (menu) : Create Global Reset Network



# Development : Summary

- NIOS II Platform Designer : System Overview



# FPGA Design for Embedded Systems

FPGA Softcore Processors and IP Acquisition

**FPGA Soft Core processors,  
and IP Acquisition.**



University of Colorado **Boulder**

Copyright © 2020 University of Colorado



# NIOS II Development : Compile

- Quartus : Instantiate
- File (menu) Open :
  - (double click) core (dir)
  - (select) core\_inst.v
  - (click) Open
- Template to instantiate
- Select All : Copy
- Open : DE10\_LITE\_Golden\_Top.v
- Paste core : change u0 to u3

# NIOS II Development : Compile

- Quartus : Instantiate

```
//=====
// Structural coding
//=====

core u3 (
    .clk_clk          ( MAX10_CLK1_50),
    .reset_reset_n   ( ARDUINO_RESET_N ),
    .clk_0_clk        ( ADC_CLK_10 ),
    .reset_0_reset_n  ( ARDUINO_RESET_N ),
    .pio_0_external_export ( LEDR ),
    .pio_1_external_export ( SW ),
    .altpll_0_c1_clk  ( ),
    .altpll_1_areset_conduit_export ( ARDUINO_IO[2] ),
    .altpll_1_locked_conduit_export ( ARDUINO_IO[3] )
```



# NIOS II Development : Compile

- Quartus : Instantiate
- Run an Analysis and Elaboration
  - (or Analysis & Synthesis).



- Double Click : Compile



# NIOS II Development : Compile Done

- Congratulations !

The screenshot shows the Quartus Prime software interface with the following details:

**Tasks** (Compilation):

| Task                                     | Time     |
|------------------------------------------|----------|
| Compile Design                           | 00:03:57 |
| > Analysis & Synthesis                   | 00:02:40 |
| > Fitter (Place & Route)                 | 00:00:56 |
| > Assembler (Generate programming files) | 00:00:06 |
| > Timing Analysis                        | 00:00:15 |
| > EDA Netlist Writer                     |          |

**Device Summary:**

|                          |                                    |                            |
|--------------------------|------------------------------------|----------------------------|
| Analysis & Synthesis     | Device                             | 10M50DAF484C6GES           |
| Fitter                   | Timing Models                      | Preliminary                |
| Flow Messages            | Total logic elements               | 9,583 / 49,760 (19 %)      |
| Flow Suppressed Messages | Total registers                    | 6252                       |
| Assembler                | Total pins                         | 185 / 360 (51 %)           |
| Timing Analyzer          | Total virtual pins                 | 0                          |
|                          | Total memory bits                  | 449,560 / 1,677,312 (27 %) |
|                          | Embedded Multiplier 9-bit elements | 6 / 288 (2 %)              |
|                          | Total PLLs                         | 2 / 4 (50 %)               |
|                          | UFM blocks                         | 1 / 1 (100 %)              |
|                          | ADC blocks                         | 1 / 2 (50 %)               |

**Messages:**

| Type | ID     | Message                                                               |
|------|--------|-----------------------------------------------------------------------|
| Info | 332114 | Report Metastability: Found 14 synchronizer chains.                   |
| Info | 332102 | Design is not fully constrained for setup requirements                |
| Info | 332102 | Design is not fully constrained for hold requirements                 |
| Info |        | Quartus Prime Timing Analyzer was successful. 0 errors, 32 warnings   |
| Info | 293000 | Quartus Prime Full Compilation was successful. 0 errors, 321 warnings |

System (3) Processing (857)



# NIOS II Development : Compile

- Potential Issues (This is normal)

**Note1 :** Quartus 18.1 : If you see Error (14740): Configuration mode on atom

"core:u3|altera\_onchip\_flash:onchip\_flash\_0|altera\_onchip\_flash\_block:altera\_onchip\_flash\_b  
lock|ufm\_block" does not match the project setting. Update and regenerate the Qsys system  
to match the project setting.

Set Following :

Assignments -> Device -> Device and Pin Options -> Configuration ->Single Uncompressed  
Image with Memory Initialization (512Kbits UFM)

**Note2 :** If you see and Error due to PLL and ADC ID:170084 Can't route signal "<name>" to  
atom "<name>" Ensure altpll\_1 c0 is connected to adc\_pll\_clock clock input



# NIOS II Development : Compile

- Potential Issues (This is normal)

Note2 : If you see an Error due to PLL and ADC ID:170084 Can't route signal "<name>" to atom "<name>" Ensure altpll\_1 c0 is connected to adc\_pll\_clock clock input



# NIOS II Development : Compile

- Potential Issues (This is normal)

Set Following :

Assignments -> Device -> Device and Pin Options -> Configuration -> Single Uncompressed Image with Memory Initialization (512Kbits UFM)



# NIOS II Development : Messages

- Quartus : Full Compilation
- SDC : constraints added
- Flow Messages : All, Error, Critical



The screenshot shows the Quartus II software interface. The 'Flow Messages' window is open, displaying a list of messages. The 'All' button in the toolbar is circled in red, and the 'Flow Messages' item in the 'Table of Contents' menu is also circled in red. The messages listed are:

| Type    | ID     | Message                                                                                                                               |
|---------|--------|---------------------------------------------------------------------------------------------------------------------------------------|
| Info    | 332060 | Analyzing Fast 1200mV OC Model                                                                                                        |
| Info    | 332060 | Node: MAX10_CLK1_50 was determined to be a clock but was found without an assigned period.                                            |
| Info    | 332060 | Node: ADC_CLK_10 was determined to be a clock but was found without an assigned period.                                               |
| Warning | 332097 | The following timing edges are non-unate. The Timing Analyzer will assume they are unate.                                             |
| Warning | 332056 | PLL cross checking found inconsistent PLL clock settings:                                                                             |
| Warning | 332168 | The following clock transfers have no clock uncertainty assignment. For these transfers, the uncertainty is set to the maximum value. |
| Warning | 332146 | Worst-case setup slack is 46.437                                                                                                      |
| Warning | 332146 | Worst-case hold slack is 0.148                                                                                                        |
| Warning | 332146 | Worst-case recovery slack is 98.541                                                                                                   |
| Warning | 332146 | Worst-case removal slack is 0.403                                                                                                     |
| Warning | 332146 | Worst-case minimum pulse width slack is 49.426                                                                                        |

# NIOS II Development : Programming

- MAX 10 : Flash
- JTAG : USB Blaster
  - Program .sof file to SRAM configuration cells
    - Temporary
  - Program .pof file to Flash
    - Loads SRAM at each Power ON



# NIOS II Development : Programming

- Quartus

- 1) Connect USB to DE10 Lite Board and Computer
- 2) Tools (menu) : Programmer



# NIOS II Development : Programming

- Quartus
- 3) Hardware Setup... (Button)
- 4) USB Blaster [USB-0] : Close

5) Install Drivers if  
USB-0 not seen



# NIOS II Development : Programming

- Quartus

6) Add File... (Button)

7) Start



# NIOS II Development : Programming

7) Start (Button) - -> 100% Successful

Note : do not press “Cancel” until you are done using the NIOS core. Time\_limited is .sof file only, no Flash without License



# Development : Summary

- NIOS II Platform Designer : Compile
- NIOS II Platform Designer : Program



# FPGA Design for Embedded Systems

## FPGA Softcore Processors and IP Acquisition



# Soft Processor : Customization

- Custom Instruction Implementation
- Build the Custom Example Hardware
  - Component Editor
  - Platform Designer



# Soft Processor : Customization

- NIOS II ALU
  - Accelerate time critical software algorithms by converting them to custom hardware logic blocks
  - Provide an easy way to experiment with hardware-software tradeoffs



# Soft Processor : Customization

- NIOS II ALU
  - Custom instruction logic block interfaces with the Nios II processor through three ports:
  - **dataa**
  - **datab**
  - **result**



# Soft Processor : Customization

- NIOS II ALU
- Each custom instruction in the Embedded Design Suite (EDS) generates a macro in the system header file system.h
- The macro can be used directly in the C or C++ application code



# Soft Processor : Customization

The Nios II custom instruction hardware tasks:

1. Open the Component Editor
2. Specify the custom instruction component type
3. Display the custom instruction block symbol
4. Add the HDL files
5. Configure the custom instruction parameter type
6. Set up the custom instruction interfaces
7. Configure the custom instruction signal type
8. Save and add the custom instruction
9. Generate the system and compile in the Quartus software



# Soft Processor : Customization

- Tools (menu): Platform Designer
- Platform Designer :
  - File (menu) : Open <nios\_file>.qsys



# Soft Processor : Customization

- Platform Designer :
  - New Component (double click) : Component Editor



# Soft Processor : Custom Instruction

- Component Editor : Component Type (tab)
  - Name : mac
  - Display name : mac
  - Version : 1.0



Component Editor - mac\_hw.tcl\*

File Templates Beta View

Component Type Block Symbol Files Parameters Signals & Interfaces

About Component Type

|                |                                                                                          |       |     |  |  |
|----------------|------------------------------------------------------------------------------------------|-------|-----|--|--|
| Name:          | mac                                                                                      |       |     |  |  |
| Display name:  | mac                                                                                      |       |     |  |  |
| Version:       | 1.0                                                                                      |       |     |  |  |
| Group:         |                                                                                          |       |     |  |  |
| Description:   |                                                                                          |       |     |  |  |
| Created by:    |                                                                                          |       |     |  |  |
| Icon:          |                                                                                          |       |     |  |  |
| Documentation: | <table border="1"><tr><td>Title</td><td>URL</td></tr><tr><td></td><td></td></tr></table> | Title | URL |  |  |
| Title          | URL                                                                                      |       |     |  |  |
|                |                                                                                          |       |     |  |  |



# Soft Processor : Custom Instruction

- Component Editor : Block Symbol (tab)
  - View



# Soft Processor : Custom Instruction

- Component Editor : Files (tab)
  - Add



Component Editor - mac\_hw.tcl\*

File Templates Beta View

Component Type Block Symbol Files Parameters Signals & Interfaces

About Files

**Synthesis Files**

These files describe this component's implementation, and will be created when a Quartus synthesis model is generated.

The parameters and signals found in the top-level module will be used for this component's parameters and signals.

| Output Path              | Source File              | Type        |
|--------------------------|--------------------------|-------------|
| mac_Component.v          | mac_Component.v          | Verilog HDL |
| mac_Custom_Instruction.v | mac_Custom_Instruction.v | Verilog HDL |

Add File... Remove File Analyze Synthesis Files Create Synthesis File from Signals

Top-level Module: (Analyze files to select module)

A red circle highlights the "Add File..." button in the bottom navigation bar of the software interface.

# Soft Processor : Custom Instruction

- Component Editor : Files (tab) : Attributes (column)
  - Select : Top-level File : OK



# Soft Processor : Custom Instruction

- Component Editor : Interface Type
  - View (menu) : Interfaces
  - Type : Custom Instruction Slave



# Soft Processor : Custom Instruction

- Component Editor :
  - Analyze Synthesis Files (button)



# Soft Processor : Custom Instruction

- Component Editor :
  - Finish : Yes, Save.



# Soft Processor : Custom Instruction

- Platform Designer : IP Catalog : mac
  - mac : (right click) Add version 1.0...



# Soft Processor : Custom Instruction

- Platform Designer : mac\_0
  - Connect the clock, reset, and instruction nodes
- Generate (menu) : Generate HDL

- Quartus : Add .qip
- Quartus : Compile



# Soft Processor : Custom Instruction

- Software Build : References

Custom Instruction User Guides :

[https://www.intel.com/content/dam/www/programmable/us/en/pdfs/literature/ug/ug\\_nios2\\_custom\\_instruction.pdf](https://www.intel.com/content/dam/www/programmable/us/en/pdfs/literature/ug/ug_nios2_custom_instruction.pdf)

<https://www.intel.com/content/www/us/en/programmable/documentation/cru1439932898327.html>

Design Example :

[https://www.intel.com/content/dam/altera-www/global/en\\_US/others/support/examples/download/ug\\_custom\\_instruction\\_files.zip](https://www.intel.com/content/dam/altera-www/global/en_US/others/support/examples/download/ug_custom_instruction_files.zip)



# Soft Processor : Custom Instruction

- Software Build : files
  - <func>\_main.c : Main program that populates random test data, executes the <func> in software with the custom instruction, validates the output, and reports the processing time.
  - <func>.c : Software <func> algorithm run by the Nios II processor
  - <func>.h : Header file for <func>.c
- ci\_<func>.c : Program that accesses <func> custom instruction
- ci\_<func>.h : Header file for ci\_<func>.c



# Soft Processor : Custom Instruction

- Software Build : Run
  - To run the application software, create an Executable and Linking Format File (.elf) first.
  - To create the .elf file, follow the instructions in the "Nios II Software Build Flow" section in the readme\_qsys.txt file in the extracted design files.
- Macro that is defined in the ci\_<func>.c file.

```
#define <func>_CI_MACRO(n, A) \
    __builtin_custom_ini(ALT_CI_<func>_CUSTOM_COMPONENT_0_N + (n & 0x7), (A))
```
- This macro accepts a single int type input operand and returns an int type value.
- Upcoming series Step into the Software process in more depth



# Soft Processor : Customization

- Custom Instruction Implementation
- Build the Custom Example Hardware
  - Component Editor
  - Platform Designer
- Begin Software Flow

