diff options
author | Miao Xie <miaox@cn.fujitsu.com> | 2013-07-22 04:36:57 -0400 |
---|---|---|
committer | Chris Mason <chris.mason@fusionio.com> | 2013-09-01 08:04:27 -0400 |
commit | 3cd846d1d7640dd6b64d251cb9efd1a490d9a601 (patch) | |
tree | 081b99d7d8e80ebfa0bbe87ad10b86987e70b4d5 /fs/btrfs/raid56.c | |
parent | 3dc0e818afa25a605091b6a16c2c4e5698c0a9c2 (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.c | 4 |
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) |