2024-07-15 21:24:50 +02:00
|
|
|
|
#
|
|
|
|
|
# Hardware settings for Teclast F5 10" Laptop
|
|
|
|
|
# NixOS @ sda2
|
|
|
|
|
#
|
|
|
|
|
# flake.nix
|
|
|
|
|
# └─ ./hosts
|
|
|
|
|
# └─ ./laptop
|
|
|
|
|
# └─ hardware-configuration.nix *
|
|
|
|
|
#
|
|
|
|
|
# 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")] ++
|
|
|
|
|
[( import ../../modules/hardware/backup.nix )];
|
|
|
|
|
|
|
|
|
|
boot = {
|
|
|
|
|
initrd = {
|
2024-07-17 21:17:50 +02:00
|
|
|
|
availableKernelModules = [ "xhci_pci" "thunderbolt" "nvme" "usb_storage" "sd_mod" "sdhci_pci" ];
|
2024-07-15 21:24:50 +02:00
|
|
|
|
kernelModules = [ "i915" "kvm_intel" "vfio_pci" "vfio" "vfio_iommu_type1" ];
|
|
|
|
|
systemd.enable = true;
|
|
|
|
|
luks = {
|
|
|
|
|
devices."crypted" = {
|
|
|
|
|
device = "/dev/disk/by-partlabel/disk-nvme0n1-luks";
|
|
|
|
|
allowDiscards = true;
|
2024-12-07 22:52:18 +01:00
|
|
|
|
bypassWorkqueues = true;
|
2024-07-15 21:24:50 +02:00
|
|
|
|
};
|
|
|
|
|
};
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
kernelModules = [ "kvm-intel" ];
|
2024-10-20 11:00:40 +02:00
|
|
|
|
kernelParams = [ "luks.options=fido2-device=auto" "sysrq_always_enabled=1" "pcie_aspm=force" ];
|
2024-08-10 06:08:14 +02:00
|
|
|
|
extraModprobeConfig = ''
|
|
|
|
|
options i915 enable_guc=3
|
|
|
|
|
'';
|
2024-07-15 21:24:50 +02:00
|
|
|
|
tmp.useTmpfs = false;
|
|
|
|
|
tmp.cleanOnBoot = true;
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
zramSwap.enable = true;
|
|
|
|
|
|
2024-08-25 20:15:26 +02:00
|
|
|
|
|
2024-07-15 21:24:50 +02:00
|
|
|
|
services = {
|
|
|
|
|
btrfs.autoScrub = {
|
|
|
|
|
enable = true;
|
|
|
|
|
interval = "monthly";
|
|
|
|
|
fileSystems = [
|
|
|
|
|
"/"
|
|
|
|
|
];
|
|
|
|
|
};
|
|
|
|
|
udev.extraRules = ''
|
|
|
|
|
ACTION=="add", SUBSYSTEM=="block", KERNEL=="mmcblk[0-9]p[0-9]", ENV{ID_FS_USAGE}=="filesystem", RUN{program}+="${pkgs.systemd}/bin/systemd-mount -o noatime,compress-force=zstd:15,ssd_spread,commit=120 --no-block --automount=yes --collect $devnode /run/media/mmcblk0p1"
|
|
|
|
|
'';
|
|
|
|
|
|
|
|
|
|
btrbk = {
|
2024-10-14 20:08:16 +02:00
|
|
|
|
extraPackages = [ pkgs.lz4 pkgs.mbuffer ];
|
2024-07-15 21:24:50 +02:00
|
|
|
|
instances = {
|
|
|
|
|
hf = {
|
|
|
|
|
onCalendar = "hourly";
|
|
|
|
|
settings = {
|
|
|
|
|
incremental = "yes";
|
|
|
|
|
snapshot_create = "ondemand";
|
|
|
|
|
snapshot_dir = "@snapshots";
|
|
|
|
|
timestamp_format = "long";
|
|
|
|
|
|
|
|
|
|
snapshot_preserve = "2m 2w 5d 5h";
|
|
|
|
|
snapshot_preserve_min = "latest";
|
|
|
|
|
|
|
|
|
|
volume = {
|
|
|
|
|
"/mnt/snapshots/root" = {
|
|
|
|
|
snapshot_create = "always";
|
|
|
|
|
subvolume = {
|
|
|
|
|
"@home" = {};
|
|
|
|
|
};
|
|
|
|
|
};
|
|
|
|
|
};
|
|
|
|
|
};
|
|
|
|
|
};
|
2024-10-14 20:18:48 +02:00
|
|
|
|
bak = {
|
|
|
|
|
onCalendar = "daily";
|
|
|
|
|
settings = {
|
|
|
|
|
stream_buffer = "256m";
|
|
|
|
|
stream_compress = "lz4";
|
|
|
|
|
incremental = "yes";
|
|
|
|
|
snapshot_create = "no";
|
|
|
|
|
snapshot_dir = "@snapshots";
|
|
|
|
|
timestamp_format = "long";
|
2024-10-14 20:08:16 +02:00
|
|
|
|
|
2024-10-14 20:18:48 +02:00
|
|
|
|
snapshot_preserve_min = "all";
|
|
|
|
|
target_preserve_min = "no";
|
2024-10-20 11:00:40 +02:00
|
|
|
|
target_preserve = "2m 4w 3d";
|
2024-10-14 20:08:16 +02:00
|
|
|
|
|
2024-10-14 20:18:48 +02:00
|
|
|
|
ssh_identity = "/etc/btrbk/ssh/id_ed25519_btrbk_nas";
|
|
|
|
|
ssh_user = "btrbk";
|
|
|
|
|
|
|
|
|
|
volume = {
|
|
|
|
|
"/mnt/snapshots/root" = {
|
|
|
|
|
subvolume = {
|
|
|
|
|
"@home" = {};
|
|
|
|
|
};
|
|
|
|
|
target = "ssh://jupiter.home.opel-online.de:2220/mnt/snapshots/Mars/@snapshots/@lifebook";
|
2024-10-14 20:08:16 +02:00
|
|
|
|
};
|
|
|
|
|
};
|
2024-10-14 20:18:48 +02:00
|
|
|
|
};
|
2024-10-14 20:08:16 +02:00
|
|
|
|
};
|
2024-10-14 20:18:48 +02:00
|
|
|
|
};
|
2024-07-15 21:24:50 +02:00
|
|
|
|
};
|
2024-10-19 08:51:01 +02:00
|
|
|
|
};
|
|
|
|
|
|
2024-10-20 11:00:40 +02:00
|
|
|
|
systemd.timers = {
|
2024-10-19 08:51:01 +02:00
|
|
|
|
btrbk-bak = {
|
2025-01-13 17:17:18 +01:00
|
|
|
|
after = [ "network-online.target" ];
|
2024-10-20 11:00:40 +02:00
|
|
|
|
requires = [ "network-online.target" ];
|
2024-10-19 08:51:01 +02:00
|
|
|
|
};
|
2024-07-15 21:24:50 +02:00
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
fileSystems."/" =
|
|
|
|
|
{ device = "/dev/mapper/crypted";
|
|
|
|
|
fsType = "btrfs";
|
|
|
|
|
options = [ "compress=zstd,space_cache=v2,ssd,noatime,subvol=@,discard=async" ];
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
fileSystems."/boot" =
|
|
|
|
|
{ device = "/dev/disk/by-label/NIXBOOT";
|
|
|
|
|
fsType = "vfat";
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
fileSystems."/home" =
|
|
|
|
|
{ device = "/dev/mapper/crypted";
|
|
|
|
|
fsType = "btrfs";
|
|
|
|
|
options = [ "compress=zstd,space_cache=v2,ssd,noatime,subvol=@home,discard=async" ];
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
fileSystems."/nix" =
|
|
|
|
|
{ device = "/dev/mapper/crypted";
|
|
|
|
|
fsType = "btrfs";
|
|
|
|
|
options = [ "compress=zstd,space_cache=v2,ssd,noatime,subvol=@nix,discard=async" ];
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
fileSystems."/srv" =
|
|
|
|
|
{ device = "/dev/mapper/crypted";
|
|
|
|
|
fsType = "btrfs";
|
|
|
|
|
options = [ "compress=zstd,space_cache=v2,ssd,noatime,subvol=@srv,discard=async" ];
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
fileSystems."/swap" =
|
|
|
|
|
{ device = "/dev/mapper/crypted";
|
|
|
|
|
fsType = "btrfs";
|
|
|
|
|
options = [ "compress=zstd,space_cache=v2,ssd,noatime,subvol=@swap,discard=async" ];
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
fileSystems."/opt" =
|
|
|
|
|
{ device = "/dev/mapper/crypted";
|
|
|
|
|
fsType = "btrfs";
|
|
|
|
|
options = [ "compress=zstd,space_cache=v2,ssd,noatime,subvol=@opt,discard=async" ];
|
|
|
|
|
};
|
|
|
|
|
|
2024-07-17 21:17:50 +02:00
|
|
|
|
fileSystems."/var" =
|
|
|
|
|
{ device = "/dev/mapper/crypted";
|
|
|
|
|
fsType = "btrfs";
|
|
|
|
|
options = [ "compress=zstd,space_cache=v2,ssd,noatime,subvol=@var,discard=async" ];
|
|
|
|
|
};
|
|
|
|
|
|
2024-07-15 21:24:50 +02:00
|
|
|
|
fileSystems."/mnt/snapshots/root" =
|
|
|
|
|
{ device = "/dev/mapper/crypted";
|
|
|
|
|
fsType = "btrfs";
|
|
|
|
|
options = [ "compress=zstd,space_cache=v2,ssd,noatime,subvolid=5,discard=async" ];
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
fileSystems."/mnt/Pluto" =
|
|
|
|
|
{ device = "jupiter:/Pluto";
|
|
|
|
|
fsType = "nfs";
|
|
|
|
|
options = [ "nofail,noauto,users,x-systemd.automount,x-systemd.device-timeout=10,soft,timeo=14,x-systemd.idle-timeout=1min,sec=sys,exec,nfsvers=4.2" ];
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
fileSystems."/mnt/Mars" =
|
|
|
|
|
{ device = "jupiter:/Mars";
|
|
|
|
|
fsType = "nfs";
|
|
|
|
|
options = [ "nofail,noauto,users,x-systemd.automount,x-systemd.device-timeout=10,soft,timeo=14,x-systemd.idle-timeout=1min,sec=sys,exec,nfsvers=4.2" ];
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
swapDevices = [ { device = "/swap/swapfile"; } ];
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
networking = {
|
|
|
|
|
useDHCP = false; # Deprecated
|
|
|
|
|
hostName = "lifebook";
|
|
|
|
|
wireless.iwd.enable = true;
|
|
|
|
|
networkmanager = {
|
|
|
|
|
enable = true;
|
|
|
|
|
wifi = {
|
|
|
|
|
backend = "iwd";
|
|
|
|
|
powersave = true;
|
|
|
|
|
};
|
|
|
|
|
};
|
|
|
|
|
# interfaces = {
|
|
|
|
|
# wlan0 = {
|
|
|
|
|
# useDHCP = true; # For versatility sake, manually edit IP on nm-applet.
|
|
|
|
|
# #ipv4.addresses = [ {
|
|
|
|
|
# # address = "192.168.0.51";
|
|
|
|
|
# # prefixLength = 24;
|
|
|
|
|
# #} ];
|
|
|
|
|
# };
|
|
|
|
|
# };
|
|
|
|
|
#defaultGateway = "192.168.0.1";
|
|
|
|
|
#nameservers = [ "192.168.0.4" ];
|
|
|
|
|
firewall = {
|
2024-10-20 11:00:40 +02:00
|
|
|
|
#checkReversePath = false;
|
2024-07-15 21:24:50 +02:00
|
|
|
|
enable = true;
|
2024-08-10 06:08:14 +02:00
|
|
|
|
allowedUDPPorts = [ 24727 51820 ];
|
2024-07-15 21:24:50 +02:00
|
|
|
|
allowedTCPPorts = [ 24727 ];
|
|
|
|
|
};
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
hardware.cpu.intel.updateMicrocode = lib.mkDefault config.hardware.enableRedistributableFirmware;
|
|
|
|
|
powerManagement = {
|
2024-08-10 06:08:14 +02:00
|
|
|
|
powertop.enable = true;
|
2024-07-15 21:24:50 +02:00
|
|
|
|
};
|
|
|
|
|
}
|