diff options
Diffstat (limited to 'fs/ext4/inode.c')
-rw-r--r-- | fs/ext4/inode.c | 16 |
1 files changed, 14 insertions, 2 deletions
diff --git a/fs/ext4/inode.c b/fs/ext4/inode.c index fa37f9504ece..72c694323492 100644 --- a/fs/ext4/inode.c +++ b/fs/ext4/inode.c | |||
@@ -767,7 +767,13 @@ failed: | |||
767 | /* Allocation failed, free what we already allocated */ | 767 | /* Allocation failed, free what we already allocated */ |
768 | for (i = 1; i <= n ; i++) { | 768 | for (i = 1; i <= n ; i++) { |
769 | BUFFER_TRACE(branch[i].bh, "call jbd2_journal_forget"); | 769 | BUFFER_TRACE(branch[i].bh, "call jbd2_journal_forget"); |
770 | ext4_journal_forget(handle, branch[i].bh); | 770 | /* |
771 | * Note: is_metadata is 0 because branch[i].bh is | ||
772 | * newly allocated, so there is no need to revoke the | ||
773 | * block. If we do, it's harmless, but not necessary. | ||
774 | */ | ||
775 | ext4_forget(handle, 0, inode, branch[i].bh, | ||
776 | branch[i].bh->b_blocknr); | ||
771 | } | 777 | } |
772 | for (i = 0; i < indirect_blks; i++) | 778 | for (i = 0; i < indirect_blks; i++) |
773 | ext4_free_blocks(handle, inode, new_blocks[i], 1, 0); | 779 | ext4_free_blocks(handle, inode, new_blocks[i], 1, 0); |
@@ -852,7 +858,13 @@ static int ext4_splice_branch(handle_t *handle, struct inode *inode, | |||
852 | err_out: | 858 | err_out: |
853 | for (i = 1; i <= num; i++) { | 859 | for (i = 1; i <= num; i++) { |
854 | BUFFER_TRACE(where[i].bh, "call jbd2_journal_forget"); | 860 | BUFFER_TRACE(where[i].bh, "call jbd2_journal_forget"); |
855 | ext4_journal_forget(handle, where[i].bh); | 861 | /* |
862 | * Note: is_metadata is 0 because branch[i].bh is | ||
863 | * newly allocated, so there is no need to revoke the | ||
864 | * block. If we do, it's harmless, but not necessary. | ||
865 | */ | ||
866 | ext4_forget(handle, 0, inode, where[i].bh, | ||
867 | where[i].bh->b_blocknr); | ||
856 | ext4_free_blocks(handle, inode, | 868 | ext4_free_blocks(handle, inode, |
857 | le32_to_cpu(where[i-1].key), 1, 0); | 869 | le32_to_cpu(where[i-1].key), 1, 0); |
858 | } | 870 | } |