|
|
a77133 |
From 0111635ea5798f98665714e161c3c7746184a04b Mon Sep 17 00:00:00 2001
|
|
|
a77133 |
From: Theodore Ts'o <tytso@mit.edu>
|
|
|
a77133 |
Date: Tue, 23 Feb 2021 16:02:42 -0500
|
|
|
a77133 |
Subject: [PATCH 21/46] Add checks for fs->blocksize == 0 which could cause
|
|
|
a77133 |
some crashes
|
|
|
a77133 |
Content-Type: text/plain
|
|
|
a77133 |
|
|
|
a77133 |
This should never happeb, but some checks is useful, and also fixes
|
|
|
a77133 |
some Coverity warnings.
|
|
|
a77133 |
|
|
|
a77133 |
Signed-off-by: Theodore Ts'o <tytso@mit.edu>
|
|
|
a77133 |
Signed-off-by: Lukas Czerner <lczerner@redhat.com>
|
|
|
a77133 |
---
|
|
|
a77133 |
debugfs/do_journal.c | 2 --
|
|
|
a77133 |
lib/ext2fs/csum.c | 3 +++
|
|
|
a77133 |
lib/ext2fs/ext2_err.et.in | 3 +++
|
|
|
a77133 |
lib/ext2fs/inode.c | 4 ++++
|
|
|
a77133 |
misc/e2image.c | 5 +++--
|
|
|
a77133 |
5 files changed, 13 insertions(+), 4 deletions(-)
|
|
|
a77133 |
|
|
|
a77133 |
diff --git a/debugfs/do_journal.c b/debugfs/do_journal.c
|
|
|
a77133 |
index 5091a530..8261fa95 100644
|
|
|
a77133 |
--- a/debugfs/do_journal.c
|
|
|
a77133 |
+++ b/debugfs/do_journal.c
|
|
|
a77133 |
@@ -528,8 +528,6 @@ static errcode_t journal_write(journal_t *journal,
|
|
|
a77133 |
}
|
|
|
a77133 |
|
|
|
a77133 |
err = journal_close_trans(&trans);
|
|
|
a77133 |
- if (err)
|
|
|
a77133 |
- goto error;
|
|
|
a77133 |
error:
|
|
|
a77133 |
return err;
|
|
|
a77133 |
}
|
|
|
a77133 |
diff --git a/lib/ext2fs/csum.c b/lib/ext2fs/csum.c
|
|
|
a77133 |
index 2151003b..28b3bb05 100644
|
|
|
a77133 |
--- a/lib/ext2fs/csum.c
|
|
|
a77133 |
+++ b/lib/ext2fs/csum.c
|
|
|
a77133 |
@@ -263,6 +263,9 @@ static errcode_t __get_dirent_tail(ext2_filsys fs,
|
|
|
a77133 |
errcode_t retval = 0;
|
|
|
a77133 |
__u16 (*translate)(__u16) = (need_swab ? disk_to_host16 : do_nothing16);
|
|
|
a77133 |
|
|
|
a77133 |
+ if (fs->blocksize < 1024)
|
|
|
a77133 |
+ return EXT2_FILSYS_CORRUPTED; /* Should never happen */
|
|
|
a77133 |
+
|
|
|
a77133 |
d = dirent;
|
|
|
a77133 |
top = EXT2_DIRENT_TAIL(dirent, fs->blocksize);
|
|
|
a77133 |
|
|
|
a77133 |
diff --git a/lib/ext2fs/ext2_err.et.in b/lib/ext2fs/ext2_err.et.in
|
|
|
a77133 |
index 0c76fee6..cf0e00ea 100644
|
|
|
a77133 |
--- a/lib/ext2fs/ext2_err.et.in
|
|
|
a77133 |
+++ b/lib/ext2fs/ext2_err.et.in
|
|
|
a77133 |
@@ -548,4 +548,7 @@ ec EXT2_ET_EA_INODE_CORRUPTED,
|
|
|
a77133 |
ec EXT2_ET_NO_GDESC,
|
|
|
a77133 |
"Group descriptors not loaded"
|
|
|
a77133 |
|
|
|
a77133 |
+ec EXT2_FILSYS_CORRUPTED,
|
|
|
a77133 |
+ "The internal ext2_filsys data structure appears to be corrupted"
|
|
|
a77133 |
+
|
|
|
a77133 |
end
|
|
|
a77133 |
diff --git a/lib/ext2fs/inode.c b/lib/ext2fs/inode.c
|
|
|
a77133 |
index c4377eeb..6f42882e 100644
|
|
|
a77133 |
--- a/lib/ext2fs/inode.c
|
|
|
a77133 |
+++ b/lib/ext2fs/inode.c
|
|
|
a77133 |
@@ -144,6 +144,8 @@ errcode_t ext2fs_open_inode_scan(ext2_filsys fs, int buffer_blocks,
|
|
|
a77133 |
errcode_t (*save_get_blocks)(ext2_filsys f, ext2_ino_t ino, blk_t *blocks);
|
|
|
a77133 |
|
|
|
a77133 |
EXT2_CHECK_MAGIC(fs, EXT2_ET_MAGIC_EXT2FS_FILSYS);
|
|
|
a77133 |
+ if (fs->blocksize < 1024)
|
|
|
a77133 |
+ return EXT2_FILSYS_CORRUPTED; /* Should never happen */
|
|
|
a77133 |
|
|
|
a77133 |
/*
|
|
|
a77133 |
* If fs->badblocks isn't set, then set it --- since the inode
|
|
|
a77133 |
@@ -764,6 +766,8 @@ errcode_t ext2fs_read_inode2(ext2_filsys fs, ext2_ino_t ino,
|
|
|
a77133 |
int cache_slot, fail_csum;
|
|
|
a77133 |
|
|
|
a77133 |
EXT2_CHECK_MAGIC(fs, EXT2_ET_MAGIC_EXT2FS_FILSYS);
|
|
|
a77133 |
+ if (fs->blocksize < 1024)
|
|
|
a77133 |
+ return EXT2_FILSYS_CORRUPTED; /* Should never happen */
|
|
|
a77133 |
|
|
|
a77133 |
/* Check to see if user has an override function */
|
|
|
a77133 |
if (fs->read_inode &&
|
|
|
a77133 |
diff --git a/misc/e2image.c b/misc/e2image.c
|
|
|
a77133 |
index 892c5371..195fabb2 100644
|
|
|
a77133 |
--- a/misc/e2image.c
|
|
|
a77133 |
+++ b/misc/e2image.c
|
|
|
a77133 |
@@ -892,8 +892,9 @@ static errcode_t initialize_qcow2_image(int fd, ext2_filsys fs,
|
|
|
a77133 |
int cluster_bits = get_bits_from_size(fs->blocksize);
|
|
|
a77133 |
struct ext2_super_block *sb = fs->super;
|
|
|
a77133 |
|
|
|
a77133 |
- if (fs->blocksize < 1024)
|
|
|
a77133 |
- return EINVAL; /* Can never happen, but just in case... */
|
|
|
a77133 |
+ /* Sbould never happen, but just in case... */
|
|
|
a77133 |
+ if (cluster_bits < 0)
|
|
|
a77133 |
+ return EXT2_FILSYS_CORRUPTED;
|
|
|
a77133 |
|
|
|
a77133 |
/* Allocate header */
|
|
|
a77133 |
ret = ext2fs_get_memzero(sizeof(struct ext2_qcow2_hdr), &header);
|
|
|
a77133 |
--
|
|
|
a77133 |
2.35.1
|
|
|
a77133 |
|