nixfiles/nixos/boxes/home/palace/default.nix

228 lines
6.3 KiB
Nix
Raw Normal View History

2023-12-03 22:58:28 +00:00
{ lib, ... }:
let
inherit (lib.my) net mkVLAN;
inherit (lib.my.c) pubDomain;
inherit (lib.my.c.home) domain vlans prefixes vips hiMTU;
2023-12-03 22:58:28 +00:00
in
{
2023-12-10 02:29:53 +00:00
imports = [ ./vms ];
2023-12-03 22:58:28 +00:00
nixos.systems.palace = {
system = "x86_64-linux";
nixpkgs = "mine-stable";
home-manager = "mine-stable";
assignments = {
hi = {
inherit domain;
mtu = hiMTU;
2023-12-03 22:58:28 +00:00
ipv4 = {
address = net.cidr.host 22 prefixes.hi.v4;
mask = 22;
gateway = vips.hi.v4;
};
ipv6 = {
iid = "::2:1";
address = net.cidr.host (65536*2+1) prefixes.hi.v6;
};
2023-12-03 22:58:28 +00:00
};
core = {
inherit domain;
name = "palace-core";
mtu = 1500;
2023-12-03 22:58:28 +00:00
ipv4 = {
address = net.cidr.host 20 prefixes.core.v4;
gateway = null;
};
};
};
configuration = { lib, pkgs, modulesPath, config, systems, assignments, allAssignments, ... }:
let
inherit (lib) mkForce mkMerge;
inherit (lib.my) networkdAssignment;
inherit (lib.my.c) networkd;
2023-12-03 22:58:28 +00:00
in
{
boot = {
2023-12-09 15:22:49 +00:00
kernelPackages = (lib.my.c.kernel.lts pkgs).extend (self: super: {
kernel = super.kernel.override {
structuredExtraConfig = with lib.kernel; {
ACPI_APEI_PCIEAER = yes;
PCIEAER = yes;
};
};
});
2023-12-03 22:58:28 +00:00
kernelModules = [ "kvm-amd" ];
kernelParams = [ "amd_iommu=on" ];
initrd = {
2023-12-10 02:29:53 +00:00
availableKernelModules = [ "xhci_pci" "ahci" "usb_storage" "usbhid" "sd_mod" "sr_mod" ];
2023-12-03 22:58:28 +00:00
};
};
hardware = {
enableRedistributableFirmware = true;
cpu = {
amd.updateMicrocode = true;
};
};
fileSystems = {
"/boot" = {
device = "/dev/disk/by-partuuid/c06a8d24-2af9-4416-bf5e-cfe6defdbd47";
fsType = "vfat";
};
"/nix" = {
2023-12-10 02:29:53 +00:00
device = "/dev/disk/by-uuid/450e1f72-238a-4160-98b8-b5e6d0d6fdf6";
2023-12-03 22:58:28 +00:00
fsType = "ext4";
};
"/persist" = {
2023-12-10 02:29:53 +00:00
device = "/dev/disk/by-uuid/9d6d53a8-dff8-49e0-9bc3-fb5f7c6760d0";
2023-12-03 22:58:28 +00:00
fsType = "ext4";
neededForBoot = true;
};
};
services = {
2023-12-10 02:29:53 +00:00
lvm = {
boot.thin.enable = true;
dmeventd.enable = true;
};
2023-12-03 22:58:28 +00:00
smartd = {
enable = true;
autodetect = true;
extraOptions = [ "-A /var/log/smartd/" "--interval=600" ];
};
2023-12-10 02:29:53 +00:00
udev.extraRules = ''
2024-06-30 01:52:52 +01:00
ACTION=="add", SUBSYSTEM=="net", ENV{ID_NET_DRIVER}=="mlx5_core", ENV{ID_PATH}=="pci-0000:44:00.0", ATTR{device/sriov_numvfs}="4"
2023-12-10 02:29:53 +00:00
'';
2023-12-03 22:58:28 +00:00
};
environment.systemPackages = with pkgs; [
pciutils
usbutils
partclone
lm_sensors
linuxPackages.cpupower
smartmontools
mstflint
ethtool
2023-12-10 02:29:53 +00:00
hwloc
2023-12-03 22:58:28 +00:00
];
2023-12-22 01:34:28 +00:00
networking = { inherit domain; };
2023-12-03 22:58:28 +00:00
systemd = {
tmpfiles.rules = [
"d /var/log/smartd 0755 root root"
];
network = {
links = {
"10-et1g0" = {
matchConfig = {
PermanentMACAddress = "e0:d5:5e:68:0c:6e";
Driver = "igb";
};
2023-12-03 22:58:28 +00:00
linkConfig.Name = "et1g0";
};
"10-lan-core" = {
matchConfig.PermanentMACAddress = "e0:d5:5e:68:0c:70";
2023-12-03 22:58:28 +00:00
linkConfig.Name = "lan-core";
};
"10-et100g" = {
matchConfig = {
PermanentMACAddress = "24:8a:07:ac:59:c0";
Driver = "mlx5_core";
};
linkConfig = {
Name = "et100g";
MTUBytes = toString hiMTU;
2023-12-03 22:58:28 +00:00
};
};
};
netdevs = mkMerge [
(mkVLAN "lan-hi" vlans.hi)
2023-12-22 01:34:28 +00:00
(mkVLAN "lan-lo-phy" vlans.lo)
{
"25-lan-lo".netdevConfig = {
Name = "lan-lo";
Kind = "bridge";
};
}
2023-12-03 22:58:28 +00:00
];
networks = {
"50-lan-core" = mkMerge [
(networkdAssignment "lan-core" assignments.core)
{
matchConfig.Name = "lan-core";
2023-12-22 01:34:28 +00:00
vlan = [ "lan-lo-phy" ];
2023-12-03 22:58:28 +00:00
networkConfig.IPv6AcceptRA = mkForce false;
}
];
"50-et100g" = {
matchConfig.Name = "et100g";
vlan = [ "lan-hi" ];
networkConfig = networkd.noL3;
linkConfig.RequiredForOnline = "no";
2023-12-10 02:29:53 +00:00
extraConfig = ''
# cellar
[SR-IOV]
VirtualFunction=0
VLANId=${toString vlans.hi}
LinkState=yes
MACAddress=52:54:00:cc:3e:70
# river
[SR-IOV]
VirtualFunction=1
LinkState=yes
MACAddress=52:54:00:8a:8a:f2
2023-12-22 01:34:28 +00:00
# sfh
[SR-IOV]
VirtualFunction=2
VLANId=${toString vlans.hi}
LinkState=yes
MACAddress=52:54:00:ac:15:a9
2024-06-30 01:52:52 +01:00
# sfh bridge
[SR-IOV]
VirtualFunction=3
VLANId=${toString vlans.hi}
LinkState=yes
MACAddress=52:54:00:90:34:95
2023-12-10 02:29:53 +00:00
'';
2023-12-03 22:58:28 +00:00
};
"60-lan-hi" = networkdAssignment "lan-hi" assignments.hi;
2023-12-22 01:34:28 +00:00
"50-lan-lo-phy" = {
matchConfig.Name = "lan-lo-phy";
networkConfig = {
Bridge = "lan-lo";
} // networkd.noL3;
};
"60-lan-lo" = {
matchConfig.Name = "lan-lo";
linkConfig.RequiredForOnline = "no";
networkConfig = networkd.noL3;
};
2023-12-03 22:58:28 +00:00
};
};
};
my = {
secrets = {
key = "ssh-ed25519 AAAAC3NzaC1lZDI1NTE5AAAAIHzVJpoDz/AAYLJGzU8t6DgZ2sY3oehRqrlSO7C+GWiK";
};
server.enable = true;
deploy.node.hostname = "192.168.68.22";
};
};
};
}