Remove the check related to CONFIG_PM in order to make the code more
concise, as the CONFIG_PM should be a required option for many drivers.

In addition, it is preferable to use devm_pm_runtime_enable() instead of
manually invoking pm_runtime_enable() followed by pm_runtime_disable().

Suggested-by: Douglas Anderson <diand...@chromium.org>
Reviewed-by: Douglas Anderson <diand...@chromium.org>
Signed-off-by: Damon Ding <damon.d...@rock-chips.com>
---
 .../drm/bridge/analogix/analogix_dp_core.c    | 30 ++++---------------
 1 file changed, 6 insertions(+), 24 deletions(-)

diff --git a/drivers/gpu/drm/bridge/analogix/analogix_dp_core.c 
b/drivers/gpu/drm/bridge/analogix/analogix_dp_core.c
index 5ef6bb6010ca..132f8513f93f 100644
--- a/drivers/gpu/drm/bridge/analogix/analogix_dp_core.c
+++ b/drivers/gpu/drm/bridge/analogix/analogix_dp_core.c
@@ -1695,15 +1695,11 @@ int analogix_dp_bind(struct analogix_dp_device *dp, 
struct drm_device *drm_dev)
        dp->drm_dev = drm_dev;
        dp->encoder = dp->plat_data->encoder;
 
-       if (IS_ENABLED(CONFIG_PM)) {
-               pm_runtime_use_autosuspend(dp->dev);
-               pm_runtime_set_autosuspend_delay(dp->dev, 100);
-               pm_runtime_enable(dp->dev);
-       } else {
-               ret = analogix_dp_resume(dp);
-               if (ret)
-                       return ret;
-       }
+       pm_runtime_use_autosuspend(dp->dev);
+       pm_runtime_set_autosuspend_delay(dp->dev, 100);
+       ret = devm_pm_runtime_enable(dp->dev);
+       if (ret)
+               return ret;
 
        dp->aux.name = "DP-AUX";
        dp->aux.transfer = analogix_dpaux_transfer;
@@ -1713,7 +1709,7 @@ int analogix_dp_bind(struct analogix_dp_device *dp, 
struct drm_device *drm_dev)
        ret = drm_dp_aux_register(&dp->aux);
        if (ret) {
                DRM_ERROR("failed to register AUX (%d)\n", ret);
-               goto err_disable_pm_runtime;
+               return ret;
        }
 
        ret = analogix_dp_create_bridge(drm_dev, dp);
@@ -1726,13 +1722,6 @@ int analogix_dp_bind(struct analogix_dp_device *dp, 
struct drm_device *drm_dev)
 
 err_unregister_aux:
        drm_dp_aux_unregister(&dp->aux);
-err_disable_pm_runtime:
-       if (IS_ENABLED(CONFIG_PM)) {
-               pm_runtime_dont_use_autosuspend(dp->dev);
-               pm_runtime_disable(dp->dev);
-       } else {
-               analogix_dp_suspend(dp);
-       }
 
        return ret;
 }
@@ -1749,13 +1738,6 @@ void analogix_dp_unbind(struct analogix_dp_device *dp)
        }
 
        drm_dp_aux_unregister(&dp->aux);
-
-       if (IS_ENABLED(CONFIG_PM)) {
-               pm_runtime_dont_use_autosuspend(dp->dev);
-               pm_runtime_disable(dp->dev);
-       } else {
-               analogix_dp_suspend(dp);
-       }
 }
 EXPORT_SYMBOL_GPL(analogix_dp_unbind);
 
-- 
2.34.1

Reply via email to