2008-05-29 18:28:48

by Josef Bacik

[permalink] [raw]
Subject: [PATCH 2/2] EXT4: fix online resize bug

Hello,

There is a bug when we are trying to verify that the reserve inode's double
indirect blocks point back to the primary gdt blocks. The fix is obvious, we
need to mod the gdb count by the addr's per block. This was verified using the
same testcase as with the ext3 equivalent of this patch. Thank you,

Signed-off-by: Josef Bacik <[email protected]>


Index: linux-2.6/fs/ext4/resize.c
===================================================================
--- linux-2.6.orig/fs/ext4/resize.c
+++ linux-2.6/fs/ext4/resize.c
@@ -563,7 +563,8 @@ static int reserve_backup_gdb(handle_t *
}

blk = EXT4_SB(sb)->s_sbh->b_blocknr + 1 + EXT4_SB(sb)->s_gdb_count;
- data = (__le32 *)dind->b_data + EXT4_SB(sb)->s_gdb_count;
+ data = (__le32 *)dind->b_data + (EXT4_SB(sb)->s_gdb_count %
+ EXT4_ADDR_PER_BLOCK(sb));
end = (__le32 *)dind->b_data + EXT4_ADDR_PER_BLOCK(sb);

/* Get each reserved primary GDT block and verify it holds backups */


2008-06-05 01:53:48

by Theodore Ts'o

[permalink] [raw]
Subject: Re: [PATCH 2/2] EXT4: fix online resize bug

On Thu, May 29, 2008 at 02:19:41PM -0400, Josef Bacik wrote:
> Hello,
>
> There is a bug when we are trying to verify that the reserve inode's double
> indirect blocks point back to the primary gdt blocks. The fix is obvious, we
> need to mod the gdb count by the addr's per block. This was verified using the
> same testcase as with the ext3 equivalent of this patch. Thank you,
>
> Signed-off-by: Josef Bacik <[email protected]>

Signed-off-by: "Theodore Ts'o" <[email protected]>

- Ted