From: Dinghao Liu Date: Sat, 2 Jan 2021 05:47:55 +0000 (+0800) Subject: Bluetooth: hci_qca: Fix memleak in qca_controller_memdump X-Git-Tag: v5.15~1802^2~74^2~32 X-Git-Url: http://review.tizen.org/git/?a=commitdiff_plain;h=71f8e707557b9bc25dc90a59a752528d4e7c1cbf;p=platform%2Fkernel%2Flinux-starfive.git Bluetooth: hci_qca: Fix memleak in qca_controller_memdump When __le32_to_cpu() fails, qca_memdump should be freed just like when vmalloc() fails. Fixes: d841502c79e3f ("Bluetooth: hci_qca: Collect controller memory dump during SSR") Signed-off-by: Dinghao Liu Signed-off-by: Marcel Holtmann --- diff --git a/drivers/bluetooth/hci_qca.c b/drivers/bluetooth/hci_qca.c index 4a96368..5dbcb7c 100644 --- a/drivers/bluetooth/hci_qca.c +++ b/drivers/bluetooth/hci_qca.c @@ -1024,7 +1024,9 @@ static void qca_controller_memdump(struct work_struct *work) dump_size = __le32_to_cpu(dump->dump_size); if (!(dump_size)) { bt_dev_err(hu->hdev, "Rx invalid memdump size"); + kfree(qca_memdump); kfree_skb(skb); + qca->qca_memdump = NULL; mutex_unlock(&qca->hci_memdump_lock); return; }