diff options
author | Chris Wilson <chris@chris-wilson.co.uk> | 2010-11-08 12:10:29 -0500 |
---|---|---|
committer | Chris Wilson <chris@chris-wilson.co.uk> | 2010-11-08 16:10:01 -0500 |
commit | 56e2ea346ab4c2ea159ecdec85fffc24f50c2903 (patch) | |
tree | 7bedc9930635e138fa9a18c50aaf92a45d921639 /drivers/gpu/drm | |
parent | 374c479bef7ecd2b41d6dd6e24aa21d73b3afae5 (diff) |
drm/i915: Fix unload after failed initialisation
If modeset init failed we attempted to unload the module, before we
finished setting it up and so triggered various oopses.
Signed-off-by: Chris Wilson <chris@chris-wilson.co.uk>
Diffstat (limited to 'drivers/gpu/drm')
-rw-r--r-- | drivers/gpu/drm/i915/i915_dma.c | 21 |
1 files changed, 12 insertions, 9 deletions
diff --git a/drivers/gpu/drm/i915/i915_dma.c b/drivers/gpu/drm/i915/i915_dma.c index eee88cfcb3aa..307bad0fcef7 100644 --- a/drivers/gpu/drm/i915/i915_dma.c +++ b/drivers/gpu/drm/i915/i915_dma.c | |||
@@ -1993,7 +1993,7 @@ int i915_driver_load(struct drm_device *dev, unsigned long flags) | |||
1993 | drm_core_check_feature(dev, DRIVER_MODESET)) { | 1993 | drm_core_check_feature(dev, DRIVER_MODESET)) { |
1994 | DRM_ERROR("kernel modesetting requires GEM, disabling driver.\n"); | 1994 | DRM_ERROR("kernel modesetting requires GEM, disabling driver.\n"); |
1995 | ret = -ENODEV; | 1995 | ret = -ENODEV; |
1996 | goto out_iomapfree; | 1996 | goto out_workqueue_free; |
1997 | } | 1997 | } |
1998 | 1998 | ||
1999 | dev->driver->get_vblank_counter = i915_get_vblank_counter; | 1999 | dev->driver->get_vblank_counter = i915_get_vblank_counter; |
@@ -2016,8 +2016,8 @@ int i915_driver_load(struct drm_device *dev, unsigned long flags) | |||
2016 | /* Init HWS */ | 2016 | /* Init HWS */ |
2017 | if (!I915_NEED_GFX_HWS(dev)) { | 2017 | if (!I915_NEED_GFX_HWS(dev)) { |
2018 | ret = i915_init_phys_hws(dev); | 2018 | ret = i915_init_phys_hws(dev); |
2019 | if (ret != 0) | 2019 | if (ret) |
2020 | goto out_workqueue_free; | 2020 | goto out_gem_unload; |
2021 | } | 2021 | } |
2022 | 2022 | ||
2023 | if (IS_PINEVIEW(dev)) | 2023 | if (IS_PINEVIEW(dev)) |
@@ -2044,11 +2044,8 @@ int i915_driver_load(struct drm_device *dev, unsigned long flags) | |||
2044 | dev_priv->trace_irq_seqno = 0; | 2044 | dev_priv->trace_irq_seqno = 0; |
2045 | 2045 | ||
2046 | ret = drm_vblank_init(dev, I915_NUM_PIPE); | 2046 | ret = drm_vblank_init(dev, I915_NUM_PIPE); |
2047 | 2047 | if (ret) | |
2048 | if (ret) { | 2048 | goto out_gem_unload; |
2049 | (void) i915_driver_unload(dev); | ||
2050 | return ret; | ||
2051 | } | ||
2052 | 2049 | ||
2053 | /* Start out suspended */ | 2050 | /* Start out suspended */ |
2054 | dev_priv->mm.suspended = 1; | 2051 | dev_priv->mm.suspended = 1; |
@@ -2059,7 +2056,7 @@ int i915_driver_load(struct drm_device *dev, unsigned long flags) | |||
2059 | ret = i915_load_modeset_init(dev); | 2056 | ret = i915_load_modeset_init(dev); |
2060 | if (ret < 0) { | 2057 | if (ret < 0) { |
2061 | DRM_ERROR("failed to init modeset\n"); | 2058 | DRM_ERROR("failed to init modeset\n"); |
2062 | goto out_workqueue_free; | 2059 | goto out_gem_unload; |
2063 | } | 2060 | } |
2064 | } | 2061 | } |
2065 | 2062 | ||
@@ -2077,6 +2074,12 @@ int i915_driver_load(struct drm_device *dev, unsigned long flags) | |||
2077 | 2074 | ||
2078 | return 0; | 2075 | return 0; |
2079 | 2076 | ||
2077 | out_gem_unload: | ||
2078 | if (dev->pdev->msi_enabled) | ||
2079 | pci_disable_msi(dev->pdev); | ||
2080 | |||
2081 | intel_teardown_gmbus(dev); | ||
2082 | intel_teardown_mchbar(dev); | ||
2080 | out_workqueue_free: | 2083 | out_workqueue_free: |
2081 | destroy_workqueue(dev_priv->wq); | 2084 | destroy_workqueue(dev_priv->wq); |
2082 | out_iomapfree: | 2085 | out_iomapfree: |