X-Git-Url: https://iankelling.org/git/?a=blobdiff_plain;f=mount-latest-subvol;h=36895aa1612ad1d58bc923775d19887117fdf60f;hb=b857462732e15f455e41f26e3048a390d7b399c0;hp=b4bec8efe51c1aec7101d4aa78b84a219b8e1bec;hpb=3a5055dce8796a1946d9f75d8c74605eb73d19df;p=distro-setup diff --git a/mount-latest-subvol b/mount-latest-subvol index b4bec8e..36895aa 100644 --- a/mount-latest-subvol +++ b/mount-latest-subvol @@ -81,6 +81,33 @@ 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 @@ -92,10 +119,14 @@ EOF shopt -s nullglob +# ssh and probably some other things care about parent directory +# ownership, and ssh doesn\'t allow any group writable parent +# directories, so we are forced to use a directory structure similar +# to home directories f=(/mnt/root/btrbk/q.*) if [[ -e $f ]]; then fstab <