2023-12-11 01:55:02 +00:00
|
|
|
{
|
|
|
|
imports = [ (import ../../routing-common 0) ];
|
|
|
|
|
|
|
|
config.nixos.systems.river = {
|
|
|
|
system = "x86_64-linux";
|
|
|
|
nixpkgs = "mine";
|
|
|
|
home-manager = "mine";
|
|
|
|
|
|
|
|
configuration = { lib, modulesPath, pkgs, config, assignments, allAssignments, ... }:
|
|
|
|
let
|
|
|
|
inherit (lib.my) networkdAssignment mkVLAN;
|
|
|
|
inherit (lib.my.c) networkd;
|
2024-06-29 23:12:21 +01:00
|
|
|
inherit (lib.my.c.home) vlans domain prefixes roceBootModules;
|
2023-12-11 01:55:02 +00:00
|
|
|
in
|
|
|
|
{
|
|
|
|
imports = [
|
|
|
|
"${modulesPath}/profiles/qemu-guest.nix"
|
|
|
|
];
|
|
|
|
|
|
|
|
config = {
|
|
|
|
boot = {
|
2024-06-29 23:12:21 +01:00
|
|
|
kernelModules = [ "kvm-amd" ];
|
2023-12-11 01:55:02 +00:00
|
|
|
kernelParams = [ "console=ttyS0,115200n8" ];
|
|
|
|
initrd = {
|
|
|
|
availableKernelModules = [
|
|
|
|
"virtio_pci" "ahci" "sr_mod" "virtio_blk"
|
2024-06-30 01:52:52 +01:00
|
|
|
"8021q"
|
2024-06-29 23:12:21 +01:00
|
|
|
] ++ roceBootModules;
|
|
|
|
kernelModules = [ "dm-snapshot" ];
|
2023-12-11 01:55:02 +00:00
|
|
|
systemd = {
|
|
|
|
network = {
|
2024-06-29 23:12:21 +01:00
|
|
|
# Don't need to put the link config here, they're copied from main config
|
2023-12-11 01:55:02 +00:00
|
|
|
netdevs = mkVLAN "lan-hi" vlans.hi;
|
|
|
|
networks = {
|
|
|
|
"20-lan" = {
|
|
|
|
matchConfig.Name = "lan";
|
|
|
|
vlan = [ "lan-hi" ];
|
|
|
|
linkConfig.RequiredForOnline = "no";
|
|
|
|
networkConfig = networkd.noL3;
|
|
|
|
};
|
|
|
|
"30-lan-hi" = networkdAssignment "lan-hi" assignments.hi;
|
|
|
|
};
|
|
|
|
};
|
|
|
|
};
|
|
|
|
};
|
|
|
|
};
|
|
|
|
|
|
|
|
hardware = {
|
|
|
|
enableRedistributableFirmware = true;
|
|
|
|
};
|
|
|
|
|
|
|
|
fileSystems = {
|
|
|
|
"/boot" = {
|
|
|
|
device = "/dev/disk/by-partuuid/3ec6c49e-b485-40cb-8eff-315581ac6fe9";
|
|
|
|
fsType = "vfat";
|
|
|
|
};
|
|
|
|
"/nix" = {
|
|
|
|
device = "/dev/main/nix";
|
|
|
|
fsType = "ext4";
|
|
|
|
};
|
|
|
|
"/persist" = {
|
|
|
|
device = "/dev/main/persist";
|
|
|
|
fsType = "ext4";
|
|
|
|
neededForBoot = true;
|
|
|
|
};
|
|
|
|
};
|
|
|
|
|
|
|
|
services = {
|
|
|
|
lvm = {
|
|
|
|
boot.thin.enable = true;
|
|
|
|
dmeventd.enable = true;
|
|
|
|
};
|
2024-06-29 23:12:21 +01:00
|
|
|
fstrim.enable = true;
|
2023-12-11 01:55:02 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
systemd.network = {
|
|
|
|
links = {
|
|
|
|
"10-wan" = {
|
|
|
|
matchConfig = {
|
|
|
|
# Matching against MAC address seems to break VLAN interfaces
|
|
|
|
# (since they share the same MAC address)
|
|
|
|
Driver = "virtio_net";
|
|
|
|
PermanentMACAddress = "e0:d5:5e:68:0c:6e";
|
|
|
|
};
|
|
|
|
linkConfig = {
|
|
|
|
Name = "wan";
|
|
|
|
RxBufferSize = 4096;
|
|
|
|
TxBufferSize = 4096;
|
|
|
|
};
|
|
|
|
};
|
|
|
|
|
2024-06-29 23:12:21 +01:00
|
|
|
"10-lan" = {
|
|
|
|
matchConfig = {
|
|
|
|
Driver = "mlx5_core";
|
|
|
|
PermanentMACAddress = "52:54:00:8a:8a:f2";
|
|
|
|
};
|
|
|
|
linkConfig = {
|
|
|
|
Name = "lan";
|
|
|
|
MTUBytes = toString lib.my.c.home.hiMTU;
|
|
|
|
};
|
|
|
|
};
|
2023-12-11 01:55:02 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
# So we don't drop the IP we use to connect to NVMe-oF!
|
|
|
|
networks."60-lan-hi".networkConfig.KeepConfiguration = "static";
|
|
|
|
};
|
|
|
|
|
|
|
|
my = {
|
|
|
|
secrets = {
|
|
|
|
key = "ssh-ed25519 AAAAC3NzaC1lZDI1NTE5AAAAIP9uFa4z9WPuXRFVA+PClQSitQCSPckhKTxo1Hq585Oa";
|
|
|
|
};
|
|
|
|
server.enable = true;
|
2023-12-12 01:34:37 +00:00
|
|
|
nvme = {
|
|
|
|
uuid = "12b52d80-ccb6-418d-9b2e-2be34bff3cd9";
|
|
|
|
boot = {
|
|
|
|
nqn = "nqn.2016-06.io.spdk:river";
|
|
|
|
address = "192.168.68.80";
|
|
|
|
};
|
|
|
|
};
|
|
|
|
|
2024-06-29 23:12:21 +01:00
|
|
|
netboot.server = {
|
|
|
|
enable = true;
|
|
|
|
ip = assignments.lo.ipv4.address;
|
|
|
|
host = "boot.${domain}";
|
|
|
|
allowedPrefixes = with prefixes; [ hi.v4 hi.v6 lo.v4 lo.v6 ];
|
|
|
|
instances = [ "sfh" ];
|
|
|
|
};
|
|
|
|
|
2023-12-11 01:55:02 +00:00
|
|
|
deploy.node.hostname = "192.168.68.1";
|
|
|
|
};
|
|
|
|
};
|
|
|
|
};
|
|
|
|
};
|
|
|
|
}
|