* [PATCH] fix calculation of meta_bg descriptor backups
@ 2015-10-05 15:48 Andy Leiserson
2015-10-18 4:37 ` Theodore Ts'o
0 siblings, 1 reply; 2+ messages in thread
From: Andy Leiserson @ 2015-10-05 15:48 UTC (permalink / raw)
To: linux-ext4; +Cc: Andy Leiserson
"group" is the group where the backup will be placed, and is initialized
to zero in the declaration. This meant that backups for meta_bg
descriptors were erroneously written to group 1 and group
(desc_per_block-1).
Signed-off-by: Andy Leiserson <andy@leiserson.org>
---
fs/ext4/resize.c | 4 ++--
1 file changed, 2 insertions(+), 2 deletions(-)
diff --git a/fs/ext4/resize.c b/fs/ext4/resize.c
index cf0c472..c7c53fd 100644
--- a/fs/ext4/resize.c
+++ b/fs/ext4/resize.c
@@ -1040,7 +1040,7 @@ exit_free:
* do not copy the full number of backups at this time. The resize
* which changed s_groups_count will backup again.
*/
-static void update_backups(struct super_block *sb, int blk_off, char *data,
+static void update_backups(struct super_block *sb, sector_t blk_off, char *data,
int size, int meta_bg)
{
struct ext4_sb_info *sbi = EXT4_SB(sb);
@@ -1065,7 +1065,7 @@ static void update_backups(struct super_block *sb, int blk_off, char *data,
group = ext4_list_backups(sb, &three, &five, &seven);
last = sbi->s_groups_count;
} else {
- group = ext4_meta_bg_first_group(sb, group) + 1;
+ group = ext4_get_group_number(sb, blk_off) + 1;
last = (ext4_group_t)(group + EXT4_DESC_PER_BLOCK(sb) - 2);
}
--
2.5.3
^ permalink raw reply related [flat|nested] 2+ messages in thread
* Re: [PATCH] fix calculation of meta_bg descriptor backups
2015-10-05 15:48 [PATCH] fix calculation of meta_bg descriptor backups Andy Leiserson
@ 2015-10-18 4:37 ` Theodore Ts'o
0 siblings, 0 replies; 2+ messages in thread
From: Theodore Ts'o @ 2015-10-18 4:37 UTC (permalink / raw)
To: Andy Leiserson; +Cc: linux-ext4
On Mon, Oct 05, 2015 at 08:48:22AM -0700, Andy Leiserson wrote:
> "group" is the group where the backup will be placed, and is initialized
> to zero in the declaration. This meant that backups for meta_bg
> descriptors were erroneously written to group 1 and group
> (desc_per_block-1).
>
> Signed-off-by: Andy Leiserson <andy@leiserson.org>
Nice catch! I added to the commit description the following
reproduction information:
mke2fs -Fq -t ext4 -b 1024 -O ^resize_inode /tmp/foo.img 16G
truncate -s 24G /tmp/foo.img
losetup /dev/loop0 /tmp/foo.img
mount /dev/loop0 /mnt
resize2fs /dev/loop0
umount /dev/loop0
dd if=/dev/zero of=/dev/loop0 bs=1024 count=2
e2fsck -fy /dev/loop0
losetup -d /dev/loop0
Cheers,
- Ted
^ permalink raw reply [flat|nested] 2+ messages in thread
end of thread, other threads:[~2015-10-18 4:37 UTC | newest]
Thread overview: 2+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2015-10-05 15:48 [PATCH] fix calculation of meta_bg descriptor backups Andy Leiserson
2015-10-18 4:37 ` Theodore Ts'o
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).