aboutsummaryrefslogtreecommitdiff
path: root/nixos/modules/hardware
diff options
context:
space:
mode:
authorShea Levy <shea@shealevy.com>2020-09-23 06:44:40 -0400
committerShea Levy <shea@shealevy.com>2020-09-23 08:10:49 -0400
commit4b1850bad3c8cba93ffb12041da1a530cbe03c6d (patch)
tree4d01ca53d27943cc8a08581f8c2d538520e5a002 /nixos/modules/hardware
parent9f43146ec4c8273d4ae3872611a7594dd430b93c (diff)
Add system76 NixOS module
Diffstat (limited to 'nixos/modules/hardware')
-rw-r--r--nixos/modules/hardware/system-76.nix56
1 files changed, 56 insertions, 0 deletions
diff --git a/nixos/modules/hardware/system-76.nix b/nixos/modules/hardware/system-76.nix
new file mode 100644
index 000000000000..48eb63f4f22d
--- /dev/null
+++ b/nixos/modules/hardware/system-76.nix
@@ -0,0 +1,56 @@
+{ config, lib, pkgs, ... }:
+
+let
+ inherit (lib) mkOption mkEnableOption types mkIf mkMerge optional versionOlder;
+ cfg = config.hardware.system76;
+
+ kpkgs = config.boot.kernelPackages;
+ modules = [ "system76" "system76-io" ] ++ (optional (versionOlder kpkgs.kernel.version "5.5") "system76-acpi");
+ modulePackages = map (m: kpkgs.${m}) modules;
+ moduleConfig = mkIf cfg.kernel-modules.enable {
+ boot.extraModulePackages = modulePackages;
+
+ boot.kernelModules = modules;
+
+ services.udev.packages = modulePackages;
+ };
+
+ firmware-pkg = pkgs.system76-firmware;
+ firmwareConfig = mkIf cfg.firmware-daemon.enable {
+ services.dbus.packages = [ firmware-pkg ];
+
+ systemd.services.system76-firmware-daemon = {
+ description = "The System76 Firmware Daemon";
+
+ serviceConfig = {
+ ExecStart = "${firmware-pkg}/bin/system76-firmware-daemon";
+
+ Restart = "on-failure";
+ };
+
+ wantedBy = [ "multi-user.target" ];
+ };
+ };
+in {
+ options = {
+ hardware.system76 = {
+ enableAll = mkEnableOption "all recommended configuration for system76 systems";
+
+ firmware-daemon.enable = mkOption {
+ default = cfg.enableAll;
+ example = true;
+ description = "Whether to enable the system76 firmware daemon";
+ type = types.bool;
+ };
+
+ kernel-modules.enable = mkOption {
+ default = cfg.enableAll;
+ example = true;
+ description = "Whether to make the system76 out-of-tree kernel modules available";
+ type = types.bool;
+ };
+ };
+ };
+
+ config = mkMerge [ moduleConfig firmwareConfig ];
+}