This section contains a brief rundown as to why the community has been transitioning over to OpenCore, and aims to dispel a few common myths in the community. Those who just want a macOS machine can skip this page.
[[toc]]
- More OS Support!
- OpenCore now supports more versions of OS X and macOS natively without painful hacks Clover and Chameleon had to implement
- This includes OSes as far back as 10.4, Tiger, and even the latest builds of 13, Ventura!
- On average, OpenCore systems boot faster than those using Clover as less unnecessary patching is done
- Better overall stability as patches can be much more precise:
- macOS 10.15.4 update
- AMD OSX patches not needing to update with every minor security update
- Better overall security in many forms:
- No need to disable System Integrity Protection (SIP)
- Built-in FileVault 2 support
- Vaulting allowing to create EFI snapshots preventing unwanted modifications
- True secure-boot support
- Both UEFI and Apple's variant
- BootCamp switching and boot device selection are supported by reading NVRAM variables set by Startup Disk, just like a real Mac.
- Supports boot hotkey via
boot.efi
- holdOption
orESC
at startup to choose a boot device,Cmd+R
to enter Recovery orCmd+Opt+P+R
to reset NVRAM.
The biggest reason someone may want to switch from other boot loaders is actually software support:
- Kexts no longer testing for Clover:
- Got a bug with a kext? Many developers including the organization Acidanthera (maker of most of your favorite kexts) won't provide support unless on OpenCore
- Many firmware drivers being merged into OpenCore:
The majority of Clover's functionality is actually supported in OpenCore in the form of some quirk, however when transitioning you should pay close attention to OpenCore's missing features as this may or may not affect yourself:
- Does not support booting MBR-based operating systems
- Work around is to chain-load rEFInd once in OpenCore
- Does not support UEFI-based VBIOS patching
- This can be done in macOS however
- Does not support automatic DeviceProperty injection for legacy GPUs
- ie. InjectIntel, InjectNVIDIA and InjectAti
- This can be done manually however: GPU patching
- Does not support IRQ conflict patching
- Can be resolved with SSDTTime
- Does not support P and C state generation for older CPUs
- Does not support Hardware UUID Injection
- Does not support many of Clover's XCPM patches
- ie. Ivy Bridge XCPM patches
- Does not support hiding specific drives
- Does not support changing settings within OpenCore's menu
- Does not patch PCIRoot UID value
- Does not support macOS-only ACPI patching
Short Answer: No
Long Answer: No
OpenCore's version number does not represent the quality of the project. Instead, it's more of a way to see the stepping stones of the project. Acidanthera still has much they'd like to do with the project including overall refinement and more feature support.
For example, OpenCore goes through proper security audits to ensure it complies with UEFI Secure Boot, and is the only Hackintosh bootloader to undergo these rigorous reviews and have such support.
Version 0.6.1 was originally designed to be the official release of OpenCore as it would have proper UEFI/Apple Secure Boot, and would be the 1 year anniversary of OpenCore's release as a public tool. However, due to circumstances around macOS Big Sur and the rewriting of OpenCore's prelinker to support it, it was decided to push off 1.0.0 for another year.
Current road map:
- 2019: Year of Beta
- 2020: Year of Secure Boot
- 2021: Year of Refinement
So please do not see the version number as a hindrance, instead as something to look forward to.
By default, OpenCore will assume that all OSes should be treated equally in regards to ACPI and SMBIOS information. The reason for this thinking consists of three parts:
- This allows for proper multiboot support, like with BootCamp
- Avoids poorly made DSDTs and encourages proper ACPI practices
- Avoids edge cases where info is injected several times, commonly seen with Clover
- i.e. How would you handle SMBIOS and ACPI data injection once you booted boot.efi, but then get kicked out? The changes are already in memory and so trying to undo them can be quite dangerous. This is why Clover's method is frowned upon.
However, there are quirks in OpenCore that allow for SMBIOS injection to be macOS-limited by patching where macOS reads SMBIOS info from. The CustomSMIOSGuid
quirk with CustomSMBIOSMode
set to Custom
can break in the future and so we only recommend this option in the event of certain software breaking in other OSes. For best stability, please disable these quirks.
Not at all in the event you have a "Vanilla" installation – what this refers to is whether the OS has tampered in any way, such as installing 3rd party kexts into the system volume or other unsupported modifications by Apple. When your system has been heavily tampered with, either by you or 3rd party utilities like Hackintool, we recommend a fresh install to avoid any potential issues.
Special note for Clover users: please reset your NVRAM when installing with OpenCore. Many of Clover variables can conflict with OpenCore and macOS.
- Note: Thinkpad laptops are known to be semi-bricked after an NVRAM reset in OpenCore, we recommend resetting NVRAM by updating the BIOS on these machines.
As of OpenCore 0.6.2, you can now boot every Intel version of macOS going all the way back to OS X 10.4! Proper support however will depend on your hardware, so please verify yourself: Hardware Limitations
::: details macOS Install Gallery
Acidanthera has tested many versions, and I myself have run many versions of OS X on my old HP DC 7900 (Core2 Quad Q8300). Here's just a small gallery of what I've tested:
:::
As of right now, the majority of Intel hardware is supported so long as the OS itself does! However please refer to the Hardware Limitations page for more info on what hardware is supported in what versions of OS X/macOS.
Currently, Intel's Yonah and newer series CPUs have been tested properly with OpenCore.
OpenCore will automatically detect Windows without any additional configuration. With OpenCore 0.7.3, OpenLinuxBoot was added to OpenCore as an EFI driver, which will automatically detect Linux partitions. This requires either ext4_x64.efi or btrfs_x64.efi depending on which format it used in your distro. For any OSes where their bootloader has an irregular path or name, you can simply add it to the BlessOverride section.
Where hackintoshing sits is in a legal grey area, mainly that while this is not illegal we are in fact breaking the EULA. The reason this is not illegal:
- We are downloading macOS from Apple's servers directly
- We are doing this as a non-profit organization for teaching and personal use
- People who plan to use their Hackintosh for work or want to resell them should refer to the Psystar case and their regional laws
While the EULA states that macOS should only be installed on real Macs or virtual machines running on genuine Macs (sections 2B-i and 2B-iii), there is no enforceable law that outright bans this. However, sites that repackage and modify macOS installers do potentially risk the issue of DMCA takedowns and such.
- Note: This is not legal advice, so please make the proper assessments yourself and discuss with your lawyers if you have any concerns.
Due to issues revolving around NVIDIA support in newer versions of macOS, many users come to the conclusion that macOS never supported NVIDIA GPUs. Apple supported Macs with NVIDIA GPUs (such as the 2013 MacBook Pro with a Kepler dGPU) until the release of Monterey Beta 7. While there are community-made patches to bring back support, they require SIP (System Integrity Protection) to be disabled, disabling important security features in macOS.
The other issue has to do with any newer NVIDIA GPUs, as Apple stopped shipping machines with them and thus they never had official OS support from Apple. Instead, users had to rely on NVIDIA for 3rd party drivers. Due to issues with Apple's newly introduced Secure Boot, they could no longer support the Web Drivers and thus NVIDIA couldn't publish them for newer platforms limiting them to mac OS 10.13, High Sierra.
For more info on OS support, see here: GPU Buyers Guide