Skip to content

macOS on the Huawei MateBook X Pro 2020 thanks to Acidanthera's OpenCore bootloader

License

Notifications You must be signed in to change notification settings

jlempen/MateBook-X-Pro-2020-OpenCore

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

36 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

OpenCore logo

MateBook-X-Pro-2020-OpenCore

macOS on the Huawei MateBook X Pro 2020 thanks to Acidanthera's OpenCore bootloader.

Software Specifications

Software Version
Target OS Apple macOS 15 Sequoia, 14 Sonoma and 13 Ventura
OpenCore MOD-OC v1.0.3
SMBIOS MacBookPro16,2
UEFI Firmware v1.26
SSD format APFS file system, GPT partition table

Abstract

The MateBook X Pro 2020 is a nearly perfect Hackintosh laptop. It looks almost like the real thing once you remove all the ugly Intel, Huawei and NVIDIA stickers from the palmrest. It sounds great with its 4 speakers, the huge trackpad supports all the native gestures and feels like a Mac trackpad, the keyboard is almost as good as the real thing, the 13.9 inch display looks amazing, the MateBook sleeps and wakes quickly and the battery life is on par with an Intel MacBook Pro/Air. It feels like a MacBook Pro/Air. I switch daily between a 2020 M1 MacBook Pro and the MateBook X Pro 2020 and very often wouldn't know which device I'm currently working with.

Tip

I recommend installing macOS 13 Ventura rather than the newer macOS 14 Sonoma or macOS 15 Sequoia. The builtin Intel Wireless chip works almost perfectly with Apple's iServices and Continuity features on Ventura while those features are partially broken at the moment on newer versions of macOS.

Tip

To boot from the USB stick containing the macOS installer, power on your MateBook X Pro 2020 and press and hold the F12 Key as soon as the Huawei Logo is displayed, then choose the USB stick in the list.

Important

For macOS to be able to boot on the MateBook X Pro 2020, the Secure Boot option must be disabled in the UEFI Settings.

Important

Please be aware that all PlatformInfo and SMBIOS information was removed from the OpenCore config.plist file. Users will therefore need to generate their own PlatformInfo with CorpNewt's GenSMBIOS tool before attempting to boot a MateBook X Pro 2020 with this repository's EFI folder.

Disclaimer

This repository is neither a howto nor an installation manual. Using these files requires at least basic knowledge of Acidanthera's OpenCore bootloader, ACPI, UEFI and the art of hackintoshing in general. I recommend reading the excellent Dortania's OpenCore Install Guide, as well as all its linked resources.

This EFI folder is based on the now defunct repository from GitHub user RepoWeaver. Fortunately for us, GitHub user Thyodas uploaded his local backup copy of RepoWeaver's EFI folder to his GitHub repository. So I downloaded his EFI folder, updated OpenCore and all the relevant SSDTs and kexts to their latest versions as of October 2023 and changed a few things, such as replacing the ALC256 layout with layout-id 76, which enables all four speakers without the need to create an aggregate audio device, moving a few iGPU-related WhateverGreen quirks from the boot-args and adding a few more WhateverGreen quirks to DeviceProperties/Add/PciRoot(0x0)/Pci(0x2,0x0). I also rebuilt the USBMap.kext in Windows with the excellent USBToolbox tool.

Recommendations

I recommend completely erasing the device's SSD by creating a new GPT partition table before attempting to install macOS, as it makes the installation process much easier. You may use any Linux live ISO with a partitioning tool such as GParted or KPartition to erase the SSD.

AirportItlwm_Ventura.kext, AirportItlwm_Sonoma14.0.kext and AirportItlwm_Sonoma14.4.kext from the OpenIntelWireless repo are required to enable the Wifi chip. This EFI will dynamically load the appropriate kext for macOS Ventura or Sonoma depending on the running kernel. No need to manually replace the kext file when updating your version of macOS.

As the Intel Wifi chip does not yet work with AirportItlwm.kext in macOS Sequoia, you'll need to use Itlwm.kext and its companion app HeliPort to connect to a Wifi network. You'll find the latest stable HeliPort.dmg in the Tools folder of this repo. This EFI will dynamically load Itlwm.kext instead of AirportItlwm.kext when you boot into macOS Sequoia.

Windows and Linux should be detected automagically by the OpenCore boot loader even when installed after macOS.

This repository uses the unofficial OpenCore_NO_ACPI_Build fork of OpenCore by btwise, wich is not endorsed by Acidanthera (the dev team behind OpenCore). The main (and only) difference between this fork and the official OpenCore version is that it allows to prevent ACPI injection (e.g. patches, tables, boot parameters) into other OSes besides macOS.

Computer Specifications

Computer Specifications

Device Hardware
CPU Intel Core i7-10510U (1.8 - 4.9 GHz, Comet Lake)
iGPU Intel UHD Graphics 620
dGPU NVIDIA GeForce MX250
Audio Realtek ALC 256
RAM 2x8 GB LPDDR3 2133 MHz
Wifi + Bluetooth Wifi 5 AC9560, Bluetooth 5.0
Storage Samsung PM981 NVMe PCIe 1 TB SSD (unsupported), replaced with a Western Digital SN850 NVMe PCIe 1 TB SSD
USB Type-C Supports Power Delivery and DisplayPort
USB-A 3.0
Camera 1 MPix recessed camera VID 0x05c8 PID 0x03c0
Keyboard / Trackpad
Display 13.90 inch 3:2, 3000 x 2000 LTPS 260 PPI, 10-Point Capacitive
Battery 56 Wh
Accelerometers, gyroscopes, ambient light sensors
What works

What works

  • CPU power management (CPUFriend.kext with CPUFriendDataProvider.kext)
  • CPU SpeedStep (CPUFriend.kext with CPUFriendDataProvider.kext)
  • iGPU with full acceleration (WhateverGreen.kext, AAPL,ig-platform-id 0400A53E, device-id A53E0000)
  • SSD drive (NVMeFix.kext)
  • Sleep/hibernate and wake
  • Rear left USB-C port with hotplug (USBMap.kext)
  • Front left USB-C port with hotplug for USB 1.1 and USB 2.0 devices only (USBMap.kext)
  • Right USB 3.0 port with hotplug (USBMap.kext)
  • WLAN (AirportItlwm.kext)
  • Bluetooth (IntelBluetoothFirmware.kext with IntelBTPatcher.kext and BlueToolFixup.kext)
  • Nose-Camera VID 0x05c8 PID 0x03c0 (don't forget to pop it up :-)
  • Internal quad speakers, microphone and Combojack (AppleALC.kext, alcid=76)
  • Keyboard with working brightness, volume and mute keys (VoodooPS2.kext)
  • Trackpad with native multi-touch gestures (VoodooI2C.kext with VoodooI2CHID.kext)
  • Touchscreen (VoodooI2C.kext with VoodooI2CHID.kext) (disabled for now)
  • Battery percentage and cycle count (VirtualSMC.kext with SMCBatteryManager.kext)
  • USB Type-C Power Delivery
What needs some more work

What needs some more work

  • Thunderbolt
  • Front left USB-C port hotplug with USB 3.x devices (depends on Thunderbolt). Using a USB-C hub on this port causes a kernel panic and restart after unplugging the hub. Using the port for power delivery seems to work fine, though.
  • Accelerometers, gyroscope
  • Ambient light sensor
What will probably never work

What will probably never work

  • NVIDIA GeForce MX250 dGPU (disabled with an SSDT)
  • Fingerprint sensor (disabled in the UEFI BIOS)
UEFI Settings

UEFI Settings

To enter the UEFI Settings, power on your MateBook X Pro 2020 and press and hold the F2 Key as soon as the Huawei Logo is displayed on the screen.

The Secure Boot setting must be disabled to boot macOS.

All other settings may remain on their default values and won't prevent macOS from booting, but keep in mind that every disabled device saves power and increases the battery runtime. For example, as the fingerprint reader won't work in macOS, disabling the device in the UEFI Settings is recommended unless you plan on using another operating system on the device as well.

Undervolting to reduce heat and improve performance

Undervolting to reduce heat and improve performance

The VoltageShift.kext undervolting tool is already included and enabled in this repository's Kexts folder. To be able to launch the voltageshift command line tool from anywhere, copy VoltageShift from the Tools folder to your /usr/local/bin folder by entering sudo cp voltageshift /usr/local/bin/ in the macOS terminal after navigating to the folder where you downloaded and unzipped the voltageshift executable file.

Please refer to the instructions found in the VoltageShift repository, as well as to the excellent howto found in zearp's repository.

Once you have found an undervolting configuration that works well on your device, make it permanent by entering the following command in the terminal after navigating to the folder where you downloaded and unzipped the VoltageShift-EFI.zip file:

sudo ./voltageshift buildlaunchd -120 -50 -80 0 0 0 1 28 18 0.002 60

The above undervolting values are only an example and shouldn't be used on your system.

Disabling CFG Lock to improve Power Management

Disabling CFG Lock to improve Power Management

  1. Boot into OpenCore
  2. Press Space to see the list of tools
  3. Select Disable CFG Lock
  4. Press enter
  5. Restart

To verify this worked, press Space and select the Check CFG Lock State tool -- if it was successful, you'll see:

This firmware has UNLOCKED MSR 0xE2 register!

Finally, edit config.plist and set Kernel -> Quirks -> AppleCpuPmCfgLock and Kernel -> Quirks -> AppleXcpmCfgLock to false and reboot.

Disabling Overclocking Lock to enable Undervolting

Disabling Overclocking Lock to enable Undervolting

  1. Boot into OpenCore
  2. Press Space to see the list of tools
  3. Select Disable Overclocking Lock
  4. Press enter
  5. Restart
Increasing DVMT Gfx Memory to improve iGPU performance

Increasing DVMT Gfx Memory to improve iGPU performance

  1. Boot into OpenCore
  2. Press Space to see the list of tools
  3. Select Set DVMT to 64M
  4. Press enter
  5. Then select Set Total GFX Mem to MAX
  6. Press enter
  7. Restart

Finally, edit config.plist and delete or comment out framebuffer-fbmem and framebuffer-stolenmem in Device Properties -> Add -> PciRoot(0x0)/Pci(0x2,0x0) and restart.

More information on the modified UEFI Firmware variables

More information on the modified UEFI Firmware variables

VarName VarOffset VarStore From To
CFG Lock 0x3E 0x3 (CpuSetup) 0x1 (Enabled) 0x0 (Disabled)
Overclocking Lock 0xDA 0x3 (CpuSetup) 0x1 (Enabled) 0x0 (Disabled)
VT-d 0x10B 0x2 (SaSetup) 0x1 (Enabled) 0x0 (Disabled)
DVMT Pre-Allocated 0x107 0x2 (SaSetup) 0x1 (32M) 0x2 (64M)
DVMT Total Gfx Mem 0x108 0x2 (SaSetup) 0x2 (256M) 0x3 (MAX)

To revert all changes made to the UEFI Firmware variables to their default values, enable the corresponding entries in the config.plist file under Misc -> Tools, restart to the OpenCore menu, press space to see the list of tools and revert the changes by launching the option you wish to revert to its default value:

  • Enable CFG Lock
  • Enable Overclocking Lock
  • Set DVMT to default (32M)
  • Set Total GFX Mem to default (256M)

Repeat for every UEFI variable you wish to revert to its default value.

Please be aware that you need to revert any changes made to your config.plist file before reverting the UEFI variables to their default values, or macOS won't boot anymore!

Enabling native HiDPI display settings in macOS

Enabling native HiDPI display settings in macOS

On the installed macOS system, the default display resolution is already "Retina", as the native 3000x2000 resolution is scaled down to 1500x1000. To enable a few more native HiDPI settings in the Display Preferences of macOS, download and run the one-key-hidpi script and select the option (6) 3000x2000 Display. I also recommend downloading and installing BetterDisplay to change and manage the display resolutions on the MateBook X Pro 2020.

Fixing broken Apple Messages and FaceTime

Fixing broken Apple Messages and FaceTime

To fix issues with Apple Messages and FaceTime related to the Intel Wireless driver on macOS Sonoma and Sequoia, disable all AirportItlwm-***.kext entries under Kernel -> Add in your config.plist file and use the itlwm_v2.3.0_stable.kext.zip and its companion app HeliPort instead. The latest version 2.3.0 of itlwm.kext is already included in the Kext folder and config.plist file.

In addition to the above, to enable itlwm.kext under macOS Ventura and macOS Sonoma, you need to delete any text (i.e. 24.0.0 and 24.99.99 respectively) in the MinKernel and MaxKernel fields under Kernel -> Add -> itlwm.kext in your config.plist file.

Related repositories

Related repositories

About

macOS on the Huawei MateBook X Pro 2020 thanks to Acidanthera's OpenCore bootloader

Resources

License

Stars

Watchers

Forks

Packages

No packages published

Languages