aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/gpu
diff options
context:
space:
mode:
authorStanislaw Gruszka <sgruszka@redhat.com>2014-01-25 04:13:37 -0500
committerDaniel Vetter <daniel.vetter@ffwll.ch>2014-01-25 06:52:48 -0500
commit22accca01713b13dac386ca90b787aadf88f6551 (patch)
treeda7f9a43000cfe486a522dc9c2ddeb7eeb440854 /drivers/gpu
parent85ba7b7d399dd2c4c65bd84b9ae4dfbd707e79e7 (diff)
i915: remove pm_qos request on error
Not removing pm qos request and free memory for it can cause crash, when some other driver use pm qos. For example, this oops: BUG: unable to handle kernel paging request at fffffffffffffff8 IP: [<ffffffff81307a6b>] plist_add+0x5b/0xd0 Call Trace: [<ffffffff810acf25>] pm_qos_update_target+0x125/0x1e0 [<ffffffff810ad071>] pm_qos_add_request+0x91/0x100 [<ffffffffa053ec14>] e1000_open+0xe4/0x5b0 [e1000e] was caused by earlier i915 probe failure: [drm:i915_report_and_clear_eir] *ERROR* EIR stuck: 0x00000010, masking [drm:init_ring_common] *ERROR* render ring initialization failed ctl 0001f001 head 00003004 tail 00000000 start 00003000 [drm:i915_driver_load] *ERROR* failed to init modeset i915: probe of 0000:00:02.0 failed with error -5 Bug report: http://bugzilla.redhat.com/show_bug.cgi?id=1057533 Reported-by: Giandomenico De Tullio <ghisha@gmail.com> Cc: stable@vger.kernel.org Signed-off-by: Stanislaw Gruszka <sgruszka@redhat.com> [danvet: Drop unnecessary code movement.] Signed-off-by: Daniel Vetter <daniel.vetter@ffwll.ch>
Diffstat (limited to 'drivers/gpu')
-rw-r--r--drivers/gpu/drm/i915/i915_dma.c1
1 files changed, 1 insertions, 0 deletions
diff --git a/drivers/gpu/drm/i915/i915_dma.c b/drivers/gpu/drm/i915/i915_dma.c
index e177d021c444..15a74f979b4b 100644
--- a/drivers/gpu/drm/i915/i915_dma.c
+++ b/drivers/gpu/drm/i915/i915_dma.c
@@ -1685,6 +1685,7 @@ out_gem_unload:
1685 1685
1686 intel_teardown_gmbus(dev); 1686 intel_teardown_gmbus(dev);
1687 intel_teardown_mchbar(dev); 1687 intel_teardown_mchbar(dev);
1688 pm_qos_remove_request(&dev_priv->pm_qos);
1688 destroy_workqueue(dev_priv->wq); 1689 destroy_workqueue(dev_priv->wq);
1689out_mtrrfree: 1690out_mtrrfree:
1690 arch_phys_wc_del(dev_priv->gtt.mtrr); 1691 arch_phys_wc_del(dev_priv->gtt.mtrr);