Signed-off-by: Tilman Sauerbeck <til...@code-monkey.de>
---
 src/gallium/winsys/r600/drm/radeon_bo_pb.c |   10 ++++++----
 1 files changed, 6 insertions(+), 4 deletions(-)

diff --git a/src/gallium/winsys/r600/drm/radeon_bo_pb.c 
b/src/gallium/winsys/r600/drm/radeon_bo_pb.c
index f74b934..312552f 100644
--- a/src/gallium/winsys/r600/drm/radeon_bo_pb.c
+++ b/src/gallium/winsys/r600/drm/radeon_bo_pb.c
@@ -63,11 +63,13 @@ static void radeon_bo_pb_destroy(struct pb_buffer *_buf)
 {
        struct radeon_bo_pb *buf = radeon_bo_pb(_buf);
 
-       LIST_DEL(&buf->maplist);
-
-       if (buf->bo->data != NULL) {
+       /* If this buffer is on the list of buffers to unmap,
+        * do the unmapping now.
+        */
+       if (!LIST_IS_EMPTY(&buf->maplist))
                radeon_bo_unmap(buf->mgr->radeon, buf->bo);
-       }
+
+       LIST_DEL(&buf->maplist);
        radeon_bo_reference(buf->mgr->radeon, &buf->bo, NULL);
        FREE(buf);
 }
-- 
1.7.3.1

_______________________________________________
mesa-dev mailing list
mesa-dev@lists.freedesktop.org
http://lists.freedesktop.org/mailman/listinfo/mesa-dev

Reply via email to