diff options
author | Chris Mason <chris.mason@oracle.com> | 2008-07-31 15:42:53 -0400 |
---|---|---|
committer | Chris Mason <chris.mason@oracle.com> | 2008-09-25 11:04:05 -0400 |
commit | 61b4944018449003ac5f9757f4d125dce519cf51 (patch) | |
tree | 553855996c641a945344db870b6dfd0d2d02086e /fs/btrfs/disk-io.c | |
parent | 37d1aeee3990385e9bb436c50c2f7e120a668df6 (diff) |
Btrfs: Fix streaming read performance with checksumming on
Large streaming reads make for large bios, which means each entry on the
list async work queues represents a large amount of data. IO
congestion throttling on the device was kicking in before the async
worker threads decided a single thread was busy and needed some help.
The end result was that a streaming read would result in a single CPU
running at 100% instead of balancing the work off to other CPUs.
This patch also changes the pre-IO checksum lookup done by reads to
work on a per-bio basis instead of a per-page. This results in many
extra btree lookups on large streaming reads. Doing the checksum lookup
right before bio submit allows us to reuse searches while processing
adjacent offsets.
Signed-off-by: Chris Mason <chris.mason@oracle.com>
Diffstat (limited to 'fs/btrfs/disk-io.c')
-rw-r--r-- | fs/btrfs/disk-io.c | 15 |
1 files changed, 15 insertions, 0 deletions
diff --git a/fs/btrfs/disk-io.c b/fs/btrfs/disk-io.c index e826730d750..d2d1cc87e8a 100644 --- a/fs/btrfs/disk-io.c +++ b/fs/btrfs/disk-io.c | |||
@@ -1357,10 +1357,25 @@ struct btrfs_root *open_ctree(struct super_block *sb, | |||
1357 | */ | 1357 | */ |
1358 | btrfs_init_workers(&fs_info->workers, fs_info->thread_pool_size); | 1358 | btrfs_init_workers(&fs_info->workers, fs_info->thread_pool_size); |
1359 | btrfs_init_workers(&fs_info->submit_workers, fs_info->thread_pool_size); | 1359 | btrfs_init_workers(&fs_info->submit_workers, fs_info->thread_pool_size); |
1360 | |||
1361 | /* a higher idle thresh on the submit workers makes it much more | ||
1362 | * likely that bios will be send down in a sane order to the | ||
1363 | * devices | ||
1364 | */ | ||
1365 | fs_info->submit_workers.idle_thresh = 64; | ||
1366 | |||
1360 | btrfs_init_workers(&fs_info->fixup_workers, 1); | 1367 | btrfs_init_workers(&fs_info->fixup_workers, 1); |
1361 | btrfs_init_workers(&fs_info->endio_workers, fs_info->thread_pool_size); | 1368 | btrfs_init_workers(&fs_info->endio_workers, fs_info->thread_pool_size); |
1362 | btrfs_init_workers(&fs_info->endio_write_workers, | 1369 | btrfs_init_workers(&fs_info->endio_write_workers, |
1363 | fs_info->thread_pool_size); | 1370 | fs_info->thread_pool_size); |
1371 | |||
1372 | /* | ||
1373 | * endios are largely parallel and should have a very | ||
1374 | * low idle thresh | ||
1375 | */ | ||
1376 | fs_info->endio_workers.idle_thresh = 4; | ||
1377 | fs_info->endio_write_workers.idle_thresh = 4; | ||
1378 | |||
1364 | btrfs_start_workers(&fs_info->workers, 1); | 1379 | btrfs_start_workers(&fs_info->workers, 1); |
1365 | btrfs_start_workers(&fs_info->submit_workers, 1); | 1380 | btrfs_start_workers(&fs_info->submit_workers, 1); |
1366 | btrfs_start_workers(&fs_info->fixup_workers, 1); | 1381 | btrfs_start_workers(&fs_info->fixup_workers, 1); |