aboutsummaryrefslogtreecommitdiffstats
path: root/fs/ext4/extents.c
diff options
context:
space:
mode:
authorVivek Haldar <haldar@google.com>2011-05-22 21:24:16 -0400
committerTheodore Ts'o <tytso@mit.edu>2011-05-22 21:24:16 -0400
commit77f4135f2a219a2127be6cc1208c42e6175b11dd (patch)
tree8f85549d2354c5a69a5b29197f68a554daad1324 /fs/ext4/extents.c
parent93917411be8db5d21abf15c781dfa43c5cc6edf2 (diff)
ext4: count hits/misses of extent cache and expose in sysfs
The number of hits and misses for each filesystem is exposed in /sys/fs/ext4/<dev>/extent_cache_{hits, misses}. Tested: fsstress, manual checks. Signed-off-by: Vivek Haldar <haldar@google.com> Signed-off-by: "Theodore Ts'o" <tytso@mit.edu>
Diffstat (limited to 'fs/ext4/extents.c')
-rw-r--r--fs/ext4/extents.c7
1 files changed, 6 insertions, 1 deletions
diff --git a/fs/ext4/extents.c b/fs/ext4/extents.c
index 9a3844adb1cb..4444317d141a 100644
--- a/fs/ext4/extents.c
+++ b/fs/ext4/extents.c
@@ -2035,6 +2035,7 @@ ext4_ext_in_cache(struct inode *inode, ext4_lblk_t block,
2035 struct ext4_extent *ex) 2035 struct ext4_extent *ex)
2036{ 2036{
2037 struct ext4_ext_cache *cex; 2037 struct ext4_ext_cache *cex;
2038 struct ext4_sb_info *sbi;
2038 int ret = 0; 2039 int ret = 0;
2039 2040
2040 /* 2041 /*
@@ -2042,6 +2043,7 @@ ext4_ext_in_cache(struct inode *inode, ext4_lblk_t block,
2042 */ 2043 */
2043 spin_lock(&EXT4_I(inode)->i_block_reservation_lock); 2044 spin_lock(&EXT4_I(inode)->i_block_reservation_lock);
2044 cex = &EXT4_I(inode)->i_cached_extent; 2045 cex = &EXT4_I(inode)->i_cached_extent;
2046 sbi = EXT4_SB(inode->i_sb);
2045 2047
2046 /* has cache valid data? */ 2048 /* has cache valid data? */
2047 if (cex->ec_len == 0) 2049 if (cex->ec_len == 0)
@@ -2057,6 +2059,10 @@ ext4_ext_in_cache(struct inode *inode, ext4_lblk_t block,
2057 ret = 1; 2059 ret = 1;
2058 } 2060 }
2059errout: 2061errout:
2062 if (!ret)
2063 sbi->extent_cache_misses++;
2064 else
2065 sbi->extent_cache_hits++;
2060 spin_unlock(&EXT4_I(inode)->i_block_reservation_lock); 2066 spin_unlock(&EXT4_I(inode)->i_block_reservation_lock);
2061 return ret; 2067 return ret;
2062} 2068}
@@ -3901,4 +3907,3 @@ int ext4_fiemap(struct inode *inode, struct fiemap_extent_info *fieinfo,
3901 3907
3902 return error; 3908 return error;
3903} 3909}
3904