Switch to devm_of_reserved_mem_device_init() so the reserved memory
region is released automatically on probe failure or device removal.
Remove the three explicit of_reserved_mem_device_release() calls and
rename the error label from err_release_reserved_mem to
err_unprepare_vclk to reflect that it now only unwinds clock state.

Signed-off-by: Mukesh Ojha <[email protected]>
---
 drivers/media/platform/aspeed/aspeed-video.c | 12 ++++--------
 1 file changed, 4 insertions(+), 8 deletions(-)

diff --git a/drivers/media/platform/aspeed/aspeed-video.c 
b/drivers/media/platform/aspeed/aspeed-video.c
index a292275f6b7b..7ba9314fdbd2 100644
--- a/drivers/media/platform/aspeed/aspeed-video.c
+++ b/drivers/media/platform/aspeed/aspeed-video.c
@@ -2267,19 +2267,19 @@ static int aspeed_video_init(struct aspeed_video *video)
        if (rc)
                goto err_unprepare_eclk;
 
-       of_reserved_mem_device_init(dev);
+       devm_of_reserved_mem_device_init(dev);
 
        rc = dma_set_mask_and_coherent(dev, DMA_BIT_MASK(32));
        if (rc) {
                dev_err(dev, "Failed to set DMA mask\n");
-               goto err_release_reserved_mem;
+               goto err_unprepare_vclk;
        }
 
        if (!aspeed_video_alloc_buf(video, &video->jpeg,
                                    VE_JPEG_HEADER_SIZE)) {
                dev_err(dev, "Failed to allocate DMA for JPEG header\n");
                rc = -ENOMEM;
-               goto err_release_reserved_mem;
+               goto err_unprepare_vclk;
        }
        dev_info(video->dev, "alloc mem size(%d) at %pad for jpeg header\n",
                 VE_JPEG_HEADER_SIZE, &video->jpeg.dma);
@@ -2288,8 +2288,7 @@ static int aspeed_video_init(struct aspeed_video *video)
 
        return 0;
 
-err_release_reserved_mem:
-       of_reserved_mem_device_release(dev);
+err_unprepare_vclk:
        clk_unprepare(video->vclk);
 err_unprepare_eclk:
        clk_unprepare(video->eclk);
@@ -2343,7 +2342,6 @@ static int aspeed_video_probe(struct platform_device 
*pdev)
        rc = aspeed_video_setup_video(video);
        if (rc) {
                aspeed_video_free_buf(video, &video->jpeg);
-               of_reserved_mem_device_release(&pdev->dev);
                clk_unprepare(video->vclk);
                clk_unprepare(video->eclk);
                return rc;
@@ -2374,8 +2372,6 @@ static void aspeed_video_remove(struct platform_device 
*pdev)
        v4l2_device_unregister(v4l2_dev);
 
        aspeed_video_free_buf(video, &video->jpeg);
-
-       of_reserved_mem_device_release(dev);
 }
 
 static struct platform_driver aspeed_video_driver = {
-- 
2.53.0


Reply via email to