Commit 097fb3ee authored by Vladislav Efanov's avatar Vladislav Efanov Committed by Greg Kroah-Hartman

usb: dwc3: qcom: Fix potential memory leak

Function dwc3_qcom_probe() allocates memory for resource structure
which is pointed by parent_res pointer. This memory is not
freed. This leads to memory leak. Use stack memory to prevent
memory leak.

Found by Linux Verification Center (linuxtesting.org) with SVACE.

Fixes: 2bc02355 ("usb: dwc3: qcom: Add support for booting with ACPI")
Signed-off-by: default avatarVladislav Efanov <VEfanov@ispras.ru>
Acked-by: default avatarShawn Guo <shawn.guo@linaro.org>
Link: https://lore.kernel.org/r/20230517172518.442591-1-VEfanov@ispras.ruSigned-off-by: default avatarGreg Kroah-Hartman <gregkh@linuxfoundation.org>
parent c722576b
...@@ -791,6 +791,7 @@ static int dwc3_qcom_probe(struct platform_device *pdev) ...@@ -791,6 +791,7 @@ static int dwc3_qcom_probe(struct platform_device *pdev)
struct device *dev = &pdev->dev; struct device *dev = &pdev->dev;
struct dwc3_qcom *qcom; struct dwc3_qcom *qcom;
struct resource *res, *parent_res = NULL; struct resource *res, *parent_res = NULL;
struct resource local_res;
int ret, i; int ret, i;
bool ignore_pipe_clk; bool ignore_pipe_clk;
bool wakeup_source; bool wakeup_source;
...@@ -842,9 +843,8 @@ static int dwc3_qcom_probe(struct platform_device *pdev) ...@@ -842,9 +843,8 @@ static int dwc3_qcom_probe(struct platform_device *pdev)
if (np) { if (np) {
parent_res = res; parent_res = res;
} else { } else {
parent_res = kmemdup(res, sizeof(struct resource), GFP_KERNEL); memcpy(&local_res, res, sizeof(struct resource));
if (!parent_res) parent_res = &local_res;
return -ENOMEM;
parent_res->start = res->start + parent_res->start = res->start +
qcom->acpi_pdata->qscratch_base_offset; qcom->acpi_pdata->qscratch_base_offset;
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment