summary refs log tree commit diff
path: root/machines/loup
diff options
context:
space:
mode:
Diffstat (limited to 'machines/loup')
-rw-r--r--machines/loup/default.nix12
-rw-r--r--machines/loup/devices.nix68
-rw-r--r--machines/loup/hardware.nix55
-rw-r--r--machines/loup/home.nix9
4 files changed, 144 insertions, 0 deletions
diff --git a/machines/loup/default.nix b/machines/loup/default.nix
new file mode 100644
index 0000000..96bebd0
--- /dev/null
+++ b/machines/loup/default.nix
@@ -0,0 +1,12 @@
+{ ... }:
+
+{
+  imports = [
+    ../../modules/common.nix
+
+    ./hardware.nix
+    ./devices.nix
+  ];
+
+  system.stateVersion = "25.11";
+}
diff --git a/machines/loup/devices.nix b/machines/loup/devices.nix
new file mode 100644
index 0000000..d8dba3e
--- /dev/null
+++ b/machines/loup/devices.nix
@@ -0,0 +1,68 @@
+{ config, pkgs, ... }:
+
+{
+  # boot settings
+  boot = {
+    kernelPackages = pkgs.linuxPackages_latest;
+
+    loader = {
+      systemd-boot.enable = true;
+      efi.canTouchEfiVariables = true;
+    };
+
+    initrd.systemd.enable = true;
+  };
+
+  # hardware settings
+  hardware = {
+    enableRedistributableFirmware = true;
+    enableAllFirmware = true;
+
+    graphics = {
+      enable = true;
+      enable32Bit = true;
+      extraPackages = with pkgs; [
+        vpl-gpu-rt
+        intel-media-driver
+        intel-vaapi-driver
+        intel-compute-runtime
+        intel-ocl
+      ];
+    };
+  };
+
+  # swap alternative
+  zramSwap = {
+    enable = true;
+    algorithm = "zstd";
+    swapDevices = 1;
+    memoryPercent = 50;
+  };
+
+  # storage
+  fileSystems = {
+    "/mnt/Kui" = {
+      device = "/dev/disk/by-label/Kui";
+      fsType = "ext4";
+      options = [
+        "defaults"
+        "users"
+        "nofail"
+        "exec"
+        "rw"
+      ];
+    };
+  };
+
+  # sound
+  security.rtkit.enable = true;
+  services.pipewire = {
+    enable = true;
+    alsa = {
+      enable = true;
+      support32Bit = true;
+    };
+    pulse.enable = true;
+    jack.enable = true;
+  };
+}
diff --git a/machines/loup/hardware.nix b/machines/loup/hardware.nix
new file mode 100644
index 0000000..ee9d233
--- /dev/null
+++ b/machines/loup/hardware.nix
@@ -0,0 +1,55 @@
+# Do not modify this file!  It was generated by ‘nixos-generate-config’
+# and may be overwritten by future invocations.  Please make changes
+# to /etc/nixos/configuration.nix instead.
+{
+  config,
+  lib,
+  pkgs,
+  modulesPath,
+  ...
+}:
+
+{
+  imports = [
+    (modulesPath + "/installer/scan/not-detected.nix")
+  ];
+
+  boot.initrd.availableKernelModules = [
+    "ahci"
+    "xhci_pci"
+    "usbhid"
+    "usb_storage"
+    "sd_mod"
+    "sr_mod"
+  ];
+  boot.initrd.kernelModules = [ ];
+  boot.kernelModules = [ "kvm-intel" ];
+  boot.extraModulePackages = [ ];
+
+  fileSystems."/" = {
+    device = "/dev/disk/by-uuid/26028e3a-764f-4378-9c28-66ea9ed877c4";
+    fsType = "ext4";
+  };
+
+  fileSystems."/boot" = {
+    device = "/dev/disk/by-uuid/C734-568D";
+    fsType = "vfat";
+    options = [
+      "fmask=0077"
+      "dmask=0077"
+    ];
+  };
+
+  swapDevices = [ ];
+
+  # Enables DHCP on each ethernet and wireless interface. In case of scripted networking
+  # (the default) this is the recommended approach. When using systemd-networkd it's
+  # still possible to use this option, but it's recommended to use it in conjunction
+  # with explicit per-interface declarations with `networking.interfaces.<interface>.useDHCP`.
+  networking.useDHCP = lib.mkDefault true;
+  # networking.interfaces.enp0s25.useDHCP = lib.mkDefault true;
+  # networking.interfaces.enp6s0.useDHCP = lib.mkDefault true;
+
+  nixpkgs.hostPlatform = lib.mkDefault "x86_64-linux";
+  hardware.cpu.intel.updateMicrocode = lib.mkDefault config.hardware.enableRedistributableFirmware;
+}
diff --git a/machines/loup/home.nix b/machines/loup/home.nix
new file mode 100644
index 0000000..d8c480a
--- /dev/null
+++ b/machines/loup/home.nix
@@ -0,0 +1,9 @@
+{ pkgs, ... }:
+
+{
+  imports = [
+    ../../modules/home/common.nix
+  ];
+
+  home.stateVersion = "25.11";
+}