summary refs log tree commit diff
diff options
context:
space:
mode:
authorbougyman <bougyman@users.noreply.github.com>2015-04-07 14:11:53 -0500
committerbougyman <bougyman@users.noreply.github.com>2015-04-07 14:11:53 -0500
commitc6c53024e237ea395b97991c04cdc39b1bb98eef (patch)
tree0e17c2d4cfe907a981782ccf7cecaa3312549d88
parent41372a524a97915a52f85caab68a003f4ae0dea8 (diff)
parentb935de9d7be296aca2dfffbc97fdcdf0beb69ea0 (diff)
downloadrunit-void-20150407.tar.gz
runit-void-20150407.tar.xz
runit-void-20150407.zip
Merge pull request #35 from bougyman/master 20150407
3: Detect and deactivate LVM Volume Groups on shutdown
-rwxr-xr-x32
-rw-r--r--functions19
2 files changed, 21 insertions, 0 deletions
diff --git a/3 b/3
index c40c894..d0428d6 100755
--- a/3
+++ b/3
@@ -49,6 +49,8 @@ fi
 sync
 
 if [ -z "$VIRTUALIZATION" ]; then
+    deactivate_vgs
+    deactivate_crypt
     if [ -e /run/runit/reboot ] && command -v kexec >/dev/null; then
         msg "Triggering kexec..."
         kexec -e 2>/dev/null
diff --git a/functions b/functions
index 35449c1..971d288 100644
--- a/functions
+++ b/functions
@@ -34,3 +34,22 @@ detect_virt() {
        export VIRTUALIZATION=1
    fi
 }
+
+deactivate_vgs() {
+   _group=${1:-All}
+   if [ -x /sbin/vgchange ]; then
+       vgs=$(vgs|wc -l)
+       if [ $vgs -gt 0 ]; then
+           msg "Deactivating $_group LVM Volume Groups..."
+           vgchange -an
+       fi
+   fi
+}
+
+deactivate_crypt() {
+   if [ -x /sbin/dmsetup ]; then
+       msg "Deactivating Crypt Volumes"
+       dmsetup ls --target crypt --exec 'cryptsetup close'
+       deactivate_vgs "Crypt"
+   fi
+}