Commit eca76e78 authored by Jaegeuk Kim's avatar Jaegeuk Kim

f2fs: avoid needless lock for node pages when fsyncing a file

When fsync is called, sync_node_pages finds a proper direct node pages to flush.
But, it locks unrelated direct node pages together unnecessarily.
Acked-by: default avatarChao Yu <yuchao0@huawei.com>
Signed-off-by: default avatarJaegeuk Kim <jaegeuk@kernel.org>
parent c27753d6
...@@ -1272,10 +1272,14 @@ int sync_node_pages(struct f2fs_sb_info *sbi, nid_t ino, ...@@ -1272,10 +1272,14 @@ int sync_node_pages(struct f2fs_sb_info *sbi, nid_t ino,
* we should not skip writing node pages. * we should not skip writing node pages.
*/ */
lock_node: lock_node:
if (ino && ino_of_node(page) == ino) if (ino) {
lock_page(page); if (ino_of_node(page) == ino)
else if (!trylock_page(page)) lock_page(page);
else
continue;
} else if (!trylock_page(page)) {
continue; continue;
}
if (unlikely(page->mapping != NODE_MAPPING(sbi))) { if (unlikely(page->mapping != NODE_MAPPING(sbi))) {
continue_unlock: continue_unlock:
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment