|
|
@@ -870,11 +870,6 @@ static int f2fs_readdir(struct file *file, struct dir_context *ctx)
|
|
|
goto out_free;
|
|
|
}
|
|
|
|
|
|
- /* readahead for multi pages of dir */
|
|
|
- if (npages - n > 1 && !ra_has_index(ra, n))
|
|
|
- page_cache_sync_readahead(inode->i_mapping, ra, file, n,
|
|
|
- min(npages - n, (pgoff_t)MAX_DIR_RA_PAGES));
|
|
|
-
|
|
|
for (; n < npages; n++) {
|
|
|
|
|
|
/* allow readdir() to be interrupted */
|
|
|
@@ -884,6 +879,11 @@ static int f2fs_readdir(struct file *file, struct dir_context *ctx)
|
|
|
}
|
|
|
cond_resched();
|
|
|
|
|
|
+ /* readahead for multi pages of dir */
|
|
|
+ if (npages - n > 1 && !ra_has_index(ra, n))
|
|
|
+ page_cache_sync_readahead(inode->i_mapping, ra, file, n,
|
|
|
+ min(npages - n, (pgoff_t)MAX_DIR_RA_PAGES));
|
|
|
+
|
|
|
dentry_page = get_lock_data_page(inode, n, false);
|
|
|
if (IS_ERR(dentry_page)) {
|
|
|
err = PTR_ERR(dentry_page);
|