trulyspinach / SMCAMDProcessor

Power management, monitoring and VirtualSMC plugin for AMD processors

Geek Repo:Geek Repo

Github PK Tool:Github PK Tool

SMCAMDProcessor

Github release Github release Continuous Delivery

XNU kernel extension for power management and monitoring of AMD processors. Also comes with a plugin for VirtualSMC to export readings to other applications.

Please note that this release is at very initial stage of development, make sure you have a proper backup of your EFI folder and never run on any system that matters. This notice has been here since the very beginning of this repository. Although I still wouldn't consider it completely finished, many users, including me, have been running these kexts daily without any major issues. If it's your first time adding these kexts to your system, please ensure you have a backup of your EFI.

Now you can also access the latest(and probably unstable) builds from Github Action.

Installation

SMCAMDProcessor now comes in two separate binaries(kernel extensions):

  • AMDRyzenCPUPowerManagement.kext for all power management features. This kext is also required if you would like to use AMD Power Gadget.
  • SMCAMDProcessor.kext to publish readings to VirtualSMC, which enables macOS applications like iStat to display sensor data. This kext depends on AMDRyzenCPUPowerManagement.kext to collect sensor data, thus must be loaded after.
  1. Download the kext(s) and application from Release page.
    • Optionally, you can instead download the latest(probably unstable) build from Github Action.
  2. Add AMDRyzenCPUPowerManagement.kext to kext folder of your bootloader.
  3. Edit your bootloader's config file to make sure the kext is enabled.
  4. If you're using VirtualSMC you can also load SMCAMDProcessor.kext to publish sensor data.
  5. Bootloaders like OpenCore will link each kext in the order they present in config file, so make sure AMDRyzenCPUPowerManagement.kext comes before SMCAMDProcessor.kext as it serves as a dependency.

Features

  • CPU power management for AMD Zen processors.
  • Supports for reading of temperature, energy and frequency data on AMD Zen Processors.
  • Manual switching of processor speed.
  • PState editing.

AMD Power Gadget

Editing PState

Since the release 0.3.1, you can now edit your CPU PState using AMD Power Tool.

To access PState editor:

  1. Open AMD Power Tool
  2. Go to 'Speed' tab
  3. Click 'Advanced Options'

Fan Control

Due to the amount of request an experimental feature for reading and overriding fan speed is out!

You can access this menu from menu bar "Open -> SMC Fans" or the button in Power Tool. Currently only a limited amount of SMC controllers are supported.

Safety Notes

  • Incorrect PState setting can potentially cause permanent damage to your computer hardware.
  • For safety concern, this function was limited to root user only. You can either launch AMD Power Gadget with root user or use -amdpnopchk to disable this check.

Contribution

If you like this project, please consider supporting it via:

  • Give it a star!

  • Buy me a coffee.

  • Open an issue(English only) if you encountered any problem or have suggestions.

  • or if you're a coding person, feel free to submit a pull request. DM me on Discord if you have any code related questions.

Credits

  • aluveitie for various enhancements and fixes.
  • mauricelos for IT86XXE SMC chip driver.
  • necross2 for adding support to temperature sensor offset.
  • Shaneee for the beautiful icon.
  • mbarbierato, Lorys89 for NCT6799D SMC chip driver.
  • All contributors for various fixes and improvements.

Notes

  • I am still fairly new to macOS kernel development, this software project was initally a hobby project, and it still is, to get some reading on my newly built AMD hackintosh computer.

  • With that being said, please bear with some of the spaghetti and not-idiomatic codes. Any criticism is much welcomed :)

stats

About

Power management, monitoring and VirtualSMC plugin for AMD processors

License:BSD 3-Clause "New" or "Revised" License


Languages

Language:C++ 71.5%Language:Swift 23.8%Language:C 4.7%