]> git.ipfire.org Git - thirdparty/linux.git/commitdiff
f2fs: validate compress cache inode only when enabled
authorWenjie Qi <qwjhust@gmail.com>
Thu, 21 May 2026 03:16:18 +0000 (11:16 +0800)
committerJaegeuk Kim <jaegeuk@kernel.org>
Mon, 22 Jun 2026 19:52:35 +0000 (19:52 +0000)
F2FS_COMPRESS_INO() uses NM_I(sbi)->max_nid as the synthetic inode
number for the compressed page cache inode. That inode only exists when
the compress_cache mount option is enabled.

When compress_cache is disabled, max_nid is outside the valid inode
range. A corrupted directory entry that points to ino == max_nid should
therefore be rejected by f2fs_check_nid_range(). However, is_meta_ino()
currently treats F2FS_COMPRESS_INO() as a meta inode unconditionally,
so f2fs_iget() bypasses do_read_inode() and its nid range check, and
instantiates a fake internal inode instead.

Gate the compressed cache inode case on COMPRESS_CACHE, matching
f2fs_init_compress_inode(). With compress_cache disabled, ino ==
max_nid now follows the normal inode path and is rejected as an
out-of-range nid.

Cc: stable@kernel.org
Fixes: 6ce19aff0b8c ("f2fs: compress: add compress_inode to cache compressed blocks")
Signed-off-by: Wenjie Qi <qiwenjie@xiaomi.com>
Reviewed-by: Chao Yu <chao@kernel.org>
Signed-off-by: Jaegeuk Kim <jaegeuk@kernel.org>
fs/f2fs/inode.c

index 939d75663a4078204cbdaeed2fd193b916f8e472..25f30b8eadc53c1b8aeddab4faa0d95f51552e65 100644 (file)
@@ -564,8 +564,13 @@ static int do_read_inode(struct inode *inode)
 
 static bool is_meta_ino(struct f2fs_sb_info *sbi, unsigned int ino)
 {
-       return ino == F2FS_NODE_INO(sbi) || ino == F2FS_META_INO(sbi) ||
-               ino == F2FS_COMPRESS_INO(sbi);
+       if (ino == F2FS_NODE_INO(sbi) || ino == F2FS_META_INO(sbi))
+               return true;
+#ifdef CONFIG_F2FS_FS_COMPRESSION
+       if (test_opt(sbi, COMPRESS_CACHE) && ino == F2FS_COMPRESS_INO(sbi))
+               return true;
+#endif
+       return false;
 }
 
 struct inode *f2fs_iget(struct super_block *sb, unsigned long ino)