summaryrefslogtreecommitdiffstats
path: root/drivers/remoteproc/ti_k3_dsp_remoteproc.c
diff options
context:
space:
mode:
authorAndrew Davis <afd@ti.com>2024-02-05 19:27:50 +0100
committerMathieu Poirier <mathieu.poirier@linaro.org>2024-02-05 21:25:51 +0100
commit585fc027a7f4fc38b6862eeb614c7446f2d5db4a (patch)
treea5e25d77cc9c8d8b30c1e49d91a3efbfb359400b /drivers/remoteproc/ti_k3_dsp_remoteproc.c
parentremoteproc: k3-dsp: Use devm_ti_sci_get_by_phandle() helper (diff)
downloadlinux-585fc027a7f4fc38b6862eeb614c7446f2d5db4a.tar.xz
linux-585fc027a7f4fc38b6862eeb614c7446f2d5db4a.zip
remoteproc: k3-dsp: Use devm_kzalloc() helper
Use device lifecycle managed devm_kzalloc() helper function. This helps prevent mistakes like freeing out of order in cleanup functions and forgetting to free on all error paths. Signed-off-by: Andrew Davis <afd@ti.com> Link: https://lore.kernel.org/r/20240205182753.36978-3-afd@ti.com Signed-off-by: Mathieu Poirier <mathieu.poirier@linaro.org>
Diffstat (limited to 'drivers/remoteproc/ti_k3_dsp_remoteproc.c')
-rw-r--r--drivers/remoteproc/ti_k3_dsp_remoteproc.c8
1 files changed, 2 insertions, 6 deletions
diff --git a/drivers/remoteproc/ti_k3_dsp_remoteproc.c b/drivers/remoteproc/ti_k3_dsp_remoteproc.c
index 64ec5759c4ec..b9332c66a52a 100644
--- a/drivers/remoteproc/ti_k3_dsp_remoteproc.c
+++ b/drivers/remoteproc/ti_k3_dsp_remoteproc.c
@@ -659,7 +659,7 @@ struct ti_sci_proc *k3_dsp_rproc_of_get_tsp(struct device *dev,
if (ret < 0)
return ERR_PTR(ret);
- tsp = kzalloc(sizeof(*tsp), GFP_KERNEL);
+ tsp = devm_kzalloc(dev, sizeof(*tsp), GFP_KERNEL);
if (!tsp)
return ERR_PTR(-ENOMEM);
@@ -730,7 +730,7 @@ static int k3_dsp_rproc_probe(struct platform_device *pdev)
ret = ti_sci_proc_request(kproc->tsp);
if (ret < 0) {
dev_err_probe(dev, ret, "ti_sci_proc_request failed\n");
- goto free_tsp;
+ return ret;
}
ret = k3_dsp_rproc_of_get_memories(pdev, kproc);
@@ -797,8 +797,6 @@ release_tsp:
ret1 = ti_sci_proc_release(kproc->tsp);
if (ret1)
dev_err(dev, "failed to release proc (%pe)\n", ERR_PTR(ret1));
-free_tsp:
- kfree(kproc->tsp);
return ret;
}
@@ -824,8 +822,6 @@ static void k3_dsp_rproc_remove(struct platform_device *pdev)
if (ret)
dev_err(dev, "failed to release proc (%pe)\n", ERR_PTR(ret));
- kfree(kproc->tsp);
-
k3_dsp_reserved_mem_exit(kproc);
}