aboutsummaryrefslogtreecommitdiffstats
path: root/drivers/gpu/drm/i915/intel_frontbuffer.c
diff options
context:
space:
mode:
authorVandana Kannan <vandana.kannan@intel.com>2015-01-09 15:55:59 -0500
committerDaniel Vetter <daniel.vetter@ffwll.ch>2015-01-27 03:51:15 -0500
commita93fad0f7fb8a3ff12e8814b630648f6d187954c (patch)
tree99c5e1da2ec4343908719363ac6d7e1f1c25d7ec /drivers/gpu/drm/i915/intel_frontbuffer.c
parentc395578e986d707c658f902340545d99a76709bb (diff)
drm/i915: DRRS calls based on frontbuffer
Calls have been added to invalidate/flush DRRS whenever invalidate/flush is called as part of frontbuffer tracking. Apart from calls as a result of GEM tracking to fb invalidate/flush, a call has been added to invalidate fb obj from crtc_page_flip as well. This is to track busyness through flip calls. The call to fb_obj_invalidate (in flip) is placed before queuing flip for this obj. drrs_invalidate() and drrs_flush() check for drrs.dp which would be NULL if it was setup in drrs_enable(). This covers for the condition when DRRS is not supported. v2: Removing the call to invalidate_drrs from page_flip. This has not been tested on Android yet, but, in case DRRS transtions do not work as expected, check by adding back this call in page_flip. Signed-off-by: Vandana Kannan <vandana.kannan@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.c2
1 files changed, 2 insertions, 0 deletions
diff --git a/drivers/gpu/drm/i915/intel_frontbuffer.c b/drivers/gpu/drm/i915/intel_frontbuffer.c
index 79f6d72179c5..73cb6e036445 100644
--- a/drivers/gpu/drm/i915/intel_frontbuffer.c
+++ b/drivers/gpu/drm/i915/intel_frontbuffer.c
@@ -157,6 +157,7 @@ void intel_fb_obj_invalidate(struct drm_i915_gem_object *obj,
157 intel_mark_fb_busy(dev, obj->frontbuffer_bits, ring); 157 intel_mark_fb_busy(dev, obj->frontbuffer_bits, ring);
158 158
159 intel_psr_invalidate(dev, obj->frontbuffer_bits); 159 intel_psr_invalidate(dev, obj->frontbuffer_bits);
160 intel_edp_drrs_invalidate(dev, obj->frontbuffer_bits);
160} 161}
161 162
162/** 163/**
@@ -182,6 +183,7 @@ void intel_frontbuffer_flush(struct drm_device *dev,
182 183
183 intel_mark_fb_busy(dev, frontbuffer_bits, NULL); 184 intel_mark_fb_busy(dev, frontbuffer_bits, NULL);
184 185
186 intel_edp_drrs_flush(dev, frontbuffer_bits);
185 intel_psr_flush(dev, frontbuffer_bits); 187 intel_psr_flush(dev, frontbuffer_bits);
186 188
187 /* 189 /*