.. _using_zephyr_as_uos: .. _using_zephyr_as_user_vm: Run Zephyr as the User VM ######################### This tutorial describes how to run Zephyr as the User VM on the ACRN hypervisor. We are using Kaby Lake-based Intel NUC (model NUC7i5DNHE) in this tutorial. Other :ref:`ACRN supported platforms ` should work as well. .. note:: This tutorial uses the (default) SDC scenario. If you use a different scenario, you will need a serial port connection to your platform to see Zephyr console output. Introduction to Zephyr ********************** The Zephyr RTOS is a scalable real-time operating system supporting multiple hardware architectures, optimized for resource constrained devices, and built with safety and security in mind. Steps for Using Zephyr as User VM ********************************* #. Build Zephyr Follow the `Zephyr Getting Started Guide `_ to set up the Zephyr development environment. The build process for ACRN User VM target is similar to other boards. We will build the `Hello World `_ sample for ACRN: .. code-block:: none $ cd samples/hello_world $ west build -p auto -b acrn . This will build the application ELF binary in ``samples/hello_world/build/zephyr/zephyr.elf``. #. Build grub2 bootloader image We can build the grub2 bootloader for Zephyr using ``boards/x86/common/scripts/build_grub.sh`` found in the `Zephyr source code `_. .. code-block:: none $ ./boards/x86/common/scripts/build_grub.sh x86_64 The EFI executable binary will be found at ``boards/x86/common/scripts/grub/bin/grub_x86_64.efi``. #. Preparing the boot device .. code-block:: none $ dd if=/dev/zero of=zephyr.img bs=1M count=35 $ mkfs.vfat -F 32 zephyr.img $ sudo mount `sudo losetup -f -P --show zephyr.img` /mnt Create the following directories. .. code-block:: none $ sudo mkdir -p /mnt/efi/boot $ sudo mkdir -p /mnt/kernel Copy ``zephyr.elf`` and ``grub_x86_64.efi`` .. code-block:: none $ sudo cp boards/x86/common/scripts/grub/bin/grub_x86_64.efi /mnt/efi/boot/bootx64.efi $ sudo cp samples/hello_world/build/zephyr/zephyr.elf /mnt/kernel Create ``/mnt/efi/boot/grub.cfg`` containing the following: .. code-block:: console set default=0 set timeout=10 menuentry "Zephyr Kernel" { multiboot /kernel/zephyr.elf } Unmount the loopback device: .. code-block:: none $ sudo umount /mnt You now have a virtual disk image with a bootable Zephyr in ``zephyr.img``. If the Zephyr build system is not the ACRN Service VM, then you will need to transfer this image to the ACRN Service VM (via, e.g, a USB drive or network) #. Follow :ref:`gsg` to boot "The ACRN Service OS" based on Ubnuntu OS (ACRN tag: v2.2) #. Boot Zephyr as User VM On the ACRN Service VM, prepare a directory and populate it with Zephyr files. .. code-block:: none $ mkdir zephyr && cd zephyr $ cp /usr/share/acrn/samples/nuc/launch_zephyr.sh . You will also need to copy the ``zephyr.img`` created in the above section into directory ``zephyr``. Run the ``launch_zephyr.sh`` script to launch Zephyr as User VM. .. code-block:: none $ sudo ./launch_zephyr.sh Then Zephyr will boot automatically. You will see a console message from the hello_world sample application: .. code-block:: console Hello World! acrn