-
Notifications
You must be signed in to change notification settings - Fork 373
/
shell.nix
96 lines (85 loc) · 3.06 KB
/
shell.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
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
{
# Will create a temp one if none is passed, for example:
# nix-shell --argstr buildpath .
buildpath ? "",
# The unikernel to build
unikernel ? "./example",
# vmrunner path, for vmrunner development
vmrunner ? "",
# Enable ccache support. See overlay.nix for details.
withCcache ? false,
# Enable multicore suport.
smp ? false,
includeos ? import ./default.nix { inherit withCcache; inherit smp; }
}:
includeos.pkgs.mkShell.override { inherit (includeos) stdenv; } rec {
vmrunnerPkg =
if vmrunner == "" then
includeos.vmrunner
else
includeos.pkgs.callPackage (builtins.toPath /. + vmrunner) {};
packages = [
(includeos.pkgs.python3.withPackages (p: [
vmrunnerPkg
]))
includeos.pkgs.buildPackages.cmake
includeos.pkgs.buildPackages.nasm
includeos.pkgs.qemu
includeos.pkgs.which
includeos.pkgs.grub2
includeos.pkgs.iputils
includeos.pkgs.xorriso
];
buildInputs = [
includeos
includeos.chainloader
includeos.lest
includeos.pkgs.openssl
includeos.pkgs.rapidjson
];
shellHook = ''
unikernel=$(realpath ${unikernel})
echo -e "Attempting to build unikernel: \n$unikernel"
if [ ! -d "$unikernel" ]; then
echo "$unikernel is not a valid directory"
exit 1
fi
export BUILDPATH=${buildpath}
if [ -z "${buildpath}" ]; then
export BUILDPATH="$(mktemp -d)"
pushd "$BUILDPATH"
else
mkdir -p "$BUILDPATH"
pushd "$BUILDPATH"
fi
cmake "$unikernel" -DARCH=x86_64 -DINCLUDEOS_PACKAGE=${includeos} -DCMAKE_MODULE_PATH=${includeos}/cmake \
-DFOR_PRODUCTION=OFF
make -j $NIX_BUILD_CORES
echo -e "\n====================== IncludeOS nix-shell ====================="
if [ -z "${buildpath}" ]; then
echo -e "\nWorking directory, generated by this script:"
echo $BUILDPATH
echo -e "\nTo use another directory pass in 'buildpath' to nix:"
echo "nix-shell --argstr buildpath you/build/path"
fi
echo -e "\nThe C++ compiler set to:"
echo $(which $CXX)
echo -e "\nIncludeOS package:"
echo ${includeos}
echo -e "\n---------------------- Network privileges ---------------------"
echo "The vmrunner for IncludeOS tests requires bridged networking for full functionality."
echo "The following commands requiring sudo privileges can be used to set this up:"
echo "1. the qemu-bridge-helper needs sudo to create a bridge. Can be enabled with:"
echo " sudo chmod u+s ${includeos.pkgs.qemu}/libexec/qemu-bridge-helper"
echo "2. bridge43 must exist. Can be set up with vmrunner's create_bridge.sh script:"
echo " ${vmrunnerPkg.create_bridge}"
echo "3. /etc/qemu/bridge.conf must contain this line:"
echo " allow bridge43"
echo ""
echo "Some tests require ping, which requires premissions to send raw packets. On some hosts"
echo "this is not enabled by default for iputils provided by nix. It can be enabled with:"
echo "4. sudo setcap cap_net_raw+ep ${includeos.pkgs.iputils}/bin/ping"
echo " "
echo
'';
}