]> git.ipfire.org Git - thirdparty/dracut.git/commitdiff
90(md|dm)raid: recognize ddf container
authorMichal Soltys <soltys@ziu.info>
Mon, 5 Sep 2011 22:17:24 +0000 (00:17 +0200)
committerHarald Hoyer <harald@redhat.com>
Thu, 22 Sep 2011 13:37:26 +0000 (15:37 +0200)
This patch adds ddf support, consistently with imsm/isw options.

Signed-off-by: Michal Soltys <soltys@ziu.info>
dracut.kernel.7.xml
modules.d/90dmraid/61-dmraid-imsm.rules
modules.d/90dmraid/parse-dm.sh
modules.d/90mdraid/65-md-incremental-imsm.rules
modules.d/90mdraid/md-noddf.sh [new file with mode: 0755]
modules.d/90mdraid/md-noimsm.sh
modules.d/90mdraid/module-setup.sh
modules.d/90mdraid/parse-md.sh

index b6e59e650d50e9e1429f4e1a70352f94fb25cb02..8d50d9486b2caecf76aa79e81e51c78c8623b952 100644 (file)
@@ -342,6 +342,12 @@ This parameter can be specified multiple times.</para>
             <para>disable MD RAID for imsm/isw raids, use DM RAID instead</para>
           </listitem>
         </varlistentry>
+        <varlistentry>
+          <term><envar>rd.md.ddf</envar>=0</term>
+          <listitem>
+            <para>disable MD RAID for SNIA ddf raids, use DM RAID instead</para>
+          </listitem>
+        </varlistentry>
         <varlistentry>
           <term>
             <envar>rd.md.conf</envar>=0
index d87fce7a8ac6b13019c3579eb09bf5b94922f08e..73ba58e542d2db201d25925dfe2072ca43da4e0c 100644 (file)
@@ -10,6 +10,7 @@ ENV{ID_FS_TYPE}=="linux_raid_member", GOTO="dm_end"
 ENV{ID_FS_TYPE}!="*_raid_member", , GOTO="dm_end"
 
 ENV{ID_FS_TYPE}=="isw_raid_member", ENV{rd_NO_MDIMSM}!="?*", GOTO="dm_end"
+ENV{ID_FS_TYPE}=="ddf_raid_member", ENV{rd_NO_MDDDF}!="?*", GOTO="dm_end"
 
 ENV{rd_NO_DM}=="?*", GOTO="dm_end"
 
index 059c396c171100ddc10d65db92c8ce660714eaca..fe38d352bf192bf4acc3aa3be7e32b52f3d00db3 100755 (executable)
@@ -12,3 +12,7 @@ if  ! command -v mdadm >/dev/null || ! getargbool 1 rd.md.imsm -n rd_NO_MDIMSM |
     udevproperty rd_NO_MDIMSM=1
 fi
 
+if  ! command -v mdadm >/dev/null || ! getargbool 1 rd.md.ddf -n rd_NO_MDDDF || getarg noddfmd; then
+    info "rd.md.ddf=0: no MD RAID for SNIA ddf raids"
+    udevproperty rd_NO_MDDDF=1
+fi
index 5e94a57602f670659fddd3659f621910f814944d..bb030cf7dfedab00cb0bc1863046492530bef812 100644 (file)
@@ -4,9 +4,10 @@
 
 ACTION!="add|change", GOTO="md_inc_end"
 SUBSYSTEM!="block", GOTO="md_inc_end"
-ENV{ID_FS_TYPE}!="linux_raid_member|isw_raid_member", GOTO="md_inc_end"
+ENV{ID_FS_TYPE}!="*_raid_member", GOTO="md_inc_end"
 
 ENV{ID_FS_TYPE}=="isw_raid_member", ENV{rd_NO_MDIMSM}=="?*", GOTO="md_inc_end"
+ENV{ID_FS_TYPE}=="ddf_raid_member", ENV{rd_NO_MDDDF}=="?*", GOTO="md_inc_end"
 
 ENV{rd_NO_MD}=="?*", GOTO="md_inc_end"
 
diff --git a/modules.d/90mdraid/md-noddf.sh b/modules.d/90mdraid/md-noddf.sh
new file mode 100755 (executable)
index 0000000..bc46dd7
--- /dev/null
@@ -0,0 +1,5 @@
+#!/bin/sh
+# -*- mode: shell-script; indent-tabs-mode: nil; sh-basic-offset: 4; -*-
+# ex: ts=8 sw=4 sts=4 et filetype=sh
+info "rd.md.ddf=0: no MD RAID for SNIA ddf raids"
+udevproperty rd_NO_MDDDF=1
index bc9cf7fc48444988ee4e9508d815260fef444a72..8272f86043a30b3423bb482bda0a12d16a5aa7ce 100755 (executable)
@@ -2,4 +2,4 @@
 # -*- mode: shell-script; indent-tabs-mode: nil; sh-basic-offset: 4; -*-
 # ex: ts=8 sw=4 sts=4 et filetype=sh
 info "rd.md.imsm=0: no MD RAID for imsm/isw raids"
-udevproperty rd_NO_MDIMSM=1
\ No newline at end of file
+udevproperty rd_NO_MDIMSM=1
index cfc2a20451d57d866cd76c76a2bb33ff82c35682..5c526a02a6f4efba6578a1d7a2d527869c6dd696 100755 (executable)
@@ -20,7 +20,7 @@ check() {
             check_block_and_slaves is_mdraid "$_rootdev" || return 1
         else
             # root is not on a block device, use the shotgun approach
-            blkid | egrep -q '(linux|isw)_raid' || return 1
+            blkid | grep -q '"[^"]*_raid_member"' || return 1
         fi
     }
 
@@ -59,9 +59,13 @@ install() {
 
     inst_rules "$moddir/65-md-incremental-imsm.rules"
 
+    # guard against pre-3.0 mdadm versions, that can't handle containers
     if ! mdadm -Q -e imsm /dev/null &> /dev/null; then
         inst_hook pre-trigger 30 "$moddir/md-noimsm.sh"
     fi
+    if ! mdadm -Q -e ddf /dev/null &> /dev/null; then
+        inst_hook pre-trigger 30 "$moddir/md-noddf.sh"
+    fi
 
     if [[ $hostonly ]] || [[ $mdadmconf = "yes" ]]; then
         if [ -f /etc/mdadm.conf ]; then
index 63f32786d3359d9057680cccac2394eb8bfa6ff6..33d93dc76f8ebb4ff61460de0a58a517500ed435 100755 (executable)
@@ -43,3 +43,9 @@ if ! getargbool 1 rd.md.imsm -n rd_NO_MDIMSM || getarg noiswmd || getarg nodmrai
     info "no MD RAID for imsm/isw raids"
     udevproperty rd_NO_MDIMSM=1
 fi
+
+# same thing with ddf containers
+if ! getargbool 1 rd.md.ddf -n rd_NO_MDDDF || getarg noddfmd || getarg nodmraid; then
+    info "no MD RAID for SNIA ddf raids"
+    udevproperty rd_NO_MDDDF=1
+fi