summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorNeilBrown <neilb@suse.de>2009-03-10 06:28:22 +0100
committerNeilBrown <neilb@suse.de>2009-03-10 06:28:22 +0100
commit661dce36178960a20a5bcbb3bbf92e721df1bec0 (patch)
tree84bc5f3fa9c8e482527b5fae9b9f4f8ac463dd60
parentDDF: fix up container_content (diff)
downloadmdadm-661dce36178960a20a5bcbb3bbf92e721df1bec0.tar.xz
mdadm-661dce36178960a20a5bcbb3bbf92e721df1bec0.zip
mdmon: allow incremental assembly of containers.
If mdmon sees a device added to a container, it should assume it is a new spare. It could be a part of the array that just hadn't been assembled yet. So check first. Signed-off-by: NeilBrown <neilb@suse.de>
-rw-r--r--managemon.c21
-rw-r--r--super-ddf.c1
2 files changed, 22 insertions, 0 deletions
diff --git a/managemon.c b/managemon.c
index 5f0a61b5..e02c77ea 100644
--- a/managemon.c
+++ b/managemon.c
@@ -241,7 +241,9 @@ static void add_disk_to_container(struct supertype *st, struct mdinfo *sd)
{
int dfd;
char nm[20];
+ struct supertype *st2;
struct metadata_update *update = NULL;
+ struct mdinfo info;
mdu_disk_info_t dk = {
.number = -1,
.major = sd->disk.major,
@@ -261,6 +263,25 @@ static void add_disk_to_container(struct supertype *st, struct mdinfo *sd)
if (dfd < 0)
return;
+ /* Check the metadata and see if it is already part of this
+ * array
+ */
+ st2 = dup_super(st);
+ if (st2->ss->load_super(st2, dfd, NULL) == 0) {
+ st2->ss->getinfo_super(st, &info);
+ if (st->ss->compare_super(st, st2) == 0 &&
+ info.disk.raid_disk >= 0) {
+ /* Looks like a good member of array.
+ * Just accept it.
+ * mdadm will incorporate any parts into
+ * active arrays.
+ */
+ st2->ss->free_super(st2);
+ return;
+ }
+ }
+ st2->ss->free_super(st2);
+
st->update_tail = &update;
st->ss->add_to_super(st, &dk, dfd, NULL);
st->ss->write_init_super(st);
diff --git a/super-ddf.c b/super-ddf.c
index 965b8e2c..6455deee 100644
--- a/super-ddf.c
+++ b/super-ddf.c
@@ -1335,6 +1335,7 @@ static void getinfo_super_ddf(struct supertype *st, struct mdinfo *info)
info->component_size = ddf->dlist->size - info->data_offset;
} else {
info->disk.number = -1;
+ info->disk.raid_disk = -1;
// info->disk.raid_disk = find refnum in the table and use index;
}
info->disk.state = (1 << MD_DISK_SYNC);