Drop the frankly misleading quickstart section for a more rounded introduction section. This new section gives an overview of the accelerators as well as a high level introduction to some of the key features of the emulator. We also expand on a general form for a QEMU command line with a hopefully not too scary worked example of what this looks like. Acked-by: Richard Henderson <richard.henderson@linaro.org> Signed-off-by: Alex Bennée <alex.bennee@linaro.org> Reviewed-by: Kashyap Chamarthy <kchamart@redhat.com> Message-Id: <20230124180127.1881110-23-alex.bennee@linaro.org>
		
			
				
	
	
		
			67 lines
		
	
	
		
			2.1 KiB
		
	
	
	
		
			ReStructuredText
		
	
	
	
	
	
			
		
		
	
	
			67 lines
		
	
	
		
			2.1 KiB
		
	
	
	
		
			ReStructuredText
		
	
	
	
	
	
| .. _Multi-process QEMU:
 | |
| 
 | |
| Multi-process QEMU
 | |
| ==================
 | |
| 
 | |
| This document describes how to configure and use multi-process qemu.
 | |
| For the design document refer to docs/devel/qemu-multiprocess.
 | |
| 
 | |
| 1) Configuration
 | |
| ----------------
 | |
| 
 | |
| multi-process is enabled by default for targets that enable KVM
 | |
| 
 | |
| 
 | |
| 2) Usage
 | |
| --------
 | |
| 
 | |
| Multi-process QEMU requires an orchestrator to launch.
 | |
| 
 | |
| Following is a description of command-line used to launch mpqemu.
 | |
| 
 | |
| * Orchestrator:
 | |
| 
 | |
|   - The Orchestrator creates a unix socketpair
 | |
| 
 | |
|   - It launches the remote process and passes one of the
 | |
|     sockets to it via command-line.
 | |
| 
 | |
|   - It then launches QEMU and specifies the other socket as an option
 | |
|     to the Proxy device object
 | |
| 
 | |
| * Remote Process:
 | |
| 
 | |
|   - QEMU can enter remote process mode by using the "remote" machine
 | |
|     option.
 | |
| 
 | |
|   - The orchestrator creates a "remote-object" with details about
 | |
|     the device and the file descriptor for the device
 | |
| 
 | |
|   - The remaining options are no different from how one launches QEMU with
 | |
|     devices.
 | |
| 
 | |
|   - Example command-line for the remote process is as follows:
 | |
| 
 | |
|       /usr/bin/qemu-system-x86_64                                        \
 | |
|       -machine x-remote                                                  \
 | |
|       -device lsi53c895a,id=lsi0                                         \
 | |
|       -drive id=drive_image2,file=/build/ol7-nvme-test-1.qcow2           \
 | |
|       -device scsi-hd,id=drive2,drive=drive_image2,bus=lsi0.0,scsi-id=0  \
 | |
|       -object x-remote-object,id=robj1,devid=lsi0,fd=4,
 | |
| 
 | |
| * QEMU:
 | |
| 
 | |
|   - Since parts of the RAM are shared between QEMU & remote process, a
 | |
|     memory-backend-memfd is required to facilitate this, as follows:
 | |
| 
 | |
|     -object memory-backend-memfd,id=mem,size=2G
 | |
| 
 | |
|   - A "x-pci-proxy-dev" device is created for each of the PCI devices emulated
 | |
|     in the remote process. A "socket" sub-option specifies the other end of
 | |
|     unix channel created by orchestrator. The "id" sub-option must be specified
 | |
|     and should be the same as the "id" specified for the remote PCI device
 | |
| 
 | |
|   - Example commandline for QEMU is as follows:
 | |
| 
 | |
|       -device x-pci-proxy-dev,id=lsi0,socket=3
 |