Microchip Polarfire-SoC Yocto 'Board Support Package' (BSP) is based on OpenEmbedded (OE). The 'Polarfire SoC Yocto BSP' layer is build on top of the RISC-V Architectural layer (meta-riscv) to provide hardware specific features and additional disk images. Using Yocto 'Openembedded' you will build the following:
- RISC-V Toolchain
- Predefined Disk Images
- Bootloader Binaries (FSBL / U-Boot)
- Device Tree Binary (DTB)
- Linux Kernel Images
The complete User Guides for each development platform, containing board and boot instructions, are available for the following supported platforms:
- ICICLE-KIT-ES (Icicle Kit Engineering Sample) (Requires minimum Design Tag 2020.11 )
- M100PFSEVP (Aries Embedded M100PFSEVP PolarFire SoC-FPGA Evaluation Platform)
- MPFS-DEV-KIT (HiFive Unleashed Expansion Board)
- LC-MPFS-DEV-KIT
Before continuing, ensure that the prerequisite packages are present on your system. Please see the Host PC setup for Yocto section for further details.
This needs to be done every time you want a clean setup based on the latest BSP.
mkdir yocto-dev && cd yocto-dev
repo init -u https://github.com/polarfire-soc/meta-polarfire-soc-yocto-bsp.git -b master -m tools/manifests/riscv-yocto.xml
For the Aries Embedded M100PFSEVP, please use:
mkdir yocto-dev && cd yocto-dev
repo init -u https://github.com/ARIES-Embedded/meta-polarfire-soc-yocto-bsp.git -b aries -m tools/manifests/riscv-yocto.xml
repo sync
repo rebase
. ./meta-polarfire-soc-yocto-bsp/polarfire-soc_yocto_setup.sh
Using yocto bitbake command and setting the MACHINE and image requried.
MACHINE=icicle-kit-es bitbake mpfs-dev-cli
Be very careful while picking /dev/sdX device! Look at dmesg, lsblk, GNOME Disks, etc. before and after plugging in your usb flash device/uSD/SD to find a proper device. Double check it to avoid overwriting any of system disks/partitions!
cd yocto-dev/build
zcat tmp-glibc/deploy/images/icicle-kit-es/mpfs-dev-cli-icicle-kit-es.wic.gz | sudo dd of=/dev/sdX bs=4096 iflag=fullblock oflag=direct conv=fsync status=progress
The MACHINE
(board) option can be used to set the target board for which linux is built, and if left blank it will default to MACHINE=icicle-kit-es
.
The following table details the available targets:
MACHINE |
Board Name |
---|---|
MACHINE=icicle-kit-es |
ICICLE-KIT-ES, Icicle Kit engineering samples |
MACHINE=m100pfsevp |
M100PFSEVP, Aries M100PFSEVP PolarFire SoC-FPGA Evaluation Platform |
MACHINE=mpfs |
MPFS-DEV-KIT, HiFive Unleashed Expansion Board |
MACHINE=lc-mpfs |
LC-MPFS-DEV-KIT, Low cost HiFive Unleashed Expansion Board |
MACHINE=qemuriscv64 |
Simulation |
When building for different 'Machines' or want a 'clean' build, we recommend deleting the 'build' directory when switching. This will delete all cache / configurations and downloads.
cd yocto-dev
rm -rf build
The table below summarizes the most common Linux images that can be built using this BSP.
bitbake <image> argument |
Description |
---|---|
core-image-minimal-dev |
A small console image with some development tools. |
mpfs-dev-cli |
A console image with development tools. |
For more information on available images refer to Yocto reference manual
Login with root
account, there is no password set.
With the bitbake environment setup, execute the bitbake command in the following format to build the disk images.
MACHINE=<machine> bitbake <image>
Example building the icicle-kit-es machine and the mpfs-dev-cli Linux image
MACHINE=icicle-kit-es bitbake mpfs-dev-cli
To work with individual recipes:
MACHINE=<MACHINE> bitbake <recipe> -c <command>
Available BSP recipes:
- hss (Microchip Hart Software Services) payload generator
- u540-c000-bootloader (Sifive FSBL)
- u-boot
- mpfs-linux (BSP kernel)
Available commands:
- clean
- configure
- compile
- install
build/tmp-glibc/deploy/images/{MACHINE}
For Example the following is the path for the Icicle-kit-es
build/tmp-glibc/deploy/images/icicle-kit-es
Compressed Disk images files use <image>-<machine>.wic.gz
format, for example,
mpfs-dev-cli-<machine>.wic.gz
. We are interested in .wic.gz
disk images for writing to emmc/uSD/SD card.
Be very careful while picking /dev/sdX device! Look at dmesg, lsblk, GNOME Disks, etc. before and after plugging in your usb flash device/uSD/SD to find a proper device. Double check it to avoid overwriting any of system disks/partitions!
Unmount any mounted partitions from uSD card before writing!
We advice to use 16GB or 32GB uSD cards. 8GB cards (shipped with HiFive Unleashed) can still be used with CLI images.
Example write the disk image to the SD card for the icicle kit:
cd yocto-dev/build
zcat tmp-glibc/deploy/images/icicle-kit-es/mpfs-dev-cli-icicle-kit-es.wic.gz | sudo dd of=/dev/sdX bs=4096 iflag=fullblock oflag=direct conv=fsync status=progress
MACHINE=qemuriscv64 runqemu nographic
This document assumes you are running on a modern Linux system. The process documented here was tested using Ubuntu 18.04 LTS. It should also work with other Linux distributions if the equivalent prerequisite packages are installed.
The BSP uses the Yocto RISCV Architecture Layer, and the Yocto release Dunfell (Revision 3.1) (Released April 2020).
Make sure to install the repo command by Google first.
Detailed instructions for various distributions can be found in the "Required Packages for the Build Host" section in the Yocto Project Reference Manual.
For Ubuntu 18.04 (or newer) install python3-distutils:
sudo apt install python3-distutils
HSS Payload Generator uses libelf and libyaml, as well as zlib (a dependency of libelf).
sudo apt-get install libyaml-dev
sudo apt-get install libelf-dev
We sometimes get dependencies not building correctly. During the process do_wic_install payload may not be present for hss or opensbi.
For example after requesting a complete build:
MACHINE=icicle-kit-es bitbake mpfs-dev-cli
If payload is missing execute the following:
MACHINE=icicle-kit-es bitbake hss -c clean
MACHINE=icicle-kit-es bitbake hss -c install
If u-boot or boot.src.uimg missing
MACHINE=icicle-kit-es bitbake u-boot -c clean
MACHINE=icicle-kit-es bitbake u-boot -c install
And finally a complete build:
MACHINE=icicle-kit-es bitbake mpfs-dev-cli
Listen uses inotify by default on Linux to monitor directories for changes. It's not uncommon to encounter a system limit on the number of files you can monitor. For example, Ubuntu Lucid's (64bit) inotify limit is set to 8192.
You can get your current inotify file watch limit by executing:
$ cat /proc/sys/fs/inotify/max_user_watches
When this limit is not enough to monitor all files inside a directory, the limit must be increased for Listen to work properly.
Run the following command:
echo fs.inotify.max_user_watches=524288 | sudo tee -a /etc/sysctl.conf && sudo sysctl -p
See Other Dependencies for installation instructions.