2024-12-10 19:26:33 +00:00
|
|
|
{
|
|
|
|
pkgs,
|
|
|
|
config,
|
|
|
|
lib,
|
|
|
|
...
|
2024-04-11 01:46:59 +00:00
|
|
|
}:
|
|
|
|
let
|
|
|
|
inherit (lib) mkEnableOption mkPackageOption mkIf;
|
|
|
|
cfg = config.programs.ryzen-monitor-ng;
|
|
|
|
in
|
|
|
|
{
|
|
|
|
options = {
|
|
|
|
programs.ryzen-monitor-ng = {
|
2024-12-10 19:26:33 +00:00
|
|
|
enable = mkEnableOption ''
|
2024-04-11 01:46:59 +00:00
|
|
|
ryzen_monitor_ng, a userspace application for setting and getting Ryzen SMU (System Management Unit) parameters via the ryzen_smu kernel driver.
|
|
|
|
|
|
|
|
Monitor power information of Ryzen processors via the PM table of the SMU.
|
|
|
|
|
|
|
|
SMU Set and Get for many parameters and CO counts.
|
|
|
|
|
|
|
|
https://github.com/mann1x/ryzen_monitor_ng
|
|
|
|
|
|
|
|
WARNING: Damage cause by use of your AMD processor outside of official AMD specifications or outside of factory settings are not covered under any AMD product warranty and may not be covered by your board or system manufacturer's warranty
|
|
|
|
'';
|
|
|
|
|
2024-12-10 19:26:33 +00:00
|
|
|
package = mkPackageOption pkgs "ryzen-monitor-ng" { };
|
2024-04-11 01:46:59 +00:00
|
|
|
};
|
|
|
|
};
|
|
|
|
|
|
|
|
config = mkIf cfg.enable {
|
|
|
|
environment.systemPackages = [ cfg.package ];
|
|
|
|
hardware.cpu.amd.ryzen-smu.enable = true;
|
|
|
|
};
|
|
|
|
|
2024-12-10 19:26:33 +00:00
|
|
|
meta.maintainers = with lib.maintainers; [
|
|
|
|
Cryolitia
|
|
|
|
phdyellow
|
|
|
|
];
|
2024-04-11 01:46:59 +00:00
|
|
|
}
|