mirror of
https://github.com/freebsd/freebsd-src.git
synced 2024-11-27 02:42:46 +00:00
13cb004130
This requires a bunch of METALOG mangling to include the files we inject into the tree. The mkisoimages.sh and make-memstick.sh scripts are now called with the current directory inside the tree so that the relative paths in the METALOG match up with the current directory. The scripts do not require this when not using a METALOG, but for simplicity we always do so. The Makefile mangles the real METALOG created from the install, as those files are shared across all uses of the tree, but the shell scripts create a temporary copy of the METALOG that they mangle as their tree modifications are specific to that image. We also need to pass -D to makefs to turn any duplicate METALOG entry errors into warnings, as we have many (harmless) instances of those. Whilst dvd1.iso should work, the !NOPKG code will need more work to support this. All media will also lack mergemaster and etcupdate trees, since more work is needed to add -DNO_ROOT modes to them. Users of install media built this way will have to manually bootstrap them. Reviewed by: brooks, gjb Differential Revision: https://reviews.freebsd.org/D33999
120 lines
3.1 KiB
Bash
120 lines
3.1 KiB
Bash
#!/bin/sh
|
|
#
|
|
# $FreeBSD$
|
|
#
|
|
# This script is used by release/Makefile to build the (optional) ISO images
|
|
# for a FreeBSD release. It is considered architecture dependent since each
|
|
# platform has a slightly unique way of making bootable CDs. This script is
|
|
# also allowed to generate any number of images since that is more of
|
|
# publishing decision than anything else.
|
|
#
|
|
# Usage:
|
|
#
|
|
# mkisoimages.sh [-b] image-label image-name base-bits-dir [extra-bits-dir]
|
|
#
|
|
# Where -b is passed if the ISO image should be made "bootable" by
|
|
# whatever standards this architecture supports (may be unsupported),
|
|
# image-label is the ISO image label, image-name is the filename of the
|
|
# resulting ISO image, base-bits-dir contains the image contents and
|
|
# extra-bits-dir, if provided, contains additional files to be merged
|
|
# into base-bits-dir as part of making the image.
|
|
|
|
set -e
|
|
|
|
scriptdir=$(dirname $(realpath $0))
|
|
. ${scriptdir}/../../tools/boot/install-boot.sh
|
|
|
|
if [ -z $ETDUMP ]; then
|
|
ETDUMP=etdump
|
|
fi
|
|
|
|
if [ -z $MAKEFS ]; then
|
|
MAKEFS=makefs
|
|
fi
|
|
|
|
if [ -z $MKIMG ]; then
|
|
MKIMG=mkimg
|
|
fi
|
|
|
|
if [ "$1" = "-b" ]; then
|
|
MAKEFSARG="$4"
|
|
else
|
|
MAKEFSARG="$3"
|
|
fi
|
|
|
|
if [ -f ${MAKEFSARG} ]; then
|
|
BASEBITSDIR=`dirname ${MAKEFSARG}`
|
|
METALOG=${MAKEFSARG}
|
|
elif [ -d ${MAKEFSARG} ]; then
|
|
BASEBITSDIR=${MAKEFSARG}
|
|
METALOG=
|
|
else
|
|
echo "${MAKEFSARG} must exist"
|
|
exit 1
|
|
fi
|
|
|
|
if [ "$1" = "-b" ]; then
|
|
# Make an EFI system partition.
|
|
espfilename=$(mktemp /tmp/efiboot.XXXXXX)
|
|
# ESP file size in KB.
|
|
espsize="2048"
|
|
make_esp_file ${espfilename} ${espsize} ${BASEBITSDIR}/boot/loader.efi
|
|
|
|
bootable="-o bootimage=efi;${espfilename} -o no-emul-boot -o platformid=efi"
|
|
|
|
shift
|
|
else
|
|
bootable=""
|
|
fi
|
|
|
|
if [ $# -lt 3 ]; then
|
|
echo "Usage: $0 [-b] image-label image-name base-bits-dir [extra-bits-dir]"
|
|
exit 1
|
|
fi
|
|
|
|
LABEL=`echo "$1" | tr '[:lower:]' '[:upper:]'`; shift
|
|
NAME="$1"; shift
|
|
# MAKEFSARG extracted already
|
|
shift
|
|
|
|
publisher="The FreeBSD Project. https://www.FreeBSD.org/"
|
|
echo "/dev/iso9660/$LABEL / cd9660 ro 0 0" > "$BASEBITSDIR/etc/fstab"
|
|
if [ -n "${METALOG}" ]; then
|
|
metalogfilename=$(mktemp /tmp/metalog.XXXXXX)
|
|
cat ${METALOG} > ${metalogfilename}
|
|
echo "./etc/fstab type=file uname=root gname=wheel mode=0644" >> ${metalogfilename}
|
|
MAKEFSARG=${metalogfilename}
|
|
fi
|
|
$MAKEFS -D -t cd9660 $bootable -o rockridge -o label="$LABEL" -o publisher="$publisher" "$NAME" "$MAKEFSARG" "$@"
|
|
rm -f "$BASEBITSDIR/etc/fstab"
|
|
rm -f ${espfilename}
|
|
if [ -n "${METALOG}" ]; then
|
|
rm ${metalogfilename}
|
|
fi
|
|
|
|
if [ "$bootable" != "" ]; then
|
|
# Look for the EFI System Partition image we dropped in the ISO image.
|
|
for entry in `$ETDUMP --format shell $NAME`; do
|
|
eval $entry
|
|
# XXX: etdump(8) returns "default" for the initial entry
|
|
if [ "$et_platform" = "default" ]; then
|
|
espstart=`expr $et_lba \* 2048`
|
|
espsize=`expr $et_sectors \* 512`
|
|
espparam="-p efi::$espsize:$espstart"
|
|
break
|
|
fi
|
|
done
|
|
|
|
# Create a GPT image containing the EFI partition.
|
|
efifilename=$(mktemp /tmp/efi.img.XXXXXX)
|
|
imgsize=`stat -f %z "$NAME"`
|
|
$MKIMG -s gpt \
|
|
--capacity $imgsize \
|
|
$espparam \
|
|
-o $efifilename
|
|
|
|
# Drop the GPT into the System Area of the ISO.
|
|
dd if=$efifilename of="$NAME" bs=32k count=1 conv=notrunc
|
|
rm -f $efifilename
|
|
fi
|