about summary refs log tree commit diff
path: root/nixos/kanata/hardware-configuration.nix
blob: 262b0c6723cc1d8b681742474226ed7bd0ce8c30 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
# 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 = [ "xhci_pci" "ahci" "mpt3sas" "usbhid" "usb_storage" "sd_mod" ];
  boot.initrd.kernelModules = [ ];
  boot.kernelModules = [ "kvm-amd" ];
  boot.extraModulePackages = [ ];

  fileSystems."/" =
    { device = "rpool/local/root";
      fsType = "zfs";
    };

  fileSystems."/boot" =
    { device = "/dev/disk/by-uuid/7141-F8DA";
      fsType = "vfat";
    };

  fileSystems."/nix" =
    { device = "rpool/local/nix";
      fsType = "zfs";
    };

  fileSystems."/home" =
    { device = "rpool/safe/home";
      fsType = "zfs";
    };

  fileSystems."/persist" =
    { device = "rpool/safe/persist";
      fsType = "zfs";
    };

  # ZFS pool `smol` is decrypted using a sops key named `zfs-smol-key`.
  # In an event of emergency, manual unlocking is possible by typing the passphrase.
  fileSystems."/smol/core" =
  { device = "smol/ds1/core";
    fsType = "zfs";
  };

  fileSystems."/smol/moon" =
  { device = "smol/ds1/moon";
    fsType = "zfs";
  };

  fileSystems."/smol/sandbox" =
  { device = "smol/ds1/sandbox";
    fsType = "zfs";
  };

  fileSystems."/smol/backups" =
  { device = "smol/ds1/backups";
    fsType = "zfs";
  };

  fileSystems."/smol/archive" =
  { device = "smol/ds1/archive";
    fsType = "zfs";
  };

  swapDevices =
    [ { device = "/dev/disk/by-uuid/c092b7a3-813c-4be7-9730-45d9426f524c"; }
    ];

  # 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`.
  # TODO FIXME(sefidel): uncomment
  # networking.useDHCP = lib.mkDefault true;
  networking.useDHCP = lib.mkForce true;
  # networking.interfaces.enp4s0.useDHCP = lib.mkDefault true;

  nixpkgs.hostPlatform = lib.mkDefault "x86_64-linux";
  hardware.cpu.amd.updateMicrocode = lib.mkDefault config.hardware.enableRedistributableFirmware;
}