lists.openwall.net   lists  /  announce  owl-users  owl-dev  john-users  john-dev  passwdqc-users  yescrypt  popa3d-users  /  oss-security  kernel-hardening  musl  sabotage  tlsify  passwords  /  crypt-dev  xvendor  /  Bugtraq  Full-Disclosure  linux-kernel  linux-netdev  linux-ext4  linux-hardening  linux-cve-announce  PHC 
Open Source and information security mailing list archives
 
Hash Suite: Windows password security audit tool. GUI, reports in PDF.
[<prev] [next>] [thread-next>] [day] [month] [year] [list]
Date:	Wed, 17 Jun 2009 14:40:19 -0500
From:	Eric Sandeen <sandeen@...hat.com>
To:	ext4 development <linux-ext4@...r.kernel.org>
Subject: [PATCH, RFC] resize2fs: update sb backup journal if journal was moved

This was reported in Fedora, since the livecd creator does
a lot of resizing.

If we've moved the journal blocks during resize (likely now,
due to the journal being in the middle) the backup blocks don't
get updated, and a subsequent e2fsck will find issues:

e2fsck 1.41.6 (30-May-2009)
Backing up journal inode block information.

Pass 1: Checking inodes, blocks, and sizes
Pass 2: Checking directory structure
Pass 3: Checking directory connectivity
Pass 4: Checking reference counts
Pass 5: Checking group summary information

/mnt/test/img: ***** FILE SYSTEM WAS MODIFIED *****
/mnt/test/img: 11/16000 files (0.0% non-contiguous), 17789/38400 blocks

This can be shown in a simple test:

# dd if=/dev/zero of=img bs=1 count=0 seek=3000M
# mke2fs -t ext4 -F img
# resize2fs img 150M
# e2fsck -f img

(thanks to the Fedora reporter Mads Kiilerich!
https://bugzilla.redhat.com/show_bug.cgi?id=506105#c2)

The following is just rough; I'd at least move it to a helper function,
and needs some error checking.

But it does fix it.  Question is, should I do it unconditionally,
or only if the journal inode got moved?  Doing it conditionally
would require a bit more work to sort out whether it's been moved.

Or, I could just compare the two and overwrite it if they differ, vs
actually walking the backup blocks and see if any are off the end
of the filesystem... what seems best?

Signed-off-by: Eric Sandeen <sandeen@...hat.com>
---

diff --git a/resize/resize2fs.c b/resize/resize2fs.c
index 0d5dc81..acb338e 100644
--- a/resize/resize2fs.c
+++ b/resize/resize2fs.c
@@ -148,6 +148,17 @@ errcode_t resize_fs(ext2_filsys fs, blk_t *new_size, int flags,
 	if (retval)
 		goto errout;
 
+	if (rfs->new_fs->super->s_feature_compat & EXT3_FEATURE_COMPAT_HAS_JOURNAL) {
+		struct ext2_inode inode;
+
+		retval = ext2fs_read_inode(rfs->new_fs,
+			  rfs->new_fs->super->s_journal_inum, &inode);
+		memcpy(rfs->new_fs->super->s_jnl_blocks, inode.i_block, EXT2_N_BLOCKS*4);
+		rfs->new_fs->super->s_jnl_blocks[16] = inode.i_size;
+		rfs->new_fs->super->s_jnl_backup_type = EXT3_JNL_BACKUP_BLOCKS;
+		ext2fs_mark_super_dirty(fs);
+	}
+
 	rfs->new_fs->flags &= ~EXT2_FLAG_MASTER_SB_ONLY;
 	retval = ext2fs_close(rfs->new_fs);
 	if (retval)

--
To unsubscribe from this list: send the line "unsubscribe linux-ext4" in
the body of a message to majordomo@...r.kernel.org
More majordomo info at  http://vger.kernel.org/majordomo-info.html

Powered by blists - more mailing lists

Powered by Openwall GNU/*/Linux Powered by OpenVZ