aboutsummaryrefslogtreecommitdiffstats
path: root/fs/btrfs
diff options
context:
space:
mode:
authorChris Mason <chris.mason@oracle.com>2008-08-28 06:15:24 -0400
committerChris Mason <chris.mason@oracle.com>2008-09-25 11:04:07 -0400
commit9473f16c75606fe6b2e5000525fe9766114505f3 (patch)
tree93080f8a9bcf59170ce9b56b7e8b03fb4bfed8d9 /fs/btrfs
parentf3f9931e3d0836509cfccdf473b34e34543a3272 (diff)
Btrfs: Throttle for async bio submits higher up the chain
The current code waits for the count of async bio submits to get below a given threshold if it is too high right after adding the latest bio to the work queue. This isn't optimal because the caller may have sequential adjacent bios pending they are waiting to send down the pipe. This changeset requires the caller to wait on the async bio count, and changes the async checksumming submits to wait for async bios any time they self throttle. The end result is much higher sequential throughput. Signed-off-by: Chris Mason <chris.mason@oracle.com>
Diffstat (limited to 'fs/btrfs')
-rw-r--r--fs/btrfs/disk-io.c8
-rw-r--r--fs/btrfs/volumes.c6
2 files changed, 7 insertions, 7 deletions
diff --git a/fs/btrfs/disk-io.c b/fs/btrfs/disk-io.c
index bbba14b629d2..6a218f792e59 100644
--- a/fs/btrfs/disk-io.c
+++ b/fs/btrfs/disk-io.c
@@ -487,9 +487,15 @@ int btrfs_wq_submit_bio(struct btrfs_fs_info *fs_info, struct inode *inode,
487 atomic_inc(&fs_info->nr_async_submits); 487 atomic_inc(&fs_info->nr_async_submits);
488 btrfs_queue_worker(&fs_info->workers, &async->work); 488 btrfs_queue_worker(&fs_info->workers, &async->work);
489 489
490 wait_event_timeout(fs_info->async_submit_wait, 490 if (atomic_read(&fs_info->nr_async_submits) > limit) {
491 wait_event_timeout(fs_info->async_submit_wait,
491 (atomic_read(&fs_info->nr_async_submits) < limit), 492 (atomic_read(&fs_info->nr_async_submits) < limit),
492 HZ/10); 493 HZ/10);
494
495 wait_event_timeout(fs_info->async_submit_wait,
496 (atomic_read(&fs_info->nr_async_bios) < limit),
497 HZ/10);
498 }
493 return 0; 499 return 0;
494} 500}
495 501
diff --git a/fs/btrfs/volumes.c b/fs/btrfs/volumes.c
index 2652660e6079..5b1b60839d21 100644
--- a/fs/btrfs/volumes.c
+++ b/fs/btrfs/volumes.c
@@ -2145,7 +2145,6 @@ int schedule_bio(struct btrfs_root *root, struct btrfs_device *device,
2145 int rw, struct bio *bio) 2145 int rw, struct bio *bio)
2146{ 2146{
2147 int should_queue = 1; 2147 int should_queue = 1;
2148 unsigned long limit;
2149 2148
2150 /* don't bother with additional async steps for reads, right now */ 2149 /* don't bother with additional async steps for reads, right now */
2151 if (!(rw & (1 << BIO_RW))) { 2150 if (!(rw & (1 << BIO_RW))) {
@@ -2182,11 +2181,6 @@ int schedule_bio(struct btrfs_root *root, struct btrfs_device *device,
2182 if (should_queue) 2181 if (should_queue)
2183 btrfs_queue_worker(&root->fs_info->submit_workers, 2182 btrfs_queue_worker(&root->fs_info->submit_workers,
2184 &device->work); 2183 &device->work);
2185
2186 limit = btrfs_async_submit_limit(root->fs_info);
2187 wait_event_timeout(root->fs_info->async_submit_wait,
2188 (atomic_read(&root->fs_info->nr_async_bios) < limit),
2189 HZ/10);
2190 return 0; 2184 return 0;
2191} 2185}
2192 2186