md: takeover should clear unrelated bits
authorShaohua Li <shli@fb.com>
Thu, 8 Dec 2016 23:48:17 +0000 (15:48 -0800)
committerShaohua Li <shli@fb.com>
Fri, 9 Dec 2016 06:00:11 +0000 (22:00 -0800)
When we change level from raid1 to raid5, the MD_FAILFAST_SUPPORTED bit
will be accidentally set, but raid5 doesn't support it. The same is true
for the MD_HAS_JOURNAL bit.

Fix: 46533ff (md: Use REQ_FAILFAST_* on metadata writes where appropriate)
Reviewed-by: NeilBrown <neilb@suse.com>
Signed-off-by: Shaohua Li <shli@fb.com>
drivers/md/raid0.c
drivers/md/raid1.c
drivers/md/raid5.c

index e628f187e5ad45e8b4c140b57ef8e5d119ebfa46..a162fedeb51a48ce31d18fbca5a51a0fe9204bf4 100644 (file)
@@ -539,8 +539,11 @@ static void *raid0_takeover_raid45(struct mddev *mddev)
        mddev->delta_disks = -1;
        /* make sure it will be not marked as dirty */
        mddev->recovery_cp = MaxSector;
+       clear_bit(MD_HAS_JOURNAL, &mddev->flags);
+       clear_bit(MD_JOURNAL_CLEAN, &mddev->flags);
 
        create_strip_zones(mddev, &priv_conf);
+
        return priv_conf;
 }
 
@@ -580,6 +583,7 @@ static void *raid0_takeover_raid10(struct mddev *mddev)
        mddev->degraded = 0;
        /* make sure it will be not marked as dirty */
        mddev->recovery_cp = MaxSector;
+       clear_bit(MD_FAILFAST_SUPPORTED, &mddev->flags);
 
        create_strip_zones(mddev, &priv_conf);
        return priv_conf;
@@ -622,6 +626,7 @@ static void *raid0_takeover_raid1(struct mddev *mddev)
        mddev->raid_disks = 1;
        /* make sure it will be not marked as dirty */
        mddev->recovery_cp = MaxSector;
+       clear_bit(MD_FAILFAST_SUPPORTED, &mddev->flags);
 
        create_strip_zones(mddev, &priv_conf);
        return priv_conf;
index 94e0afce6d4cc92e7dab48641d36c32b1c32a03a..efc2e744cfd3d22cd86959b877f34c389747f91e 100644 (file)
@@ -3243,9 +3243,12 @@ static void *raid1_takeover(struct mddev *mddev)
                mddev->new_layout = 0;
                mddev->new_chunk_sectors = 0;
                conf = setup_conf(mddev);
-               if (!IS_ERR(conf))
+               if (!IS_ERR(conf)) {
                        /* Array must appear to be quiesced */
                        conf->array_frozen = 1;
+                       clear_bit(MD_HAS_JOURNAL, &mddev->flags);
+                       clear_bit(MD_JOURNAL_CLEAN, &mddev->flags);
+               }
                return conf;
        }
        return ERR_PTR(-EINVAL);
index 6bf3c2604a2f78f25433d70ed9d0df871325dcb9..3e6a2a0d61e9a56500cabd248259b8f6cc5f20af 100644 (file)
@@ -7811,6 +7811,7 @@ static void *raid45_takeover_raid0(struct mddev *mddev, int level)
 static void *raid5_takeover_raid1(struct mddev *mddev)
 {
        int chunksect;
+       void *ret;
 
        if (mddev->raid_disks != 2 ||
            mddev->degraded > 1)
@@ -7832,7 +7833,10 @@ static void *raid5_takeover_raid1(struct mddev *mddev)
        mddev->new_layout = ALGORITHM_LEFT_SYMMETRIC;
        mddev->new_chunk_sectors = chunksect;
 
-       return setup_conf(mddev);
+       ret = setup_conf(mddev);
+       if (!IS_ERR_VALUE(ret))
+               clear_bit(MD_FAILFAST_SUPPORTED, &mddev->flags);
+       return ret;
 }
 
 static void *raid5_takeover_raid6(struct mddev *mddev)