Used OpenCore version: 1.0.2
This EFI is compatible with all Ryzen and Athlon 2xxGE processors with macOS-compatible peripherals.
Support for 15h (FX series), 16h (A series) and Threadripper CPUs is not covered here.
Model | Compatible? |
---|---|
Integrated | No |
Nvidia | Partially 1 |
AMD | Yes 2 3 |
1 Support for Nvidia GPUs was dropped in Monterey Beta 7, the only way to get it back is using OpenCore Legacy Patcher. Kepler series under correct PAT Patch. Others require WebDrivers which work only in High Sierra or are not supported. More details on Dortania.
2 Some R7 and R9 GPUs require FakeID. More details here
3 Lexa series GPUs are not supported. Older than 7000 series are supported up to High Sierra (10.13), their support is not covered here.
For AMD Navi 10 and 20 Series GPUs (RX 5000 and RX 6000) you need to add agdpmod=pikera
to boot-args
to fix the black screen issue.
PAT Patch made by Shaneee is used by default. It improves GPU performance but it has a few caveats. Audio passed by HDMI or DisplayPort won't work or will be unstable. It also may not work with Nvidia GPUs.
If you want to control monitor's brightness or HDMI/DP audio volume you need to use MonitorControl for that.
All laptops with AMD CPUs are not supported due to integrated GPUs incompatbility.
Chipset/Socket | Details |
---|---|
B550, A520 | Requires SSDT-CPUR to boot. Details here. |
B550, A520, B450, X470, X570 | SetupVirtualMap has to be disabled. |
Older than A520, B550, X570 | May require disabling Disable 10 bit tags patch |
AM5 with Thunderbolt/USB4 | It's complicated 1 |
Other | Should be compatible out of the box. |
1 On AM5 motherboards with on-board Thunderbolt/USB4 macOS Ventura and newer may not enumerate devices on the PCI bus properly when on-board WiFi and on-board Thunderbolt are both enabled. Patch Fix PCI bus enumeration on AM5
bypasses the problem. This patch is disabled by default.
Follow these steps to properly install SSDT-CPUR.
OC/ACPI
directory.On AM5 motherboards with on-board Thunderbolt/USB4, macOS Ventura may not enumerate devices on the PCI bus properly when on-board WiFi and on-board Thunderbolt are both enabled. Patch CaseySJ | IOPCIIsHotplugPort | Fix PCI bus enumeration on AM5 | 13.0+
bypasses the problem. This patch is disabled by default. If you have described issue you have to enable this patch.
To disable SetupVirtualMap
simply go to Booter -> Quirks -> SetupVirtualMap
in your configuration file and disable it. (Should be false
).
If you have the Above 4G Decoding
option in your BIOS settings, enable it and remove the npci=0x2000
parameter from the boot-args
(NVRAM section).
If you have the Resizable BAR
option in your BIOS settings and your GPU supports it, you can enable it for better GPU performance. Then, set Booter -> Quirks -> ResizeAppleGpuBars
to 0
.
If you experience issues related to Secure Boot in the macOS installer, set Misc -> Security -> SecureBootModel
to Disabled
. After installation, you can set it to the value corresponding to the used SMBIOS. Look here for more information.
Follow these steps if your audio chipset is different than the one specified in the Specification.
boot-args
settings and look for alcid=11
.alcid=10
if layout 10
Caveats:
If you experience any issues with your network connection, then your best bet would be to install a different kext, preferably from here.
If you use High Sierra and Realtek 8111 Ethernet Card then you should use older version of kext.
If you have issues with network card on Monterey or newer try adding e1000=0
to boots-args
.
SmallTree kext does not work on Monterey for now. You can try AppleIGB kext, it works on some systems. If it does not work you have to stay on Big Sur and wait for SmallTree's update.
Only Apple Airport and Fenvi cards work out of the box. Here you can list of all supported cards and needed kexts for them.
Rembember that AirDrop, Handoff, etc. works only on cards with Broadcom chip.
Option | Status |
---|---|
SATA Mode | AHCI |
Above 4G Decoding | Enabled 1 |
EHCI/XHCI Hand-off | Enabled |
SVM | Enabled |
CSM | Disabled |
Secure Boot | Disabled |
Serial Port | Disabled |
Parallel Port | Disabled |
1 If you have this option in BIOS you must also remove npci=0x2000
from boot-args
in your configuration file.
Some of these options may not exist in your firmware, just try to match it as closely as possible.
Before booting macOS remember to update BIOS to the latest version.
Follow this guide to create your bootable USB.
Clone this repository and copy "BOOT" & "OC" directories to your "EFI" directory on your bootable USB. The structure should look somewhat like this: EFI -> BOOT, OC
.
Modify Core Count patches to match your CPU's cores amount.
Find four algrey - Force cpuid_cores_per_package
patches under Kernel -> Patch
in your config.
Modify these patches for your CPU physical cores. Change first pair of 00
in Replace
of these patches to Hex value
from below table.
e. g. for Ryzen 7 1700 with 8 Cores three modified patches should look like:
Physical CPU cores | Hex value |
---|---|
4 Cores | 04 |
6 Cores | 06 |
8 Cores | 08 |
12 Cores | 0C |
16 Cores | 10 |
24 Cores | 18 |
32 Cores | 20 |
SMBIOS has to be unique, you cannot use one present in this repository.
Run the tool and select Generate SMBIOS
.
Select the appropriate model for your hardware using the table below.
Go to Apple Coverage and paste generated Serial. You need "Invalid Serial" or "Purchase Date not Validated" message. If you get something another you have to generate SMBIOS data and check it again.
Open config.plist and search for PlatformInfo -> Generic
and replace these values:
ROM entry should be set to your network card's MAC address, without separators (e. g. :
, -
).
GPU Series | Model |
---|---|
AMD Navi Series | iMacPro1,1 1 |
AMD Vega Series | iMacPro1,1 1 |
AMD Polaris Series | iMacPro1,1 1 |
AMD Radeon R5/R7/R9 | MacPro6,1 |
AMD HD 8000 Series | MacPro6,1 |
AMD HD 7000 Series | MacPro6,1 |
Nvidia Kepler Series | MacPro7,1 2 |
1 For Catalina and newer you can also use MacPro7,1
if you have some issues (e. g. unfixable DRMs).
2 For Catalina and older use iMac14,2
.
Unknown
instead of your CPU name in About this Mac go to PlatformInfo -> Generic -> ProcessorType
in your configuration file. Set it to 3841
if your CPU has 8 or more physical cores, else set it to 1537
.-v debug=0x100 keepsyms=1
from boot-args
in your configuration file.In general, enabling Bootstrap is not required, but it will protect your OpenCore from being overriden. \ Remember to do not enable Bootstrap on pendrive - do it only after copying OpenCore to your disk's EFI.
Misc -> Boot -> LauncherOption
in your configuration file and set it to Full
.OpenCore
. Set BIOS to boot from it, instead of your drive.Shaneee's | Algrey's |
---|---|
Much better GPU performance | Worse GPU performance |
May not work with Nvidia GPUs | Compatible with all GPUs |
HDMI/DP audio may not work | HDMI/DP audio works |
Enabled by default | Disabled by default |
To switch to another patch look for fix PAT
in config.plist
. There are two versions of these patches. macOS 15 (Sequoia) has it's own PAT patch. Then set Enabled
to true
for the patch you want to use for your macOS version. Remember to set Enabled
to false
on the other PAT patch. Do not try to enable both at the same time, trust me, it won't work.
Some applications for macOS use MKL - Math Kernel Library. Unfortunately, it does not work on AMD CPUs natively - we need to patch it with this script.
There's also intel_fast_memset
instruction which, obviously, doesn't exist on AMD systems. It's very common in Adobe software - you can simply fix it by running this script. Older versions of Adobe software (e. g. up to 22.3.1 for Photoshop) need it's legacy version. For details about Adobe patching check thead on macos86.it.
If you have problems while running script from file, try to copy and paste it's code to Terminal.
DRMs are fixed by default only for Big Sur and newer versions. For older versions you have to:
unfairgva=1
from boot-args
in your configuration file.boot-args
in your configuration file.
shikigva=80
or shikigva=16
- it's common to work even when chart says something another.Firstly, check if your sleep works out of the box. If it works, you can skip reading this section.
The most common reason of broken sleep on AMD systems are USB problems. \
You have to map your USB ports. If you have working Windows instance I recommend this tool, otherwise you have to do it manually. \
After mapping remember to disable Kernel -> Quriks -> XhciPortLimit
in your configuration file.
If USB fixes does not help, probably something another is broken. You can read more detailed guide about it on Dortania.
SVM
enabled in your BIOS settings.Software | Compatibility |
---|---|
Parallels Desktop | Up to 13.1 unless AppleHV is used.1 2 3 |
VirtualBox | Drastically decreased performance. |
VMWare Fusion 10 | Only Catalina and older, for Catalina with this patch. |
Docker | Only Docker in VirtualBox or Docker Toolbox. |
Android Emulator | Only Android-x86 with compatible VM software. |
iOS Emulator | Works out of the box. |
1 Parallels will not work by default on Big Sur and newer, you need to use SYSTEM_VERSION_COMPAT=1
environment variable.
2 Use this launcher package to simplify the Parallels usage.
3 Only Windows 10 Anniversary Update (build 1607) or older systems work.
You shouldn't add too much resources to your virtual machines, as it causes performance issues regardless of your hardware.
Use the following configuration for best results.
Firstly try to disable AMDRyzenCPUPowerManagement and SMCAMDProcessor kexts - it may cause random kernel panic with some hardware configurations.
If you have any other questions or issues, feel free to ask on AMD-OSX Discord or Forum.
Due to the diversity of configurations, I am unable to assist with issues related to specific computer specifications. For troubleshooting, I recommend starting with inquiries on the AMD-OSX Discord.
Please create an Issue on GitHub primarily for cases concerning more general problems.