diff options
author | Chris Wilson <chris@chris-wilson.co.uk> | 2012-06-21 06:19:59 -0400 |
---|---|---|
committer | Daniel Vetter <daniel.vetter@ffwll.ch> | 2012-08-22 11:39:01 -0400 |
commit | 44f46b4222a9ba5b21dcdf13f93dc53f48768d2b (patch) | |
tree | 6b040cfc4603479b595c80b9d7edbca0c0f9abf9 /drivers | |
parent | de9932d13c95c4125d2ed8703f5574fcc108bbcf (diff) |
drm/i915: Cantiga+ cannot handle a hsync front porch of 0
This addresses WaPruneModeWithIncorrectHsyncOffset.
Bugzilla: http://bugs.freedesktop.org/show_bug.cgi?id=50236
Signed-off-by: Chris Wilson <chris@chris-wilson.co.uk>
Signed-off-by: Jani Nikula <jani.nikula@intel.com>
Signed-off-by: Daniel Vetter <daniel.vetter@ffwll.ch>
Diffstat (limited to 'drivers')
-rw-r--r-- | drivers/gpu/drm/i915/intel_display.c | 7 |
1 files changed, 7 insertions, 0 deletions
diff --git a/drivers/gpu/drm/i915/intel_display.c b/drivers/gpu/drm/i915/intel_display.c index 42c57581c53f..778cbb88bddc 100644 --- a/drivers/gpu/drm/i915/intel_display.c +++ b/drivers/gpu/drm/i915/intel_display.c | |||
@@ -3602,6 +3602,13 @@ static bool intel_crtc_mode_fixup(struct drm_crtc *crtc, | |||
3602 | if (!(adjusted_mode->private_flags & INTEL_MODE_CRTC_TIMINGS_SET)) | 3602 | if (!(adjusted_mode->private_flags & INTEL_MODE_CRTC_TIMINGS_SET)) |
3603 | drm_mode_set_crtcinfo(adjusted_mode, 0); | 3603 | drm_mode_set_crtcinfo(adjusted_mode, 0); |
3604 | 3604 | ||
3605 | /* WaPruneModeWithIncorrectHsyncOffset: Cantiga+ cannot handle modes | ||
3606 | * with a hsync front porch of 0. | ||
3607 | */ | ||
3608 | if ((INTEL_INFO(dev)->gen > 4 || IS_G4X(dev)) && | ||
3609 | adjusted_mode->hsync_start == adjusted_mode->hdisplay) | ||
3610 | return false; | ||
3611 | |||
3605 | return true; | 3612 | return true; |
3606 | } | 3613 | } |
3607 | 3614 | ||