 06ecb6ac19
			
		
	
	
		06ecb6ac19
		
	
	
	
	
		
			
			I noticed the code blocks where not rendering properly so thought I'd better fix things up. So: - Use better title for the machine type - Explain why Xen is a little different - Add a proper anchor to the tpm-device link - add newline so code block properly renders - add some indentation to make continuation clearer Signed-off-by: Alex Bennée <alex.bennee@linaro.org> Signed-off-by: Stefan Hajnoczi <stefanha@redhat.com> Message-ID: <20231207130623.360473-1-alex.bennee@linaro.org>
		
			
				
	
	
		
			40 lines
		
	
	
		
			1.5 KiB
		
	
	
	
		
			ReStructuredText
		
	
	
	
	
	
			
		
		
	
	
			40 lines
		
	
	
		
			1.5 KiB
		
	
	
	
		
			ReStructuredText
		
	
	
	
	
	
| 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.
 |