2023-10-16 18:02:02 +00:00
|
|
|
.\" Automatically generated by Pandoc 3.1.8
|
2022-02-25 23:03:58 +00:00
|
|
|
.\"
|
2023-10-18 16:07:42 +00:00
|
|
|
.TH "QUICKEMU_CONF" "1" "October 18, 2023" "quickemu_conf" "Quickemu Configuration Manual"
|
2022-02-25 23:03:58 +00:00
|
|
|
.SH NAME
|
|
|
|
quickemu_conf - Options and parameters in the quickemu <vm>.conf
|
|
|
|
.SH DESCRIPTION
|
|
|
|
\f[B]quickemu\f[R] will create and run highly optimised desktop virtual
|
|
|
|
machines for Linux, macOS and Windows.
|
|
|
|
It uses sensible defaults, but many configuration options can be
|
|
|
|
overridden in the required configuration file, which will as a minimum
|
|
|
|
specify the path to the installation ISO and QEMU disk for the installed
|
|
|
|
VM
|
|
|
|
.SH OPTIONS
|
|
|
|
These are the options and defaults for the <vm>.conf file
|
|
|
|
.IP
|
2023-10-16 18:02:02 +00:00
|
|
|
.EX
|
2022-02-25 23:03:58 +00:00
|
|
|
# Lowercase variables are used in the VM config file only
|
|
|
|
boot=\[dq]efi\[dq]
|
|
|
|
cpu_cores=\[dq]\[dq]
|
|
|
|
disk_img=\[dq]\[dq]
|
|
|
|
disk_size=\[dq]\[dq]
|
2023-02-03 18:04:57 +00:00
|
|
|
display=\[dq]\[dq]
|
|
|
|
extra_args=\[dq]\[dq]
|
2022-02-25 23:03:58 +00:00
|
|
|
fixed_iso=\[dq]\[dq]
|
|
|
|
floppy=\[dq]\[dq]
|
|
|
|
guest_os=\[dq]linux\[dq]
|
|
|
|
img=\[dq]\[dq]
|
|
|
|
iso=\[dq]\[dq]
|
2022-08-19 21:36:32 +00:00
|
|
|
macaddr=\[dq]\[dq]
|
2022-02-25 23:03:58 +00:00
|
|
|
macos_release=\[dq]\[dq]
|
2022-08-19 21:36:32 +00:00
|
|
|
network=\[dq]\[dq]
|
2022-02-25 23:03:58 +00:00
|
|
|
port_forwards=()
|
|
|
|
preallocation=\[dq]off\[dq]
|
|
|
|
ram=\[dq]\[dq]
|
|
|
|
secureboot=\[dq]off\[dq]
|
|
|
|
tpm=\[dq]off\[dq]
|
|
|
|
usb_devices=()
|
2023-02-03 18:04:57 +00:00
|
|
|
viewer=\[dq]spicy\[dq]
|
|
|
|
ssh_port=\[dq]\[dq]
|
|
|
|
spice_port=\[dq]\[dq]
|
|
|
|
public_dir=\[dq]\[dq]
|
|
|
|
monitor=\[dq]socket\[dq]
|
|
|
|
monitor_telnet_port=\[dq]4440\[dq]
|
|
|
|
monitor_telnet_host=\[dq]localhost\[dq]
|
|
|
|
monitor_cmd=\[dq]\[dq]
|
|
|
|
serial=\[dq]socket\[dq]
|
|
|
|
serial_telnet_port=\[dq]6660\[dq]
|
|
|
|
serial_telnet_host=\[dq]localhost\[dq]
|
|
|
|
# options: ehci(USB2.0), xhci(USB3.0)
|
|
|
|
usb_controller=\[dq]ehci\[dq]
|
|
|
|
# options: ps2, usb, virtio
|
|
|
|
keyboard=\[dq]usb\[dq]
|
|
|
|
keyboard_layout=\[dq]en-us\[dq]
|
|
|
|
# options: ps2, usb, tablet, virtio
|
|
|
|
mouse=\[dq]tablet\[dq]
|
2023-10-16 18:02:02 +00:00
|
|
|
.EE
|
2022-02-25 23:03:58 +00:00
|
|
|
.SH EXAMPLES
|
|
|
|
.IP
|
2023-10-16 18:02:02 +00:00
|
|
|
.EX
|
2022-02-25 23:03:58 +00:00
|
|
|
guest_os=\[dq]linux\[dq]
|
|
|
|
disk_img=\[dq]debian-bullseye/disk.qcow2\[dq]
|
|
|
|
iso=\[dq]debian-bullseye/firmware-11.0.0-amd64-DVD-1.iso\[dq]
|
2023-10-16 18:02:02 +00:00
|
|
|
.EE
|
2022-02-25 23:03:58 +00:00
|
|
|
.PP
|
|
|
|
The default macOS configuration looks like this:
|
|
|
|
.IP
|
2023-10-16 18:02:02 +00:00
|
|
|
.EX
|
2022-02-25 23:03:58 +00:00
|
|
|
guest_os=\[dq]macos\[dq]
|
|
|
|
img=\[dq]macos-catalina/RecoveryImage.img\[dq]
|
|
|
|
disk_img=\[dq]macos-catalina/disk.qcow2\[dq]
|
|
|
|
macos_release=\[dq]catalina\[dq]
|
2023-10-16 18:02:02 +00:00
|
|
|
.EE
|
2022-02-25 23:03:58 +00:00
|
|
|
.IP \[bu] 2
|
2023-10-16 18:02:02 +00:00
|
|
|
\f[CR]guest_os=\[dq]macos\[dq]\f[R] instructs Quickemu to optimise for
|
2022-02-25 23:03:58 +00:00
|
|
|
macOS.
|
|
|
|
.IP \[bu] 2
|
2023-10-16 18:02:02 +00:00
|
|
|
\f[CR]macos_release=\[dq]catalina\[dq]\f[R] instructs Quickemu to
|
2022-02-25 23:03:58 +00:00
|
|
|
optimise for a particular macOS release.
|
|
|
|
.RS 2
|
|
|
|
.IP \[bu] 2
|
|
|
|
For example VirtIO Network and Memory Ballooning are available in Big
|
|
|
|
Sur and newer, but not previous releases.
|
|
|
|
.IP \[bu] 2
|
|
|
|
And VirtIO Block Media (disks) are supported/stable in Catalina and
|
|
|
|
newer.
|
|
|
|
.RE
|
|
|
|
.PP
|
|
|
|
The default Windows 11 configuration looks like this:
|
|
|
|
.IP
|
2023-10-16 18:02:02 +00:00
|
|
|
.EX
|
2022-02-25 23:03:58 +00:00
|
|
|
guest_os=\[dq]windows\[dq]
|
|
|
|
disk_img=\[dq]windows-11/disk.qcow2\[dq]
|
|
|
|
iso=\[dq]windows-11/Win11_EnglishInternational_x64.iso\[dq]
|
|
|
|
fixed_iso=\[dq]windows-11/virtio-win.iso\[dq]
|
|
|
|
tpm=\[dq]on\[dq]
|
2022-08-19 21:36:32 +00:00
|
|
|
secureboot=\[dq]on\[dq]
|
2023-10-16 18:02:02 +00:00
|
|
|
.EE
|
2022-02-25 23:03:58 +00:00
|
|
|
.IP \[bu] 2
|
2023-10-16 18:02:02 +00:00
|
|
|
\f[CR]guest_os=\[dq]windows\[dq]\f[R] instructs \f[CR]quickemu\f[R] to
|
2022-02-25 23:03:58 +00:00
|
|
|
optimise for Windows.
|
|
|
|
.IP \[bu] 2
|
2023-10-16 18:02:02 +00:00
|
|
|
\f[CR]fixed_iso=\f[R] specifies the ISO image that provides VirtIO
|
2022-02-25 23:03:58 +00:00
|
|
|
drivers.
|
|
|
|
.IP \[bu] 2
|
2023-10-16 18:02:02 +00:00
|
|
|
\f[CR]tpm=\[dq]on\[dq]\f[R] instructs \f[CR]quickemu\f[R] to create a
|
|
|
|
software emulated TPM device using \f[CR]swtpm\f[R].
|
2022-02-25 23:03:58 +00:00
|
|
|
.SH BIOS and EFI
|
2023-10-16 18:02:02 +00:00
|
|
|
Since Quickemu 2.1.0 \f[CR]efi\f[R] is the default boot option.
|
2022-02-25 23:03:58 +00:00
|
|
|
If you want to override this behaviour then add the following line to
|
|
|
|
you VM configuration to enable legacy BIOS.
|
|
|
|
.IP \[bu] 2
|
2023-10-16 18:02:02 +00:00
|
|
|
\f[CR]boot=\[dq]legacy\[dq]\f[R] - Enable Legacy BIOS boot
|
2022-02-25 23:03:58 +00:00
|
|
|
.SH Tuning CPU cores, RAM & disks
|
|
|
|
By default, Quickemu will calculate the number of CPUs cores and RAM to
|
|
|
|
allocate to a VM based on the specifications of your host computer.
|
|
|
|
You can override this default behaviour and tune the VM configuration to
|
|
|
|
your liking.
|
|
|
|
.PP
|
|
|
|
Add additional lines to your virtual machine configuration:
|
|
|
|
.IP \[bu] 2
|
2023-10-16 18:02:02 +00:00
|
|
|
\f[CR]cpu_cores=\[dq]4\[dq]\f[R] - Specify the number of CPU cores
|
2022-02-25 23:03:58 +00:00
|
|
|
allocated to the VM
|
|
|
|
.IP \[bu] 2
|
2023-10-16 18:02:02 +00:00
|
|
|
\f[CR]ram=\[dq]4G\[dq]\f[R] - Specify the amount of RAM to allocate to
|
2022-02-25 23:03:58 +00:00
|
|
|
the VM
|
|
|
|
.IP \[bu] 2
|
2023-10-16 18:02:02 +00:00
|
|
|
\f[CR]disk_size=\[dq]16G\[dq]\f[R] - Specify the size of the virtual
|
|
|
|
disk allocated to the VM
|
2022-02-25 23:03:58 +00:00
|
|
|
.SS Disk preallocation
|
2023-10-16 18:02:02 +00:00
|
|
|
Preallocation mode (allowed values: \f[CR]off\f[R] (default),
|
|
|
|
\f[CR]metadata\f[R], \f[CR]falloc\f[R], \f[CR]full\f[R]).
|
2022-02-25 23:03:58 +00:00
|
|
|
An image with preallocated metadata is initially larger but can improve
|
|
|
|
performance when the image needs to grow.
|
|
|
|
.PP
|
|
|
|
Specify what disk preallocation should be used, if any, when creating
|
|
|
|
the system disk image by adding a line like this to your VM
|
|
|
|
configuration.
|
|
|
|
.IP \[bu] 2
|
2023-10-16 18:02:02 +00:00
|
|
|
\f[CR]preallocation=\[dq]metadata\[dq]\f[R]
|
2022-02-25 23:03:58 +00:00
|
|
|
.SS CD-ROM disks
|
|
|
|
If you want to expose an ISO image from the host to guest add the
|
|
|
|
following line to the VM configuration:
|
|
|
|
.IP \[bu] 2
|
2023-10-16 18:02:02 +00:00
|
|
|
\f[CR]fixed_iso=\[dq]/path/to/image.iso\[dq]\f[R]
|
2022-02-25 23:03:58 +00:00
|
|
|
.SS Floppy disks
|
|
|
|
If you\[cq]re like Alan Pope (https://popey.com) you\[cq]ll probably
|
|
|
|
want to mount a floppy disk image in the guest.
|
|
|
|
To do so add the following line to the VM configuration:
|
|
|
|
.IP \[bu] 2
|
2023-10-16 18:02:02 +00:00
|
|
|
\f[CR]floppy=\[dq]/path/to/floppy.img\[dq]\f[R]
|
2022-02-25 23:03:58 +00:00
|
|
|
.SH File Sharing
|
2023-10-16 18:02:02 +00:00
|
|
|
All File Sharing options will only expose \f[CR]\[ti]/Public\f[R] (or
|
2022-02-25 23:03:58 +00:00
|
|
|
localised variations) for the current user to the guest VMs.
|
2023-06-14 10:25:36 +00:00
|
|
|
.SS Samba 🐧 🍏 🪟
|
2023-10-16 18:02:02 +00:00
|
|
|
If \f[CR]smbd\f[R] is available on the host, Quickemu will automatically
|
2022-02-25 23:03:58 +00:00
|
|
|
enable the built-in QEMU support for exposing a Samba share from the
|
|
|
|
host to the guest.
|
|
|
|
.PP
|
|
|
|
You can install the minimal Samba components on Ubuntu using:
|
|
|
|
.IP
|
2023-10-16 18:02:02 +00:00
|
|
|
.EX
|
2022-02-25 23:03:58 +00:00
|
|
|
sudo apt install --no-install-recommends samba
|
2023-10-16 18:02:02 +00:00
|
|
|
.EE
|
2022-07-30 06:56:23 +00:00
|
|
|
.PP
|
2023-10-16 18:02:02 +00:00
|
|
|
If everything is set up correctly, the \f[CR]smbd\f[R] address will be
|
2022-07-30 06:56:23 +00:00
|
|
|
printed when the virtual machine is started.
|
|
|
|
For example:
|
|
|
|
.IP
|
2023-10-16 18:02:02 +00:00
|
|
|
.EX
|
2022-07-30 06:56:23 +00:00
|
|
|
- smbd: On guest: smb://10.0.2.4/qemu
|
2023-10-16 18:02:02 +00:00
|
|
|
.EE
|
2022-07-30 06:56:23 +00:00
|
|
|
.PP
|
|
|
|
If using a Windows guest, right-click on \[lq]This PC\[rq], click
|
|
|
|
\[lq]Add a network location\[rq], and paste this address, removing
|
2023-10-16 18:02:02 +00:00
|
|
|
\f[CR]smb:\f[R] and replacing forward slashes with backslashes (in this
|
|
|
|
example \f[CR]\[rs]\[rs]10.0.2.4\[rs]qemu\f[R]).
|
2023-06-14 10:25:36 +00:00
|
|
|
.SS SPICE WebDAV 🐧 🪟
|
2022-02-25 23:03:58 +00:00
|
|
|
.IP \[bu] 2
|
|
|
|
TBD
|
2023-06-14 10:25:36 +00:00
|
|
|
.SS VirtIO-9P 🐧 🍏
|
2022-02-25 23:03:58 +00:00
|
|
|
.IP \[bu] 2
|
|
|
|
TBD
|
|
|
|
.SH Network port forwarding
|
|
|
|
Add an additional line to your virtual machine configuration.
|
|
|
|
For example:
|
|
|
|
.IP \[bu] 2
|
2023-10-16 18:02:02 +00:00
|
|
|
\f[CR]port_forwards=(\[dq]8123:8123\[dq] \[dq]8888:80\[dq])\f[R]
|
2022-02-25 23:03:58 +00:00
|
|
|
.PP
|
|
|
|
In the example above:
|
|
|
|
.IP \[bu] 2
|
|
|
|
Port 8123 on the host is forwarded to port 8123 on the guest.
|
|
|
|
.IP \[bu] 2
|
|
|
|
Port 8888 on the host is forwarded to port 80 on the guest.
|
2022-08-19 19:10:21 +00:00
|
|
|
.SH Disable networking
|
|
|
|
To completely disable all network interfaces in a guest VM add this
|
|
|
|
additional line to your virtual machine configuration:
|
|
|
|
.IP \[bu] 2
|
2023-10-16 18:02:02 +00:00
|
|
|
\f[CR]network=\[dq]none\[dq]\f[R]
|
2022-08-19 19:10:21 +00:00
|
|
|
.SH Restricted networking
|
|
|
|
You can isolate the guest from the host (and broader network) using the
|
|
|
|
restrict option, which will restrict networking to just the guest and
|
|
|
|
any virtual devices.
|
|
|
|
.PP
|
|
|
|
This can be used to prevent software running inside the guest from
|
|
|
|
phoning home while still providing a network inside the guest.
|
|
|
|
Add this additional line to your virtual machine configuration:
|
|
|
|
.IP \[bu] 2
|
2023-10-16 18:02:02 +00:00
|
|
|
\f[CR]network=\[dq]restrict\[dq]\f[R]
|
2022-02-25 23:03:58 +00:00
|
|
|
.SH Bridged networking
|
|
|
|
Connect your virtual machine to a preconfigured network bridge.
|
2022-08-19 21:36:32 +00:00
|
|
|
Add an additional line to your virtual machine configuration:
|
2022-02-25 23:03:58 +00:00
|
|
|
.IP \[bu] 2
|
2023-10-16 18:02:02 +00:00
|
|
|
\f[CR]network=\[dq]br0\[dq]\f[R]
|
2022-08-19 21:36:32 +00:00
|
|
|
.PP
|
|
|
|
If you want to have a persistent MAC address for your bridged network
|
2023-10-16 18:02:02 +00:00
|
|
|
interface in the guest VM you can add \f[CR]macaddr\f[R] to the virtual
|
2022-08-19 21:36:32 +00:00
|
|
|
machine configuration.
|
|
|
|
QEMU requires that the MAC address is in the range:
|
|
|
|
\f[B]52:54:00:AB:00:00 - 52:54:00:AB:FF:FF\f[R]
|
|
|
|
.PP
|
|
|
|
So you can generate your own MAC addresses with:
|
|
|
|
.IP \[bu] 2
|
2023-10-16 18:02:02 +00:00
|
|
|
\f[CR]macaddr=\[dq]52:54:00:AB:51:AE\[dq]\f[R]
|
2022-02-25 23:03:58 +00:00
|
|
|
.SH USB redirection
|
|
|
|
Quickemu supports USB redirection via SPICE pass-through and host
|
|
|
|
pass-through.
|
|
|
|
.SS SPICE redirection (recommended)
|
|
|
|
Using SPICE for USB pass-through is easiest as it doesn\[cq]t require
|
2023-10-16 18:02:02 +00:00
|
|
|
any elevated permission, start Quickemu with \f[CR]--display spice\f[R]
|
|
|
|
and then select \f[CR]Input\f[R] ->
|
|
|
|
\f[CR]Select USB Device for redirection\f[R] from the menu to choose
|
2022-02-25 23:03:58 +00:00
|
|
|
which device(s) you want to attach to the guest.
|
|
|
|
.SS Host redirection \f[B]NOT Recommended\f[R]
|
|
|
|
\f[B]USB host redirection is not recommended\f[R], it is provided purely
|
|
|
|
for backwards compatibility to older versions of Quickemu.
|
|
|
|
Using SPICE is preferred, see above.
|
|
|
|
.PP
|
|
|
|
Add an additional line to your virtual machine configuration.
|
|
|
|
For example:
|
|
|
|
.IP \[bu] 2
|
2023-10-16 18:02:02 +00:00
|
|
|
\f[CR]usb_devices=(\[dq]046d:082d\[dq] \[dq]046d:085e\[dq])\f[R]
|
2022-02-25 23:03:58 +00:00
|
|
|
.PP
|
|
|
|
In the example above:
|
|
|
|
.IP \[bu] 2
|
|
|
|
The USB device with vendor_id 046d and product_id 082d will be exposed
|
|
|
|
to the guest.
|
|
|
|
.IP \[bu] 2
|
|
|
|
The USB device with vendor_id 046d and product_id 085e will be exposed
|
|
|
|
to the guest.
|
|
|
|
.PP
|
2023-10-16 18:02:02 +00:00
|
|
|
If the USB devices are not writable, \f[CR]quickemu\f[R] will display
|
|
|
|
the appropriate commands to modify the USB device(s) access permissions,
|
2022-02-25 23:03:58 +00:00
|
|
|
like this:
|
|
|
|
.IP
|
2023-10-16 18:02:02 +00:00
|
|
|
.EX
|
2022-02-25 23:03:58 +00:00
|
|
|
- USB: Host pass-through requested:
|
|
|
|
- Sennheiser Communications EPOS GTW 270 on bus 001 device 005 needs permission changes:
|
|
|
|
sudo chown -v root:user /dev/bus/usb/001/005
|
2023-06-14 10:25:36 +00:00
|
|
|
ERROR! USB permission changes are required 👆
|
2023-10-16 18:02:02 +00:00
|
|
|
.EE
|
2022-02-25 23:03:58 +00:00
|
|
|
.SH TPM
|
|
|
|
Since Quickemu 2.2.0 a software emulated TPM device can be added to
|
|
|
|
guest virtual machines.
|
2023-10-16 18:02:02 +00:00
|
|
|
Just add \f[CR]tpm=\[dq]on\[dq]\f[R] to your VM configuration.
|
|
|
|
\f[CR]quickget\f[R] will automatically add this line to Windows 11
|
2022-02-25 23:03:58 +00:00
|
|
|
virtual machines.
|
|
|
|
.SH AUTHORS
|
|
|
|
Written by Martin Wimpress.
|
|
|
|
.SH BUGS
|
|
|
|
Submit bug reports online at:
|
|
|
|
<https://github.com/quickemu-project/quickemu/issues>
|
|
|
|
.SH SEE ALSO
|
|
|
|
Full sources at: <https://github.com/quickemu-project/quickemu>
|
|
|
|
.PP
|
|
|
|
quickget(1), quickemu(1), quickgui(1)
|
|
|
|
.SH AUTHORS
|
|
|
|
Martin Wimpress.
|