blob: f337f967a3a4989e9909ca0b74cfb0d169d48b00 (
plain)
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
97
98
99
100
101
102
103
|
#!/bin/bash
set -ex
image="$1"
buildmaster="$2"
slavename="$3"
password="$4"
usage ()
{
echo "$@"
cat <<EOF
Usage: $0 <buildmaster> <buildslave> <password>
E.g., $0 lab.llvm.org:9994 linaro-apm-05 PASSWORD
EOF
exit 1
}
if groups 2>/dev/null | grep -q docker; then
# Run docker straight up if $USER is in "docker" group.
DOCKER="docker"
else
# Fallback to sudo otherwise.
DOCKER="sudo docker"
fi
case "$slavename" in
linaro-armv8-01-aarch64-full) ;;
linaro-armv8-01-aarch64-global-isel) ;;
linaro-armv8-01-aarch64-libcxx) ;;
linaro-armv8-01-aarch64-libcxx-noeh) ;;
linaro-armv8-01-aarch64-lld) ;;
linaro-armv8-01-aarch64-quick) ;;
linaro-armv8-01-arm-full) ;;
linaro-armv8-01-arm-full-selfhost) ;;
linaro-armv8-01-arm-global-isel) ;;
linaro-armv8-01-arm-libcxx) ;;
linaro-armv8-01-arm-libcxx-noeh) ;;
linaro-armv8-01-arm-lld) ;;
linaro-armv8-01-arm-lnt) ;;
linaro-armv8-01-arm-quick) ;;
linaro-armv8-01-arm-selfhost-neon) ;;
linaro-tk1-*) ;;
*)
echo "WARNING: Unknown slavename $slavename"
esac
case "$slavename:$image" in
*-aarch64-*:*-arm64-*) ;;
*-arm-*:*-armhf-*) ;;
linaro-tk1-*:*-armhf-*) ;;
*)
echo "ERROR: $slavename should not run on $image."
echo "Make sure you're running an AArch64 bot on an arm64 image or an ARM bot on an armhf image."
exit 1
esac
case "$buildmaster" in
"normal")
mastername="normal"
masterurl="lab.llvm.org:9990"
;;
"silent")
mastername="silent"
masterurl="lab.llvm.org:9994"
;;
*)
mastername="custom"
masterurl="$buildmaster"
esac
# Set relative CPU weight of containers running silent bots to 1/20th of
# normal containers. We want to run a full set of silent bots for
# troubleshooting purposes, but don't want to waste a lot of CPU cycles.
case "$mastername" in
"silent") cpu_shares=50 ;;
*) cpu_shares=1000 ;;
esac
memlimit=$(free -m | awk '/^Mem/ { print $2 }')
case "$slavename" in
linaro-tk1-*)
# Use at most 90% of RAM on TK1s
memlimit=$(($memlimit * 9 / 10))m
;;
*)
# Use at most half of all available RAM.
memlimit=$(($memlimit / 2))m
;;
esac
case "$slavename" in
*-lld) pids_limit="15000" ;;
*) pids_limit="5000" ;;
esac
# IPC_LOCK is required for some implementations of ssh-agent (e.g., MATE's).
# SYS_PTRACE is required for debugger work.
# seccomp:unconfined is required to disable ASLR for sanitizer tests.
caps="--cap-add=IPC_LOCK --cap-add=SYS_PTRACE --security-opt seccomp:unconfined"
$DOCKER run --name=$mastername-$slavename --hostname=$mastername-$slavename --restart=unless-stopped -dt -p 22 --cpu-shares=$cpu_shares --memory=$memlimit --pids-limit=$pids_limit $caps "$image" "$masterurl" "$slavename" "$password"
|