diff options
author | NeilBrown <neilb@suse.de> | 2011-10-11 01:50:01 -0400 |
---|---|---|
committer | NeilBrown <neilb@suse.de> | 2011-10-11 01:50:01 -0400 |
commit | 34db0cd60f8a1f4ab73d118a8be3797c20388223 (patch) | |
tree | 45d1d629d6b9195d47d30980595686c9a3ee92f9 /drivers/md/raid1.h | |
parent | 84fc4b56db85cb9e05326424049973a2036c9940 (diff) |
md: add proper write-congestion reporting to RAID1 and RAID10.
RAID1 and RAID10 handle write requests by queuing them for handling by
a separate thread. This is because when a write-intent-bitmap is
active we might need to update the bitmap first, so it is good to
queue a lot of writes, then do one big bitmap update for them all.
However writeback request devices to appear to be congested after a
while so it can make some guesstimate of throughput. The infinite
queue defeats that (note that RAID5 has already has a finite queue so
it doesn't suffer from this problem).
So impose a limit on the number of pending write requests. By default
it is 1024 which seems to be generally suitable. Make it configurable
via module option just in case someone finds a regression.
Signed-off-by: NeilBrown <neilb@suse.de>
Diffstat (limited to 'drivers/md/raid1.h')
-rw-r--r-- | drivers/md/raid1.h | 1 |
1 files changed, 1 insertions, 0 deletions
diff --git a/drivers/md/raid1.h b/drivers/md/raid1.h index 5b16d09817df..c732b6cce935 100644 --- a/drivers/md/raid1.h +++ b/drivers/md/raid1.h | |||
@@ -46,6 +46,7 @@ struct r1conf { | |||
46 | 46 | ||
47 | /* queue pending writes to be submitted on unplug */ | 47 | /* queue pending writes to be submitted on unplug */ |
48 | struct bio_list pending_bio_list; | 48 | struct bio_list pending_bio_list; |
49 | int pending_count; | ||
49 | 50 | ||
50 | /* for use when syncing mirrors: | 51 | /* for use when syncing mirrors: |
51 | * We don't allow both normal IO and resync/recovery IO at | 52 | * We don't allow both normal IO and resync/recovery IO at |