nixos/corefreq: add program defining both the daemon service and its kernel module
This commit is contained in:
parent
ed18fab640
commit
dcc8b99d85
@ -171,6 +171,7 @@
|
|||||||
./programs/cpu-energy-meter.nix
|
./programs/cpu-energy-meter.nix
|
||||||
./programs/command-not-found/command-not-found.nix
|
./programs/command-not-found/command-not-found.nix
|
||||||
./programs/coolercontrol.nix
|
./programs/coolercontrol.nix
|
||||||
|
./programs/corefreq.nix
|
||||||
./programs/criu.nix
|
./programs/criu.nix
|
||||||
./programs/darling.nix
|
./programs/darling.nix
|
||||||
./programs/dconf.nix
|
./programs/dconf.nix
|
||||||
|
42
nixos/modules/programs/corefreq.nix
Normal file
42
nixos/modules/programs/corefreq.nix
Normal file
@ -0,0 +1,42 @@
|
|||||||
|
{
|
||||||
|
config,
|
||||||
|
lib,
|
||||||
|
pkgs,
|
||||||
|
...
|
||||||
|
}:
|
||||||
|
|
||||||
|
let
|
||||||
|
cfg = config.programs.corefreq;
|
||||||
|
kernelPackages = config.boot.kernelPackages;
|
||||||
|
in
|
||||||
|
{
|
||||||
|
options = {
|
||||||
|
programs.corefreq = {
|
||||||
|
enable = lib.mkEnableOption "Whether to enable the corefreq daemon and kernel module";
|
||||||
|
|
||||||
|
package = lib.mkOption {
|
||||||
|
type = lib.types.package;
|
||||||
|
default = kernelPackages.corefreq;
|
||||||
|
defaultText = lib.literalExpression "config.boot.kernelPackages.corefreq";
|
||||||
|
description = ''
|
||||||
|
The corefreq package to use.
|
||||||
|
'';
|
||||||
|
};
|
||||||
|
};
|
||||||
|
};
|
||||||
|
|
||||||
|
config = lib.mkIf cfg.enable {
|
||||||
|
environment.systemPackages = [ cfg.package ];
|
||||||
|
boot.extraModulePackages = [ cfg.package ];
|
||||||
|
boot.kernelModules = [ "corefreqk" ];
|
||||||
|
|
||||||
|
# Create a systemd service for the corefreq daemon
|
||||||
|
systemd.services.corefreq = {
|
||||||
|
description = "CoreFreq daemon";
|
||||||
|
wantedBy = [ "multi-user.target" ];
|
||||||
|
serviceConfig = {
|
||||||
|
ExecStart = lib.getExe' cfg.package "corefreqd";
|
||||||
|
};
|
||||||
|
};
|
||||||
|
};
|
||||||
|
}
|
Loading…
Reference in New Issue
Block a user