framework/12th-gen-intel: Refactor module
https://github.com/NixOS/nixos-hardware/pull/897 https://github.com/NixOS/nixos-hardware/pull/846 https://github.com/NixOS/nixos-hardware/issues/894
This commit is contained in:
parent
f8e89e4e84
commit
8cde8633d4
|
@ -1,25 +1,38 @@
|
||||||
{ lib, pkgs, ... }: {
|
{ config, lib, pkgs, ... }:
|
||||||
|
{
|
||||||
imports = [
|
imports = [
|
||||||
../common
|
../common
|
||||||
../common/intel.nix
|
../common/intel.nix
|
||||||
];
|
];
|
||||||
|
|
||||||
|
config = lib.mkMerge [
|
||||||
|
{
|
||||||
|
hardware.intelgpu.loadInInitrd = lib.versionOlder config.boot.kernelPackages.kernel.version "6.2";
|
||||||
|
}
|
||||||
|
# https://community.frame.work/t/tracking-hard-freezing-on-fedora-36-with-the-new-12th-gen-system/20675/391
|
||||||
|
(lib.mkIf (lib.versionOlder config.boot.kernelPackages.kernel.version "6.2") {
|
||||||
boot.kernelParams = [
|
boot.kernelParams = [
|
||||||
# For Power consumption
|
|
||||||
# https://kvark.github.io/linux/framework/2021/10/17/framework-nixos.html
|
|
||||||
"mem_sleep_default=deep"
|
|
||||||
# Workaround iGPU hangs
|
# Workaround iGPU hangs
|
||||||
# https://discourse.nixos.org/t/intel-12th-gen-igpu-freezes/21768/4
|
# https://discourse.nixos.org/t/intel-12th-gen-igpu-freezes/21768/4
|
||||||
"i915.enable_psr=1"
|
"i915.enable_psr=1"
|
||||||
];
|
];
|
||||||
|
})
|
||||||
|
(lib.mkIf (lib.versionOlder config.boot.kernelPackages.kernel.version "6.8") {
|
||||||
boot.blacklistedKernelModules = [
|
boot.blacklistedKernelModules = [
|
||||||
# This enables the brightness and airplane mode keys to work
|
# This enables the brightness and airplane mode keys to work
|
||||||
# https://community.frame.work/t/12th-gen-not-sending-xf86monbrightnessup-down/20605/11
|
# https://community.frame.work/t/12th-gen-not-sending-xf86monbrightnessup-down/20605/11
|
||||||
"hid-sensor-hub"
|
"hid-sensor-hub"
|
||||||
# This fixes controller crashes during sleep
|
# This fixes controller crashes during sleep
|
||||||
# https://community.frame.work/t/tracking-fn-key-stops-working-on-popos-after-a-while/21208/32
|
# https://community.frame.work/t/tracking-fn-key-stops-working-on-popos-after-a-while/21208/32
|
||||||
"cros_ec_lpcs"
|
(lib.mkIf (config.hardware.framework.enableKmod == false) "cros_ec_lpcs")
|
||||||
|
];
|
||||||
|
|
||||||
|
boot.kernelParams = [
|
||||||
|
# For Power consumption
|
||||||
|
# https://kvark.github.io/linux/framework/2021/10/17/framework-nixos.html
|
||||||
|
# Update 04/2024: Combined with acpi_osi from framework-intel it increases the idle power-usage in my test (SebTM)
|
||||||
|
# (see: https://github.com/NixOS/nixos-hardware/pull/903#issuecomment-2068146658)
|
||||||
|
"mem_sleep_default=deep"
|
||||||
];
|
];
|
||||||
|
|
||||||
# Further tweak to ensure the brightness and airplane mode keys work
|
# Further tweak to ensure the brightness and airplane mode keys work
|
||||||
|
@ -44,9 +57,6 @@
|
||||||
fi
|
fi
|
||||||
'';
|
'';
|
||||||
};
|
};
|
||||||
|
})
|
||||||
# Alder Lake CPUs benefit from kernel 5.18 for ThreadDirector
|
];
|
||||||
# https://www.tomshardware.com/news/intel-thread-director-coming-to-linux-5-18
|
|
||||||
boot.kernelPackages = lib.mkIf (lib.versionOlder pkgs.linux.version "5.18") (lib.mkDefault pkgs.linuxPackages_latest);
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,15 +1,17 @@
|
||||||
{ lib, pkgs, ... }: {
|
{ config, lib, pkgs, ... }: {
|
||||||
imports = [
|
imports = [
|
||||||
../../../common/cpu/intel
|
../../../common/cpu/intel
|
||||||
];
|
];
|
||||||
|
|
||||||
boot.kernelParams = [
|
boot.kernelParams = [
|
||||||
# Fixes a regression in s2idle, making it more power efficient than deep sleep
|
|
||||||
"acpi_osi=\"!Windows 2020\""
|
|
||||||
# For Power consumption
|
# For Power consumption
|
||||||
# https://community.frame.work/t/linux-battery-life-tuning/6665/156
|
# https://community.frame.work/t/linux-battery-life-tuning/6665/156
|
||||||
"nvme.noacpi=1"
|
"nvme.noacpi=1"
|
||||||
];
|
]
|
||||||
|
# Fixes a regression in s2idle, making it more power efficient than deep sleep
|
||||||
|
# Update 04/2024: It appears that s2idle-regression got fixed in newer kernel-versions (SebTM)
|
||||||
|
# (see: https://github.com/NixOS/nixos-hardware/pull/903#discussion_r1556096657)
|
||||||
|
++ lib.lists.optional (lib.versionOlder config.boot.kernelPackages.kernel.version "6.8") "acpi_osi=\"!Windows 2020\"";
|
||||||
|
|
||||||
# Requires at least 5.16 for working wi-fi and bluetooth.
|
# Requires at least 5.16 for working wi-fi and bluetooth.
|
||||||
# https://community.frame.work/t/using-the-ax210-with-linux-on-the-framework-laptop/1844/89
|
# https://community.frame.work/t/using-the-ax210-with-linux-on-the-framework-laptop/1844/89
|
||||||
|
|
Loading…
Reference in a new issue