]> git.ipfire.org Git - thirdparty/dracut.git/commitdiff
95fstab-sys: use det_fs and wrap_fsck
authorMichal Soltys <soltys@ziu.info>
Fri, 20 May 2011 15:09:25 +0000 (17:09 +0200)
committerHarald Hoyer <harald@redhat.com>
Fri, 20 May 2011 15:16:50 +0000 (17:16 +0200)
This patch mainly adds fsck functionality to fstab-sys, with additional
sanity checks (checking for device existence, verifying fstype via
det_fs).

Signed-off-by: Michal Soltys <soltys@ziu.info>
modules.d/95fstab-sys/module-setup.sh
modules.d/95fstab-sys/mount-sys.sh

index f46c03723c449c04765176e2b8d97e23dc42ceaa..1fbd55b490ec906a9cced300cdb2286546e04a10 100755 (executable)
@@ -12,5 +12,7 @@ depends() {
 
 install() {
     dracut_install /etc/fstab.sys
+    dracut_install /sbin/fsck*
+    type -P e2fsck >/dev/null && dracut_install e2fsck
     inst_hook pre-pivot 00 "$moddir/mount-sys.sh"
 }
index 266576e96cf462431812680167a41041bbf43314..b444071c865087f79be0624687494eada55af2ec 100755 (executable)
@@ -2,14 +2,25 @@
 # -*- mode: shell-script; indent-tabs-mode: nil; sh-basic-offset: 4; -*-
 # ex: ts=8 sw=4 sts=4 et filetype=sh
 
-fstab_mount(){
-    local dev mp type opts rest
+type getarg >/dev/null 2>&1 || . /lib/dracut-lib.sh
+
+fstab_mount() {
+    local _dev _mp _fs _opts _dump _pass _rest
     test -e "$1" || return 1
     info "Mounting from $1"
-    while read dev mp type opts rest; do
-       [ -z "${dev%%#*}" ]&& continue # Skip comment lines
-       mount -v -t $type -o $opts $dev $NEWROOT/$mp
-    done < $1 | vinfo
+    while read _dev _mp _fs _opts _dump _pass _rest; do
+        [ -z "${_dev%%#*}" ] && continue # Skip comment lines
+        if [ ! -e "$_dev" ]; then
+            warn "Device $_dev doesn't exist, skipping mount."
+            continue
+        fi
+        if [ "$_pass" -gt 0 ] && ! strstr "$_opts" _netdev; then
+            wrap_fsck "$_dev"
+        fi
+        _fs=$(det_fs "$_dev" "$_fs" /etc/fstab.sys)
+        info "Mounting $_dev"
+        mount -v -t $_fs -o $_opts $_dev $NEWROOT/$_mp 2>&1 | vinfo
+    done < $1
     return 0
 }