X-Git-Url: http://git.grml.org/?a=blobdiff_plain;f=hooks%2Flive;h=40802d0ef1bb896e722a7b5f2b91f9782b3edb46;hb=3039c635545638a79f4f5e7705affb7997e5f918;hp=4e29226a9e01afd57c9507d3d0a4227e0b82d0ce;hpb=3cd34c818ca9695d0b5a8bab80c0ef08544acfbf;p=live-boot-grml.git diff --git a/hooks/live b/hooks/live index 4e29226..40802d0 100755 --- a/hooks/live +++ b/hooks/live @@ -1,6 +1,6 @@ #!/bin/sh -# initramfs hook for live-initramfs (Debian Live) +# initramfs hook for live-boot (Debian Live) set -e @@ -22,25 +22,47 @@ esac . /usr/share/initramfs-tools/hook-functions -# live-initramfs hook +[ "${QUIET}" ] || echo -n live-boot: -# Handling live-initramfs +# live-boot hook -# Configuration -if [ -r /etc/live.conf ] +# Reading configuration file from filesystem +if [ -e /etc/live/boot.conf ] then - . /etc/live.conf + . /etc/live/boot.conf +fi - mkdir -p "${DESTDIR}"/etc - cp /etc/live.conf "${DESTDIR}"/etc +if ls /etc/live/boot.d/*.conf > /dev/null 2>&1 +then + for _FILE in /etc/live/boot.d/*.conf + do + . ${_FILE} + done +fi + +# Handling live-boot + +if [ ! -e /usr/share/live-boot ] +then + echo "W: live-boot-initramfs-tools (backend) installed without live-boot," + echo "W: this initramfs will *NOT* have live support." + exit 0 +fi + +[ "${QUIET}" ] || echo -n " "core +# Configuration +if [ -e /usr/share/live-boot/languagelist ] +then + mkdir -p "${DESTDIR}"/usr/share/live-boot + cp /usr/share/live-boot/languagelist "${DESTDIR}"/usr/share/live-boot fi # Directories -mkdir -p "${DESTDIR}"/lib/live-initramfs +mkdir -p "${DESTDIR}"/lib/live-boot # Executables -copy_exec /usr/share/live-initramfs/live-reconfigure /bin -copy_exec /usr/share/live-initramfs/live-preseed /bin +copy_exec /usr/share/live-boot/live-reconfigure /bin +copy_exec /usr/share/live-boot/live-preseed /bin # Scripts cp /usr/share/initramfs-tools/scripts/live-functions "${DESTDIR}"/scripts @@ -49,14 +71,31 @@ cp /usr/share/initramfs-tools/scripts/live-helpers "${DESTDIR}"/scripts # klibc dependencies for FILE in /lib/libacl* /lib/libblkid* /lib/libuuid* /lib/libdevmapper* /lib/libattr* do - if [ ! -e "${DESTDIR}"/"${FILE}" ] + if [ ! -e "${DESTDIR}"/"${FILE}" ] && ls ${FILE} > /dev/null 2>&1 then cp -a "${FILE}" "${DESTDIR}"/"${FILE}" fi done +# udev dependencies (squeeze and newer) +for FILE in /lib/udev/*_id +do + if [ ! -e "${DESTDIR}/${FILE}" ] + then + mkdir -p "${DESTDIR}/lib/udev" + copy_exec "${FILE}" /lib/udev + fi +done + +if [ -e /lib/udev/rules.d/60-cdrom_id.rules ] +then + mkdir -p ${DESTDIR}/lib/udev/rules.d + cp -p /lib/udev/rules.d/60-cdrom_id.rules ${DESTDIR}/lib/udev/rules.d +fi + # Handling other stuff +[ "${QUIET}" ] || echo -n " "filesystems # Configuration: keymap (usefull when using encryption) if [ -x /bin/loadkeys ] && [ -r /etc/console/boottime.kmap.gz ] then @@ -73,6 +112,9 @@ then uuidgen -r > "${DESTDIR}"/conf/uuid.conf fi +# Filesystem: btrfs +manual_add_modules btrfs + # Filesystem: cifs if [ -x /sbin/mount.cifs ] then @@ -87,6 +129,11 @@ manual_add_modules ext4 # Filesystem: jffs2 manual_add_modules jffs2 +if [ -x /usr/bin/rsync ] +then + copy_exec /usr/bin/rsync /bin +fi + # Filesystem: squashfs copy_exec /sbin/losetup /sbin manual_add_modules loop @@ -94,10 +141,17 @@ manual_add_modules squashfs manual_add_modules sqlzma manual_add_modules unlzma -# Filesystem: aufs/unionfs +# Filesystem: aufs/overlayfs/unionfs manual_add_modules aufs +manual_add_modules overlayfs manual_add_modules unionfs +# Filesystem: unionfs-fuse +if [ -x /usr/bin/unionfs-fuse ] +then + copy_exec /usr/bin/unionfs-fuse /bin +fi + # Filesystem: vfat manual_add_modules nls_cp437 manual_add_modules nls_iso8859-1 @@ -107,6 +161,7 @@ manual_add_modules vfat # Filesystem: ntfs manual_add_modules ntfs +[ "${QUIET}" ] || echo -n " "devices # Hardware: cdrom manual_add_modules ide-cd manual_add_modules ide-generic @@ -126,9 +181,19 @@ then copy_exec /usr/bin/eject /bin fi +[ "${QUIET}" ] || echo -n " "utils # Program: md5sum copy_exec /usr/bin/md5sum /bin +# Program: memdisk +if [ -x /usr/bin/memdiskfind ] +then +[ "${QUIET}" ] || echo -n :memdisk + copy_exec /usr/bin/memdiskfind + manual_add_modules phram + manual_add_modules mtdblock +fi + # Program: cpio # busybox and klibc lacks --no-absolute-filenames and --sparse, needed for snapshots if [ -e "${DESTDIR}/bin/cpio" ] @@ -141,38 +206,78 @@ copy_exec /bin/cpio /bin # Program: udev if [ -x /sbin/udevadm ] then - # lenny + [ "${QUIET}" ] || echo -n " "udev copy_exec /sbin/udevadm /sbin -else - # etch - copy_exec /sbin/udevtrigger /sbin - copy_exec /sbin/udevsettle /sbin fi if [ -x /usr/bin/udevinfo ] then + [ "${QUIET}" ] || echo -n " "udev copy_exec /usr/bin/udevinfo /bin fi # Program: wget if [ -x /usr/bin/wget ] then + [ "${QUIET}" ] || echo -n " "wget copy_exec /usr/bin/wget /bin fi +# Program: blockdev +if [ -x /sbin/blockdev ] +then + [ "${QUIET}" ] || echo -n " "blockdev + copy_exec /sbin/blockdev /sbin +fi + # FUSE kernel module manual_add_modules fuse # FUSE filesystem: httpfs2 if [ -x /usr/bin/httpfs2_ssl ] then + [ "${QUIET}" ] || echo -n " "httpfs:ssl copy_exec /usr/bin/httpfs2_ssl /bin/httpfs elif [ -x /usr/bin/httpfs2 ] then + [ "${QUIET}" ] || echo -n " "httpfs copy_exec /usr/bin/httpfs2 /bin/httpfs fi # FUSE filesystem: curlftpfs if [ -x /usr/bin/curlftpfs ] then + [ "${QUIET}" ] || echo -n " "ftpfs copy_exec /usr/bin/curlftpfs /bin fi + +# iSCSI +if [ -x /usr/sbin/iscsistart ] +then + [ "${QUIET}" ] || echo -n " "iscsi + copy_exec /usr/sbin/iscsistart /bin + #manual_add_modules ib_iser + manual_add_modules iscsi_tcp + manual_add_modules crc32c +fi + +if [ "${LIVE_DNS}" = "true" ] +then + [ "${QUIET}" ] || echo -n " "dns + #copy_exec /lib/libnss_files.so.* /lib # /etc/hosts and /etc/passwd + copy_exec /lib/libnss_dns.so.* /lib # DNS server + #copy_exec /lib/libnss_compat.so.* /lib # /etc/passwd + + # Configuration file - may be needed if /etc/hosts is used. + #mkdir -p $DESTDIR/etc + #cp -p /etc/nsswitch.conf $DESTDIR/etc +fi + +if [ "${LIVE_UNIONMOUNT}" = "true" ] +then + [ "${QUIET}" ] || echo -n " "unionmount + # UnionMount + # only mount from patched util-linux can do this currently + copy_exec /bin/mount /bin/mount_full +fi + +[ "${QUIET}" ] || echo .