f2fs: sanity check segment count
authorJin Qian <jinqian@google.com>
Tue, 25 Apr 2017 23:28:48 +0000 (16:28 -0700)
committerSasha Levin <alexander.levin@verizon.com>
Tue, 13 Jun 2017 13:29:21 +0000 (09:29 -0400)
[ Upstream commit b9dd46188edc2f0d1f37328637860bb65a771124 ]

F2FS uses 4 bytes to represent block address. As a result, supported
size of disk is 16 TB and it equals to 16 * 1024 * 1024 / 2 segments.

Signed-off-by: Jin Qian <jinqian@google.com>
Signed-off-by: Jaegeuk Kim <jaegeuk@kernel.org>
Signed-off-by: Sasha Levin <alexander.levin@verizon.com>
fs/f2fs/super.c
include/linux/f2fs_fs.h

index 37f61388a64d285344b505f9fad01c8a9436036f..660183e9ab7c012862abd7d4e4844c959f68adf5 100644 (file)
@@ -960,6 +960,13 @@ static int sanity_check_raw_super(struct super_block *sb,
                return 1;
        }
 
+       if (le32_to_cpu(raw_super->segment_count) > F2FS_MAX_SEGMENT) {
+               f2fs_msg(sb, KERN_INFO,
+                       "Invalid segment count (%u)",
+                       le32_to_cpu(raw_super->segment_count));
+               return 1;
+       }
+
        /* check CP/SIT/NAT/SSA/MAIN_AREA area boundary */
        if (sanity_check_area_boundary(sb, raw_super))
                return 1;
index 591f8c3ef41091c30bc8eadbbe10ffecf232ad9a..eab77da75b7cceab766fb8b9c5a708ae722fff10 100644 (file)
@@ -275,6 +275,12 @@ struct f2fs_nat_block {
 #define SIT_VBLOCK_MAP_SIZE 64
 #define SIT_ENTRY_PER_BLOCK (PAGE_CACHE_SIZE / sizeof(struct f2fs_sit_entry))
 
+/*
+ * F2FS uses 4 bytes to represent block address. As a result, supported size of
+ * disk is 16 TB and it equals to 16 * 1024 * 1024 / 2 segments.
+ */
+#define F2FS_MAX_SEGMENT       ((16 * 1024 * 1024) / 2)
+
 /*
  * Note that f2fs_sit_entry->vblocks has the following bit-field information.
  * [15:10] : allocation type such as CURSEG_XXXX_TYPE