commit:     1bb133b505d5aade0cc0b6c6e16f1bc3e9a266f7
Author:     Thomas Deutschmann <whissi <AT> gentoo <DOT> org>
AuthorDate: Tue Apr 14 17:42:51 2020 +0000
Commit:     Thomas Deutschmann <whissi <AT> gentoo <DOT> org>
CommitDate: Tue Apr 14 18:34:20 2020 +0000
URL:        https://gitweb.gentoo.org/repo/gentoo.git/commit/?id=1bb133b5

sys-fs/lvm2: runscript: rework start()

- Don't use LVM script anymore: If one command within script failed,
  any following command won't run anymore.

- Be verbose when rc_verbose=yes is set.

- Only call pvscan when lvmetad is used.

Signed-off-by: Thomas Deutschmann <whissi <AT> gentoo.org>

 sys-fs/lvm2/files/lvm.rc-2.02.187 | 33 +++++++++++++++++++++------------
 1 file changed, 21 insertions(+), 12 deletions(-)

diff --git a/sys-fs/lvm2/files/lvm.rc-2.02.187 
b/sys-fs/lvm2/files/lvm.rc-2.02.187
index d9c11730cdb..f9ad753ea82 100644
--- a/sys-fs/lvm2/files/lvm.rc-2.02.187
+++ b/sys-fs/lvm2/files/lvm.rc-2.02.187
@@ -86,24 +86,33 @@ start() {
                fi
 
                if [ -d /proc/lvm ] || dm_in_proc ; then
-                       ebegin "Setting up the Logical Volume Manager"
-                       #still echo stderr for debugging
-                       lvm_commands="#!${lvm_path}\n"
-                       # Extra PV find pass because some devices might not 
have been available until very recently
-                       lvm_commands="${lvm_commands}pvscan --config 
'${config}'\n"
+                       local has_errors=0 verbose_command
+
+                       yesno "${rc_verbose}" && verbose_command=" -v"
+
+                       ebegin "Starting the Logical Volume Manager"
+
+                       if _use_lvmetad ; then
+                               # Extra PV find pass because some devices might 
not have been available until very recently
+                               ${lvm_path} pvscan${verbose_command} --config 
"${config}" --cache
+                               [ $? -ne 0 ] && has_errors=1
+                       fi
+
                        # Now make the nodes
-                       lvm_commands="${lvm_commands}vgscan --config 
'${config}' --mknodes\n"
-                       # And turn them on!
-                       lvm_commands="${lvm_commands}vgchange --config 
'${config}' --sysinit -a ly\n"
+                       ${lvm_path} vgscan${verbose_command} --config 
"${config}" --mknodes
+                       [ $? -ne 0 ] && has_errors=1
+
+                       # Enable all VGs
+                       ${lvm_path} vgchange${verbose_command} --config 
"${config}" --sysinit --activate y
+                       [ $? -ne 0 ] && has_errors=1
 
                        if _use_lvmlockd ; then
                                # Start lockd VGs as required
-                               lvm_commands="${lvm_commands}vgchange --config 
'${config}' --lock-start --lock-opt auto\n"
+                               ${lvm_path} vgchange${verbose_command} --config 
"${config}" --lock-start --lock-opt auto
+                               [ $? -ne 0 ] && has_errors=1
                        fi
 
-                       # Order of this is important, have to work around dash 
and LVM readline
-                       printf "%b\n" "${lvm_commands}" | $lvm_path 
/proc/self/fd/0 >/dev/null
-                       eend $? "Failed to setup the LVM"
+                       eend ${has_errors} "Failed to start the Logical Volume 
Manager"
                fi
        fi
 }

Reply via email to