|  | Xen Device Emulation Backend (``xenpvh``) | 
|  | ========================================= | 
|  |  | 
|  | This machine is a little unusual compared to others as QEMU just acts | 
|  | as an IOREQ server to register/connect with Xen Hypervisor. Control of | 
|  | the VMs themselves is left to the Xen tooling. | 
|  |  | 
|  | When TPM is enabled, this machine also creates a tpm-tis-device at a | 
|  | user input tpm base address, adds a TPM emulator and connects to a | 
|  | swtpm application running on host machine via chardev socket. This | 
|  | enables xenpvh to support TPM functionalities for a guest domain. | 
|  |  | 
|  | More information about TPM use and installing swtpm linux application | 
|  | can be found in the :ref:`tpm-device` section. | 
|  |  | 
|  | Example for starting swtpm on host machine: | 
|  |  | 
|  | .. code-block:: console | 
|  |  | 
|  | mkdir /tmp/vtpm2 | 
|  | swtpm socket --tpmstate dir=/tmp/vtpm2 \ | 
|  | --ctrl type=unixio,path=/tmp/vtpm2/swtpm-sock & | 
|  |  | 
|  | Sample QEMU xenpvh commands for running and connecting with Xen: | 
|  |  | 
|  | .. code-block:: console | 
|  |  | 
|  | qemu-system-aarch64 -xen-domid 1 \ | 
|  | -chardev socket,id=libxl-cmd,path=qmp-libxl-1,server=on,wait=off \ | 
|  | -mon chardev=libxl-cmd,mode=control \ | 
|  | -chardev socket,id=libxenstat-cmd,path=qmp-libxenstat-1,server=on,wait=off \ | 
|  | -mon chardev=libxenstat-cmd,mode=control \ | 
|  | -xen-attach -name guest0 -vnc none -display none -nographic \ | 
|  | -machine xenpvh -m 1301 \ | 
|  | -chardev socket,id=chrtpm,path=tmp/vtpm2/swtpm-sock \ | 
|  | -tpmdev emulator,id=tpm0,chardev=chrtpm -machine tpm-base-addr=0x0C000000 | 
|  |  | 
|  | In above QEMU command, last two lines are for connecting xenpvh QEMU to swtpm | 
|  | via chardev socket. |