93 lines
3.4 KiB
Nix
93 lines
3.4 KiB
Nix
{ config, pkgs, modulesPath, lib, nixos-hardware, ... }: {
|
|
networking.hostName = "thinkrac";
|
|
networking.hostId = "2bfaea87";
|
|
|
|
imports = [
|
|
(modulesPath + "/installer/scan/not-detected.nix")
|
|
./systemd-boot.nix
|
|
./desktop.nix
|
|
./services/tpm2.nix
|
|
nixos-hardware.nixosModules.lenovo-thinkpad-t470s
|
|
nixos-hardware.nixosModules.common-cpu-intel-kaby-lake
|
|
nixos-hardware.nixosModules.common-pc-ssd
|
|
];
|
|
hardware.cpu.intel.updateMicrocode = true;
|
|
|
|
boot.initrd.availableKernelModules = [ "xhci_pci" "nvme" "usb_storage" "sd_mod" "bcache" ];
|
|
boot.initrd.kernelModules = [ ];
|
|
boot.kernelModules = [ "kvm-intel" ];
|
|
boot.extraModulePackages = [ ];
|
|
|
|
boot.supportedFilesystems = [ "bcachefs" ];
|
|
|
|
boot.initrd.luks.devices = {
|
|
disk = {
|
|
device = "/dev/disk/by-uuid/2100a2e1-d874-4aaa-a89f-0b01665445b4";
|
|
allowDiscards = true;
|
|
};
|
|
};
|
|
|
|
fileSystems."/" = {
|
|
device = "/dev/mapper/disk";
|
|
fsType = "bcachefs";
|
|
};
|
|
|
|
|
|
fileSystems."/boot" = {
|
|
device = "/dev/disk/by-uuid/EE61-E55F";
|
|
fsType = "vfat";
|
|
};
|
|
|
|
networking.interfaces.enp0s31f6.useDHCP = true;
|
|
system.stateVersion = "21.11";
|
|
networking.wireguard.interfaces."wg0".ips = [
|
|
"fd0d:a262:1fa6:e621:f45a:db9f:eb7c:1a3f/64"
|
|
];
|
|
networking.nameservers = [ "fd00:e621:e621:2::2" ];
|
|
services.xserver.videoDrivers = [ "intel" ];
|
|
nix.settings.cores = 4;
|
|
|
|
# Disable kernel mitigations
|
|
#
|
|
# Rationale:
|
|
# - device has a limited workload, consisting mostly of running trusted code and visiting trusted websites with an advertisement blocker
|
|
# - device is battery powered (we want to spend more time in an idle state, as opposed to running user code or mitigating cpu bugs)
|
|
# - device is also not involved in any sort of virtualization
|
|
boot.kernelParams = [ "mitigations=off" ];
|
|
# use the lowest frequency possible, to save power
|
|
powerManagement.cpuFreqGovernor = "powersave";
|
|
# lm_sensors who cares
|
|
environment.etc."sysconfig/lm_sensors".text = ''
|
|
# Generated by sensors-detect on Tue Aug 7 10:54:09 2018
|
|
# This file is sourced by /etc/init.d/lm_sensors and defines the modules to
|
|
# be loaded/unloaded.
|
|
#
|
|
# The format of this file is a shell script that simply defines variables:
|
|
# HWMON_MODULES for hardware monitoring driver modules, and optionally
|
|
# BUS_MODULES for any required bus driver module (for example for I2C or SPI).
|
|
|
|
HWMON_MODULES="coretemp"
|
|
'';
|
|
services.thermald.enable = true;
|
|
boot.extraModprobeConfig = ''
|
|
# enable power savings mode of snd_hda_intel
|
|
options snd-hda-intel power_save=1 power_save_controller=y
|
|
# enable power savings mode of igpu, enable framebuffer compression, downclock the LVDS connection
|
|
options i915 i915_enable_rc6=7 i915_enable_fbc=1 lvds_downclock=1
|
|
# automatically suspend USB devices
|
|
options usbcore autosuspend=2
|
|
# Fan control for thinkpads
|
|
options thinkpad_acpi fan_control=1
|
|
'';
|
|
boot.kernel.sysctl = {
|
|
# Probably unnecessary
|
|
"kernel.nmi_watchdog" = "0";
|
|
"vm.laptop_mode" = "5";
|
|
# The kernel flusher threads will periodically wake up and write `old' data out to disk. This
|
|
# tunable expresses the interval between those wakeups, in 100'ths of a second (Default is 500).
|
|
"vm.dirty_writeback_centisecs" = "1500";
|
|
};
|
|
networking.networkmanager.enable = true;
|
|
users.users.darkkirb.extraGroups = [ "networkmanager" ];
|
|
nix.settings.max-jobs = 0;
|
|
}
|