# 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.kernelParams = [ # === NVMe SSD Timeout / Freeze Fix for Linux === # https://community.frame.work/t/nvme-timeout-woes/54999 "nvme_core.default_ps_max_latency_us=0" # Explanation: Completely disables NVMe Autonomous Power State Transition (APST) # Why: Your drive enters deep sleep states during high load. Wake-up latency is too slow (>30 ms), # causing the kernel to think the command timed out. # Setting it to 0 = never let the drive sleep → root-cause fix for "freezes during big reads/writes" "nvme_core.io_timeout=4294967295" # Explanation: Increases the kernel's NVMe command timeout to the maximum possible value (~49 days) # Why: Linux default is only 30 seconds, after which it aborts the request and resets the controller. # This makes the kernel "patient" so even if the drive is momentarily slow, it won't crash/reset. "pcie_aspm=off" # Explanation: Fully disables PCIe Active State Power Management (link power saving) # Why: The PCIe link dropping into L1/L1.2 low-power states is the #1 cause of NVMe timeouts on Linux. # Turning it off keeps the link at full speed at all times → eliminates "Link is Down" + timeout errors. ]; # Use the EFI boot loader. boot.loader.efi.canTouchEfiVariables = true; # depending on how you configured your disk mounts, change this to /boot or /boot/efi. boot.loader.efi.efiSysMountPoint = "/boot"; boot.loader.systemd-boot.enable = true; # https://github.com/NixOS/nixpkgs/blob/nixos-unstable/pkgs/top-level/linux-kernels.nix boot.kernelPackages = pkgs.linuxPackages_6_18; # 6.19 works not well with nvidia driver boot.initrd.availableKernelModules = [ "xhci_pci" "ahci" "nvme" "usbhid" "usb_storage" "sd_mod" ]; boot.initrd.kernelModules = [ ]; boot.kernelModules = [ "kvm-intel" ]; # kvm virtualization support boot.extraModprobeConfig = "options kvm_intel nested=1"; # for intel cpu boot.extraModulePackages = [ ]; # clear /tmp on boot to get a stateless /tmp directory. boot.tmp.cleanOnBoot = true; # Enable binfmt emulation of aarch64-linux, this is required for cross compilation. boot.binfmt.emulatedSystems = [ "aarch64-linux" "riscv64-linux" ]; # This enables the kernel to preload the emulator binaries when the binfmt registrations are added, # obviating the need to make the emulator binaries available inside chroots and chroot-like sandboxes. boot.binfmt.preferStaticEmulators = true; # required to work with podman # supported file systems, so we can mount any removable disks with these filesystems boot.supportedFilesystems = [ "ext4" "btrfs" "xfs" "ntfs" "fat" "vfat" "exfat" ]; # LUKS initrd, all fileSystems (/, /boot, /btr_pool, /nix, /gnu, /persistent, /snapshots, /tmp, /swap) # and swap (including /swap/swapfile bind and swapDevices) are managed by disko (disko-fs.nix). # 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..useDHCP`. networking.useDHCP = lib.mkDefault true; # networking.interfaces.enp5s0.useDHCP = lib.mkDefault true; # networking.interfaces.wlo1.useDHCP = lib.mkDefault true; nixpkgs.hostPlatform = lib.mkDefault "x86_64-linux"; powerManagement.cpuFreqGovernor = lib.mkDefault "performance"; # ondemand / powersave / performance hardware.cpu.intel.updateMicrocode = lib.mkDefault config.hardware.enableRedistributableFirmware; }