aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/md/raid1.c
diff options
context:
space:
mode:
authorNeilBrown <neilb@suse.de>2015-04-21 18:00:20 -0400
committerNeilBrown <neilb@suse.de>2015-04-21 18:00:20 -0400
commitd51e4fe6d68098d4361a6b6d41d8da727b1f1af4 (patch)
tree6c070a877db9697a2b68e84b2b2d0aa299bb6216 /drivers/md/raid1.c
parent47d68979cc968535cb87f3e5f2e6a3533ea48fbd (diff)
parent97f6cd39da227459cb46ed4088d37d5d8db51c50 (diff)
Merge branch 'cluster' into for-next
Diffstat (limited to 'drivers/md/raid1.c')
-rw-r--r--drivers/md/raid1.c20
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)) {