aboutsummaryrefslogtreecommitdiffstats
path: root/fs
diff options
context:
space:
mode:
Diffstat (limited to 'fs')
-rw-r--r--fs/ext3/dir.c14
-rw-r--r--fs/ext4/dir.c14
2 files changed, 16 insertions, 12 deletions
diff --git a/fs/ext3/dir.c b/fs/ext3/dir.c
index 852869840f24..3c6d384a2c66 100644
--- a/fs/ext3/dir.c
+++ b/fs/ext3/dir.c
@@ -136,12 +136,14 @@ static int ext3_readdir(struct file * filp,
136 err = ext3_get_blocks_handle(NULL, inode, blk, 1, 136 err = ext3_get_blocks_handle(NULL, inode, blk, 1,
137 &map_bh, 0, 0); 137 &map_bh, 0, 0);
138 if (err > 0) { 138 if (err > 0) {
139 page_cache_readahead(sb->s_bdev->bd_inode->i_mapping, 139 pgoff_t index = map_bh.b_blocknr >>
140 &filp->f_ra, 140 (PAGE_CACHE_SHIFT - inode->i_blkbits);
141 filp, 141 if (!ra_has_index(&filp->f_ra, index))
142 map_bh.b_blocknr >> 142 page_cache_readahead_ondemand(
143 (PAGE_CACHE_SHIFT - inode->i_blkbits), 143 sb->s_bdev->bd_inode->i_mapping,
144 1); 144 &filp->f_ra, filp,
145 NULL, index, 1);
146 filp->f_ra.prev_index = index;
145 bh = ext3_bread(NULL, inode, blk, 0, &err); 147 bh = ext3_bread(NULL, inode, blk, 0, &err);
146 } 148 }
147 149
diff --git a/fs/ext4/dir.c b/fs/ext4/dir.c
index e8ad06e28318..0a872a09fed8 100644
--- a/fs/ext4/dir.c
+++ b/fs/ext4/dir.c
@@ -135,12 +135,14 @@ static int ext4_readdir(struct file * filp,
135 map_bh.b_state = 0; 135 map_bh.b_state = 0;
136 err = ext4_get_blocks_wrap(NULL, inode, blk, 1, &map_bh, 0, 0); 136 err = ext4_get_blocks_wrap(NULL, inode, blk, 1, &map_bh, 0, 0);
137 if (err > 0) { 137 if (err > 0) {
138 page_cache_readahead(sb->s_bdev->bd_inode->i_mapping, 138 pgoff_t index = map_bh.b_blocknr >>
139 &filp->f_ra, 139 (PAGE_CACHE_SHIFT - inode->i_blkbits);
140 filp, 140 if (!ra_has_index(&filp->f_ra, index))
141 map_bh.b_blocknr >> 141 page_cache_readahead_ondemand(
142 (PAGE_CACHE_SHIFT - inode->i_blkbits), 142 sb->s_bdev->bd_inode->i_mapping,
143 1); 143 &filp->f_ra, filp,
144 NULL, index, 1);
145 filp->f_ra.prev_index = index;
144 bh = ext4_bread(NULL, inode, blk, 0, &err); 146 bh = ext4_bread(NULL, inode, blk, 0, &err);
145 } 147 }
146 148