panfrost: Properly undo pm_runtime_enable when deferring a probe
authorTomeu Vizoso <tomeu.vizoso@collabora.com>
Wed, 23 Oct 2019 12:21:57 +0000 (14:21 +0200)
committerRob Herring <robh@kernel.org>
Wed, 23 Oct 2019 17:50:47 +0000 (12:50 -0500)
When deferring the probe because of a missing regulator, we were calling
pm_runtime_disable even if pm_runtime_enable wasn't called.

Move the call to pm_runtime_disable to the right place.

Fixes: 635430797d3f ("drm/panfrost: Rework runtime PM initialization")
Reported-by: Chen-Yu Tsai <wens@csie.org>
Cc: Robin Murphy <robin.murphy@arm.com>
Signed-off-by: Tomeu Vizoso <tomeu.vizoso@collabora.com>
Reviewed-by: Robin Murphy <robin.murphy@arm.com>
Reviewed-by: Steven Price <steven.price@arm.com>
Signed-off-by: Rob Herring <robh@kernel.org>
Link: https://patchwork.freedesktop.org/patch/msgid/20191023122157.32067-1-tomeu.vizoso@collabora.com
drivers/gpu/drm/panfrost/panfrost_drv.c

index bc2ddeb55f5d86ffbc9cbe1a39e2e90d77ce60df..f21bc8a7ee3a2fe7d6cdef0747079cf450dc6e6d 100644 (file)
@@ -556,11 +556,11 @@ static int panfrost_probe(struct platform_device *pdev)
        return 0;
 
 err_out2:
+       pm_runtime_disable(pfdev->dev);
        panfrost_devfreq_fini(pfdev);
 err_out1:
        panfrost_device_fini(pfdev);
 err_out0:
-       pm_runtime_disable(pfdev->dev);
        drm_dev_put(ddev);
        return err;
 }