Add msi host
This commit is contained in:
parent
e8d8c1c788
commit
b93969cf34
15
flake.nix
15
flake.nix
|
@ -50,6 +50,20 @@
|
||||||
|
|
||||||
outputs = inputs @ { self, nixpkgs, ... }: {
|
outputs = inputs @ { self, nixpkgs, ... }: {
|
||||||
nixosConfigurations = {
|
nixosConfigurations = {
|
||||||
|
msi = nixpkgs.lib.nixosSystem rec {
|
||||||
|
system = "x86_64-linux";
|
||||||
|
specialArgs = { inherit self system inputs; };
|
||||||
|
|
||||||
|
modules = [
|
||||||
|
./modules/impurity.nix
|
||||||
|
./modules/preserve-system.nix
|
||||||
|
./modules/devenv
|
||||||
|
./modules/system.nix
|
||||||
|
./modules/hyprland
|
||||||
|
./systems/msi
|
||||||
|
];
|
||||||
|
};
|
||||||
|
|
||||||
lenovo = nixpkgs.lib.nixosSystem rec {
|
lenovo = nixpkgs.lib.nixosSystem rec {
|
||||||
system = "x86_64-linux";
|
system = "x86_64-linux";
|
||||||
specialArgs = { inherit self system inputs; };
|
specialArgs = { inherit self system inputs; };
|
||||||
|
@ -64,6 +78,7 @@
|
||||||
];
|
];
|
||||||
};
|
};
|
||||||
|
|
||||||
|
msi-impure = self.nixosConfigurations.msi.extendModules { modules = [ { impurity.enable = true; } ]; };
|
||||||
lenovo-impure = self.nixosConfigurations.lenovo.extendModules { modules = [ { impurity.enable = true; } ]; };
|
lenovo-impure = self.nixosConfigurations.lenovo.extendModules { modules = [ { impurity.enable = true; } ]; };
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
|
@ -21,6 +21,8 @@
|
||||||
environment.systemPackages = with pkgs; [
|
environment.systemPackages = with pkgs; [
|
||||||
git
|
git
|
||||||
vim
|
vim
|
||||||
|
];
|
||||||
|
|
||||||
networking = {
|
networking = {
|
||||||
networkmanager = {
|
networkmanager = {
|
||||||
enable = true;
|
enable = true;
|
||||||
|
@ -41,5 +43,4 @@
|
||||||
|
|
||||||
# removable disks in file manager
|
# removable disks in file manager
|
||||||
services.udisks2.enable = true;
|
services.udisks2.enable = true;
|
||||||
];
|
|
||||||
}
|
}
|
||||||
|
|
11
systems/msi/default.nix
Normal file
11
systems/msi/default.nix
Normal file
|
@ -0,0 +1,11 @@
|
||||||
|
{ pkgs, ... }: {
|
||||||
|
imports = [
|
||||||
|
./hardware.nix
|
||||||
|
./mullvad.nix
|
||||||
|
./hyprland
|
||||||
|
];
|
||||||
|
|
||||||
|
system.stateVersion = "23.11";
|
||||||
|
networking.hostName = "msi";
|
||||||
|
time.timeZone = "America/Vancouver";
|
||||||
|
}
|
36
systems/msi/hardware-configuration.nix
Normal file
36
systems/msi/hardware-configuration.nix
Normal file
|
@ -0,0 +1,36 @@
|
||||||
|
# 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 = [ "nvme" "xhci_pci" "usbhid" "usb_storage" "sd_mod" ];
|
||||||
|
boot.initrd.kernelModules = [ ];
|
||||||
|
boot.kernelModules = [ "kvm-amd" ];
|
||||||
|
boot.extraModulePackages = [ ];
|
||||||
|
|
||||||
|
fileSystems."/" =
|
||||||
|
{ device = "/dev/disk/by-uuid/c9cb1730-c0d1-4a2e-a092-12dfa7098476";
|
||||||
|
fsType = "ext4";
|
||||||
|
};
|
||||||
|
|
||||||
|
fileSystems."/boot" =
|
||||||
|
{ device = "/dev/disk/by-uuid/9BF9-E3ED";
|
||||||
|
fsType = "vfat";
|
||||||
|
};
|
||||||
|
|
||||||
|
swapDevices = [ ];
|
||||||
|
|
||||||
|
# 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`.
|
||||||
|
networking.useDHCP = lib.mkDefault true;
|
||||||
|
# networking.interfaces.wlp4s0.useDHCP = lib.mkDefault true;
|
||||||
|
|
||||||
|
hardware.cpu.amd.updateMicrocode = lib.mkDefault config.hardware.enableRedistributableFirmware;
|
||||||
|
}
|
18
systems/msi/hardware.nix
Normal file
18
systems/msi/hardware.nix
Normal file
|
@ -0,0 +1,18 @@
|
||||||
|
{ pkgs, ... }: {
|
||||||
|
imports = [ ./hardware-configuration.nix ];
|
||||||
|
|
||||||
|
hardware.opengl = {
|
||||||
|
enable = true;
|
||||||
|
driSupport = true;
|
||||||
|
driSupport32Bit = true;
|
||||||
|
|
||||||
|
extraPackages = with pkgs; [
|
||||||
|
rocm-opencl-icd
|
||||||
|
amdvlk
|
||||||
|
];
|
||||||
|
|
||||||
|
extraPackages32 = with pkgs; [
|
||||||
|
driversi686Linux.amdvlk
|
||||||
|
];
|
||||||
|
};
|
||||||
|
}
|
6
systems/msi/hyprland/default.nix
Normal file
6
systems/msi/hyprland/default.nix
Normal file
|
@ -0,0 +1,6 @@
|
||||||
|
{ impurity, ... }: {
|
||||||
|
hyprland-session = {
|
||||||
|
prerun = "export WLR_DRM_DEVICES=/dev/dri/card0:/dev/dri/card1";
|
||||||
|
extraConfig = "source = ${impurity.link ./hyprland.conf}";
|
||||||
|
};
|
||||||
|
}
|
24
systems/msi/hyprland/hyprland.conf
Normal file
24
systems/msi/hyprland/hyprland.conf
Normal file
|
@ -0,0 +1,24 @@
|
||||||
|
monitor = eDP-1, 1920x1080@240Hz, 0x1440, 1
|
||||||
|
monitor = DP-1, 5120x1440@120Hz, 1350x0, 1
|
||||||
|
monitor = , preferred, auto, 1
|
||||||
|
|
||||||
|
workspace = 01, monitor:DP-1, default:true
|
||||||
|
workspace = 02, monitor:DP-1
|
||||||
|
workspace = 03, monitor:DP-1
|
||||||
|
workspace = 04, monitor:DP-1
|
||||||
|
workspace = 05, monitor:DP-1
|
||||||
|
workspace = 06, monitor:DP-1
|
||||||
|
workspace = 07, monitor:DP-1
|
||||||
|
workspace = 08, monitor:DP-1
|
||||||
|
workspace = 09, monitor:DP-1
|
||||||
|
workspace = 10, monitor:DP-1
|
||||||
|
workspace = 11, monitor:eDP-1, default:true
|
||||||
|
workspace = 12, monitor:eDP-1
|
||||||
|
workspace = 13, monitor:eDP-1
|
||||||
|
workspace = 14, monitor:eDP-1
|
||||||
|
workspace = 15, monitor:eDP-1
|
||||||
|
workspace = 16, monitor:eDP-1
|
||||||
|
workspace = 17, monitor:eDP-1
|
||||||
|
workspace = 18, monitor:eDP-1
|
||||||
|
workspace = 19, monitor:eDP-1
|
||||||
|
workspace = 20, monitor:eDP-1
|
4
systems/msi/mullvad.nix
Normal file
4
systems/msi/mullvad.nix
Normal file
|
@ -0,0 +1,4 @@
|
||||||
|
{ pkgs, config, ... }: {
|
||||||
|
services.mullvad-vpn.enable = true;
|
||||||
|
home-manager.users.${config.main-user}.home.packages = [ pkgs.mullvad-vpn ];
|
||||||
|
}
|
Loading…
Reference in a new issue