]> www.infradead.org Git - users/hch/misc.git/commitdiff
drm/vmwgfx: Add new keep_resv BO param
authorIan Forbes <ian.forbes@broadcom.com>
Fri, 10 Jan 2025 18:53:35 +0000 (12:53 -0600)
committerZack Rusin <zack.rusin@broadcom.com>
Tue, 14 Jan 2025 18:01:43 +0000 (13:01 -0500)
Adds a new BO param that keeps the reservation locked after creation.
This removes the need to re-reserve the BO after creation which is a
waste of cycles.

This also fixes a bug in vmw_prime_import_sg_table where the imported
reservation is unlocked twice.

Signed-off-by: Ian Forbes <ian.forbes@broadcom.com>
Fixes: b32233acceff ("drm/vmwgfx: Fix prime import/export")
Reviewed-by: Zack Rusin <zack.rusin@broadcom.com>
Signed-off-by: Zack Rusin <zack.rusin@broadcom.com>
Link: https://patchwork.freedesktop.org/patch/msgid/20250110185335.15301-1-ian.forbes@broadcom.com
drivers/gpu/drm/vmwgfx/vmwgfx_bo.c
drivers/gpu/drm/vmwgfx/vmwgfx_bo.h
drivers/gpu/drm/vmwgfx/vmwgfx_drv.c
drivers/gpu/drm/vmwgfx/vmwgfx_gem.c
drivers/gpu/drm/vmwgfx/vmwgfx_shader.c
drivers/gpu/drm/vmwgfx/vmwgfx_ttm_buffer.c

index 5f13285f83e0b5f8f9a8536e9ab1e0187bd4deb7..9b5b8c1f063bb7896e0f4697ae6a48c6c7c17d7a 100644 (file)
@@ -442,7 +442,8 @@ static int vmw_bo_init(struct vmw_private *dev_priv,
 
        if (params->pin)
                ttm_bo_pin(&vmw_bo->tbo);
-       ttm_bo_unreserve(&vmw_bo->tbo);
+       if (!params->keep_resv)
+               ttm_bo_unreserve(&vmw_bo->tbo);
 
        return 0;
 }
index 07749f0a5f294df48cb420f2fafee43c6fbf7dba..11e330c7c7f52be1472d5471efbde7d750fb98a7 100644 (file)
@@ -56,8 +56,9 @@ struct vmw_bo_params {
        u32 domain;
        u32 busy_domain;
        enum ttm_bo_type bo_type;
-       size_t size;
        bool pin;
+       bool keep_resv;
+       size_t size;
        struct dma_resv *resv;
        struct sg_table *sg;
 };
index 2c46897876ddeca6c7ace4458b6c395edf915b80..b19a062592b087289f7671eea276c356cd2f3be1 100644 (file)
@@ -403,7 +403,8 @@ static int vmw_dummy_query_bo_create(struct vmw_private *dev_priv)
                .busy_domain = VMW_BO_DOMAIN_SYS,
                .bo_type = ttm_bo_type_kernel,
                .size = PAGE_SIZE,
-               .pin = true
+               .pin = true,
+               .keep_resv = true,
        };
 
        /*
@@ -415,10 +416,6 @@ static int vmw_dummy_query_bo_create(struct vmw_private *dev_priv)
        if (unlikely(ret != 0))
                return ret;
 
-       ret = ttm_bo_reserve(&vbo->tbo, false, true, NULL);
-       BUG_ON(ret != 0);
-       vmw_bo_pin_reserved(vbo, true);
-
        ret = ttm_bo_kmap(&vbo->tbo, 0, 1, &map);
        if (likely(ret == 0)) {
                result = ttm_kmap_obj_virtual(&map, &dummy);
index b9857f37ca1ac6f81b6285270a63c4de9a0b6f2e..ed5015ced3920a2444266e147349b57813684121 100644 (file)
@@ -206,6 +206,7 @@ struct drm_gem_object *vmw_prime_import_sg_table(struct drm_device *dev,
                .bo_type = ttm_bo_type_sg,
                .size = attach->dmabuf->size,
                .pin = false,
+               .keep_resv = true,
                .resv = attach->dmabuf->resv,
                .sg = table,
 
index a01ca3226d0af8909df61837e55d4726cd16a306..7fb1c88bcc475f2987630e099bef06ce369b7b32 100644 (file)
@@ -896,7 +896,8 @@ int vmw_compat_shader_add(struct vmw_private *dev_priv,
                .busy_domain = VMW_BO_DOMAIN_SYS,
                .bo_type = ttm_bo_type_device,
                .size = size,
-               .pin = true
+               .pin = true,
+               .keep_resv = true,
        };
 
        if (!vmw_shader_id_ok(user_key, shader_type))
@@ -906,10 +907,6 @@ int vmw_compat_shader_add(struct vmw_private *dev_priv,
        if (unlikely(ret != 0))
                goto out;
 
-       ret = ttm_bo_reserve(&buf->tbo, false, true, NULL);
-       if (unlikely(ret != 0))
-               goto no_reserve;
-
        /* Map and copy shader bytecode. */
        ret = ttm_bo_kmap(&buf->tbo, 0, PFN_UP(size), &map);
        if (unlikely(ret != 0)) {
index 621d98b376bbbc4b40cef6b9c6759b975610dd56..5553892d7c3e0d10cd0ff389bb2e00f6049f8d96 100644 (file)
@@ -572,15 +572,14 @@ int vmw_bo_create_and_populate(struct vmw_private *dev_priv,
                .busy_domain = domain,
                .bo_type = ttm_bo_type_kernel,
                .size = bo_size,
-               .pin = true
+               .pin = true,
+               .keep_resv = true,
        };
 
        ret = vmw_bo_create(dev_priv, &bo_params, &vbo);
        if (unlikely(ret != 0))
                return ret;
 
-       ret = ttm_bo_reserve(&vbo->tbo, false, true, NULL);
-       BUG_ON(ret != 0);
        ret = vmw_ttm_populate(vbo->tbo.bdev, vbo->tbo.ttm, &ctx);
        if (likely(ret == 0)) {
                struct vmw_ttm_tt *vmw_tt =