Blame 0049-90-md-dm-raid-recognize-ddf-container.patch

Harald Hoyer 55891e
From cf5891424ef026eede69606a918dadf5560095fd Mon Sep 17 00:00:00 2001
Harald Hoyer 55891e
From: Michal Soltys <soltys@ziu.info>
Harald Hoyer 55891e
Date: Tue, 6 Sep 2011 00:17:24 +0200
Harald Hoyer 55891e
Subject: [PATCH] 90(md|dm)raid: recognize ddf container
Harald Hoyer 55891e
Harald Hoyer 55891e
This patch adds ddf support, consistently with imsm/isw options.
Harald Hoyer 55891e
Harald Hoyer 55891e
Signed-off-by: Michal Soltys <soltys@ziu.info>
Harald Hoyer 55891e
---
Harald Hoyer 55891e
 dracut.kernel.7.xml                             |    6 ++++++
Harald Hoyer 55891e
 modules.d/90dmraid/61-dmraid-imsm.rules         |    1 +
Harald Hoyer 55891e
 modules.d/90dmraid/parse-dm.sh                  |    4 ++++
Harald Hoyer 55891e
 modules.d/90mdraid/65-md-incremental-imsm.rules |    3 ++-
Harald Hoyer 55891e
 modules.d/90mdraid/md-noddf.sh                  |    5 +++++
Harald Hoyer 55891e
 modules.d/90mdraid/md-noimsm.sh                 |    2 +-
Harald Hoyer 55891e
 modules.d/90mdraid/module-setup.sh              |    6 +++++-
Harald Hoyer 55891e
 modules.d/90mdraid/parse-md.sh                  |    6 ++++++
Harald Hoyer 55891e
 8 files changed, 30 insertions(+), 3 deletions(-)
Harald Hoyer 55891e
 create mode 100755 modules.d/90mdraid/md-noddf.sh
Harald Hoyer 55891e
Harald Hoyer 55891e
diff --git a/dracut.kernel.7.xml b/dracut.kernel.7.xml
Harald Hoyer 55891e
index b6e59e6..8d50d94 100644
Harald Hoyer 55891e
--- a/dracut.kernel.7.xml
Harald Hoyer 55891e
+++ b/dracut.kernel.7.xml
Harald Hoyer 55891e
@@ -343,6 +343,12 @@ This parameter can be specified multiple times.</para>
Harald Hoyer 55891e
           </listitem>
Harald Hoyer 55891e
         </varlistentry>
Harald Hoyer 55891e
         <varlistentry>
Harald Hoyer 55891e
+          <term><envar>rd.md.ddf</envar>=0</term>
Harald Hoyer 55891e
+          <listitem>
Harald Hoyer 55891e
+            <para>disable MD RAID for SNIA ddf raids, use DM RAID instead</para>
Harald Hoyer 55891e
+          </listitem>
Harald Hoyer 55891e
+        </varlistentry>
Harald Hoyer 55891e
+        <varlistentry>
Harald Hoyer 55891e
           <term>
Harald Hoyer 55891e
             <envar>rd.md.conf</envar>=0
Harald Hoyer 55891e
           </term>
Harald Hoyer 55891e
diff --git a/modules.d/90dmraid/61-dmraid-imsm.rules b/modules.d/90dmraid/61-dmraid-imsm.rules
Harald Hoyer 55891e
index d87fce7..73ba58e 100644
Harald Hoyer 55891e
--- a/modules.d/90dmraid/61-dmraid-imsm.rules
Harald Hoyer 55891e
+++ b/modules.d/90dmraid/61-dmraid-imsm.rules
Harald Hoyer 55891e
@@ -10,6 +10,7 @@ ENV{ID_FS_TYPE}=="linux_raid_member", GOTO="dm_end"
Harald Hoyer 55891e
 ENV{ID_FS_TYPE}!="*_raid_member", , GOTO="dm_end"
Harald Hoyer 55891e
 
Harald Hoyer 55891e
 ENV{ID_FS_TYPE}=="isw_raid_member", ENV{rd_NO_MDIMSM}!="?*", GOTO="dm_end"
Harald Hoyer 55891e
+ENV{ID_FS_TYPE}=="ddf_raid_member", ENV{rd_NO_MDDDF}!="?*", GOTO="dm_end"
Harald Hoyer 55891e
 
Harald Hoyer 55891e
 ENV{rd_NO_DM}=="?*", GOTO="dm_end"
Harald Hoyer 55891e
 
Harald Hoyer 55891e
diff --git a/modules.d/90dmraid/parse-dm.sh b/modules.d/90dmraid/parse-dm.sh
Harald Hoyer 55891e
index 059c396..fe38d35 100755
Harald Hoyer 55891e
--- a/modules.d/90dmraid/parse-dm.sh
Harald Hoyer 55891e
+++ b/modules.d/90dmraid/parse-dm.sh
Harald Hoyer 55891e
@@ -12,3 +12,7 @@ if  ! command -v mdadm >/dev/null || ! getargbool 1 rd.md.imsm -n rd_NO_MDIMSM |
Harald Hoyer 55891e
     udevproperty rd_NO_MDIMSM=1
Harald Hoyer 55891e
 fi
Harald Hoyer 55891e
 
Harald Hoyer 55891e
+if  ! command -v mdadm >/dev/null || ! getargbool 1 rd.md.ddf -n rd_NO_MDDDF || getarg noddfmd; then
Harald Hoyer 55891e
+    info "rd.md.ddf=0: no MD RAID for SNIA ddf raids"
Harald Hoyer 55891e
+    udevproperty rd_NO_MDDDF=1
Harald Hoyer 55891e
+fi
Harald Hoyer 55891e
diff --git a/modules.d/90mdraid/65-md-incremental-imsm.rules b/modules.d/90mdraid/65-md-incremental-imsm.rules
Harald Hoyer 55891e
index 5e94a57..bb030cf 100644
Harald Hoyer 55891e
--- a/modules.d/90mdraid/65-md-incremental-imsm.rules
Harald Hoyer 55891e
+++ b/modules.d/90mdraid/65-md-incremental-imsm.rules
Harald Hoyer 55891e
@@ -4,9 +4,10 @@
Harald Hoyer 55891e
 
Harald Hoyer 55891e
 ACTION!="add|change", GOTO="md_inc_end"
Harald Hoyer 55891e
 SUBSYSTEM!="block", GOTO="md_inc_end"
Harald Hoyer 55891e
-ENV{ID_FS_TYPE}!="linux_raid_member|isw_raid_member", GOTO="md_inc_end"
Harald Hoyer 55891e
+ENV{ID_FS_TYPE}!="*_raid_member", GOTO="md_inc_end"
Harald Hoyer 55891e
 
Harald Hoyer 55891e
 ENV{ID_FS_TYPE}=="isw_raid_member", ENV{rd_NO_MDIMSM}=="?*", GOTO="md_inc_end"
Harald Hoyer 55891e
+ENV{ID_FS_TYPE}=="ddf_raid_member", ENV{rd_NO_MDDDF}=="?*", GOTO="md_inc_end"
Harald Hoyer 55891e
 
Harald Hoyer 55891e
 ENV{rd_NO_MD}=="?*", GOTO="md_inc_end"
Harald Hoyer 55891e
 
Harald Hoyer 55891e
diff --git a/modules.d/90mdraid/md-noddf.sh b/modules.d/90mdraid/md-noddf.sh
Harald Hoyer 55891e
new file mode 100755
Harald Hoyer 55891e
index 0000000..bc46dd7
Harald Hoyer 55891e
--- /dev/null
Harald Hoyer 55891e
+++ b/modules.d/90mdraid/md-noddf.sh
Harald Hoyer 55891e
@@ -0,0 +1,5 @@
Harald Hoyer 55891e
+#!/bin/sh
Harald Hoyer 55891e
+# -*- mode: shell-script; indent-tabs-mode: nil; sh-basic-offset: 4; -*-
Harald Hoyer 55891e
+# ex: ts=8 sw=4 sts=4 et filetype=sh
Harald Hoyer 55891e
+info "rd.md.ddf=0: no MD RAID for SNIA ddf raids"
Harald Hoyer 55891e
+udevproperty rd_NO_MDDDF=1
Harald Hoyer 55891e
diff --git a/modules.d/90mdraid/md-noimsm.sh b/modules.d/90mdraid/md-noimsm.sh
Harald Hoyer 55891e
index bc9cf7f..8272f86 100755
Harald Hoyer 55891e
--- a/modules.d/90mdraid/md-noimsm.sh
Harald Hoyer 55891e
+++ b/modules.d/90mdraid/md-noimsm.sh
Harald Hoyer 55891e
@@ -2,4 +2,4 @@
Harald Hoyer 55891e
 # -*- mode: shell-script; indent-tabs-mode: nil; sh-basic-offset: 4; -*-
Harald Hoyer 55891e
 # ex: ts=8 sw=4 sts=4 et filetype=sh
Harald Hoyer 55891e
 info "rd.md.imsm=0: no MD RAID for imsm/isw raids"
Harald Hoyer 55891e
-udevproperty rd_NO_MDIMSM=1
Harald Hoyer 55891e
\ No newline at end of file
Harald Hoyer 55891e
+udevproperty rd_NO_MDIMSM=1
Harald Hoyer 55891e
diff --git a/modules.d/90mdraid/module-setup.sh b/modules.d/90mdraid/module-setup.sh
Harald Hoyer 55891e
index cfc2a20..5c526a0 100755
Harald Hoyer 55891e
--- a/modules.d/90mdraid/module-setup.sh
Harald Hoyer 55891e
+++ b/modules.d/90mdraid/module-setup.sh
Harald Hoyer 55891e
@@ -20,7 +20,7 @@ check() {
Harald Hoyer 55891e
             check_block_and_slaves is_mdraid "$_rootdev" || return 1
Harald Hoyer 55891e
         else
Harald Hoyer 55891e
             # root is not on a block device, use the shotgun approach
Harald Hoyer 55891e
-            blkid | egrep -q '(linux|isw)_raid' || return 1
Harald Hoyer 55891e
+            blkid | grep -q '"[^"]*_raid_member"' || return 1
Harald Hoyer 55891e
         fi
Harald Hoyer 55891e
     }
Harald Hoyer 55891e
 
Harald Hoyer 55891e
@@ -59,9 +59,13 @@ install() {
Harald Hoyer 55891e
 
Harald Hoyer 55891e
     inst_rules "$moddir/65-md-incremental-imsm.rules"
Harald Hoyer 55891e
 
Harald Hoyer 55891e
+    # guard against pre-3.0 mdadm versions, that can't handle containers
Harald Hoyer 55891e
     if ! mdadm -Q -e imsm /dev/null &> /dev/null; then
Harald Hoyer 55891e
         inst_hook pre-trigger 30 "$moddir/md-noimsm.sh"
Harald Hoyer 55891e
     fi
Harald Hoyer 55891e
+    if ! mdadm -Q -e ddf /dev/null &> /dev/null; then
Harald Hoyer 55891e
+        inst_hook pre-trigger 30 "$moddir/md-noddf.sh"
Harald Hoyer 55891e
+    fi
Harald Hoyer 55891e
 
Harald Hoyer 55891e
     if [[ $hostonly ]] || [[ $mdadmconf = "yes" ]]; then
Harald Hoyer 55891e
         if [ -f /etc/mdadm.conf ]; then
Harald Hoyer 55891e
diff --git a/modules.d/90mdraid/parse-md.sh b/modules.d/90mdraid/parse-md.sh
Harald Hoyer 55891e
index 63f3278..33d93dc 100755
Harald Hoyer 55891e
--- a/modules.d/90mdraid/parse-md.sh
Harald Hoyer 55891e
+++ b/modules.d/90mdraid/parse-md.sh
Harald Hoyer 55891e
@@ -43,3 +43,9 @@ if ! getargbool 1 rd.md.imsm -n rd_NO_MDIMSM || getarg noiswmd || getarg nodmrai
Harald Hoyer 55891e
     info "no MD RAID for imsm/isw raids"
Harald Hoyer 55891e
     udevproperty rd_NO_MDIMSM=1
Harald Hoyer 55891e
 fi
Harald Hoyer 55891e
+
Harald Hoyer 55891e
+# same thing with ddf containers
Harald Hoyer 55891e
+if ! getargbool 1 rd.md.ddf -n rd_NO_MDDDF || getarg noddfmd || getarg nodmraid; then
Harald Hoyer 55891e
+    info "no MD RAID for SNIA ddf raids"
Harald Hoyer 55891e
+    udevproperty rd_NO_MDDDF=1
Harald Hoyer 55891e
+fi