Accepting request 29126 from home:michal-m:branches:Base:System

Copy from home:michal-m:branches:Base:System/mdadm via accept of submit request 29126 revision 2.
Request was accepted with message:
Reviewed ok

OBS-URL: https://build.opensuse.org/request/show/29126
OBS-URL: https://build.opensuse.org/package/show/Base:System/mdadm?expand=0&rev=10
This commit is contained in:
Michal Marek 2010-01-11 14:06:42 +00:00 committed by Git OBS Bridge
parent f5eef324e8
commit bc6e213f2e
8 changed files with 129 additions and 134 deletions

View File

@ -1,32 +0,0 @@
From 0e90271e53c0f6efb33e904cf407498350e2a14d Mon Sep 17 00:00:00 2001
From: NeilBrown <neilb@suse.de>
Date: Thu, 1 Oct 2009 12:38:31 +1000
Subject: [PATCH 1/2] Add missing space in "--detail --brief" output.
We need a space between the device name and the word "level"..
Signed-off-by: NeilBrown <neilb@suse.de>
---
Detail.c | 4 ++--
1 files changed, 2 insertions(+), 2 deletions(-)
diff --git a/Detail.c b/Detail.c
index 001012a..a70db34 100644
--- a/Detail.c
+++ b/Detail.c
@@ -207,11 +207,11 @@ int Detail(char *dev, int brief, int export, int test, char *homehost)
printf("ARRAY %s", dev);
if (brief > 1) {
if (array.raid_disks)
- printf("level=%s num-devices=%d",
+ printf(" level=%s num-devices=%d",
c?c:"-unknown-",
array.raid_disks );
else
- printf("level=container num-devices=%d",
+ printf(" level=container num-devices=%d",
array.nr_disks);
}
if (container) {
--
1.6.3.3

View File

@ -1,48 +0,0 @@
From 2b9aa337af7291d3f141322da96c9f667c99d53c Mon Sep 17 00:00:00 2001
From: NeilBrown <neilb@suse.de>
Date: Thu, 1 Oct 2009 12:51:04 +1000
Subject: [PATCH 2/2] Fix null-dereference in set_member_info
set_member_info would try to dereference ->metadata_version, without
checking that it isn't NULL.
Signed-off-by: NeilBrown <neilb@suse.de>
---
mapfile.c | 15 +++++++++------
1 files changed, 9 insertions(+), 6 deletions(-)
diff --git a/mapfile.c b/mapfile.c
index a3038be..ed59db5 100644
--- a/mapfile.c
+++ b/mapfile.c
@@ -303,19 +303,22 @@ struct map_ent *map_by_name(struct map_ent **map, char *name)
*/
static void set_member_info(struct supertype *st, struct mdstat_ent *ent)
{
- char version[strlen(ent->metadata_version)+1];
st->subarray[0] = '\0';
- if (strncmp(ent->metadata_version, "external:", 9) != 0)
+ if (ent->metadata_version == NULL ||
+ strncmp(ent->metadata_version, "external:", 9) != 0)
return;
- strcpy(version, ent->metadata_version);
-
- if (is_subarray(&version[9])) {
- char *subarray = strrchr(version, '/');
+ if (is_subarray(&ent->metadata_version[9])) {
+ char version[strlen(ent->metadata_version)+1];
+ char *subarray;
char *name = &version[10];
+ strcpy(version, ent->metadata_version);
+ subarray = strrchr(version, '/');
+ name = &version[10];
+
if (!subarray)
return;
*subarray++ = '\0';
--
1.6.3.3

View File

@ -1,3 +0,0 @@
version https://git-lfs.github.com/spec/v1
oid sha256:821c2a073daed4916973226a6c623de5d697cceb077de935e2b1c316b11f3da7
size 252754

3
mdadm-3.0.3.tar.bz2 Normal file
View File

@ -0,0 +1,3 @@
version https://git-lfs.github.com/spec/v1
oid sha256:b51a52aebfb83b09ae7faee9eebb4d49a7ad27767bcc9569079df62c7d510599
size 257554

View File

@ -1,8 +1,27 @@
-------------------------------------------------------------------
Wed Jan 6 15:47:03 CET 2010 - mmarek@suse.cz
- mkinitrd-*.sh: fix booting from partitionable md devices and
from container devices (bnc#565219).
-------------------------------------------------------------------
Tue Dec 15 20:26:46 CET 2009 - jengelh@medozas.de
- enable parallel building
-------------------------------------------------------------------
Fri Dec 4 18:00:40 CET 2009 - mmarek@suse.cz
- Support for partitionable md devices in mkinitrd scripts
(fate#305883).
-------------------------------------------------------------------
Tue Nov 3 11:03:54 CET 2009 - mmarek@suse.cz
- update to 3.0.3 (fate#307159)
* mdmon improvements (needed for fate#306823)
* other fixes
-------------------------------------------------------------------
Fri Oct 30 16:49:40 CET 2009 - mmarek@suse.cz

View File

@ -19,7 +19,7 @@
Name: mdadm
Version: 3.0.2
Version: 3.0.3
Release: 3
BuildRequires: sgmltool
PreReq: %fillup_prereq %insserv_prereq
@ -31,8 +31,6 @@ Url: http://www.kernel.org/pub/linux/utils/raid/mdadm/
Summary: Utility for Configuring MD Setup
BuildRoot: %{_tmppath}/%{name}-%{version}-build
Source: %{name}-%{version}.tar.bz2
Patch1: 0001-Add-missing-space-in-detail-brief-output.patch
Patch2: 0002-Fix-null-dereference-in-set_member_info.patch
Source1: Software-RAID.HOWTO.tar.bz2
Source2: sysconfig.mdadm
Source3: mdadmd
@ -53,8 +51,6 @@ Authors:
%prep
%setup -q -a1
%patch1 -p1
%patch2 -p1
%build
%{suse_update_config -f}

View File

@ -1,7 +1,7 @@
#!/bin/bash
#%stage: softraid
#%programs: /sbin/mdadm /sbin/mdmon
#%modules: raid0 raid1 raid456
#%modules: raid0 raid1 raid10 raid456
#%if: -n "$need_mdadm"
#
##### MD (Software-)Raid
@ -33,36 +33,41 @@ if [ -f /sys/module/md_mod/parameters/start_ro ]; then
echo 1 > /sys/module/md_mod/parameters/start_ro
fi
if [ -n "$need_mdadm" ]; then
md_assemble()
{
local dev=$1 mdconf container
if [ -f /etc/mdadm.conf ] ; then
mdconf="-Ac /etc/mdadm.conf"
[ -z "$md_dev" ] && md_dev="--scan"
case "$dev" in
/dev/md[0-9]*p[0-9]*)
dev=${dev%p[0-9]*}
esac
if test -f /etc/mdadm.conf; then
mdconf="-c /etc/mdadm.conf"
container=$( \
sed -rn "s:^ARRAY +$dev .*container=([^ ]*).*:\\1:p" \
/etc/mdadm.conf)
else
mdconf="-c partitions"
fi
if test -n "$container"; then
mdadm -A $mdconf --uuid="$container" /dev/md/container
fi
mdadm -A $mdconf $mdarg "$dev"
}
if [ -n "$need_mdadm" ]; then
if [ -n "$md_uuid" ] ; then
mdarg="--uuid=$md_uuid"
elif [ -n "$md_uuid" ] ; then
mdarg="$mdarg --uuid=$md_uuid"
fi
if [ -n "$md_minor" ] ; then
mdarg="$mdarg --super-minor=$md_minor"
md_dev="/dev/md$md_minor"
elif [ -z "$md_minor" -a -n "$md_minor" ] ; then
mdarg="$mdarg --super-minor=$md_minor"
fi
case $resumedev in
/dev/md*)
echo 1 > /sys/module/md_mod/parameters/start_ro
resume_minor="${resumedev#/dev/md}"
mdadm -Ac partitions -m $resume_minor --auto=md $resumedev
;;
md_assemble "$resumedev"
esac
if [ "$md_dev" ] ; then
/sbin/mdadm $mdconf --auto=md $md_dev || /sbin/mdadm -Ac partitions $mdarg --auto=md $md_dev
if [ -n "$md_dev" ] ; then
md_assemble "$md_dev"
fi
wait_for_events
fi

View File

@ -4,40 +4,95 @@
#
mdblockdev=
# Full mdadm.conf generated by mdadm.
# Contains all created MD RAIDs
mdadm_conf=$(mdadm --examine --brief --scan)
cont_list=
md_devs=
# blockdev contains real devices (/dev/X) for root, resume, journal, dumb
echo "blockdev: $blockdev"
for bd in $blockdev ; do
# get information about the current blockdev
update_blockdev $bd
mdconf=$(mdadm -Db $bd 2> /dev/null | sed -n "s@/dev/md[0-9]*@/dev/md$blockminor@p")
if [ -n "$mdconf" ] ; then
md_tmpblockdev=$(mdadm -Dbv $bd 2> /dev/null | sed -n "1D;s/,/ /g;s/^ *devices=\(.*\)/\1/p")
is_part_dev=false
case $bd in
/dev/md[0-9]*p[0-9]*)
# Partitionable MD RAID. This is partition on RAID. Get the RAID
bd=${bd%%p[0-9]*}
is_part_dev=true
;;
/dev/md[0-9]*)
;;
*)
mdblockdev="$mdblockdev $bd"
continue
;;
esac
# Check if this device is already added (possible for partitionable).
md_dev=${bd##/dev/}
dup_found=0
dup_found=false
for dup in $md_devs; do
if [ x"$dup" = x"$md_dev" ]; then
dup_found=1
dup_found=true
break
fi
done
if [ $dup_found -eq 0 ]; then
mdblockdev="$mdblockdev $md_tmpblockdev"
eval md_conf_${md_dev}=\"$mdconf\"
md_devs="$md_devs $md_dev"
root_md=1
else
if $dup_found; then
if ! $is_part_dev; then
echo "setup-md.sh: $md_dev found multiple times" >&2
fi
else
mdblockdev="$mdblockdev $bd"
continue
fi
# Get UUID of block device
tmp_uuid=$(mdadm -D $bd --export 2>/dev/null | grep UUID=)
if [ -n "$tmp_uuid" ]; then
md_tmpblockdev=$(mdadm -Dbv $bd 2> /dev/null | sed -n "1D;s/,/ /g;s/^ *devices=\(.*\)/\1/p")
uuid=${tmp_uuid##MD_}
# Get the corresponding line from config
arr_line=$(echo "$mdadm_conf" | grep "$uuid")
if test -z "$arr_line"; then
continue
fi
# Check for container
cont_line=
cont=$(echo "$arr_line" | sed -n "s/.*container=\([0-9a-z]\{8\}:[0-9a-z]\{8\}:[0-9a-z]\{8\}:[0-9a-z]\{8\}\).*/\1/p")
if [ -n "$cont" ]; then
cnt_dup=0
for cnt in $cont_list; do
if [ x"$cont"= x"$cnt" ]; then
cnt_dup=1
fi
done
if [ $cnt_dup -eq 0 ]; then
cont_list="$cont_list $cont"
cont_line=$(echo "$mdadm_conf" | grep "UUID=$cont")
cont_line="$cont_line\n"
fi
fi
# add a line with the "real" md device name so that boot-md.sh finds it
cfg_dev=$(echo "$arr_line" | sed -rn 's/^ARRAY +([^ ]*).*/\1/p; T; q')
real_dev=$(readlink -f "$cfg_dev")
if test -n "$real_dev" -a "$real_dev" != "$cfg_dev"; then
arr_line="$arr_line$(echo -e "\\n$arr_line" | \
sed -r "s:^(ARRAY +)$cfg_dev:\\1$real_dev:")"
fi
mdblockdev="$mdblockdev $md_tmpblockdev"
# Add ARRAY line (with container line before if needed).
cfg_line=$(echo -e "$cont_line$arr_line")
eval md_conf_${md_dev}=\""$cfg_line"\"
md_devs="$md_devs $md_dev"
root_md=1
fi
done
# Any 'md' device is replaced by it's component disks.
blockdev="$mdblockdev"
if [ -n "$root_md" ] ; then
need_mdadm=1
echo "DEVICE partitions" > $tmp_mnt/etc/mdadm.conf
echo -n "" > $tmp_mnt/etc/mdadm.conf
for md in $md_devs; do
eval echo \$md_conf_$md >> $tmp_mnt/etc/mdadm.conf
eval echo -e \"\$md_conf_$md\" >> $tmp_mnt/etc/mdadm.conf
done
fi