coreboot and qemu rescue disks and bootchecks
This commit is contained in:
parent
ef4ffedd46
commit
aa8d7b2647
4 changed files with 110 additions and 75 deletions
|
@ -71,5 +71,8 @@ datetime_mod_SOURCES = lib/cmos_datetime.c
|
||||||
datetime_mod_CFLAGS = $(COMMON_CFLAGS)
|
datetime_mod_CFLAGS = $(COMMON_CFLAGS)
|
||||||
datetime_mod_LDFLAGS = $(COMMON_LDFLAGS)
|
datetime_mod_LDFLAGS = $(COMMON_LDFLAGS)
|
||||||
|
|
||||||
|
BOOTTARGET=coreboot
|
||||||
|
QEMU32=qemu-system-i386
|
||||||
|
|
||||||
include $(srcdir)/conf/i386.mk
|
include $(srcdir)/conf/i386.mk
|
||||||
include $(srcdir)/conf/common.mk
|
include $(srcdir)/conf/common.mk
|
||||||
|
|
|
@ -61,5 +61,8 @@ datetime_mod_SOURCES = lib/cmos_datetime.c
|
||||||
datetime_mod_CFLAGS = $(COMMON_CFLAGS)
|
datetime_mod_CFLAGS = $(COMMON_CFLAGS)
|
||||||
datetime_mod_LDFLAGS = $(COMMON_LDFLAGS)
|
datetime_mod_LDFLAGS = $(COMMON_LDFLAGS)
|
||||||
|
|
||||||
|
BOOTTARGET=qemu
|
||||||
|
QEMU32=qemu-system-i386
|
||||||
|
|
||||||
include $(srcdir)/conf/i386.mk
|
include $(srcdir)/conf/i386.mk
|
||||||
include $(srcdir)/conf/common.mk
|
include $(srcdir)/conf/common.mk
|
||||||
|
|
|
@ -83,6 +83,8 @@ for option in "$@"; do
|
||||||
if [ "$dev" = "fd" ] ; then boot=fd;
|
if [ "$dev" = "fd" ] ; then boot=fd;
|
||||||
elif [ "$dev" = "hd" ] ; then boot=hd;
|
elif [ "$dev" = "hd" ] ; then boot=hd;
|
||||||
elif [ "$dev" = "cd" ] ; then boot=cd;
|
elif [ "$dev" = "cd" ] ; then boot=cd;
|
||||||
|
elif [ "$dev" = "qemu" ] ; then boot=qemu;
|
||||||
|
elif [ "$dev" = "coreboot" ] ; then boot=coreboot;
|
||||||
else
|
else
|
||||||
echo "Unrecognized boot method \`$dev'" 1>&2
|
echo "Unrecognized boot method \`$dev'" 1>&2
|
||||||
usage
|
usage
|
||||||
|
@ -119,6 +121,8 @@ terminal_input serial
|
||||||
terminal_output serial
|
terminal_output serial
|
||||||
EOF
|
EOF
|
||||||
|
|
||||||
|
rom_directory=`mktemp -d`
|
||||||
|
|
||||||
for mod in ${modules}
|
for mod in ${modules}
|
||||||
do
|
do
|
||||||
echo "insmod ${mod}" >> ${cfgfile}
|
echo "insmod ${mod}" >> ${cfgfile}
|
||||||
|
@ -131,25 +135,43 @@ EOF
|
||||||
|
|
||||||
isofile=`mktemp`
|
isofile=`mktemp`
|
||||||
grub-mkrescue --output=${isofile} --override-directory=${builddir} \
|
grub-mkrescue --output=${isofile} --override-directory=${builddir} \
|
||||||
|
--rom-directory="${rom_directory}" \
|
||||||
/boot/grub/grub.cfg=${cfgfile} /boot/grub/testcase.cfg=${source} \
|
/boot/grub/grub.cfg=${cfgfile} /boot/grub/testcase.cfg=${source} \
|
||||||
${files} >/dev/null 2>&1
|
${files} >/dev/null 2>&1
|
||||||
if [ x$boot = xhd ]; then
|
if [ x$boot = xhd ]; then
|
||||||
device=hda
|
device=hda
|
||||||
bootdev=c
|
bootdev="-boot c"
|
||||||
fi
|
fi
|
||||||
if [ x$boot = xcd ]; then
|
if [ x$boot = xcd ]; then
|
||||||
device=cdrom
|
device=cdrom
|
||||||
bootdev=d
|
bootdev="-boot d"
|
||||||
fi
|
fi
|
||||||
if [ x$boot = xfd ]; then
|
if [ x$boot = xfd ]; then
|
||||||
device=fda
|
device=fda
|
||||||
bootdev=a
|
bootdev="-boot a"
|
||||||
fi
|
fi
|
||||||
|
|
||||||
${qemu} ${qemuopts} -nographic -serial file:/dev/stdout -monitor file:/dev/null -${device} ${isofile} -boot ${bootdev} | tr -d "\r"
|
if [ x$boot = xqemu ]; then
|
||||||
rm -f ${isofile}
|
bootdev="-bios ${rom_directory}/qemu.img"
|
||||||
|
device=cdrom
|
||||||
|
fi
|
||||||
|
|
||||||
rm -f ${tmpfile} ${cfgfile}
|
if [ x$boot = xcoreboot ]; then
|
||||||
|
imgfile=`mktemp`
|
||||||
|
cp "${GRUB_COREBOOT_ROM}" "${imgfile}"
|
||||||
|
"${GRUB_CBFSTOOL}" "${imgfile}" add-payload "${rom_directory}/coreboot.elf" fallback/payload
|
||||||
|
bootdev="-bios ${imgfile}"
|
||||||
|
device=cdrom
|
||||||
|
fi
|
||||||
|
|
||||||
|
${qemu} ${qemuopts} -nographic -serial file:/dev/stdout -monitor file:/dev/null -${device} ${isofile} ${bootdev} | tr -d "\r"
|
||||||
|
rm -f "${isofile}" "${imgfile}"
|
||||||
|
rm -rf "${rom_directory}"
|
||||||
|
if [ x$boot = xcoreboot ]; then
|
||||||
|
rm -f "${imgfile}"
|
||||||
|
fi
|
||||||
|
|
||||||
|
rm -f "${tmpfile}" "${cfgfile}"
|
||||||
exit 0
|
exit 0
|
||||||
|
|
||||||
|
|
||||||
|
|
|
@ -30,10 +30,13 @@ target_cpu=@target_cpu@
|
||||||
native_platform=@platform@
|
native_platform=@platform@
|
||||||
pkglib_DATA="@pkglib_DATA@"
|
pkglib_DATA="@pkglib_DATA@"
|
||||||
|
|
||||||
multiboot_dir=${libdir}/$(echo ${PACKAGE_TARNAME} | sed ${transform})/${target_cpu}-multiboot
|
multiboot_dir=${libdir}/$(echo ${PACKAGE_TARNAME} | sed ${transform})/i386-multiboot
|
||||||
pc_dir=${libdir}/$(echo ${PACKAGE_TARNAME} | sed ${transform})/${target_cpu}-pc
|
coreboot_dir=${libdir}/$(echo ${PACKAGE_TARNAME} | sed ${transform})/i386-coreboot
|
||||||
|
qemu_dir=${libdir}/$(echo ${PACKAGE_TARNAME} | sed ${transform})/i386-qemu
|
||||||
|
pc_dir=${libdir}/$(echo ${PACKAGE_TARNAME} | sed ${transform})/i386-pc
|
||||||
efi32_dir=${libdir}/$(echo ${PACKAGE_TARNAME} | sed ${transform})/i386-efi
|
efi32_dir=${libdir}/$(echo ${PACKAGE_TARNAME} | sed ${transform})/i386-efi
|
||||||
efi64_dir=${libdir}/$(echo ${PACKAGE_TARNAME} | sed ${transform})/x86_64-efi
|
efi64_dir=${libdir}/$(echo ${PACKAGE_TARNAME} | sed ${transform})/x86_64-efi
|
||||||
|
rom_directory=
|
||||||
|
|
||||||
# Usage: usage
|
# Usage: usage
|
||||||
# Print the usage.
|
# Print the usage.
|
||||||
|
@ -46,6 +49,7 @@ Make GRUB rescue image.
|
||||||
-v, --version print the version information and exit
|
-v, --version print the version information and exit
|
||||||
--modules=MODULES pre-load specified modules MODULES
|
--modules=MODULES pre-load specified modules MODULES
|
||||||
--output=FILE save output in FILE [required]
|
--output=FILE save output in FILE [required]
|
||||||
|
--rom-directory=DIR save rom images in DIR [optional]
|
||||||
|
|
||||||
$0 generates a bootable rescue image with specified source files or directories.
|
$0 generates a bootable rescue image with specified source files or directories.
|
||||||
|
|
||||||
|
@ -66,6 +70,8 @@ for option in "$@"; do
|
||||||
modules=`echo "$option" | sed 's/--modules=//'` ;;
|
modules=`echo "$option" | sed 's/--modules=//'` ;;
|
||||||
--output=*)
|
--output=*)
|
||||||
output_image=`echo "$option" | sed 's/--output=//'` ;;
|
output_image=`echo "$option" | sed 's/--output=//'` ;;
|
||||||
|
--rom-directory=*)
|
||||||
|
rom_directory=`echo "$option" | sed 's/--rom-directory=//'` ;;
|
||||||
# Intentionally undocumented
|
# Intentionally undocumented
|
||||||
--override-directory=*)
|
--override-directory=*)
|
||||||
override_dir=`echo "${option}/" | sed 's/--override-directory=//'`
|
override_dir=`echo "${option}/" | sed 's/--override-directory=//'`
|
||||||
|
@ -103,15 +109,15 @@ process_input_dir ()
|
||||||
{
|
{
|
||||||
input_dir="$1"
|
input_dir="$1"
|
||||||
platform="$2"
|
platform="$2"
|
||||||
mkdir -p ${iso9660_dir}/boot/grub/${target_cpu}-${platform}
|
mkdir -p ${iso9660_dir}/boot/grub/${platform}
|
||||||
for file in ${input_dir}/*.mod; do
|
for file in ${input_dir}/*.mod; do
|
||||||
if test -f "$file"; then
|
if test -f "$file"; then
|
||||||
cp -f "$file" ${iso9660_dir}/boot/grub/${target_cpu}-${platform}/
|
cp -f "$file" ${iso9660_dir}/boot/grub/${platform}/
|
||||||
fi
|
fi
|
||||||
done
|
done
|
||||||
for file in ${pkglib_DATA}; do
|
for file in ${pkglib_DATA}; do
|
||||||
if test -f "${input_dir}/${file}"; then
|
if test -f "${input_dir}/${file}"; then
|
||||||
cp -f "${input_dir}/${file}" ${iso9660_dir}/boot/grub/${target_cpu}-${platform}/
|
cp -f "${input_dir}/${file}" ${iso9660_dir}/boot/grub/${platform}/
|
||||||
fi
|
fi
|
||||||
done
|
done
|
||||||
|
|
||||||
|
@ -123,27 +129,70 @@ process_input_dir ()
|
||||||
done
|
done
|
||||||
}
|
}
|
||||||
|
|
||||||
|
make_image ()
|
||||||
|
{
|
||||||
|
source_directory="$1"
|
||||||
|
platform=$2
|
||||||
|
if ! test -e "${source_directory}"; then
|
||||||
|
return;
|
||||||
|
fi
|
||||||
|
|
||||||
|
echo "Enabling $2 support ..."
|
||||||
|
|
||||||
|
memdisk_img=`mktemp "$MKTEMP_TEMPLATE"`
|
||||||
|
memdisk_dir=`mktemp -d "$MKTEMP_TEMPLATE"`
|
||||||
|
mkdir -p ${memdisk_dir}/boot/grub
|
||||||
|
|
||||||
|
modules="$(cat ${source_directory}/partmap.lst) ${modules}"
|
||||||
|
cat << EOF > ${memdisk_dir}/boot/grub/grub.cfg
|
||||||
|
search --fs-uuid --set ${iso_uuid}
|
||||||
|
set prefix=(\${root})/boot/grub/${platform}
|
||||||
|
source \$prefix/grub.cfg
|
||||||
|
EOF
|
||||||
|
(for i in ${modules} ; do
|
||||||
|
echo "insmod $i"
|
||||||
|
done ; \
|
||||||
|
echo "source /boot/grub/grub.cfg") \
|
||||||
|
> ${iso9660_dir}/boot/grub/${platform}/grub.cfg
|
||||||
|
|
||||||
|
tar -C ${memdisk_dir} -cf ${memdisk_img} boot
|
||||||
|
rm -rf ${memdisk_dir}
|
||||||
|
grub-mkimage -O ${platform} -d "${source_directory}" -m "${memdisk_img}" -o "$3" --prefix='(memdisk)/boot/grub' \
|
||||||
|
search iso9660 configfile sh memdisk tar $4
|
||||||
|
rm -rf ${memdisk_img}
|
||||||
|
}
|
||||||
|
|
||||||
if [ "${override_dir}" = "" ] ; then
|
if [ "${override_dir}" = "" ] ; then
|
||||||
if test -e "${multiboot_dir}" ; then
|
if test -e "${multiboot_dir}" ; then
|
||||||
process_input_dir ${multiboot_dir} multiboot
|
process_input_dir ${multiboot_dir} i386-multiboot
|
||||||
|
fi
|
||||||
|
if test -e "${coreboot_dir}" ; then
|
||||||
|
process_input_dir ${coreboot_dir} i386-coreboot
|
||||||
|
fi
|
||||||
|
if test -e "${qemu_dir}" ; then
|
||||||
|
process_input_dir ${qemu_dir} i386-qemu
|
||||||
fi
|
fi
|
||||||
if test -e "${pc_dir}" ; then
|
if test -e "${pc_dir}" ; then
|
||||||
process_input_dir ${pc_dir} pc
|
process_input_dir ${pc_dir} i386-pc
|
||||||
fi
|
fi
|
||||||
if test -e "${efi32_dir}" ; then
|
if test -e "${efi32_dir}" ; then
|
||||||
process_input_dir ${efi32_dir} efi32
|
process_input_dir ${efi32_dir} i386-efi
|
||||||
fi
|
fi
|
||||||
if test -e "${efi64_dir}" ; then
|
if test -e "${efi64_dir}" ; then
|
||||||
process_input_dir ${efi64_dir} efi64
|
process_input_dir ${efi64_dir} x86_64-efi
|
||||||
fi
|
fi
|
||||||
else
|
else
|
||||||
process_input_dir ${override_dir} ${native_platform}
|
process_input_dir ${override_dir} ${target_cpu}-${native_platform}
|
||||||
multiboot_dir=
|
multiboot_dir=
|
||||||
pc_dir=
|
pc_dir=
|
||||||
efi32_dir=
|
efi32_dir=
|
||||||
efi64_dir=
|
efi64_dir=
|
||||||
case "${native_platform}" in
|
coreboot_dir=
|
||||||
|
qemu_dir=
|
||||||
|
case "${target_cpu}-${native_platform}" in
|
||||||
i386-multiboot) multiboot_dir=${override_dir} ;;
|
i386-multiboot) multiboot_dir=${override_dir} ;;
|
||||||
|
i386-coreboot) coreboot_dir=${override_dir} ;;
|
||||||
|
i386-qemu) qemu_dir=${override_dir} ;;
|
||||||
i386-pc) pc_dir=${override_dir} ;;
|
i386-pc) pc_dir=${override_dir} ;;
|
||||||
i386-efi) efi32_dir=${override_dir} ;;
|
i386-efi) efi32_dir=${override_dir} ;;
|
||||||
x86_64-efi) efi64_dir=${override_dir} ;;
|
x86_64-efi) efi64_dir=${override_dir} ;;
|
||||||
|
@ -154,33 +203,6 @@ fi
|
||||||
iso_uuid=$(date -u +%Y-%m-%d-%H-%M-%S-00)
|
iso_uuid=$(date -u +%Y-%m-%d-%H-%M-%S-00)
|
||||||
grub_mkisofs_arguments="${grub_mkisofs_arguments} --modification-date=$(echo ${iso_uuid} | sed -e s/-//g)"
|
grub_mkisofs_arguments="${grub_mkisofs_arguments} --modification-date=$(echo ${iso_uuid} | sed -e s/-//g)"
|
||||||
|
|
||||||
# build multiboot core.img
|
|
||||||
if test -e "${multiboot_dir}" ; then
|
|
||||||
echo "Enabling multiboot support ..."
|
|
||||||
memdisk_img=`mktemp "$MKTEMP_TEMPLATE"`
|
|
||||||
memdisk_dir=`mktemp -d "$MKTEMP_TEMPLATE"`
|
|
||||||
mkdir -p ${memdisk_dir}/boot/grub
|
|
||||||
|
|
||||||
modules="$(cat ${multiboot_dir}/partmap.lst) ${modules}"
|
|
||||||
cat << EOF > ${memdisk_dir}/boot/grub/grub.cfg
|
|
||||||
search --fs-uuid --set ${iso_uuid}
|
|
||||||
set prefix=(\${root})/boot/grub/${target_cpu}-multiboot
|
|
||||||
source \$prefix/grub.cfg
|
|
||||||
EOF
|
|
||||||
(for i in ${modules} ; do
|
|
||||||
echo "insmod $i"
|
|
||||||
done ; \
|
|
||||||
echo "source /boot/grub/grub.cfg") \
|
|
||||||
> ${iso9660_dir}/boot/grub/i386-multiboot/grub.cfg
|
|
||||||
|
|
||||||
tar -C ${memdisk_dir} -cf ${memdisk_img} boot
|
|
||||||
rm -rf ${memdisk_dir}
|
|
||||||
grub-mkimage -O i386-multiboot -d ${multiboot_dir}/ -m ${memdisk_img} -o ${iso9660_dir}/boot/multiboot.img \
|
|
||||||
memdisk tar search iso9660 configfile sh \
|
|
||||||
ata at_keyboard
|
|
||||||
rm -f ${memdisk_img}
|
|
||||||
fi
|
|
||||||
|
|
||||||
# build BIOS core.img
|
# build BIOS core.img
|
||||||
if test -e "${pc_dir}" ; then
|
if test -e "${pc_dir}" ; then
|
||||||
echo "Enabling BIOS support ..."
|
echo "Enabling BIOS support ..."
|
||||||
|
@ -205,47 +227,32 @@ if test -e "${pc_dir}" ; then
|
||||||
--embedded-boot ${embed_img}"
|
--embedded-boot ${embed_img}"
|
||||||
fi
|
fi
|
||||||
|
|
||||||
|
# build multiboot core.img
|
||||||
|
make_image "${multiboot_dir}" i386-multiboot "${iso9660_dir}/boot/multiboot.img" "ata at_keyboard"
|
||||||
|
|
||||||
if test -e "${efi64_dir}" || test -e "${efi32_dir}"; then
|
if test -e "${efi64_dir}" || test -e "${efi32_dir}"; then
|
||||||
efi_dir=`mktemp -d "$MKTEMP_TEMPLATE"`
|
efi_dir=`mktemp -d "$MKTEMP_TEMPLATE"`
|
||||||
mkdir -p "${efi_dir}/efi/boot"
|
mkdir -p "${efi_dir}/efi/boot"
|
||||||
else
|
|
||||||
efi_dir=
|
|
||||||
fi
|
|
||||||
|
|
||||||
# build bootx64.efi
|
# build bootx64.efi
|
||||||
if test -e "${efi64_dir}" ; then
|
make_image "${efi64_dir}" x86_64-efi "${efi_dir}"/efi/boot/bootx64.efi ""
|
||||||
echo "Enabling EFI64 support ..."
|
# build bootia32.efi
|
||||||
memdisk_img=`mktemp "$MKTEMP_TEMPLATE"`
|
make_image "${efi32_dir}" i386-efi "${efi_dir}"/efi/boot/bootia32.efi ""
|
||||||
memdisk_dir=`mktemp -d "$MKTEMP_TEMPLATE"`
|
|
||||||
mkdir -p ${memdisk_dir}/boot/grub
|
|
||||||
|
|
||||||
cat << EOF > ${memdisk_dir}/boot/grub/grub.cfg
|
|
||||||
search --fs-uuid --set ${iso_uuid}
|
|
||||||
set prefix=(\${root})/boot/grub/${target_cpu}-efi
|
|
||||||
source \$prefix/grub.cfg
|
|
||||||
EOF
|
|
||||||
|
|
||||||
tar -C ${memdisk_dir} -cf ${memdisk_img} boot
|
|
||||||
rm -rf ${memdisk_dir}
|
|
||||||
|
|
||||||
grub-mkimage -O x86_64-efi -d "${efi64_dir}" -m "${memdisk_img}" -o "${efi_dir}"/efi/boot/bootx64.efi --prefix='(memdisk)/boot/grub' \
|
|
||||||
search iso9660 configfile sh memdisk tar
|
|
||||||
rm -f ${memdisk_img}
|
|
||||||
|
|
||||||
modules="$(cat "${efi64_dir}"/partmap.lst) ${modules}"
|
|
||||||
(for i in ${modules} ; do
|
|
||||||
echo "insmod $i"
|
|
||||||
done ; \
|
|
||||||
echo "source /boot/grub/grub.cfg") \
|
|
||||||
> "${iso9660_dir}"/boot/grub/x86_64-efi/grub.cfg
|
|
||||||
fi
|
|
||||||
|
|
||||||
if test x"${efi_dir}" != x; then
|
|
||||||
mformat -C -f 2880 -L 16 -i "${iso9660_dir}"/efi.img ::
|
mformat -C -f 2880 -L 16 -i "${iso9660_dir}"/efi.img ::
|
||||||
mcopy -s -i "${iso9660_dir}"/efi.img ${efi_dir}/efi ::/
|
mcopy -s -i "${iso9660_dir}"/efi.img ${efi_dir}/efi ::/
|
||||||
grub_mkisofs_arguments="${grub_mkisofs_arguments} --efi-boot efi.img"
|
grub_mkisofs_arguments="${grub_mkisofs_arguments} --efi-boot efi.img"
|
||||||
fi
|
fi
|
||||||
|
|
||||||
|
make_image "${qemu_dir}" i386-qemu "${iso9660_dir}/boot/qemu.img" "ata at_keyboard"
|
||||||
|
if [ -e "${iso9660_dir}/boot/qemu.img" ] && [ -d "${rom_directory}" ]; then
|
||||||
|
cp "${iso9660_dir}/boot/qemu.img" "${rom_directory}/qemu.img"
|
||||||
|
fi
|
||||||
|
make_image "${coreboot_dir}" i386-coreboot "${iso9660_dir}/boot/coreboot.elf" "ata at_keyboard"
|
||||||
|
if [ -e "${iso9660_dir}/boot/coreboot.elf" ] && [ -d "${rom_directory}" ]; then
|
||||||
|
cp "${iso9660_dir}/boot/coreboot.elf" "${rom_directory}/coreboot.elf"
|
||||||
|
fi
|
||||||
|
|
||||||
# build iso image
|
# build iso image
|
||||||
xorriso -pathspecs on -as mkisofs ${grub_mkisofs_arguments} --protective-msdos-label -o ${output_image} -r ${iso9660_dir} ${source}
|
xorriso -pathspecs on -as mkisofs ${grub_mkisofs_arguments} --protective-msdos-label -o ${output_image} -r ${iso9660_dir} ${source}
|
||||||
rm -rf ${iso9660_dir}
|
rm -rf ${iso9660_dir}
|
||||||
|
|
Loading…
Reference in a new issue