summaryrefslogtreecommitdiff
path: root/lib/mpi/mpi-cmp.c
diff options
context:
space:
mode:
authorQu Wenruo <wqu@suse.com>2022-10-10 18:36:07 +0800
committerDavid Sterba <dsterba@suse.com>2022-10-24 15:26:56 +0200
commitab4c54c643a01067669df8332b64e3f31b69e071 (patch)
tree4e7fc7142755fe3d85f795974a29e47ffb2acae7 /lib/mpi/mpi-cmp.c
parentf15fb2cd979a07fbfc666e2f04b8b30ec9233b2a (diff)
btrfs: raid56: avoid double freeing for rbio if full_stripe_write() failed
Currently if full_stripe_write() failed to allocate the pages for parity, it will call __free_raid_bio() first, then return -ENOMEM. But some caller of full_stripe_write() will also call __free_raid_bio() again, this would cause double freeing. And it's not a logically sound either, normally we should either free the memory at the same level where we allocated it, or let endio to handle everything. So this patch will solve the double freeing by make raid56_parity_write() to handle the error and free the rbio. Just like what we do in raid56_parity_recover(). Signed-off-by: Qu Wenruo <wqu@suse.com> Signed-off-by: David Sterba <dsterba@suse.com>
Diffstat (limited to 'lib/mpi/mpi-cmp.c')
0 files changed, 0 insertions, 0 deletions