diff options
| author | Jaegeuk Kim <jaegeuk@kernel.org> | 2015-12-23 17:17:47 -0500 |
|---|---|---|
| committer | Jaegeuk Kim <jaegeuk@kernel.org> | 2015-12-30 13:14:12 -0500 |
| commit | 4aa69d5667914dd0844d98ad84804b79a4845fa3 (patch) | |
| tree | 16b2012fcf7aa4718999d1f38b31d63eb44f01a4 /fs/f2fs | |
| parent | 2aadac085cf0ca3e0295988d4d1dbdeafc15a9f6 (diff) | |
f2fs: return early when trying to read null nid
If get_node_page() gets zero nid, we can return early without getting a wrong
page. For example, get_dnode_of_data() can try to do that.
Signed-off-by: Jaegeuk Kim <jaegeuk@kernel.org>
Diffstat (limited to 'fs/f2fs')
| -rw-r--r-- | fs/f2fs/node.c | 4 |
1 files changed, 4 insertions, 0 deletions
diff --git a/fs/f2fs/node.c b/fs/f2fs/node.c index 341de5d2353b..929265d20c32 100644 --- a/fs/f2fs/node.c +++ b/fs/f2fs/node.c | |||
| @@ -1059,6 +1059,10 @@ struct page *get_node_page(struct f2fs_sb_info *sbi, pgoff_t nid) | |||
| 1059 | { | 1059 | { |
| 1060 | struct page *page; | 1060 | struct page *page; |
| 1061 | int err; | 1061 | int err; |
| 1062 | |||
| 1063 | if (!nid) | ||
| 1064 | return ERR_PTR(-ENOENT); | ||
| 1065 | f2fs_bug_on(sbi, check_nid_range(sbi, nid)); | ||
| 1062 | repeat: | 1066 | repeat: |
| 1063 | page = grab_cache_page(NODE_MAPPING(sbi), nid); | 1067 | page = grab_cache_page(NODE_MAPPING(sbi), nid); |
| 1064 | if (!page) | 1068 | if (!page) |
