only elf/multiboot images

This commit is contained in:
Ben Gras 2012-05-01 13:55:49 +02:00
parent c0ef4c4956
commit cd47780252
3 changed files with 14 additions and 48 deletions

View file

@ -88,16 +88,12 @@ hdboot: image
[ "$$n" -ge 10 ] && prefix="mod" || prefix="mod0"; \ [ "$$n" -ge 10 ] && prefix="mod" || prefix="mod0"; \
newname="/boot/minix/.temp/$${prefix}$${n}_`basename $$i`"; \ newname="/boot/minix/.temp/$${prefix}$${n}_`basename $$i`"; \
cp $$i $$newname; \ cp $$i $$newname; \
if [ -d /boot/image ]; \ strip -s $$newname; \
then ln -f $$newname /boot/`basename $$i`; \
else strip -s $$newname; \
gzip $$newname; \ gzip $$newname; \
fi \
done done
cp ../kernel/kernel /boot/minix/.temp/ cp ../kernel/kernel /boot/minix/.temp/
strip -s /boot/minix/.temp/kernel strip -s /boot/minix/.temp/kernel
[ -d /boot/image ] && ln -f /boot/minix/.temp/kernel /boot/kernel || true sh mkboot $@
sh mkboot $@ minix
sh ../commands/update_bootcfg/update_bootcfg.sh sh ../commands/update_bootcfg/update_bootcfg.sh
fdboot: image fdboot: image

View file

@ -4,7 +4,7 @@
# Author: Kees J. Bot # Author: Kees J. Bot
usage() { usage() {
echo "Usage: $0 [bootable | hdboot [minix or image] | fdboot [device]]" >&2 echo "Usage: $0 [bootable | hdboot | fdboot [device]]" >&2
exit 1 exit 1
} }
@ -17,7 +17,7 @@ rotate_oldest() {
# Not much there, do not remove a thing. # Not much there, do not remove a thing.
;; ;;
*) *)
# Remove the third-newest $hdboot_t in /boot/$hdboot_t, but # Remove the third-newest image in /boot/$hdboot_t, but
# only if there's an older one (which is kept). # only if there's an older one (which is kept).
echo "rm $root:$base_dir/$3" echo "rm $root:$base_dir/$3"
rm -rf "$base_dir/$3" rm -rf "$base_dir/$3"
@ -31,20 +31,12 @@ mdec=/usr/mdec # bootstraps
# Check arguments. # Check arguments.
case "$#:$1" in case "$#:$1" in
1:bootable | 2:hdboot | [12]:fdboot ) 1:bootable | 1:hdboot | [12]:fdboot )
action=$1 dev=$2 size=$3 action=$1 dev=$2 size=$3
;; ;;
*) usage *) usage
esac esac
if [ "$1" = "hdboot" ]
then
if [ "$2" != "image" -a "$2" != "minix" ]
then usage
fi
hdboot_t="$2"
fi
# Get the device table. # Get the device table.
FSTAB=/etc/fstab FSTAB=/etc/fstab
touch $FSTAB touch $FSTAB
@ -77,17 +69,6 @@ esac
case $action in case $action in
hdboot) hdboot)
# Install a new image on the root device.
if [ -e $rootdir/boot/$hdboot_t -a ! -d $rootdir/boot/$hdboot_t ]
then
# /boot/$hdboot_t is not yet a directory! Fix it.
su root -c \
"exec mv $rootdir/boot/$hdboot_t /M"
install -d $rootdir/boot/$hdboot_t
su root -c \
"exec mv $rootdir/M $rootdir/boot/$hdboot_t/`uname -r`"
fi
sh tell_config OS_RELEASE . OS_VERSION >/tmp/mkb.$$ sh tell_config OS_RELEASE . OS_VERSION >/tmp/mkb.$$
version=`sed 's/[" ]//g;/^$/d' </tmp/mkb.$$` version=`sed 's/[" ]//g;/^$/d' </tmp/mkb.$$`
@ -119,25 +100,15 @@ hdboot)
target="${version}${rrevision}${gitrev}" target="${version}${rrevision}${gitrev}"
rotate_oldest "$rootdir/boot/$hdboot_t" rotate_oldest "$rootdir/boot/minix"
# rotate system processes. We assume latest ones are in # rotate system processes. We assume latest ones are in
# /boot/modules/.temp and we maintain /boot/modules/ by ourselves. # /boot/modules/.temp and we maintain /boot/modules/ by ourselves.
if [ "$hdboot_t" = "minix" ]
then
[ -d /boot/minix/.temp ] || exit 1 [ -d /boot/minix/.temp ] || exit 1
rm -rf /boot/minix/"$target"/ rm -rf /boot/minix/"$target"/
mv /boot/minix/.temp /boot/minix/"$target" mv /boot/minix/.temp /boot/minix/"$target"
rm -f /boot/minix_latest rm -f /boot/minix_latest
ln -s minix/"$target" /boot/minix_latest ln -s minix/"$target" /boot/minix_latest
else
# Install the new image.
echo "install $hdboot_t $root:/boot/$hdboot_t/$target"
install -o root -m 600 $hdboot_t $rootdir/boot/$hdboot_t/$target || exit 1
# Tell bootloader which image is newest
ln -f $rootdir/boot/$hdboot_t/$target $rootdir/boot/${hdboot_t}_latest
fi
# Save the revision number. # Save the revision number.
test "$revision" != "$oldrev" && echo $revision >revision test "$revision" != "$oldrev" && echo $revision >revision

View file

@ -301,10 +301,9 @@ then
fi fi
echo " * Removing files to create minimal image" echo " * Removing files to create minimal image"
rm -rf $RELEASEDIR/boot/image/* $RELEASEDIR/usr/man/man*/* \ rm -rf $RELEASEDIR/usr/man/man*/* \
$RELEASEDIR/usr/share/zoneinfo* $RELEASEDIR/usr/src $RELEASEDIR/usr/share/zoneinfo* $RELEASEDIR/usr/src
mkdir -p $RELEASEDIR/usr/src/tools mkdir -p $RELEASEDIR/usr/src/tools
ln $RELEASEDIR/boot/image_big $RELEASEDIR/boot/image/$version
fi fi
if [ $EXTRAS_INSTALL -ne 0 ] ; then if [ $EXTRAS_INSTALL -ne 0 ] ; then