Skip to content
/ rsyocto Public

πŸ€– SoCFPGA: Open-Source Embedded Linux Distribution with a highly flexible build system, developed for Intel (ALTERA) SoC-FPGAs (Cyclone V & Arria 10)

License

Notifications You must be signed in to change notification settings

robseb/rsyocto

Β 
Β 

Folders and files

NameName
Last commit message
Last commit date

Latest commit

Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 
Β 

Repository files navigation

rsyocto is an open source embedded Linux Distribution designed with the Yocto Project and with a custom build flow to be optimized for Intel SoC-FPGAs (Intel Cyclone V and Intel Arria 10 with a ARM CORTEX-A9) to achieve the best customization for the strong requirements of modern embedded SoC-FPGA applications.

GitHub release (latest by date) GitHub Releases GitHub Releases GitHub issues license


rsyocto implements a modern Linux Kernel (linux-socfpga 5.7) and brings a set of today fundamentally needed components to Intel SoC-FPGAs and helps to simplify the complex process of development for FPGA-, Industrial 4.0-, Internet of things- or deep learning applications.

To realize that Python3 with the Python Package manager pip (PyPI) and the Apache Webserver with PHP are already included. Thereby it is really easy to install Python applications from the Raspberry Pi on a powerful Intel SoC-FPGA. rsyocto is for its best optimization complete console based, but the Apache Webserver can bring any GUI to Computers, Smartphones or Tablets, by hosting for example a monitor web interface. For that the Python Web framework Django 3.0 with the AdminLTE Dashboard is pre-installed.

During development, a major concern was placed on the integration of powerful and simple to install development IDEs that do not require a JTAG-connection or any cross-building environment. All kinds of rsyocto applications and parts can be build, deployed and even debugged over the network (fully rootable over the Internet). With the implementation of Microsoft Visual Studio and Visual Studio Code a simple installment and quick jump start in the development process is possible, because all required compilers run directly on rsyocto.

It is with the implementation of drivers for all Hard-IP Interfaces (e.g. IΒ²C-, CAN-BUS,…) and simple Linux test commands (e.g. i2c-tools or can-utils) ready for the development of industrial connected solutions. With a single command rsyocto is capable to load a new FPGA configuration or to read and write the AXI-Bridge Interface to the FPGA fabric. The Linux test commands allow in a simple fashion to communicate with the FPGA fabric via all available interfaces, such as Lightweight HPS-to-FPGA-, HPS-to-FPGA-Bridge, shared-memory or general purpose signals (gpi and gpo). Python- and C++- demo applications show a powerful way with a high throughput.

rsyocto was designed with an automatically Python based build system. That generates an entirely requirement optimized customize rsyocto-image with the installment of users own applications,boot configurations,scripts,FPGA configuration files, that will be configured on the FPGA fabric before the Linux boots and a lot more.

The final rsyocto-Image can be installed on a SD-Card with any commonly used Boot-Image creating tools. Versions are available for the Terasic DE10 Standard- (Cyclone V), Terasic DE10 Nano- (Cyclone V), Terasic Han Pilot (Arria 10) and Terasic DE0-Nano SoC (Cyclone V).

On the Terasic DE10 Nano board the Arduino Uno header can be used to connect external devices to a Hard-IP Bus, because the HPS interfaces with the pre-installed configuration are routed to FPGA I/O-Pins. An example shows how to use rsyocto, the FPGA-to-HPS-Bridge to access Hard-IP of the HPS with a NIOS II Soft-Core Processor running FreeRTOS. NIOS II Eclipse platforms can also be generated automatically.


I noticed that right now only desktop Linux systems, like Ubuntu, are available for free. In my opinion they are not designed for embedded SoC-FPGAs and therefore, they cannot be considered for long-term embedded systems.

That was for me the starting point to try to develop my own fully optimized Linux distribution. Shortly after, I announced that the Intel development tools and documentations for HPS development are not nearly as good as those for the FPGA part. At the beginning it was really complicated to get anything running. After a hard time, I'm able to present this first working project. To get there, I designed my own built flow with my own scripts.

I think nearly everybody will have the same problems that I had during the development. For that reason, I try to give everybody a solution for their rapid prototyping. Within this repository I have also integrated a step by step guide to show my solution with the Yocto project and the Intel SoC EDS.

This project is by far not finished and issue free. I will continue my work and upload newer versions. I invite everybody to submit issues, comments and ideas.


System Overview of rsyocto

Alt text


Build, debug and deploy your applications over the network

Alt text Ready for powerful remote development IDEs and fitted with a Web server to host modern web applications

Key Advantages

  • Embedded Linux specially developed for Intel SoC-FPGAs
  • Full usage of the Dual-Core ARM Cortex A9 with
    • the NEON-Engine
    • the Vector Floating Point Unit (VFP)
    • the Thumb-2 Instruction Set
    • the ARM CoreSight Debugging engine
  • For the best performance completely custom optimized
  • Console based (GUI less) with Busybox
  • Watchdog timer is enabled

  • FPGA fabric configuration during the boot and with a single Linux command
  • Tools to interact with the FPGA fabric via the HPS to FPGA bridges
  • Access the FPGA fabric with Shell scripts, C++-, Python-Applications or PHP or Django web applications
  • HPS Hard IP components (IΒ²C-,SPI-, CAN-BUS or UART) are routed to FPGA I/O
    • Ready for connecting different devices
      • e.g. Arduino Uno shields
  • Accelerometer and ADC can be accessed via Python or C++ (Demos available)
  • Console based Bus test tools (e.g. can-utils)
  • Console memory dump tools (e.g. devmem2)

  • Ethernet with dynamic and static iPv4 is supported
  • SSH-Server starts automatically
  • resolvconf the Linux DNS network tool is pre-installed
  • Support for remote based development IDEs pre-installed
    • Visual Studio Code for remote python debugging
    • Visual Studio for remote C++ debugging*
    • ARM DS-5 Studio for remote- and JTAG- C++ debugging
      β€’ gcc-compiler and gdb-server
  • ARM DS-5 Streamline is pre-installed and immediately is after start ready for trace analysis
  • The "NIOSII_EclipseCompProject" can generate custom Eclipse for NIOS II projects with for instance a real-time operating system FreeRTOS

  • Python3,Python3-dev
  • Apache webserver with PHP and SQLite
  • Latest Django version is pre-installed for Python-based web framework development
  • The adminLTE web dashboard can bring modern complex web applications to SoC-FPGAs (example)

  • git,curl and wget download manager
  • Full integrated python pip3 (python-pip) package manager
  • opkg package manager

  • Custom designed Build System to generate the entire bootflow for Intel SoC-FPGAs automatically
    • Allows to design highly optimized rsyocto flavors for your specific requirements
    • Overview of the main feature of the "socfpgaPlatformGenerator" Build System
      • Automatically generate a bootable image file with configuration provided by a Quartus Prime project
      • Cloning and compiling of the u-boot bootloader for Intel SoC-FPGAs
      • Allows a highly optimization of the u-boot (e.g. via menuconfig)
      • In case of the u-boot script is configured to load a FPGA configuration the depending FPGA configuration will be generated
      • Allows to pre-install any files or operating systems to a SD-Card image
      • Boot image (.img) file generation for distributing embedded Linux Distributions
      • Dynamic mode: Partition size = Size of the files to add to the partition
      • Linux device tree (dts) -files inside a partition can be automatically compiled and replaced with the un-compiled file
      • Compressed files (e.g. "tar.gz") containing for instance the Linux rootfs can be unzipped and automatically added to the partition
    • To add the following to a deployable and shareable image file
      • Custom bootloader configuration
      • FPGA configuration files
      • u-boot boot script
      • Files/Applications
      • Software Libraries
      • Web sites
      • Linux Shell Startup scripts
      • Network Interface settings

  • Full supported boards
    • Terasic DE10-Standard (Intel Cyclone V)
    • Terasic DE10-Nano (Intel Cyclone V)
    • Terasic DE0-Nano SoC Kit (Atlas-SoC Kit) (Intel Cyclone V)
    • Terasic HAN-Pilot (Intel Arria 10 SX)

Tutorials

Getting Started Guides

Level Objective Guide
1 Booting rsyocto on your Board Getting started Guide
2 Use of Hard IP, FPGA-IP and configuration of the FPGA fabric Step by step guide 1
3 Debugging C++ applications remotely Step by step guide 2
4 Debugging Python applications remotely Step by step guide 3
5 Analyzation of applications with ARM DS-5 Streamline Step by step guide 4
6 Developing a custom FPGA configuration with Intel Quartus Prime Step by step guide 5

Customization Guides

No. Objective Guide
1 Designing of custom rsyoto versions Guide

Application-specific Guides

No. Objective Guide
1 Transmitting CAN-Bus packages with Python Guide
2 Developing a Django web application for interacting with the FPGA fabric Guide
3 Writing a Linux Startup script Guide
4 Examples of using Microsoft Visual Studio for C++ development Guide
5 Using the Intel NIOS II Processor, running FreeRTOS, to interact with HPS Hard-IP Guide

Folder Structure

Folder Content
doc Documentation
fpga Quartus Prime projects
examples/python rsyocto Python examples
build_system rsyocto build scripts

The final rsyocto Versions are available inside the packages-Part of this repository!

Built With / Credits & Contribution


Development Process

The first version of rsyocto (release december of 2019) was developed with the Intel Embedded Development Suite (SoC EDS) version 18.1 and a custom Yocto Project meta-layer.

By default the specifications of these two development tools are not compatible to each other. To handle this issue I designed a custom build flow to progress the output Linux files of the Yocto project and to create all necessary boot stages.

This build system consists of an Ubuntu Linux and a CentOS Linux part. On CentOS was an Altera script used to generate the boot images. With re-design of the bootflow of Intel SoC-FPGAs with the SoC EDS Version 19.1 it was essential for me to design an new build system that can run on a single development computer (Ubuntu Linux or CentOS) and generate all required bootloaders fully automatically.

My first approach to design this Linux Distribution Alt text Build Flow to create the first rsyocto version

Build system for generation of custom rsyocto flavors

Alt text Block diagram of the fully automated build system to design new releases

This illustration shows my new development procedure and the required complexity to create rsyocto. I entirely automated the required complex bootflow to generate with a Intel Quartus Prime FPGA project and Linux Distribution files (e.g. zImage,rootfs,...) a bootable image file (.img). The script uses the Intel Embedded Development Suite (SoC EDS) in version 20.1 (2020) to design the necessary bootloader based on the project settings. It was designed to allow a high optimization of all components, such as the u-boot boot script or the Linux device tree. With this project I want to give other developers a full-functional system to reduce their development effort.

For designing custom rsyocto Versions it is only necessary to copy the "socfpgaPlatformGenerator"- Folder (available inside Repository's Releases part) into a Quartus Prime FPGA project folder. The included Python script can then generate the entire platform and can output a shareable and a bootable image file ("*.img").

My build flow consists of three stages to allow the usage for other embedded Linux platforms or with different embedded Linux Distributions. In the following table these three stages are visible. The stage one is on the lowest level and its classes will be used by the next stage.

Stage Python Script Name Description Output
1 LinuxBootImageFileGenerator Class to automatically generate a bootable Image file with a specifiable partition table Image file for enabling booting for almost all embedded Linux distributions
2 socfpgaPlatformGenerator Class to generate all necessary components for booting an embedded Linux on Intel (ALTERA) SoC-FPGAs to build the bootloader (u-boot) and bring all components to a bootable image Image for booting any Intel SoC-FPGA
3 makersyoctoSDImage.py Python script to generate a custom rsyocto version with for instance rootfs changes (SSH configuration) Image with a custom rsyocto flavor

How to get started with the Yocto Project for Intel SoC-FPGAs?

Inside my meta-intelfpga BSP layer I described in details how to get started with the Yocto project for Intel SoC-FPGAs. Also I published inside this layer the source code and documentation to bring tools to update the FPGA configuration with the running Linux and to interact with simple commands with the FPGA fabric to the Yocto Project.

How to import Python pip (python-pip) packages or setup scripts with the Yocto Project

I designed a simple python script to pre-install Python pip (PyPI)- Packages within a final Yocto Project Linux Image (see here.

For the implementation of custom startup scripts to the boot process of an embedded Linux with Yocto project I also added a simple way to my meta-rstoolslayer.

How to automatically generate an Intel NIOS II Eclipse project with for instance FreeRTOS

I wrote Python Script to automatically generate an Intel NIOS II Eclipse Project with custom software components (e.g. FreeRTOS).


Continuation

I will continue my work and upload newer versions. I invite everybody to submit issues, comments and ideas.

Currently I am working on a Windows 10 .net Desktop application to manage FPGA configurations and to allow to record data via the network. To release that I will design a server task, running on rsyocto, that can send python- or C++-values with TCP to the desktop. The following screenshot shows the development state of this project.

Alt text


Author

  • Robin Sebastian

rsyocto are projects, that I have fully developed on my own. No companies are involved in my projects. I’m recently graduated as a master in electrical engineering with the major embedded systems (M. Sc.).

Github sponsoring is welcome.

Gitter Email me!

GitHub stars GitHub watchers GitHub followers