summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorAndreas Loibl <andreas@andreas-loibl.de>2011-03-05 11:53:55 +0100
committerAndreas Loibl <andreas@andreas-loibl.de>2011-03-24 22:05:28 +0100
commit319aa92a25614b17181a5beb917998777fa893d7 (patch)
tree51fe2ac5c857efe2f33daecf69ff3282d2ee1803
parent3fa575103c6549ad7df429e385ce69f228e7ee31 (diff)
downloadlive-build-319aa92a25614b17181a5beb917998777fa893d7.zip
live-build-319aa92a25614b17181a5beb917998777fa893d7.tar.gz
added support for burg bootloader
-rwxr-xr-xscripts/build/lb_binary1
-rwxr-xr-xscripts/build/lb_binary_burg288
-rwxr-xr-xscripts/build/lb_binary_iso54
-rwxr-xr-xscripts/build/lb_config2
-rw-r--r--templates/burg/burg.cfg7
5 files changed, 351 insertions, 1 deletions
diff --git a/scripts/build/lb_binary b/scripts/build/lb_binary
index 27921f2..73b49d7 100755
--- a/scripts/build/lb_binary
+++ b/scripts/build/lb_binary
@@ -65,6 +65,7 @@ lb binary_debian-installer ${*}
lb binary_memtest ${*}
lb binary_grub ${*}
lb binary_grub2 ${*}
+lb binary_burg ${*}
lb binary_syslinux ${*}
lb binary_yaboot ${*}
lb binary_silo ${*}
diff --git a/scripts/build/lb_binary_burg b/scripts/build/lb_binary_burg
new file mode 100755
index 0000000..9afca88
--- /dev/null
+++ b/scripts/build/lb_binary_burg
@@ -0,0 +1,288 @@
+#!/bin/sh
+
+## live-build(7) - System Build Scripts
+## Copyright (C) 2006-2011 Daniel Baumann <daniel@debian.org>
+##
+## live-build comes with ABSOLUTELY NO WARRANTY; for details see COPYING.
+## This is free software, and you are welcome to redistribute it
+## under certain conditions; see COPYING for details.
+
+
+set -e
+
+# Including common functions
+. "${LB_BASE:-/usr/share/live/build}"/scripts/build.sh
+
+# Setting static variables
+DESCRIPTION="$(Echo 'installs burg into binary')"
+HELP=""
+USAGE="${PROGRAM} [--force]"
+
+Arguments "${@}"
+
+# Reading configuration files
+Read_conffiles config/all config/common config/bootstrap config/chroot config/binary config/source
+Set_defaults
+
+if [ "${LB_BOOTLOADER}" != "burg" ]
+then
+ exit 0
+fi
+
+Echo_message "Begin installing burg..."
+
+# Requiring stage file
+Require_stagefile .stage/config .stage/bootstrap
+
+# Checking stage file
+Check_stagefile .stage/binary_burg
+
+# Checking burg templates
+Check_templates burg
+
+# Checking lock file
+Check_lockfile .lock
+
+# Creating lock file
+Create_lockfile .lock
+
+# Check architecture
+Check_architecture amd64 i386
+Check_crossarchitecture
+
+# Checking depends
+Check_package chroot/usr/bin/burg-mkimage burg-pc
+
+# Restoring cache
+Restore_cache cache/packages_binary
+
+# Installing depends
+Install_package
+
+# Local functions
+Burg_live_entry ()
+{
+ LABEL="${1}"
+ KERNEL="${2}"
+ INITRD="${3}"
+ APPEND="${4}"
+
+ LINUX_LIVE="${LINUX_LIVE}\nmenuentry \"Debian GNU/Linux - ${LABEL}\" {"
+ LINUX_LIVE="${LINUX_LIVE}\nlinux\t\t/${KERNEL} boot=${INITFS} config LB_BOOTAPPEND_LIVE ${APPEND}"
+ LINUX_LIVE="${LINUX_LIVE}\ninitrd\t\t/${INITRD}"
+ LINUX_LIVE="${LINUX_LIVE}\n}"
+}
+
+Burg_install_entry ()
+{
+ LABEL="${1}"
+ KERNEL="${2}"
+ INITRD="${3}"
+ APPEND="${4}"
+
+ if [ "${LABEL}" != "rescue" ] && [ "${LABEL}" != "rescuegui" ]
+ then
+ APPEND="${APPEND} quiet"
+ fi
+
+ LINUX_INSTALL="${LINUX_INSTALL}\nmenuentry \"Debian GNU/Linux - ${LABEL}\" {"
+ LINUX_INSTALL="${LINUX_INSTALL}\nlinux\t\t/${KERNEL} ${APPEND} LB_BOOTAPPEND_INSTALL"
+ LINUX_INSTALL="${LINUX_INSTALL}\ninitrd\t\t/${INITRD}"
+ LINUX_INSTALL="${LINUX_INSTALL}\n}"
+}
+
+case "${LB_INITRAMFS}" in
+ casper)
+ INITFS="casper"
+ ;;
+
+ live-initramfs|live-boot)
+ INITFS="live"
+ ;;
+esac
+
+# Setting destination directory
+case "${LB_BINARY_IMAGES}" in
+ iso*|tar)
+ case "${LB_INITRAMFS}" in
+ casper)
+ DESTDIR_LIVE="binary/casper"
+ ;;
+
+ live-initramfs|live-boot)
+ DESTDIR_LIVE="binary/live"
+ ;;
+ esac
+
+ DESTDIR_INSTALL="binary/install"
+ ;;
+
+ usb*|net)
+ Echo_warning "Bootloader in this image type not yet supported by live-build."
+ Echo_warning "This would produce a not bootable image, aborting (FIXME)."
+ exit 1
+ ;;
+esac
+
+Check_multiarchitecture
+
+# Creating directory
+mkdir -p "${DESTDIR_LIVE}"
+
+# Setting boot parameters
+
+case "${LB_ENCRYPTION}" in
+ ""|false)
+ ;;
+ *)
+ LB_BOOTAPPEND_LIVE="${LB_BOOTAPPEND_LIVE} encryption=${LB_ENCRYPTION}"
+esac
+
+if [ -n "${LB_USERNAME}" ]
+then
+ case "${LB_INITRAMFS}" in
+ casper)
+ LB_BOOTAPPEND_LIVE="${LB_BOOTAPPEND_LIVE} username=${LB_USERNAME}"
+ ;;
+
+ live-initramfs|live-boot)
+ if [ "${LB_USERNAME}" != "user" ]
+ then
+ LB_BOOTAPPEND_LIVE="${LB_BOOTAPPEND_LIVE} username=${LB_USERNAME}"
+ fi
+ ;;
+ esac
+fi
+
+if [ -n "${LB_HOSTNAME}" ]
+then
+ case "${LB_INITRAMFS}" in
+ casper)
+ LB_BOOTAPPEND_LIVE="${LB_BOOTAPPEND_LIVE} hostname=${LB_HOSTNAME}"
+ ;;
+
+ live-initramfs|live-boot)
+ if [ "${LB_HOSTNAME}" != "debian" ]
+ then
+ LB_BOOTAPPEND_LIVE="${LB_BOOTAPPEND_LIVE} hostname=${LB_HOSTNAME}"
+ fi
+ ;;
+ esac
+fi
+
+if [ "${LB_UNION_FILESYSTEM}" != "aufs" ]
+then
+ LB_BOOTAPPEND_LIVE="${LB_BOOTAPPEND_LIVE} union=${LB_UNION_FILESYSTEM}"
+fi
+
+if [ -n "${LB_NET_COW_PATH}" ]
+then
+ Echo_error "Net cow not yet supported on burg"
+ exit 1
+fi
+
+if [ "${LB_EXPOSED_ROOT}" != "false" ]
+then
+ LB_BOOTAPPEND_LIVE="${LB_BOOTAPPEND_LIVE} exposedroot"
+fi
+
+LB_BOOTAPPEND_LIVE="$(echo ${LB_BOOTAPPEND_LIVE} | sed -e 's| ||')"
+
+# Parameters are listed at: linux/Documentation/kernel-parameters.txt
+FAILSAFE="noapic noapm nodma nomce nolapic nomodeset nosmp vga=normal"
+
+# Assembling kernel configuration
+
+# Default entries
+DEFAULT_FLAVOUR="$(echo ${LB_LINUX_FLAVOURS} | awk '{ print $1 }')"
+DEFAULT_KERNEL="$(basename chroot/boot/vmlinuz-*${DEFAULT_FLAVOUR})"
+DEFAULT_INITRD="initrd.img-$(echo ${DEFAULT_KERNEL} | sed -e 's|vmlinuz-||')"
+
+Burg_live_entry "live" "$(basename ${DESTDIR_LIVE})/${DEFAULT_KERNEL}" "$(basename ${DESTDIR_LIVE})/${DEFAULT_INITRD}"
+Burg_live_entry "live (fail-safe mode)" "$(basename ${DESTDIR_LIVE})/${DEFAULT_KERNEL}" "$(basename ${DESTDIR_LIVE})/${DEFAULT_INITRD}" "${FAILSAFE}"
+
+for KERNEL in chroot/boot/vmlinuz-*
+do
+ VERSION="$(basename ${KERNEL} | sed -e 's|vmlinuz-||')"
+
+ Burg_live_entry "live, kernel ${VERSION}" "$(basename ${DESTDIR_LIVE})/$(basename ${KERNEL})" "$(basename ${DESTDIR_LIVE})/initrd.img-${VERSION}"
+ Burg_live_entry "live, kernel ${VERSION} (fail-safe mode)" "$(basename ${DESTDIR_LIVE})/$(basename ${KERNEL})" "$(basename ${DESTDIR_LIVE})/initrd.img-${VERSION}" "${FAILSAFE}"
+done
+
+LINUX_LIVE="$(/bin/echo ${LINUX_LIVE} | sed -e 's|binary||g' -e 's|//|/|g')"
+
+# Assembling debian-installer configuration
+if [ "${LB_DEBIAN_INSTALLER}" != "false" ]
+then
+ LINUX_LIVE="#\t \"Live\"\n${LINUX_LIVE}"
+ LINUX_INSTALL="#\t \"Installer\"\n"
+
+ VMLINUZ_DI="install/vmlinuz"
+ INITRD_DI="install/initrd.gz"
+ APPEND_DI="vga=normal"
+
+ VMLINUZ_GI="install/gtk/vmlinuz"
+ INITRD_GI="install/gtk/initrd.gz"
+ APPEND_GI="video=vesa:ywrap,mtrr vga=788"
+
+ Burg_install_entry "install" "${VMLINUZ_DI}" "${INITRD_DI}" "${APPEND_DI}"
+ Burg_install_entry "installgui" "${VMLINUZ_GI}" "${INITRD_GI}" "${APPEND_GI}"
+ Burg_install_entry "expert" "${VMLINUZ_DI}" "${INITRD_DI}" "priority=low ${APPEND_DI}"
+ Burg_install_entry "expertgui" "${VMLINUZ_GI}" "${INITRD_GI}" "priority=low ${APPEND_GI}"
+ Burg_install_entry "rescue" "${VMLINUZ_DI}" "${INITRD_DI}" "rescue/enable=true ${APPEND_DI}"
+ Burg_install_entry "rescuegui" "${VMLINUZ_GI}" "${INITRD_GI}" "rescue/enable=true ${APPEND_GI}"
+ Burg_install_entry "auto" "${VMLINUZ_DI}" "${INITRD_DI}" "auto=true priority=critical ${APPEND_DI}"
+ Burg_install_entry "autogui" "${VMLINUZ_GI}" "${INITRD_GI}" "auto=true priority=critical ${APPEND_GI}"
+fi
+
+LINUX_INSTALL="$(/bin/echo ${LINUX_INSTALL} | sed -e 's|binary||g' -e 's|//|/|g')"
+
+# Assembling memtest configuration
+if [ -f "${DESTDIR_LIVE}"/memtest ]
+then
+ MEMTEST="#\t \"Other\"\n"
+ MEMTEST="${MEMTEST}\nmenuentry\t\"${LB_MEMTEST}\" {\nlinux16\t$(basename ${DESTDIR_LIVE})/memtest\n}"
+ MEMTEST="$(/bin/echo ${MEMTEST} | sed -e 's|//|/|g')"
+fi
+
+# Copying templates
+mkdir -p binary/boot/burg
+cp -r "${TEMPLATES}"/* binary/boot/burg
+
+case ${LB_BINARY_IMAGES} in
+ iso*)
+ FILES="chroot/usr/lib/burg/i386-pc/*.mod chroot/usr/lib/burg/i386-pc/*.lst chroot/usr/lib/burg/i386-pc/efiemu??.o chroot/usr/share/burg/*.pf2"
+ ;;
+
+ usb*|tar)
+ FILES="chroot/usr/lib/burg/i386-pc/*"
+ ;;
+esac
+
+if [ "${LB_BUILD_WITH_CHROOT}" = "false" ]
+then
+ FILES="$(echo ${FILES} | sed -e 's|chroot||g')"
+fi
+
+# Copying burg
+cp ${FILES} binary/boot/burg
+
+# Copying local configuration file
+if [ -f config/binary_burg/burg.cfg ]
+then
+ cp config/binary_burg/burg.cfg binary/boot/burg/burg.cfg
+fi
+
+sed -i -e "s|LINUX_LIVE|${LINUX_LIVE}|" -e "s|LINUX_INSTALL|${LINUX_INSTALL}|" -e "s|MEMTEST|${MEMTEST}|" binary/boot/burg/burg.cfg
+sed -i -e "s|LB_BOOTAPPEND_INSTALL|${LB_BOOTAPPEND_INSTALL}|" -e "s|LB_BOOTAPPEND_LIVE|${LB_BOOTAPPEND_LIVE}|" binary/boot/burg/burg.cfg
+
+sed -i -e 's|\ $||g' binary/boot/burg/burg.cfg
+
+# Saving cache
+Save_cache cache/packages_binary
+
+# Removing depends
+Remove_package
+
+# Creating stage file
+Create_stagefile .stage/binary_burg
diff --git a/scripts/build/lb_binary_iso b/scripts/build/lb_binary_iso
index 0394d36..813919f 100755
--- a/scripts/build/lb_binary_iso
+++ b/scripts/build/lb_binary_iso
@@ -120,6 +120,12 @@ case "${LB_BOOTLOADER}" in
GENISOIMAGE_EXCLUDE="boot/grub/grub_eltorito"
;;
+ burg)
+ GENISOIMAGE_OPTIONS="${GENISOIMAGE_OPTIONS} -no-emul-boot -boot-load-size 4 -boot-info-table"
+ GENISOIMAGE_OPTIONS="${GENISOIMAGE_OPTIONS} -r -b boot/burg/burg_eltorito -J"
+ GENISOIMAGE_EXCLUDE="boot/burg/burg_eltorito"
+ ;;
+
silo)
GENISOIMAGE_OPTIONS="${GENISOIMAGE_OPTIONS} -r -G boot/isofs.b -B ..."
GENISOIMAGE_EXCLUDE="boot/isofs.b"
@@ -180,6 +186,11 @@ grub-mkimage -d \${input_dir} -o \${core_img} ${GRUB_MKIMAGE_OPTIONS} biosdisk i
# build grub_eltorito image
cat \${input_dir}/cdboot.img \${core_img} > binary/boot/grub/grub_eltorito
+if [ "${LB_BINARY_IMAGES}" = "iso-hybrid" ]; then
+ for i in \$(seq 64); do echo -n "ACRITOX!"; done > binary/boot.isohybrid
+ cat \${core_img} >> binary/boot.isohybrid
+fi
+
rm -f \${core_img}
for file in \${input_dir}/*.mod \${input_dir}/efiemu??.o \
@@ -193,6 +204,39 @@ do
done
EOF
+elif [ "${LB_BOOTLOADER}" = "burg" ]
+then
+
+cat > binary.sh << EOF
+#!/bin/sh
+
+input_dir=/usr/lib/burg/i386-pc
+
+# build core.img
+core_img=\$(mktemp)
+burg-mkimage -d \${input_dir} -o \${core_img} biosdisk iso9660
+
+# build burg_eltorito image
+cat \${input_dir}/cdboot.img \${core_img} > binary/boot/burg/burg_eltorito
+
+if [ "${LB_BINARY_IMAGES}" = "iso-hybrid" ]; then
+ for i in \$(seq 64); do echo -n "ACRITOX!"; done > binary/boot.isohybrid
+ cat \${core_img} >> binary/boot.isohybrid
+fi
+
+rm -f \${core_img}
+
+for file in \${input_dir}/*.mod \${input_dir}/efiemu??.o \
+ \${input_dir}/command.lst \${input_dir}/moddep.lst \${input_dir}/fs.lst \
+ \${input_dir}/handler.lst \${input_dir}/parttool.lst
+do
+ if test -f "\$file"
+ then
+ cp -f "\$file" binary/boot/burg
+ fi
+done
+EOF
+
else
echo "#!/bin/sh" > binary.sh
fi
@@ -205,10 +249,20 @@ EOF
if [ "${LB_BINARY_IMAGES}" = "iso-hybrid" ]
then
+case "${LB_BOOTLOADER}" in
+grub2|burg)
+cat >> binary.sh << EOF
+
+isohybrid-bg2 ${ISOHYBRID_OPTIONS} ${IMAGE}
+EOF
+;;
+syslinux)
cat >> binary.sh << EOF
isohybrid ${ISOHYBRID_OPTIONS} ${IMAGE}
EOF
+;;
+esac
fi
diff --git a/scripts/build/lb_config b/scripts/build/lb_config
index ac6beb0..afd9dca 100755
--- a/scripts/build/lb_config
+++ b/scripts/build/lb_config
@@ -44,7 +44,7 @@ USAGE="${PROGRAM} [--apt apt|aptitude]\n\
\t [--binary-indices true|false|none]\n\
\t [--bootappend-install PARAMETER|\"PARAMETERS\"]\n\
\t [--bootappend-live PARAMETER|\"PARAMETERS\"]\n\
-\t [--bootloader grub|syslinux|yaboot]\n\
+\t [--bootloader grub|grub2|burg|syslinux|yaboot]\n\
\t [--bootstrap cdebootstrap|cdebootstrap-static|debootstrap|copy]\n\
\t [--bootstrap-config FILE]\n\
\t [-f|--bootstrap-flavour minimal|standard]\n\
diff --git a/templates/burg/burg.cfg b/templates/burg/burg.cfg
new file mode 100644
index 0000000..957e465
--- /dev/null
+++ b/templates/burg/burg.cfg
@@ -0,0 +1,7 @@
+set default=0
+
+LINUX_LIVE
+
+LINUX_INSTALL
+
+MEMTEST