2023-12-10 02:29:53 +00:00
|
|
|
{
|
|
|
|
imports = [
|
|
|
|
./cellar
|
2023-12-11 01:55:02 +00:00
|
|
|
./river.nix
|
2023-12-10 02:29:53 +00:00
|
|
|
];
|
|
|
|
|
2023-12-12 01:34:37 +00:00
|
|
|
nixos.systems.palace.configuration = { lib, pkgs, config, systems, allAssignments, ... }:
|
2023-12-10 02:29:53 +00:00
|
|
|
let
|
|
|
|
inherit (lib) mkMerge;
|
|
|
|
inherit (lib.my) vm;
|
2023-12-11 01:55:02 +00:00
|
|
|
inherit (lib.my.c) networkd;
|
2023-12-10 02:29:53 +00:00
|
|
|
|
|
|
|
installerDisk = {
|
|
|
|
name = "installer";
|
|
|
|
backend = {
|
|
|
|
driver = "file";
|
|
|
|
filename = "/persist/home/dev/nixos-installer-devplayer0.iso";
|
|
|
|
read-only = "on";
|
|
|
|
};
|
|
|
|
format.driver = "raw";
|
|
|
|
frontend = "ide-cd";
|
|
|
|
frontendOpts = {
|
|
|
|
bootindex = 1;
|
|
|
|
};
|
|
|
|
};
|
|
|
|
in
|
|
|
|
{
|
2023-12-11 01:55:02 +00:00
|
|
|
systemd.network = {
|
|
|
|
netdevs = {
|
|
|
|
"25-vm-et1g0" = {
|
|
|
|
netdevConfig = {
|
|
|
|
Name = "vm-et1g0";
|
|
|
|
Kind = "macvtap";
|
|
|
|
};
|
|
|
|
# TODO: Upstream this missing section
|
|
|
|
extraConfig = ''
|
|
|
|
[MACVTAP]
|
|
|
|
Mode=passthru
|
|
|
|
'';
|
|
|
|
};
|
|
|
|
};
|
|
|
|
networks = {
|
|
|
|
"75-et1g0" = {
|
|
|
|
matchConfig.Name = "et1g0";
|
|
|
|
linkConfig.RequiredForOnline = "no";
|
|
|
|
networkConfig = {
|
|
|
|
MACVTAP = "vm-et1g0";
|
|
|
|
} // networkd.noL3;
|
|
|
|
};
|
|
|
|
"75-vm-et1g0" = {
|
|
|
|
matchConfig.Name = "vm-et1g0";
|
|
|
|
linkConfig.RequiredForOnline = "no";
|
|
|
|
networkConfig = networkd.noL3;
|
|
|
|
};
|
|
|
|
};
|
|
|
|
};
|
|
|
|
|
2023-12-22 01:34:28 +00:00
|
|
|
systemd.services =
|
|
|
|
let
|
|
|
|
awaitCellar = {
|
|
|
|
after = [ "vm@cellar.service" ];
|
|
|
|
bindsTo = [ "vm@cellar.service" ];
|
|
|
|
preStart = ''
|
|
|
|
until ${pkgs.netcat}/bin/nc -w1 -z ${allAssignments.cellar.hi.ipv4.address} 22; do
|
|
|
|
sleep 1
|
|
|
|
done
|
|
|
|
'';
|
|
|
|
};
|
|
|
|
in
|
|
|
|
{
|
2023-12-10 02:29:53 +00:00
|
|
|
"vm@cellar" = {
|
|
|
|
serviceConfig = {
|
|
|
|
CPUAffinity = "numa";
|
|
|
|
NUMAPolicy = "bind";
|
|
|
|
NUMAMask = "1";
|
|
|
|
};
|
|
|
|
};
|
2023-12-22 01:34:28 +00:00
|
|
|
|
2023-12-11 01:55:02 +00:00
|
|
|
"vm@river" =
|
|
|
|
let
|
|
|
|
vtapUnit = "sys-subsystem-net-devices-vm\\x2det1g0.device";
|
|
|
|
in
|
2023-12-22 01:34:28 +00:00
|
|
|
mkMerge [
|
|
|
|
awaitCellar
|
|
|
|
{
|
|
|
|
requires = [ vtapUnit ];
|
|
|
|
after = [ vtapUnit ];
|
|
|
|
}
|
|
|
|
];
|
|
|
|
"vm@sfh" = awaitCellar;
|
2023-12-10 02:29:53 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
my = {
|
|
|
|
vms = {
|
|
|
|
instances = {
|
|
|
|
cellar = {
|
|
|
|
uuid = "b126d135-9fc1-415a-b675-aaf727bf2f38";
|
|
|
|
cpu = "host,topoext";
|
|
|
|
smp = {
|
|
|
|
cpus = 8;
|
|
|
|
threads = 2;
|
|
|
|
};
|
2023-12-12 01:34:37 +00:00
|
|
|
memory = 16384;
|
|
|
|
cleanShutdown.timeout = 120;
|
2023-12-10 02:29:53 +00:00
|
|
|
drives = [
|
|
|
|
(mkMerge [ (vm.disk "cellar" "esp") { frontendOpts.bootindex = 0; } ])
|
|
|
|
(vm.disk "cellar" "nix")
|
|
|
|
(vm.disk "cellar" "persist")
|
|
|
|
];
|
|
|
|
hostDevices = {
|
|
|
|
et100g0vf0 = {
|
|
|
|
index = 0;
|
|
|
|
hostBDF = "44:00.1";
|
|
|
|
};
|
|
|
|
nvme0 = {
|
|
|
|
index = 1;
|
|
|
|
hostBDF = "41:00.0";
|
|
|
|
};
|
|
|
|
nvme1 = {
|
|
|
|
index = 2;
|
|
|
|
hostBDF = "42:00.0";
|
|
|
|
};
|
|
|
|
nvme2 = {
|
|
|
|
index = 3;
|
|
|
|
hostBDF = "43:00.0";
|
|
|
|
};
|
|
|
|
};
|
2023-12-13 11:23:47 +00:00
|
|
|
qemuFlags = [
|
|
|
|
"machine kernel-irqchip=split"
|
|
|
|
"device intel-iommu,caching-mode=on,device-iotlb=on,intremap=on"
|
|
|
|
];
|
2023-12-10 02:29:53 +00:00
|
|
|
};
|
2023-12-11 01:55:02 +00:00
|
|
|
|
|
|
|
river = {
|
|
|
|
uuid = "12b52d80-ccb6-418d-9b2e-2be34bff3cd9";
|
|
|
|
cpu = "host,topoext";
|
|
|
|
smp = {
|
|
|
|
cpus = 3;
|
|
|
|
threads = 2;
|
|
|
|
};
|
|
|
|
memory = 4096;
|
2023-12-22 01:34:28 +00:00
|
|
|
cleanShutdown.timeout = 60;
|
2023-12-11 01:55:02 +00:00
|
|
|
networks = {
|
|
|
|
et1g0 = {
|
|
|
|
ifname = "vm-et1g0";
|
|
|
|
bridge = null;
|
|
|
|
tapFD = 100;
|
|
|
|
# Real hardware MAC
|
|
|
|
mac = "e0:d5:5e:68:0c:6e";
|
|
|
|
waitOnline = false;
|
|
|
|
};
|
|
|
|
};
|
|
|
|
drives = [
|
|
|
|
installerDisk
|
|
|
|
(mkMerge [ (vm.disk "river" "esp") { frontendOpts.bootindex = 0; } ])
|
|
|
|
];
|
|
|
|
hostDevices = {
|
|
|
|
et100g0vf1 = {
|
|
|
|
index = 0;
|
|
|
|
hostBDF = "44:00.2";
|
|
|
|
};
|
|
|
|
};
|
|
|
|
};
|
2023-12-22 01:34:28 +00:00
|
|
|
|
|
|
|
sfh = {
|
|
|
|
uuid = "82ec149d-577c-421a-93e2-a9307c756cd8";
|
|
|
|
cpu = "host,topoext";
|
|
|
|
smp = {
|
|
|
|
cpus = 8;
|
|
|
|
threads = 2;
|
|
|
|
};
|
|
|
|
memory = 32768;
|
|
|
|
cleanShutdown.timeout = 120;
|
|
|
|
networks.netboot = {
|
|
|
|
bridge = "lan-lo";
|
|
|
|
waitOnline = "carrier";
|
|
|
|
mac = "52:54:00:a5:7e:93";
|
|
|
|
extraOptions.bootindex = 1;
|
|
|
|
};
|
|
|
|
hostDevices = {
|
|
|
|
et100g0vf2 = {
|
|
|
|
index = 0;
|
|
|
|
hostBDF = "44:00.3";
|
|
|
|
};
|
|
|
|
};
|
|
|
|
};
|
2023-12-10 02:29:53 +00:00
|
|
|
};
|
|
|
|
};
|
|
|
|
};
|
|
|
|
};
|
|
|
|
}
|