diff options
author | Marek Olšák <marek.olsak@amd.com> | 2016-08-05 01:28:17 +0200 |
---|---|---|
committer | Marek Olšák <marek.olsak@amd.com> | 2016-08-10 01:11:10 +0200 |
commit | 1e04483c22e372aac8a664fe2b272b10aa774eea (patch) | |
tree | 80ebf5aab7b27571cf6a1fec4d5f678fa9633c1c /src/gallium/winsys/amdgpu | |
parent | 8276776e645fa25a1cbac2aa7d52a319ffdc2d9a (diff) | |
download | external_mesa3d-1e04483c22e372aac8a664fe2b272b10aa774eea.zip external_mesa3d-1e04483c22e372aac8a664fe2b272b10aa774eea.tar.gz external_mesa3d-1e04483c22e372aac8a664fe2b272b10aa774eea.tar.bz2 |
winsys/amdgpu: track the amount of mapped memory
Reviewed-by: Nicolai Hähnle <nicolai.haehnle@amd.com>
Diffstat (limited to 'src/gallium/winsys/amdgpu')
-rw-r--r-- | src/gallium/winsys/amdgpu/drm/amdgpu_bo.c | 18 | ||||
-rw-r--r-- | src/gallium/winsys/amdgpu/drm/amdgpu_bo.h | 1 | ||||
-rw-r--r-- | src/gallium/winsys/amdgpu/drm/amdgpu_winsys.c | 4 | ||||
-rw-r--r-- | src/gallium/winsys/amdgpu/drm/amdgpu_winsys.h | 2 |
4 files changed, 24 insertions, 1 deletions
diff --git a/src/gallium/winsys/amdgpu/drm/amdgpu_bo.c b/src/gallium/winsys/amdgpu/drm/amdgpu_bo.c index db2c77f..a4bc474 100644 --- a/src/gallium/winsys/amdgpu/drm/amdgpu_bo.c +++ b/src/gallium/winsys/amdgpu/drm/amdgpu_bo.c @@ -256,8 +256,17 @@ static void *amdgpu_bo_map(struct pb_buffer *buf, /* Clear the cache and try again. */ pb_cache_release_all_buffers(&bo->ws->bo_cache); r = amdgpu_bo_cpu_map(bo->bo, &cpu); + if (r) + return NULL; + } + + if (p_atomic_inc_return(&bo->map_count) == 1) { + if (bo->initial_domain & RADEON_DOMAIN_VRAM) + bo->ws->mapped_vram += bo->base.size; + else + bo->ws->mapped_gtt += bo->base.size; } - return r ? NULL : cpu; + return cpu; } static void amdgpu_bo_unmap(struct pb_buffer *buf) @@ -267,6 +276,13 @@ static void amdgpu_bo_unmap(struct pb_buffer *buf) if (bo->user_ptr) return; + if (p_atomic_dec_zero(&bo->map_count)) { + if (bo->initial_domain & RADEON_DOMAIN_VRAM) + bo->ws->mapped_vram -= bo->base.size; + else + bo->ws->mapped_gtt -= bo->base.size; + } + amdgpu_bo_cpu_unmap(bo->bo); } diff --git a/src/gallium/winsys/amdgpu/drm/amdgpu_bo.h b/src/gallium/winsys/amdgpu/drm/amdgpu_bo.h index a768771..e2ee049 100644 --- a/src/gallium/winsys/amdgpu/drm/amdgpu_bo.h +++ b/src/gallium/winsys/amdgpu/drm/amdgpu_bo.h @@ -44,6 +44,7 @@ struct amdgpu_winsys_bo { void *user_ptr; /* from buffer_from_ptr */ amdgpu_bo_handle bo; + int map_count; uint32_t unique_id; amdgpu_va_handle va_handle; uint64_t va; diff --git a/src/gallium/winsys/amdgpu/drm/amdgpu_winsys.c b/src/gallium/winsys/amdgpu/drm/amdgpu_winsys.c index 1f24fcd..9556777 100644 --- a/src/gallium/winsys/amdgpu/drm/amdgpu_winsys.c +++ b/src/gallium/winsys/amdgpu/drm/amdgpu_winsys.c @@ -379,6 +379,10 @@ static uint64_t amdgpu_query_value(struct radeon_winsys *rws, return ws->allocated_vram; case RADEON_REQUESTED_GTT_MEMORY: return ws->allocated_gtt; + case RADEON_MAPPED_VRAM: + return ws->mapped_vram; + case RADEON_MAPPED_GTT: + return ws->mapped_gtt; case RADEON_BUFFER_WAIT_TIME_NS: return ws->buffer_wait_time; case RADEON_TIMESTAMP: diff --git a/src/gallium/winsys/amdgpu/drm/amdgpu_winsys.h b/src/gallium/winsys/amdgpu/drm/amdgpu_winsys.h index 8489530..96d4e6d 100644 --- a/src/gallium/winsys/amdgpu/drm/amdgpu_winsys.h +++ b/src/gallium/winsys/amdgpu/drm/amdgpu_winsys.h @@ -53,6 +53,8 @@ struct amdgpu_winsys { uint32_t next_bo_unique_id; uint64_t allocated_vram; uint64_t allocated_gtt; + uint64_t mapped_vram; + uint64_t mapped_gtt; uint64_t buffer_wait_time; /* time spent in buffer_wait in ns */ uint64_t num_cs_flushes; |