Skip to content

leon9078/Z87X-OC_Catalina

Repository files navigation

Hackintosh_Main

• macOS: Catalina 10.15.7
• OpenCore: 0.7.0 RELEASE (June 2021)
• Related kexts: latest RELEASE (June 2021)

>>> Hardware

- GIGABYTE GA-Z87X-OC // rev 1.1
- Intel Core i7-4770K // Q2'13 (Haswell)
- Intel HD Graphics 4600
- NVIDIA GeForce GFX 770 // ASUS 2 GB GDDR5
- Crucial Ballistix Tactical // DDR3 1600 MHz CL8 (2 x 8 GB)
- Broadcom BCM94360CD // 802.11ac + Bluetooth 4.0
- Samsung SSD 850 EVO // SATA 250 GB
- Cooler Master B700 // 700W

>>> We need a USB Flash Drive (64 MB+) to write fpt_RU.iso

Windows

Open rufus, select fpt_RU.iso, flash to USB

macOS

# dd if=/path/to/fpt_RU.iso of=/dev/rdiskX && sync

Linux

# dd if=/path/to/fpt_RU.iso of=/dev/sdX && sync

BIOS: F8 (This version fixes a lot of issues)

  1. Problematic memory map (issues with wake from sleep, happening even on Linux)
  • Kernel trap at ... type=13 (memory protection)
  • Kernel trap at ... type=14 (page fault)
  • a freed zone element has been modified in X expected Y
  • Possible memory corruption: pmap_pv_remove
  • and so on...
  1. Conflicting RTC memory offset: 8A (inside IOHibernateRTCVariables)

This prevent macOS from going into hibernation, resulting in a CMOS reset

This motherboard has proprietary DualBIOS technology, so we need to update the BIOS twice.

First, shutdown PC and remove power cord. Then, switch to the Backup BIOS (BIOS_SW > 2)

To boot from fpt_RU USB, make sure you have the following settings in BIOS

- BIOS Features > Windows 8 Features: Other OS
- BIOS Features > Boot Mode Selection: UEFI and Legacy
- Peripherals > Legacy USB Support: Enabled

>>> Power on PC, press F12 key, select the Legacy option (not "UEFI: "), then wait until you see a green output "FPT Operation Passed"

-savemac argument will save our own MAC Address, so we don't need to reflash it later

CTRL+ALT+DEL to restart

Now the PC will shutdown twice. When it boot for the 3rd time press F12 key, select the UEFI option ("UEFI: "). There will be a reboot, select again the ("UEFI: ") option, this time it will boot

This will enter RU environment. This tool allows us to edit different BIOS settings, so it's very dangerous!

Now we need to disable VT-d

This removes DMAR table from ACPI stack

This option is hidden in BIOS (because of my specific CPU)

- Press Alt + = for UEFI Variables
- Scroll down with PgDown key, select Setup [EC87D643-EBA4-4BB5...], Size: 0x9B4
- Scroll down with Ctrl+PgDown, select Variable: 0x2A0 (Value should be 0x1, Enabled)
- Press Enter key, type 0 (to Disable), Enter key again, then Ctrl + W (There should be UPDATE: Setup: OK)

CTRL+ALT+DEL to reboot, unplug USB key

BIOS settings:

System Information

  • Working Environment: Classic Mode

Press F10 key to save, then enter BIOS again (Delete key)

M.I.T.

  • Advanced Frequency Settings > Advanced CPU Core Settings > Hyper-Threading Technology: Enabled
  • Advanced Memory Settings > Extreme Memory Profile(X.M.P.): Profile1

BIOS Features

  • Full Screen LOGO Show: Disabled

This removes BGRT table from ACPI stack

  • Windows 8 Features: Windows 8
  • Boot Mode Selection: UEFI Only
  • Storage Boot Option Control: UEFI Only
  • Secure Boot: Disabled

Press F10 key to save, then enter BIOS again (Delete key)

BIOS Features

  • CSM Support: Never

Press F10 key to save, then enter BIOS again (Delete key)

Peripherals

  • XHCI Mode: Enabled

This avoids a lot of issues like USB2 port routing (Method XSEL,ESEL,XWAK), USB devices not working after wake from sleep, iPad charge/discharge through USB2 ports, renaming EHC1/2 to EH01/2

  • Intel Processor Graphics: Disabled

This avoid issues with graphic drivers in Linux, and it's useful to disable also in macOS

  • Legacy USB Support: Disabled
  • Super IO Configuration > Serial Port A: Disabled
  • Intel(R) Ethernet Network Connection i217-V > NIC Configuration > Wake on LAN: Disabled

Power Management

  • Wake on LAN: Disabled

Press F10 key to save, then enter BIOS again (Delete key)

Power Management

  • ErP: Enabled

Press F10 key to save, you are done!

Now power off PC, remove power cord, switch to the Main BIOS (BIOS_SW > 1) and repeat the above steps!

Install macOS

Post install: adding Security features

1) Enable FileVault in "System Preferences > Security & Privacy > FileVault" (Choose recovery key)
2) ScanPolicy
$ sudo diskutil mount /dev/disk0s1

Change "config.plist > Misc > Security > ScanPolicy" value from 0 to 65795 (FILE_SYSTEM_LOCK, DEVICE_LOCK, ALLOW_FS_APFS, ALLOW_DEVICE_SATA)

3) OpenCore Menu password
$ curl -LJO https://github.com/acidanthera/OpenCorePkg/releases/download/0.7.0/OpenCore-0.7.0-RELEASE.zip
$ unzip -j OpenCore-0.7.0-RELEASE.zip "Utilities/ocpasswordgen/ocpasswordgen"
$ ./ocpasswordgen (Follow instructions)
$ echo "{copy/paste output from PasswordHash}" | xxd -r -p | base64

Copy output value to "config.plist > Misc > Security > PasswordHash"

$ echo "{copy/paste output from PasswordSalt}" | xxd -r -p | base64

Copy output value to "config.plist > Misc > Security > PasswordSalt"

Change "config.plist > Misc > Security > EnablePassword" from NO to YES

$ rm ocpasswordgen

4) OpenCore's "Vault"

First, make sure you have "Terminal" checked in System Preferences > Security & Privacy > Privacy > Full Disk Access

Close every Finder window

Open Terminal, then type:

$ touch /tmp/.com.apple.dt.CommandLineTools.installondemand.in-progress && softwareupdate -i "$(softwareupdate -l | awk '$1 == "*" && $2 == "Label:" && $3 == "Command" && $4 == "Line" && $5 == "Tools" {$1=$2=""; sub(/^[ \t]+/, ""); print}')" && rm /tmp/.com.apple.dt.CommandLineTools.installondemand.in-progress

$ bsdtar -x --include="Utilities/" -C /Volumes/EFI/ -f OpenCore-0.7.0-RELEASE.zip && rm -rf OpenCore-0.7.0-RELEASE.zip

$ sed -i '' 's/Optional/Secure/' /Volumes/EFI/EFI/OC/config.plist
$ find /Volumes/EFI ! -path "/Volumes/EFI" -name ".*" | xargs rm -rf && /Volumes/EFI/Utilities/CreateVault/sign.command && find /Volumes/EFI ! -path "/Volumes/EFI" -name ".*" -o -name "Utilities" | xargs rm -rf && diskutil unmount /dev/disk0s1

Done!

If you want to adventure with Hibernation, first prepare OpenCore for the detection

  • config.plist > Misc > Boot > HibernateMode | RTC

"restoreMachineState" MUST be enabled ONLY for hibernation (and not normal sleep). Because of this you have 2 options, see below

1. Default behaviour (for hibernation after standbydelay time):

  • hibernatemode 0
  • standby 1
  • autopoweroff 1

Hack will first sleep then, after standbydelay time, will hibernate. To prevent Kernel Panic (Sleep Wake failure in EFI) or hang on a black screen after exit hibernation, we need to use HibernationFixup.kext

  • config.plist > Kernel > Add > [HibernationFixup] (Manually add this entry)
  • config.plist > Kernel > Patch > [Disable RTC wake scheduling] | false
  • config.plist > Kernel > Patch > [restoreMachineState] > Enabled | false
  • REBOOT TWICE!

HibernationFixup ensures "restoreMachineState" patch is being applied dynamically (only for hibernation, but not for normal sleep)

2. Pure hibernation (never going to normal sleep):

  • config.plist > Kernel > Add > [HibernationFixup] (Manually remove this entry)
  • config.plist > Kernel > Patch > [Disable RTC wake scheduling] | true
  • config.plist > Kernel > Patch > [restoreMachineState] > Enabled | true
  • $ sudo pmset hibernatemode 25
  • REBOOT TWICE!

If you have a Fusion Drive, use this script to make sure autosleep is working!

$ sudo mkdir /usr/local/bin
$ sudo cp kill_UserEeventAgent.sh /usr/local/bin/
$ EDITOR=nano sudo crontab -e
> */10 * * * * /usr/local/bin/kill_UserEeventAgent.sh &>/dev/null

  • Reboot

About

No description, website, or topics provided.

Resources

Stars

Watchers

Forks