- Add check_cocoa_gl_es_support(): detect QEMU cocoa gl=es support and look for ANGLE/libEGL in QEMU prefix, Homebrew and DYLD paths - Use the check in configure_display() to enable "gl=es" for cocoa when available and fall back to disabling GL (preserving previous stability behaviour) - Improve virtio GL selection: prefer virtio-gpu(-gl) / virtio-gpu-gl-pci / virtio-vga-gl variants when GL is enabled and QEMU exposes the device - Remove the hard disable of GL for cocoa in display_param_check() (now handled by the detection function) - Ensure user-visible display/GL/VirGL status remains printed for diagnostics Enables safer GL usage on macOS (covers Nix/Homebrew QEMU and ANGLE cases); falls back cleanly when support is absent. Signed-off-by: Martin Wimpress <martin@wimpress.org> |
||
|---|---|---|
| .github | ||
| build-docs@c5907eae9c | ||
| debian | ||
| docs | ||
| .editorconfig | ||
| .envrc | ||
| .gitignore | ||
| .gitmodules | ||
| AGENTS.md | ||
| CODE_OF_CONDUCT.md | ||
| CONTRIBUTING.md | ||
| LICENSE | ||
| README.md | ||
| SECURITY.md | ||
| chunkcheck | ||
| devshell.nix | ||
| flake.lock | ||
| flake.nix | ||
| package.nix | ||
| quickemu | ||
| quickget | ||
| quickreport | ||
README.md
Quickemu
Quickly create and run optimised Windows, macOS and Linux virtual machines:
Made with 💝 for
& ![]()
Introduction
Quickemu is a wrapper for the excellent QEMU that automatically "does the right thing" when creating virtual machines. No requirement for exhaustive configuration options. You decide what operating system you want to run and Quickemu takes care of the rest 🤖
quickgetautomatically downloads the upstream OS and creates the configuration 📀quickemuenumerates your hardware and launches the virtual machine with the optimum configuration best suited to your computer ⚡️
The original objective of the project was to enable quick testing of Linux distributions where the virtual machines and their configuration can be stored anywhere (such as external USB storage or your home directory) and no elevated permissions are required to run the virtual machines.
Today, Quickemu includes comprehensive support for macOS, Windows, most of the BSDs, novel non-Linux operating systems such as FreeDOS, Haiku, KolibriOS, OpenIndiana, ReactOS, and more.
Features
- Host support for Linux and macOS
- macOS Sequoia, Sonoma, Ventura, Monterey, Big Sur, Catalina & Mojave
- Windows 10 and 11 including TPM 2.0
- Windows Server 2022 2019 2016
- Ubuntu and all the official Ubuntu flavours
- Nearly 1000 operating system editions are supported!
- Full SPICE support including host/guest clipboard sharing
- VirtIO-webdavd file sharing for Linux and Windows guests
- VirtIO-9p file sharing for Linux and macOS guests
- QEMU Guest Agent support; provides access to a system-level agent via standard QMP commands
- Samba file sharing for Linux, macOS and Windows guests (if
smbdis installed on the host) - VirGL acceleration
- USB device pass-through
- Smartcard pass-through
- Automatic SSH port forwarding to guests
- Network port forwarding
- Full duplex audio
- Braille support
- EFI (with or without SecureBoot) and Legacy BIOS boot
As featured on Linux Matters podcast!
The presenters of Linux Matters 🐧🎙️ are the creators of each of the principal Quickemu projects. We discussed Quickemu's 2024 reboot in Episode 30 - Quickemu Rising From the Bashes.
Quick start
Once Quickemu is installed, there are two simple steps to create and run a virtual machine:
quickgetautomatically downloads the ISO image for the operating system you want to run and creates a configuration file for the virtual machine.
quickget nixos unstable minimal
quickemustarts the virtual machine using the configuration file created byquickget.
quickemu --vm nixos-unstable-minimal.conf
Execute quickget (with no arguments) to see a list of all the supported operating systems.
Demo
Documentation
The wiki describes how to get up and running with Quickemu and also covers more advanced configuration and usage.
