drm/i915: Stop skipping the final clflush back to system pages
authorChris Wilson <chris@chris-wilson.co.uk>
Fri, 11 Nov 2016 14:58:09 +0000 (14:58 +0000)
committerChris Wilson <chris@chris-wilson.co.uk>
Fri, 11 Nov 2016 16:21:52 +0000 (16:21 +0000)
When we release the shmem backing storage, we make sure that the pages
are coherent with the cpu cache. However, our clflush routine was
skipping the flush as the object had no pages at release time. Fix this by
explicitly flushing the sg_table we are decoupling.

Fixes: 03ac84f1830e ("drm/i915: Pass around sg_table to get_pages/put_pages backend")
Signed-off-by: Chris Wilson <chris@chris-wilson.co.uk>
Cc: Joonas Lahtinen <joonas.lahtinen@linux.intel.com>
Reviewed-by: Joonas Lahtinen <joonas.lahtinen@linux.intel.com>
Link: http://patchwork.freedesktop.org/patch/msgid/20161111145809.9701-2-chris@chris-wilson.co.uk
drivers/gpu/drm/i915/i915_gem.c

index 4ea3e537eceb9bdec72f6cdd3c6952d11567a1e3..ed4465d22ddea9f294f1733727eaceb2cf683aaa 100644 (file)
@@ -220,7 +220,8 @@ i915_gem_object_get_pages_phys(struct drm_i915_gem_object *obj)
 }
 
 static void
-__i915_gem_object_release_shmem(struct drm_i915_gem_object *obj)
+__i915_gem_object_release_shmem(struct drm_i915_gem_object *obj,
+                               struct sg_table *pages)
 {
        GEM_BUG_ON(obj->mm.madv == __I915_MADV_PURGED);
 
@@ -228,7 +229,7 @@ __i915_gem_object_release_shmem(struct drm_i915_gem_object *obj)
                obj->mm.dirty = false;
 
        if ((obj->base.read_domains & I915_GEM_DOMAIN_CPU) == 0)
-               i915_gem_clflush_object(obj, false);
+               drm_clflush_sg(pages);
 
        obj->base.read_domains = I915_GEM_DOMAIN_CPU;
        obj->base.write_domain = I915_GEM_DOMAIN_CPU;
@@ -238,7 +239,7 @@ static void
 i915_gem_object_put_pages_phys(struct drm_i915_gem_object *obj,
                               struct sg_table *pages)
 {
-       __i915_gem_object_release_shmem(obj);
+       __i915_gem_object_release_shmem(obj, pages);
 
        if (obj->mm.dirty) {
                struct address_space *mapping = obj->base.filp->f_mapping;
@@ -2150,7 +2151,7 @@ i915_gem_object_put_pages_gtt(struct drm_i915_gem_object *obj,
        struct sgt_iter sgt_iter;
        struct page *page;
 
-       __i915_gem_object_release_shmem(obj);
+       __i915_gem_object_release_shmem(obj, pages);
 
        i915_gem_gtt_finish_pages(obj, pages);