Mesa (master): r600g: Respect PB_USAGE_UNSYNCHRONIZED in radeon_bo_pb_map_internal().

Henri Verbeet hverbeet at kemper.freedesktop.org
Sun Sep 19 21:03:27 UTC 2010


Module: Mesa
Branch: master
Commit: 0f9181811fc0e2943b156acc4d43f2da8a4846d1
URL:    http://cgit.freedesktop.org/mesa/mesa/commit/?id=0f9181811fc0e2943b156acc4d43f2da8a4846d1

Author: Henri Verbeet <hverbeet at gmail.com>
Date:   Sun Sep 19 22:58:42 2010 +0200

r600g: Respect PB_USAGE_UNSYNCHRONIZED in radeon_bo_pb_map_internal().

---

 src/gallium/winsys/r600/drm/radeon_bo_pb.c |    8 ++++++++
 1 files changed, 8 insertions(+), 0 deletions(-)

diff --git a/src/gallium/winsys/r600/drm/radeon_bo_pb.c b/src/gallium/winsys/r600/drm/radeon_bo_pb.c
index b8744b0..93dc927 100644
--- a/src/gallium/winsys/r600/drm/radeon_bo_pb.c
+++ b/src/gallium/winsys/r600/drm/radeon_bo_pb.c
@@ -54,6 +54,14 @@ radeon_bo_pb_map_internal(struct pb_buffer *_buf,
 {
 	struct radeon_bo_pb *buf = radeon_bo_pb(_buf);
 
+	if (flags & PB_USAGE_UNSYNCHRONIZED) {
+		if (!buf->bo->data && radeon_bo_map(buf->mgr->radeon, buf->bo)) {
+			return NULL;
+		}
+		LIST_DELINIT(&buf->maplist);
+		return buf->bo->data;
+	}
+
 	if (p_atomic_read(&buf->bo->reference.count) > 1) {
 		if (flags & PB_USAGE_DONTBLOCK) {
 			return NULL;




More information about the mesa-commit mailing list