OSDN Git Service

gallium/radeon/winsyses: fix counting mapped memory
authorMarek Olšák <marek.olsak@amd.com>
Sun, 4 Sep 2016 12:21:41 +0000 (14:21 +0200)
committerMarek Olšák <marek.olsak@amd.com>
Wed, 7 Sep 2016 09:13:13 +0000 (11:13 +0200)
Not all buffers are unmapped explicitly.

Reviewed-by: Nicolai Hähnle <nicolai.haehnle@amd.com>
src/gallium/winsys/amdgpu/drm/amdgpu_bo.c
src/gallium/winsys/radeon/drm/radeon_drm_bo.c

index a4bc474..32df0be 100644 (file)
@@ -151,6 +151,14 @@ void amdgpu_bo_destroy(struct pb_buffer *_buf)
       bo->ws->allocated_vram -= align64(bo->base.size, bo->ws->info.gart_page_size);
    else if (bo->initial_domain & RADEON_DOMAIN_GTT)
       bo->ws->allocated_gtt -= align64(bo->base.size, bo->ws->info.gart_page_size);
+
+   if (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;
+   }
+
    FREE(bo);
 }
 
index 56aab48..5db2061 100644 (file)
@@ -316,6 +316,14 @@ void radeon_bo_destroy(struct pb_buffer *_buf)
         rws->allocated_vram -= align(bo->base.size, rws->info.gart_page_size);
     else if (bo->initial_domain & RADEON_DOMAIN_GTT)
         rws->allocated_gtt -= align(bo->base.size, rws->info.gart_page_size);
+
+    if (bo->map_count >= 1) {
+        if (bo->initial_domain & RADEON_DOMAIN_VRAM)
+            bo->rws->mapped_vram -= bo->base.size;
+        else
+            bo->rws->mapped_gtt -= bo->base.size;
+    }
+
     FREE(bo);
 }