aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/gpu/drm/i915/intel_frontbuffer.c
diff options
context:
space:
mode:
authorPaulo Zanoni <paulo.r.zanoni@intel.com>2015-02-13 14:23:46 -0500
committerDaniel Vetter <daniel.vetter@ffwll.ch>2015-03-17 17:29:56 -0400
commitdbef0f15b5c83231dacb214dbf9a6dba063ca21c (patch)
tree15099ab183b769bdba6949d3c0c5995295013bd3 /drivers/gpu/drm/i915/intel_frontbuffer.c
parent3954e733ab0c9449443897f2669e17fff4471a0e (diff)
drm/i915: add frontbuffer tracking to FBC
Kill the blt/render tracking we currently have and use the frontbuffer tracking infrastructure. Don't enable things by default yet. v2: (Rodrigo) Fix small conflict on rebase and typo at subject. v3: (Paulo) Rebase on RENDER_CS change. v4: (Paulo) Rebase. v5: (Paulo) Simplify: flushes don't have origin (Daniel). Also rebase due to patch order changes. Signed-off-by: Rodrigo Vivi <rodrigo.vivi@intel.com> Signed-off-by: Paulo Zanoni <paulo.r.zanoni@intel.com> Reviewed-by: Rodrigo Vivi <rodrigo.vivi@intel.com> Signed-off-by: Daniel Vetter <daniel.vetter@ffwll.ch>
Diffstat (limited to 'drivers/gpu/drm/i915/intel_frontbuffer.c')
-rw-r--r--drivers/gpu/drm/i915/intel_frontbuffer.c14
1 files changed, 2 insertions, 12 deletions
diff --git a/drivers/gpu/drm/i915/intel_frontbuffer.c b/drivers/gpu/drm/i915/intel_frontbuffer.c
index 5da73f0124ce..0a1bac8ac72b 100644
--- a/drivers/gpu/drm/i915/intel_frontbuffer.c
+++ b/drivers/gpu/drm/i915/intel_frontbuffer.c
@@ -118,8 +118,6 @@ static void intel_mark_fb_busy(struct drm_device *dev,
118 continue; 118 continue;
119 119
120 intel_increase_pllclock(dev, pipe); 120 intel_increase_pllclock(dev, pipe);
121 if (ring && intel_fbc_enabled(dev))
122 ring->fbc_dirty = true;
123 } 121 }
124} 122}
125 123
@@ -160,6 +158,7 @@ void intel_fb_obj_invalidate(struct drm_i915_gem_object *obj,
160 158
161 intel_psr_invalidate(dev, obj->frontbuffer_bits); 159 intel_psr_invalidate(dev, obj->frontbuffer_bits);
162 intel_edp_drrs_invalidate(dev, obj->frontbuffer_bits); 160 intel_edp_drrs_invalidate(dev, obj->frontbuffer_bits);
161 intel_fbc_invalidate(dev_priv, obj->frontbuffer_bits, origin);
163} 162}
164 163
165/** 164/**
@@ -187,16 +186,7 @@ void intel_frontbuffer_flush(struct drm_device *dev,
187 186
188 intel_edp_drrs_flush(dev, frontbuffer_bits); 187 intel_edp_drrs_flush(dev, frontbuffer_bits);
189 intel_psr_flush(dev, frontbuffer_bits); 188 intel_psr_flush(dev, frontbuffer_bits);
190 189 intel_fbc_flush(dev_priv, frontbuffer_bits);
191 /*
192 * FIXME: Unconditional fbc flushing here is a rather gross hack and
193 * needs to be reworked into a proper frontbuffer tracking scheme like
194 * psr employs.
195 */
196 if (dev_priv->fbc.need_sw_cache_clean) {
197 dev_priv->fbc.need_sw_cache_clean = false;
198 bdw_fbc_sw_flush(dev, FBC_REND_CACHE_CLEAN);
199 }
200} 190}
201 191
202/** 192/**