X-Git-Url: http://git.onelab.eu/?a=blobdiff_plain;f=build.sh;h=a51797c7b881140c364b41b941c3a09971445590;hb=refs%2Fheads%2Fplanetlab-3_2-branch;hp=7f2a1bfdbf134d38c56d9dd2bf1874333d78bc17;hpb=12f6c7676589f08298cf183e5555fce75ea2ea32;p=bootcd.git diff --git a/build.sh b/build.sh index 7f2a1bf..a51797c 100755 --- a/build.sh +++ b/build.sh @@ -8,7 +8,7 @@ CONFIGURATIONS_DIR=configurations/ # where built files are stored BUILD_DIR=build/ -BOOTCD_VERSION="3.0-beta0.5" +BOOTCD_VERSION="3.2" FULL_VERSION_STRING="PlanetLab BootCD" OUTPUT_IMAGE_NAME='PlanetLab-BootCD' @@ -29,7 +29,9 @@ INITRD_BYTES_PER_INODE=1024 # make sure the boot manager source is checked out in the same directory # as the bootcd_v3 repository -BOOTMANAGER_DIR=../bootmanager/ +for BOOTMANAGER_DIR in ../bootmanager-* ../bootmanager ; do + [ -d $BOOTMANAGER_DIR ] && break +done if [ ! -d $BOOTMANAGER_DIR ]; then echo "the bootmanager repository needs to be checked out at the same" @@ -68,20 +70,64 @@ function build_cdroot() echo "setup rpm to install only en_US locale and no docs" mkdir -p $CD_ROOT/etc/rpm cp -f $CONF_FILES_DIR/macros $CD_ROOT/etc/rpm + # trick rpm and yum + export HOME=$PWD + cp -f $CONF_FILES_DIR/macros $PWD/.rpmmacros echo "initialize rpm db" mkdir -p $CD_ROOT/var/lib/rpm rpm --root $CD_ROOT --initdb + + # XXX Should download yum.conf from the boot server? + echo "generate yum.conf" +cat >yum.conf <>yum.conf <##g'` + packages=$(curl $yumgroups | sed -n -e '/BootCD<\/name>/,//{ s/.*\(.*\)<\/packagereq>/\1/p }') set +e for package in $packages; do echo "checking for package $package" - chroot $CD_ROOT /bin/rpm -qi $package > /dev/null + /usr/sbin/chroot $CD_ROOT /bin/rpm -qi $package > /dev/null if [[ "$?" -ne 0 ]]; then echo "package $package was not installed in the cd root." echo "make sure it exists in the yum repository." @@ -96,7 +142,7 @@ function build_cdroot() echo "setting up non-ssh authentication" mkdir -p $CD_ROOT/etc/samba - chroot $CD_ROOT /usr/sbin/authconfig --nostart --kickstart \ + /usr/sbin/chroot $CD_ROOT /usr/sbin/authconfig --nostart --kickstart \ --enablemd5 --enableshadow echo "setting root password" @@ -109,6 +155,12 @@ function build_cdroot() mv $CD_ROOT/var/lib/rpm $CD_ROOT/usr/relocated/var/lib/ (cd $CD_ROOT/var/lib && ln -s ../../usr/relocated/var/lib/rpm rpm) + # get /var/cache/yum out, its 100Mb. create in its place a + # symbolic link to /usr/relocated/var/cache/yum + mkdir -p $CD_ROOT/usr/relocated/var/cache/ + mv $CD_ROOT/var/cache/yum $CD_ROOT/usr/relocated/var/cache/ + (cd $CD_ROOT/var/cache && ln -s ../../usr/relocated/var/cache/yum yum) + # get /lib/tls out mkdir -p $CD_ROOT/usr/relocated/lib mv $CD_ROOT/lib/tls $CD_ROOT/usr/relocated/lib/ @@ -228,7 +280,7 @@ function build_initrd() $module_dep_file $pci_map_file $pci_table $CD_ROOT/etc/pl_pcitable dd if=/dev/zero of=$INITRD bs=1M count=$RAMDISK_SIZE - mkfs.ext2 -F -m 0 -i $INITRD_BYTES_PER_INODE $INITRD + /sbin/mkfs.ext2 -F -m 0 -i $INITRD_BYTES_PER_INODE $INITRD mkdir -p $INITRD_MOUNT mount -o loop,rw $INITRD $INITRD_MOUNT @@ -253,10 +305,31 @@ function build() # always build/rebuild initrd build_initrd + # build iso image rm -f $ISO mkisofs -o $ISO -R -allow-leading-dots -J -r -b isolinux/isolinux.bin \ -c isolinux/boot.cat -no-emul-boot -boot-load-size 4 -boot-info-table \ $CD_ROOT/usr + + # build usb image and make it bootable with syslinux (instead of isolinux) + USB_IMAGE=${ISO%*.iso}.usb + # leave 1 MB of free space on the filesystem + USB_KB=$(du -kc $ISO $CD_ROOT/usr/isolinux | awk '$2 == "total" { print $1 + 1024 }') + /sbin/mkfs.vfat -C $USB_IMAGE $USB_KB + + mkdir -p $INITRD_MOUNT + mount -o loop,rw $USB_IMAGE $INITRD_MOUNT + + # populate the root of the image with the iso, pl_version, and the syslinux files + cp -a $ISO $INITRD_MOUNT + cp -a $CD_ROOT/usr/isolinux/{initrd.gz,kernel,message.txt,pl_version} $INITRD_MOUNT + cp -a $CD_ROOT/usr/isolinux/isolinux.cfg $INITRD_MOUNT/syslinux.cfg + + umount $INITRD_MOUNT + rmdir $INITRD_MOUNT + + # make it bootable + syslinux $USB_IMAGE } function burn()