This guide will show how to set up the host machine for Yocto build and then how to build and boot ACRN Hypervisor, Service VM and User VMs on Intel platforms.
=================
I. Overview
III. Building ACRN Bootable Image
- MACHINE Configuration
- Adding Guests
- ACRN Configuration
- Kernel Configuration
- GRUB Configuration
- Override distro configuration
VII. Tested Hardware
VIII.Contributing
This layer provides ACRN Hypvervisor integration with Yocto Project.
ACRN is supported on the following Intel platforms:
- Tiger Lake
- Alder Lake
- Raptor Lake
About minimum system requirements and limitations, please find more information at Supported Hardware
Make sure your build host meets the following requirements:
- 90 Gbytes of free disk space
- 8 Gbytes of RAM
- Runs a supported Linux distribution
Currently, the Yocto Project is supported on a number of Linux Distributions. This guide covers only for Ubuntu 22.04 (LTS). To know more about the complete list of supported Linux distributions, please visit Supported Linux Distributions
- Git 1.8.3.1 or greater
- tar 1.28 or greater
- Python 3.8.0 or greater
- gcc 8.0 or greater
- GNU make 4.0 or greater
Install essential host packages on your build host (Ubuntu):
$ sudo apt install gawk wget git diffstat unzip texinfo gcc build-essential chrpath socat cpio python3 python3-pip python3-pexpect xz-utils debianutils iputils-ping python3-git python3-jinja2 libegl1-mesa libsdl1.2-dev python3-subunit mesa-common-dev zstd liblz4-tool file locales
$ sudo locale-gen en_US.UTF-8
meta-acrn layer depends on:
- poky, branch master [or kirkstone]
- meta-oe, branch master [or kirkstone]
- meta-python, branch master [or kirkstone]
- meta-filesystems, branch master [or kirkstone]
- meta-networking, branch master [or kirkstone]
- meta-virtualization, branch master [or kirkstone]
- meta-intel, branch master [or kirkstone]
- Create build workspace
$ mkdir workspace
- Clone poky
$ cd workspace
$ git clone https://git.yoctoproject.org/git/poky
- Clone all dependent layers
$ cd poky
$ git clone https://github.com/openembedded/meta-openembedded.git
$ git clone https://git.yoctoproject.org/git/meta-virtualization
$ git clone https://git.yoctoproject.org/git/meta-intel
$ git clone https://github.com/intel/meta-acrn.git
- Initialize build environment
$ source oe-init-build-env
- Add layers to build environment
conf/bblayers.conf
$ bitbake-layers add-layer ../meta-openembedded/meta-oe
$ bitbake-layers add-layer ../meta-openembedded/meta-python
$ bitbake-layers add-layer ../meta-openembedded/meta-filesystems
$ bitbake-layers add-layer ../meta-openembedded/meta-networking
$ bitbake-layers add-layer ../meta-virtualization
$ bitbake-layers add-layer ../meta-intel
$ bitbake-layers add-layer ../meta-acrn
meta-acrn maintains prototype DISTRO configurations for both Servcie VM OS (SOS) and User VM OS (UOS). acrn-demo-service-vm
for Service VM OS and acrn-demo-user-vm
for User VM OS.
local.conf
carries the common configuration, which can be overwritten by individual multiconfigs conf/multiconfig/xxx.conf
For the Service VM OS, we carry configuration in conf/local.conf
and for User VM OS we carry in conf/multiconfig/uos.conf
Append the following configuration in conf/local.conf
:
MACHINE = "intel-corei7-64"
TMPDIR = "${TOPDIR}/master-acrn-sos"
DISTRO = "acrn-demo-service-vm"
# Also use the 'uos' configuration
BBMULTICONFIG = "uos"
# The packages-from-images class (container-package.bbclass) needs to know where images are
CONTAINER_PACKAGE_DEPLOY_DIR = "${TOPDIR}/master-acrn-uos/deploy/images/${MACHINE}"
CONTAINER_PACKAGE_MC = "uos"
# Add core-image-base-package to acrn-image-base
IMAGE_INSTALL:append:pn-acrn-image-base = " core-image-base-package"
# Add core-image-weston-package to acrn-image-sato
IMAGE_INSTALL:append:pn-acrn-image-sato = " core-image-weston-package"
# set preferred kernel for sos
PREFERRED_PROVIDER_virtual/kernel = "linux-intel-acrn-service-vm"
Add the following in conf/multiconfig/uos.conf
:
DISTRO = "acrn-demo-user-vm"
TMPDIR = "${TOPDIR}/master-acrn-uos"
PREFERRED_PROVIDER_virtual/kernel = "linux-intel-acrn-user-vm"
Note how the parent
local.conf
refers to whatDEPLOY_DIR_IMAGE
will be inuos.conf
. Remember to keep these in sync.
Based on your target image, It can be:
- acrn-image-base
- acrn-image-sato
- acrn-image-weston
- acrn-image-minimal
$ bitbake acrn-image-base
By default, building acrn-image-base
will build a .wic
image and can be located at build/master-acrn-sos/deploy/images/intel-corei7-64/
.
Based on configuration, it will also build post-launched VM and install on acrn-image-*.wic along with launch script. Separately user VMs can be located at build/master-acrn-uos/deploy/images/intel-corei7-64/
. User VM images can be core-image-base, core-image-sato and core-image-weston.
On successful build, you will find the ACRN bootable image acrn-image-base-intel-corei7-64.wic
in the build/master-acrn-sos/deploy/images/intel-corei7-64/
directory.
Under Linux, insert a USB flash drive. Assuming the USB flash drive
takes device /dev/sdf
, use dd
to copy the image to it. Before the image
can be burned onto a USB drive, it should be un-mounted. Some Linux distros
may automatically mount a USB drive when it is plugged in. Using USB device
/dev/sdf as an example, find all mounted partitions:
$ mount | grep sdf
and un-mount those that are mounted, for example:
$ umount /dev/sdf1
$ umount /dev/sdf2
Now burn the image onto the USB drive:
$ sudo dd if=acrn-image-base-intel-corei7-64.wic of=/dev/sdf status=progress
$ sync
$ eject /dev/sdf
This should give you a bootable USB flash device. Insert the device into a bootable USB socket on the target, and power on. It should give two boot options, 'boot' and 'ACRN (Yocto)'. Select 'ACRN (Yocto)' to spawn hypervisor, while 'boot' to boot as normal Linux.
$ /var/lib/machines/launch-base.sh
Once a graphical UOS has been started you'll want to interact with it. One simple solution is to set the relevant variables so that logging into the console can access the display.
For X:
$ export DISPLAY=:1
And for Weston:
$ export XDG_RUNTIME_DIR=/run/user/$(id -u)
That will let you start applications but you still can't interact with them: good enough for running glmark2 but not for anything interactive. For this, USB host virtualisation lets you pass specific USB ports through to the guest. Start by using lsusb
to identify the bus and port you want to forward, and then edit launch-weston.sh
or similar to pass another option to acrn-dm
:
-s 7,xhci,1-1,1-2
This forwards ports 1-1 and 1-2 into the UOS, which on Skull Canyon is the two front ports (1-1 on the left, 1-2 on the right). You'll need two input devices for this to work, obviously.
meta-intel provides the following machine configurations:
-
intel-corei7-64
-
intel-skylake-64
intel-skylake-64 is 64-bit machine with -march=skylake and avx2 instruction-set set up. For more information, please check intel-skylake-64.conf
intel-skylake-64 machine must be used for Skylake and successor platforms
To configure MACHINE, set the following in your conf/local.conf
MACHINE = "intel-corei7-64"
The multiconfig/package magic works with a <image>-package.bb
recipe that inherits container-package
. This puts the wic image and launcher script into a package which can be added as usual.
To add core-image-base.wic image into Service OS (Add core-image-base-package to your target ACRN image)
IMAGE_INSTALL:append:pn-acrn-image-base = " core-image-base-package"
To add core-image-weston-package to acrn-image-weston
IMAGE_INSTALL:append:pn-acrn-image-weston = " core-image-weston-package"
To add core-image-weston-package to acrn-image-base
IMAGE_INSTALL:append:pn-acrn-image-base = " core-image-weston-package"
To build for your target board, set ACRN_BOARD
in your conf/local.conf
. By default it is set to nuc11tnbi5
ACRN_BOARD = "whl-ipc-i5"
Supported Boards:
- nuc11tnbi5
- alderlake
- raptorlake
For More information, Please check Supported Hardware
To build for your acrn scenario, set ACRN_SCENARIO
in your conf/local.conf
. By default it is set to shared
scenario.
ACRN_SCENARIO = "hybrid"
Supported scenarios:
- sdc
- shared
- partitioned
- hybrid
- hybrid_rt
For more information, please check Generate a Scenario Configuration File and Launch Scripts
To customize ACRN Configruation, please check Introduction to ACRN Configuration
To build ACRN in RELEASE
mode, set y
to ACRN_RELEASE
in your conf/local.conf
. By default it is set to n
ACRN_RELEASE = "y"
To build ACRN in DEBUG
mode, set n
to ACRN_RELEASE
in your conf/local.conf
.
ACRN_RELEASE = "n"
There are multiple kernel variant available for both Service VM and User VM.
To switch to linux-intel-acrn-service-vm LTS 5.15 kernel (default), in 'local.conf' replace with the following lines:
PREFERRED_PROVIDER_virtual/kernel = "linux-intel-acrn-service-vm"
PREFERRED_VERSION_linux-intel-acrn-service-vm = "5.15%"
To switch to linux-intel-acrn-service-vm mainline tracking 5.19 kernel, in 'local.conf' replace with the following lines:
PREFERRED_PROVIDER_virtual/kernel = "linux-intel-acrn-service-vm"
PREFERRED_VERSION_linux-intel-acrn-service-vm = "5.19%"
To switch to linux-intel-acrn-user-vm LTS 5.15 kernel (default), in 'conf/multiconfig/uos.conf' replace with following lines:
PREFERRED_PROVIDER_virtual/kernel = "linux-intel-acrn-user-vm"
PREFERRED_VERSION_linux-intel-acrn-user-vm = "5.15%"
To switch to linux-intel-acrn-user-vm mainline tracking 5.19 kernel, in 'conf/multiconfig/uos.conf' replace with following lines:
PREFERRED_PROVIDER_virtual/kernel = "linux-intel-acrn-user-vm"
PREFERRED_VERSION_linux-intel-acrn-user-vm = "5.19%"
To switch to linux-intel-acrn-rtvm Preempt-RT 5.15 kernel, in 'conf/multiconfig/uos.conf' replace with following line:
PREFERRED_PROVIDER_virtual/kernel = "linux-intel-acrn-rtvm"
PREFERRED_VERSION_linux-intel-acrn-rtvm = "5.15%"
To switch to linux-intel-acrn-rtvm Preempt-RT mainline tracking 5.19 kernel, in 'conf/multiconfig/uos.conf' replace with following line:
PREFERRED_PROVIDER_virtual/kernel = "linux-intel-acrn-rtvm"
PREFERRED_VERSION_linux-intel-acrn-rtvm = "5.19%"
Following variables are used to prepare kernel command lines for Pre-launched User VMs and Service VM. Based on these variables an ACRN specific grub.cfg
gets generated.
These variables can be overwritten in your local config.
-
VMFLAGS - list of pre-launched VMs including Service VM For example: VMFLAGS = "vm0 vm1 ... vmx"
-
VM_APPEND - VM kernel commandline
-
KERNEL_IMAGE - kernel image like bzImage for each vm
-
KERNEL_MOD - kern_mod tag in acrn scenario xml for each
-
ACPI_TAG - ACPI tag for specific VM
-
ACPI_BIN - binary of ACPI tables for a specific vm
-
PART_LABEL - Partition Label, if set, it allow grub bootloader to pick modules/kernel binaries by partition label
For example, using hybrid scenario for nuc7i7dnb:
VMFLAGS = "vm0 vm1"
# vm0 (prelaunch vm zephyr)
VM_APPEND_vm0 = "xxx"
KERNEL_IMAGE_vm0 = "/custom path/zephyr.bin"
KERNEL_MOD_vm0 = "Zephyr_RawImage"
ACPI_TAG_vm0 = "ACPI_VM0"
ACPI_BIN_vm0 = "ACPI_VM0.bin"
PART_LABEL_vm0 = "zephyr module partition label"
# vm1 (sos)
VM_APPEND_vm1 = "xxx"
KERNEL_IMAGE_vm1 = "/custom path/bzImage" //Pass complete path
KERNEL_MOD_vm1 = "Linux_bzImage"
PART_LABEL_vm1 = "boot"
- ACRN_EFI_GRUB2_MOD_CFG wic variable (semicolon (;) separated list) to make additional entries in grub.cfg i.e insmod ext3
Additionaly grub bootloader uses 'search' command at grub menu entry to find the device by file (--file).
- ACRN_HV_EFI_CFG wic variable to add ACRN Hyperviosr parameters
For more information, please check Update Ubuntu GRUB, acrn-bootconf.bbclass and ACRN Hypervisor Parameters
Due to parsing sequence conflict with meta-intel
, weak assignments are not used in acrn-demo-service-vm
and acrn-demo-user-vm
distros. So to override distro configuration in conf/local.conf
, override syntax can be used i.e
WKS_FILE_acrn-demo-service-vm = "your-custom.wks.in"
To install the image on to NUC, you could burn the .wic image to the target hardware's internal storage.
Alternatively, you could build a wic based installer image where you can burn the .wic image onto USB flash drive and use USB flash drive as installer. To build the installer image for ACRN, add the following lines to conf/local.conf
:
BBMULTICONFIG:append = " installer "
Add followings in conf/multiconfig/installer.conf
:
# use the installer wks file
WKS_FILE:pn-acrn-image-base = "image-installer.wks.in"
# build initramsfs to start the installation
INITRD_IMAGE_LIVE="core-image-minimal-initramfs"
# make sure initramfs and ext4 image are ready before building wic image
do_image_wic[depends] += "${INITRD_IMAGE_LIVE}:do_image_complete"
IMAGE_TYPEDEP_wic = "ext4"
# content to be installed
IMAGE_BOOT_FILES:append = "\
${KERNEL_IMAGETYPE} \
acrn.bin;esp/acrn.bin \
microcode.cpio;esp/microcode.cpio \
grub-efi-bootx64.efi;EFI/BOOT/bootx64.efi \
${IMAGE_ROOTFS}/boot/EFI/BOOT/grub.cfg;esp/EFI/BOOT/grub.cfg \
${IMGDEPLOYDIR}/${IMAGE_BASENAME}-${MACHINE}.ext4;rootfs.img \
"
Now build the installer image:
$ bitbake mc:installer:acrn-image-base
The following undergo regular basic testing with their respective MACHINE types.
intel-corei7-64: NUC11TNHi5
intel-skylake-64: NUC11TNHi5
You are encouraged to follow Github Pull request workflow to share changes and following commit message guidelines are recommended OE patch guidelines
Layer Maintainer: Naveen Saini <[email protected]>