# Enable virtualization

Virtualization uses software to create an abstraction layer over
computer hardware.

The abstraction layer divides the hardware elements of a single computer,
such as processor, memory, and storage into different
virtual entities, called as virtual machines (VMs). Each VM runs its
own OS and behaves like an independent computer,
though it’s running on the same underlying computer hardware.

![../_images/virtualization-3.png](data:image/png;base64,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)

**Figure: Virtualization**

Note

Virtualization is supported on the custom BSP variant only.

## Qualcomm virtualization solution

Qualcomm uses Gunyah, a type-1 hypervisor designed for strong security,
high performance, OS independence, and higher CPU privilege level.

Gunyah doesn’t depend on any lower-privileged OS kernel or code for its
core functionality to offer increased security. Gunyah is designed for
isolated virtual machine use cases, and for launching isolated
virtual machines from a relatively less trusted host virtual machine.

The following figure shows the Qualcomm virtualization solution
architecture:

![../_images/virtualization-solution.png](data:image/png;base64,UklGRsAOAABXRUJQVlA4TLQOAAAvYIJwAO8mx7Zt1Yrmk4+7ZxZ7o+kKqRN65O68e++Bqk7AsW1reXK+P57KcPc6NYtxMFwqBkDl7lRx+STfu3Bs21qenF+jnSe4SwujYZxUzIFSq1R43OW9785/HcCQhCQlx0kYOCkZnIQBwiEMkMqQkZCEgZMwBBIGSEiKSUjCEIAQkhAgxSQkhJAECAkhJCH5DxSTkCQ3VdUz6GsW7hIMjWLdpA//Oss9FltoaOfuoT5X/5svv5aWOTTgxdsU32EjbcbsYRmMFZlJ2/GJx7jHLdDQI1MXseTdR38pBZeDC8lnWqvnkc6bkOQQJG+SN5032ZsAiCBACxoWABrwaoecHtCz0sygqZrncMIJ0BOdLfyp+jvznQyacGuo5bwCx8Z+V9B3BfAPL4Yuds44gScOYA/LwB4WuYATvcYWGuZAs5jwCZ/I8RzqmmpJjhXO0NhCSSs5u5IkeZezS95EkpxdSZK8KRbYjD3GxGT1gHf0hiuomwOoWe1HPGMLOIEj4I5XeAauuAEu4NEuwBW9D06wcP3paTj2OphJ3nRpR458yiBol5Eqx5I3yjWzwBNuAQZeG3PKaMupqgzrwUBYQp8ToA51swB9x7w5cjfmzoG61cuamzNs2z2f8I4T4AB45gqOHkwMq2Bx+z/HbaIZWHwOSnF8TlNoRhhXzZ1F77333ubOsVCinC7xmbL0JiFCk0/0jjjLIqbYSPSOTAcnKwWZqrv7Z3Z/MytrZ2e1S9mI/kuCJElSIy9drR1Q0tNzYwtvDOpPS72oWoLZWrJ/mHhUdeBKYBXxsmof3R5hQnqD3lSFCCF/xvh9QtYqXlV1hEkvxgeQIcW7qhAJ74b7SY+HZT9Cdvf99+unY46WpK///xfX5q23JOkEdKJrg5Aknej7z/ef7z9fKx09RNgKLRPKmn4iaoW7A1ZaFiJiVf8aJ9JJRK7wMoGsJSLXQJuFn2EiXAUdSC8RurrF0RYmQlfQOt0irgvaZcv2I6ZfHCuI2ELWGSACVofj2JOIbUAcnYLrsQ4RUafvP99/f4glMl3MAUkEqrjpeZMQtmF999hPErEV0zOovP65o4CKW7IthVQBJcxmVTFnEsIuBOgeaajDLC2Feum/pQykgkX/FxQzCWEXAnSPDamNZUiimefJ3duR2kK4dyp2F1L5sycyPZs1CWETInSPJNSLObCajzk//ky5d2o2y5899VLGJIRNiNA9tsdZwJjlrGUQmS5ljMVdAl9E6B45uHcqxi5nLYNUIQG2JDwH/YwSZiFsQoDuse8kxVyLo17MwfUSd1aZhrALAbrHrbh3CsFKcBQ3ZolJCLsQoXtcSiOJGHA/qrH5ZhsidI8bmQRu7JjTkqrtidA9LuSO4AzgBLA9AbrHpZzg/QGpvCuMdtfE7pEI3nENJ4PaclyiuneqlOGMnYTdNbF7pCfyI7jI7oE9Tcj3n+8/30OBFk+4FaIMia1PHAHB7WudPhGtcB77iu0DcSi9YuuyzgdCvgEJ59Eu9JAJtQlk2aDI9las0xYSzuAK6WpOrQkKW/oKSSBK+9qgsNWhWFpdQbFqbbsH9q6ffP/5/vP95/vP95/vv982CHQPEkErHOoQSkcoTAStodAyoXT1iPtamvu2W2rtvj0iVeiDQFMFBonI1SmQFUTkGgoIZA0RufrbLHyVt17x5lRnM+1NhNYrkB4idO0nkCEidK21TlDE1yZupj4idrULoy0stn5xrCBiC0n6lXYHBLeni30xet9/vv9cjSSC9dqWLCH1V2/LApGTX07IxykvI4Revc4khN1Y2D1Oj62YDiGVTSMdkV8QrE1ZHRtio81Y2T1ia9aYSiKV794p1UZUuIwXijlSL74YA+qvFaSjjmauy+rds91YAFOForE2Om07Uu3F0u6Rjnu3I1vhBaiXfiplwHL1L+lIFWaZnYZppJIfkMqkidmLpd1jW2oDGZi1GLKv0wtGjGTpdOmoF3OcsWOynbEXS7tHLiIvoZnbkV0bpfunEsb8mT1NNiLTs1luhMg02nRd1oas6h4JufeNLdmkrbC1kegy9dms3k6kZOPeKXbjBjqHRH5GtryZpd0jmwYhdvTa9QRI6ner/156CIkc9b8XEZrN2oul3WP3SYo5e1MJuXu6+E8C6VPo7WxKRo2GIvyIbDaJpd3j8ODBVgLSZ8h9+i9Scpvk3inOMWIpY6tJrO0eR2+ocKNSzMHNyQ/FW1/PkZTc7sgYP/ZkSfe0EEgSzWaBVOEV43ZyOsFL2DOnSVTckjX2KOzWsLZ7WgCkjhLwiMuYDTrJXaL6gQkxk7HXJSpLu8fxsb8CR1x1pBpkd5H9sJcL4IkBNrvIbmX32P8aaCnDyaCyXObThLxelpXvP99/v/MTcHNCYgsrwlCGxNYnjoDg9rVOv4g6mmit2LoFsrfY1olD6RVbl3X2FdBQ2yLY61t/QCBtvWK/RLJAlg2KbG/FOoEB8axWmknpCgpba9oUgSjKmqCw1aWIRGlfGxS2OhQrq33vHrGqu8MDe0Mgvv98//n++92sN9+UpCPRMa7N118rkqyDlRZJS1e+/3z//WbO8sfPvtAd1TNfyNpXl1L3VGdbatnqoEi1rqOZlrupT0qfsVCQiFa9geZ5ktKrXJOr6JUfWma1iK+82DwXuqhP+ndKH7NMj5Cv0d00V1LqipthO79WOHXJiO8/33+elZsnyhjvPCTeVCML8/HGYzQ9vkNLIrZiegaV4+6XESpuzDqMkUkMSzveBUgVQJaZjLPI452Hxym9ehJXxqzVWjX4a0uuyDS6Xp9gGiUcRbS8gxnPNXxqy+/eqRhzTw7BfDhveOBYOECN2xnT3fQp1g6ldBdOG6nmqpTe8AnG2iFxYPOCngrgxuCnzFe2TmL8zbhudIKTt1rDlU+140G2+c3gEU6WQTyQT48wPM7EG3dSnJIny1aBJjCoNLwt3YVPpTUmimHHpyCCgR+Dl1L3PbNLGS2DvFXDzjKevwGnYbYRQ57d82TzVcZgvLhjSzpJA47DxlXjtIb1WPnKGJhuw5yxMovOwVTz4/Q7XAW4MXgpaR5rZxiHLlU9wT1xI8GpekB28INshg3G46BgrOfxtjhIasRzykmKuQakCrNZB7JhDus1v5nPGKBg1O3Cp7L5LjrrwU8woB0PUxn4MXgp89rxIFLl2nIVhquCRwMHP8gGacNn3UIpfBgw6VY9nnNLFfQsTtNoFCcCGIK78KmcTadJKvM1Li9lHg7OmvacHpcJDJMaucDvQYwaxnDPMFpOU5j0WPiAnLnxA5p53lFO8IL1G+cIoWG0VhmD6zr810POvHlukdiUjYHbYrgS5T64myfgqHd2vDvV/9VhRMvzcR5me2wqWj5irgrXd3qqxWJTmjTSpitqWjPCcINffeOn2vHchmOLsKfenOYEr3bILZSO3Pgpno/ncdo4UjBlHEyeaqjG6eineJE4KWke7xhnDhW0Q43jh3KVI1r+t3Y8FC1Xb6F0dEE7njuJY6sj1ZGugU5iWMY43AX+wKfmQ7eG4RqV3cIuCpMSfPmESRmFTe14FrPwUO4d4Srl5XNEbJUynAxqqsAJ4yAX2TmnVbXha6he35Xx8OYFc9FyFQT8FOOdh+ub3EXhpcxXtk5gPBxnTvDi4XFu0hpOU8bIC2Xj4VD2RPC2W6hjSyKRyLXAfTY7JTTmnTwPbVRfkTU7pacC7vKlm57SYzGygLc1PSXLA3uqtu8/3382coVLNmRn57ksD1smJKL2pnmc0qtclCvetcyKsHjWK02jXOiqvj+mWFddg4IJr29ronfPd1E/P6ZYWoFOkWqF/sAWo4H66vFn3FE9/KEH9qaMfP/5/vP993tcnet7XFF1f9AubeuIa6rBZZLWQVxU9Uha0E0h7XK2n6uyp+8/33+/rXTKywihV5/XJRGo4qbndT8Uc0CqEPN4RKYRrATA/JDzktTRzLOERO4qFHM6FYz1X1DMQ5JEs1kmQIxFItOzWe9InRm+JHLSsxykXsp4QTjrSM5q1Jv6cu9UjDTgoJ9RgnhWmNLbnlKjAcWNehZPaRJeAs4kxETC25EqzGY5AUwkUQL+FaR6Pyd4ryMkckcBqcTEvVPoH1kSubNQynhHl6gAbpMJdD3xeJDIXa8ghF59lgCNXH2/zgN7mpDvP99/f7BnvasSkLMuN6VfkTMl5KJ0ypoS7HVJ73Ug1OGBveMU338+5A4gQx6WEAnvht8nZJ1npTNMejHePUxIb9CbqhAhZCXGeCXxsmovbNSS/cNelQNXYu+rfP/9PtOXn8uoPnaR3jnnSiqnuuIp1/h5GZVXXeASnUul5SpKn3CF3r6SyuzjYlfocyoxf6P0HTfoUcn56A+B3PgZxvibM7wrI5NMuOG4VyWPd5wR1yf/FFc9KtHyfBz+mQV8qjclrx3PGeJVmq9sncT4m3HD6ATG2iFxfcTP3/Qp1g7lbszLTLbRCT3B8Dg1ssXh7UYWqjVcGaejn2L8LT+/SwdHJDdCvvI91ssY7NEyiFw1Vqmg0ryNOczGRquMmdhZxvPxaBkm4uV37TbM8UZcvjKWx9oZxuGGHiaP74kbEU7VVeO0hqucqMYgvgGn9Wjb4iClCWMJALcb+Q8+lZvfK6AdD9ahlTFjQw0iVI0UcDiztOGzbmFGOJOSrzLGfzi8/J5BY4zqVdOOj5aZzPObOYN2F7zrGmgfEo+W05RJyQMT6JEYvPxxb2CShlS2mqM3T4CRelOTVca8gTviNXhDc4SDG/fqGz/VjuM12M03ZNZIewIneCk8wQtCjLOHC9qhxjFEucrDWcPeQunognY8MwkMnDYWDYYR4XBKbyzz83sEl6jy2iempzX4m12TO8JVXjRKwVZ7x6cMNrV2PDe/R3CRPV/ZOsFeDR2dwODsbQNGXihjvPNw9tzttluoXt+V8fDmBQ5wgnfHODe/F/A0IWhM3EtUf6CEUvq7PY94Xz6i9CqJ/XAFdoV1MZVZnesS/1dFmbniPewO66HLpeWSL93j/935yNNyqofexl5YYQ==)

**Figure: Qualcomm virtualization solution architecture**

Gunyah provides the following features:

Table: Features of Gunyah

| Features | Description |
| --- | --- |
| Threads and scheduling | Scheduler schedules virtual CPUs (VCPUs) on physical CPUs and allows time-sharing of the CPUs. |
| Memory management | Gunyah tracks memory ownership and memory usage under its control. Gunyah provides low-level dynamic memory management APIs on top of which the higher-level donation, lending, and sharing are built. |
| Interrupt virtualization | Gunyah manages interrupts that are routed directly to the assigned VM. |
| Inter-VM communication | Message queues and doorbells provide mechanisms for communication between the VMs. |
| Device virtualization | Para-virtualization of devices is supported using inter-VM communication and virtio primitives. The hardware virtualization and emulation support low-level architecture features and devices, such as CPU timers and interrupt controllers. |
| Resource manager | Gunyah supports a root VM that initially owns all the VM memory and input/output resources. The Gunyah resource manager is the default-bundled root VM and provides high-level services including dynamic VM management, secure memory donation, lending, and sharing. |

The Gunyah hypervisor support is added to the
[crosvm](https://chromium.googlesource.com/chromiumos/platform/crosvm)
virtual memory monitor (VMM). The crosvm interacts with the Gunyah VM
manager in the kernel through the `/dev/gunyah` interface and creates a
VM.

The following figure shows the blocks in the Qualcomm virtualization
solution:

![../_images/virtualization_solution_new.png](data:image/png;base64,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)

**Figure: Qualcomm virtualization solution**

For more information about type 1 hypervisor, see
[gunyah-hypervisor](https://github.com/quic/gunyah-hypervisor).

### Guest VM build support

To compile the guest VM kernel and initrd images, use the following procedure:

During the guest VM kernel compilation, both the guest kernel and the
minimal `rootfs` are built. `qcom_vm_defconfig` serves as the
base configuration for compiling the guest kernel. The
`qcom_vm_debug.config` builds the debug variant of the guest VM.

`crosvm` serves as the VMM and interacts with the Gunyah VM
manager in the kernel through the `/dev/gunyah` interface to create VMs.

#### Build a guest VM

For more information about `crosvm` support, see
[Create secondary virtual machine](https://docs.qualcomm.com/bundle/publicresource/topics/80-70018-27/qualcomm_linux_software_components.html#create-secondary-virtual-machine).

After the build process completes, certain images are generated. These
images get stored in the
`<workspace>/build-qcom-wayland/tmp-glibc/deploy/images/<SoC>/qcom-console-image`
directory.

To compile the guest VM, run the following command:

export SHELL=/bin/bash && MACHINE=SOC DISTRO=qcom-wayland source setup-environment
    
    bitbake qcom-console-image
    Copy to clipboard

#### Guest VM initrd image

- The `svm-initramfs-qcom-image-<SoC>.cpio.gz` file is created for
the guest VM. This image contains an initrd image, used during the
boot process.
- The `svm-initramfs-qcom-image-<SoC>.cpio.gz` file is generated in
the
`build-qcom-wayland/tmp-glibc/deploy/images/<SoC>/svm-initramfs-qcom-image`
directory.
- On the booted device, the image is stored in the
`/var/gunyah/initrd.img` file within the system rootfs.

#### Guest VM kernel image

- `svm-initramfs-qcom-image-<SoC>.cpio.gz` image is generated for
the secondary virtual machine (SVM), which is the guest kernel image.
- The SVM kernel image is generated in the
`build-qcom-wayland/tmp-glibc/deploy/images/<SoC>/linux-svm-kernel-qcom`
directory.
- On the booted device, the image is in a `/var/gunyah/Image` file
within the system rootfs.

Both the `initrd.img` and the SVM kernel images are packed in the
`system.img` file. The final `system.img` file is found in the same
directory as the other images
`<workspace>/build-qcom-wayland/tmp-glibc/deploy/images/<SoC>/qcom-console-image`.

### Launch guest virtual machine

Use the `crosvm` VMM and the Gunyah hypervisor to launch the guest virtual
machines.

To launch the VM, run the following command:

# /usr/bin/crosvm --log-level=debug --no-syslog run --disable-sandbox --hypervisor \
                                              gunyah --protected-vm-without-firmware \
                                              --serial=type=stdout,hardware=virtio-console,console,stdin,num=1 \
                                              --serial=type=stdout,hardware=serial,earlycon,num=1 \
                                              --initrd /var/gunyah/initrd.img --no-balloon --no-rng \
                                              --params "rw root=/dev/ram earlyprintk=serial panic=0" \
                                              /var/gunyah/Image
    Copy to clipboard

The following are the supported parameters for the `crosvm` command to
launch guest VMs:

Table: Supported parameters

| Parameters | Description |
| --- | --- |
| /usr/bin/crosvm<br>    Copy to clipboard | Shows the path of the `crosvm` binary |
| --log-level=debug<br>    Copy to clipboard | Sets the logging level to debug while running `crosvm` |
| --no-syslog<br>    Copy to clipboard | Disables syslog |
| --disable-sandbox<br>    Copy to clipboard | Disables sandboxing |
| --hypervisor gunyah<br>    Copy to clipboard | Specifies the hypervisor to be used (in this case, `gunyah`) |
| --protected-vm-without-firmware<br>    Copy to clipboard | Indicates that the VM is protected and doesn’t require firmware |
| --serial=...<br>    Copy to clipboard | Configures serial devices for input/output |
| --initrd /var/gunyah/initrd.img<br>    Copy to clipboard | Specifies the initial RAM disk (initrd) image |
| --no-balloon<br>    Copy to clipboard | Disables memory ballooning |
| --no-rng<br>    Copy to clipboard | Disables the entropy source used to seed the guest OS entropy pool |
| --params "..."<br>    Copy to clipboard | Specifies the kernel command-line options |
| /var/gunyah/Image<br>    Copy to clipboard | Specifies the path to the kernel image |

#### View VM and boot logs

The following sample output shows the VM logs:

bash-5.1# cat /proc/cpuinfo
    processor       : 0
    BogoMIPS        : 38.40
    Features        : fp asimd evtstrm aes pmull sha1 crc32 atomics cpuid asimdrdm dcpop asimddp
    CPU implementer : 0x00
    CPU architecture: 8
    CPU variant     : 0x0
    CPU part        : 0x048
    CPU revision    : 0
    
    bash-5.1# cat /proc/meminfo
    MemTotal:         161656 kB
    MemFree:          124940 kB
    MemAvailable:     124032 kB
    Buffers:               0 kB
    Cached:            19816 kB
    SwapCached:            0 kB
    Active:               12 kB
    Copy to clipboard

The following code snippet shows the boot logs:

[2022-04-28T17:43:03.290477745+00:00 DEBUG crosvm::crosvm::sys::linux] creating hypervisor: Gunyah { device: None }
    [    0.000000] Booting Linux on physical CPU 0x0000000000 [0x000f0480]
    [    0.000000] Linux version 6.6.0 (oe-user@oe-host) (aarch64-qcom-linux-gcc (GCC) 11.4.0, GNU ld (GNU Binutils) 2.38.20220708) #1 SMP PREEMPT Wed Feb  7 04:56:59 UTC 2024
    [    0.000000] KASLR enabled
    [    0.000000] random: crng init done
    [    0.000000] Machine model: linux,dummy-virt
    [    0.000000] earlycon: uart8250 at MMIO 0x00000000000003f8 (options '')
    [    0.000000] printk: bootconsole [uart8250] enabled
    [    0.000000] efi: UEFI not found.
    [    0.000000] software IO TLB: Reserved memory: created restricted DMA pool at 0x0000000090000000, size 64 MiB
    [    0.000000] OF: reserved mem: initialized node restricted_dma_reserved@90000000, compatible id restricted-dma-pool
    [    0.000000] OF: reserved mem: 0x0000000090000000..0x0000000093ffffff (65536 KiB) map non-reusable restricted_dma_reserved@90000000
    [    0.000000] NUMA: No NUMA configuration found
    [    0.000000] NUMA: Faking a node at [mem 0x0000000080000000-0x0000000093ffffff]
    [    0.000000] NUMA: NODE_DATA [mem 0x8ff509c0-0x8ff52fff]
    [    0.000000] Zone ranges:
    [    0.000000]   DMA      [mem 0x0000000080000000-0x0000000093ffffff]
    [    0.000000]   DMA32    empty
    [    0.000000]   Normal   empty
    [    0.000000] Movable zone start for each node
    [    0.000000] Early memory node ranges
    [    0.000000]   node   0: [mem 0x0000000080000000-0x0000000093ffffff]
    [    0.000000] Initmem setup node 0 [mem 0x0000000080000000-0x0000000093ffffff]
    [    0.000000] On node 0, zone DMA: 16384 pages in unavailable ranges
    [    0.000000] cma: Reserved 32 MiB at 0x000000008d600000 on node -1
    [    0.000000] psci: probing for conduit method from DT.
    [    0.000000] psci: PSCIv1.1 detected in firmware.
    [    0.000000] psci: Using standard PSCI v0.2 function IDs
    [    0.000000] psci: MIGRATE_INFO_TYPE not supported.
    [    0.000000] psci: SMC Calling Convention v1.3
    [    0.000000] percpu: Embedded 31 pages/cpu s86568 r8192 d32216 u126976
    [    0.000000] Detected PIPT I-cache on CPU0
    [    0.000000] CPU features: detected: GIC system register CPU interface
    [    0.000000] CPU features: detected: Spectre-v4
    [    0.000000] CPU features: kernel page table isolation forced ON by KASLR
    [    0.000000] CPU features: detected: Kernel page table isolation (KPTI)
    [    0.000000] alternatives: applying boot alternatives
    [    0.000000] Kernel command line: panic=-1 console=hvc0 earlycon=uart8250,mmio,0x3f8 rw root=/dev/ram earlyprintk=serial panic=0
    [    0.000000] Unknown kernel command line parameters "earlyprintk=serial", will be passed to user space.
    [    0.000000] Dentry cache hash table entries: 65536 (order: 7, 524288 bytes, linear)
    [    0.000000] Inode-cache hash table entries: 32768 (order: 6, 262144 bytes, linear)
    [    0.000000] Fallback order for Node 0: 0
    [    0.000000] Built 1 zonelists, mobility grouping on.  Total pages: 80640
    [    0.000000] Policy zone: DMA
    [    0.000000] mem auto-init: stack:off, heap alloc:off, heap free:off
    [    0.000000] software IO TLB: area num 1.
    [    0.000000] software IO TLB: mapped [mem 0x0000000089600000-0x000000008d600000] (64MB)
    [    0.000000] Memory: 116344K/327680K available (14528K kernel code, 3938K rwdata, 7112K rodata, 6080K init, 571K bss, 178568K reserved, 32768K cma-reserved)
    [    0.000000] SLUB: HWalign=64, Order=0-3, MinObjects=0, CPUs=1, Nodes=1
    [    0.000000] trace event string verifier disabled
    [    0.000000] rcu: Preemptible hierarchical RCU implementation.
    [    0.000000] rcu:     RCU event tracing is enabled.
    [    0.000000] rcu:     RCU restricting CPUs from NR_CPUS=256 to nr_cpu_ids=1.
    [    0.000000]  Trampoline variant of Tasks RCU enabled.
    [    0.000000]  Tracing variant of Tasks RCU enabled.
    [    0.000000] rcu: RCU calculated value of scheduler-enlistment delay is 25 jiffies.
    [    0.000000] rcu: Adjusting geometry for rcu_fanout_leaf=16, nr_cpu_ids=1
    [    0.000000] NR_IRQS: 64, nr_irqs: 64, preallocated irqs: 0
    [    0.000000] GICv3: 988 SPIs implemented
    [    0.000000] GICv3: 0 Extended SPIs implemented
    [    0.000000] Root IRQ handler: gic_handle_irq
    [    0.000000] GICv3: GICv3 features: 16 PPIs
    [    0.000000] GICv3: CPU0: found redistributor 0 region 0:0x000000003ffd0000
    [    0.000000] rcu: srcu_init: Setting srcu_struct sizes based on contention.
    [    0.000000] arch_timer: cp15 timer(s) running at 19.20MHz (virt).
    [    0.000000] clocksource: arch_sys_counter: mask: 0xffffffffffffff max_cycles: 0x46d987e47, max_idle_ns: 440795202767 ns
    [    0.000000] sched_clock: 56 bits at 19MHz, resolution 52ns, wraps every 4398046511078ns
    [    0.002616] arm-pv: using stolen time PV
    [    0.003945] Console: colour dummy device 80x25
    [    0.005300] Calibrating delay loop (skipped), value calculated using timer frequency.. 38.40 BogoMIPS (lpj=76800)
    [    0.008475] pid_max: default: 32768 minimum: 301
    [    0.009923] LSM: initializing lsm=capability,selinux,integrity
    [    0.011702] SELinux:  Initializing.
    [    0.012884] Mount-cache hash table entries: 1024 (order: 1, 8192 bytes, linear)
    [    0.015180] Mountpoint-cache hash table entries: 1024 (order: 1, 8192 bytes, linear)
    [    0.017809] cacheinfo: Unable to detect cache hierarchy for CPU 0
    [    0.019820] RCU Tasks: Setting shift to 0 and lim to 1 rcu_task_cb_adjust=1.
    [    0.022107] RCU Tasks Trace: Setting shift to 0 and lim to 1 rcu_task_cb_adjust=1.
    [    0.024472] rcu: Hierarchical SRCU implementation.
    [    0.025891] rcu:     Max phase no-delay instances is 1000.
    [    0.027767] EFI services will not be available.
    [    0.029190] smp: Bringing up secondary CPUs ...
    [    0.030713] smp: Brought up 1 node, 1 CPU
    [    0.032002] SMP: Total of 1 processors activated.
    [    0.033471] CPU features: detected: 32-bit EL0 Support
    [    0.035048] CPU features: detected: Data cache clean to the PoU not required for I/D coherence
    [    0.037742] CPU features: detected: Common not Private translations
    [    0.039678] CPU features: detected: CRC32 instructions
    [    0.041275] CPU features: detected: LSE atomic instructions
    [    0.043105] CPU features: detected: Privileged Access Never
    [    0.044891] CPU: All CPU(s) started at EL1
    [    0.046161] alternatives: applying system-wide alternatives
    [    0.050071] devtmpfs: initialized
    [    0.051500] clocksource: jiffies: mask: 0xffffffff max_cycles: 0xffffffff, max_idle_ns: 7645041785100000 ns
    [    0.054767] futex hash table entries: 256 (order: 2, 16384 bytes, linear)
    [    0.057122] pinctrl core: initialized pinctrl subsystem
    [    0.058872] DMI not present or invalid.
    [    0.060334] NET: Registered PF_NETLINK/PF_ROUTE protocol family
    [    0.062534] DMA: preallocated 128 KiB GFP_KERNEL pool for atomic allocations
    [    0.064964] DMA: preallocated 128 KiB GFP_KERNEL|GFP_DMA pool for atomic allocations
    [    0.067353] DMA: preallocated 128 KiB GFP_KERNEL|GFP_DMA32 pool for atomic allocations
    [    0.069943] audit: initializing netlink subsys (disabled)
    [    0.071632] audit: type=2000 audit(0.056:1): state=initialized audit_enabled=0 res=1
    [    0.074141] thermal_sys: Registered thermal governor 'step_wise'
    [    0.074143] thermal_sys: Registered thermal governor 'power_allocator'
    [    0.076118] cpuidle: using governor menu
    [    0.079536] hw-breakpoint: found 6 breakpoint and 4 watchpoint registers.
    [    0.081693] ASID allocator initialised with 32768 entries
    [    0.083662] Serial: AMBA PL011 UART driver
    [    0.085582] Modules: 2G module region forced by RANDOMIZE_MODULE_REGION_FULL
    [    0.087812] Modules: 0 pages in range for non-PLT usage
    [    0.087813] Modules: 516176 pages in range for PLT usage
    [    0.091914] HugeTLB: registered 1.00 GiB page size, pre-allocated 0 pages
    [    0.099837] HugeTLB: 0 KiB vmemmap can be freed for a 1.00 GiB page
    [    0.101815] HugeTLB: registered 32.0 MiB page size, pre-allocated 0 pages
    [    0.107895] HugeTLB: 0 KiB vmemmap can be freed for a 32.0 MiB page
    [    0.109875] HugeTLB: registered 2.00 MiB page size, pre-allocated 0 pages
    [    0.116064] HugeTLB: 0 KiB vmemmap can be freed for a 2.00 MiB page
    [    0.118084] HugeTLB: registered 64.0 KiB page size, pre-allocated 0 pages
    [    0.124190] HugeTLB: 0 KiB vmemmap can be freed for a 64.0 KiB page
    [    0.128423] ACPI: Interpreter disabled.
    [    0.132206] iommu: Default domain type: Translated
    [    0.133734] iommu: DMA domain TLB invalidation policy: strict mode
    [    0.135749] SCSI subsystem initialized
    [    0.140957] usbcore: registered new interface driver usbfs
    [    0.142744] usbcore: registered new interface driver hub
    [    0.144353] usbcore: registered new device driver usb
    [    0.149976] pps_core: LinuxPPS API ver. 1 registered
    [    0.151488] pps_core: Software ver. 5.3.6 - Copyright 2005-2007 Rodolfo Giometti <giometti@linux.it>
    [    0.162194] PTP clock support registered
    [    0.163436] EDAC MC: Ver: 3.0.0
    [    0.164532] scmi_core: SCMI protocol bus registered
    [    0.166176] FPGA manager framework
    [    0.171350] Advanced Linux Sound Architecture Driver Initialized.
    [    0.173213] vgaarb: loaded
    [    0.174176] clocksource: Switched to clocksource arch_sys_counter
    [    0.235827] VFS: Disk quotas dquot_6.6.0
    [    0.237108] VFS: Dquot-cache hash table entries: 512 (order 0, 4096 bytes)
    [    0.239428] pnp: PnP ACPI: disabled
    [    0.241483] NET: Registered PF_INET protocol family
    [    0.243293] IP idents hash table entries: 8192 (order: 4, 65536 bytes, linear)
    [    0.245817] tcp_listen_portaddr_hash hash table entries: 256 (order: 0, 4096 bytes, linear)
    [    0.248604] Table-perturb hash table entries: 65536 (order: 6, 262144 bytes, linear)
    [    0.251034] TCP established hash table entries: 4096 (order: 3, 32768 bytes, linear)
    [    0.253323] TCP bind hash table entries: 4096 (order: 5, 131072 bytes, linear)
    [    0.255664] TCP: Hash tables configured (established 4096 bind 4096)
    [    0.257584] UDP hash table entries: 256 (order: 1, 8192 bytes, linear)
    [    0.259650] UDP-Lite hash table entries: 256 (order: 1, 8192 bytes, linear)
    [    0.261768] NET: Registered PF_UNIX/PF_LOCAL protocol family
    [    0.263829] RPC: Registered named UNIX socket transport module.
    [    0.265673] RPC: Registered udp transport module.
    [    0.267186] RPC: Registered tcp transport module.
    [    0.268641] RPC: Registered tcp-with-tls transport module.
    [    0.270380] RPC: Registered tcp NFSv4.1 backchannel transport module.
    [    0.272421] PCI: CLS 0 bytes, default 64
    [    0.273680] Unpacking initramfs...
    [    0.278241] kvm [1]: HYP mode not available
    [    0.279783] Initialise system trusted keyrings
    [    0.286209] workingset: timestamp_bits=42 max_order=16 bucket_order=0
    [    0.288474] squashfs: version 4.0 (2009/01/31) Phillip Lougher
    [    0.294313] NFS: Registering the id_resolver key type
    [    0.295881] Key type id_resolver registered
    [    0.297197] Key type id_legacy registered
    [    0.302225] nfs4filelayout_init: NFSv4 File Layout Driver Registering...
    [    0.304407] nfs4flexfilelayout_init: NFSv4 Flexfile Layout Driver Registering...
    [    0.310289] 9p: Installing v9fs 9p2000 file system support
    [    0.320607] NET: Registered PF_ALG protocol family
    [    0.322022] Key type asymmetric registered
    [    0.330205] Asymmetric key parser 'x509' registered
    [    0.331833] Block layer SCSI generic (bsg) driver version 0.4 loaded (major 245)
    [    0.334140] io scheduler mq-deadline registered
    [    0.342201] io scheduler kyber registered
    [    0.343459] io scheduler bfq registered
    [    0.353648] pci-host-generic 10000.pci: assigned reserved memory node restricted_dma_reserved@90000000
    [    0.362220] pci-host-generic 10000.pci: host bridge /pci ranges:
    [    0.364055] pci-host-generic 10000.pci:      MEM 0x0002000000..0x0003ffffff -> 0x0002000000
    [    0.370193] pci-host-generic 10000.pci:      MEM 0x0094800000..0xffffffffff -> 0x0094800000
    [    0.372927] pci-host-generic 10000.pci: Memory resource size exceeds max for 32 bits
    [    0.382221] PCI: OF: PROBE_ONLY enabled
    [    0.383535] pci-host-generic 10000.pci: ECAM at [mem 0x00010000-0x0100ffff] for [bus 00]
    [    0.386134] pci-host-generic 10000.pci: PCI host bridge to bus 0000:00
    [    0.394279] pci_bus 0000:00: root bus resource [bus 00]
    [    0.395912] pci_bus 0000:00: root bus resource [mem 0x02000000-0x03ffffff]
    [    0.397972] pci_bus 0000:00: root bus resource [mem 0x94800000-0xffffffffff]
    [    0.406329] pci 0000:00:00.0: [8086:1237] type 00 class 0x060000
    [    0.409065] pci 0000:00:01.0: [1af4:1043] type 00 class 0x00ff00
    [    0.419597] pci 0000:00:01.0: reg 0x10: [mem 0x02000000-0x02007fff]
    [    0.425686] Freeing initrd memory: 6464K
    [    0.428105] pci 0000:00:01.0: PME# supported from D0 D3hot D3cold
    [    0.430575] pci 0000:00:02.0: [1b36:0011] type 00 class 0xffff00
    [    0.432661] pci 0000:00:02.0: reg 0x10: [mem 0x02008000-0x0200800f]
    [    0.436076] pci 0000:00:00.0: Limiting direct PCI/PCI transfers
    [    0.438471] virtio-pci 0000:00:01.0: assigned reserved memory node restricted_dma_reserved@90000000
    [    0.443123] Serial: 8250/16550 driver, 4 ports, IRQ sharing enabled
    [    0.445534] 2e8.U6_16550A: ttyS0 at MMIO 0x2e8 (irq = 14, base_baud = 115200) is a 16550A
    [    0.448422] 2f8.U6_16550A: ttyS1 at MMIO 0x2f8 (irq = 14, base_baud = 115200) is a 16550A
    [    0.451159] 3e8.U6_16550A: ttyS2 at MMIO 0x3e8 (irq = 15, base_baud = 115200) is a 16550A
    [    0.453983] 3f8.U6_16550A: ttyS3 at MMIO 0x3f8 (irq = 15, base_baud = 115200) is a 16550A
    [    0.456935] msm_serial: driver initialized
    [    0.460508] printk: console [hvc0] enabled
    [    0.461772] printk: bootconsole [uart8250] disabled
    [    0.475305] loop: module loaded
    [    0.475957] megasas: 07.725.01.00-rc1
    [    0.476374] tun: Universal TUN/TAP device driver, 1.6
    [    0.477187] VFIO - User Level meta-driver version: 0.3
    [    0.477691] usbcore: registered new interface driver usb-storage
    [    0.478075] i2c_dev: i2c /dev entries driver
    [    0.478575] sdhci: Secure Digital Host Controller Interface driver
    [    0.479311] sdhci: Copyright(c) Pierre Ossman
    [    0.479612] sdhci-pltfm: SDHCI platform and OF driver helper
    [    0.479932] ledtrig-cpu: registered to indicate activity on CPUs
    [    0.480343] SMCCC: SOC_ID: ARCH_SOC_ID not implemented, skipping ....
    [    0.480864] usbcore: registered new interface driver usbhid
    [    0.481329] usbhid: USB HID core driver
    [    0.482042] NET: Registered PF_PACKET protocol family
    [    0.482342] 9pnet: Installing 9P2000 support
    [    0.482635] Key type dns_resolver registered
    [    0.484383] registered taskstats version 1
    [    0.484775] Loading compiled-in X.509 certificates
    [    0.486896] page_owner is disabled
    [    0.487629] Key type .fscrypt registered
    [    0.487943] Key type fscrypt-provisioning registered
    [    0.488391] clk: Disabling unused clocks
    [    0.488759] ALSA device list:
    [    0.489050]   No soundcards found.
    [    0.490311] Freeing unused kernel memory: 6080K
    [    0.498264] Run /init as init process
    Starting version 250.5+
    bash: cannot set terminal process group (-1): Inappropriate ioctl for device
    bash: no job control in this shell
    bash-5.1#
    Copy to clipboard

#### Launch a VM with two CPUs and default RAM

To launch a guest VM with two CPUs, use the
`--cpus num-cores=2` parameter:

#/usr/bin/crosvm --log-level=debug --no-syslog run --disable-sandbox --hypervisor \
                                              gunyah --protected-vm-without-firmware \
                                              --cpus num-cores=2 \
                                              --serial=type=stdout,hardware=virtio-console,console,stdin,num=1 \
                                              --serial=type=stdout,hardware=serial,earlycon,num=1 \
                                              --initrd /var/gunyah/initrd.img --no-balloon --no-rng \
                                              --params "rw root=/dev/ram earlyprintk=serial panic=0" \
                                              /var/gunyah/Image
    Copy to clipboard

The following code snippet shows the VM logs:

bash-5.1# cat /proc/cpuinfo
    processor       : 0
    BogoMIPS        : 38.40
    Features        : fp asimd evtstrm aes pmull sha1 crc32 atomics cpuid asimdrdm dcpop asimddp
    CPU implementer : 0x00
    CPU architecture: 8
    CPU variant     : 0x0
    CPU part        : 0x048
    CPU revision    : 0
    
    processor       : 1
    BogoMIPS        : 38.40
    Features        : fp asimd evtstrm aes pmull sha1 crc32 atomics cpuid asimdrdm dcpop asimddp
    CPU implementer : 0x00
    CPU architecture: 8
    CPU variant     : 0x0
    CPU part        : 0x048
    CPU revision    : 0
    
    bash-5.1# cat /proc/meminfo
    MemTotal:         161656 kB
    MemFree:          124940 kB
    MemAvailable:     124032 kB
    Buffers:               0 kB
    Cached:            19816 kB
    SwapCached:            0 kB
    Active:               12 kB
    Copy to clipboard

#### Launch a VM with two CPUs and 512 MB RAM

To launch a guest VM with two CPUs and 512 MB RAM, use the
`--cpus num-cores=2 `` and ``--mem size=512` parameters.

#/usr/bin/crosvm --log-level=debug --no-syslog run --disable-sandbox --hypervisor \
                                              gunyah --protected-vm-without-firmware \
                                              --cpus num-cores=2 --mem size=512      \
                                              --serial=type=stdout,hardware=virtio-console,console,stdin,num=1 \
                                              --serial=type=stdout,hardware=serial,earlycon,num=1              \
                                              --initrd /var/gunyah/initrd.img --no-balloon --no-rng            \
                                              --params "rw root=/dev/ram earlyprintk=serial panic=0"           \
                                              /var/gunyah/Image
    Copy to clipboard

The following code snippet shows the VM logs:

bash-5.1# cat /proc/cpuinfo
    processor       : 0
    BogoMIPS        : 38.40
    Features        : fp asimd evtstrm aes pmull sha1 crc32 atomics cpuid asimdrdm dcpop asimddp
    CPU implementer : 0x00
    CPU architecture: 8
    CPU variant     : 0x0
    CPU part        : 0x048
    CPU revision    : 0
    
    processor       : 1
    BogoMIPS        : 38.40
    Features        : fp asimd evtstrm aes pmull sha1 crc32 atomics cpuid asimdrdm dcpop asimddp
    CPU implementer : 0x00
    CPU architecture: 8
    CPU variant     : 0x0
    CPU part        : 0x048
    CPU revision    : 0
    
    bash-5.1# cat /proc/meminfo
    MemTotal:         418304 kB
    MemFree:          378356 kB
    MemAvailable:     376048 kB
    Buffers:               0 kB
    Cached:            20308 kB
    SwapCached:            0 kB
    Active:                0 kB
    Copy to clipboard

#### Launch a VM with block device

To launch the VM, run the following command:

#/usr/bin/crosvm --log-level=debug --no-syslog run --disable-sandbox --hypervisor \
                                              gunyah --protected-vm-without-firmware \
                                              --block disk.img \
                                              --cpus num-cores=2 --mem size=256      \
                                              --serial=type=stdout,hardware=virtio-console,console,stdin,num=1 \
                                              --serial=type=stdout,hardware=serial,earlycon,num=1              \
                                              --initrd /var/gunyah/initrd.img --no-balloon --no-rng            \
                                              --params "rw root=/dev/ram earlyprintk=serial panic=0"           \
                                              /var/gunyah/Image
    Copy to clipboard

- Use the `--block` flag to specify the block device name (in this case,
disk.img).
- This flag creates `/dev/vda, /dev/vdb`, and `/dev/vd*` nodes in the guest VM.

bash-5.1# ls -al /dev/block/
    total 0
    drwxr-xr-x    2 root     root           220 Jan  1 00:00 .
    drwxr-xr-x    9 root     root          2980 Jan  1 00:00 ..
    lrwxrwxrwx    1 root     root             6 Jan  1 00:00 254:0 -> ../vda
    lrwxrwxrwx    1 root     root             8 Jan  1 00:00 7:0 -> ../loop0
    lrwxrwxrwx    1 root     root             8 Jan  1 00:00 7:1 -> ../loop1
    Copy to clipboard

To mount the device in the guest VM, run the following command:
`mount -t ext4 /dev/vda /mount-point`.

bash-5.1# mkdir /data
    bash-5.1# mount -t ext4 /dev/vda /data
    [  112.311376] EXT4-fs (vda): mounted filesystem 4b577765-65ad-4fd8-910c-0eac437d8afb r/w with ordered data mode. Quota mode: none.
    Copy to clipboard

### KVM overview

A kernel-based virtual machine (KVM) is an open-source virtualization module integrated into the Linux kernel.
This integration allows the KVM to act as a hypervisor.
KVM facilitates hardware-assisted virtualization for guest operating systems.

Note

KVM is supported on QCS8275 and QCS9075 SoCs only.

![../_images/kvm-blockdiagram.png](data:image/png;base64,UklGRmo8AABXRUJQVlA4TF08AAAvEoPRAFWPg7aRJCkp/qz7m9sjEBETwM9tH6iyNSv6JGDPPokV2IWrtZxlEwNqA8iY4BYQlH5Bv/i8XpJkqJv3GR9Q1Bf/rF4kAXn+wOHbCipJLmlAvbzEYv+/K0lyGtYRathwYMOGDQsWbNiwYMGGBQsWTFiwYMGCBRsWTKaC8koo723EC5PXvXvf666Q15g1BB375HilXJ9Zg0zIwlqBzC7qNEoQ+0haq7jjoMU654farOBuoHCy5ONnA4FyzCaS9g6GpbyEagEydbQDrSBl9xCoTaDeRIAkvQHR0Ol96JHxM6uoLSQqKJcLKBTyuiR50F6BvOo81puYF6S3IbsMnRiDagEjGCCw3AbqiI1bg/cz2xgkGKcWUDuoE+jKryEPFNm2rUZruD0UJBKJRD4ZGRmJjEQ+idz9dxrJtqwM+7BfeeWVVz5FPfklIRECYRACFkdo/adF23aQSNrXELSBIZYUdouE+cUibf8rS3IuLDhLEFQIFbywlyBY8MILBWsJggkbagkFL+wlCCYcqCUUu6H/z/xPmsqbeWoMk6uIijhISKwjrsxp1APlpQWICd4sGTgheLi8hEQrQt7VXUFFU80mOuKu4G7gyDNbkfFDswGZZOK1gRQqrUJoHBYeg6Z2cRspcge5gjkydwsTpY7xqIaKjVhDoTFHXp3RkXcZV97TQfKOWyjapQ0MlOtxh1Z0REXXFo689Jf3qtlAh1ZwNyDkF+FT3tsqoV6AvBagDWTUDoROrUBuARMnCgk1E+3DLkm5jlyBYmBNOLFtJ4zeMkbiGolEjisycmTlLAmJRCJTh6xEgssyKqFo2xu2+aFg2MIWFrMZGo5NUFCwMEcozBEKCwcNDVXWMENBlTmsRyjsvyzItsK2OWqwRYR0lMkLkgFJ/fUUbdveRtu20Q6MwAiMQAiMsOiqY9+2/ZCddrqj8w+mIYmBEZjRReDEaAiqOhGESmBcRE4mMokNh2ah0tguBgLQw2t0AjKRfS5GYqIqQTgpatrDE4IgmMvF4VfVTGtbDYOMxMEWrJMxIjNCZGVGYIU6RkCWDZBfVqKJJDWU5yAp3wFf4l8F6SIBHPQfFmRbQZtjQ0eC9ujMqxo0j+/PRFiRj4oPYniQCX4SPD4p9nFfhgqZyvgkh2z5oAwLauf2fek+ikkycG4iER5kyrl2krRdA5+C8CDIPPhpVolz1VBBZq6P/1+X/FfyX4lSkL8oKOzDbmyD3GW6BagmbMUFkL9sxkcBagkVYzZC8gabYExFNV0IMwbIXvbAbIBaQstcBPl7HeFeMC0opb7plPx3W/+5qisyEE4zJo5zoOPkeJ1i7Ijdi78VG7sgWzr7aE1jXPIL478uE1VQ/E3ov4w/GEsQyTVWOrlcRcYoeVtofG6RNk4XGUysnF+LX+iO5AMmNIa+LQyUG5z2A/msrQYclrmGPSLjj251+P5xBn8royFoGpy2/iOiejYxN41Lhwjz88EyGSq25CaDvIXis35dSXEEMtjSk1ogk4kqZDWknOaIj+DbwKAvCCM06x+Xzla3PYMJQob+Lpmo2KNgDuxgdZ/5l6RG2wXB6ueyZzLITVay+RDjAoFYPdoQFMS2L3doCD7IQrM4OPcMcrg4fiAPpyxkOMB83+c5LjA5qB4TkaFtjAg6YUHxJkMUYopH7+ls9dEYPJqyC53T+L4OFaB/iaJ0IUPnQJ0ddvGMDP4ffa5FZo+rfEXeADmftdVMA6l7OHYJmqA6k8FnbvG0w7eLF4ESx+EgC89+yB4ZAqcDubdMVLmJn7FCQPEXfg8dudnGDNGGJqqQ2XurAohdIuIgiJ8Di+3SwR7GffAWxgShoto2BrcFDn00K+rTXQSqt27ao1vRUyZiKOC4bsdTGihb7uC/Ijpy+6zT/kKGcHzfHuamPaiIH4jIEHMUYo3j6HHB08QS38cKbDHagNjZQVoV7WAe6+8ScXw0+1m/jvEDdH7PdSTZIuP3SEcS/+h7ioyjueDA0Vyo0B5CVOQzd/hwMvNZf+nbv90N2Q3wLeIk32cVGTvqoFch5tslOqXf1n9K/rut/5RYJY7LMhQbgV/pIkREhJf8iHH0BZEPAkQG8fI14xRygBjige5H5cSEu3xBF6QNO2LIJdgEkcHgCnVxY0NT0LmXcXk9ERANTO3Y3brIYd73UTcgzCRiyJXoCAwGlzSiaMPPFHSi6KLmqyAW6O4a1rcuFw5T33n4SQG5hHhTnRn7gK+HoJMZWY0hmMG2Nfi0bfEzP5FN1cgzJuyRaI9IIJRBkilc3hK5hORu0dtawgZQtpeit6WKUfLfVQBFUWTdx6pTFCFZO5vIdd3Isg9ysiQUIVn7msid6n9m3pJ25G549+kbkxooP9ILTRYduljIriZyzxvb9D6nSNMcG66ivCM8XUUEMLgS0gihZXGiE7WTyTU5fJ5s0xtDOARDEyfAEfFCKERZEdbYLiZyN7yat3XqdDXnwmYm5TcxZt6lAtyMu26MOeO6oTFm6K4lxuQP3xALWnTWINGVdFKXFIyiGoD8YZnIGFvKeoylLS2U7Sl+pt8FH/OP/NTsNOd5Cndd5UOIDd1ZM2QEKEhrJZ0Pz1AFkj1rQOyMgrhHVT9TZ5PQGG8QFw1fTy6ER85BnAHzUBEdOUcFNsQdg6wi112Zvk8Ur0OGU/G8i0KZaJ+nitzJAiTHNK9GaNQUdJKqjggFoOuGh5chlnBkUYHzlAnIA5+pzBrDgfzAilRXNG0uL0OHUEY7AKlBo6k/lkrcX8xRRRzEpN4ni0B01snh3CA21Mn0xv6QbmqwwECpTtFEQtMfJ4/H3k2pkScidbSmyYIZlXWDp6G7dp85wn3mNCAPrHj4DRI9K2k5sEkaYqlJDq+T4MgK+5ljvG4KQHy2GiH2ARnshGWCTsIk2WQRbBVSIyw6iGFNwaAiQ3Fq/KHWGQ2WElgTzJRn8uxmn0yOmcshT1ahFkK0GiGutlC53s6YOFENCtFRVtSIrlvtTqWeoTl1FEVwUo5PXUKaHeqzZw8vw6ylbAIHD++EWZSiOyjcFlMabrBY4NBIbTVCxikTkQGF5vNGSGAQB5UbmlNHeBtryb45UmzfnIVip+L8QWh59KHwvK4YhfnZPGRpEp7e2H+bvl/jP9CA04epMUYLawQV1sybRMzHU5Fa+A2SnMyJMXBQhgX07SFQbt9cqMIy1LWHbGPI0oI04dbOLYyjieGyKeRIjsQchTVCZzrtGTjbJcIRPj0BD0aA5oMecaAC2lZzpv+h35HEf6C41853EfaWUBMhDwlQphj1IR9wkWpNQgJnhHQk11IjBN+Hz6TFokhXU0URI3AVyUd6xEEjQH2uYpbzO7o5evTzYN+U9HDzUfomKKamu+kPtLc0eoZuJEFxWQ0MXaL75i0qZWOfmkCNIVXbaD7miAsfelVDyCZcDi0MUOB2rOQa7iL9rJtWbwNcoyjijuKqIbRGxB23bk59ePc+b9Q3QLrfjjh8PdwSyUxT0jE3MiM1M4t7bb3gnvmuZkgToDU5jIehWkxCa91pisMwJosx9kmxZzOZGhrcLs+9ymcCp0T1Nkjt3FRLr6sJ2PHqMNib60NzPrYfagc2S/QS+k11pxK7gGuWiETDIWbVSaN6u+v7oV6XRMjMaPD6BiLzGaKfiXQStAGYuik56+ktobYT/FFZNUA1lK0xor79PBMjo7VvH9E3UW/DumczJnB6diDDOoJuygVcf/VLQhC6aNFuoZ0bm8kXGs/37r3We51Lw2aZQnp+qqFJXE3tySIsi3d0QOVm2wU4I5vC4Gq8cn9/6Ow1Pgofagc2I8DvuhP0M5GQDLHgxmQYPACDNI1jHb7XrtdNWfJuBxPTO+bYMkm1RA8hBm1hseQCBq4ZtEUzu/DXx05vCfWLIkMsyJgMHKKhMQSiw7UfYhkREr/QP9Gr9ys8O6ToXVEtC/rhw7AebknAlfpDBvgYGD/kZbOBozUibMmPHY8Z3cqNycCsxgxYRwefpIFj2mFlx6IheucSER9uKJxcF7EPCSqnRu989AQIOsSChB4JMAaiU8BM2j84vR/H0kpPvBqtibxcaFZhyfGB80ftQsENsSgYeoDXO5bqFkl7O6dWHEzQBmJc41VgLPaKKFoTdqJoTMYyqbcUQg4eYqEFWwVdCrMiTwaxBtMWB28ADf12TEUmfuhqJOwc3S1iWD+1I4vRIRZ6TCDy8GMURhSmkGxAQsCjsdkWEcdUZCyAxrntpZBzZJwArJxhLVMn0pmiI0nBlxDD+Y6v/FhTtpPnBagEjJmRsGA4/y1XlvPD/vgISb4EiHyGw08b/1uuLOOfqo+AjnFHYqKe8k89zO4qFIvv8HQF/AqaQ8NKalAJziOrfu8fmXi3T5EDOOZVtwGwDL/SW0xYiVEK9JCq2vmOWSL6dg73bkI8IuFTrWZ0Pjp3o/cmZqqNNgbYbdnou9dgT29nXNzLiNgr8EOqCbv9HB7krjsf57lXlqFbcPdwGyJ4b4Rn7GL/J3Cjv5ha/Z6tgveQqr0latf4OM+9MqdLz4/5oeVG4HdPxxPh+36B5WxDvIdU+amkAvBzrwwYXl27zUDvTpzYvxHLcfH9Z2Dff+EzIYWVG6cpChypQa4pSG9Kwd3EwpAxHOgag4wFe3uLtNW4OZN6X+UbrGtvEDhtAj/3mqVatsIt+d7MFb7g3wQ3/woVlX9dYDlFUUZqdFNyIVn2JhaGjuFYTFkLmiA6SW+pk/RXqa7dkcC0ASzzRIV/S2Z4g2Z83/cLLVcIHnP7FvZy48SCPYYDOAsdoSH5RNfGyKZIykNXJwA/91qkejv48KYMFgk6CXsXiwBDb2KhG8PBWVgG69oZeA+pZjhdzsfTJaBwn3vtc4tth8c+Ft4UidIkxhijG8NBLApM7JH2kLqTA4defKNq56nWNdcfsjXQmxcoGoWO1LCSTeOKjuFYjVkLEpVaiK6twdXtKPfaKWPjTiSSsdzGjSS+/9iiULxi5KYU7E0s6BiOVkNCzoLe3kIH0a2+UaGD0m/LJvyBVZHvU8uaXHNanyuQz5b72VRfGnVEu87eRECd6HRphB0deJO51sDpfBO6YM4v+DZa/4s67c7c3SFwyoz+5JTyB7fEeCQAQ+4mAipl3EunS92JMnxx7hezifMRTLJoOh+1K/SOpSWOPAsB0A7Ln97OmN5OwOumzE0EFAr1jsM3LcOTF1624cSDYYchVV9+9wGHZmcIHFNueJ2Edcy9NWA5h7uJgEqZ6g6fYoIw2+fYr31iOj9EZtGYfu0GrWvQX3qZLKkR0mEW3MAL2n2KSFoyQs3kZHRGMIiNut5/b2fMuI/G60Szah+5mwiIS77zR8mDNc2ntJBy4tKZMSZzWPs1z3QYdgMUUq2Ggx5PggyzYAdeaNEakXyii+qLtgP2bFv9krs3HPxDCKEmZG4iIC7QQ+PNGCAJrD0GlvPshtOkT7Tvnaq3oQDt3OwIXjcl3wrp+QHbpVYLa8TCnFa0GpMArc5hWxYa0vMxgMjnbiIgssEV8JqLJUKTI1fYxUpqUIBq6XeFTsKAh1mUAG50hiehAdifLeimSEGdtnA3ERAZPcytZUE7N9mZTLXGfZrXDtNf1CXGmNIkaFIRsZhuG7TQMq3GOKizNxGghZcqt5aIAQWWBO2ztO830KMzkA+x19XYzWrwYME3tmCwZIRHelN9fAoUss/0szpTGZKbCIiNHubUMvHwFVZ0upxv3XOSyHG63P/x3tGnW3XHy+5QdYt8wjX+5NuFhgyzYME3tqBYM2o1JMSjM8h9XuqqmHwcSILUW0vFbLYc/IQtm6mW1tiLT9KSARhed2gxEzjMVspl8jqJhNBDsyQdn4d4X50D1YFTdoQ3NNoPOHRBf8ju9JqXG+3QCBrYTpqpmY5o8ZPbwunhatA190grtXPdSHaH7q0qAuTmX4O4OM3oB5MKDQbb5XOPRuxmQ2NDVfwKRQxkY71Z701AwMdWuRba0i3nU/r9mX1TOvYUqxGfMRcINtZ+q4ohVnCf1NZzXsAduJ8a4n6lM6yJC048Orqkcf8B+EvLjBhY9xOHo+ggxPs9jadJFvZJodU7UFvppJW5CQgL4tujzVXM48FPHgysfPb3yMOgUN/mQ7OysHIxTm1HX+vWqAnLsuwHIhTtEtHpQWaMU0ys/vHouapE70JaG66nvZbO5MOga0uw4nJHdBxW5AbRo1VI86/Kc6Nypa89f5aJXizDMqCfyd3Z/i2kO7wnuGv8G/6InudGDxM6i9ORhtJ4426k62Y97Z3JndZTlk7CMgB1XxGGViOErivQTv8dP/02uoPTkQ60vHFloTKdu1PKU/pzb2SCh/qqMJDu8GR4X5ApWWl5p81bvEtgQYBuNcBAu8P3lsT8UrBpoVe45CyBzQFj9MvvDzRV0vx13iWw8zDpEY+yydOsIX7lj4JLzfWC9HfnvN7YmA3uasn0lUefbpFinuPjA0vxSiG6OfdGdhhT4E34ksBSUuvrIpbABubygnYsB/6qgPUKLDNMgLrG27H0TuWlDyxknyGW7hhjy6JHutASwgDJSkvnXUJIoNzT+ZfAhiKNS3/V498fXFo6oPMuISTQXNf5lhAWwIrOswTmeOLg0Rnov7GQdyP/fQWsIl75vvOtwpL1ae1dAnu8QUxHZ/Sz0JD/vgJVES00K5XUrFQqlRgqLK3onCWw5mbyX1dg/kcLqzE/YEO49NB4UlbjwfSC9i6BOZ2c1LqhozPYnulURbx3Uq+98B//fm1dQuiR9iyBPWFvJ3NpchaqIl56mFP7ju6OQy7Vx3a7gjsNwmgmZwkMTtJJyOgMHqJCHbfVjP+wmJg8q85hnvVBE1ixOZXOvZFRrUYdj87QLEFUBEwPPbX/sJgaf3vlE5LZ+uai2HGaZx0undzvqbTyzKkucRXesjDMuwSpOZAkzdS+xCIhmkXTy/ciMQm1AJawHneO3QwrR/QwU/sSC6LJyLMOxjD5/8pQ7DPDYazogZukM7R+qhCJp5f3yFmHLOtf4dq06XQ6pyqVynSzOUMJkMS85I20VhcJAhaV9Oabb/7uNE0X1tdrxgwpQPzQ7eVl9XPFlnt2ygEQqEgrOl9mRjeTh8HGOhJgjt69jCDF4pLOd8LP7NEspCG+LloTYKILzX0MVCz0dIFC3hujtTsFmLXo3ssIUHRu1jmlN2rBEuebH6iUvC0OUoxmdE452YKloV4pOR2oDObOaG9XGqM3woYFjLdUaoANC2CYpdNsT8bBM7pndNOLC7AsiXRT8cIlKo5bRDdgZ3Gmpr9Cl8uwLIlc3RQVLVrcqChubkQ3YGPRXNe6swjLksgNDZ6GKynMFSlqIndWCRbBbd+ckotctDf2FTeXW+vHYFlzZEMsTC6G3xI5ikMeUUQ8aHQRQ83xHuNLiCKUEHHGVSMb7OgtnKzAsgjFFyVitxS5WMJF1Qx1chGMoe54j/EFNEaRy7nqZAMBtQqBbLZc6rNVFLMyneHNsGwCATrjrhtj5t0IWa3Bcx4N3fAM+JxxiQeUO3LOJYZrydulxsyDDDkyQ+77cuR9cysPvr2Z5thw7akSHbqouqKuLjJaJru1JgrIGw/6kSmtCgmbvJ6w2bMYB7LfJGR1wOCuq4BZS9Q/9KVEZs1w9vCyeyoeUg8kyBiuJWoD60aprav8CO2MEpg1ivTIOdihU/EZF+0is1dgxOxGtCYGaPbzZs70+gxkQZpYEMmLnvBnxX+TkNWHKSvpPFQkEFRkTeQAbW16n3MaD8bwDZJ5113Dyw2ZCI7cEJhHkihIlQS3V2BEd0MUA4wMkzkmMSis8Z/9zbiexE+OzdmGBHTmgYMK1ViHlyFUYHb9yDnsQWAMH5oMkSgDCbFZYIghe8TtFTE6vFxBsrFi1jv5MsysBQOpjc5IJFv0mY15GMwaHJs4qE7FSAGCK5x3qQeCMbTCugXc8Azaw1n2o2ZmNwQyaLH3cPbVI8HYf5j5fIosqKZQmaw8+LMePOdG1INN1LJFSZTKf/KuLoLZrTVxKDAbI5uORMIey2U+EwJFYn42EiMYtCZkcip+CPi5rssIEkMOffY6z0o6BR1ephFIYHYrIJGdhDOaYrjKIK189DPbeZd64NN1xvAvtFyFllXFWCI3NGolyEhTv6HlAk8RarGgn+LOGmMgVFDpiPFwQ6Y95PCyNuHaQ3jIZ7x0rxgZYzzF1yjXbOSYDAnwjdt6GUUeP8c6RWzTN1Wgh3nYV6uE949th9ftoq9RokksdR1nBJQDL8A4RK67Pu/yTkw5KsIsp/FlbJAT31tLs4tBoWL3El9L4LCurIcuBXyzlSo4XLfcvwKTSQSCHJ/ZnvjOd76Dk9l8VKAySSjKFiwmGvbgImGZC5gqJc+NfUe+biPlbrafJTKbf/VrcQ+sIDB4LSNDDdWYxCLeosXY+9HRifAdj/Wvx1zvP7Z2IP9NgFkdJ6z/uPRG/FpLzOS9Ne7/bYLLkVfFsOLAXHW9XxUvQqe/beEFsL7k0hvhtbYg/4jwYq1IsFWV+6uQXlpCuyPc34m+5dIbt6FXLHZEkHIMJidRFaCW66/fhh5nxTRFkLmWgPjVKkCXWm754jtLZwyQl4ggoxbEc+dbfN8agOQ9jO4HTXY9PMRd/vfRXwBBE88k+99XvbEAkuVYcFlOIDjjJ3Uus/dFFzIBoDAfZT96o20iHJy793MFl3v/agyRQXdsl8/LbNy+KQn+7Gd3ee5TsPi3f5vsfA8pcr7zyRvI5zH5+0+cgDca8KqjQvzQfFyAZ+K6Plk58PdPeMITnk5ovr+2Wk6B3jwtmg8Gq2I8tOr0AAGFl27xfs4/LeOlz5n0fC9axgUUK+WentvTcNvI9Yr9J/DLb+eB5JwoD8C9O0EgwQIAaM1HsvG8z7J8b4Eekx5E8L6oaM+GC/J8FJ4rSluqGAEVvK7tDMC77Q489rG3roOl5/Ow/YksPZ9HZLtj/Wb1WJ7cArX2orckIk4JIf9bif44mvQzkW4642L1ZvVryRmX3iXMtfwsQ2RNNQn9LIRvOcUKugIIHE9CY7xBXA0QRcV5liF6O8gahFbDIVFWYlrX5A0NdKwSdJLqAHhaG/IwQw+1/CxDLn2YoeodIptXb0m6KZjcUcThNJ54u27qichkESUyiKmOJ0qCozceNY/hHeivxtUAeAPkYYYm9WP1WYbYhxmacZHkS7gihevuCl4nYeqpENUt/cwxXjflNELTWwrhUAyCjuj0dsagzODVsQUoVgmsH16mDzNk8VmGIvZhhmZaVC2NHImpEYgU42s6DNol2iI40FSEofpFOfAaKMZ2IogOiTiGdlidMERYfJahiH2YoZk8SW0/RgAG7tBAy0RkgL4H8BoGJAaYTISsWkKG3rGU2YEqYoZi9VmGuIcZmqmRTR5I5hCa0JpAXSOwPYDlZdCfhK17jDEUjcZqzCZMxdZNKV7dtKqQRShWn2XoKu5hhmbmGU0R0bdzxPlYLd8TYyAm3/urTOtLD/0CKEFkPnP5McZAxQUmh6/bwDP2PT/7b6C/IAeKDuJWI4TvUVgNFHTtQQyrIzpKgScIjak+VsSgfZYhTgAVGs7QpFeTBPZUHH7y0C+o/FdL3/+NDyGDD0p+5NCzfr00ljh0rtUl0W3gGXvCE+gzrYaI1I0x6JMsJmE1kNpbNMJWQ0Ksoy3WuiZG3lVFE+G8y2HtWYbW8lzMkE87XXprcPgV6aV2blCgWkCp7qq3AXSgPrOrIgC/O7H/74symrNK70jCYfFZhvJezJAP4+hq529OdbUYDV6rQAjChYvNTuk3kUleAr07ofifC/f/2xU+Kbcfyp2PWihXTXc3tNRQHll7lqF8a3Gnn6uWYgROjcaI+o8kOG6LZ+HrGdkuJPz0/v3v+/M+V+4KS+Wq8U7pWIFbLu9K5axGnmOrJGXAle28xcL4Pz97YfFmap6hS/7+cAGgnX3cCxGoKThu/4HIJPCmWIvUPPj8bH0Gjjm7iMcL/egFJi9PyCwIvakJ8fPPQ6Q1zkcX7v2I1AJ6QQb7gGub/SHozc9vq/QXU0sqVdqYb1//1NzW5AmQ0dVVydoxdiBJqUOtv5hqpaxi0d+OuwzC9h7IqAs01AI3c9+9EdJWcs0IDNQ2zrSMI4t+JoPYUI1/WPx8kdAQWwxRoYKgnbexpGRtT7KQDshAPQ09QVgZgaFMdGMx0FiNbsokWV1pEFssh1UYQaz9thU4uU69rcaGjMAg8YfQjcDggo89QiO2DKsxb0v2iRfE2v2Ki8U9onQcVhKh6MEjMDRYGIEBIaYbi+Gh+ozR0NqSfeIFsXblBcn9RelHE8gkEh3WEjJ53VRZEAOridaWoBf0unm3CpzElzTE2PvRxjqWywEZgUGz4cAq6Ka6ERiwJmXAsBrTbKKh4HeCg2aDHLAaV1osqm+LBJi3TQSsVCJDLdAGvut2Kkfk4cdSoxuB0WpIyIzFQBa4GNW4eTFld4Kv+TTF4lZDwkqLxWCc50R3gTe/+irPuKx+HtJqhNVDRxLhXuBN0MZaEV6UQZBF2NfuIbeMMbeWQasRFtjL0LSFv0AU0mAcKznXRfcPcOguIsh0IVlMKz2Ho21K6DCIjsLKOyv11QzB/aPVKkTucPRcaYQb88hV+ykvyF7Bv097nqOL+CvybplIyBqDBumzjh1JJ/WKi8XGOnruAOLO/aPoBKwkXvQQ6fJBrtpPUN3Sl0LS1Zz0PKcX8ccJa8wnxJEYV170hWa0eu7ElRRyxvmw342iw7Bi8dg6l7lgUumhEdTbGZP+5dxMu27JqLeTwBqzaLukV1ws3KV1xHTGmE3EdB59HJZrRd2+aufwEHd5oRe5wn9sOeB1EtIFV0cwWYR0NWeM+pkITVhjNlt37f8KjEXM9iWi3YLJXFoy3KbrXqNhBcMi4fEyG+H7ZZRYoO3oQ2w1tphYguxABcaC7Vxr+owfVyIcFjxejCn8QMsoWwecuYSk5tFcxL+w7NVYe+3/Sgk/LQU4eFal4JJ9y6gYQVuMGPEX8ceVD2tMaTWYoeOkk3pVjhRc2HVl60hSnTOTPP57uCA1JlMFwVirPVWYIDXGUwVofB/h+2UHY3VOFZTx//GGG95H7nLDDTf4lSvJxBgAAhxY7YReiJiSqjLI9xHhts5uwdPz+BVsRTbLCmRBJMSqUBAvdDorcuDaa39pm/93AHOJjQODf1u98dJt/4W+Vh/0s0Kv3E8uqWbo6AwyjANrfA3l80VCKkbMsBiCDNYguzPzo4d5/gGnIrxcUoWALrNZ0JX7DXPpfjo6gwzjwMaDWH+5/kFsiBkWU9DBGnQfZvxFkOapt/kX/Fp1gCKjt1TAlftRxOkOwEhfQmyMEzJ+gxzCUQ0iZuE6/mbmRw9z6orwckk1QtBJCr1yP3/p/owfrBFwsNZsr8QAww3WIPtQBawIaU5dAV7gtWpJCr1yPx7uqn/UIc8CWAxhJWF3pwpAD8v5FWRz4JIiDnvw3YcLunK/IQokiNo0odk8WIyiy8Yyq/HMBtFv5Nx4adkOwcGJ6x4dEczLF83v6OWVg7/OBp9XFXLlfubTKTo6g1RiyPjhmoSIGWJGxJjBGjNfMVQf9hpiuec8qHiG99eER3DTxvphMRjM4P6P+nn46+chvZ1xVdiRBMdPX/caBvM/pw/GIPpW8PbMGJvvAqunY/glegxVDYLX3DsGm9kpriPqyB3M/rTwP/f3TyZAx1DVC6T3C6w+Ib97Ewg6eBe7XvMarinaEbi46XfZ3QjO3Tuw9ZrXsOuug1db119Mb22A3pLgrlatRkjuckGHY7CjOWx1yPCNhzVC0x9HpzcMc5cLh16Alo7AqE1g+mdZ6Kdl3dD3fQlCoy2om8BhLDTPObQUVgUzRLcCi45+WeIfbYxx+XUfC0xU0e2AZUP/eGerA5MBWUDva3HwYdfEnMViSiEjMGZ+6G0FoLYlN5HBab88k12ypbNPNlA4MlGlcIAZSMQApkn1fziYMBY8MHnddMZPqG0FyGxwGuWXJTftUX8HSISRSpDp706XI1y0etovDGC61pEFdKCFJw5nQSGjOaoC6G4FDsTARJUyBO21qiPhZwC7FoioKmhhdYuPTMTxlcwQLUfr0OCxBZEdM0Ya0IEWvWMpZ0HgR3PM+NDcChayIZh91q/7lsndaotYg0ljdgrVfX4wOA0/hYVMhlBlWgA8rOMZy8qbAORTc5pbwSM875S+fVJgPC/LYtaAhKMNUueQvwm+v5DBBoLODj3gYpnLZc0Ul8ADxa3AswzPfExCtR76o4D+Mmj+QljgaMOxzBZZLlINNthAeCvgCewd+gFAJUgrQ8tADWmV12CmXMwdwAYcCG8Fxd1h6WGdzvHOVh+omlzIhgWjHJ0CFsmOFPHTCToQ3gqKnoTJA0lgN+8Gu6s9alQhByL+QsazsPolBa1ophy0oLUVML8gvFtPReEFny1AxC1k0PwiQ+XQ2XG0ISxq76XAJkIdsKC1FTD3EWGR6xOIA/vHfAKd5SYykSH6CyGypYOfAZWCO5IEK2htBTmrx+qBJPqTHR8m/EGD7zMePiNHVCb3vAYsKG0F7B1uSGb1FrJhoT/jAAkDW0GY57FQEdYe4Eo0m3P+zAIQxLf5qnnwVxVP0o43KzkdxK2vj1ZiX5W/RcqvP0o9qdzsTUvnpJ+9H9BrrutC+QpP9MzoDGyA7yvyJ09pwgb5ii/BPT3SRZdwgW6NpmElixBaf/AumaVbJ2+G9SFH7hCDExtrMNp8xKerUqm44kdOvI1dh4+D6Er+bgwmU33uTbDy+Km50UUVP2Lx3J8Ho9GPqoLsvuzRtz+XwayuPgxWYtW+G9an6Efdcf+fZzAPO3z7OEG4/XAstr4KWHml1yuwPsUiPvI/TF6m9fEB+WeD1etilkyFi2+xDF+mtRAimUYzulARHDFFbenOMdiQgS4vwoYDTjZ13hIS6Nys85WQgV4sw4YMdLoAKzoz5mRgZqGnc4roWAxNE7IXPTSxFFkcg/YWAVo0KxXZy5w5BStJdGUdVoTeuG7kLye1NFmqwYqQBXo+vDtJGWtGL4aVIgf+KlvEyFqu3u3HEEKmTcrecWBypHIyU4SHx20+XYIQWl9j8MqBhW7Y4SejTJEP0MO5GEK4iGVjUolwps9RYGVEasySCNSMyVaywIKnWAkBPTQmU4mgzlbygKunX0qkxoigQs0Yb6VU/K32VPzX3ioYlBojgir74U/Z1CqVilrxtVoMFdAziwBsIKjf75m5fr//Ru7/2CPzMwoE7wAtM/Kc8yM8YK1Hpvkl/5X8V/Jf6S+COFlOiADT4julmu/7gO/7ttnFcjAjvBNv+pdce+21Imq5S/yaF8x0Ousm27GI5v1WFt7pmf0DgqYDNXFSM56UYYVQpbDishuzuyZm2ov/9yEoC+8c/v4B/FoTL4Jabi2CKoX4fmftrpGZzq35r8TXH9gBeK2VV1Tz1iKoUojvd9bumpnpbC2E9p/SEN7vLPVa5QOOUitDDIkhvOzeXcKnk5RDwPSxjlHEvPtCRUMG4Y2LRimz0oMMOmWGaTNO1DBXTi8Y04P0wbQZnklUMn9l5t4I6bNoKolapmam5U/NnFFMx0xF/hgDxVSRQ0nJf1df1FuSEJM/LOumt97Ado4ZZfHkSXGRyZmmN4iPJ920n0loPBnEVTN42a7hIYnM7qcfNGECmuospi3dj26IY6plPirGNuuSmaeyoJP3tdWWbsqC4rObVs1062clM/V9l3QxAajDeIrQVM08Sz69m029JfVaNfPq+lnp1GVTICKOjcv/sqPVkHqSP0YDUAVfUJW018GTo8O0kQ4JStOWTrIdgNYfixzMSSgCsoBj38L04Ya39R/JI4nWZAaFFBw/k9jGRhQQKWHR+ih9VFrTFA82l7qTmZwu/7pEDwpTgBXaNNXSa9ONyJupehtU1qIpGqun+LvjuQQG6Oox7rV9YCOSOL8Y/i5fP+umNS+aDoNULXuhyb8v/7CjiqovvxNJqkF41cpNgGNGWnhQK2eBlymkWQin02W/9rJDy9+Yqe4AjfEwmBtdzbWdvy0RfTtHYLyxWS9NEXDSpzH9CmLBK9FyjCXsREtrvzLrXsAYTbIS+LZzEh6j7jTi5Q+b2auxox1uhjgx47lzOTIZ5BaDySBHZN28D2bsNxGqibl7HIQTY4n2vbNr8gTHGGAhppGOVO3ci9s1hmN2uvTYFpRECl3mgHS4dXD3w86T6NhvRqgGJg5/pz9kMQahk7Brj9TAozEeQfQCCQszULR2DmTGx7l2BtleoG7OxEF1zz/TkRr1JM/Kjf1mhGpfDgOtH2LM3oLD1LhP80KcqDr89qF2kJ29mVAR2IyolmcXQSMwPMFTiM9quM7pjFCNXCx6Z+17Ae37DfTXoGzRk2Z9g0oeRWCzZ7tAYabGsHIMYp6gpiatBxee7OCCnC7fU5t8NYfXn3VXGHN4vqs7ny/d1AR0tJ4eRqhG5pTawJoewfmIaI3UrsBi9gkxOl2zSJ7Z871Yq4FO2uXJZio06aZ6GKHaGAsr+BntqhyZonGZ6o6bo1Mek3XMnvH+EAgyppgeTbFaubuhYyHJb8dvsE5BPafe7TUn37MiZdpSN62cVNQeYgEqVIPA7Qt73G9txzwr91axndqf7d4kVc7dgcvxG7unsv1B4mm+X/zn6t+wbbEunXY/VD/JP8qnr1JAr35WXTKzc5gooOSjortj95A85n2HXhZKXAdUyX8l/5WggfGTdx+Sx/ze3tNPCiU0cSubl7G8ffXRKmhsVza/9F3/aqifiYmEni3nq9TPMyXUtern2pL/ylaKjPFvi7ZPPZKDgimEi8hsoiepvEIr6TfVYnPb2ghNzZNsLY1B0Bm8jYptZ4HRDhUY2YqjXGJxPjq120PVsnuUbAUPksNBRcagDB4iJxJ0DDPne56vq0kmPpKYjJrcgZn6ut428t5wjLN/QCUS4hmNEUEHCLVzRDQ2micYmAp52HLno8gwM7ZS9zSwsbD6tqCNOR6+Mt9nE0bccQ5FBA2AaIQt93S9bQTTw2D/DFDU2VPOXiqf0AgDYeyFrwYG7zTBgAEb9gBBxzAztlIeEBdaVcthMAEe9xZDm2b6NBouR7SngZnCBji6vI3OIDcTLMp7ytkrKo2qCTpfmiyoaE10gta+DhkPx/CPImMrfRtQolrQho4qK5OELW6rxR0zHZyo4cxEL0/X2Rs4oFOIYhZ1nHivlEaLNQQM6I+DKrnUnSQ43IznI3oQjuH3zBABnQsP2haQpBiegMxZF0iASnZgpoany3uDd03CEXWceC9dS6diCo5Nszpd4GLEYmLtxR6AY1iIMaL+Y3YZXeA4Z8t5QGS9DgYN3ZT8GWdv0IBOfVHP6XQpmapzBf+Tl4QjkX379W2Q4+EWUpuHJZ6u6GHgmoUKiQd0WqSQ5Oyl0olUjyFHLxCioWWyBzQhwyxOBGkKwgu4MVN9Phav5pj2dHlv8IBO/WrHydlL5dRicAFO//ix3RgUMeKwcQx/y0Pto3cAx8xiFqmFFjtd9rBNK35m5ug6e4MGdGrKLOo4OXuppOoP4U9xpwiLH7zu8Dy0Ov0hdZcpvF6MYT0MDoX6Q5rN+kOqZV+oPwRP36JJ+P0h7MR7qRS63ZAE3L7nvEzin0ffyVnOFclsQ1Yp04GeNcr5FN0CZ7e4sp5xzq0suyldGns9nzell2Sonc/HHxagM6IfJJ7m+8V/fi4a6YwKuvGQfObGq6T1tz31QRfymakQ4uFQYraS/0reyXzL7AZqG7tIYsMyGK0B014b5JAAoQ1d4Lv22bAU5nyUvYepWjYotgEXZTFXTujFZ24QVXwyV+gr9h1IxMnwRXYZVX8wIfYq7dxUC+ZsyaeozyViWUEF8dO3VG9fwxLeOSnzULWXwKijhPL2a0KpugqlqAefaunddPTZtPLVghlRnbTyTi55M/ISytuq2Xsnw3w2Rb2f1NFJRw8USCsPNpRW3sslb0bONtiqxTCOsF2hFPXF0tHnEgaTNRjZPFzXQNiSUetLbdVsvFJnCqaob18HPx29x1gASivv5ZJPirANtmv29epSKEW9m2jYZjYqKK288+kXyHjbcMiuJZ+i3qv209Fn0sp7UFp5jkDE2wbblms2Rb2bID6Tjv7qp5V3rdfYC42y46D4Zfs2yaeo9/tDnHT02f4QH/qMl3PJg4yzDbZpd0PfoFCK+oJd4L5u/o5FcMpoOxJ2Vad0wXdRb1ch+C7q7dxE+kHiab5f/EepfZWE+kkF7CNPQn3QRP0ke57WZbPsGiYKCC+qy2VeBBWUJMmj/18ikyRJEjp0QV/yX8l/V1syNLFi+isZ1DF9xXTALMmf1CyopTfOmab8aQ1NRSlLx3RgZY/FkjEn04oq5tSKWWlJIIvpOaOSWdCwEsgi7lf8MAfmKn6Y3gxgpZCFP6ZspuGDyY75FCkNZoyp+eNPNFBRNiZThQowYzJqIYOyMZ4qRIAZ41ELFZSNyalCBP1+v2aW+v0zCBMeBjqmDyBUWJD1sLbkv5L/Sv4r+S/chBDiZDmIFzqdFVPrdHoIEQap8WSowwR66JEiTJgEqbcOF+ihpw4XFoQ0W4cN9DBbByjgj0mHOkjpXBjxoOp8MD+6JZwPJg9VB4AUQtUpZRpT8CU8lsEnRaKI8ZerzsWQPoidQ6KSmXINCTSRbpCoZdqZSvq0HRTTwA3kj3NJyX/7G9RbkhDwpJtagArdBiRazy0iL5n0lgb/kXX/2ZhXyOS7Xku6k9zFMSYAsX42iImcIXYgN/hAG5u2wFRXLiKdxASCpu7nK4lWQyQ0njIgcmAsjIZjN4MnRW8JKhvpTt+PJaknrwlK9aTVAA9wEnFMW+pULu0huz5kquVSuxpjWlPEJC6I0BgUYLjaakvoyUVZ50lKCMthQtDCU2hXz6CzE8QgJuvHRQOpt+UtGt33yIgcAtkFdjeeDHIrXelJ50kIdA6PhfrZRV8yiNvyVKkbKpdQOomtXSyQ70pbk3Kn4OyHq+wUynQSD1VCWI6hn8mTzap0U/s60cwwxVIT4I+2QMETzYwhxWzrFaH2j59YGnwEhrSH4HYQCY0qXjeGysWEVk4qtIdsl+huWPKfZLgmHlDPcuAs3kdHP402j6fJRZdyEGhAw83Sj3NtDl/HDepxgwBD1c1+4PeJfjIjMWeqbtZRz6yrBheyhYWbm+dL7GbPz1LP+Vk3FXSpclez8Vy1A2UNVjT2/w19TLSdgSZuTAgVNEfnp6fIGHlqpNGsOEFdSjZg+0Ba0Zrk8Iwup77O3gnlz4pSE9WleANNO4XJvC2jfS6adLlR/n1vzL7ZWOls+tZNjYWpObrMHUPzg+Bndt+NU/KLRk1bh1m3OZmIbGo8mvr0sZjP9/dYhMj9RqP828cU5xvj5V77+/YqTsKvN+9I7U4B2dTYjqG4cvZOKvLu99rfJ3tHl8telnvdSXF5JYDk7nTjhPpR2T/MZqdFv9av/X2wgZMXPxsFrwO+wT9iu1PFO598ZzsI79uyJtoADrxKxGR3pwWAg/2D920Z3gCmEs1MenfKAx62UcJS5EWMMcWtwdN7FTLp3amGy9z72U3Z8FsMIvB7zq+Id5PYnRYFalN7qBj8Er/290GDoMAv9MXPdpmrBNgmQhENioWWvp+N1B7yfZsXfZ/I3hHUVyLnG12HFqsUHUlI7U4pr32vjThgA7Wao99l3BGDaWioIN0NSe1OCSo6BbCB+lYxx0HEgzUYCgCp3SkBNGwaiv7PiuqrS+R2p7gqbeIq1QbivPd1LCrkdqekKkVVqi2E53UsLJPanQb33/me1O40uDeZ3Wno4Pz58/tNJraX9SBQNp/BQhcRDc462GoHXSfxTxpu1tHOLHc9vSQDN8vALftkBReSqqPf3RyH/c01nGOhX7/GNQGGJOmKt1dStBts9P6qhKQiywz0ER5KXJVByX8l/5X8t78j7H7/ucvTdZFPET33AKi3MSbbxinq3yCHWph3LGRA7AVbZaGJjZiU5YZjIO1lji733FWhEKrOVakPsqtO6NGGa1Bv43yb2Ha/7Fx7nvrT2XaO0G3ARBsbrgFlMOXaYOMS4GMi5tk4CXPsHAidNG3Axl8TGmSedcfGlZpXXVUZVF2csLF9zBPaPJCwkHkyzxRYOVFs24HUk86Ca5xTBg3Hxukju65K5sXWYOZfeMhsHtWEn81+4KaY2exVgXMJP+DaXJnnyLyLS/67qoqfEjSFit5SiEAKTskh3EbqyDaRPrJtVDedxBjTz+rIppwg0UaWEGgiUwi0UR0ZbxCXG5NtI2sm2UTmTLKNiqnVqKOjjX4mIiEmEKeU0GgjTRSaSBWFNioaugFFPwuN8SQEAglNKaHRRpooNJEqCm1UOUE3VXjdFFkoPAlNSaHQRqrIN5Eu8m1UQL2lbop5qjimtJBvI13Em0gZ8TYqEALvNkyrQQ7AB/8wlkpcWsi3kS7iTaSMeBsVCIG/k2KVQQwH4O1OUlIotJEq8k2ki3wbVY43iCmwAaCflXYR8m2kOwnxJlKehHwbFU4/cwyAPtP38J9W0+6mpWwipNFGmh8RUmgi1Y8IKbRReZA4CsITkUFsEL2leik7ktBoI80DSSg0keqBJBTaGEocbljy3/7ghRJnLFfLfi2mmO3XguIzBdfgaPOIXVUx+7WYcg2f6v2oHeT0fpRUnatSD+E+8qin7Ui9Peo616beRsJ95FWpp+Ea11ylqSfVJEm69EP0nXqXp0uFh2DbGEpclUHJf8GoKRnUdggfBvNuoJjaLpY/sXNQzLoBK3ssqs4NusqY5apzsT/h8KaUaWSKBLKIB1V1zACwUshCIZMd8ynBTkr+K/mvNC/lxOGXl1SFIL7EBjG0Hhi/3POSs1zbhZpAXOXuu/8DFPVzvPfqhiZfuQXla638ymDidmxz22qds/zAk78OKgKxc7OcxbkBirCxjqI1vuK6X63/nUH3yfX6Wc5Sr2/bogsV0Xaz5zlLZqQw3JUZu5OvqDdvVthjty3Wz/KXrUu8SElkC3c3F6OgO6JM4e3mvk1hO0fwWM7WDwUGpgo7yKVPKmxsl0+P3o+uZrOJy1kS2laI2ImKsE42HM3RaNTE5SwJbRtELjtFWAQ5UoUCAriMEEylAc3Ra49FzQ8akXI6oavHNN9p1NwWiNw1/OT5++bWpvex7EZKBG0AO608eE7vywZp2aB2jqg7lRKgaYhbvgnNIaui9JvMVF4JCj7XRUQ4yiIQYKBHc9yaqCRIlBxN0UjTYVAZwQim5ghPAGjwKs3miJmaZZRN44oUjSJ68Oa6hIiIRNyasCR2ikqMTpcm6Wg8H52/BH8gcx4HCq7Q1RHzjV6SjHC5y0VkU+PRa28kbQz+mPwgpbCp4b3udNnG7HtHr/19e0eXX/xs2AlLXX2dPOadR80yKsYxiRozqQFR9gZ53v88zbHsThY1ZuokIHJP5Y1ub8wZV5mgNa39+z+jI7zwjLJdV8uVmPa9M9rX4fTX14gH+7qqWqLuktB9OqIXHcHiMEjtnNZkplj/iHnMU3ftHNGIVF+KfJ+oCWLr6utU0J29k4o9pHDy7J1GJzc1Hl1+4H6jk/cjTigwIUBPXvxso2YZkpxxZw8vA4la3Uo6dNf3YeLDyyvpPJjMKpO1ZAiqKP9UPCw50/loVEtzutRdtfRwvBrPx3buNdUdSL0N5pfczMRhbkzXHEhVL8yCHqW99r3uBNURmnntjcizbfrGHTctVrFHj+CUFDjCOX9ZMr3PORVhCGXgzh7ZEAueiVC8QTWED+EYwVMx2kpZ0Ujj3sLMgq99hQMRSUliIYdXCFDXSC/NalRRnb0TKJzEqPxP35hTfvQx1Rtf/J2Jk/LDCnK2DEHlKHCCsq4BheZaAsdpVBBF5/p8ybOdaHsbgMnWGxEHJ+Ku8BPRQNwlOYf3jg5JQtUXJ1DzqARgktF9/0m93czY1Jg4IWhN1hyWOdYSVSuphGVl+j42XPq8c+W0iF9I8pFs3VS4uAU0fGlyuSpwX5Qw2fj7B+5HnBCQjdtPyhxt9pFzSgNOcEKcoKUiN3zoS51zo/JZ0emClymnC1yXeNipmZGqeU1jDWD160CqL8mChJjIZkvuXnrsttlIJbj02TtRJ7zE1dfh+bKGnOabXJ5p8lPGzKs1GZPLH3zeAg5wEGfU0mXQRFgt0EWY+DOih8X8D7QKLKYx4l7jCyJnMZt/ad5Iwrd1NNkN8E5NTqo5LCOuimjLhkvyiQcRQDNUiJcjMVw+HUkEM2KRK9UX6A9xRAuovDhvN8z0iLt/gHcaclLDUjGJA6VwOZJPPLAAgQjxcq73wxBaiv7bjD3aKZ3B0nHe227/xaBboQd0VnWiNZYOSkdHZ3Ykxe2BjpYKJb7Nt/8ZcWGHxXBKtf/l085DJVF1s/zFwRb0sGiNv0RHChu//IE6h+XavS9UhEXD8Rbv6ZmLuMtfNtYxCjd+7Iita9T5y//DqgiL+SpviVFU4296Lm95TTGtx9TO4Q88i7P8wI99VPgSeezyRxRdvUzc3shZ3geEEB2ChRLdRpb8V/JfyX+34ZmGa4cNPvl/lVSdixEipOEaSdJ1s646CAsy33BukCTJwIULqSbZxB+UIYLGVJKTz8B/hAX5VKskkwQA)

**Figure: High-level overview of KVM/QEMU virtualization**

The following are the prerequisites to enable KVM Hypervisor on Arm CPU-based systems:

- The Boot loader starts the Linux kernel in the exception level 2 (EL2)
- `CONFIG_KVM` is enabled in the kernel configuration

To verify if KVM is available on the device, run the following command to verify the presence of `/dev/kvm`:

ls -l /dev/kvm
    Copy to clipboard

In the Qualcomm Linux default boot flow, the Linux Kernel starts in EL1 while Gunyah assumes
the role of the Hypervisor. For instructions on booting the Linux Kernel in EL2 to enable the KVM Hypervisor,
see [UEFI](https://docs.qualcomm.com/bundle/publicresource/topics/80-70018-4/boot-developer-touchpoints.html#uefi).

Consider the following when enabling KVM:

- Virtual host extensions (VHE) are enabled by default on all the Qualcomm Linux SoCs that support Arm (v8.1) or
later instruction sets. This configuration allows the entire Linux Kernel to run at EL2 with slight modifications.
The guest OS kernel and user space run at EL1 and EL0.
With VHE, transitions between the guest and host incur less penalty because the guest and host kernels
operate at different exception levels.
- The Linux Kernel manages all accessible non-secure memory. It doesn’t support protected
use cases that require specific isolation from the Linux kernel. The Gunyah hypervisor
controls the S2 page tables of the Linux Kernel in the default boot flow.
- The peripheral image loading (PIL) services aren’t supported.
Hence, any applications that require aDSP, cDSP, and neural signal processor (NSP)
don’t work when KVM is enabled.
- The power state coordination interface (PSCI) for KVM is supported on the Linux kernel. PSCI ensures that
CPU hotplug and low-power modes (LPM) function correctly with KVM.

#### Virtual machine manager

Quick emulator (QEMU) is used as the virtual machine manager (VMM) for virtualization.
Libvirt acts as a management layer that interacts with QEMU to start, stop, and manage virtual machines.

##### QEMU

Use QEMU as a VMM with the KVM to run VMs at near-native performance. QEMU supports emulated devices, for example,
virtio devices, that provide high-performance I/O operations and allows access to USB and peripheral component
interconnect (PCI) devices from the VM.
The QEMU process and its threads manage a single VM. Invoke QEMU directly to create the VMs. For more information,
see [QEMU’s](https://qemu-project.gitlab.io/qemu/index.html).

##### Libvirt

Libvirt is a suite of tools, including an API library, a daemon (libvirtd), and a command-line utility (virsh),
for managing VMs. The virsh utility is useful for managing multiple VMs.
For more information, see [virsh](https://www.libvirt.org/manpages/virsh.html).

#### Launch guest VM

To launch an ARM64-based VM, use QEMU or virsh commands that internally work with libvirt. The commands allow you to configure the VM with CPU, memory, and storage.
Specify the number of virtual CPUs and the amount of memory allocated to the VM. Additionally, the VM can boot with a ramdisk (initrd) and a `.ext4` root file system.

Note

Verify that the guest kernel image (`Image`), root filesystem CPIO (`rootfs.cpio.gz`), and
root filesystem image (`rootfs.ext4`) are present in the `/mnt/overlay/guest` directory
in the host filesystem before launching the guest. These file paths and formats are examples for reference.

##### QEMU

To bring up the VMs with various configurations, run the following commands:

###### Boot with ramdisk

qemu-system-aarch64 \
       -M virt -m 2G \
       -kernel /mnt/overlay/guest/Image \
       -initrd /mnt/overlay/guest/rootfs.cpio.gz \
       -cpu host --enable-kvm -smp 4 -nographic
    Copy to clipboard

###### Boot with rootfs image

qemu-system-aarch64 \
       -M virt -m 2G \
       -kernel /mnt/overlay/guest/Image \
       -drive file=/mnt/overlay/guest/rootfs.ext4,if=virtio,format=raw \
       -append "root=/dev/vda" \
       -cpu host --enable-kvm -smp 4 -nographic
    Copy to clipboard

##### Libvirt

Libvirt enables you to use QEMU and KVM to create, interact, and manage VMs.

###### VM management with virsh

virsh provides a range of commands to create, control, and monitor VMs.

The following are the virsh commands used for VM management:

# Define a new VM domain called initrd_simple
    virsh define /mnt/overlay/libvirt_initrd_simple.xml
    Copy to clipboard

# List all domains and check the state of initrd_simple, it is not started yet
    virsh list --all
    Copy to clipboard

# start the initrd_simple VM
    virsh start initrd_simple
    Copy to clipboard

# connect to console
    virsh console initrd_simple
    Copy to clipboard

# Disconnect from console by pressing (Ctrl + ]) key combination
    Copy to clipboard

# shutdown the VM
    Copy to clipboard

virsh shutdown initrd_simple
    Copy to clipboard

# Undefine the VM if there is no intention to restart/resue it
    virsh undefine initrd_simple
    Copy to clipboard

###### Boot with ramdisk

Copy the following XML content to `/mnt/overlay/guest/libvirt_initrd_simple.xml` on the host:

<domain type='kvm' xmlns:qemu='http://libvirt.org/schemas/domain/qemu/1.0'>
      <name>simple_initrd</name>
       <!-- specify VM memory in KB  -->
      <memory unit='KiB'>2097152</memory>
       <!-- 4 vCPUs affined to all host CPUs  -->
      <vcpu placement='static'>4</vcpu>
      <resource>
        <partition>/machine</partition>
      </resource>
      <os>
        <type arch='aarch64' machine='virt-6.2'>hvm</type>
        <!-- specify kernel/initrd file  -->
        <kernel>/mnt/overlay/guest/Image</kernel>
        <initrd>/mnt/overlay/guest/rootfs.cpio.gz</initrd>
        <boot dev='hd'/>
      </os>
      <features>
        <gic version='3'/>
      </features>
      <cpu mode='host-passthrough' check='none'/>
      <devices>
        <!-- Guest console will be available over pty on the host -->
        <console type='pty'>
        </console>
      </devices>
    </domain>
    Copy to clipboard

###### Boot with rootfs image

Copy the following XML file to the host file system in the `/mnt/overlay/guest/libvirt_rootfs_simple.xml` file.
Use the VM management commands with `rootfs_simple` as VM domain/name instead of `initrd_simple`.

<domain type='kvm' xmlns:qemu='http://libvirt.org/schemas/domain/qemu/1.0'>
      <name>simple_rootfs</name>
      <memory unit='KiB'>2097152</memory>
      <vcpu placement='static'>4</vcpu>
      <resource>
        <partition>/machine</partition>
      </resource>
      <os>
        <type arch='aarch64' machine='virt-6.2'>hvm</type>
        <kernel>/mnt/overlay/guest/Image</kernel>
        <cmdline>root=/dev/vda</cmdline>
        <boot dev='hd'/>
      </os>
      <features>
        <gic version='3'/>
      </features>
      <cpu mode='host-passthrough' check='none'/>
      <devices>
        <console type='pty'>
        </console>
        <disk type="file" device="disk">
          <driver name="qemu" type="raw"/>
          <!-- specify rootfs image file  -->
          <source file="/mnt/overlay/guest/rootfs.ext4"/>
          <target dev="vda" bus="virtio"/>
        </disk>
      </devices>
    </domain>
    Copy to clipboard

> 
> 
>

#### Virtio framework

Virtio abstracts devices in a paravirtualized hypervisor environment.
It provides an I/O paravirtualization framework to interact with the paravirtualized (paravirt) devices.
The virtual machine monitor (VMM) or hypervisor (HYP) emulates most of the devices exposed to virtual machines (VMs) using virtio.

#### Key features

The following are the key features of virtual network:

- Paravirtualization and full virtualization

> 
> 
> - Full virtualization: In a fully virtual environment, the guest VM doesn’t recognize the hypervisor, it runs without modifications. However, full virtualization results in higher overhead due to the device emulation.
>     - Paravirtualization: In a paravirtualize environment, the VM recognizes the hypervisor and requires modifications to the OS. Paravirtualization allows efficient communication between the guest and the host.
- Virtio architecture

> 
> 
> ![../_images/virtio_arch.png](data:image/png;base64,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)
> 
> **Figure : A high-level overview of the virtio architecture**
> 
>     - Front-end drivers: Implements in the guest OS. The front-end drivers interact with the back-end drivers
> in the hypervisor
>     - Back-end drivers: Implements in the VMM/HYP. The back-end drivers handle the actual device emulation,
> and interacts with the front-end drivers through virtual queues
>     - Virtual queues: Virtio uses virtual queues (virtqueues) to facilitate communication between front-end and back-end drivers. These queues are implemented as rings to manage guest-to-hypervisor transitions efficiently.
- Vhost

> 
> 
> Vhost is a protocol that offloads the virtio data plane implementation to another element
> (user process or kernel module) to enhance performance. This offloading reduces the overhead
> of context switching between the guest VM and the hypervisor.

    - Vhost-net: A kernel-level implementation that allows the data plane to bypass the QEMU process,
to reduce latency and improves performance.
For more information about v-host-net, see [Introduction to
virtio-networking and vhost-net](https://www.redhat.com/en/blog/introduction-virtio-networking-and-vhost-net).
    - Vhost-user: A user-space implementation that handles the data plane with a separate process, to provide flexibility and
better performance for workloads. For more information about v-host-user,
see [Vhost-user Protocol](https://www.qemu.org/docs/master/interop/vhost-user.html).

#### Benefits

The following are the advantages of using virtio framework:

- Standardization: Virtio provides a common interface for device emulation. It promotes code reuse and efficiency across different
virtualization platforms.
- Flexibility: Virtio supports block devices and network devices.

#### Virtio interfaces

The following are the virtio-supported interfaces:

##### 9P transport overview

`virtio-9p` enables you to share files between the host and the VMs under the 9P
(Plan 9 file system) protocol to enhance the performance within the virtio framework.

Note

Ensure that the following configurations are enabled in the host and guest kernels:

Host side: CONFIG_NET_9P, CONFIG_NET_9P_VIRTIO
    Copy to clipboard

Guest side: CONFIG_NET_9P, CONFIG_NET_9P_VIRTIO, CONFIG_9P_FS
    Copy to clipboard

To create a `virtio-9p` shared directory, define it on the host, and configure the guest VM to mount it.
See the following example:

> 
> 
> root@qcs9100-ride-sx:~# ls -la /mnt/overlay/test_dir
>     total 12
>     drwxr-xr-x. 2 root root 4096 Apr 29 21:36 .
>     drwxr-xr-x. 7 root root 4096 Apr 29 21:36 ..
>     -rw-r--r--. 1 root root    8 Apr 29 21:36 file.txt
>     root@qcs9100-ride-sx:~# cat /mnt/overlay/test_dir/file.txt
>     testing
>     root@qcs9100-ride-sx:~#
>     Copy to clipboard

Create a `/mnt/overlay/test_dir` directory on the host to share it with the guest VM. Pass this information either in the libvirt XML configuration or as QEMU arguments.
To configure the 9P transport, run the following command:

qemu-system-aarch64 \
    -M virt -m 2G \
    -kernel /mnt/overlay/guest/Image \
    -drive file=/mnt/overlay/guest/rootfs.ext4,if=virtio,format=raw \
    -append "root=/dev/vda" \
    -cpu host --enable-kvm -smp 4 -nographic \
    -fsdev local,id=fsdev0,path=/mnt/overlay/test_dir,security_model=passthrough \
    -device virtio-9p-pci,fsdev=fsdev0,mount_tag=hostshare
    Copy to clipboard

To identify and mount the shared directory on the guest VM, use the `fsdev0` and `hostshare` filesystem devices.

To launch the Libvirt guest VM from the libvirt interface with the following sample XML,
see [Libvirt](https://docs.qualcomm.com/doc/80-70018-3/topic/virtualization.html#id7).

<domain type='kvm' xmlns:qemu='http://libvirt.org/schemas/domain/qemu/1.0'>
      <name>simple_9p</name>
      <memory unit='KiB'>2097152</memory>
      <vcpu placement='static'>4</vcpu>
      <resource>
        <partition>/machine</partition>
      </resource>
      <os>
        <type arch='aarch64' machine='virt-6.2'>hvm</type>
        <kernel>/mnt/overlay/guest/Image</kernel>
        <cmdline>root=/dev/vda</cmdline>
        <boot dev='hd'/>
      </os>
      <features>
        <gic version='3'/>
      </features>
      <cpu mode='host-passthrough' check='none'/>
      <devices>
        <console type='pty'>
        </console>
        <disk type="file" device="disk">
          <driver name="qemu" type="raw"/><!-- Specify rootfs image file here -->
          <source file="/mnt/overlay/guest/rootfs.ext4"/>
          <target dev="vda" bus="virtio"/>
        </disk>
        <filesystem type='mount' accessmode='mapped' fmode='644' dmode='755'>
          <!-- Specify the directory to be shared -->
          <source dir='/mnt/overlay/test_dir'/>
          <!-- Specify the mount_tag to identify the mount point -->
          <target dir='hostshare'/>
        </filesystem>
      </devices>
    </domain>
    Copy to clipboard

Note

Copy the XML content to `/mnt/overlay/guest/libvirt_virtio_9p.xml` file in the host.

After the guest VM boots up, verify if the virtio device is probed successfully.

> 
> 
> root@v8a-arm64:~# lspci
>     00:00.0 Host bridge: Red Hat, Inc. QEMU PCIe Host bridge
>     00:01.0 PCI bridge: Red Hat, Inc. QEMU PCIe Root port
>     00:01.1 PCI bridge: Red Hat, Inc. QEMU PCIe Root port
>     00:01.2 PCI bridge: Red Hat, Inc. QEMU PCIe Root port
>     01:00.0 Unclassified device [0002]: Red Hat, Inc. Virtio 1.0 filesystem (rev 01)
>     02:00.0 SCSI storage controller: Red Hat, Inc. Virtio 1.0 block device (rev 01)
>     root@v8a-arm64:~#root@v8a-arm64:~# cat /sys/bus/pci/devices/0000\:01\:00.0/virtio0/uevent
>     DRIVER=9pnet_virtio
>     MODALIAS=virtio:d00000009v00001AF4
>     root@v8a-arm64:~#
>     Copy to clipboard

To mount the shared directory in the guest VM, run the following command:

mount -t 9p -o trans=virtio hostshare mountpoint
    Copy to clipboard

##### VSOCK overview

VSOCK is a virtual socket interface that allows communication between VMs and the host OS.
It’s used in KVM and QEMU. VSOCK is supported through a virtio interface. virtio-vsock is a vhost-based virtio device where the host kernel manages all the data transfer
while the KVM hypervisor controls the information.

To create a VSOCK connection in a KVM and QEMU environment, specify the context identifier (CID) and port the
number. The CID is a unique identifier assigned to each VM in a VSOCK environment, which is used to route
communication between the host and the VMs. The host has a CID of 2 while VMs are assigned CIDs starting from 3
and above.

The following table lists the CID values:

Table: CID values

| CID | Description |
| --- | --- |
| -1 | Any address for binding |
| 0 | Hypervisor |
| 1 | Loopback |
| 2 | Host |

Note

Ensure that the following configurations are enabled in the host and guest kernels.

Host side: CONFIG_VSOCKETS, CONFIG_VHOST_VSOCK
    
    Guest side: CONFIG_VSOCKETS, CONFIG_VIRTIO_VSOCKETS
    Copy to clipboard

- Enable VSOCK device: To enable the VSOCK device, specify the device in the VM configuration file (libvirt XML), or pass an argument to QEMU.

qemu-system-aarch64 \
        -machine virt -m 2G \
        -kernel /mnt/overlay/guest/Image \
        -drive file=/mnt/overlay/guest/rootfs.ext4,if=virtio,format=raw \
        -append "root=/dev/vda" \
        -cpu host --enable-kvm -smp 4 -nographic \
        -device vhost-vsock-pci,guest-cid=73
        Copy to clipboard

In this command, `guest-cid=73` specifies the CID for the VM.

- Launch the guest VM using the libvirt interface: To use the VSOCK device with libvirt, define the VSOCK device in the VM XML configuration file.

    To launch the guest VM using the libvirt interface, see [Libvirt](https://docs.qualcomm.com/doc/80-70018-3/topic/virtualization.html#id7).

Copy the XML content to `/mnt/overlay/guest/libvirt_virtio_vsock.xml` on the host.
After the Guest VM boots up, verify that the device is probed successfully.

> 
> 
> root@v8a-arm64:~# lspci
>     00:00.0 Host bridge: Red Hat, Inc. QEMU PCIe Host bridge
>     00:01.0 PCI bridge: Red Hat, Inc. QEMU PCIe Root port
>     00:01.1 PCI bridge: Red Hat, Inc. QEMU PCIe Root port
>     00:01.2 PCI bridge: Red Hat, Inc. QEMU PCIe Root port
>     01:00.0 SCSI storage controller: Red Hat, Inc. Virtio 1.0 block device (rev 01)
>     02:00.0 Communication controller: Red Hat, Inc. Virtio 1.0 socket (rev 01)
>     root@v8a-arm64:~#
>     root@v8a-arm64:~# cat /sys/bus/pci/devices/0000\:02\:00.0/virtio1/uevent
>     DRIVER=vmw_vsock_virtio_transport
>     MODALIAS=virtio:d00000013v00001AF4
>     root@v8a-arm64:~#
>     Copy to clipboard

To verify the host-to-guest and guest-to-host interaction, use the `socat` utility.
Ensure that the `socat` utility is supported on host and guest.

- On the host, verify the following port:

> 
> 
> socat STDIN VSOCK-LISTEN:1234
>     Copy to clipboard

- On the guest, connect to the host using the host CID (2):

socat STDOUT VSOCK-CONNECT:2:1234
    Copy to clipboard

- In this setup, the guest and host show the same values.

##### Virtio block overview

The virtio block is a standardized way to present block devices to the VM. Each virtio block device appears as a disk
inside the guest VM. The virtio block allows the VMs to read and write operations.

The following are the key features of the virtio-block device:

- Simplicity: Easy to implement and use
- Performance: Designed to minimize overhead and maximize throughput
- Flexibility: Designed to use with various types of storage back ends

Note

Ensure that `CONFIG_VIRTIO_BLK` is enabled in the guest kernel.

To use a virtio-block device, do the following:

1. To configure the VM for including a virtio-block device, specify the device in the
VM configuration file (libvirt XML), or pass an argument to QEMU.

    1. To enable the virtio-block device in the VM, use the following QEMU command:

qemu-system-aarch64 \
            -M virt -m 2G \
            -kernel /mnt/overlay/guest/Image \
            -drive file=/mnt/overlay/guest/rootfs.ext4,if=virtio,format=raw \
            -append "root=/dev/vda" \
            -cpu host --enable-kvm -smp 4 -nographic \
            -drive file=/mnt/overlay/guest/disk.img,if=virtio,format=raw
            Copy to clipboard

        In this command, `rootfs.ext4` and `disk.img` are the disks inside the guest VM.
    2. Launch the guest VM using the libvirt interface: To launch the guest VM with the following sample XML,
see [Libvirt](https://docs.qualcomm.com/doc/80-70018-3/topic/virtualization.html#id7):

<domain type='kvm' xmlns:qemu='http://libvirt.org/schemas/domain/qemu/1.0'>
              <name>simple_block_device</name>
              <memory unit='KiB'>2097152</memory>
              <vcpu placement='static'>4</vcpu>
              <resource>
                <partition>/machine</partition>
              </resource>
              <os>
                <type arch='aarch64' machine='virt-6.2'>hvm</type>
                <kernel>/mnt/overlay/guest/Image</kernel>
                <cmdline>root=/dev/vda</cmdline>
                <boot dev='hd'/>
              </os>
              <features>
                <gic version='3'/>
              </features>
              <cpu mode='host-passthrough' check='none'/>
              <devices>
                <console type='pty'>
                </console>
                <disk type="file" device="disk">
                  <driver name="qemu" type="raw"/>
                  <!-- specify rootfs image file  -->
                  <source file="/mnt/overlay/guest/rootfs.ext4"/>
                  <target dev="vda" bus="virtio"/>
                </disk>
                <disk type="file" device="disk">
                  <driver name="qemu" type="raw"/>
                  <!-- specify a different disk image file -->
                  <source file="/mnt/overlay/guest/disk.img"/>
                  <target dev="vdb" bus="virtio"/>
                </disk>
              </devices>
            </domain>
            Copy to clipboard

Note

Copy the XML content to `/mnt/overlay/guest/libvirt_virtio_blk.xml` on the host.
2. The guest OS detects the virtio-block device and initializes it. In this process, the guest driver
communicates with the device to set up the necessary data structures and queues.

> 
> 
> root@v8a-arm64:~# dmesg | grep virtio
>         [    0.225425] virtio-pci 0000:01:00.0: enabling device (0000 -> 0002)
>         [    0.227073] virtio-pci 0000:02:00.0: enabling device (0000 -> 0002)
>         [    0.234012] virtio_blk virtio0: 4/0/0 default/read/poll queues
>         [    0.235405] virtio_blk virtio0: [vda] 2220734 512-byte logical blocks (1.14 GB/1.06 GiB)
>         [    0.241213] virtio_blk virtio1: 4/0/0 default/read/poll queues
>         [    0.242418] virtio_blk virtio1: [vdb] 8192000 512-byte logical blocks (4.19 GB/3.91 GiB)
>         root@v8a-arm64:~#
>         root@v8a-arm64:~# lspci
>         00:00.0 Host bridge: Red Hat, Inc. QEMU PCIe Host bridge
>         00:01.0 PCI bridge: Red Hat, Inc. QEMU PCIe Root port
>         00:01.1 PCI bridge: Red Hat, Inc. QEMU PCIe Root port
>         00:01.2 PCI bridge: Red Hat, Inc. QEMU PCIe Root port
>         01:00.0 SCSI storage controller: Red Hat, Inc. Virtio 1.0 block device (rev 01)
>         02:00.0 SCSI storage controller: Red Hat, Inc. Virtio 1.0 block device (rev 01)
>         root@v8a-arm64:~#
>         Copy to clipboard
3. After initializing, you can use the virtio-block and other block devices.
The guest OS performs read and write operations on the virtio driver and passes the operations
to the host for processing.
4. To manage the virtio-block device, use the standard tools and commands available in the guest OS.
For example, `lsblk` and `df`.

##### Virtio-IOMMU overview

Virtio-IOMMU is a paravirtualized input/output memory management unit (IOMMU) that provides
direct memory access (DMA) management in the virtual environments.
Virtio-IOMMU integrates with the existing software APIs such as virtual function I/O (VFIO) and removes the
need for page table emulation, making it a lightweight and high-performance solution.
Virtio-IOMMU acts as a proxy for physical IOMMUs and manages the devices assigned to the guest.
As virtual IOMMU, it manages, emulates, and paravirtualizes the devices.

The following are the key features of Virtio-IOMMU:

- Paravirtualization: Leverages existing transport mechanisms and reduces overhead
- Flexibility: Supports PCI passthrough and shares virtual memory
- Integration: Integrates with software APIs and enhances compatibility. For example, VFIO

Note

Ensure that `CONFIG_VIRTIO_IOMMU` is enabled in the guest kernel.

To use a Virtio-IOMMU device, do the following:

1. To configure the VM for including a Virtio-IOMMU device, specify the device in the
VM configuration file (XML), or pass an argument to QEMU.

> 
> 
> 1. Enable a Virtio-IOMMU device: To enable the Virtio-IOMMU device in the VM, use the following QEMU command:
> 
> 
> 
> 
> > 
> > 
> > qemu-system-aarch64 \
> >     -M virt -m 2G \
> >     -kernel /mnt/overlay/guest/Image \
> >     -drive file=/mnt/overlay/guest/rootfs.ext4,if=virtio,format=raw \
> >     -append "root=/dev/vda" \
> >     -cpu host --enable-kvm -smp 4 -nographic \
> >     -device virtio-iommu-pci
> >     Copy to clipboard
> 
> 
> 2. Launch guest VM using the libvirt interface: To launch the guest VM with the following sample XML, see [Libvirt](https://docs.qualcomm.com/doc/80-70018-3/topic/virtualization.html#id7).
> 
> 
> 
> 
> > 
> > 
> > <domain type='kvm' xmlns:qemu='http://libvirt.org/schemas/domain/qemu/1.0'>
> >       <name>simple_iommu</name>
> >       <memory unit='KiB'>2097152</memory>
> >       <vcpu placement='static'>4</vcpu>
> >       <resource>
> >         <partition>/machine</partition>
> >       </resource>
> >       <os>
> >         <type arch='aarch64' machine='virt-6.2'>hvm</type>
> >         <kernel>/mnt/overlay/guest/Image</kernel>
> >         <cmdline>root=/dev/vda</cmdline>
> >         <boot dev='hd'/>
> >       </os>
> >       <features>
> >         <gic version='3'/>
> >       </features>
> >       <cpu mode='host-passthrough' check='none'/>
> >       <devices>
> >         <controller type='pci' index='0' model='pcie-root'>
> >           <alias name='pcie.0'/>
> >         </controller>
> >         <console type='pty'>
> >         </console>
> >         <disk type="file" device="disk">
> >           <driver name="qemu" type="raw"/>
> >           <!-- specify rootfs image file  -->
> >           <source file="/mnt/overlay/guest/rootfs.ext4"/>
> >           <target dev="vda" bus="virtio"/>
> >         </disk>
> >       </devices>
> >       <qemu:commandline>
> >         <qemu:arg value="-device"/>
> >         <qemu:arg value='{"driver":"virtio-iommu-pci","bus":"pcie.0","addr":"0x3"}'/>
> >       </qemu:commandline>
> >     </domain>
> >     Copy to clipboard
> 
> 
> 
> Note
> 
> 
> Copy the XML content to `/mnt/overlay/guest/libvirt_virtio_iommu.xml` on the host.

2. The guest OS detects the Virtio-IOMMU device and initializes it.
In this process, the guest driver communicates with the device to set up the necessary data structures and mappings.

> 
> 
> root@v8a-arm64:~# dmesg | grep virtio
>     [    0.184166] virtio-pci 0000:00:03.0: enabling device (0000 -> 0002)
>     [    0.189122] virtio_iommu virtio0: input address: 64 bits
>     [    0.189516] virtio_iommu virtio0: page mask: 0xfffffffffffff000
>     [    0.220135] virtio-pci 0000:01:00.0: Adding to iommu group 0
>     [    0.220676] virtio-pci 0000:01:00.0: enabling device (0000 -> 0002)
>     [    0.223065] virtio_blk virtio1: 4/0/0 default/read/poll queues
>     [    0.224713] virtio_blk virtio1: [vda] 2220734 512-byte logical blocks (1.14 GB/1.06 GiB)
>     root@v8a-arm64:~#
>     Copy to clipboard
> 
> 
> The DMESG logs show that the virtio-block device is attached to the IOMMU domain,
> which is a part of the IOMMU group `0`.

3. After initializing, the Virtio-IOMMU device manages DMA operations for attached devices.
The guest OS performs mapping and unmapping operations with the virtio driver
and passes the operations to the host for processing.

> 
> 
> The following example shows Virtio-IOMMU device operations:
> 
> 
> root@v8a-arm64:~# cat /sys/kernel/iommu_groups/0/devices/0000\:01\:00.0/virtio1/uevent
>     DRIVER=virtio_blk
>     MODALIAS=virtio:d00000002v00001AF4
>     root@v8a-arm64:~#
>     Copy to clipboard

##### Virtio-net overview

The virtio-net device is a virtual network device that provides an interface for network
operations in virtualized environments. It offers high performance and low overhead.

The following are the key features of the virtio-net device:

- Efficiency: Minimizes overhead and maximizes throughput.
- Simplicity: Easy to implement and use.
- Flexibility: Supports various network configurations and back ends.

Note

Ensure that `CONFIG_VIRTIO_NET` is enabled in the guest kernel.

To use a virtio-net device, do the following:

1. To configure the VM for including a virtio-net device, specify the device in
the VM configuration file (libvirt XML), or pass an argument to QEMU.

> 
> 
> 1. To enable the virtio-net device in the VM, use the following QEMU command:
> 
> 
> 
> 
> > 
> > 
> > qemu-system-aarch64 \
> >     -M virt -m 2G \
> >     -kernel /mnt/overlay/guest/Image \
> >     -drive file=/mnt/overlay/guest/rootfs.ext4,if=virtio,format=raw \
> >     -append "root=/dev/vda" \
> >     -cpu host --enable-kvm -smp 4 -nographic \
> >     -netdev tap,id=net0,ifname=tap0,script=no,downscript=no \
> >     -device virtio-net-pci,netdev=net0
> >     Copy to clipboard
> > 
> > 
> > Note
> > 
> > 
> > This command creates a Tap interface on the host. To create the Tap interface manually,
> > run the following command:
> > 
> > 
> > ip tuntap add dev tap0 mode tap
> >     Copy to clipboard
> 
> 
> 2. To launch the guest VM with the following sample XML, see [Libvirt](https://docs.qualcomm.com/doc/80-70018-3/topic/virtualization.html#id7).
> 
> 
> 
> 
> > 
> > 
> > <domain type='kvm' xmlns:qemu='http://libvirt.org/schemas/domain/qemu/1.0'>
> >       <name>simple_net</name>
> >       <memory unit='KiB'>2097152</memory>
> >       <vcpu placement='static'>4</vcpu>
> >       <resource>
> >         <partition>/machine</partition>
> >       </resource>
> >       <os>
> >         <type arch='aarch64' machine='virt-6.2'>hvm</type>
> >         <kernel>/mnt/overlay/guest/Image</kernel>
> >         <cmdline>root=/dev/vda</cmdline>
> >         <boot dev='hd'/>
> >       </os>
> >       <features>
> >         <gic version='3'/>
> >       </features>
> >       <cpu mode='host-passthrough' check='none'/>
> >       <devices>
> >         <console type='pty'>
> >         </console>
> >         <disk type="file" device="disk">
> >           <driver name="qemu" type="raw"/><!-- Specify rootfs image file here -->
> >           <source file="/mnt/overlay/guest/rootfs.ext4"/>
> >           <target dev="vda" bus="virtio"/>
> >         </disk>
> >         <interface type='ethernet'>
> >           <target dev='tap0'/>
> >           <model type='virtio'/>
> >         </interface>
> >       </devices>
> >     </domain>
> >     Copy to clipboard
> > 
> > 
> > To create a tap interface for direct communication between the host VM and the guest VM, copy the XML content to `/mnt/overlay/guest/libvirt_virtio_net.xml` on the host.

2. The guest operating system detects the virtio-net device and initializes it.
In this process, the guest driver communicates with the device to set up the necessary data structures and queues.

> 
> 
> root@v8a-arm64:~# dmesg | grep virtio
>     [    0.394365] virtio-pci 0000:01:00.0: enabling device (0000 -> 0002)
>     [    0.396364] virtio-pci 0000:02:00.0: enabling device (0000 -> 0002)
>     [    0.404496] virtio_blk virtio1: 4/0/0 default/read/poll queues
>     [    0.406048] virtio_blk virtio1: [vda] 2220734 512-byte logical blocks (1.14 GB/1.06 GiB)
>     [    0.980919] virtio_net virtio0 enp1s0: renamed from eth0
>     root@v8a-arm64:~# lspci
>     00:00.0 Host bridge: Red Hat, Inc. QEMU PCIe Host bridge
>     00:01.0 PCI bridge: Red Hat, Inc. QEMU PCIe Root port
>     00:01.1 PCI bridge: Red Hat, Inc. QEMU PCIe Root port
>     00:01.2 PCI bridge: Red Hat, Inc. QEMU PCIe Root port
>     01:00.0 Ethernet controller: Red Hat, Inc. Virtio 1.0 network device (rev 01)
>     02:00.0 SCSI storage controller: Red Hat, Inc. Virtio 1.0 block device (rev 01)
>     root@v8a-arm64:~#
>     Copy to clipboard

3. Operate: After you initialize and configure the virtio-net device, use it as other network interface.
The guest OS performs standard network operations with the virtio driver
and passes the operations to the host for processing.

To use the Tap interface, run the following network configurations on the host VM and the guest VM:

- Host configuration:

root@qcs9100-ride-sx:~# ip addr add 192.168.100.1/24 dev tap0
        root@qcs9100-ride-sx:~# ip link set dev tap0 up
        Copy to clipboard
- Guest configuration:

root@v8a-arm64:~# ip addr add 192.168.100.2/24 dev enp1s0
        root@v8a-arm64:~# ip link set dev enp1s0 up
        Copy to clipboard

To run the network traffic on this interface, use the following example:

> 
> 
> root@v8a-arm64:~# ping 192.168.100.1
>     PING 192.168.100.1 (192.168.100.1): 56 data bytes
>     64 bytes from 192.168.100.1: seq=0 ttl=64 time=0.364 ms
>     64 bytes from 192.168.100.1: seq=1 ttl=64 time=0.156 ms
>     Copy to clipboard

##### Virtio-serial and virtio-console overview

The virtio-serial device provides an interface for serial communication between the host VM and the guest VM in virtual environments.

The following are the key features of the virtio-serial device:

- Multiple ports: Supports multiple serial ports, allows various communication channels
- Efficiency: Minimizes overhead and maximizes throughput
- Flexibility: Supports different types of data exchange. For example, console access and file transfer

Note

Ensure that `CONFIG_VIRTIO_CONSOLE` is enabled in the guest kernel.

To use a virtio-serial device, do the following:

1. To configure the VM for including a virtio-serial device, specify the device in
the VM configuration file (libvirt XML), or pass an argument to QEMU.

    1. To enable the virtio-net device in the VM, use the following QEMU command:

> 
> 
> qemu-system-aarch64 \
>         -M virt -m 2G \
>         -kernel /mnt/overlay/guest/Image \
>         -drive file=/mnt/overlay/guest/rootfs.ext4,if=virtio,format=raw \
>         -append "root=/dev/vda" \
>         -cpu host --enable-kvm -smp 4 -nographic \
>         -device virtio-serial-pci,id=virtio-serial0 \
>         -chardev pty,id=charconsole0 \
>         -device virtconsole,chardev=charconsole0,id=console0 \
>         -chardev socket,path=/tmp/qemu.sock,server=on,wait=off,id=charchannel0 \
>         -device virtserialport,chardev=charchannel0,name=org.qemu.guest_agent.0
>         Copy to clipboard

    2. To launch the guest VM with the following sample XML, see [Libvirt](https://docs.qualcomm.com/doc/80-70018-3/topic/virtualization.html#id7).

<domain type='kvm' xmlns:qemu='http://libvirt.org/schemas/domain/qemu/1.0'>
          <name>simple_serial</name>
          <memory unit='KiB'>2097152</memory>
          <vcpu placement='static'>4</vcpu>
          <resource>
            <partition>/machine</partition>
          </resource>
          <os>
            <type arch='aarch64' machine='virt-6.2'>hvm</type>
            <kernel>/mnt/overlay/guest/Image</kernel>
            <cmdline>root=/dev/vda</cmdline>
            <boot dev='hd'/>
          </os>
          <features>
            <gic version='3'/>
          </features>
          <cpu mode='host-passthrough' check='none'/>
          <devices>
            <console type='pty'>
            </console>
            <disk type="file" device="disk">
              <driver name="qemu" type="raw"/><!-- Specify rootfs image file here -->
              <source file="/mnt/overlay/guest/rootfs.ext4"/>
              <target dev="vda" bus="virtio"/>
            </disk>
            <controller type='virtio-serial' index='0'>
              <alias name='virtio-serial0'/>
            </controller>
            <console type='pty'>
              <target type='virtio' port='0'/>
            </console>
            <channel type='unix'>
              <target type='virtio' name='org.qemu.guest_agent.0'/>
              <address type='virtio-serial' controller='0' bus='0' port='1'/>
            </channel>
          </devices>
        </domain>
        Copy to clipboard

Note

Copy the XML content to `/mnt/overlay/guest/virtio_serial.xml` on the host.
2. The guest operating system detects the virtio-serial device and initializes it.
In this process, the guest driver communicates with the device to set up the necessary data structures and ports.

> 
> 
> root@v8a-arm64:~# lspci
>     00:00.0 Host bridge: Red Hat, Inc. QEMU PCIe Host bridge
>     00:01.0 PCI bridge: Red Hat, Inc. QEMU PCIe Root port
>     00:01.1 PCI bridge: Red Hat, Inc. QEMU PCIe Root port
>     00:01.2 PCI bridge: Red Hat, Inc. QEMU PCIe Root port
>     01:00.0 Communication controller: Red Hat, Inc. Virtio 1.0 console (rev 01)
>     02:00.0 SCSI storage controller: Red Hat, Inc. Virtio 1.0 block device (rev 01)
>     root@v8a-arm64:~#
>     root@v8a-arm64:~# cat /sys/bus/virtio/devices/virtio0/uevent
>     DRIVER=virtio_console
>     MODALIAS=virtio:d00000003v00001AF4
>     root@v8a-arm64:~#
>     Copy to clipboard

3. After initialization, you can use the virtio-serial device as a serial device. The guest OS performs read and write operations with the virtio driver and passes the operations to the host for processing.
4. To manage the virtio-serial device, do the following:

    - Monitor the performance
    - Verify the device status
    - Perform maintenance tasks
    - Use the standard tools and commands available in the guest OS

###### Memory balloon device support

The traditional virtio memory balloon device manages the guest memory.
It allows the host system to reclaim memory from VMs. The memory balloon instructs VMs to return a
portion of their memory to the host. This process involves inflating the memory balloon inside the Guest VM, which reduces the memory available for other tasks within the VM. The Guest OS decides which memory pages to give back to the host, indicating which pages it doesn’t need or access. The host then un-maps these pages from the guest VM and marks them as unavailable for the guest VM and allows the host system to use them. If the guest VM requires more memory later, the host deflates the balloon to return the pages. This feature allows each guest VM to continue running while its available memory is managed.

Use the following for the virtio-balloon device to relocate physical memory between a guest VM and the host:

1. Balloon inflation: The guest driver allocates memory and informs the host. The host then reuses the inflated memory for other VMs.
2. Balloon deflation: After informing the host, the guest driver frees the previously allocated memory
and enables the guest VM to use the deflated memory.

`Target balloon size` controls the balloon inflation or deflation through a request to change the guest
VM memory size. The resize request is sent through QEMU monitor mode or through virsh commands.

The following are the key features of the virtio-balloon device:

- Memory management: Adjusts memory allocation in real time based on the requirements.
- Efficiency: Reclaims unused memory from idle VMs and redistributes it to the active ones.
- Flexibility: Enables various virtualization setups to optimize resource usage.

Note

Ensure that `CONFIG_VIRTIO_BALLOON` is enabled in the guest kernel.

To use a virtio-balloon device, do the following:

1. Configure the VM for including a virtio-balloon device, specify the device in the VM configuration file (libvirt XML), or pass an argument to QEMU.

    1. To enable the virtio-balloon device in the VM, use the following QEMU command:

qemu-system-aarch64 \
            -M virt -m 2G \
            -kernel /mnt/overlay/guest/Image \
            -drive file=/mnt/overlay/guest/rootfs.ext4,if=virtio,format=raw \
            -append "root=/dev/vda" \
            -cpu host --enable-kvm -smp 4 -nographic \
            -device virtio-balloon-pci,id=balloon0
            Copy to clipboard
    2. To launch the guest VM with the following sample XML, see [Libvirt](https://docs.qualcomm.com/doc/80-70018-3/topic/virtualization.html#id7):

<domain type='kvm' xmlns:qemu='http://libvirt.org/schemas/domain/qemu/1.0'>
              <name>simple_balloon</name>
              <memory unit='KiB'>2097152</memory>
              <vcpu placement='static'>4</vcpu>
              <resource>
                <partition>/machine</partition>
              </resource>
              <os>
                <type arch='aarch64' machine='virt-6.2'>hvm</type>
                <kernel>/mnt/overlay/guest/Image</kernel>
                <cmdline>root=/dev/vda</cmdline>
                <boot dev='hd'/>
              </os>
              <features>
                <gic version='3'/>
              </features>
              <cpu mode='host-passthrough' check='none'/>
              <devices>
                <console type='pty'>
                </console>
                <disk type="file" device="disk">
                  <driver name="qemu" type="raw"/><!-- Specify rootfs image file here -->
                  <source file="/mnt/overlay/guest/rootfs.ext4"/>
                  <target dev="vda" bus="virtio"/>
                </disk>
                <memballoon model='virtio'/>
              </devices>
            </domain>
            Copy to clipboard

Note

Copy the XML content to `/mnt/overlay/guest/libvirt_virtio_balloon.xml` file on the host.
2. The guest OS detects the virtio-balloon device and initializes it. In this process, the guest driver
communicates with the device to set up the necessary data structures and memory management mechanisms.

> 
> 
> root@v8a-arm64:~# lspci
>         00:00.0 Host bridge: Red Hat, Inc. QEMU PCIe Host bridge
>         00:01.0 PCI bridge: Red Hat, Inc. QEMU PCIe Root port
>         00:01.1 PCI bridge: Red Hat, Inc. QEMU PCIe Root port
>         00:01.2 PCI bridge: Red Hat, Inc. QEMU PCIe Root port
>         01:00.0 SCSI storage controller: Red Hat, Inc. Virtio 1.0 block device (rev 01)
>         02:00.0 Unclassified device [00ff]: Red Hat, Inc. Virtio 1.0 memory balloon (rev 01)
>         root@v8a-arm64:~#
>         Copy to clipboard
3. After initializing, the virtio-balloon device adjusts the memory allocated to the VM. The guest OS performs memory
inflation and deflation operations, which are handled by the virtio driver, and passes it to the host for processing.

To adjust the guest memory, run the following virsh commands on the host:

- To verify the guest VM initial memory (2 GB), run the following command:

> 
> 
> root@v8a-arm64:~# cat /proc/meminfo  | grep Mem
>     MemTotal:        1966180 kB
>     MemFree:         1807432 kB
>     MemAvailable:    1817552 kB
>     root@v8a-arm64:~#
>     Copy to clipboard

- To inflate the balloon and reduce the guest VM memory to 512 MB, run the following command:

root@qcs9100-ride-sx:~# virsh setmem simple_balloon 512M --live
        Copy to clipboard
- To verify the guest VM memory after inflation, run the following command:

root@v8a-arm64:~# cat /proc/meminfo  | grep Mem
        MemTotal:         393316 kB
        MemFree:          235708 kB
        MemAvailable:     245836 kB
        root@v8a-arm64:~#
        Copy to clipboard
- To deflate the balloon (Guest VM memory back to 2 GB):

root@qcs9100-ride-sx:~# virsh setmem simple_balloon 2G --live
        Copy to clipboard
- To verify the guest VM memory after deflation:

root@v8a-arm64:~# cat /proc/meminfo  | grep Mem
        MemTotal:        1966180 kB
        MemFree:         1811844 kB
        MemAvailable:    1821988 kB
        root@v8a-arm64:~#
        Copy to clipboard

###### Access host devices

You can use the enumerated devices on the host system from the guest.
The device assignment interface to the guest varies based on the device type.
Some devices act as a back end for a device emulated by QEMU, for example,
UART. Configure universal asynchronous
receiver transmitter (UART) as a character device (chardev) back end on the host.
For more information about QEMU chardev, see  [Character device options](https://www.qemu.org/docs/master/system/invocation.html#hxtool-6).

PCI and USB devices work on the kernel VFIO framework.

- PCI passthrough allows a guest VM to directly access a physical PCI device on
the host. The VFIO framework in the Linux kernel is used for the device assignment.
For more information about the VFIO, see [VFIO - Virtual Function I/O](https://docs.kernel.org/driver-api/vfio.html).
- A USB device operates in Passthrough mode, allowing the guest VM to use USB peripherals
connected to the host. QEMU emulates the USB controller and works
with libusb on the host to present USB peripherals to the guest.
For more information, see [USB emulation](https://qemu-project.gitlab.io/qemu/system/devices/usb.html).

**USB passthrough overview**

Identify the USB device that’s enumerated on the host computer to assign it to the guest.
To see all the USB devices that are enumerated on the host, use the `lusb` command.
Find the device by its `vendor id` and `product id`.

In the following example, `vendor id` is 0x0781 and `product id` is 0x5567 for the USB memory stick.

sh-5.1# lsusb
    Bus 002 Device 001: ID 1d6b:0003 Linux Foundation 3.0 root hub
    Bus 001 Device 004: ID 0781:5567 SanDisk Corp. Cruzer Blade
    Bus 001 Device 001: ID 1d6b:0002 Linux Foundation 2.0 root hub
    Bus 003 Device 001: ID 1d6b:0002 Linux Foundation 2.0 root hub
    Copy to clipboard

Note

Copy the following XML file on the host file system in `/mnt/overlay/guest/libvirt_usb.xml`
file and modify the XML file per `vendor id` and `product id`.

Launch a guest VM with the following sample XML and do the following:

1. After the guest VM is launched, connect to the console.
2. Verify the `lsusb` output in the guest VM.
3. Ensure that the output lists the USB device assigned to the guest.

<domain type='kvm' xmlns:qemu='http://libvirt.org/schemas/domain/qemu/1.0'>
      <name>simple_usb</name>
      <memory unit='KiB'>2097152</memory>
      <vcpu placement='static'>4</vcpu>
      <resource>
        <partition>/machine</partition>
      </resource>
      <os>
        <type arch='aarch64' machine='virt-6.2'>hvm</type>
        <kernel>/mnt/overlay/guest/Image</kernel>
        <cmdline>root=/dev/vda</cmdline>
        <boot dev='hd'/>
      </os>
      <features>
        <gic version='3'/>
      </features>
      <cpu mode='host-passthrough' check='none'/>
      <devices>
        <console type='pty'>
        </console>
        <disk type="file" device="disk">
          <driver name="qemu" type="raw"/><!-- Specify rootfs image file here -->
          <source file="/mnt/overlay/guest/rootfs.ext4"/>
          <target dev="vda" bus="virtio"/>
        </disk>
        <controller type='usb' index='0' model='qemu-xhci' ports='4'/>
        <hostdev mode='subsystem' type='usb' managed='yes'>
          <source><!-- Specify USB device VID/PID here -->
            <vendor id='0x0781'/>
            <product id='0x5567'/>
          </source>
        </hostdev>
      </devices>
    </domain>
    Copy to clipboard

**PCI overview**

Identify the PCI device that’s enumerated on the host computer to assign it to the guest.
To see all the PCI devices that are enumerated on the host, use the `lspci` command.
Find the device by its `[domain:]bus:device.function`.
For more information about `lspci` command, see [lspci(8)—Linux manual page](https://man7.org/linux/man-pages/man8/lspci.8.html).

The following example shows supported values for domain, bus, device, and function for `Ethernet controller: Aquantia Corp. AQC107 NBase-T/IEEE 802.3bz` device:

- Domain is 0001
- Bus is 01
- Device is 00
- Function is 0 for

sh-5.1# lspci
    0000:00:00.0 PCI bridge: Qualcomm Device 0115
    0000:01:00.0 Network controller: Qualcomm QCNFA765 Wireless Network Adapter (rev 01)
    0001:00:00.0 PCI bridge: Qualcomm Device 0115
    0001:01:00.0 Ethernet controller: Aquantia Corp. AQC107 NBase-T/IEEE 802.3bz
    Copy to clipboard

Note

Copy the XML content to `/mnt/overlay/guest/libvirt_pci.xml` file and change the `hostdev` section in the XML file according to your device requirements.

To launch the guest VM, see [Libvirt](https://docs.qualcomm.com/doc/80-70018-3/topic/virtualization.html#id7). After you launch the guest VM, connect it to the console
and verify the `lspci` output in the guest. Ensure that the output lists the PCI device assigned to the guest.

Note

The output shows different slots based on the guest PCI topology selected by QEMU and Libvirt.

When `managed` is marked as *yes* in `hostdev` in the following XML, the PCI device gets detached from the
host before it passes on to the guest, and re-attached to the host after the guest exits.
For more information, see [USB / PCI / SCSI devices](https://libvirt.org/formatdomain.html#usb-pci-scsi-devices).

<domain type='kvm' xmlns:qemu='http://libvirt.org/schemas/domain/qemu/1.0'>
      <name>simple_pci</name>
      <memory unit='KiB'>2097152</memory>
      <vcpu placement='static'>4</vcpu>
      <resource>
        <partition>/machine</partition>
      </resource>
      <os>
        <type arch='aarch64' machine='virt-6.2'>hvm</type>
        <kernel>/mnt/overlay/guest/Image</kernel>
        <cmdline>root=/dev/vda</cmdline>
        <boot dev='hd'/>
      </os>
      <features>
        <gic version='3'/>
      </features>
      <cpu mode='host-passthrough' check='none'/>
      <devices>
        <console type='pty'>
        </console>
        <disk type="file" device="disk">
          <driver name="qemu" type="raw"/>
          <source file="/mnt/overlay/guest/rootfs.ext4"/>
          <target dev="vda" bus="virtio"/>
        </disk>
        <hostdev mode='subsystem' type='pci' managed='yes'>
          <source><!-- specify your PCI device details here -->
            <address domain='0x0001' bus='0x01' slot='0x00' function='0x0'/>
          </source>
        </hostdev>
      </devices>
    </domain>
    Copy to clipboard

**UART passthrough overview**

Identify the `/dev/ttyX` teletype (TTY) device file corresponding to the UART to use it from the guest.
Ensure that no application on the host is using this interface.

Note

Copy the XML content to `/mnt/overlay/guest/libvirt_uart.xml` file on the host and modify the TTY device file as per your device requirements.

Launch a guest VM and connect to the console. The serial interface at `/dev/virtio-ports/hostserial`
acts as a front end to the real UART on the host. Use the following XML file:

<domain type='kvm' xmlns:qemu='http://libvirt.org/schemas/domain/qemu/1.0'>
      <name>simple_uart</name>
      <memory unit='KiB'>2097152</memory>
      <vcpu placement='static'>4</vcpu>
      <resource>
        <partition>/machine</partition>
      </resource>
      <os>
        <type arch='aarch64' machine='virt-6.2'>hvm</type>
        <kernel>/mnt/overlay/guest/Image</kernel>
        <cmdline>root=/dev/vda</cmdline>
        <boot dev='hd'/>
      </os>
      <features>
        <gic version='3'/>
      </features>
      <cpu mode='host-passthrough' check='none'/>
      <devices>
        <console type='pty'>
        </console>
        <channel type='dev'>
          <source path='/dev/ttyMSM0'/>
          <target type='virtio' name='hostserial'/>
          <address type='virtio-serial' controller='0' bus='0' port='1'/>
        </channel>
        <disk type="file" device="disk">
          <driver name="qemu" type="raw"/>
          <source file="/mnt/overlay/guest/rootfs.ext4"/>
          <target dev="vda" bus="virtio"/>
        </disk>
      </devices>
    </domain>
    Copy to clipboard

#### KVM customizations

The following features allow you to modify the KVM hypervisor to meet specific requirements:

#### Remote command execution

To enable the QEMU guest agent in the guest OS user space, run the remote commands on the guest VMs from the host.
For more information about `qemu-ga`, see [QEMU Guest Agent](https://qemu-project.gitlab.io/qemu/interop/qemu-ga.html).

`qemu-agent-command` is the virsh command that includes `guest-exec` and `guest-exec-status`
as the subcommands to execute and verify the status or output of the guest VMs.
For more information about how to configure `qemu-ga` through virtio-serial interface, see
[QEMU Guest Agent](https://wiki.libvirt.org/Qemu_guest_agent.html).

For more information about how `virt-exec` wraps virsh commands and provides an interface,
see [kvm-qemu/virt-exec](https://github.com/ildar-shaimordanov/my-scripts/blob/master/kvm-qemu/virt-exec).

The following example shows how to run `/proc/meminfo` on the guest VM from the host computer using a `virt-exec` utility:

sh-5.2# ./virt-exec testvm cat /proc/meminfo | grep -i total
    MemTotal:        1968056 kB
    SwapTotal:             0 kB
    VmallocTotal:   133141626880 kB
    CmaTotal:          32768 kB
    HugePages_Total:       0
    Copy to clipboard

##### Watchdog configuration

A QEMU-emulated I6300 ESB watchdog device is supported in the guest VM.
The Linux kernel has a driver for this watchdog and exposes the standard watchdog character device.
To enable the watchdog, set `CONFIG_I6300ESB_WDT` in the guest kernel configuration.
A guest user space daemon must pet the watchdog.

The guest Libvirt XML has an option to select `poweroff` or `reset` on watchdog
timeout. For more information, see [Watchdog devices](https://libvirt.org/formatdomain.html#watchdog-devices).

Add the following snippet to the guest XML to enable I6300 ESB watchdog emulation in QEMU. The
default action is `reset`, which restarts the guest.

<devices>
      <watchdog model='i6300esb'/>
    </devices>
    Copy to clipboard

##### KVM traces

To enable KVM traces, run the following command:

echo 1 > /sys/kernel/tracing/events/kvm/enable
    Copy to clipboard

The KVM guest interactions are recorded in kernel function trace (ftrace).
To inspect interactions between KVM and guest VMs, read the kernel trace buffer.

QEMU also supports trace events, which can be redirected to kernel ftrace. For more information about how to redirect QEMU trace back-end events to the ftrace buffer, see [Trace backends](https://qemu-project.gitlab.io/qemu/devel/tracing.html#trace-backends). This option is selected by default in the Qualcomm Linux release.

To launch a guest VM with virtio traces enabled in the QEMU code, run the following command:

qemu-system-aarch64 \
        -M virt -m 2G \
        -kernel /mnt/overlay/guest/Image \
        -drive file=/mnt/overlay/guest/rootfs.ext4,if=virtio,format=raw \
        -append "root=/dev/vda" \
        -cpu host --enable-kvm -smp 4 -nographic \
        -trace "virtio*"
    Copy to clipboard

Last Published: Apr 10, 2025

[Previous Topic
Kernel features](https://docs.qualcomm.com/bundle/publicresource/80-70018-3/topics/features.md) [Next Topic
Real-time (RT) kernel overview](https://docs.qualcomm.com/bundle/publicresource/80-70018-3/topics/real_time_kernel_overview.md)