summaryrefslogtreecommitdiff
path: root/super0.c
diff options
context:
space:
mode:
authorNeilBrown <neilb@suse.de>2010-11-30 16:46:01 +1100
committerNeilBrown <neilb@suse.de>2011-03-10 17:21:43 +1100
commit1f9476aaf86cb465566b5a1cd5a2fb493531c2eb (patch)
tree2cd7d3ea6c8d619918dbb657f9406e2d42cdbf99 /super0.c
parent321e575910214cb66212a436729c18736542f6bb (diff)
Assemble: add --update=no-bitmap
This allows an array with a corrupt internal bitmap to be assembled without the bitmap. Signed-off-by: NeilBrown <neilb@suse.de>
Diffstat (limited to 'super0.c')
-rw-r--r--super0.c7
1 files changed, 5 insertions, 2 deletions
diff --git a/super0.c b/super0.c
index b141b746..e8555413 100644
--- a/super0.c
+++ b/super0.c
@@ -402,8 +402,9 @@ static int update_super0(struct supertype *st, struct mdinfo *info,
char *devname, int verbose,
int uuid_set, char *homehost)
{
- /* NOTE: for 'assemble' and 'force' we need to return non-zero if any change was made.
- * For others, the return value is ignored.
+ /* NOTE: for 'assemble' and 'force' we need to return non-zero
+ * if any change was made. For others, the return value is
+ * ignored.
*/
int rv = 0;
mdp_super_t *sb = st->sb;
@@ -556,6 +557,8 @@ static int update_super0(struct supertype *st, struct mdinfo *info,
bm = (struct bitmap_super_s*)(sb+1);
uuid_from_super0(st, (int*)bm->uuid);
}
+ } else if (strcmp(update, "no-bitmap") == 0) {
+ sb->state &= ~(1<<MD_SB_BITMAP_PRESENT);
}
if (strcmp(update, "_reshape_progress")==0)
sb->reshape_position = info->reshape_progress;