A carefully crafted OpenCore ISO image that makes creating macOS virtual machines on Proxmox VE and QEMU/KVM straightforward.
Completely redesigned from scratch with a clean, efficient architecture that eliminates outdated methods and legacy configurations.
Supports every Intel-based macOS release, from Mac OS X 10.4 Tiger through macOS 26 Tahoe.
Tip
Enjoy true vanilla macOS experience with no kernel patches. This is likely the best way to run macOS on AMD hardware while still retaining full hypervisor access to run other VMs.
- Download
- Quick Start Guide
- Post-Install
- macOS Tahoe Cursor Freeze Fix
- Contributing
- Credits
- License & Attribution
- Disclaimer
- Get the latest OpenCore-ISO: 👉 Release page
- For macOS installers and recovery ISOs: 👉 LongQT-sea/macos-iso-builder
Tip
Run Create_macOS_ISO.command inside your VM to download the full macOS installer from Apple and generate a proper DVD-format macOS installer ISO.
- VM ID: Any available ID
- Name: Any name you like for the macOS VM
- ISO Image: Select
LongQT-OpenCore-v0.X.iso - Guest OS Type: Leave as default (
Linux)
-
Machine Type: q35 (if using i440fx, add
+invtscCPU flag, see cpu-models.conf) -
BIOS: OVMF (UEFI)
-
Add EFI Disk: ✅ Enabled
-
Pre-Enroll Keys: ❌ Untick to disable Secure Boot
-
QEMU Guest Agent:
- ✅ Enable for macOS 10.14 – macOS 26
- ❌ Leave as default for macOS 10.4 – macOS 10.13
The disk bus type depends on your needs:
- VirtIO – Better performance
- SATA – Supports TRIM/Discard for more efficient storage usage
| macOS Version | Supports Bus Type |
|---|---|
| macOS 10.15 – macOS 26 | SATA / VirtIO Block |
| macOS 10.4 – macOS 10.14 | SATA |
Tip
Choosing SATA with ✅ SSD emulation and ✅ Discard enabled is recommended, as it automatically supports TRIM for more efficient storage usage.
Caution
Follow these CPU settings carefully! Incorrect CPU configuration will cause boot failure.
- Choose based on your hardware: 1 / 2 / 4 / 8 / 16 / 32 / 64
Tip
- For 6 cores: choose 2 cores and 3 sockets
- For 12 cores: choose 4 cores and 3 sockets
- For 20 cores: choose 4 cores and 5 sockets
- For 24 cores: choose 8 cores and 3 sockets
| macOS Version | Recommended CPU Type |
|---|---|
| macOS 10.11 – macOS 26 | Skylake-Client-v4, Skylake-Server-v4 (AVX-512) |
| macOS 10.4 – macOS 10.10 | Penryn |
Note
AMD CPUs:
-
macOS 10.4 – macOS 12, tick ✅ Advanced, under Extra CPU Flags, turn off
pcidandspec-ctrl. 1 -
macOS 13 – macOS 26, need to set the CPU manually via the Proxmox VE Shell2, example:
# For CPUs with AVX2 support qm set [VMID] --args "-cpu Skylake-Client-v4,vendor=GenuineIntel" # For CPUs with AVX-512 support qm set [VMID] --args "-cpu Skylake-Server-v4,vendor=GenuineIntel"
Intel CPUs:
-
Intel HEDT / E5-2xxx v3/v4 need to override CPUID
model3, example:qm set [VMID] --args "-cpu Broadwell-noTSX,vendor=GenuineIntel,model=158" qm set [VMID] --args "-cpu Haswell-noTSX,vendor=GenuineIntel,model=158" -
Intel Haswell desktops need to override
steppingwhen usingHaswell-noTSX4:qm set [VMID] --args "-cpu Haswell-noTSX,vendor=GenuineIntel,stepping=3" -
Avoid using
hostpassthrough CPU types5 — they can be ~30% slower (single-core) and ~44% slower (multi-core) compared torecommendedCPU types.
For more details, see QEMU CPU Guide – macOS Guests.
- RAM: Minimum 2 GB (4 GB or more recommended)
- Disable ❌ Ballooning Device
Choose the correct adapter based on macOS version:
| macOS Version | Network Adapter |
|---|---|
| macOS 11 – 26 | VirtIO (default) |
| macOS 10.11 – 10.15 | VMware vmxnet3 |
| macOS 10.4 – 10.10 | Intel E1000 |
Add an additional CD/DVD drive for the macOS installer or Recovery ISO, then start the VM to begin installation.
Tip
- First-time installing macOS? Format the disk in Disk Utility before installing macOS.
- Skip iCloud login during setup (configure it later, see Post-Install)
Got it running? Maybe give the repo a star... nah nevermind, do whatever.
If you encounter boot issues, check:
- Secure Boot is disabled (
Pre-Enroll Keysunchecked) - The ISO is mounted as a CD/DVD, not a disk
- Try a different CPU model
macOS 10.4 Tiger no-keyboard issue:
- Either add
-device usb-kbdto the QEMU args or rundevice_add usb-kbdin the VM Monitor tab.
- After macOS installation is complete, open
LongQT-OpenCoreon the Desktop and runMount_EFI.commandto mount the EFI partition on the macOS startup disk. - Copy the EFI folder from
LongQT-OpenCore/EFI_RELEASE/to the mounted EFI partition. This ensures that macOS will boot using the OpenCore EFI stored on the macOS startup disk in future startups. - Run
Install_Python3.commandto install Python 3, many apps and scripts need it. - Copy
Mount_EFI.command,ProperTree, andGenSMBIOSto the Desktop for later use when you need to editconfig.plist. - You can now remove the LongQT-OpenCore ISO CD/DVD from the VM Hardware tab.
- Follow Dortania iServices guide to generate your own SMBIOS.
- macOS 15 and macOS 26 need to install VMHide.kext
-
Pass through a supported Intel iGPU or dGPU:
- Intel iGPU passthrough: see LongQT-sea/intel-igpu-passthru
- dGPU passthrough: ensure you have a supported dGPU, see Dortania GPU Buyers Guide
Important
PCIe/dGPU passthrough on a q35 machine requires:
- Disable Resizable BAR / Smart Access Memory in UEFI/BIOS.
- Disable QEMU ACPI-based PCI hotplug (revert to native PCIe hotplug). Run this in the Proxmox shell:
clear; read -p "Enter your macOS VM ID number: " VMID; \
ARGS="$(qm config $VMID --current | grep ^args: | cut -d' ' -f2-)"; \
qm set $VMID -args "$ARGS -global ICH9-LPC.acpi-pci-hotplug-with-bridge-support=off"
Tip
If you need ReBAR enabled for another GPU then you need to set BAR 0 of the dGPU you want to passthrough to 256MB, e.g.
echo 8 > /sys/bus/pci/devices/0000:04:00.0/resource0_resize
For details on changing BAR size at the OS level, see: https://angrysysadmins.tech/index.php/2023/08/grassyloki/vfio-how-to-enable-resizeable-bar-rebar-in-your-vfio-virtual-machine/
Tip
On modern macOS versions, if you need a dummy virtual sound device (e.g., for Parsec, Sunshine/MoonLight), run this in Proxmox shell:
clear; read -p "Enter your macOS VM ID number: " VMID; \
ARGS="$(qm config $VMID --current | grep ^args: | cut -d' ' -f2-)"; \
qm set $VMID -args "$ARGS -device virtio-sound,audiodev=dummy -audiodev none,id=dummy"
Tip
To disable SIP, press Spacebar in the OpenCore boot menu and select the "Toggle SIP" option.
On macOS 26, the cursor may randomly freeze. A temporary workaround is to toggle Use tablet for pointer in VM’s Options tab.
A better fix is to use virtio-tablet-pci. To do this, disable Use tablet for pointer in VM’s Options tab, then run this in Proxmox shell:
clear; read -p "Enter your macOS VM ID number: " VMID; \
ARGS="$(qm config $VMID --current | grep ^args: | cut -d' ' -f2-)"; \
qm set $VMID -args "$ARGS -device virtio-tablet"
Note
With virtio-tablet-pci, middle-click on your real mouse acts as a right-click in the VM.
The most reliable solution is to passthrough a physical mouse and keyboard together with an iGPU or dGPU.
Alternatively, use a remote desktop solution, e.g. VNC Screen Sharing (Settings → General → Sharing) or Chrome Remote Desktop.
Contributions are welcome! Please feel free to submit a pull request. For major changes, open a Discussion first to discuss what you would like to change.
- Acidanthera team for OpenCorePkg and kexts.
- CorpNewt for ProperTree, GenSMBIOS.
- Dortania for comprehensive guides.
This project is licensed under the MIT License (see LICENSE file).
It also includes components from Acidanthera and other developers, each with their own licenses. All third-party components retain their original licenses.
If you create content using this project (videos, blog posts, tutorials, articles):
- Please link back to this repository:
https://github.com/LongQT-sea/OpenCore-ISO - Mention that detailed instructions are in this GitHub repo.
Thank you for respecting the work that went into this project!
This project is provided “as‑is”, without any warranties, and is intended for educational, research, and security testing purposes. In no event shall the authors or contributors be liable for any direct, indirect, incidental, special, or consequential damages arising from use of the project, even if advised of the possibility of such damages.
All product names, trademarks, and registered trademarks are property of their respective owners. All company, product, and service names used in this repository are for identification purposes only.
Footnotes
-
The
pcidandspec-ctrlflags are Intel-only CPU features. ↩ -
On macOS 13–26 running on AMD processors, these CPU flags
enforce,+kvm_pv_eoi,+kvm_pv_unhalt(the default in Proxmox) prevent macOS from booting, so we override them with custom-cpuargs. ↩ -
Override the CPUID model to one used in real Macs (e.g.,
model=158, which corresponds to the Coffee Lake CPUID model). ↩ -
QEMU Haswell-noTSX CPU model has
stepping=4, but macOS expects an earlier stepping (below 4). ↩ -
This is one of the main reasons I created this project. All other project use
hostwhen running on supported Intel CPUs. ↩