return 0;
        }
 
+       /* WaFbcTurnOffFbcWhenHyperVisorIsUsed:skl,bxt */
+       if (i915_vtd_active(i915) && (IS_SKYLAKE(i915) || IS_BROXTON(i915))) {
+               plane_state->no_fbc_reason = "VT-d enabled";
+               return 0;
+       }
+
        crtc_state = intel_atomic_get_new_crtc_state(state, crtc);
 
        if (crtc_state->hw.adjusted_mode.flags & DRM_MODE_FLAG_INTERLACE) {
        return 0;
 }
 
-static bool need_fbc_vtd_wa(struct drm_i915_private *i915)
-{
-       /* WaFbcTurnOffFbcWhenHyperVisorIsUsed:skl,bxt */
-       if (i915_vtd_active(i915) &&
-           (IS_SKYLAKE(i915) || IS_BROXTON(i915))) {
-               drm_info(&i915->drm,
-                        "Disabling framebuffer compression (FBC) to prevent screen flicker with VT-d enabled\n");
-               return true;
-       }
-
-       return false;
-}
-
 void intel_fbc_add_plane(struct intel_fbc *fbc, struct intel_plane *plane)
 {
        plane->fbc = fbc;
 {
        enum intel_fbc_id fbc_id;
 
-       if (need_fbc_vtd_wa(i915))
-               DISPLAY_RUNTIME_INFO(i915)->fbc_mask = 0;
-
        i915->display.params.enable_fbc = intel_sanitize_fbc_option(i915);
        drm_dbg_kms(&i915->drm, "Sanitized enable_fbc value: %d\n",
                    i915->display.params.enable_fbc);