Synced with trunk @ 15505

svn path=/nixos/branches/modular-nixos/; revision=15640
This commit is contained in:
Marc Weber 2009-05-18 12:01:31 +00:00
parent 1d0c0a4291
commit 81d6032c43
2 changed files with 69 additions and 38 deletions

@ -15,6 +15,9 @@ bootMount="@bootMount@"
if test -z "$bootMount"; then bootMount=/boot; fi
echo "updating the Grub menu..."
target=/boot/grub/menu.lst
tmp=$target.tmp
@ -27,14 +30,13 @@ GRUBEND
if test -n "@grubSplashImage@"; then
splashLocation=@grubSplashImage@
# !!! image in /nix/store doesn't seem to work
#if test -n "@copyKernels@"; then
cp -f $splashLocation /boot/background.xpm.gz
splashLocation="$bootMount/background.xpm.gz"
#fi
# Splash images in /nix/store don't seem to work, so copy them.
cp -f $splashLocation /boot/background.xpm.gz
splashLocation="$bootMount/background.xpm.gz"
echo "splashimage $splashLocation" >> $tmp
fi
configurationCounter=0
configurationLimit="@configurationLimit@"
numAlienEntries=`cat <<EOF | egrep '^[[:space:]]*title' | wc -l
@ -42,18 +44,48 @@ numAlienEntries=`cat <<EOF | egrep '^[[:space:]]*title' | wc -l
EOF`
if test $((configurationLimit+numAlienEntries)) -gt 190; then
configurationLimit=$((190-numAlienEntries));
configurationLimit=$((190-numAlienEntries));
fi
# Convert a path to a file in the Nix store such as
# /nix/store/<hash>-<name>/file to <hash>-<name>-<file>.
cleanName() {
local path="$1"
echo "$path" | sed 's|^/nix/store/||' | sed 's|/|-|g'
}
# Copy a file from the Nix store to /boot/kernels.
declare -A filesCopied
copyToKernelsDir() {
local src="$1"
local dst="/boot/kernels/$(cleanName $src)"
# Don't copy the file if $dst already exists. This means that we
# have to create $dst atomically to prevent partially copied
# kernels or initrd if this script is ever interrupted.
if ! test -e $dst; then
local dstTmp=$dst.tmp.$$
cp $src $dstTmp
mv $dstTmp $dst
fi
filesCopied[$dst]=1
result=$dst
}
# Add an entry for a configuration to the Grub menu, and if
# appropriate, copy its kernel and initrd to /boot/kernels.
addEntry() {
local name="$1"
local path="$2"
local shortSuffix="$3"
configurationCounter=$((configurationCounter + 1))
if test $configurationCounter -gt @configurationLimit@ ; then
return
fi;
if test $configurationCounter -gt @configurationLimit@; then
return
fi
if ! test -e $path/kernel -a -e $path/initrd; then
return
@ -63,10 +95,10 @@ addEntry() {
local initrd=$(readlink -f $path/initrd)
if test "$path" = "$default"; then
cp "$kernel" /boot/nixos-kernel
cp "$initrd" /boot/nixos-initrd
cp "$(readlink -f "$path/init")" /boot/nixos-init
cat > /boot/nixos-grub-config <<EOF
cp "$kernel" /boot/nixos-kernel
cp "$initrd" /boot/nixos-initrd
cp "$(readlink -f "$path/init")" /boot/nixos-init
cat > /boot/nixos-grub-config <<EOF
title Emergency boot
kernel ${bootMount:-/boot}/nixos-kernel systemConfig=$(readlink -f "$path") init=/boot/nixos-init $(cat "$path/kernel-params")
initrd ${bootMount:-/boot}/nixos-initrd
@ -74,30 +106,21 @@ EOF
fi
if test -n "@copyKernels@"; then
local kernel2=/boot/kernels/$(echo $kernel | sed 's^/^-^g')
if ! test -e $kernel2; then
cp $kernel $kernel2
fi
kernel=$kernel2
local initrd2=/boot/kernels/$(echo $initrd | sed 's^/^-^g')
if ! test -e $initrd2; then
cp $initrd $initrd2
fi
initrd=$initrd2
if test -n "$bootMount"; then
kernel=$(echo $kernel2 | sed -e "s^/boot^$bootMount^")
initrd=$(echo $initrd2 | sed -e "s^/boot^$bootMount^")
fi
copyToKernelsDir $kernel; kernel=$result
copyToKernelsDir $initrd; initrd=$result
fi
if test -n "$bootMount"; then
kernel=$(echo $kernel | sed -e "s^/boot^$bootMount^")
initrd=$(echo $initrd | sed -e "s^/boot^$bootMount^")
fi
local confName=$(if test -e $path/configuration-name; then
cat $path/configuration-name;
fi);
if test -n "$confName" ; then
name="$confName $3";
fi;
fi)
if test -n "$confName"; then
name="$confName $3"
fi
cat >> $tmp << GRUBEND
@ -108,11 +131,11 @@ GRUBEND
}
rm -rf /boot/kernels
if test -n "@copyKernels@"; then
mkdir -p /boot/kernels
fi
# Additional entries specified verbatim by the configuration.
extraGrubEntries=`cat <<EOF
@extraGrubEntries@
@ -135,11 +158,11 @@ for link in $((ls -d $default/fine-tune/* ) | sort -n); do
date=$(stat --printf="%y\n" $link | sed 's/\..*//')
addEntry "NixOS - variation" $link ""
done
for generation in $(
(cd /nix/var/nix/profiles && ls -d system-*-link) \
| sed 's/system-\([0-9]\+\)-link/\1/' \
| sort -n -r); do
echo $generation
link=/nix/var/nix/profiles/system-$generation-link
date=$(stat --printf="%y\n" $link | sed 's/\..*//')
kernelVersion=$(cd $(dirname $(readlink -f $link/kernel))/lib/modules && echo *)
@ -150,3 +173,11 @@ done
# Atomically update /boot/grub/menu.lst. !!! should do an fsync()
# here on $tmp, especially on ext4.
mv $tmp $target
# Remove obsolete files from /boot/kernels.
for fn in $(ls /boot/kernels/*); do
if ! test "${filesCopied[$fn]}" = 1; then
rm -vf -- "$fn"
fi
done

@ -50,8 +50,8 @@ EOF
oldEvents=$(readlink -f /etc/event.d || true)
newEvents=$(readlink -f @out@/etc/event.d)
echo "old: $oldEvents"
echo "new: $newEvents"
#echo "old: $oldEvents"
#echo "new: $newEvents"
stopJob() {
local job=$1
@ -73,7 +73,7 @@ EOF
# Activate the new configuration (i.e., update /etc, make
# accounts, and so on).
echo "Activating the configuration..."
echo "activating the configuration..."
@out@/activate @out@
# Make Upstart reload its events. !!! Should wait until it has