Browse Source

drm/i915: Fix power domain HW state cleanup on error path

Move the cleanup of the power domain HW state on the error path to the
same function where the corresponding init call was called from. I
noticed this problem when loading the module with load failure injection
enabled, making i915_load_modeset_init() fail.

CC: Chris Wilson <chris@chris-wilson.co.uk>
Signed-off-by: Imre Deak <imre.deak@intel.com>
Reviewed-by: Chris Wilson <chris@chris-wilson.co.uk>
Link: http://patchwork.freedesktop.org/patch/msgid/1458128348-15730-19-git-send-email-imre.deak@intel.com
Imre Deak 9 years ago
parent
commit
65ff442f6b
1 changed files with 3 additions and 3 deletions
  1. 3 3
      drivers/gpu/drm/i915/i915_dma.c

+ 3 - 3
drivers/gpu/drm/i915/i915_dma.c

@@ -453,6 +453,7 @@ cleanup_irq:
 	intel_teardown_gmbus(dev);
 	intel_teardown_gmbus(dev);
 cleanup_csr:
 cleanup_csr:
 	intel_csr_ucode_fini(dev_priv);
 	intel_csr_ucode_fini(dev_priv);
+	intel_power_domains_fini(dev_priv);
 	vga_switcheroo_unregister_client(dev->pdev);
 	vga_switcheroo_unregister_client(dev->pdev);
 cleanup_vga_client:
 cleanup_vga_client:
 	vga_client_register(dev->pdev, NULL, NULL, NULL);
 	vga_client_register(dev->pdev, NULL, NULL, NULL);
@@ -1306,7 +1307,7 @@ int i915_driver_load(struct drm_device *dev, unsigned long flags)
 	ret = i915_load_modeset_init(dev);
 	ret = i915_load_modeset_init(dev);
 	if (ret < 0) {
 	if (ret < 0) {
 		DRM_ERROR("failed to init modeset\n");
 		DRM_ERROR("failed to init modeset\n");
-		goto out_power_well;
+		goto out_cleanup_vblank;
 	}
 	}
 
 
 	i915_driver_register(dev_priv);
 	i915_driver_register(dev_priv);
@@ -1317,8 +1318,7 @@ int i915_driver_load(struct drm_device *dev, unsigned long flags)
 
 
 	return 0;
 	return 0;
 
 
-out_power_well:
-	intel_power_domains_fini(dev_priv);
+out_cleanup_vblank:
 	drm_vblank_cleanup(dev);
 	drm_vblank_cleanup(dev);
 out_cleanup_hw:
 out_cleanup_hw:
 	i915_driver_cleanup_hw(dev_priv);
 	i915_driver_cleanup_hw(dev_priv);