aboutsummaryrefslogtreecommitdiffstats
path: root/fs/btrfs/raid56.c
diff options
context:
space:
mode:
authorMiao Xie <miaox@cn.fujitsu.com>2013-07-22 04:36:57 -0400
committerChris Mason <chris.mason@fusionio.com>2013-09-01 08:04:27 -0400
commit3cd846d1d7640dd6b64d251cb9efd1a490d9a601 (patch)
tree081b99d7d8e80ebfa0bbe87ad10b86987e70b4d5 /fs/btrfs/raid56.c
parent3dc0e818afa25a605091b6a16c2c4e5698c0a9c2 (diff)
Btrfs, raid56: fix memory leak when allocating pages for p/q stripes failed
Signed-off-by: Miao Xie <miaox@cn.fujitsu.com> Signed-off-by: Josef Bacik <jbacik@fusionio.com> Signed-off-by: Chris Mason <chris.mason@fusionio.com>
Diffstat (limited to 'fs/btrfs/raid56.c')
-rw-r--r--fs/btrfs/raid56.c4
1 files changed, 3 insertions, 1 deletions
diff --git a/fs/btrfs/raid56.c b/fs/btrfs/raid56.c
index 0db856ceecc4..d0ecfbd9cc9f 100644
--- a/fs/btrfs/raid56.c
+++ b/fs/btrfs/raid56.c
@@ -1540,8 +1540,10 @@ static int full_stripe_write(struct btrfs_raid_bio *rbio)
1540 int ret; 1540 int ret;
1541 1541
1542 ret = alloc_rbio_parity_pages(rbio); 1542 ret = alloc_rbio_parity_pages(rbio);
1543 if (ret) 1543 if (ret) {
1544 __free_raid_bio(rbio);
1544 return ret; 1545 return ret;
1546 }
1545 1547
1546 ret = lock_stripe_add(rbio); 1548 ret = lock_stripe_add(rbio);
1547 if (ret == 0) 1549 if (ret == 0)