]> git.proxmox.com Git - mirror_ubuntu-jammy-kernel.git/commitdiff
drm/ttm: fix broken merge between drm-next and drm-misc-next
authorChristian König <christian.koenig@amd.com>
Wed, 19 Aug 2020 13:27:48 +0000 (15:27 +0200)
committerChristian König <christian.koenig@amd.com>
Thu, 20 Aug 2020 12:03:10 +0000 (14:03 +0200)
drm-next reverted the changes to ttm_tt_create() to do the
NULL check inside the function, but drm-misc-next adds new
users of this approach.

Re-apply the NULL check change inside the function to fix this.

Signed-off-by: Christian König <christian.koenig@amd.com>
Reviewed-by: Dave Airlie <airlied@redhat.com>
Link: https://patchwork.freedesktop.org/patch/386628/
drivers/gpu/drm/ttm/ttm_bo.c
drivers/gpu/drm/ttm/ttm_tt.c

index 97ac662a47cb34ff81adcba7b0544595c082798f..e3931e515906e80f5007742ca75944d9d55a11b8 100644 (file)
@@ -1180,7 +1180,7 @@ int ttm_bo_validate(struct ttm_buffer_object *bo,
        /*
         * We might need to add a TTM.
         */
-       if (bo->mem.mem_type == TTM_PL_SYSTEM && bo->ttm == NULL) {
+       if (bo->mem.mem_type == TTM_PL_SYSTEM) {
                ret = ttm_tt_create(bo, true);
                if (ret)
                        return ret;
index 9aa4fbe386e62361d3dc05468fdcccf27eea236c..1ccf1ef050d6cf71cc83b3323c7498ad720a120e 100644 (file)
@@ -50,6 +50,9 @@ int ttm_tt_create(struct ttm_buffer_object *bo, bool zero_alloc)
 
        dma_resv_assert_held(bo->base.resv);
 
+       if (bo->ttm)
+               return 0;
+
        if (bdev->need_dma32)
                page_flags |= TTM_PAGE_FLAG_DMA32;
 
@@ -67,7 +70,6 @@ int ttm_tt_create(struct ttm_buffer_object *bo, bool zero_alloc)
                page_flags |= TTM_PAGE_FLAG_SG;
                break;
        default:
-               bo->ttm = NULL;
                pr_err("Illegal buffer object type\n");
                return -EINVAL;
        }