]> www.infradead.org Git - users/dwmw2/linux.git/commit
media: venus: vdec: fixed possible memory leak issue
authorAmeer Hamza <amhamza.mgc@gmail.com>
Mon, 6 Dec 2021 10:43:15 +0000 (11:43 +0100)
committerGreg Kroah-Hartman <gregkh@linuxfoundation.org>
Fri, 8 Apr 2022 11:57:29 +0000 (13:57 +0200)
commit5f89d05ba93df9c2cdfe493843f93288e55e99eb
tree22db3f91d24f14e66ae1b68caae4aa9806477561
parent389d9bf28d814fcdaeb632935084b79e98db0407
media: venus: vdec: fixed possible memory leak issue

commit 8403fdd775858a7bf04868d43daea0acbe49ddfc upstream.

The venus_helper_alloc_dpb_bufs() implementation allows an early return
on an error path when checking the id from ida_alloc_min() which would
not release the earlier buffer allocation.

Move the direct kfree() from the error checking of dma_alloc_attrs() to
the common fail path to ensure that allocations are released on all
error paths in this function.

Addresses-Coverity: 1494120 ("Resource leak")

cc: stable@vger.kernel.org # 5.16+
Fixes: 40d87aafee29 ("media: venus: vdec: decoded picture buffer handling during reconfig sequence")
Signed-off-by: Ameer Hamza <amhamza.mgc@gmail.com>
Reviewed-by: Kieran Bingham <kieran.bingham+renesas@ideasonboard.com>
Signed-off-by: Stanimir Varbanov <stanimir.varbanov@linaro.org>
Signed-off-by: Mauro Carvalho Chehab <mchehab@kernel.org>
Signed-off-by: Greg Kroah-Hartman <gregkh@linuxfoundation.org>
drivers/media/platform/qcom/venus/helpers.c