-
Notifications
You must be signed in to change notification settings - Fork 40
/
linux-build-slave.nix
48 lines (45 loc) · 1.71 KB
/
linux-build-slave.nix
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
{ sshKeyFile ? null, memory ? 512, rootsize ? "10g" }:
# usage: nix-build linux-build-slave.nix -I nixpkgs=https://github.com/nixos/nixpkgs/archive/c29d2fde74d.tar.gz --arg sshKeyFile ~/.ssh/id_rsa.pub
let
pkgs = import <nixpkgs> {};
eval = import ./. {
inherit configuration;
system = "x86_64-linux";
};
configuration = { pkgs, ... }: {
imports = [ ./qemu.nix ];
not-os = {
nix = true;
simpleStaticIp = true;
preMount = ''
${pkgs.e2fsprogs}/bin/mkfs.ext4 $realroot || true
'';
};
boot.kernelParams = [ "realroot=/dev/vdb" ];
boot.initrd.kernelModules = [ "ext4" "crc32c_generic" ];
environment.systemPackages = with pkgs; [ ];
environment.etc = {
"ssh/authorized_keys.d/root" = {
text = "${if (sshKeyFile != null) then builtins.readFile sshKeyFile else ""}";
mode = "0444";
};
};
};
runvm = pkgs.writeScript "runner" ''
#!${pkgs.stdenv.shell}
set -e
export PATH=${pkgs.coreutils}/bin/:$PATH
rm -f rootdisk.img
truncate -s ${rootsize} rootdisk.img
exec ${pkgs.qemu_kvm}/bin/qemu-kvm -name buildSlave -m ${toString memory} \
-drive index=0,id=drive0,file=${eval.config.system.build.squashfs},readonly=on,media=cdrom,format=raw,if=virtio \
-drive index=1,id=drive1,file=rootdisk.img,format=raw,if=virtio \
-kernel ${eval.config.system.build.kernel}/bzImage -initrd ${eval.config.system.build.initialRamdisk}/initrd -nographic \
-append "console=ttyS0 ${toString eval.config.boot.kernelParams} quiet panic=-1" -no-reboot \
-net nic,model=virtio \
-net user,net=10.0.2.0/24,host=10.0.2.2,dns=10.0.2.3,hostfwd=tcp::2222-:22 \
-device virtio-rng-pci
'';
in {
inherit runvm;
}