Menu

[099886]: / master / expert / dangerous_build_rest.sh  Maximize  Restore  History

Download this file

204 lines (153 with data), 5.2 kB

  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
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
#!/bin/sh
#
# KaarPux: http://kaarpux.kaarposoft.dk
#
# Copyright (C) 2013-2014: Henrik Kaare Poulsen
#
# License: http://kaarpux.kaarposoft.dk/license.html
#
set -o nounset
set -o errexit
if test "${1:-unset}" = "RECURSIVE_SH"; then
shift
else
test $(id -u) -eq 0 || { echo "*** *** This script must be run as root" >&2; exit 1; }
if test -t 0 -a x"${1:-}" != x"--yes"; then
cat <<EOF
------------------------------------------------------------
This script will build the linux and opt phases of KaarPux system.
It *WILL* mess with your system directories.
The script is intended to be run inside a virtual machine.
You are advised to read through the script before executing.
Also modify settings in the top of the script as appropriate.
------------------------------------------------------------
EOF
systemd-detect-virt --quiet --vm || { echo "*** You are NOT running in a virtual machine"; }
read -r -p "Are you REALLY sure you want to continue? " DOIT
case $DOIT in
[yY][eE][sS]|[yY])
;;
*)
echo "Aborting...."
exit
;;
esac
echo ""
fi
test x"${1:-}" = x"--yes" && shift
"time" --verbose "$0" "RECURSIVE_SH" "$@"
exit
fi
# ============================================================
# Device containing downloads
DDEV=/dev/vdb
# Where are we?
HERE=$(pwd)
# ============================================================
build_linux () {
local PHASE=$1
echo ------------------------------------------------------------
echo "Build linux ${PHASE}"
mount -t tmpfs -o size=32G tmpfs /home/kaarpux/kaarpux/linux/build/linux
chown kaarpux:kaarpux /home/kaarpux/kaarpux/linux/build/linux
cd /home/kaarpux/kaarpux/
linux/scripts/complete_linux_${PHASE}.sh
df -h >> /home/kaarpux/kaarpux/build.log
uptime >> /home/kaarpux/kaarpux/build.log
umount /home/kaarpux/kaarpux/linux/build/linux
echo "done"
}
# ============================================================
build_opt () {
local PHASE=$1
echo ------------------------------------------------------------
echo "Build opt ${PHASE}"
mount -t tmpfs -o size=48G tmpfs /home/kaarpux/kaarpux/linux/build/opt
chown kaarpux:kaarpux /home/kaarpux/kaarpux/linux/build/opt
cd /home/kaarpux/kaarpux/
su -l kaarpux <<EOF
set -o nounset
set -o errexit
cd /home/kaarpux/kaarpux/
linux/scripts/complete_opt_${PHASE}.sh
EOF
df -h >> /home/kaarpux/kaarpux/build.log
uptime >> /home/kaarpux/kaarpux/build.log
umount /home/kaarpux/kaarpux/linux/build/opt
echo "done"
}
# ============================================================
echo ------------------------------------------------------------
echo "Improved scheduling; errors are not fatal"
MULT=10
sysctl -w kernel.sched_min_granularity_ns=$(( MULT * 3000000)) || true
sysctl -w kernel.sched_latency_ns=$(( MULT * 24000000)) || true
sysctl -w kernel.sched_wakeup_granularity_ns=$(( MULT * 4000000)) || true
sysctl -w kernel.sched_migration_cost_ns=$(( MULT * 500000)) || true
sysctl -w kernel.sched_shares_window_ns=$(( MULT * 10000000)) || true
sysctl -w kernel.sched_child_runs_first=1 || true
sysctl -w kernel.sched_autogroup_enabled=0 || true
# batch scheduling
chrt -a -b -p 0 $$ || true
for F in $(ls /sys/block/sd*/queue/scheduler /sys/block/vd*/queue/scheduler 2>/dev/null); do
echo $F
echo deadline > $F || true
done
# ============================================================
echo ------------------------------------------------------------
echo "Changing ownership of log files"
touch /home/kaarpux/kaarpux/build.log && chown kaarpux:kaarpux /home/kaarpux/kaarpux/build.log
# ============================================================
echo ------------------------------------------------------------
echo "Downloading All Packages"
fsck -a ${DDEV}
mount ${DDEV} /home/kaarpux/kaarpux/downloads
su kaarpux <<EOF
/home/kaarpux/kaarpux/linux/download_packages_2.sh
EOF
echo "done"
# ============================================================
build_linux base
build_linux xorg
# ============================================================
# Dummy X11 server for testing packages
export DISPLAY=:42
T=$(mktemp -d)
chown kaarpux:kaarpux $T
su kaarpux <<EOF
mkfifo $T/fifo
cat > ~/.xinitrc <<EOF2
dbus-launch --sh-syntax --exit-with-session > $T/fifo
exec xterm
EOF2
(xinit -- /bin/Xvfb :42 2>&1 | logger --tag Xvfb42 )&
echo \$! > $T/pid
EOF
# dbus-launch writes export commands to stdout, ie. the fifo
. $T/fifo
# ============================================================
build_linux gnome_pre
build_linux gnome
build_linux gnome_post
# ============================================================
build_opt desktop
build_opt libreoffice
build_opt programming
build_opt coins
build_opt closed_source
# ============================================================
# http://stackoverflow.com/a/3211182
killtree() {
local _pid=$1
local _sig=${2:--TERM}
kill -stop ${_pid} # needed to stop quickly forking parent from producing children between child killing and parent killing
for _child in $(ps -o pid --no-headers --ppid ${_pid}); do
killtree ${_child} ${_sig}
done
kill -${_sig} ${_pid}
}
killtree $(cat $T/pid) KILL
rm -r $T
echo ------------------------------------------------------------
echo "We are done"
echo ""