Very good. I should've added this when adding the dirtyfb flush... Thanks, Reviewed-by: Rodrigo Vivi <[email protected]>
On Tue, Jul 14, 2015 at 12:30 PM Paulo Zanoni <[email protected]> wrote: > From: Paulo Zanoni <[email protected]> > > First, an introduction. We currently have two types of GTT mmaps: the > "normal" old mmap, and the WC mmap. For frontbuffer-related features > that have automatic hardware tracking, only the non-WC mmap writes are > detected by the hardware. Since inside the Kernel both are treated as > ORIGIN_GTT, any features ignoring ORIGIN_GTT because of the hardware > tracking are destined to fail. > > One of the special rules defined for the WC mmaps is that the user > should call the dirtyfb IOCTL after he is done using the pointers, so > that results in an intel_fb_obj_flush() call. The problem is that the > dirtyfb is passing ORIGIN_GTT, so it is being ignored by FBC - even > though the hardware tracking is not detecing the WC mmap operations. > So in order to fix that without having to give up the automatic > hardware tracking for GTT mmaps we transform the flush operation from > dirtyfb into a special operation: ORIGIN_DIRTYFB. > > This commit fixes all the kms_frontbuffer_tracking subtests that > contain "fbc" and "mmap-wc" in their names and are currently failing > (for a total of 16 subtests). > > Signed-off-by: Paulo Zanoni <[email protected]> > --- > drivers/gpu/drm/i915/i915_drv.h | 1 + > drivers/gpu/drm/i915/intel_display.c | 2 +- > 2 files changed, 2 insertions(+), 1 deletion(-) > > diff --git a/drivers/gpu/drm/i915/i915_drv.h > b/drivers/gpu/drm/i915/i915_drv.h > index cf6761c..78d21c1 100644 > --- a/drivers/gpu/drm/i915/i915_drv.h > +++ b/drivers/gpu/drm/i915/i915_drv.h > @@ -894,6 +894,7 @@ enum fb_op_origin { > ORIGIN_CPU, > ORIGIN_CS, > ORIGIN_FLIP, > + ORIGIN_DIRTYFB, > }; > > struct i915_fbc { > diff --git a/drivers/gpu/drm/i915/intel_display.c > b/drivers/gpu/drm/i915/intel_display.c > index 6e3ba5f..cffaaf4a3 100644 > --- a/drivers/gpu/drm/i915/intel_display.c > +++ b/drivers/gpu/drm/i915/intel_display.c > @@ -14479,7 +14479,7 @@ static int intel_user_framebuffer_dirty(struct > drm_framebuffer *fb, > struct drm_i915_gem_object *obj = intel_fb->obj; > > mutex_lock(&dev->struct_mutex); > - intel_fb_obj_flush(obj, false, ORIGIN_GTT); > + intel_fb_obj_flush(obj, false, ORIGIN_DIRTYFB); > mutex_unlock(&dev->struct_mutex); > > return 0; > -- > 2.1.4 > > _______________________________________________ > Intel-gfx mailing list > [email protected] > http://lists.freedesktop.org/mailman/listinfo/intel-gfx >
_______________________________________________ Intel-gfx mailing list [email protected] http://lists.freedesktop.org/mailman/listinfo/intel-gfx
