diff options
author | NeilBrown <neilb@suse.de> | 2015-04-21 18:00:20 -0400 |
---|---|---|
committer | NeilBrown <neilb@suse.de> | 2015-04-21 18:00:20 -0400 |
commit | d51e4fe6d68098d4361a6b6d41d8da727b1f1af4 (patch) | |
tree | 6c070a877db9697a2b68e84b2b2d0aa299bb6216 /drivers/md/raid1.c | |
parent | 47d68979cc968535cb87f3e5f2e6a3533ea48fbd (diff) | |
parent | 97f6cd39da227459cb46ed4088d37d5d8db51c50 (diff) |
Merge branch 'cluster' into for-next
Diffstat (limited to 'drivers/md/raid1.c')
-rw-r--r-- | drivers/md/raid1.c | 20 |
1 files changed, 16 insertions, 4 deletions
diff --git a/drivers/md/raid1.c b/drivers/md/raid1.c index d34e238afa54..4efa50186a2a 100644 --- a/drivers/md/raid1.c +++ b/drivers/md/raid1.c | |||
@@ -539,7 +539,13 @@ static int read_balance(struct r1conf *conf, struct r1bio *r1_bio, int *max_sect | |||
539 | has_nonrot_disk = 0; | 539 | has_nonrot_disk = 0; |
540 | choose_next_idle = 0; | 540 | choose_next_idle = 0; |
541 | 541 | ||
542 | choose_first = (conf->mddev->recovery_cp < this_sector + sectors); | 542 | if ((conf->mddev->recovery_cp < this_sector + sectors) || |
543 | (mddev_is_clustered(conf->mddev) && | ||
544 | md_cluster_ops->area_resyncing(conf->mddev, this_sector, | ||
545 | this_sector + sectors))) | ||
546 | choose_first = 1; | ||
547 | else | ||
548 | choose_first = 0; | ||
543 | 549 | ||
544 | for (disk = 0 ; disk < conf->raid_disks * 2 ; disk++) { | 550 | for (disk = 0 ; disk < conf->raid_disks * 2 ; disk++) { |
545 | sector_t dist; | 551 | sector_t dist; |
@@ -1102,8 +1108,10 @@ static void make_request(struct mddev *mddev, struct bio * bio) | |||
1102 | md_write_start(mddev, bio); /* wait on superblock update early */ | 1108 | md_write_start(mddev, bio); /* wait on superblock update early */ |
1103 | 1109 | ||
1104 | if (bio_data_dir(bio) == WRITE && | 1110 | if (bio_data_dir(bio) == WRITE && |
1105 | bio_end_sector(bio) > mddev->suspend_lo && | 1111 | ((bio_end_sector(bio) > mddev->suspend_lo && |
1106 | bio->bi_iter.bi_sector < mddev->suspend_hi) { | 1112 | bio->bi_iter.bi_sector < mddev->suspend_hi) || |
1113 | (mddev_is_clustered(mddev) && | ||
1114 | md_cluster_ops->area_resyncing(mddev, bio->bi_iter.bi_sector, bio_end_sector(bio))))) { | ||
1107 | /* As the suspend_* range is controlled by | 1115 | /* As the suspend_* range is controlled by |
1108 | * userspace, we want an interruptible | 1116 | * userspace, we want an interruptible |
1109 | * wait. | 1117 | * wait. |
@@ -1114,7 +1122,10 @@ static void make_request(struct mddev *mddev, struct bio * bio) | |||
1114 | prepare_to_wait(&conf->wait_barrier, | 1122 | prepare_to_wait(&conf->wait_barrier, |
1115 | &w, TASK_INTERRUPTIBLE); | 1123 | &w, TASK_INTERRUPTIBLE); |
1116 | if (bio_end_sector(bio) <= mddev->suspend_lo || | 1124 | if (bio_end_sector(bio) <= mddev->suspend_lo || |
1117 | bio->bi_iter.bi_sector >= mddev->suspend_hi) | 1125 | bio->bi_iter.bi_sector >= mddev->suspend_hi || |
1126 | (mddev_is_clustered(mddev) && | ||
1127 | !md_cluster_ops->area_resyncing(mddev, | ||
1128 | bio->bi_iter.bi_sector, bio_end_sector(bio)))) | ||
1118 | break; | 1129 | break; |
1119 | schedule(); | 1130 | schedule(); |
1120 | } | 1131 | } |
@@ -1561,6 +1572,7 @@ static int raid1_spare_active(struct mddev *mddev) | |||
1561 | struct md_rdev *rdev = conf->mirrors[i].rdev; | 1572 | struct md_rdev *rdev = conf->mirrors[i].rdev; |
1562 | struct md_rdev *repl = conf->mirrors[conf->raid_disks + i].rdev; | 1573 | struct md_rdev *repl = conf->mirrors[conf->raid_disks + i].rdev; |
1563 | if (repl | 1574 | if (repl |
1575 | && !test_bit(Candidate, &repl->flags) | ||
1564 | && repl->recovery_offset == MaxSector | 1576 | && repl->recovery_offset == MaxSector |
1565 | && !test_bit(Faulty, &repl->flags) | 1577 | && !test_bit(Faulty, &repl->flags) |
1566 | && !test_and_set_bit(In_sync, &repl->flags)) { | 1578 | && !test_and_set_bit(In_sync, &repl->flags)) { |