diff options
author | Daniel Vetter <daniel.vetter@ffwll.ch> | 2012-10-02 11:54:35 -0400 |
---|---|---|
committer | Daniel Vetter <daniel.vetter@ffwll.ch> | 2012-10-04 04:33:43 -0400 |
commit | 74d44445afb9f50126eba052adeb89827cee88f3 (patch) | |
tree | 763925fb8f2080134b9c75aa2f24e99742c96e25 | |
parent | 4d0f817e7482969a31c2295a530c966f135faa7e (diff) |
drm/i915: call drm_handle_vblank before finish_page_flip
... since finish_page_flip needs the vblank timestamp generated
in drm_handle_vblank. Somehow all the gmch platforms get it right,
but all the pch platform irq handlers get is wrong. Hooray for copy&
pasting!
Currently this gets papered over by a gross hack in finish_page_flip.
A second patch will remove that.
Note that without this, the new timestamp sanity checks in flip_test
occasionally get tripped up, hence the cc: stable tag.
Cc: stable@vger.kernel.org
Reviewed-by: mario.kleiner@tuebingen.mpg.de
Tested-by: Imre Deak <imre.deak@intel.com>
Signed-off-by: Daniel Vetter <daniel.vetter@ffwll.ch>
-rw-r--r-- | drivers/gpu/drm/i915/i915_irq.c | 16 |
1 files changed, 8 insertions, 8 deletions
diff --git a/drivers/gpu/drm/i915/i915_irq.c b/drivers/gpu/drm/i915/i915_irq.c index d7f0066538a9..1fc2489bf847 100644 --- a/drivers/gpu/drm/i915/i915_irq.c +++ b/drivers/gpu/drm/i915/i915_irq.c | |||
@@ -698,12 +698,12 @@ static irqreturn_t ivybridge_irq_handler(DRM_IRQ_ARGS) | |||
698 | intel_opregion_gse_intr(dev); | 698 | intel_opregion_gse_intr(dev); |
699 | 699 | ||
700 | for (i = 0; i < 3; i++) { | 700 | for (i = 0; i < 3; i++) { |
701 | if (de_iir & (DE_PIPEA_VBLANK_IVB << (5 * i))) | ||
702 | drm_handle_vblank(dev, i); | ||
701 | if (de_iir & (DE_PLANEA_FLIP_DONE_IVB << (5 * i))) { | 703 | if (de_iir & (DE_PLANEA_FLIP_DONE_IVB << (5 * i))) { |
702 | intel_prepare_page_flip(dev, i); | 704 | intel_prepare_page_flip(dev, i); |
703 | intel_finish_page_flip_plane(dev, i); | 705 | intel_finish_page_flip_plane(dev, i); |
704 | } | 706 | } |
705 | if (de_iir & (DE_PIPEA_VBLANK_IVB << (5 * i))) | ||
706 | drm_handle_vblank(dev, i); | ||
707 | } | 707 | } |
708 | 708 | ||
709 | /* check event from PCH */ | 709 | /* check event from PCH */ |
@@ -785,6 +785,12 @@ static irqreturn_t ironlake_irq_handler(DRM_IRQ_ARGS) | |||
785 | if (de_iir & DE_GSE) | 785 | if (de_iir & DE_GSE) |
786 | intel_opregion_gse_intr(dev); | 786 | intel_opregion_gse_intr(dev); |
787 | 787 | ||
788 | if (de_iir & DE_PIPEA_VBLANK) | ||
789 | drm_handle_vblank(dev, 0); | ||
790 | |||
791 | if (de_iir & DE_PIPEB_VBLANK) | ||
792 | drm_handle_vblank(dev, 1); | ||
793 | |||
788 | if (de_iir & DE_PLANEA_FLIP_DONE) { | 794 | if (de_iir & DE_PLANEA_FLIP_DONE) { |
789 | intel_prepare_page_flip(dev, 0); | 795 | intel_prepare_page_flip(dev, 0); |
790 | intel_finish_page_flip_plane(dev, 0); | 796 | intel_finish_page_flip_plane(dev, 0); |
@@ -795,12 +801,6 @@ static irqreturn_t ironlake_irq_handler(DRM_IRQ_ARGS) | |||
795 | intel_finish_page_flip_plane(dev, 1); | 801 | intel_finish_page_flip_plane(dev, 1); |
796 | } | 802 | } |
797 | 803 | ||
798 | if (de_iir & DE_PIPEA_VBLANK) | ||
799 | drm_handle_vblank(dev, 0); | ||
800 | |||
801 | if (de_iir & DE_PIPEB_VBLANK) | ||
802 | drm_handle_vblank(dev, 1); | ||
803 | |||
804 | /* check event from PCH */ | 804 | /* check event from PCH */ |
805 | if (de_iir & DE_PCH_EVENT) { | 805 | if (de_iir & DE_PCH_EVENT) { |
806 | if (pch_iir & hotplug_mask) | 806 | if (pch_iir & hotplug_mask) |