Last modified: Wed Jun 03 2020 14:35:16 GMT+0000 (Coordinated Universal Time)
- Supported version: 0.5.9
Table of Contents:
Do note that this is only recommended for users who have already installed macOS, for users who are installing for the first time enable
Kernel -> Quirks
CFG-Lock is a setting in your BIOS that allows for a specific register(in this case the MSR 0xE2) to be written to. By default, most motherboards lock this variable with many even hiding the option outright in the GUI. And why we care about it is that macOS actually wants to write to this variable, and not just one part of macOS. Instead both the Kernel(XNU) and AppleIntelPowerManagement want this register.
So to fix it we have 2 options:
Patch macOS to work with our hardware
This creates instability and unnecessary patching for many
The 2 patches we use for this:
AppleXcpmCfgLockfor the Kernel(XNU)
Patch our firmware to support MSR E2 write
Very much preferred, as avoids patching allowing for greater flexibility regarding stability and OS upgrades
Note: Penyrn based machines actually don't need to worry about unlocking this register
So you've installed macOS but you're using those pesky
CFG-Lock patches that we want to get rid of, well to do this is fairly simple. You'll need the following:
Inside your EFI/OC/Tools folder and config.plist:
And some apps to help us out:
And don't forget to disable the following from your config.plist under
Kernel -> Quirks:
And the final part, grabbing your BIOS from the vendors' website.
Now the fun part!
Boot OpenCore and select the
VerifyMsrE2 option in the picker. This tool will tell you whether your BIOS supports CFG-Lock and if it can be unlocked.
- Open your firmware with UEFITool and then find
CFG Lockas a Unicode string. If nothing pops up then your firmware doesn't support
CFG Lock, otherwise continue on.
- You'll find that this string is found within a Setup folder, right-click and export as
Open your setup file with
ifrextractand export as a .txt file with terminal:
path/to/ifrextract path/to/Setup.bin path/to/Setup.txt
Open the text file and search for
CFG Lock, VarStoreInfo (VarOffset/VarName):and note the offset right after it(ie:
Run the Modified GRUB Shell and paste the following where
0x5A4is replaced with your value:
setup_var 0x5A4 0x00
Do note that variable offsets are unique not just to each motherboard but even to its firmware version. Never try to use an offset without checking.
And you're done! Now you'll have correct CPU power management
Note: Every time you reset your BIOS you will need to flip this bit again, make sure to write it down with the BIOS version so you know which.