* In platforms after DISPLAY13, we might need to override
         * first async flip in order to change watermark levels
         * as part of optimization.
-        * So for those, we are checking if this is a first async flip.
-        * For platforms earlier than DISPLAY13 we always do async flip.
+        *
+        * And let's do this for all skl+ so that we can eg. change the
+        * modifier as well.
+        *
+        * TODO: For older platforms there is less reason to do this as
+        * only X-tile is supported with async flips, though we could
+        * extend this so other scanout parameters (stride/etc) could
+        * be changed as well...
+        *
+        * FIXME: Platforms with need_async_flip_disable_wa==true will
+        * now end up doing two sync flips initially. Would be nice to
+        * combine those into just the one sync flip...
         */
-       return DISPLAY_VER(i915) < 13 || old_crtc_state->uapi.async_flip;
+       return DISPLAY_VER(i915) < 9 || old_crtc_state->uapi.async_flip;
 }
 
 static bool i9xx_must_disable_cxsr(const struct intel_crtc_state *new_crtc_state,
 
                        return -EINVAL;
                }
 
+               /*
+                * We turn the first async flip request into a sync flip
+                * so that we can reconfigure the plane (eg. change modifier).
+                */
+               if (!new_crtc_state->do_async_flip)
+                       continue;
+
                if (old_plane_state->view.color_plane[0].mapping_stride !=
                    new_plane_state->view.color_plane[0].mapping_stride) {
                        drm_dbg_kms(&i915->drm,