ext4: fix unjournalled bg descriptor while initializing inode bitmap
authorTheodore Ts'o <tytso@mit.edu>
Sat, 5 Jul 2014 20:28:35 +0000 (16:28 -0400)
committerJiri Slaby <jslaby@suse.cz>
Fri, 18 Jul 2014 13:51:25 +0000 (15:51 +0200)
commit 61c219f5814277ecb71d64cb30297028d6665979 upstream.

The first time that we allocate from an uninitialized inode allocation
bitmap, if the block allocation bitmap is also uninitalized, we need
to get write access to the block group descriptor before we start
modifying the block group descriptor flags and updating the free block
count, etc.  Otherwise, there is the potential of a bad journal
checksum (if journal checksums are enabled), and of the file system
becoming inconsistent if we crash at exactly the wrong time.

Signed-off-by: Theodore Ts'o <tytso@mit.edu>
Signed-off-by: Jiri Slaby <jslaby@suse.cz>
fs/ext4/ialloc.c

index 137193ff389b88510f414499116c8a9ee858abe5..5b5971c20af13263e98774107a7979ac642bd236 100644 (file)
@@ -851,6 +851,13 @@ struct inode *__ext4_new_inode(handle_t *handle, struct inode *dir,
                goto out;
        }
 
+       BUFFER_TRACE(group_desc_bh, "get_write_access");
+       err = ext4_journal_get_write_access(handle, group_desc_bh);
+       if (err) {
+               ext4_std_error(sb, err);
+               goto out;
+       }
+
        /* We may have to initialize the block bitmap if it isn't already */
        if (ext4_has_group_desc_csum(sb) &&
            gdp->bg_flags & cpu_to_le16(EXT4_BG_BLOCK_UNINIT)) {
@@ -887,13 +894,6 @@ struct inode *__ext4_new_inode(handle_t *handle, struct inode *dir,
                }
        }
 
-       BUFFER_TRACE(group_desc_bh, "get_write_access");
-       err = ext4_journal_get_write_access(handle, group_desc_bh);
-       if (err) {
-               ext4_std_error(sb, err);
-               goto out;
-       }
-
        /* Update the relevant bg descriptor fields */
        if (ext4_has_group_desc_csum(sb)) {
                int free;