feat(pstate): opt in changes and sooooo
This commit is contained in:
@@ -5,6 +5,7 @@
|
|||||||
variant = "latest";
|
variant = "latest";
|
||||||
hardware = [ "amd" ];
|
hardware = [ "amd" ];
|
||||||
extraKernelParams = [ ];
|
extraKernelParams = [ ];
|
||||||
|
amdOverdrive.enable = true;
|
||||||
};
|
};
|
||||||
loader = {
|
loader = {
|
||||||
default = {
|
default = {
|
||||||
|
|||||||
@@ -5,7 +5,12 @@
|
|||||||
...
|
...
|
||||||
}:
|
}:
|
||||||
let
|
let
|
||||||
inherit (lib) mkOption types;
|
inherit (lib)
|
||||||
|
mkOption
|
||||||
|
types
|
||||||
|
mkEnableOption
|
||||||
|
mkIf
|
||||||
|
;
|
||||||
cfg = config.nixos.boot.kernel;
|
cfg = config.nixos.boot.kernel;
|
||||||
|
|
||||||
hasHardware = hw: builtins.elem hw cfg.hardware;
|
hasHardware = hw: builtins.elem hw cfg.hardware;
|
||||||
@@ -37,8 +42,11 @@ in
|
|||||||
);
|
);
|
||||||
default = [ ];
|
default = [ ];
|
||||||
description = "List of hardware types (e.g. GPU and CPU vendors) to configure kernel settings for.";
|
description = "List of hardware types (e.g. GPU and CPU vendors) to configure kernel settings for.";
|
||||||
|
|
||||||
};
|
};
|
||||||
|
|
||||||
|
amdOverdrive.enable = mkEnableOption "Enable AMD pstate/overdrive";
|
||||||
|
|
||||||
extraKernelParams = mkOption {
|
extraKernelParams = mkOption {
|
||||||
type = types.listOf types.str;
|
type = types.listOf types.str;
|
||||||
default = [ ];
|
default = [ ];
|
||||||
@@ -74,7 +82,7 @@ in
|
|||||||
"quiet"
|
"quiet"
|
||||||
"splash"
|
"splash"
|
||||||
]
|
]
|
||||||
++ (if hasHardware "amd" then [ "amd_pstate=active" ] else [ ])
|
++ (if hasHardware "amd" then [ ] else [ ])
|
||||||
++ (if hasHardware "intel" then [ ] else [ ])
|
++ (if hasHardware "intel" then [ ] else [ ])
|
||||||
++ (if hasHardware "nvidia" then [ ] else [ ])
|
++ (if hasHardware "nvidia" then [ ] else [ ])
|
||||||
++ cfg.extraKernelParams;
|
++ cfg.extraKernelParams;
|
||||||
@@ -85,5 +93,6 @@ in
|
|||||||
++ (if hasHardware "nvidia" then [ "nouveau" ] else [ ])
|
++ (if hasHardware "nvidia" then [ "nouveau" ] else [ ])
|
||||||
++ cfg.extraBlacklistedModules;
|
++ cfg.extraBlacklistedModules;
|
||||||
};
|
};
|
||||||
|
hardware.amdgpu.overdrive.enable = mkIf cfg.amdOverdrive.enable true;
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -89,7 +89,8 @@ in
|
|||||||
|
|
||||||
config = mkIf cfg.enable (mkMerge [
|
config = mkIf cfg.enable (mkMerge [
|
||||||
{
|
{
|
||||||
hardware.graphics = {
|
hardware = {
|
||||||
|
graphics = {
|
||||||
enable = true;
|
enable = true;
|
||||||
enable32Bit = true;
|
enable32Bit = true;
|
||||||
extraPackages = flatten (
|
extraPackages = flatten (
|
||||||
@@ -121,6 +122,7 @@ in
|
|||||||
|
|
||||||
extraPackages32 = flatten (concatMap (_: commonPackages32) cfg.vendors);
|
extraPackages32 = flatten (concatMap (_: commonPackages32) cfg.vendors);
|
||||||
};
|
};
|
||||||
|
};
|
||||||
|
|
||||||
environment.systemPackages = flatten (
|
environment.systemPackages = flatten (
|
||||||
concatMap (
|
concatMap (
|
||||||
@@ -145,10 +147,6 @@ in
|
|||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
(mkIf (hasVendor "amd") {
|
|
||||||
hardware.amdgpu.overdrive.enable = true;
|
|
||||||
})
|
|
||||||
|
|
||||||
(mkIf (hasVendor "nvidia") {
|
(mkIf (hasVendor "nvidia") {
|
||||||
hardware.nvidia = {
|
hardware.nvidia = {
|
||||||
package =
|
package =
|
||||||
|
|||||||
@@ -132,7 +132,7 @@
|
|||||||
enable = true;
|
enable = true;
|
||||||
};
|
};
|
||||||
syncthing = {
|
syncthing = {
|
||||||
enable = true;
|
enable = false;
|
||||||
};
|
};
|
||||||
udiskie = {
|
udiskie = {
|
||||||
enable = true;
|
enable = true;
|
||||||
|
|||||||
Reference in New Issue
Block a user