#!/bin/bash # Do install stuff for armhf # Sets up a grub-efi installer # # $1 is the CD number # $2 is the temporary CD build dir . $BASEDIR/tools/boot/$DI_CODENAME/common.sh set -e N=$1 CDDIR=$2 INSTALLDIR="install.ahf" # Workaround for #823881: export MTOOLS_SKIP_CHECK=1 # Common options for all disks add_mkisofs_opt $CDDIR/../$N.mkisofs_opts "-J -joliet-long" add_mkisofs_opt $CDDIR/../$N.mkisofs_opts "-cache-inodes" add_mkisofs_opt $CDDIR/../$N.mkisofs_opts "-l" # Exit if this is not CD#1/DVD#1 if [ $N != "1" ]; then exit 0 fi if [ "$DI_WWW_HOME" = "default" ]; then DI_WWW_HOME="https://d-i.debian.org/daily-images/armhf/daily" try_di_image_cache else DI_WWW_HOME=$(echo $DI_WWW_HOME | sed "s,%ARCH%,$ARCH,") fi # armhf is not bootable directly from CD/DVD/USB for all plaforms. For # those that are not, add the needed files in the right place so that # users can find them, at least copy_arch_images # Now for the more clever stuff - for U-Boot EFI support or a direct # qemu etc. we can boot using EFI! case "$MKISOFS" in *xorriso*) XORRISO_VER=$(xorriso_version) ;; *) echo "ERROR: debian-cd depends on xorriso for making $ARCH bootable CDs." exit 1; ;; esac cd $CDDIR/.. BOOT_IMAGES="cdrom/initrd.gz cdrom/vmlinuz cdrom/debian-cd_info.tar.gz" # Download boot images. for image in $BOOT_IMAGES; do if [ ! -e "$image" ]; then dir=$(dirname $image) mkdir -p $dir if [ -n "$LOCAL" -a -f "${LOCALDEBS:-$MIRROR}/dists/$DI_DIST/local/installer-$ARCH/current/images/$image" ]; then cp "${LOCALDEBS:-$MIRROR}/dists/$DI_DIST/local/installer-$ARCH/current/images/$image" "$image" elif [ ! "$DI_WWW_HOME" ];then if [ ! "$DI_DIR" ];then DI_DIR="$MIRROR/dists/$DI_DIST/main/installer-$ARCH/current/images" fi cp "$DI_DIR/$image" "$image" else $WGET "$DI_WWW_HOME/$image" -O "$image" fi fi done mkdir -p $CDDIR/$INSTALLDIR cp -lf cdrom/vmlinuz $CDDIR/$INSTALLDIR/ cp -lf cdrom/initrd.gz $CDDIR/$INSTALLDIR/ # Boot setup including config and help files comes from d-i. mkdir -pv $PWD/boot$N cat cdrom/debian-cd_info.tar.gz | (cd boot$N/; tar zx) if [ -d boot$N/grub ] ; then echo " Adding EFI boot code for $ARCH on CD$N" # Move GRUB files to the right place. mkdir -p $CDDIR/EFI/boot mcopy -n -s -i boot$N/grub/efi.img '::efi/*' $CDDIR/EFI mkdir -p $CDDIR/boot/grub mv boot$N/grub/* $CDDIR/boot/grub/ rmdir boot$N/grub change_grub_cfg_uuid $CDDIR # Stuff the EFI boot files into a FAT filesystem, making it as # small as possible. We end up re-packing like this in case we're # making a multi-arch image # First, work out how many blocks we need blocks=$(calculate_efi_image_size $CDDIR) # Now make a new image to contain the files rm -f $CDDIR/boot/grub/efi.img mkfs.msdos --invariant -v -i deb00001 -C "$CDDIR/boot/grub/efi.img" $blocks >/dev/null # And copy them into place mmd -i "$CDDIR/boot/grub/efi.img" ::efi mcopy -o -s -i "$CDDIR/boot/grub/efi.img" $CDDIR/EFI/* \ "::efi" # Ugh - different code here depending on the version of xorriso we've got if [ $XORRISO_VER -le 10202 ] ; then echo "ERROR: debian-cd depends on xorriso > 1.2.2 for making $ARCH bootable CDs." exit 1; elif [ $XORRISO_VER -gt 10202 ] ; then echo " Using newer EFI support in xorriso $XORRISO_VER" # Location of the EFI boot image, and don't emulate a floppy or HD add_mkisofs_opt $CDDIR/../$N.mkisofs_opts "-e boot/grub/efi.img -no-emul-boot" # Add an *extra* partition on the end for the EFI bits add_mkisofs_opt $CDDIR/../$N.mkisofs_opts "-append_partition 2 0xef $CDDIR/boot/grub/efi.img" # And force alignment add_mkisofs_opt $CDDIR/../$N.mkisofs_opts "-partition_cyl_align all" fi # Finally, belt and braces - fix up the %install% entries in grub # in case they're still there sed -i "s|\%install\%|$INSTALLDIR|g" $CDDIR/boot/grub/grub.cfg # Substitute custom KERNEL_PARAMS into grub.cfg sed -i "s|/vmlinuz |/vmlinuz $KERNEL_PARAMS |g" $CDDIR/boot/grub/grub.cfg else echo " No EFI boot code for $ARCH on CD$N" fi # th,th, thats all