Main Content

Generate SoC Design

This tutorial shows how to build hardware and software executables for your model and execute your application. Your SoC model can contain a processor model, an FPGA model, or both.

To use SoC Builder, you must install the support package that corresponds to the board you specify in the configuration parameters. For more information, see SoC Blockset Supported Hardware.

Set Up FPGA Design Software Tools

To generate SoC binaries, you must include the path to Vivado® or Quartus® executables on your system path. If the executables are not already in your system path, use hdlsetuptoolpath function to add them to your path.

 Xilinx Software

 Intel Software

Prepare Model for Generation

Start the SoC Builder tool. In the Simulink® toolstrip, on the System on Chip tab, click Configure, Build & Deploy.

Prepare your model by selecting a starting point for the build process, and then review the model information.

Note

If SoC Builder does not detect a support package installation, SoC Builder first prompts you to install the required support package.

  1. Specify the starting point for the build process. If you are building a model for the first time, select Build model. If you already completed the build process and saved the binaries in a folder, select Load existing binaries.

  2. SoC Builder parses the model and displays the top model, the FPGA model (if one exists), and the ARM model (if one exists). Review this information for accuracy. If the information is incorrect, revise the model, save it, and restart the SoC Builder tool.

    Note

    If your FPGA model is a frame-based Simulink model variant, then SoC Builder does not display the model in the table. To display the model in the table, set the model variant to sample-based and recompile your design.

  3. Click Next.

Select Build Action

Select one of these build actions for your model and automate the build process.

  • Build, load, and run — Select this option to generate HDL and C code, build software executables, and build an FPGA programming file from your model. After building, SoC Builder loads the generated code to the FPGA board and executes the application.

  • Build only — Select this option to generate HDL and C code, build software executables and an FPGA programming file from your model. SoC Builder saves the generated binaries in a folder, and you can continue execution later.

  • Build and load for external mode — Select this option to build the design and run it in external mode. Use external mode to tune parameters on the FPGA without having to rebuild the FPGA design. You can also log data from the FPGA and display it on the host computer. For more information about external mode, see External Mode Simulations for Parameter Tuning, Signal Monitoring, and Code Execution Profiling (Simulink Coder).

  • Automate build process — Select this option to build your model with fewer clicks. Automating the build process performs these actions.

    • Skips these steps: select project folder, review hardware mapping, and review memory map

    • Runs these steps : validate, build, and load

    All these steps use the inputs that you provided in the most recent build. If you are running the build process for the first time, SoC Builder uses default inputs for these steps.

  • Advanced build options — Select the build type as one of these options.

    • Processor and FPGA (default) — Build the processor and FPGA models in your top model.

    • Processor only — Build only the processor model in your top model.

    • FPGA only — Build only the FPGA model in your top model.

After you specify the build options, click Next.

Select Project Folder

  1. Specify a path to a project folder by entering the path in the Project Folder text box or by browsing to a folder location. SoC Builder places all the generated files, including reports, executables, and the bitstream, in this specified folder.

  2. If you select Load existing binaries as the starting point for the build process, specify the project folder location of the previous binaries and reports.

  3. Click Next.

Review Hardware Mapping

  1. Open the Hardware Mapping tool by clicking View/Edit.

  2. Review the software tasks and peripherals on the selected hardware board, and edit them if you need to.

    Note

    This hardware mapping step of SoC Builder is visible only if you have an event-driven task defined in the Task Manager block in your top model.

  3. Click Next.

Review Memory Map

  1. Open the Memory Mapper tool by clicking View/Edit.

  2. Review the base addresses and offsets, and edit them if you need to.

    Note

    This memory map step of SoC Builder is visible only if you have an FPGA model in your top model. If your FPGA model is set to frame-based modeling, then no FPGA model is visible. In this case, you cannot access the Memory Mapper tool.

  3. Click Next.

Validate Model

Check the model against the selected board and generate a report. Check the report to ensure that the design meets your needs.

Note

You must connect the FPGA model in your top model only to an SoC Blockset™ library block.

SoC Builder names the report modelname_system_report and saves it in the html subfolder of the project folder. The report contains an overview section with information about the model, project folder, and generated files. The report also lists your IP cores and vendor-provided IP cores, including the address map of registers and memory blocks.

Build Model

To generate a bitstream for your FPGA design and a compiled executable for your software, click Build.

Clicking Build opens an external shell and runs third-party tools for synthesis and implementation of the design. The generation time depends on the complexity of your model and your host computer. The software generates the bitstream with the model name you specify. SoC Builder generates a JTAG test bench script if you enable the Include AXI Manager for host-based interaction option in the configuration parameters. The script shows how to set up MATLAB as an AXI Manager and configure your FPGA design over JTAG. You can customize the script to create your own test bench. For more information about using MATLAB as an AXI Manager, see the support package documentation: SoC Blockset Supported Hardware.

SoC Builder generates the host interface script for your FPGA design. The script contains the DUT ports and interface mapping information. Use this script to access the board memory, DUT registers, and AXI4-Stream interfaces from MATLAB. The tool generates these MATLAB files:

  • gs_modelName_setup — This script adds the AXI4 slave, AXI4-Stream, and memory interfaces. The script also contains DUT port objects that contain the port name, direction, data type, and interface mapping information. The script then maps the DUT ports to the corresponding interfaces.

  • gs_modelName_interface — This script creates a target object, instantiates the setup script gs_modelName_setup, and then connects to the target hardware. The script then sends read and write commands to the generated HDL IP core.

For more information about host interface script, see Host Interface Script Files (HDL Coder).

Note

If you encounter a build error in the external shell while working with Intel boards, try installing the tee.exe file on your Windows® machine by following these steps:

  1. Download the coreutils-5.3.0 file for Windows from this link: https://sourceforge.net/projects/gnuwin32/files/coreutils/5.3.0/coreutils-5.3.0.exe/download.

  2. Run the coreutils-5.3.0 application and follow the setup steps.

  3. Add the bin folder path to the System variables pane as a Windows environment variable.

    1. Right-click the Computer icon and click Properties. Alternatively, in the Windows Control Panel, click System.

    2. Click Advanced system settings.

    3. On the Advanced tab, click Environment Variables.

    4. In the System variables pane, select the Path variable and click Edit.

    5. In the Edit environment variable pane, click New to add a new folder path.

    6. Restart the system.

  4. Run the SoC Builder tool.

Connect Hardware

Review the IPv4 address, SSH Port number, and login credentials. Edit any of these values if necessary. This step is critical if you have more than one board connected to the host computer. SoC Builder requires this information to identify the correct port connection. Verify that the displayed IP address matches the IP address of the board you intend to use.

Verify that the board is connected to the host with an Ethernet cable, and then click Test Connection to test the physical connection to the board.

Note

This step in the SoC Builder is visible only if your top model includes a processor model.

Load and Run Application

Note

If your top model includes an FPGA model, but no processor model, the button shows as Load.

Verify that your board is connected to the host computer.

  • If your top model includes a processor model, connect to the board with an Ethernet cable.

  • If the top model includes an FPGA model, but no processor model, connect to the board with a JTAG cable.

Click Load and Run. This action loads the generated bitstream to the FPGA, programs the processor, and runs the application.

If you select Tune parameters and monitor signals in external mode in the Select Build Action step, this action loads the bitstream to the FPGA and opens the model in external mode. You can now choose signals for logging and monitoring or change tunable parameters. In the System on Chip tab, in the Run on Hardware section, click Monitor and Tune to run the application on hardware. Click Connect if you already built your design and loaded it onto an FPGA. This action connects your Simulink model to the FPGA model.

SoC Builder packages the project files into a ZIP archive. The packaged zip file contains all the files required to deploy the design onto the hardware board. Unzip this packaged ZIP archive to load and run your design from a different host computer.

See Also

Tools

Objects