return ERR_CAST(dp->clock);
        }
 
-       clk_prepare_enable(dp->clock);
-
        res = platform_get_resource(pdev, IORESOURCE_MEM, 0);
 
        dp->reg_base = devm_ioremap_resource(&pdev->dev, res);
 }
 EXPORT_SYMBOL_GPL(analogix_dp_probe);
 
+int analogix_dp_suspend(struct analogix_dp_device *dp)
+{
+       clk_disable_unprepare(dp->clock);
+
+       return 0;
+}
+EXPORT_SYMBOL_GPL(analogix_dp_suspend);
+
+int analogix_dp_resume(struct analogix_dp_device *dp)
+{
+       int ret;
+
+       ret = clk_prepare_enable(dp->clock);
+       if (ret < 0) {
+               DRM_ERROR("Failed to prepare_enable the clock clk [%d]\n", ret);
+               return ret;
+       }
+
+       return 0;
+}
+EXPORT_SYMBOL_GPL(analogix_dp_resume);
+
 int analogix_dp_bind(struct analogix_dp_device *dp, struct drm_device *drm_dev)
 {
        int ret;
        dp->drm_dev = drm_dev;
        dp->encoder = dp->plat_data->encoder;
 
-       pm_runtime_use_autosuspend(dp->dev);
-       pm_runtime_set_autosuspend_delay(dp->dev, 100);
-       pm_runtime_enable(dp->dev);
+       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;
+       }
 
        dp->aux.name = "DP-AUX";
        dp->aux.transfer = analogix_dpaux_transfer;
 err_unregister_aux:
        drm_dp_aux_unregister(&dp->aux);
 err_disable_pm_runtime:
-       pm_runtime_dont_use_autosuspend(dp->dev);
-       pm_runtime_disable(dp->dev);
+       if (IS_ENABLED(CONFIG_PM)) {
+               pm_runtime_dont_use_autosuspend(dp->dev);
+               pm_runtime_disable(dp->dev);
+       } else {
+               analogix_dp_suspend(dp);
+       }
 
        return ret;
 }
        }
 
        drm_dp_aux_unregister(&dp->aux);
-       pm_runtime_dont_use_autosuspend(dp->dev);
-       pm_runtime_disable(dp->dev);
+
+       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);
 
 void analogix_dp_remove(struct analogix_dp_device *dp)
 {
-       clk_disable_unprepare(dp->clock);
 }
 EXPORT_SYMBOL_GPL(analogix_dp_remove);
 
-#ifdef CONFIG_PM
-int analogix_dp_suspend(struct analogix_dp_device *dp)
-{
-       clk_disable_unprepare(dp->clock);
-       return 0;
-}
-EXPORT_SYMBOL_GPL(analogix_dp_suspend);
-
-int analogix_dp_resume(struct analogix_dp_device *dp)
-{
-       int ret;
-
-       ret = clk_prepare_enable(dp->clock);
-       if (ret < 0) {
-               DRM_ERROR("Failed to prepare_enable the clock clk [%d]\n", ret);
-               return ret;
-       }
-
-       return 0;
-}
-EXPORT_SYMBOL_GPL(analogix_dp_resume);
-#endif
-
 int analogix_dp_start_crc(struct drm_connector *connector)
 {
        struct analogix_dp_device *dp = to_dp(connector);