6 echo -ne "\033[0G\033[0K"
12 echo ${module} >> /etc/modules/extra_load
15 modules_scan extra_load
20 [ -d "/etc/modules/${1}" ] || touch /etc/modules/${1}
22 [ -f "/etc/modules/${1}" ] && MODS=`cat /etc/modules/${1}`
25 MLOAD=`echo ${MLIST} | sed -e "s/.*${x}.*/${x}/"`
26 if [ "${MLOAD}" = "${x}" ] # Only module to no-load
28 echo -e "${BOLD} ::${NORMAL} Skipping ${x}..."
29 elif [ "${MLOAD}" = "${MLIST}" ] # == No change == No specified no-load
31 [ -n "${DEBUG}" ] && echo -ne "${BOLD} ::${NORMAL} Checking for ${x}..."
32 # find -name does not work since the return status is always zero
33 if find /lib/modules/${KV} | grep /"${x}${KSUFF}" >/dev/null 2>&1
35 echo -ne "${BOLD} ::${NORMAL} Scanning for ${x}..."
41 echo -e "${BOLD} ::${NORMAL} Skipping ${x}..."
48 echo $1 | tr 'a-z' 'A-Z'
53 # $1 = mount dir name / media name
54 # $2 = recognition file
55 # $3 = variable to have the device path
56 # $4 = actual mount dir path (full path)
57 # args remaining are possible devices
59 local media=$1 recon=$2 vrbl=$3 mntdir=$4
62 good_msg "Looking for the ${media}" ${CRYPT_SILENT}
66 [ ! -d "${mntdir}" ] && mkdir -p ${mntdir} 2>/dev/null >/dev/null
67 if [ -n "${ISOBOOT}" ]
69 mntcddir="${mntdir%${media}}iso"
70 if [ ! -f ${mntcddir} ]
80 # Check for a block device to mount
86 # If disk and it has at least one partition, skip.
87 # We use /sys/block/${bsn}/${bsn}[0-9]* to make sure that we
88 # don't skip device mapper devices. Even the craziest scenario
89 # deserves a fair chance.
91 for part in `ls /sys/block/${bsn}/${bsn}*[0-9]* 2>/dev/null`
100 good_msg "Attempting to mount media:- ${x}" ${CRYPT_SILENT}
102 mount -r -t ${CDROOT_TYPE} ${x} ${mntcddir} >/dev/null 2>&1
105 if [ -n "${ISOBOOT}" ]; then
106 if [ -f ${mntcddir}/${ISOBOOT} ]; then
107 mount -o loop ${mntcddir}/${ISOBOOT} ${mntdir}
108 if [ "$?" = "0" ]; then
109 good_msg "iso mounted on ${mntdir}"
114 # Check for the media
115 if [ -f "${mntdir}/${recon}" ]
117 #set REAL_ROOT, CRYPT_ROOT_KEYDEV or whatever ${vrbl} is
118 eval ${vrbl}'='"${x}"
119 good_msg "Media found on ${x}" ${CRYPT_SILENT}
129 eval local result='$'${vrbl}
131 [ -n "${result}" ] || bad_msg "Media not found" ${CRYPT_SILENT}
135 # Locate the cdrom device with our media on it.
137 local DEVICES="/dev/cdroms/* /dev/ide/cd/* /dev/sr*"
138 # USB Keychain/Storage
139 DEVICES="$DEVICES /dev/sd*"
141 DEVICES="$DEVICES /dev/hd*"
143 DEVICES="$DEVICES /dev/vd*"
144 # USB using the USB Block Driver
145 DEVICES="$DEVICES /dev/ubd* /dev/ubd/*"
147 DEVICES="$DEVICES /dev/iseries/vcd*"
148 # builtin mmc/sd card reader devices
149 DEVICES="$DEVICES /dev/mmcblk* /dev/mmcblk*/*"
150 # fallback scanning, this might scan something twice, but it's better than
152 [ -e /proc/partitions ] && DEVICES="${DEVICES} $(awk -r '/([0-9]+[[:space:]]+)/{print "/dev/" $4}' /proc/partitions)"
157 local DEVICES=`devicelist`
158 # The device was specified on the command line, so there's no need to scan
159 # a bunch of extra devices
160 [ -n "${CDROOT_DEV}" ] && DEVICES="${CDROOT_DEV}"
162 findmediamount "cdrom" "${SUBDIR}/livecd" "REAL_ROOT" "${CDROOT_PATH}" ${DEVICES}
167 local KEYDEVS=`devicelist`
168 eval local keyloc='"${CRYPT_'${1}'_KEY}"'
170 findmediamount "key" "${keyloc}" "CRYPT_${1}_KEYDEV" "/mnt/key" ${KEYDEVS}
173 cache_cd_contents() {
174 # Check loop file exists and cache to ramdisk if DO_cache is enabled
175 if [ "${LOOPTYPE}" != "noloop" ] && [ "${LOOPTYPE}" != "sgimips" ]
180 # TODO: Check the size of the image versus the size of our tmpfs
181 # along with the amount of available RAM and increase tmpfs size
182 # if necessary. (Not having awk sucks...)
184 # for i in $(cat /proc/meminfo | grep -e ^MemFree -e ^Cached | \
185 # cut -d: -f2 | cut -dk -f1 | sed -e "s/^\s*//") ; do
186 # z=$(($z + $i)) ; done
188 good_msg "Copying loop file for caching..."
189 # Verify that the needed directory exists
190 mkdir -p "$(dirname ${NEW_ROOT}/mnt/${LOOP})"
191 cp -a ${CDROOT_PATH}/${LOOP} ${NEW_ROOT}/mnt/${LOOP}
194 bad_msg "Failed to cache the loop file! Lack of space?"
195 rm -rf ${NEW_ROOT}/mnt/livecd.* 2>/dev/null
196 rm -rf ${NEW_ROOT}/mnt/image.* 2>/dev/null
197 rm -rf ${NEW_ROOT}/mnt/zisofs 2>/dev/null
206 mount -t sysfs sysfs /sys -o noexec,nosuid,nodev >/dev/null 2>&1
208 [ ${ret} -eq 0 ] || bad_msg "Failed to mount /sys!"
212 if [ "${IP}" != '' ] || busybox udhcpc -n -T 15 -q
214 [ -e /rootpath ] && NFSROOT=`cat /rootpath`
216 if [ "${NFSROOT}" = '' ]
219 OPTIONS=`busybox dmesg | grep rootserver | sed -e "s/,/ /g"`
220 for OPTION in $OPTIONS
222 if [ `echo $OPTION | sed -e "s/=/ /g" | cut -d " " -f 1` = 'rootserver' ]
224 NFSIP=`echo $OPTION | sed -e "s/=/ /g" | cut -d " " -f 2`
229 OPTIONS=`busybox dmesg | grep rootpath | sed -e "s/,/ /g"`
230 for OPTION in $OPTIONS
232 if [ `echo $OPTION | sed -e "s/=/ /g" | cut -d " " -f 1` = 'rootpath' ]
234 NFSPATH=`echo $OPTION | sed -e "s/=/ /g" | cut -d " " -f 2`
239 if [ "${NFSIP}" != '' ] && [ "$NFSPATH" != '' ]
241 NFSROOT="${NFSIP}:${NFSPATH}"
243 bad_msg "The DHCP Server did not send a valid root-path."
244 bad_msg "Please check your DHCP setup, or provide a nfsroot=<...> parameter."
248 if [ "${NFSROOT}" != '' ]
250 NFSOPTIONS=${NFSROOT#*,}
251 NFSROOT=${NFSROOT%%,*}
252 if [ "${NFSOPTIONS}" = "${NFSROOT}" ]
254 NFSOPTIONS=$DEFAULT_NFSOPTIONS
256 NFSOPTIONS="${DEFAULT_NFSOPTIONS},${NFSOPTIONS}"
259 if [ "${CDROOT}" != '0' ]
261 good_msg "Attempting to mount NFS CD image on ${NFSROOT} with options ${NFSOPTIONS}"
262 mount -t nfs -o ${NFSOPTIONS} ${NFSROOT} ${CDROOT_PATH}
267 bad_msg "NFS Mounting failed. Is the path corrent ?"
270 good_msg "Attempting to mount NFS root on ${NFSROOT} with options ${NFSOPTIONS}"
271 mount -t nfs -o ${NFSOPTIONS} ${NFSROOT} ${NEW_ROOT}
276 bad_msg "NFS Mounting failed. Is the path correct ?"
278 # FIXME: Need to start portmap and the other rpc daemons in
279 # order to remount rw.
287 if [ "${LOOP}" = '' -o ! -e "${CDROOT_PATH}/${LOOP}" ]
290 bad_msg "Invalid loop location: ${LOOP}"
291 bad_msg 'Please export LOOP with a valid location, or reboot and pass a proper loop=...'
292 bad_msg 'kernel command line!'
303 # Use devtmpfs if enabled in kernel,
304 # else tmpfs. Always run mdev just in case
306 if grep -qs devtmpfs /proc/filesystems ; then
310 # Options copied from /etc/init.d/udev-mount, should probably be kept in sync
311 mount -t $devfs -o "exec,nosuid,mode=0755,size=10M" udev /dev \
312 || bad_msg "Failed to mount /dev as ${devfs}"
314 # http://git.busybox.net/busybox/plain/docs/mdev.txt
315 mkdir -m 0755 /dev/pts
316 mount -t devpts -o gid=5,mode=0620 devpts /dev/pts || bad_msg "Failed to mount /dev/pts"
317 mdev -s || bad_msg "Failed to receive dynamic updates from mdev"
322 # If last command failed send error message and fall back to a shell
323 if [ "$retcode" != '0' ]
326 error_string="${error_string:-run command}"
327 bad_msg 'Failed to $1; failing back to the shell...'
333 # msg functions arguments
339 msg_string="${msg_string:-...}"
340 [ "$2" != 1 ] && echo -e "${GOOD}>>${NORMAL}${BOLD} ${msg_string} ${NORMAL}"
345 msg_string="${msg_string:-...}"
348 splash 'verbose' > /dev/null &
349 echo -e "${BAD}!!${NORMAL}${BOLD} ${msg_string} ${NORMAL}"
355 msg_string="${msg_string:-...}"
356 [ "$2" != 1 ] && echo -e "${WARN}**${NORMAL}${BOLD} ${msg_string} ${NORMAL}"
360 if [ "${CRYPT_SILENT}" = '1' ]
362 eval $1 >/dev/null 2>/dev/null
364 splash 'verbose' > /dev/null &
369 splash set_msg 'Disk unlocked.'
376 # $1 = variable whose value is the path (examples: "REAL_ROOT",
379 # $3 = optional explanations for failure
381 eval local oldvalue='$'${1}
383 [ \( $# != 2 \) -a \( $# != 3 \) ] && \
384 bad_msg "Bad invocation of function prompt_user, please file a bug \
385 report with this message" && exit 1
386 [ -n "${3}" ] && local explnt=" or : ${3}" || local explnt="."
388 bad_msg "Could not find the ${2} in ${oldvalue}${explnt}"
389 echo ' Please specify another value or: press Enter for the same, type "shell" for a shell, or "q" to skip...'
390 echo -n "${2}(${oldvalue}) :: "
392 case `eval echo '$'${1}` in
394 eval ${1}'='${oldvalue}
395 warn_msg "Skipping step, this will likely cause a boot failure."
399 eval ${1}'='${oldvalue}
400 echo "To leave and try again just press <Ctrl>+D"
404 eval ${1}'='${oldvalue}
410 if [ "${KV_2_6_OR_GREATER}" ]
412 echo /sbin/mdev > /proc/sys/kernel/hotplug
417 # This function removes unset DO_slowusb if there is no usb-storage attached.
418 # If noslowusb is set, skip this function
419 [ "${DO_slowusb}" ] || return
421 # Unset DO_slowusb, so we can set it again if usb-storage has something attached
424 local usb_storage_dir="/sys/bus/usb/drivers/usb-storage"
425 if [ ! -d "${usb_storage_dir}" ]
427 # no automated slowusb required. no usb-storage devices attached.
430 for x in "${usb_storage_dir}"/*
432 [ -d "${x}" ] && [ "${x}" != "${usb_storage_dir}/module" ] \
433 && { DO_slowusb="1" ; break ; }
438 if [ "${KV_2_6_OR_GREATER}" ]
441 good_msg 'Activating mdev'
448 # Scan CMDLINE for any "doscsi" or "noscsi"-type arguments
456 if [ "${y}" = "do${x}" ]
458 MY_HWOPTS="${MY_HWOPTS} $x"
459 elif [ "${y}" = "no${x}" ]
461 MY_HWOPTS="`echo ${MY_HWOPTS} | sed -e \"s/${x}//g\" -`"
463 if [ "$(echo ${y} | cut -b -7)" = "keymap=" ]
465 MY_HWOPTS="${MY_HWOPTS} keymap"
470 # Shouldnt need to sort this as the following loop should figure out the
471 # duplicates and strip them out
472 #MY_HWOPTS=`echo ${MY_HWOPTS}| sort`
474 for x in ${MY_HWOPTS}
477 for y in ${TMP_HWOPTS}
479 if [ "${y}" = "${x}" ]
484 TMP_HWOPTS="${TMP_HWOPTS} ${x}"
485 eval DO_`echo ${x} | sed 's/-//'`=1
488 MY_HWOPTS=${TMP_HWOPTS}
492 # Load modules listed in MY_HWOPTS if /lib/modules exists for the running
494 if [ -d "/lib/modules/${KV}" ]
496 good_msg 'Loading modules'
497 # Load appropriate kernel modules
498 for modules in $MY_HWOPTS
500 modules_scan $modules
503 good_msg 'Skipping module load; no modules in the ramdisk!'
508 if [ "${DO_keymap}" ]
510 if [ ! -e /dev/vc/0 -a ! -e /dev/tty0 ]
513 mount -o bind ${NEW_ROOT}/dev /dev
515 [ ! -e /dev/tty0 ] && ln -s /dev/tty1 /dev/tty0
517 [ -f /lib/keymaps/keymapList ] && chooseKeymap
519 [ "${DEVBIND}" = '1' ] && umount /dev
521 if [ -e /etc/sysconfig/keyboard -a "${CDROOT}" = '1' ]
523 mkdir -p ${NEW_ROOT}/etc/sysconfig/
524 cp /etc/sysconfig/keyboard ${NEW_ROOT}/etc/sysconfig/keyboard
530 good_msg "Loading keymaps"
531 if [ -z "${keymap}" ]
533 splash 'verbose' > /dev/null &
534 cat /lib/keymaps/keymapList
535 read -t 10 -p '<< Load keymap (Enter for default): ' keymap
537 1|azerty) keymap=azerty ;;
540 4|br-a) keymap=br-a ;;
541 5|br-l) keymap=br-l ;;
544 8|croat) keymap=croat ;;
548 12|dvorak) keymap=dvorak ;;
570 34|sk-y) keymap=sk-y ;;
571 35|sk-z) keymap=sk-z ;;
572 36|slovene) keymap=slovene ;;
573 37|trf) keymap=trf ;;
574 38|trq) keymap=trq ;;
578 42|wangbe) keymap=wangbe ;;
581 if [ -e /lib/keymaps/${keymap}.map ]
583 good_msg "Loading the ''${keymap}'' keymap"
584 loadkmap < /lib/keymaps/${keymap}.map
586 # echo ${keymap} | egrep -e "[0-9]+" >/dev/null 2>&1
589 # xkeymap=`tail -n 7 /lib/keymaps/keymapList | grep ${keymap} | sed -r "s/.*\s+${keymap}\s+([a-z-]+).*/\1/g" | egrep -v 1`
591 mkdir -p /etc/sysconfig
592 # echo "XKEYBOARD=${xkeymap}" > /etc/sysconfig/keyboard
593 echo "XKEYBOARD=${keymap}" > /etc/sysconfig/keyboard
594 splash set_msg "Set keymap to ${keymap}"
595 elif [ -z "${keymap}" ]
598 good_msg "Keeping default keymap"
599 splash set_msg "Keeping default keymap"
601 bad_msg "Sorry, but keymap ''${keymap}'' is invalid!"
608 #good_msg 'Checking if volumes need to be started...'
610 # Here, we check for /dev/device-mapper, and if it exists, we setup a
611 # a symlink, which should hopefully fix bug #142775 and bug #147015
612 if [ -e /dev/device-mapper ] && [ ! -e /dev/mapper/control ]
615 ln -sf /dev/device-mapper /dev/mapper/control
618 if [ "${USE_MDADM}" = '1' ]
620 /sbin/mdadm --assemble --scan
623 if [ "${USE_DMRAID_NORMAL}" = '1' ]
625 if [ -e '/sbin/dmraid' ]
627 good_msg "Activating Device-Mapper RAID(s)"
628 if [ '${DMRAID_OPTS}' = '' ]
632 /sbin/dmraid -ay ${DMRAID_OPTS}
637 if [ "${USE_LVM_NORMAL}" = '1' ]
641 for dev in ${RAID_DEVICES}
643 setup_md_device "${dev}"
646 # This is needed for /bin/lvm to accept the following logic
647 lvm_commands="#! /bin/lvm"
649 # If there is a cahe, update it. Unbreak at least dmcrypt
650 [ -d /etc/lvm/cache ] && lvm_commands="${lvm_commands} \nvgscan"
652 # To activate volumegroups on all devices in the cache
653 lvm_commands="${lvm_commands} \nvgchange -ay --sysinit"
655 # To create symlinks so users can use real_root=/dev/vg/root
656 # This needs to run after vgchange, using vgchange --mknodes is too
658 lvm_commands="${lvm_commands} \nvgmknodes --ignorelockingfailure"
660 # And finally execute it all (/proc/... needed if lvm is compiled without readline)
661 good_msg "Scanning for and activating Volume Groups"
662 printf "%b\n" "${lvm_commands}" | /bin/lvm /proc/self/fd/0
664 bad_msg "vgscan or vgchange not found: skipping LVM volume group activation!"
668 if [ "${USE_ZFS}" = '1' ]
670 /sbin/zpool import -N -a ${ZPOOL_FORCE}
676 if [ ! -n "${ISCSI_NOIBFT}" ]
678 good_msg "Activating iSCSI via iBFT"
682 if [ -n "${ISCSI_INITIATORNAME}" ] && [ -n "${ISCSI_TARGET}" ] && [ -n "${ISCSI_ADDRESS}" ]
684 good_msg "Activating iSCSI via cmdline"
686 if [ "${ISCSI_TGPT}" ]
688 ADDITIONAL="${ADDITIONAL} -g ${ISCSI_TGPT}"
690 ADDITIONAL="${ADDITIONAL} -g 1"
693 if [ "${ISCSI_PORT}" ]
695 ADDITIONAL="${ADDITIONAL} -p ${ISCSI_PORT}"
698 if [ "${ISCSI_USERNAME}" ]
700 ADDITIONAL="${ADDITIONAL} -u ${ISCSI_USERNAME}"
703 if [ "${ISCSI_PASSWORD}" ]
705 ADDITIONAL="${ADDITIONAL} -w ${ISCSI_PASSWORD}"
708 if [ "${ISCSI_USERNAME_IN}" ]
710 ADDITIONAL="${ADDITIONAL} -U ${ISCSI_USERNAME_IN}"
713 if [ "${ISCSI_PASSWORD_IN}" ]
715 ADDITIONAL="${ADDITIONAL} -W ${ISCSI_PASSWORD_IN}"
718 if [ "${ISCSI_DEBUG}" ]
720 ADDITIONAL="${ADDITIONAL} -d ${ISCSI_DEBUG}"
723 iscsistart -i "${ISCSI_INITIATORNAME}" -t "${ISCSI_TARGET}" -a "${ISCSI_ADDRESS}" ${ADDITIONAL}
725 # let iscsid settle - otherwise mounting the iSCSI-disk will fail (very rarely, though)
732 # It is either the root or a swap, other devices are supported in the scripts provided with sys-fs/cryptsetup-luks
735 # please use 'tr' and this line, or remove it
736 # eval local TYPE=`uppercase $1`
747 eval local LUKS_DEVICE='"${CRYPT_'${TYPE}'}"' LUKS_NAME="$1" LUKS_KEY='"${CRYPT_'${TYPE}'_KEY}"' LUKS_KEYDEV='"${CRYPT_'${TYPE}'_KEYDEV}"' LUKS_TRIM='"${CRYPT_'${TYPE}'_TRIM}"'
748 local DEV_ERROR=0 KEY_ERROR=0 KEYDEV_ERROR=0
749 local mntkey="/mnt/key/" cryptsetup_options=''
751 [ ! -e /sbin/cryptsetup ] && bad_msg "The ramdisk does not support LUKS" && exit 1
755 # if crypt_silent=1 and some error occurs, enter shell quietly
756 if [ \( ${CRYPT_SILENT} -eq 1 \) -a \( \( \( ${DEV_ERROR} -eq 1 \) -o \( ${KEY_ERROR} -eq 1 \) \) -o \( ${KEYDEV_ERROR} -eq 1 \) \) ]
759 elif [ ${DEV_ERROR} -eq 1 ]
761 prompt_user "LUKS_DEVICE" "${LUKS_NAME}"
763 elif [ ${KEY_ERROR} -eq 1 ]
765 prompt_user "LUKS_KEY" "${LUKS_NAME} key"
767 elif [ ${KEYDEV_ERROR} -eq 1 ]
769 prompt_user "LUKS_KEYDEV" "${LUKS_NAME} key device"
772 case "${LUKS_DEVICE}" in
777 if [ "${retval}" -ne 0 ]; then
778 REAL_LUKS=`findfs "${LUKS_DEVICE}" 2>/dev/null`
782 if [ "$retval" -ne 0 ]; then
783 REAL_LUKS=`busybox findfs "${LUKS_DEVICE}" 2>/dev/null`
787 if [ "${retval}" -ne 0 ]; then
788 REAL_LUKS=`blkid -l -t "${LUKS_DEVICE}" | cut -d ":" -f 1 2>/dev/null`
792 if [ "${retval}" -eq 0 ] && [ -n "${REAL_LUKS}" ]; then
793 good_msg "Detected device ${REAL_LUKS}"
794 LUKS_DEVICE="${REAL_LUKS}"
799 setup_md_device ${LUKS_DEVICE}
800 cryptsetup isLuks ${LUKS_DEVICE}
803 bad_msg "The LUKS device ${LUKS_DEVICE} does not contain a LUKS header" ${CRYPT_SILENT}
808 if [ "x${LUKS_TRIM}" = "xyes" ]
810 good_msg "Enabling TRIM support for ${LUKS_NAME}." ${CRYPT_SILENT}
811 cryptsetup_options="${cryptsetup_options} --allow-discards"
814 if [ -n "${LUKS_KEY}" ]
816 if [ ! -e "${mntkey}${LUKS_KEY}" ]
818 if [ -b "${LUKS_KEYDEV}" ]
819 then good_msg "Using key device ${LUKS_KEYDEV}." ${CRYPT_SILENT}
821 good_msg "Please insert removable device ${LUKS_KEYDEV} for ${LUKS_NAME}" ${CRYPT_SILENT}
822 # abort after 10 secs
824 while [ ${count} -gt 0 ]
828 if [ -b "${LUKS_KEYDEV}" ]
830 good_msg "Removable device ${LUKS_KEYDEV} detected." ${CRYPT_SILENT}
834 if [ ! -b "${LUKS_KEYDEV}" ]
836 eval CRYPT_${TYPE}_KEY=${LUKS_KEY}
838 eval LUKS_KEYDEV='"${CRYPT_'${TYPE}'_KEYDEV}"'
839 if [ ! -b "${LUKS_KEYDEV}" ]; then
841 bad_msg "Removable device ${LUKS_KEYDEV} not found." ${CRYPT_SILENT}
844 # continue otherwise will mount keydev which is mounted by bootstrap
848 # At this point a device was recognized, now let's see if the key is there
849 [ ! -d "$mntkey" ] && mkdir -p ${mntkey} 2>/dev/null >/dev/null
851 mount -n -o ro ${LUKS_KEYDEV} ${mntkey} >/dev/null 2>/dev/null
855 bad_msg "Mounting of device ${LUKS_KEYDEV} failed." ${CRYPT_SILENT}
858 good_msg "Removable device ${LUKS_KEYDEV} mounted." ${CRYPT_SILENT}
861 if [ ! -e "${mntkey}${LUKS_KEY}" ]; then
862 umount -n ${mntkey} 2>/dev/null >/dev/null
865 bad_msg "Key {LUKS_KEY} on device ${LUKS_KEYDEV} not found." ${CRYPT_SILENT}
870 # At this point a candidate key exists (either mounted before or not)
871 good_msg "${LUKS_KEY} on device ${LUKS_KEYDEV} found" ${CRYPT_SILENT}
872 if [ "$(echo ${LUKS_KEY} | grep -o '.gpg$')" = ".gpg" ] && [ -e /sbin/gpg ] ; then
873 [ -e /dev/tty ] && mv /dev/tty /dev/tty.org
875 cryptsetup_options="-d -"
876 gpg_cmd="/sbin/gpg --logger-file /dev/null --quiet --decrypt ${mntkey}${LUKS_KEY} |"
878 cryptsetup_options="-d ${mntkey}${LUKS_KEY}"
881 # At this point, keyfile or not, we're ready!
882 crypt_filter "${gpg_cmd}cryptsetup ${cryptsetup_options} luksOpen ${LUKS_DEVICE} ${LUKS_NAME}"
885 good_msg "LUKS device ${LUKS_DEVICE} opened" ${CRYPT_SILENT}
888 bad_msg "Failed to open LUKS device ${LUKS_DEVICE}" ${CRYPT_SILENT}
896 umount ${mntkey} 2>/dev/null >/dev/null
897 rmdir -p ${mntkey} 2>/dev/null >/dev/null
902 # if key is set but key device isn't, find it
904 [ -n "${CRYPT_ROOT_KEY}" ] && [ -z "${CRYPT_ROOT_KEYDEV}" ] \
905 && sleep 6 && bootstrapKey "ROOT"
907 if [ -n "${CRYPT_ROOT}" ]; then
909 if [ -n "${REAL_ROOT}" ]
914 REAL_ROOT="/dev/mapper/root"
918 # same for swap, but no need to sleep if root was unencrypted
919 [ -n "${CRYPT_SWAP_KEY}" ] && [ -z "${CRYPT_SWAP_KEYDEV}" ] \
920 && { [ -z "${CRYPT_ROOT}" ] && sleep 6; bootstrapKey "SWAP"; }
922 if [ -n "${CRYPT_SWAP}" ]; then
924 if [ -z "${REAL_RESUME}" ]
926 # Resume from swap as default
927 REAL_RESUME="/dev/mapper/swap"
933 # Sleep a specific number of seconds if SDELAY is set
936 good_msg "Waiting ${SDELAY} seconds..."
938 elif [ "${CDROOT}" = '1' ]
940 # many CD/DVD drives require extra sleep, especially when
941 # connected via USB. Many people reported that 1 second sleep
942 # is not enough on their notebooks, that's why sleep 3, when booting
943 # off a livecd is a better default.
946 good_msg 'Hint: Use parameter scandelay[=seconds] if you need waiting here'
951 # if QUIET is set make the kernel less chatty
952 [ -n "$QUIET" ] && echo '0' > /proc/sys/kernel/printk
956 # if QUIET is set make the kernel less chatty
957 [ -n "$QUIET" ] && echo '6' > /proc/sys/kernel/printk
962 if [ "${CDROOT}" = '1' ]
964 if [ -x /${CDROOT_PATH}/cdupdate.sh ]
966 good_msg "Running cdupdate.sh"
967 ${CDROOT_PATH}/cdupdate.sh
970 bad_msg "Executing cdupdate.sh failed!"
974 good_msg 'No cdupdate.sh script found, skipping...'
980 # start BTRFS volume detection, if available
981 [ -x /sbin/btrfsctl ] && /sbin/btrfsctl -a
987 [ -z "$1" ] && device="${REAL_ROOT}" || device="$1"
988 [ -z "${device}" ] && return # LiveCD
990 if [ `echo ${device}|sed -e 's#\(luks:\)\?\(/dev/md\)[[:digit:]]\+#\2#'` = "/dev/md" ]
992 good_msg 'Detected real_root as a md device. Setting up the device node...'
993 MD_NUMBER=`echo ${device}|sed -e 's#\(luks:\)\?/dev/md\([[:digit:]]\+\)#\2#'`
994 if [ ! -e /dev/md${MD_NUMBER} ]
996 mknod /dev/md${MD_NUMBER} b 9 ${MD_NUMBER} >/dev/null 2>&1
997 [ $? -ne 0 ] && bad_msg "Creation of /dev/md${MD_NUMBER} failed..."
999 mdstart ${MDPART} /dev/md${MD_NUMBER}
1006 good_msg 'Starting debug shell as requested by "debug" option.'
1007 good_msg 'Type "exit" to continue with normal bootup.'
1008 [ -x /bin/sh ] && /bin/sh || /bin/ash
1013 if [ -d /proc/suspend2 -o -d /sys/power/suspend2 -o -d /sys/power/tuxonice ]; then
1021 # determine swap resume partition
1022 local device=$(ls -lL "${REAL_RESUME}" | sed 's/\ */ /g' | cut -d \ -f 5-6 | sed 's/,\ */:/')
1023 [ -f /sys/power/resume ] && echo "${device}" > /sys/power/resume
1028 if grep "splash=" /proc/cmdline > /dev/null 2>&1; then
1029 splash_theme=$(cat /proc/cmdline | sed 's/.*splash=/splash=/' | sed 's/ .*//' | sed 's/.*theme://' | sed 's/,.*//')
1032 local tuxonice_userui_program="/sys/power/tuxonice/user_interface/program"
1033 local tuxonice_do_resume="/sys/power/tuxonice/do_resume"
1034 local tuxonice_resumedev="/sys/power/tuxonice/resume"
1035 local tuxonice_replace_swsusp="/sys/power/tuxonice/replace_swsusp"
1038 # Backward compatibility
1040 if [ -e /sys/power/suspend2 ]; then
1041 tuxonice_userui_program="/sys/power/suspend2/user_interface/program"
1042 tuxonice_do_resume="/sys/power/suspend2/do_resume"
1043 tuxonice_resumedev="/sys/power/suspend2/resume"
1044 tuxonice_replace_swsusp="/sys/power/suspend2/replace_swsusp"
1045 elif [ -e /proc/suspend2 ]; then
1046 tuxonice_userui_program="/proc/suspend2/userui_program"
1047 tuxonice_do_resume="/proc/suspend2/do_resume"
1048 tuxonice_resumedev="/proc/suspend2/resume"
1049 tuxonice_replace_swsusp="/proc/suspend2/replace_swsusp"
1052 # if 'use_swsusp' is given, use swsusp instead
1053 if grep "use_swsusp" /proc/cmdline > /dev/null 2>&1; then
1054 echo 0 > ${tuxonice_replace_swsusp}
1059 modules_scan tuxonice
1061 # we both configure tuxonice and activate resuming,
1062 # however the kernel will resume only if an image is found
1064 if ! grep suspend_noui /proc/cmdline > /dev/null 2>&1; then
1065 which suspend2ui_text > /dev/null 2>&1 && which suspend2ui_text > "${tuxonice_userui_program}"
1066 which tuxoniceui_text > /dev/null 2>&1 && which tuxoniceui_text > "${tuxonice_userui_program}"
1068 if [ -n "${splash_theme}" ]; then
1069 ln -s /etc/splash/${splash_theme} /etc/splash/suspend2
1070 ln -s /etc/splash/${splash_theme} /etc/splash/tuxonice
1072 which suspend2ui_fbsplash > /dev/null 2>&1 && which suspend2ui_fbsplash > "${tuxonice_userui_program}"
1073 which tuxoniceui_fbsplash > /dev/null 2>&1 && which tuxoniceui_fbsplash > "${tuxonice_userui_program}"
1077 echo "${REAL_RESUME}" > "${tuxonice_resumedev}"
1078 echo > "${tuxonice_do_resume}"
1082 for loop in ${LOOPS}
1084 if [ -e "${CDROOT_PATH}""${loop}" ]
1092 LOOPTYPE="${LOOP##*.}"
1093 [ "${LOOPTYPE}" == "loop" ] && LOOPTYPE="normal"
1094 [ "${LOOP}" == "/zisofs" ] && LOOPTYPE="${LOOP#/}"
1095 [ -z "${LOOPTYPE}" ] && LOOPTYPE="noloop"
1099 echo $(( $(hexdump -n 4 -s $((316 + 12 * $2)) -e '"%i"' $1) * 512))
1102 setup_squashfs_aufs() {
1104 # Setup aufs directories and vars
1105 local overlay=/mnt/overlay
1106 local static=/mnt/livecd
1108 for i in "${overlay}" "${static}"; do
1109 [ ! -d "${i}" ] && mkdir -p "${i}"
1111 good_msg "Loading aufs"
1112 modprobe aufs > /dev/null 2>&1
1114 mount -t squashfs -o loop,ro "${CDROOT_PATH}/${LOOPEXT}${LOOP}" "${static}"
1115 mount -t tmpfs none "${overlay}"
1116 mount -t aufs -o br:${overlay}:${static} aufs "${NEW_ROOT}"
1118 [ ! -d "${NEW_ROOT}${overlay}" ] && mkdir -p "${NEW_ROOT}${overlay}"
1119 [ ! -d "${NEW_ROOT}${static}" ] && mkdir -p "${NEW_ROOT}${static}"
1120 echo "aufs / aufs defaults 0 0" > "${NEW_ROOT}"/etc/fstab
1121 for i in "${overlay}" "${static}"; do mount --move "${i}" "${NEW_ROOT}${i}"; done
1123 # have handy /mnt/cdrom (CDROOT_PATH) as well
1124 local new_cdroot="${NEW_ROOT}${CDROOT_PATH}"
1125 [ ! -d "${new_cdroot}" ] && mkdir -p "${new_cdroot}"
1126 mount --bind "${CDROOT_PATH}" "${new_cdroot}"
1133 if [ "${USE_UNIONFS_NORMAL}" = '1' ]
1135 # Directory used for rw changes in union mount filesystem
1140 # CHANGES=$MEMORY/unionfs_changes/default
1142 # CHANGES=$MEMORY/unionfs_changes/$UID
1145 # mkdir -p ${MEMORY}
1147 good_msg "Loading fuse module"
1148 modprobe fuse > /dev/null 2>&1
1149 # if [ -n "${UNIONFS}" ]
1151 # CHANGESDEV=${UNIONFS}
1152 # good_msg "mounting $CHANGESDEV to $MEMORY for unionfs support"
1153 # mount -t auto $CHANGESDEV $MEMORY
1154 # # mount tmpfs only in the case when changes= boot parameter was
1155 # # empty or we were not able to mount the storage device
1157 # if [ ${ret} -ne 0 ]
1159 # bad_msg "mount of $CHANGESDEV failed falling back to ramdisk based unionfs"
1160 # mount -t tmpfs tmpfs $MEMORY
1162 # if [ "${CDROOT}" -eq '1' -a ! -f ${MEMORY}/livecd.unionfs ]
1165 # bad_msg "failed to find livecd.unionfs file on $CHANGESDEV"
1166 # bad_msg "create a livecd.unionfs file on this device if you wish to use it for unionfs"
1167 # bad_msg "falling back to ramdisk based unionfs for safety"
1168 # mount -t tmpfs tmpfs $MEMORY
1171 # good_msg "Mounting ramdisk to $MEMORY for unionfs support..."
1172 # mount -t tmpfs tmpfs $MEMORY
1178 # mount -t unionfs -o dirs=$CHANGES=rw unionfs ${UNION}
1179 good_msg "Creating union mount"
1180 unionfs -o allow_other,cow,noinitgroups,suid,dev,default_permissions,use_ino ${rw_dir}=RW:${ro_dir}=RO ${UNION} 2>/dev/null
1184 bad_msg "Can't setup union mount!"
1185 USE_UNIONFS_NORMAL=0
1187 [ ! -d "${NEW_ROOT}${CDROOT_PATH}" ] && mkdir -p "${NEW_ROOT}${CDROOT_PATH}"
1188 mount --bind "${CDROOT_PATH}" "${NEW_ROOT}${CDROOT_PATH}"
1190 USE_UNIONFS_NORMAL=0
1197 /^[[:blank:]]*#/ { next }
1199 ' ${NEW_ROOT}/etc/initramfs.mounts
1205 /^[[:blank:]]*#/ { next }
1206 $2 == fs { print $3 }
1207 ' ${NEW_ROOT}/etc/fstab
1213 /^[[:blank:]]*#/ { next }
1214 $2 == fs { print $1 }
1215 ' ${NEW_ROOT}/etc/fstab