diff options
-rw-r--r-- | drivers/gpu/drm/i915/intel_display.c | 13 |
1 files changed, 8 insertions, 5 deletions
diff --git a/drivers/gpu/drm/i915/intel_display.c b/drivers/gpu/drm/i915/intel_display.c index e031d82381e5..990f065374b2 100644 --- a/drivers/gpu/drm/i915/intel_display.c +++ b/drivers/gpu/drm/i915/intel_display.c | |||
@@ -4991,9 +4991,7 @@ static void do_intel_finish_page_flip(struct drm_device *dev, | |||
4991 | 4991 | ||
4992 | spin_unlock_irqrestore(&dev->event_lock, flags); | 4992 | spin_unlock_irqrestore(&dev->event_lock, flags); |
4993 | 4993 | ||
4994 | obj_priv = to_intel_bo(work->pending_flip_obj); | 4994 | obj_priv = to_intel_bo(work->old_fb_obj); |
4995 | |||
4996 | /* Initial scanout buffer will have a 0 pending flip count */ | ||
4997 | atomic_clear_mask(1 << intel_crtc->plane, | 4995 | atomic_clear_mask(1 << intel_crtc->plane, |
4998 | &obj_priv->pending_flip.counter); | 4996 | &obj_priv->pending_flip.counter); |
4999 | if (atomic_read(&obj_priv->pending_flip) == 0) | 4997 | if (atomic_read(&obj_priv->pending_flip) == 0) |
@@ -5092,9 +5090,14 @@ static int intel_crtc_page_flip(struct drm_crtc *crtc, | |||
5092 | if (ret) | 5090 | if (ret) |
5093 | goto cleanup_objs; | 5091 | goto cleanup_objs; |
5094 | 5092 | ||
5095 | obj_priv = to_intel_bo(obj); | 5093 | /* Block clients from rendering to the new back buffer until |
5096 | atomic_add(1 << intel_crtc->plane, &obj_priv->pending_flip); | 5094 | * the flip occurs and the object is no longer visible. |
5095 | */ | ||
5096 | atomic_add(1 << intel_crtc->plane, | ||
5097 | &to_intel_bo(work->old_fb_obj)->pending_flip); | ||
5098 | |||
5097 | work->pending_flip_obj = obj; | 5099 | work->pending_flip_obj = obj; |
5100 | obj_priv = to_intel_bo(obj); | ||
5098 | 5101 | ||
5099 | if (IS_GEN3(dev) || IS_GEN2(dev)) { | 5102 | if (IS_GEN3(dev) || IS_GEN2(dev)) { |
5100 | u32 flip_mask; | 5103 | u32 flip_mask; |