linux/fs/gfs2
Hisashi Hifumi 229615def3 GFS2: Pagecache usage optimization on GFS2
I introduced "is_partially_uptodate" aops for GFS2.

A page can have multiple buffers and even if a page is not uptodate, some buffers
can be uptodate on pagesize != blocksize environment.
This aops checks that all buffers which correspond to a part of a file
that we want to read are uptodate. If so, we do not have to issue actual
read IO to HDD even if a page is not uptodate because the portion we
want to read are uptodate.
"block_is_partially_uptodate" function is already used by ext2/3/4.
With the following patch random read/write mixed workloads or random read after
random write workloads can be optimized and we can get performance improvement.

I did a performance test using the sysbench.

#sysbench --num-threads=16 --max-requests=200000 --test=fileio --file-num=1
--file-block-size=8K --file-total-size=2G --file-test-mode=rndrw --file-fsync-freq=0
--file-rw-ratio=1 run

-2.6.29-rc6
Test execution summary:
    total time:                          202.6389s
    total number of events:              200000
    total time taken by event execution: 2580.0480
    per-request statistics:
         min:                            0.0000s
         avg:                            0.0129s
         max:                            49.5852s
         approx.  95 percentile:         0.0462s

-2.6.29-rc6-patched
Test execution summary:
    total time:                          177.8639s
    total number of events:              200000
    total time taken by event execution: 2419.0199
    per-request statistics:
         min:                            0.0000s
         avg:                            0.0121s
         max:                            52.4306s
         approx.  95 percentile:         0.0444s

arch: ia64
pagesize: 16k
blocksize: 4k

Signed-off-by: Hisashi Hifumi <hifumi.hisashi@oss.ntt.co.jp>
Signed-off-by: Steven Whitehouse <swhiteho@redhat.com>
2009-03-24 11:21:25 +00:00
..
acl.c GFS2: Merge lock_dlm module into GFS2 2009-03-24 11:21:14 +00:00
acl.h [GFS2] Remove gfs2_check_acl() 2006-11-30 10:37:32 -05:00
bmap.c GFS2: Merge lock_dlm module into GFS2 2009-03-24 11:21:14 +00:00
bmap.h GFS2: Streamline alloc calculations for writes 2009-01-05 07:39:17 +00:00
dir.c GFS2: Merge lock_dlm module into GFS2 2009-03-24 11:21:14 +00:00
dir.h GFS2: Fix bug in gfs2_lock_fs_check_clean() 2009-01-05 07:39:11 +00:00
eaops.c GFS2: Merge lock_dlm module into GFS2 2009-03-24 11:21:14 +00:00
eaops.h [GFS2] mark struct *_operations const 2007-10-10 08:55:03 +01:00
eattr.c GFS2: Merge lock_dlm module into GFS2 2009-03-24 11:21:14 +00:00
eattr.h [GFS2] gfs2 misc endianness annotations 2006-11-30 10:33:46 -05:00
gfs2.h [GFS2] Remove remote lock dropping code 2008-06-27 09:39:44 +01:00
glock.c GFS2: Add a "demote a glock" interface to sysfs 2009-03-24 11:21:22 +00:00
glock.h GFS2: Merge lock_dlm module into GFS2 2009-03-24 11:21:14 +00:00
glops.c GFS2: Add a "demote a glock" interface to sysfs 2009-03-24 11:21:22 +00:00
glops.h GFS2: Add a "demote a glock" interface to sysfs 2009-03-24 11:21:22 +00:00
incore.h GFS2: Expose UUID via sysfs/uevent 2009-03-24 11:21:21 +00:00
inode.c GFS2: Merge lock_dlm module into GFS2 2009-03-24 11:21:14 +00:00
inode.h GFS2: Merge lock_dlm module into GFS2 2009-03-24 11:21:14 +00:00
Kconfig GFS2: Merge lock_dlm module into GFS2 2009-03-24 11:21:14 +00:00
lock_dlm.c GFS2: Merge lock_dlm module into GFS2 2009-03-24 11:21:14 +00:00
log.c GFS2: Merge lock_dlm module into GFS2 2009-03-24 11:21:14 +00:00
log.h [GFS2] trivial sparse lock annotations 2008-06-27 09:39:31 +01:00
lops.c GFS2: Merge lock_dlm module into GFS2 2009-03-24 11:21:14 +00:00
lops.h [GFS2] Only do lo_incore_commit once 2008-03-31 10:39:54 +01:00
main.c GFS2: Merge lock_dlm module into GFS2 2009-03-24 11:21:14 +00:00
Makefile GFS2: Merge lock_dlm module into GFS2 2009-03-24 11:21:14 +00:00
meta_io.c GFS2: Merge lock_dlm module into GFS2 2009-03-24 11:21:14 +00:00
meta_io.h [GFS2] Clean up the glock core 2008-06-27 09:39:22 +01:00
mount.c GFS2: Support quota/noquota mount arguments 2009-03-24 11:21:23 +00:00
ops_address.c GFS2: Pagecache usage optimization on GFS2 2009-03-24 11:21:25 +00:00
ops_address.h [GFS2] Remove function gfs2_get_block 2008-01-25 08:08:25 +00:00
ops_dentry.c GFS2: Merge lock_dlm module into GFS2 2009-03-24 11:21:14 +00:00
ops_export.c GFS2: Merge lock_dlm module into GFS2 2009-03-24 11:21:14 +00:00
ops_file.c GFS2: Merge lock_dlm module into GFS2 2009-03-24 11:21:14 +00:00
ops_fstype.c GFS2: Expose UUID via sysfs/uevent 2009-03-24 11:21:21 +00:00
ops_inode.c GFS2: Merge lock_dlm module into GFS2 2009-03-24 11:21:14 +00:00
ops_super.c GFS2: Support generation of discard requests 2009-03-24 11:21:20 +00:00
quota.c GFS2: Merge lock_dlm module into GFS2 2009-03-24 11:21:14 +00:00
quota.h GFS2: change gfs2_quota_scan into a shrinker 2009-03-24 11:21:12 +00:00
recovery.c GFS2: Merge lock_dlm module into GFS2 2009-03-24 11:21:14 +00:00
recovery.h GFS2: Move gfs2_recoverd into recovery.c 2009-01-05 07:39:07 +00:00
rgrp.c GFS2: fix sparse warning: Should it be static? 2009-03-24 11:21:25 +00:00
rgrp.h [GFS2] Add extent allocation to block allocator 2008-03-31 10:40:47 +01:00
super.c GFS2: Merge lock_dlm module into GFS2 2009-03-24 11:21:14 +00:00
super.h GFS2: Fix remount argument parsing 2009-03-24 11:21:10 +00:00
sys.c GFS2: Add a "demote a glock" interface to sysfs 2009-03-24 11:21:22 +00:00
sys.h GFS2: Remove ancient, unused code 2009-01-05 07:39:13 +00:00
trans.c GFS2: Fix deadlock on journal flush 2009-03-24 11:21:18 +00:00
trans.h [GFS2] Update gfs2_trans_add_unrevoke to accept extents 2008-03-31 10:40:42 +01:00
util.c GFS2: Merge lock_dlm module into GFS2 2009-03-24 11:21:14 +00:00
util.h GFS2: Clean up & move gfs2_quotad 2009-01-05 07:39:05 +00:00