diff options
author | An-Cheng Huang <ancheng@vyatta.com> | 2009-10-30 18:42:30 -0700 |
---|---|---|
committer | An-Cheng Huang <ancheng@vyatta.com> | 2009-10-30 18:42:30 -0700 |
commit | 1f5174a65f21d1280827d7fb911232f4bfc56eb7 (patch) | |
tree | 389ce51f25870f0fb9b273951853ce79abd649d7 /scripts/install/install-image-new | |
parent | c758197af1f11727cb01188b14d0a4801448cfcd (diff) | |
download | vyatta-cfg-quagga-1f5174a65f21d1280827d7fb911232f4bfc56eb7.tar.gz vyatta-cfg-quagga-1f5174a65f21d1280827d7fb911232f4bfc56eb7.zip |
add unified install-image
Diffstat (limited to 'scripts/install/install-image-new')
-rwxr-xr-x | scripts/install/install-image-new | 76 |
1 files changed, 76 insertions, 0 deletions
diff --git a/scripts/install/install-image-new b/scripts/install/install-image-new new file mode 100755 index 00000000..7294fc35 --- /dev/null +++ b/scripts/install/install-image-new @@ -0,0 +1,76 @@ +#!/bin/bash + +if [ `whoami` != 'root' ] ; then + echo "This script must be run with root privileges." + exit 1 +fi + +# source in the functions +source /opt/vyatta/sbin/install-functions + +# the INSTALL_LOG env var should be exported by the "caller". +# it will be used to log messages. + +# the install partition e.g. sda1 +ROOT_PARTITION=$1 + +becho "Mounting /dev/$ROOT_PARTITION..." + +# mount the partition +mkdir -p $WRITE_ROOT +if ! try_mount "/dev/$ROOT_PARTITION $WRITE_ROOT"; then + echo 'Exiting...' + exit 1 +fi + +version=$(get_new_version) +if [ -z "$version" ]; then + echo 'Cannot find new version. Exiting...' + exit 1 +fi + +# make the dir for the new version +mkdir -p $WRITE_ROOT/boot/$version +# make dir for backing store +rw_dir=$WRITE_ROOT/boot/$version/live-rw +mkdir -p $rw_dir + +echo Copying squashfs image... +# these are the defaults if installing from a specified ISO image file. +# in such cases, the ISO image has already been mounted by caller. +squash_img=${CD_ROOT}/live/filesystem.squashfs +boot_dir=${CD_SQUASH_ROOT}/boot +boot_files=$(find $boot_dir -maxdepth 1 -type f -o -type l 2>/dev/null) +if [ ! -f "$squash_img" ] || [ -z "$boot_files" ]; then + # maybe installing from a live CD boot? + squash_img=/live/image/live/filesystem.squashfs + boot_dir=/boot + boot_files=$(find $boot_dir -maxdepth 1 -type f -o -type l 2>/dev/null) + if [ ! -f "$squash_img" ] || [ -z "$boot_files" ]; then + # not a live CD boot either. give up. + becho 'Cannot find the squashfs image. Exiting...' + exit 1 + fi +fi + +target_squash=$WRITE_ROOT/boot/$version/$version.squashfs +cp -p $squash_img $target_squash +echo Copying kernel and initrd images... +cp -dp $boot_files $WRITE_ROOT/boot/$version/ + +# set up union root for postinst +mkdir -p $INST_ROOT $READ_ROOT +if ! try_mount "-o loop,ro -t squashfs $target_squash $READ_ROOT"; then + echo 'Exiting...' + exit 1 +fi +margs="-t unionfs -o noatime,dirs=$rw_dir=rw:$READ_ROOT=ro unionfs $INST_ROOT" +if ! try_mount "$margs"; then + echo 'Exiting...' + exit 1 +fi + +becho "Done!" + +exit 0 + |