diff options
author | Richard Yao <[email protected]> | 2014-07-11 14:35:58 -0400 |
---|---|---|
committer | Brian Behlendorf <[email protected]> | 2017-05-04 18:00:27 -0400 |
commit | bc17f1047a83cc8c4065e0ef84333a0d9b9d73aa (patch) | |
tree | 240277a2f851d5bcfe4839dcb7e720dd58662945 /config/kernel-blk-queue-bdi.m4 | |
parent | 5731140eaf4aaf2526a8bfdbfe250195842e79eb (diff) |
Enable Linux read-ahead for a single page on ZVOLs
Linux has read-ahead logic designed to accelerate sequential workloads.
ZFS has its own read-ahead logic called zprefetch that operates on both
ZVOLs and datasets. Having two prefetchers active at the same time can
cause overprefetching, which unnecessarily reduces IOPS performance on
CoW filesystems like ZFS.
Testing shows that entirely disabling the Linux prefetch results in
a significant performance penalty for reads while commensurate benefits
are seen in random writes. It appears that read-ahead benefits are
inversely proportional to random write benefits, and so a single page
of Linux-layer read-ahead appears to offer the middle ground for both
workloads.
Reviewed-by: Chunwei Chen <[email protected]>
Reviewed-by: Brian Behlendorf <[email protected]>
Signed-off-by: Richard Yao <[email protected]>
Issue #5902
Diffstat (limited to 'config/kernel-blk-queue-bdi.m4')
-rw-r--r-- | config/kernel-blk-queue-bdi.m4 | 20 |
1 files changed, 20 insertions, 0 deletions
diff --git a/config/kernel-blk-queue-bdi.m4 b/config/kernel-blk-queue-bdi.m4 new file mode 100644 index 000000000..816471166 --- /dev/null +++ b/config/kernel-blk-queue-bdi.m4 @@ -0,0 +1,20 @@ +dnl # +dnl # 2.6.32 - 4.11, statically allocated bdi in request_queue +dnl # 4.12 - x.y, dynamically allocated bdi in request_queue +dnl # +AC_DEFUN([ZFS_AC_KERNEL_BLK_QUEUE_BDI], [ + AC_MSG_CHECKING([whether blk_queue bdi is dynamic]) + ZFS_LINUX_TRY_COMPILE([ + #include <linux/blkdev.h> + ],[ + struct request_queue q; + struct backing_dev_info bdi; + q.backing_dev_info = &bdi; + ],[ + AC_MSG_RESULT(yes) + AC_DEFINE(HAVE_BLK_QUEUE_BDI_DYNAMIC, 1, + [blk queue backing_dev_info is dynamic]) + ],[ + AC_MSG_RESULT(no) + ]) +]) |