dpu_hw_intr_destroy(dpu_kms->hw_intr);
        dpu_kms->hw_intr = NULL;
 
-       if (dpu_kms->power_event)
-               dpu_power_handle_unregister_event(
-                               &dpu_kms->phandle, dpu_kms->power_event);
-
        /* safe to call these more than once during shutdown */
        _dpu_debugfs_destroy(dpu_kms);
        _dpu_kms_mmu_destroy(dpu_kms);
        return clk_get_rate(clk->clk);
 }
 
-static void dpu_kms_handle_power_event(u32 event_type, void *usr)
-{
-       struct dpu_kms *dpu_kms = usr;
-
-       if (!dpu_kms)
-               return;
-
-       dpu_vbif_init_memtypes(dpu_kms);
-}
-
 static int dpu_kms_hw_init(struct msm_kms *kms)
 {
        struct dpu_kms *dpu_kms;
         */
        dev->mode_config.allow_fb_modifiers = true;
 
-       /*
-        * Handle (re)initializations during power enable
-        */
-       dpu_kms_handle_power_event(DPU_POWER_EVENT_ENABLE, dpu_kms);
-       dpu_kms->power_event = dpu_power_handle_register_event(
-                       &dpu_kms->phandle, DPU_POWER_EVENT_ENABLE,
-                       dpu_kms_handle_power_event, dpu_kms, "kms");
+       dpu_vbif_init_memtypes(dpu_kms);
 
        pm_runtime_put_sync(&dpu_kms->pdev->dev);
 
                return rc;
        }
 
+       dpu_vbif_init_memtypes(dpu_kms);
+
        rc = dpu_power_resource_enable(&dpu_kms->phandle, true);
        if (rc)
                DPU_ERROR("resource enable failed: %d\n", rc);