Nios® V Embedded Processor Design Handbook

ID 726952
Date 1/27/2025
Public
Document Table of Contents

4.6.1.2. Software Design Flow

This section provides the design flow to generate and build a Nios® V processor software project. To ensure a streamlined build flow, you are encouraged to create a similar directory tree in your design project. The software design flow is based on this directory tree.

Use the following steps to create the software project directory tree:

  1. In your design project folder, create a folder called software.
  2. In the software folder, create two folders called app and bsp.
    Figure 59. Software Project Directory Tree

Creating the BSP Project Application

To launch the BSP Editor, perform the following steps:
  1. Enter the Nios® V Command Shell.
  2. Invoke the BSP Editor with niosv-bsp-editor command.
  3. In the BSP Editor, click File > New BSP to start your BSP project.
  4. Configure the following settings:
    • SOPC Information File name: Provide the SOPCINFO file (.sopcinfo).
    • CPU name: Select Nios® V processor.
    • Operating system: Select the operating system of the Nios® V processor.
    • Version: Leave as default.
    • BSP target directory: Select the directory path of the BSP project. You can pre-set it at <Project directory>/software/hal_bsp by enabling Use default locations.
    • BSP Settings File name: Type the name of the BSP Settings File.
    • Additional Tcl scripts: Provide a BSP Tcl script by enabling Enable Additional Tcl script.
    • Click OK.
    Figure 60. Configure New BSP

Configuring BSP Editor and Generating the BSP Project

You can define the processor’s exception vector either in On-Chip Memory (OCRAM) or QSPI Flash based on your design preference. Setting the exception vector memory to OCRAM/External RAM is recommended to make the interrupt processing faster.

  1. Go to Main > Settings > Advanced > hal.linker.
  2. If you select QSPI Flash as exception vector, follow these steps:
    1. Turn on the following settings:
      • allow_code_at_reset
      • enable_alt_load
      • enable_alt_load_copy_rodata
      • enable_alt_load_copy_rwdata
      Figure 61. Advanced.hal.linker SettingsThis setting is available if exception vector memory is set to On-Chip Memory (OCRAM)
    2. Click on the Linker Script tab in the BSP Editor.
    3. Set .exceptions and .text regions in the Linker Section Name to QSPI Flash.
    4. Set the rest of the regions in the Linker Section Name list to the On-Chip Memory (OCRAM) or external RAM.
    Figure 62. Linker Region Settings (Exception Vector Memory: QSPI Flash)
  3. If you select OCRAM/External RAM as exception vector, follow these steps:
    1. Enable the following settings:
      • allow_code_at_reset
      • enable_alt_load
      • enable_alt_load_copy_rodata
      • enable_alt_load_copy_rwdata
      • enable_alt_load_copy_exception
      Figure 63. Advanced.hal.linker SettingsThis setting is available if exception vector memory is set to On-Chip Memory (OCRAM) or external RAM.
    2. Click on the Linker Script tab in the BSP Editor.
    3. Set the .text regions in the Linker Section Name to QSPI Flash.
    4. Set the rest of the regions in the Linker Section Name list to the On-Chip Memory (OCRAM) or external RAM.
    Figure 64. Linker Region Settings (Exception Vector Memory: OCRAM)
  4. Navigate to the BSP Drivers tab.
  5. Turn off the Generic Serial Flash Interface driver (intel_generic_serial_flash_interface_top).
  6. Click Generate to generate the BSP project.

Generating the User Application Project File

  1. Navigate to the software/hal folder and create your application source code.
  2. Launch the Nios® V Command Shell.
  3. Execute the command below to generate the application CMakeLists.txt.
niosv-app --app-dir=software/app --bsp-dir=software/bsp \
  --srcs=software/hal app/<user application>

Building the Application Project

You can choose to build the application project using the RiscFree* IDE for Intel FPGAs or through the command line interface (CLI).

If you prefer using CLI, you can build the application using the following command:

cmake -G "Unix Makefiles" -B software \
  hal_app/build -S software/hal_app 
 make -C software/hal app/debug

The application (.elf) file is created in software/app/debug folder.

Generating HEX File

You must generate a .hex file from your application .elf file, so you can create a .pof file suitable for programming flash devices.

  1. Launch the Nios V Command Shell.
  2. For Nios® V processor application boot from QSPI flash, use the following commands line to convert the ELF to HEX for your application.
elf2flash --input software/hal_app/debug/<Nios V application>.elf \
  --output flash.srec --reset <reset offset + base address of GSFI AVL MEM> \
  --base <base address of GSFI AVL MEM> \
  --end <end address of GSFI AVL MEM>
riscv32-unknown-elf-objcopy --input-target srec --output-target ihex \
  flash.srec <Nios V application>.hex