diff options
author | Miao Xie <miaox@cn.fujitsu.com> | 2012-09-20 00:14:29 -0400 |
---|---|---|
committer | Chris Mason <chris.mason@fusionio.com> | 2012-10-09 09:15:38 -0400 |
commit | e8830e606ffee383f073e32313f11fc5692813fe (patch) | |
tree | 1d11a33e8d59736ad35018da316383eb64c63527 /fs/btrfs/transaction.c | |
parent | d24bec3ae528a47149b838aad76c006d40fe8a39 (diff) |
Btrfs: fix memory leak in start_transaction()
This patch fixes memory leak of the transaction handle which happened
when starting transaction failed on a freezed fs.
Signed-off-by: Miao Xie <miaox@cn.fujitsu.com>
Diffstat (limited to 'fs/btrfs/transaction.c')
-rw-r--r-- | fs/btrfs/transaction.c | 4 |
1 files changed, 3 insertions, 1 deletions
diff --git a/fs/btrfs/transaction.c b/fs/btrfs/transaction.c index 910ff8051ba9..35489644c247 100644 --- a/fs/btrfs/transaction.c +++ b/fs/btrfs/transaction.c | |||
@@ -351,8 +351,10 @@ again: | |||
351 | */ | 351 | */ |
352 | if (type != TRANS_JOIN_NOLOCK && | 352 | if (type != TRANS_JOIN_NOLOCK && |
353 | !__sb_start_write(root->fs_info->sb, SB_FREEZE_FS, false)) { | 353 | !__sb_start_write(root->fs_info->sb, SB_FREEZE_FS, false)) { |
354 | if (type == TRANS_JOIN_FREEZE) | 354 | if (type == TRANS_JOIN_FREEZE) { |
355 | kmem_cache_free(btrfs_trans_handle_cachep, h); | ||
355 | return ERR_PTR(-EPERM); | 356 | return ERR_PTR(-EPERM); |
357 | } | ||
356 | sb_start_intwrite(root->fs_info->sb); | 358 | sb_start_intwrite(root->fs_info->sb); |
357 | } | 359 | } |
358 | 360 | ||