diff options
author | NeilBrown <neilb@suse.de> | 2009-12-13 20:49:51 -0500 |
---|---|---|
committer | NeilBrown <neilb@suse.de> | 2009-12-13 20:51:40 -0500 |
commit | 6eef4b21ffc9207b78fdd718154f5b004644b97d (patch) | |
tree | 554d8dafa2cd8ff7a9e719b12bd2f07c9745e7be /drivers | |
parent | 729a18663a30a9c8076e3adc2b3e4c866974f935 (diff) |
md: add honouring of suspend_{lo,hi} to raid1.
This will allow us to stop writeout to portions of the array
while they are resynced by someone else - e.g. another node in
a cluster.
Signed-off-by: NeilBrown <neilb@suse.de>
Diffstat (limited to 'drivers')
-rw-r--r-- | drivers/md/raid1.c | 22 |
1 files changed, 22 insertions, 0 deletions
diff --git a/drivers/md/raid1.c b/drivers/md/raid1.c index e07ce2e033a9..35b2d8646ae9 100644 --- a/drivers/md/raid1.c +++ b/drivers/md/raid1.c | |||
@@ -801,6 +801,25 @@ static int make_request(struct request_queue *q, struct bio * bio) | |||
801 | 801 | ||
802 | md_write_start(mddev, bio); /* wait on superblock update early */ | 802 | md_write_start(mddev, bio); /* wait on superblock update early */ |
803 | 803 | ||
804 | if (bio_data_dir(bio) == WRITE && | ||
805 | bio->bi_sector + bio->bi_size/512 > mddev->suspend_lo && | ||
806 | bio->bi_sector < mddev->suspend_hi) { | ||
807 | /* As the suspend_* range is controlled by | ||
808 | * userspace, we want an interruptible | ||
809 | * wait. | ||
810 | */ | ||
811 | DEFINE_WAIT(w); | ||
812 | for (;;) { | ||
813 | flush_signals(current); | ||
814 | prepare_to_wait(&conf->wait_barrier, | ||
815 | &w, TASK_INTERRUPTIBLE); | ||
816 | if (bio->bi_sector + bio->bi_size/512 <= mddev->suspend_lo || | ||
817 | bio->bi_sector >= mddev->suspend_hi) | ||
818 | break; | ||
819 | schedule(); | ||
820 | } | ||
821 | finish_wait(&conf->wait_barrier, &w); | ||
822 | } | ||
804 | if (unlikely(!mddev->barriers_work && | 823 | if (unlikely(!mddev->barriers_work && |
805 | bio_rw_flagged(bio, BIO_RW_BARRIER))) { | 824 | bio_rw_flagged(bio, BIO_RW_BARRIER))) { |
806 | if (rw == WRITE) | 825 | if (rw == WRITE) |
@@ -2271,6 +2290,9 @@ static void raid1_quiesce(mddev_t *mddev, int state) | |||
2271 | conf_t *conf = mddev->private; | 2290 | conf_t *conf = mddev->private; |
2272 | 2291 | ||
2273 | switch(state) { | 2292 | switch(state) { |
2293 | case 2: /* wake for suspend */ | ||
2294 | wake_up(&conf->wait_barrier); | ||
2295 | break; | ||
2274 | case 1: | 2296 | case 1: |
2275 | raise_barrier(conf); | 2297 | raise_barrier(conf); |
2276 | break; | 2298 | break; |