2024-02-29 22:20:26 -05:00
|
|
|
|
# Edit this configuration file to define what should be installed on
|
|
|
|
|
|
# your system. Help is available in the configuration.nix(5) man page
|
|
|
|
|
|
# and in the NixOS manual (accessible by running ‘nixos-help’).
|
|
|
|
|
|
{
|
|
|
|
|
|
config,
|
|
|
|
|
|
pkgs,
|
|
|
|
|
|
inputs,
|
2024-03-01 02:33:22 -05:00
|
|
|
|
lib,
|
2024-02-29 22:20:26 -05:00
|
|
|
|
...
|
|
|
|
|
|
}: {
|
|
|
|
|
|
imports = [
|
2024-03-01 14:34:11 -05:00
|
|
|
|
../common/default.nix
|
|
|
|
|
|
|
2024-02-29 22:20:26 -05:00
|
|
|
|
# Include the results of the hardware scan.
|
|
|
|
|
|
./hardware-configuration.nix
|
|
|
|
|
|
./nvidia.nix
|
|
|
|
|
|
../../env/wayland
|
2024-03-01 12:02:57 -05:00
|
|
|
|
({
|
|
|
|
|
|
options,
|
|
|
|
|
|
lib,
|
|
|
|
|
|
...
|
|
|
|
|
|
}:
|
|
|
|
|
|
lib.mkIf (options ? virtualisation.memorySize) {
|
|
|
|
|
|
users.users.zack.password = "foo";
|
|
|
|
|
|
})
|
2024-02-29 22:20:26 -05:00
|
|
|
|
];
|
|
|
|
|
|
|
|
|
|
|
|
# Bootloader.
|
|
|
|
|
|
boot.loader.systemd-boot.enable = true;
|
|
|
|
|
|
boot.loader.efi.canTouchEfiVariables = true;
|
|
|
|
|
|
|
|
|
|
|
|
networking.hostName = "earth"; # Define your hostname.
|
|
|
|
|
|
|
2024-03-01 02:03:49 -05:00
|
|
|
|
networking.networkmanager.unmanaged = ["enp6s0"];
|
|
|
|
|
|
|
2024-02-29 23:05:56 -05:00
|
|
|
|
boot.supportedFilesystems = ["ntfs"];
|
|
|
|
|
|
|
2024-02-29 22:20:26 -05:00
|
|
|
|
# Load nvidia driver for Xorg and Wayland
|
|
|
|
|
|
services.xserver.videoDrivers = ["nvidia"]; # or "nvidiaLegacy470 etc.
|
|
|
|
|
|
|
2024-03-02 00:06:29 -05:00
|
|
|
|
programs.steam = {
|
|
|
|
|
|
enable = true;
|
|
|
|
|
|
remotePlay.openFirewall = true;
|
|
|
|
|
|
};
|
|
|
|
|
|
|
2024-03-02 00:07:41 -05:00
|
|
|
|
environment.systemPackages = with pkgs; [
|
|
|
|
|
|
alvr
|
|
|
|
|
|
];
|
|
|
|
|
|
|
2024-02-29 22:20:26 -05:00
|
|
|
|
hardware.nvidia = {
|
|
|
|
|
|
# Modesetting is required.
|
|
|
|
|
|
modesetting.enable = true;
|
|
|
|
|
|
|
|
|
|
|
|
# Nvidia power management. Experimental, and can cause sleep/suspend to fail.
|
|
|
|
|
|
# Enable this if you have graphical corruption issues or application crashes after waking
|
|
|
|
|
|
# up from sleep. This fixes it by saving the entire VRAM memory to /tmp/ instead
|
|
|
|
|
|
# of just the bare essentials.
|
|
|
|
|
|
powerManagement.enable = false;
|
|
|
|
|
|
|
|
|
|
|
|
# Fine-grained power management. Turns off GPU when not in use.
|
|
|
|
|
|
# Experimental and only works on modern Nvidia GPUs (Turing or newer).
|
|
|
|
|
|
powerManagement.finegrained = false;
|
|
|
|
|
|
|
|
|
|
|
|
# Use the NVidia open source kernel module (not to be confused with the
|
|
|
|
|
|
# independent third-party "nouveau" open source driver).
|
|
|
|
|
|
# Support is limited to the Turing and later architectures. Full list of
|
|
|
|
|
|
# supported GPUs is at:
|
|
|
|
|
|
# https://github.com/NVIDIA/open-gpu-kernel-modules#compatible-gpus
|
|
|
|
|
|
# Only available from driver 515.43.04+
|
|
|
|
|
|
# Currently alpha-quality/buggy, so false is currently the recommended setting.
|
|
|
|
|
|
open = false;
|
|
|
|
|
|
|
|
|
|
|
|
# Enable the Nvidia settings menu,
|
|
|
|
|
|
# accessible via `nvidia-settings`.
|
|
|
|
|
|
nvidiaSettings = true;
|
|
|
|
|
|
|
|
|
|
|
|
# Optionally, you may need to select the appropriate driver version for your specific GPU.
|
|
|
|
|
|
package = config.boot.kernelPackages.nvidiaPackages.stable;
|
|
|
|
|
|
};
|
|
|
|
|
|
|
2024-03-01 02:52:11 -05:00
|
|
|
|
programs.virt-manager.enable = true;
|
|
|
|
|
|
|
2024-02-29 22:49:49 -05:00
|
|
|
|
virtualisation.docker.enable = true;
|
|
|
|
|
|
virtualisation.libvirtd.enable = true;
|
2024-02-29 22:20:26 -05:00
|
|
|
|
}
|