X-Git-Url: https://iankelling.org/git/?a=blobdiff_plain;f=mount-latest-subvol;h=36895aa1612ad1d58bc923775d19887117fdf60f;hb=b857462732e15f455e41f26e3048a390d7b399c0;hp=c43bb587e150ff5de248f7cce52f8f76d95c12ca;hpb=f3e6a97425746ed185c28dcc03acf7e67a6af560;p=distro-setup diff --git a/mount-latest-subvol b/mount-latest-subvol index c43bb58..36895aa 100644 --- a/mount-latest-subvol +++ b/mount-latest-subvol @@ -32,7 +32,7 @@ errcatch() { set -o pipefail } bash-trace() { - local -i argc_index=0 arg frame i start=${1:-1} max_indent=8 indent + local -i argc_index=0 frame i start=${1:-1} max_indent=8 indent local source local extdebug=false if [[ $(shopt -p extdebug) == *-s* ]]; then @@ -73,27 +73,80 @@ mnt() { e mount $dir fi } +fstab() { + while read -r start mpoint end; do + l="$start $mpoint $end" + # kill off any lines that duplicate the mount point. + sed --follow-symlinks -ri "\%$l%b;\%^\s*\S+\s+$mpoint\s%d" /etc/fstab + tu /etc/fstab <<<"$l" + done +} +kill-dir() { + for sig; do + echo kill-dir $sig + found_pids=false + if pids=$(timeout 4 lsof -t $dir); then + found_pids=true + timeout 4 lsof -w $dir + kill -$sig $pids + fi + # fuser will find open sockets that lsof won't, for example from gpg-agent. + # note: -v shows kernel processes, which then doesn't return true when we want + if timeout 4 fuser -m $dir &>/dev/null; then + found_pids=true + fuser -$sig -mvk $dir + fi + sleep .5 + if ! $found_pids; then + return 0 + fi + done + return 1 +} + +force=false +if [[ $1 == -f ]]; then + force=true +fi ret=0 ##### begin setup fstab for subvols we care about ###### first_root_crypt=$(awk '$2 == "/" {print $1}' /etc/mtab) -tu /etc/fstab </dev/null; then continue @@ -120,15 +173,16 @@ for vol in q a o; do # if latest is already mounted, make sure binds are mounted and move on if e check-subvol-stale $d; then + mnt $d for b in ${binds[@]}; do mnt $b done continue fi - last_snap=$(