ext4: Add BUG_ON debugging checks to noalloc_get_block_write()
authorTheodore Ts'o <tytso@mit.edu>
Tue, 12 May 2009 17:51:29 +0000 (13:51 -0400)
committerTheodore Ts'o <tytso@mit.edu>
Tue, 12 May 2009 17:51:29 +0000 (13:51 -0400)
Enforce that noalloc_get_block_write() is only called to map one block
at a time, and that it always is successful in finding a mapping for
given an inode's logical block block number if it is called with
create == 1.

Signed-off-by: "Theodore Ts'o" <tytso@mit.edu>
fs/ext4/inode.c

index fd5f27a9b81bb28bd9e174f4df761ba9ab2ba4c4..e6113c3a126f8abbaa5697e589ecd2ad5ea7c16c 100644 (file)
@@ -2433,11 +2433,14 @@ static int noalloc_get_block_write(struct inode *inode, sector_t iblock,
        int ret = 0;
        unsigned max_blocks = bh_result->b_size >> inode->i_blkbits;
 
+       BUG_ON(bh_result->b_size != inode->i_sb->s_blocksize);
+
        /*
         * we don't want to do block allocation in writepage
         * so call get_block_wrap with create = 0
         */
        ret = ext4_get_blocks(NULL, inode, iblock, max_blocks, bh_result, 0);
+       BUG_ON(create && ret == 0);
        if (ret > 0) {
                bh_result->b_size = (ret << inode->i_blkbits);
                ret = 0;