diff options
author | Daniel Vetter <daniel.vetter@ffwll.ch> | 2014-03-18 11:26:25 -0400 |
---|---|---|
committer | Daniel Vetter <daniel.vetter@ffwll.ch> | 2014-03-18 11:31:34 -0400 |
commit | 05efeebd2838f0dedf765179244a7fb543fdca8a (patch) | |
tree | 7bc3fa3ae13eae5b37147f038640a3941bf2c393 | |
parent | 0294ae7b44bba7ab0d4cef9a8736287f38bdb4fd (diff) |
drm/i915: Fix up the forcewake timer initialization
This is a regression introduced in
commit 0294ae7b44bba7ab0d4cef9a8736287f38bdb4fd
Author: Chris Wilson <chris@chris-wilson.co.uk>
Date: Thu Mar 13 12:00:29 2014 +0000
drm/i915: Consolidate forcewake resetting to a single function
The reordered setup sequence ended up calling del_timer_sync before
the timer was set up correctly, resulting in endless hilarity when
loading the driver.
Compared to Ben's patch (which moved around the setup_timer call to
sanitize_early) this moves the sanitize_early call around in the
driver load call. This way we avoid calling setup_timer again in the
resume code (where we also call sanitize_early).
Cc: Chris Wilson <chris@chris-wilson.co.uk>
Cc: Mika Kuoppala <mika.kuoppala@intel.com>
Cc: Ben Widawsky <benjamin.widawsky@intel.com>
Tested-by: Rodrigo Vivi <rodrigo.vivi@gmail.com>
Bugzilla: https://bugs.freedesktop.org/show_bug.cgi?id=76242
Signed-off-by: Daniel Vetter <daniel.vetter@ffwll.ch>
-rw-r--r-- | drivers/gpu/drm/i915/i915_dma.c | 2 | ||||
-rw-r--r-- | drivers/gpu/drm/i915/intel_uncore.c | 2 |
2 files changed, 2 insertions, 2 deletions
diff --git a/drivers/gpu/drm/i915/i915_dma.c b/drivers/gpu/drm/i915/i915_dma.c index e4d2b9f15ae2..9faee49f210d 100644 --- a/drivers/gpu/drm/i915/i915_dma.c +++ b/drivers/gpu/drm/i915/i915_dma.c | |||
@@ -1608,8 +1608,6 @@ int i915_driver_load(struct drm_device *dev, unsigned long flags) | |||
1608 | goto put_bridge; | 1608 | goto put_bridge; |
1609 | } | 1609 | } |
1610 | 1610 | ||
1611 | intel_uncore_early_sanitize(dev); | ||
1612 | |||
1613 | /* This must be called before any calls to HAS_PCH_* */ | 1611 | /* This must be called before any calls to HAS_PCH_* */ |
1614 | intel_detect_pch(dev); | 1612 | intel_detect_pch(dev); |
1615 | 1613 | ||
diff --git a/drivers/gpu/drm/i915/intel_uncore.c b/drivers/gpu/drm/i915/intel_uncore.c index e6bb421a3dbd..ab5165c66381 100644 --- a/drivers/gpu/drm/i915/intel_uncore.c +++ b/drivers/gpu/drm/i915/intel_uncore.c | |||
@@ -727,6 +727,8 @@ void intel_uncore_init(struct drm_device *dev) | |||
727 | setup_timer(&dev_priv->uncore.force_wake_timer, | 727 | setup_timer(&dev_priv->uncore.force_wake_timer, |
728 | gen6_force_wake_timer, (unsigned long)dev_priv); | 728 | gen6_force_wake_timer, (unsigned long)dev_priv); |
729 | 729 | ||
730 | intel_uncore_early_sanitize(dev); | ||
731 | |||
730 | if (IS_VALLEYVIEW(dev)) { | 732 | if (IS_VALLEYVIEW(dev)) { |
731 | dev_priv->uncore.funcs.force_wake_get = __vlv_force_wake_get; | 733 | dev_priv->uncore.funcs.force_wake_get = __vlv_force_wake_get; |
732 | dev_priv->uncore.funcs.force_wake_put = __vlv_force_wake_put; | 734 | dev_priv->uncore.funcs.force_wake_put = __vlv_force_wake_put; |