X-Git-Url: http://git.grml.org/?a=blobdiff_plain;f=scripts%2Flive-helpers;h=9a80b110a2cf3762bf9eca8cb1bfca499ea81016;hb=f92f379a6e868bc486c050ff5ca81c1707da7374;hp=5306cf5ba6292bf6f4a8555842b10402942ab089;hpb=65dc1e4b2ba0d3e086308d4ad3104a1ce3a098cd;p=live-boot-grml.git diff --git a/scripts/live-helpers b/scripts/live-helpers index 5306cf5..9a80b11 100644 --- a/scripts/live-helpers +++ b/scripts/live-helpers @@ -15,14 +15,13 @@ else udevinfo='udevinfo' fi -root_overlay_label="full-ov" old_root_overlay_label="live-rw" old_home_overlay_label="home-rw" custom_overlay_label="custom-ov" root_snapshot_label="live-sn" old_root_snapshot_label="live-sn" home_snapshot_label="home-sn" -persistence_list="live.persist" +persistence_list="live-persistence.conf" Arguments () { @@ -89,9 +88,14 @@ Arguments () export FETCH ;; - forcepersistentfsck) - FORCEPERSISTENTFSCK="Yes" - export FORCEPERSISTENTFSCK + findiso=*) + FINDISO="${ARGUMENT#findiso=}" + export FINDISO + ;; + + forcepersistencefsck) + FORCEPERSISTENCEFSCK="Yes" + export FORCEPERSISTENCEFSCK ;; ftpfs=*) @@ -188,8 +192,8 @@ Arguments () export NFSOPTS ;; - nfscow=*) - NFS_COW="${ARGUMENT#nfscow=}" + nfsoverlay=*) + NFS_COW="${ARGUMENT#nfsoverlay=}" export NFS_COW ;; @@ -222,52 +226,51 @@ Arguments () export SWAPON ;; - persistent) - PERSISTENT="Yes" - export PERSISTENT + persistence) + PERSISTENCE="Yes" + export PERSISTENCE ;; - persistent-encryption=*) - PERSISTENT_ENCRYPTION="${ARGUMENT#*=}" - export PERSISTENT_ENCRYPTION + persistence-encryption=*) + PERSISTENCE_ENCRYPTION="${ARGUMENT#*=}" + export PERSISTENCE_ENCRYPTION ;; - persistent-media=*) - PERSISTENT_MEDIA="${ARGUMENT#*=}" - export PERSISTENT_MEDIA + persistence-media=*) + PERSISTENCE_MEDIA="${ARGUMENT#*=}" + export PERSISTENCE_MEDIA ;; - persistent-method=*) - PERSISTENT_METHOD="${ARGUMENT#*=}" - export PERSISTENT_METHOD + persistence-method=*) + PERSISTENCE_METHOD="${ARGUMENT#*=}" + export PERSISTENCE_METHOD ;; - persistent-path=*) - PERSISTENT_PATH="${ARGUMENT#persistent-path=}" - export PERSISTENT_PATH + persistence-path=*) + PERSISTENCE_PATH="${ARGUMENT#persistence-path=}" + export PERSISTENCE_PATH ;; - persistent-read-only) - PERSISTENT_READONLY="Yes" - export PERSISTENT_READONLY + persistence-read-only) + PERSISTENCE_READONLY="Yes" + export PERSISTENCE_READONLY ;; - persistent-storage=*) - PERSISTENT_STORAGE="${ARGUMENT#persistent-storage=}" - export PERSISTENT_STORAGE + persistence-storage=*) + PERSISTENCE_STORAGE="${ARGUMENT#persistence-storage=}" + export PERSISTENCE_STORAGE ;; - persistent-subtext=*) - root_overlay_label="${root_overlay_label}-${ARGUMENT#persistent-subtext=}" - old_root_overlay_label="${old_root_overlay_label}-${ARGUMENT#persistent-subtext=}" - old_home_overlay_label="${old_home_overlay_label}-${ARGUMENT#persistent-subtext=}" - custom_overlay_label="${custom_overlay_label}-${ARGUMENT#persistent-subtext=}" - root_snapshot_label="${root_snapshot_label}-${ARGUMENT#persistent-subtext=}" - old_root_snapshot_label="${root_snapshot_label}-${ARGUMENT#persistent-subtext=}" - home_snapshot_label="${home_snapshot_label}-${ARGUMENT#persistent-subtext=}" + persistence-subtext=*) + old_root_overlay_label="${old_root_overlay_label}-${ARGUMENT#persistence-subtext=}" + old_home_overlay_label="${old_home_overlay_label}-${ARGUMENT#persistence-subtext=}" + custom_overlay_label="${custom_overlay_label}-${ARGUMENT#persistence-subtext=}" + root_snapshot_label="${root_snapshot_label}-${ARGUMENT#persistence-subtext=}" + old_root_snapshot_label="${root_snapshot_label}-${ARGUMENT#persistence-subtext=}" + home_snapshot_label="${home_snapshot_label}-${ARGUMENT#persistence-subtext=}" ;; - nopersistent) - NOPERSISTENT="Yes" - export NOPERSISTENT + nopersistence) + NOPERSISTENCE="Yes" + export NOPERSISTENCE ;; noprompt) @@ -381,37 +384,37 @@ Arguments () export UNIONTYPE fi - if [ -z "${PERSISTENT_ENCRYPTION}" ] + if [ -z "${PERSISTENCE_ENCRYPTION}" ] then - PERSISTENT_ENCRYPTION="none" - export PERSISTENT_ENCRYPTION - elif echo ${PERSISTENT_ENCRYPTION} | grep -qe "\" + PERSISTENCE_ENCRYPTION="none" + export PERSISTENCE_ENCRYPTION + elif echo ${PERSISTENCE_ENCRYPTION} | grep -qe "\" then if ! modprobe dm-crypt then log_warning_msg "Unable to load module dm-crypt" - PERSISTENT_ENCRYPTION=$(echo ${PERSISTENT_ENCRYPTION} | sed -e 's/\" && \ + if echo ${PERSISTENCE_ENCRYPTION} | grep -qe "\" && \ is_luks_partition ${dev} then if luks_device=$(open_luks_device "${dev}") @@ -994,14 +988,14 @@ find_persistent_media () # skip $dev since we failed/chose not to open it continue fi - elif echo ${PERSISTENT_ENCRYPTION} | grep -qve "\" + elif echo ${PERSISTENCE_ENCRYPTION} | grep -qve "\" then # skip $dev since we don't allow unencrypted storage continue fi # Probe for matching GPT partition names or filesystem labels - if echo ${PERSISTENT_STORAGE} | grep -qe "\" + if echo ${PERSISTENCE_STORAGE} | grep -qe "\" then result=$(probe_for_gpt_name "${overlays}" "${snapshots}" ${dev}) if [ -n "${result}" ] @@ -1019,7 +1013,7 @@ find_persistent_media () fi # Probe for files with matching name on mounted partition - if echo ${PERSISTENT_STORAGE} | grep -qe "\" + if echo ${PERSISTENCE_STORAGE} | grep -qe "\" then result=$(probe_for_file_name "${overlays}" "${snapshots}" ${dev}) if [ -n "${result}" ] @@ -1158,8 +1152,8 @@ link_files () # live-boot normally does (into $rootmnt)). # remove multiple /:s and ensure ending on / - local src_dir="$(echo "${1}"/ | sed -e 's|/\+|/|g')" - local dest_dir="$(echo "${2}"/ | sed -e 's|/\+|/|g')" + local src_dir="$(trim_path ${1})/" + local dest_dir="$(trim_path ${2})/" local src_mask="${3}" # This check can only trigger on the inital, non-recursive call since @@ -1181,9 +1175,8 @@ link_files () if [ ! -d "${dest}" ] then mkdir -p "${dest}" - prev="$(dirname "${dest}")" - chown_ref "${prev}" "${dest}" - chmod_ref "${prev}" "${dest}" + chown_ref "${src}" "${dest}" + chmod_ref "${src}" "${dest}" fi link_files "${src}" "${dest}" "${src_mask}" else @@ -1262,7 +1255,7 @@ do_union () get_custom_mounts () { - # Side-effect: leaves $devices with live.persist mounted in ${rootmnt}/live/persistent + # Side-effect: leaves $devices with live-persistence.conf mounted in /live/persistence # Side-effect: prints info to file $custom_mounts local custom_mounts=${1} @@ -1281,7 +1274,7 @@ get_custom_mounts () fi local device_name="$(basename ${device})" - local backing=$(mount_persistent_media ${device}) + local backing=$(mount_persistence_media ${device}) if [ -z "${backing}" ] then continue @@ -1295,7 +1288,7 @@ get_custom_mounts () if [ -n "${DEBUG}" ] && [ -e "${include_list}" ] then - cp ${include_list} ${rootmnt}/live/persistent/${persistence_list}.${device_name} + cp ${include_list} /live/persistence/${persistence_list}.${device_name} fi while read dir options # < ${include_list} @@ -1306,24 +1299,24 @@ get_custom_mounts () continue fi - if trim_path ${dir} | grep -q -e "^[^/]" -e "^/$" -e "^/live\(/.*\)\?$" -e "^/\(.*/\)\?\.\.\?\(/.*\)\?$" + if trim_path ${dir} | grep -q -e "^[^/]" -e "^/live\(/.*\)\?$" -e "^/\(.*/\)\?\.\.\?\(/.*\)\?$" then - log_warning_msg "Skipping unsafe custom mount ${dir}: must be an absolute path containing neither the \".\" nor \"..\" special dirs, and cannot be \"/live\" (or any sub-directory therein) or \"/\" (for the latter, use ${root_overlay_label}-type persistence)" + log_warning_msg "Skipping unsafe custom mount ${dir}: must be an absolute path containing neither the \".\" nor \"..\" special dirs, and cannot be \"/live\" or any sub-directory therein." continue fi local opt_source="" - local opt_linkfiles="" + local opt_link="" for opt in $(echo ${options} | tr ',' ' '); do case "${opt}" in source=*) opt_source=${opt#source=} ;; - linkfiles) - opt_linkfiles="yes" + link) + opt_link="yes" ;; - union) + union|bind) ;; *) log_warning_msg "Skipping custom mount with unkown option: ${opt}" @@ -1346,7 +1339,7 @@ get_custom_mounts () local full_source="$(trim_path ${backing}/${source})" local full_dest="$(trim_path ${rootmnt}/${dir})" - if [ -n "${opt_linkfiles}" ] + if [ -n "${opt_link}" ] then echo "${device} ${full_source} ${full_dest} ${options}" >> ${links} else @@ -1375,7 +1368,7 @@ get_custom_mounts () do if echo ${source} | grep -qe "^${prev_source}\(/.*\)\?$" then - panic "Two persistent mounts have the same or nested sources: ${source} on ${dest}, and ${prev_source} on ${prev_dest}" + panic "Two persistence mounts have the same or nested sources: ${source} on ${dest}, and ${prev_source} on ${prev_dest}" fi prev_source=${source} prev_dest=${dest} @@ -1389,29 +1382,36 @@ activate_custom_mounts () while read device source dest options # < ${custom_mounts} do - local opt_linkfiles="" + local opt_bind="yes" + local opt_link="" local opt_union="" for opt in $(echo ${options} | tr ',' ' '); do case "${opt}" in - linkfiles) - opt_linkfiles="yes" + bind) + opt_bind="yes" + unset opt_link opt_union + ;; + link) + opt_link="yes" + unset opt_bind opt_union ;; union) opt_union="yes" + unset opt_bind opt_link ;; esac done - if [ -n "${opt_linkfiles}" ] && [ -n "${opt_union}" ] - then - log_warning_msg "Skipping custom mount ${dest} with options ${options}: \"linkfiles\" and \"union\" are mutually exclusive options" - fi - if [ -n "$(what_is_mounted_on "${dest}")" ] then - log_warning_msg "Skipping custom mount ${dest}: $(what_is_mounted_on "${dest}") is already mounted there" - continue + if [ "${dest}" = "${rootmnt}" ] + then + umount "${dest}" + else + log_warning_msg "Skipping custom mount ${dest}: $(what_is_mounted_on "${dest}") is already mounted there" + continue + fi fi if [ ! -d "${dest}" ] @@ -1439,23 +1439,24 @@ activate_custom_mounts () done fi - # if ${source} doesn't exist on our persistent media + # if ${source} doesn't exist on our persistence media # we bootstrap it with $dest from the live filesystem. # this both makes sense and is critical if we're # dealing with /etc or other system dir. if [ ! -d "${source}" ] then - if [ -n "${PERSISTENT_READONLY}" ] + if [ -n "${PERSISTENCE_READONLY}" ] then continue - elif [ -n "${opt_union}" ] || [ -n "${opt_linkfiles}" ] + elif [ -n "${opt_union}" ] || [ -n "${opt_link}" ] then # unions and don't need to be bootstrapped - # linkfiles dirs can't be bootstrapped in a sensible way + # link dirs can't be bootstrapped in a sensible way mkdir -p "${source}" chown_ref "${dest}" "${source}" chmod_ref "${dest}" "${source}" - else + elif [ -n "${opt_bind}" ] + then # ensure that $dest is not copied *into* $source mkdir -p "$(dirname ${source})" cp -a "${dest}" "${source}" @@ -1464,49 +1465,66 @@ activate_custom_mounts () # XXX: If CONFIG_AUFS_ROBR is added to the Debian kernel we can # ignore the loop below and set rofs_dest_backing=$dest - rofs_dest_backing="" - for d in ${rootmnt}/live/rofs/* - do - if [ -n "${rootmnt}" ] - then - rofs_dest_backing="${d}/$(echo ${dest} | sed -e "s|${rootmnt}||")" - else - rofs_dest_backing="${d}/${dest}" - fi - if [ -d "${rofs_dest_backing}" ] - then - break - else - rofs_dest_backing="" - fi - done + local rofs_dest_backing="" + if [ -n "${opt_link}"] + then + for d in /live/rofs/* + do + if [ -n "${rootmnt}" ] + then + rofs_dest_backing="${d}/$(echo ${dest} | sed -e "s|${rootmnt}||")" + else + rofs_dest_backing="${d}/${dest}" + fi + if [ -d "${rofs_dest_backing}" ] + then + break + else + rofs_dest_backing="" + fi + done + fi - if [ -z "${PERSISTENT_READONLY}" ] + if [ -n "${opt_link}" ] && [ -z "${PERSISTENCE_READONLY}" ] then - if [ -n "${opt_linkfiles}" ] - then - links_source="${source}" - links_dest="${dest}" - elif [ -n "${opt_union}" ] - then - do_union ${dest} ${source} ${rofs_dest_backing} - else - mount --bind "${source}" "${dest}" - fi - else - if [ -n "${opt_linkfiles}" ] - then - links_dest="${dest}" - dest="$(mktemp -d ${persistent_backing}/links_source-XXXXXX)" - links_source="${dest}" - fi + link_files ${source} ${dest} ${rootmnt} + elif [ -n "${opt_link}" ] && [ -n "${PERSISTENCE_READONLY}" ] + then + mkdir -p /live/persistence + local links_source=$(mktemp -d /live/persistence/links-source-XXXXXX) + chown_ref ${source} ${links_source} + chmod_ref ${source} ${links_source} + # We put the cow dir in the below strange place to + # make it absolutely certain that the link source + # has its own directory and isn't nested with some + # other custom mount (if so that mount's files would + # be linked, causing breakage. + local cow_dir="/live/overlay/live/persistence/$(basename ${links_source})" + mkdir -p ${cow_dir} + chown_ref "${source}" "${cow_dir}" + chmod_ref "${source}" "${cow_dir}" + do_union ${links_source} ${cow_dir} ${source} ${rofs_dest_backing} + link_files ${links_source} ${dest} ${rootmnt} + elif [ -n "${opt_union}" ] && [ -z "${PERSISTENCE_READONLY}" ] + then + do_union ${dest} ${source} ${rofs_dest_backing} + elif [ -n "${opt_bind}" ] && [ -z "${PERSISTENCE_READONLY}" ] + then + mount --bind "${source}" "${dest}" + elif [ -n "${opt_bind}" -o -n "${opt_union}" ] && [ -n "${PERSISTENCE_READONLY}" ] + then + # bind-mount and union mount are handled the same + # in read-only mode, but note that rofs_dest_backing + # is non-empty (and necessary) only for unions if [ -n "${rootmnt}" ] then - cow_dir="$(echo ${dest} | sed -e "s|${rootmnt}|/cow/|")" + local cow_dir="$(echo ${dest} | sed -e "s|^${rootmnt}|/live/overlay/|")" else - cow_dir="/live/cow/${dest}" + # This is happens if persistence is activated + # post boot + local cow_dir="/live/overlay/${dest}" fi - if [ -e "${cow_dir}" ] + if [ -e "${cow_dir}" ] && [ -z "${opt_link}" ] then # If an earlier custom mount has files here # it will "block" the current mount's files @@ -1519,11 +1537,6 @@ activate_custom_mounts () do_union ${dest} ${cow_dir} ${source} ${rofs_dest_backing} fi - if [ -n "${opt_linkfiles}" ] - then - link_files "${links_source}" "${links_dest}" "${rootmnt}" - fi - PERSISTENCE_IS_ON="1" export PERSISTENCE_IS_ON @@ -1536,16 +1549,18 @@ activate_custom_mounts () echo ${used_devices} } -fix_home_rw_compatibility () +fix_backwards_compatibility () { local device=${1} + local dir=${2} + local opt=${3} - if [ -n "${PERSISTENT_READONLY}" ] + if [ -n "${PERSISTENCE_READONLY}" ] then return fi - local backing="$(mount_persistent_media ${device})" + local backing="$(mount_persistence_media ${device})" if [ -z "${backing}" ] then return @@ -1554,7 +1569,14 @@ fix_home_rw_compatibility () local include_list="${backing}/${persistence_list}" if [ ! -r "${include_list}" ] then - echo "# home-rw backwards compatibility: -/home source=." > "${include_list}" + echo "# persistence backwards compatibility: +${dir} ${opt},source=." > "${include_list}" fi } + +is_mountpoint () +{ + directory="$1" + + [ $(stat -fc%d:%D "${directory}") != $(stat -fc%d:%D "${directory}/..") ] +}