Since an fb may have multiple VMA (due to rotations etc), we need to
wait a vblank and unpin the old VMA not if the fb itself is changed, but
if the underlying VMA is changed.

Signed-off-by: Chris Wilson <ch...@chris-wilson.co.uk>
---
 drivers/gpu/drm/i915/intel_display.c | 10 +++++++---
 1 file changed, 7 insertions(+), 3 deletions(-)

diff --git a/drivers/gpu/drm/i915/intel_display.c 
b/drivers/gpu/drm/i915/intel_display.c
index 8925f9d6ecfd..a52a7ef8aecf 100644
--- a/drivers/gpu/drm/i915/intel_display.c
+++ b/drivers/gpu/drm/i915/intel_display.c
@@ -12315,9 +12315,6 @@ int intel_plane_atomic_calc_changes(struct 
drm_crtc_state *crtc_state,
        if (!was_visible && !visible)
                return 0;
 
-       if (fb != old_plane_state->base.fb)
-               pipe_config->fb_changed = true;
-
        turn_off = was_visible && (!visible || mode_changed);
        turn_on = visible && (!was_visible || mode_changed);
 
@@ -13995,6 +13992,13 @@ intel_prepare_plane_fb(struct drm_plane *plane,
                        return PTR_ERR(vma);
 
                to_intel_plane_state(new_state)->vma = vma;
+               if (to_intel_plane_state(plane->state)->vma != vma) {
+                       struct intel_crtc_state *crtc_state;
+
+                       crtc_state = 
intel_atomic_get_crtc_state(new_state->state,
+                                                                
to_intel_crtc(new_state->crtc));
+                       crtc_state->fb_changed = true;
+               }
        }
 
        new_state->fence =
-- 
2.9.3

_______________________________________________
Intel-gfx mailing list
Intel-gfx@lists.freedesktop.org
https://lists.freedesktop.org/mailman/listinfo/intel-gfx

Reply via email to