radeonsi: don't reallocate on DMABUF export if local BOs are disabled
authorMarek Olšák <marek.olsak@amd.com>
Thu, 15 Mar 2018 19:58:57 +0000 (15:58 -0400)
committerMarek Olšák <marek.olsak@amd.com>
Mon, 26 Mar 2018 23:22:12 +0000 (19:22 -0400)
src/amd/common/ac_gpu_info.c
src/amd/common/ac_gpu_info.h
src/gallium/drivers/radeon/r600_texture.c
src/gallium/winsys/amdgpu/drm/amdgpu_bo.c

index 73b5da0fe188d5615950bf800f12170d5b2807d0..73fc36203c1d95eb5dabe6e5c05fb0c732290fcb 100644 (file)
@@ -313,6 +313,8 @@ bool ac_query_gpu_info(int fd, amdgpu_device_handle dev,
        info->has_syncobj_wait_for_submit = info->has_syncobj && info->drm_minor >= 20;
        info->has_fence_to_handle = info->has_syncobj && info->drm_minor >= 21;
        info->has_ctx_priority = info->drm_minor >= 22;
+       /* TODO: Enable this once the kernel handles it efficiently. */
+       /*info->has_local_buffers = ws->info.drm_minor >= 20;*/
        info->num_render_backends = amdinfo->rb_pipes;
        info->clock_crystal_freq = amdinfo->gpu_counter_freq;
        if (!info->clock_crystal_freq) {
index 34d91bec14280d708c4cb40555c78729bfa3bda8..3f08b577c4bbe7604e788848ae3150e3778a1ff5 100644 (file)
@@ -89,6 +89,7 @@ struct radeon_info {
        bool                        has_syncobj_wait_for_submit;
        bool                        has_fence_to_handle;
        bool                        has_ctx_priority;
+       bool                        has_local_buffers;
 
        /* Shader cores. */
        uint32_t                    r600_max_quad_pipes; /* wave size / 16 */
index 3a0a79187b8a667268d93e36a0d025259fdbca4f..1614df63c98a2b46002484b226890fc9c4e01f83 100644 (file)
@@ -701,6 +701,7 @@ static boolean r600_texture_get_handle(struct pipe_screen* screen,
                if (sscreen->ws->buffer_is_suballocated(res->buf) ||
                    rtex->surface.tile_swizzle ||
                    (rtex->resource.flags & RADEON_FLAG_NO_INTERPROCESS_SHARING &&
+                    sscreen->info.has_local_buffers &&
                     whandle->type != DRM_API_HANDLE_TYPE_KMS)) {
                        assert(!res->b.is_shared);
                        r600_reallocate_texture_inplace(rctx, rtex,
@@ -762,7 +763,8 @@ static boolean r600_texture_get_handle(struct pipe_screen* screen,
                /* Move a suballocated buffer into a non-suballocated allocation. */
                if (sscreen->ws->buffer_is_suballocated(res->buf) ||
                    /* A DMABUF export always fails if the BO is local. */
-                   rtex->resource.flags & RADEON_FLAG_NO_INTERPROCESS_SHARING) {
+                   (rtex->resource.flags & RADEON_FLAG_NO_INTERPROCESS_SHARING &&
+                    sscreen->info.has_local_buffers)) {
                        assert(!res->b.is_shared);
 
                        /* Allocate a new buffer with PIPE_BIND_SHARED. */
index 12d497d29214f9be958283ffd5459580d786acfc..7740b46b7b9ef21b1c9931f495faaf2cc465b457 100644 (file)
@@ -423,10 +423,9 @@ static struct amdgpu_winsys_bo *amdgpu_create_bo(struct amdgpu_winsys *ws,
       request.flags |= AMDGPU_GEM_CREATE_NO_CPU_ACCESS;
    if (flags & RADEON_FLAG_GTT_WC)
       request.flags |= AMDGPU_GEM_CREATE_CPU_GTT_USWC;
-   /* TODO: Enable this once the kernel handles it efficiently. */
-   /*if (flags & RADEON_FLAG_NO_INTERPROCESS_SHARING &&
-       ws->info.drm_minor >= 20)
-      request.flags |= AMDGPU_GEM_CREATE_VM_ALWAYS_VALID;*/
+   if (flags & RADEON_FLAG_NO_INTERPROCESS_SHARING &&
+       ws->info.has_local_buffers)
+      request.flags |= AMDGPU_GEM_CREATE_VM_ALWAYS_VALID;
 
    r = amdgpu_bo_alloc(ws->dev, &request, &buf_handle);
    if (r) {