diff options
-rw-r--r-- | fs/ext4/inode.c | 5 | ||||
-rw-r--r-- | fs/ext4/mballoc.c | 2 |
2 files changed, 7 insertions, 0 deletions
diff --git a/fs/ext4/inode.c b/fs/ext4/inode.c index 58604fe11f4f..077c3c9c432e 100644 --- a/fs/ext4/inode.c +++ b/fs/ext4/inode.c | |||
@@ -761,6 +761,11 @@ static int ext4_alloc_branch(handle_t *handle, struct inode *inode, | |||
761 | * parent to disk. | 761 | * parent to disk. |
762 | */ | 762 | */ |
763 | bh = sb_getblk(inode->i_sb, new_blocks[n-1]); | 763 | bh = sb_getblk(inode->i_sb, new_blocks[n-1]); |
764 | if (unlikely(!bh)) { | ||
765 | err = -EIO; | ||
766 | goto failed; | ||
767 | } | ||
768 | |||
764 | branch[n].bh = bh; | 769 | branch[n].bh = bh; |
765 | lock_buffer(bh); | 770 | lock_buffer(bh); |
766 | BUFFER_TRACE(bh, "call get_create_access"); | 771 | BUFFER_TRACE(bh, "call get_create_access"); |
diff --git a/fs/ext4/mballoc.c b/fs/ext4/mballoc.c index d732ef5a835d..611c866ef3fe 100644 --- a/fs/ext4/mballoc.c +++ b/fs/ext4/mballoc.c | |||
@@ -4537,6 +4537,8 @@ void ext4_free_blocks(handle_t *handle, struct inode *inode, | |||
4537 | if (!bh) | 4537 | if (!bh) |
4538 | tbh = sb_find_get_block(inode->i_sb, | 4538 | tbh = sb_find_get_block(inode->i_sb, |
4539 | block + i); | 4539 | block + i); |
4540 | if (unlikely(!tbh)) | ||
4541 | continue; | ||
4540 | ext4_forget(handle, flags & EXT4_FREE_BLOCKS_METADATA, | 4542 | ext4_forget(handle, flags & EXT4_FREE_BLOCKS_METADATA, |
4541 | inode, tbh, block + i); | 4543 | inode, tbh, block + i); |
4542 | } | 4544 | } |