dma-buf: add DMA_RESV_USAGE_KERNEL v3
authorChristian König <christian.koenig@amd.com>
Fri, 26 Nov 2021 13:12:42 +0000 (14:12 +0100)
committerChristian König <christian.koenig@amd.com>
Thu, 7 Apr 2022 10:53:54 +0000 (12:53 +0200)
Add an usage for kernel submissions. Waiting for those are mandatory for
dynamic DMA-bufs.

As a precaution this patch also changes all occurrences where fences are
added as part of memory management in TTM, VMWGFX and i915 to use the
new value because it now becomes possible for drivers to ignore fences
with the WRITE usage.

v2: use "must" in documentation, fix whitespaces
v3: separate out some driver changes and better document why some
    changes should still be part of this patch.

Signed-off-by: Christian König <christian.koenig@amd.com>
Reviewed-by: Daniel Vetter <daniel.vetter@ffwll.ch>
Link: https://patchwork.freedesktop.org/patch/msgid/20220407085946.744568-5-christian.koenig@amd.com
drivers/dma-buf/dma-resv.c
drivers/dma-buf/st-dma-resv.c
drivers/gpu/drm/i915/gem/i915_gem_clflush.c
drivers/gpu/drm/ttm/ttm_bo.c
drivers/gpu/drm/ttm/ttm_bo_util.c
drivers/gpu/drm/vmwgfx/vmwgfx_bo.c
include/linux/dma-resv.h

index 378d47e1cfea33e14df05776f4269c77fc041c42..f4860e5f2d8b5b879311f4ff094372d7f989a406 100644 (file)
@@ -726,7 +726,7 @@ EXPORT_SYMBOL_GPL(dma_resv_test_signaled);
  */
 void dma_resv_describe(struct dma_resv *obj, struct seq_file *seq)
 {
-       static const char *usage[] = { "write", "read" };
+       static const char *usage[] = { "kernel", "write", "read" };
        struct dma_resv_iter cursor;
        struct dma_fence *fence;
 
index d0f7c2bfd4f0d73d461012bf0d9c1fce5d4ab63f..062b57d63fa65b3e749668736e0d03237062689d 100644 (file)
@@ -296,7 +296,7 @@ int dma_resv(void)
        int r;
 
        spin_lock_init(&fence_lock);
-       for (usage = DMA_RESV_USAGE_WRITE; usage <= DMA_RESV_USAGE_READ;
+       for (usage = DMA_RESV_USAGE_KERNEL; usage <= DMA_RESV_USAGE_READ;
             ++usage) {
                r = subtests(tests, (void *)(unsigned long)usage);
                if (r)
index f5f2b8b115eac348e9bc367e71be511bbe5f1c5a..0512afdd20d8bcd56a83a3322ce8a9ba0683cc39 100644 (file)
@@ -117,7 +117,7 @@ bool i915_gem_clflush_object(struct drm_i915_gem_object *obj,
                                                i915_fence_timeout(i915),
                                                I915_FENCE_GFP);
                dma_resv_add_fence(obj->base.resv, &clflush->base.dma,
-                                  DMA_RESV_USAGE_WRITE);
+                                  DMA_RESV_USAGE_KERNEL);
                dma_fence_work_commit(&clflush->base);
                /*
                 * We must have successfully populated the pages(since we are
index d74f9eea855e228602460234cba0e80989cc601c..6bf3fb1c80451df0b9013810e91ae545ea90d68b 100644 (file)
@@ -739,7 +739,7 @@ static int ttm_bo_add_move_fence(struct ttm_buffer_object *bo,
                return ret;
        }
 
-       dma_resv_add_fence(bo->base.resv, fence, DMA_RESV_USAGE_WRITE);
+       dma_resv_add_fence(bo->base.resv, fence, DMA_RESV_USAGE_KERNEL);
 
        ret = dma_resv_reserve_fences(bo->base.resv, 1);
        if (unlikely(ret)) {
index 7a96a1db13a753ccb6de7ef05d1e72dac7fcc273..99deb45894f412bba12f03f8f5256a8fc2bdaa91 100644 (file)
@@ -508,7 +508,7 @@ static int ttm_bo_move_to_ghost(struct ttm_buffer_object *bo,
                return ret;
 
        dma_resv_add_fence(&ghost_obj->base._resv, fence,
-                          DMA_RESV_USAGE_WRITE);
+                          DMA_RESV_USAGE_KERNEL);
 
        /**
         * If we're not moving to fixed memory, the TTM object
@@ -562,7 +562,7 @@ int ttm_bo_move_accel_cleanup(struct ttm_buffer_object *bo,
        struct ttm_resource_manager *man = ttm_manager_type(bdev, new_mem->mem_type);
        int ret = 0;
 
-       dma_resv_add_fence(bo->base.resv, fence, DMA_RESV_USAGE_WRITE);
+       dma_resv_add_fence(bo->base.resv, fence, DMA_RESV_USAGE_KERNEL);
        if (!evict)
                ret = ttm_bo_move_to_ghost(bo, fence, man->use_tt);
        else if (!from->use_tt && pipeline)
index bec50223efe50a86007639208b5539a481b9137b..408ede1f967f195962a65ad7dad8ae4ff2939fcd 100644 (file)
@@ -759,7 +759,7 @@ void vmw_bo_fence_single(struct ttm_buffer_object *bo,
        ret = dma_resv_reserve_fences(bo->base.resv, 1);
        if (!ret)
                dma_resv_add_fence(bo->base.resv, &fence->base,
-                                  DMA_RESV_USAGE_WRITE);
+                                  DMA_RESV_USAGE_KERNEL);
        else
                /* Last resort fallback when we are OOM */
                dma_fence_wait(&fence->base, false);
index 7bb7e7edbb6f082bedacdbee15ba8e74eac659ef..a749f229ae917d226a786fabb75290ea74d161ad 100644 (file)
@@ -55,11 +55,29 @@ struct dma_resv_list;
  * This enum describes the different use cases for a dma_resv object and
  * controls which fences are returned when queried.
  *
- * An important fact is that there is the order WRITE<READ and when the
- * dma_resv object is asked for fences for one use case the fences for the
- * lower use case are returned as well.
+ * An important fact is that there is the order KERNEL<WRITE<READ and
+ * when the dma_resv object is asked for fences for one use case the fences
+ * for the lower use case are returned as well.
+ *
+ * For example when asking for WRITE fences then the KERNEL fences are returned
+ * as well. Similar when asked for READ fences then both WRITE and KERNEL
+ * fences are returned as well.
  */
 enum dma_resv_usage {
+       /**
+        * @DMA_RESV_USAGE_KERNEL: For in kernel memory management only.
+        *
+        * This should only be used for things like copying or clearing memory
+        * with a DMA hardware engine for the purpose of kernel memory
+        * management.
+        *
+        * Drivers *always* must wait for those fences before accessing the
+        * resource protected by the dma_resv object. The only exception for
+        * that is when the resource is known to be locked down in place by
+        * pinning it previously.
+        */
+       DMA_RESV_USAGE_KERNEL,
+
        /**
         * @DMA_RESV_USAGE_WRITE: Implicit write synchronization.
         *