mdraid: add rd_NO_MDADMCONF --mdadmconf --nomdadmconf

Copy /etc/mdadm.conf to initramfs (even for non-hostonly) if
mdadmconf="yes" is set in dracut.conf or --mdadmconf is specified on the
dracut command line.

This was done, because there seems _no_ sane way to autoassemble md raid
arrays.

also moved rd_NO_MD to an udev ENV
master
Harald Hoyer 2009-09-15 09:00:13 +02:00
parent 11fcc8c8f9
commit 2f02ae9d45
11 changed files with 58 additions and 12 deletions

7
dracut
View File

@ -45,6 +45,8 @@ Creates initial ramdisk images for preloading modules
--no-kernel Do not install kernel drivers and firmware files --no-kernel Do not install kernel drivers and firmware files
--strip Strip binaries in the initramfs (default) --strip Strip binaries in the initramfs (default)
--nostrip Do not strip binaries in the initramfs --nostrip Do not strip binaries in the initramfs
--mdadmconf Include local /etc/mdadm.conf
--nomdadmconf Do not include local /etc/mdadm.conf
-h, --help This message -h, --help This message
--debug Output debug information of the build process --debug Output debug information of the build process
-v, --verbose Verbose output during the build process -v, --verbose Verbose output during the build process
@ -78,6 +80,8 @@ while (($# > 0)); do
--no-kernel) kernel_only="no"; no_kernel="yes";; --no-kernel) kernel_only="no"; no_kernel="yes";;
--strip) do_strip_l="yes";; --strip) do_strip_l="yes";;
--nostrip) do_strip_l="no";; --nostrip) do_strip_l="no";;
--mdadmconf) mdadmconf_l="yes";;
--nomdadmconf) mdadmconf_l="no";;
-h|--help) usage; exit 1 ;; -h|--help) usage; exit 1 ;;
--debug) debug="yes";; --debug) debug="yes";;
-v|--verbose) beverbose="yes";; -v|--verbose) beverbose="yes";;
@ -115,6 +119,7 @@ PATH=/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/sbin:/bin:$PATH
[[ $fw_dir_l ]] && fw_dir=$fw_dir_l [[ $fw_dir_l ]] && fw_dir=$fw_dir_l
[[ $do_strip_l ]] && do_strip=$do_strip_l [[ $do_strip_l ]] && do_strip=$do_strip_l
[[ $hostonly_l ]] && hostonly=$hostonly_l [[ $hostonly_l ]] && hostonly=$hostonly_l
[[ $mdadmconf_l ]] && mdadmconf=$mdadmconf_l
[[ $dracutbasedir ]] || dracutbasedir=/usr/share/dracut [[ $dracutbasedir ]] || dracutbasedir=/usr/share/dracut
[[ $fw_dir ]] || fw_dir=/lib/firmware [[ $fw_dir ]] || fw_dir=/lib/firmware
[[ $do_strip ]] || do_strip=yes [[ $do_strip ]] || do_strip=yes
@ -163,7 +168,7 @@ chmod 755 "$initdir"


export initdir hookdirs dsrc dracutmodules drivers \ export initdir hookdirs dsrc dracutmodules drivers \
fw_dir drivers_dir debug beverbose no_kernel kernel_only \ fw_dir drivers_dir debug beverbose no_kernel kernel_only \
add_drivers add_drivers mdadmconf


if [[ $kernel_only != yes ]]; then if [[ $kernel_only != yes ]]; then
# Create some directory structure first # Create some directory structure first

View File

@ -44,6 +44,12 @@ only install kernel drivers and firmware files
.BR \-\-no-kernel .BR \-\-no-kernel
do not install kernel drivers and firmware files do not install kernel drivers and firmware files
.TP .TP
.BR \-\-mdadmconf
include local /etc/mdadm.conf
.TP
.BR \-\-nomdadmconf
do not include local /etc/mdadm.conf
.TP
.BR \-\-strip .BR \-\-strip
strip binaries in the initramfs (default) strip binaries in the initramfs (default)
.TP .TP
@ -146,6 +152,9 @@ disable MD RAID detection
.B rd_NO_MDIMSM .B rd_NO_MDIMSM
no MD RAID for imsm/isw raids, use dmraid instead no MD RAID for imsm/isw raids, use dmraid instead
.TP .TP
.B rd_NO_MDADMCONF
ignore mdadm.conf included in initramfs
.TP
.B rd_MD_UUID=<md uuid> .B rd_MD_UUID=<md uuid>
only activate the raid sets with the given UUID only activate the raid sets with the given UUID



View File

@ -11,3 +11,7 @@


# build initrd only to boot current hardware # build initrd only to boot current hardware
#hostonly="-h" #hostonly="-h"
#

# install local /etc/mdadm.conf
mdadmconf="yes"

View File

@ -11,11 +11,14 @@ ENV{DEVTYPE}!="partition", \


ENV{ID_FS_TYPE}=="isw_raid_member", ENV{rd_NO_MDIMSM}=="?*", GOTO="md_inc_end" ENV{ID_FS_TYPE}=="isw_raid_member", ENV{rd_NO_MDIMSM}=="?*", GOTO="md_inc_end"


ENV{rd_NO_MD}=="?*", GOTO="md_inc_end"

TEST=="/tmp/.mdraid_start-%k", GOTO="md_inc_end" TEST=="/tmp/.mdraid_start-%k", GOTO="md_inc_end"
TEST=="/tmp/.mdraid_container-%k", GOTO="md_inc_end" TEST=="/tmp/.mdraid_container-%k", GOTO="md_inc_end"


KERNEL!="md*", IMPORT{program}="/sbin/mdadm --examine --export $tempnode" KERNEL!="md*", IMPORT{program}="/sbin/mdadm --examine --export $tempnode"



# UUID CHECK # UUID CHECK


LABEL="do_md_inc" LABEL="do_md_inc"
@ -41,6 +44,8 @@ ACTION=="add|change", \
KERNEL=="md[0-9]*|md/*", \ KERNEL=="md[0-9]*|md/*", \
ENV{MD_LEVEL}!="container", \ ENV{MD_LEVEL}!="container", \
ENV{MD_CONTAINER}!="?*", \ ENV{MD_CONTAINER}!="?*", \
ENV{rd_MDADMCONF}!="?*", \
ENV{rd_NO_MD}!="?*", \
GOTO="do_raidstart" GOTO="do_raidstart"


GOTO="end_raidstart" GOTO="end_raidstart"
@ -63,6 +68,8 @@ ACTION=="add|change", \
KERNEL=="md[0-9]*|md/*", \ KERNEL=="md[0-9]*|md/*", \
ENV{DEVTYPE}!="partition", \ ENV{DEVTYPE}!="partition", \
ENV{MD_LEVEL}=="container", \ ENV{MD_LEVEL}=="container", \
ENV{rd_MDADMCONF}!="?*", \
ENV{rd_NO_MD}!="?*", \
GOTO="do_container" GOTO="do_container"


GOTO="end_container" GOTO="end_container"

View File

@ -21,7 +21,7 @@ if ! mdadm -Q -e imsm /dev/null &> /dev/null; then
inst_hook pre-trigger 30 "$moddir/md-noimsm.sh" inst_hook pre-trigger 30 "$moddir/md-noimsm.sh"
fi fi


if [[ $hostonly ]]; then if [[ $hostonly ]] || [[ $mdadmconf = "yes" ]]; then
[ -f /etc/mdadm/mdadm.conf ] && inst /etc/mdadm/mdadm.conf /etc/mdadm.conf [ -f /etc/mdadm/mdadm.conf ] && inst /etc/mdadm/mdadm.conf /etc/mdadm.conf
[ -f /etc/mdadm.conf ] && inst /etc/mdadm.conf [ -f /etc/mdadm.conf ] && inst /etc/mdadm.conf
fi fi
@ -33,6 +33,7 @@ fi


inst "$moddir/mdraid_start.sh" /sbin/mdraid_start inst "$moddir/mdraid_start.sh" /sbin/mdraid_start
inst "$moddir/mdcontainer_start.sh" /sbin/mdcontainer_start inst "$moddir/mdcontainer_start.sh" /sbin/mdcontainer_start
inst "$moddir/mdadm_auto.sh" /sbin/mdadm_auto
inst_hook pre-trigger 30 "$moddir/parse-md.sh" inst_hook pre-trigger 30 "$moddir/parse-md.sh"
inst_hook pre-pivot 30 "$moddir/mdraid-cleanup.sh" inst_hook pre-pivot 30 "$moddir/mdraid-cleanup.sh"
inst_hook pre-pivot 31 "$moddir/mdraid-cleanup.sh" inst_hook pre-pivot 31 "$moddir/mdraid-cleanup.sh"

View File

@ -0,0 +1,7 @@
#!/bin/sh
. /lib/dracut-lib.sh

info "Autoassembling MD Raid"
udevadm control --stop-exec-queue
/sbin/mdadm -As --auto=yes --run 2>&1 | vinfo
udevadm control --start-exec-queue

View File

@ -1,6 +1,6 @@
if getarg rd_NO_MD; then if getarg rd_NO_MD; then
info "rd_NO_MD: removing MD RAID activation" info "rd_NO_MD: removing MD RAID activation"
rm /etc/udev/rules.d/65-md-incremental*.rules udevadm control --property=rd_NO_MD=1
else else
MD_UUID=$(getargs rd_MD_UUID=) MD_UUID=$(getargs rd_MD_UUID=)


@ -24,6 +24,12 @@ else
fi fi
fi fi



if [ -e /etc/mdadm.conf ] && ! getarg rd_NO_MDADMCONF; then
udevadm control --property=rd_MDADMCONF=1
rm -f /pre-pivot/*mdraid-cleanup.sh
fi

if getarg rd_NO_MDIMSM; then if getarg rd_NO_MDIMSM; then
info "rd_NO_MDIMSM: no MD RAID for imsm/isw raids" info "rd_NO_MDIMSM: no MD RAID for imsm/isw raids"
udevadm control --property=rd_NO_MDIMSM=1 udevadm control --property=rd_NO_MDIMSM=1

View File

@ -47,6 +47,7 @@ test_setup() {
$basedir/dracut -l -i overlay / \ $basedir/dracut -l -i overlay / \
-m "dash crypt lvm mdraid udev-rules base rootfs-block kernel-modules" \ -m "dash crypt lvm mdraid udev-rules base rootfs-block kernel-modules" \
-d "ata_piix ext2 sd_mod" \ -d "ata_piix ext2 sd_mod" \
--nomdadmconf \
-f initramfs.makeroot $KVERSION || return 1 -f initramfs.makeroot $KVERSION || return 1
rm -rf overlay rm -rf overlay
# Invoke KVM and/or QEMU to actually create the target filesystem. # Invoke KVM and/or QEMU to actually create the target filesystem.

View File

@ -30,7 +30,9 @@ cp -a -t /sysroot /source/* && \
umount /sysroot && \ umount /sysroot && \
lvm lvchange -a n /dev/dracut/root && \ lvm lvchange -a n /dev/dracut/root && \
cryptsetup luksClose /dev/mapper/dracut_crypt_test && \ cryptsetup luksClose /dev/mapper/dracut_crypt_test && \
{ mdadm -W /dev/md0 || : ;} && \
mdadm /dev/md0 --fail /dev/sda2 --remove /dev/sda2 && \ mdadm /dev/md0 --fail /dev/sda2 --remove /dev/sda2 && \
{ mdadm -W /dev/md0 || : ;} && \
{ {
/sbin/mdadm --detail --export /dev/md0 > /tmp/mduuid ; /sbin/mdadm --detail --export /dev/md0 > /tmp/mduuid ;
. /tmp/mduuid; . /tmp/mduuid;

View File

@ -28,6 +28,8 @@ test_run() {


client_run || return 1 client_run || return 1
client_run rd_NO_MDADMCONF || return 1

client_run rd_NO_LVM && return 1 client_run rd_NO_LVM && return 1


client_run rd_LVM_VG=failme && return 1 client_run rd_LVM_VG=failme && return 1
@ -36,13 +38,13 @@ test_run() {


client_run rd_LVM_VG=dummy1 rd_LVM_VG=dracut rd_LVM_VG=dummy2 || return 1 client_run rd_LVM_VG=dummy1 rd_LVM_VG=dracut rd_LVM_VG=dummy2 || return 1


client_run rd_MD_UUID=failme && return 1 client_run rd_MD_UUID=failme rd_NO_MDADMCONF && return 1


client_run rd_NO_MD && return 1 client_run rd_NO_MD && return 1


client_run rd_MD_UUID=$MD_UUID || return 1 client_run rd_MD_UUID=$MD_UUID rd_NO_MDADMCONF || return 1


client_run rd_MD_UUID=dummy1 rd_MD_UUID=$MD_UUID rd_MD_UUID=dummy2 || return 1 client_run rd_MD_UUID=dummy1 rd_MD_UUID=$MD_UUID rd_MD_UUID=dummy2 rd_NO_MDADMCONF|| return 1


return 0 return 0
} }
@ -88,12 +90,15 @@ test_setup() {
-append "root=/dev/dracut/root rw rootfstype=ext2 quiet console=ttyS0,115200n81" \ -append "root=/dev/dracut/root rw rootfstype=ext2 quiet console=ttyS0,115200n81" \
-initrd initramfs.makeroot || return 1 -initrd initramfs.makeroot || return 1
grep -m 1 -q dracut-root-block-created root.ext2 || return 1 grep -m 1 -q dracut-root-block-created root.ext2 || return 1
eval $(grep --binary-files=text -m 1 MD_UUID root.ext2)
( (
initdir=overlay initdir=overlay
. $basedir/dracut-functions . $basedir/dracut-functions
dracut_install poweroff shutdown dracut_install poweroff shutdown
inst_simple ./hard-off.sh /emergency/01hard-off.sh inst_simple ./hard-off.sh /emergency/01hard-off.sh
inst ./cryptroot-ask /sbin/cryptroot-ask inst ./cryptroot-ask /sbin/cryptroot-ask
mkdir -p overlay/etc
echo "ARRAY /dev/md0 level=raid5 num-devices=3 UUID=$MD_UUID" > overlay/etc/mdadm.conf
) )
sudo $basedir/dracut -l -i overlay / \ sudo $basedir/dracut -l -i overlay / \
-o "plymouth" \ -o "plymouth" \

View File

@ -26,11 +26,10 @@ test_run() {
client_run || return 1 client_run || return 1
client_run rd_NO_MDIMSM || return 1 client_run rd_NO_MDIMSM || return 1
client_run rd_NO_DM || return 1 client_run rd_NO_DM || return 1
client_run rd_NO_MD rd_NO_MDIMSM && return 1 client_run rd_NO_DM rd_NO_MDIMSM rd_NO_MDADMCONF || return 1
# FIXME: client_run rd_NO_MD rd_NO_MDIMSM && return 1
# client_run rd_NO_DM rd_NO_MDIMSM && return 1 client_run rd_NO_MD && return 1
# client_run rd_NO_MD && return 1 return 0
return 0
} }


test_setup() { test_setup() {