From: Michel Dänzer Date: Sun, 6 Sep 2009 16:12:14 +0000 (+0200) Subject: r300g: Handle PIPE_BUFFER_USAGE_DONTBLOCK as intended. X-Git-Tag: 062012170305~15523^2~132 X-Git-Url: http://review.tizen.org/git/?a=commitdiff_plain;h=7b8ec0d8e72b4dd0c60db9c9454acd1f1ec75a7e;p=profile%2Fivi%2Fmesa.git r300g: Handle PIPE_BUFFER_USAGE_DONTBLOCK as intended. Return NULL if the BO is busy, otherwise just map it. --- diff --git a/src/gallium/winsys/drm/radeon/core/radeon_buffer.c b/src/gallium/winsys/drm/radeon/core/radeon_buffer.c index 07551e7..ee39af9 100644 --- a/src/gallium/winsys/drm/radeon/core/radeon_buffer.c +++ b/src/gallium/winsys/drm/radeon/core/radeon_buffer.c @@ -134,8 +134,11 @@ static void *radeon_buffer_map(struct pipe_winsys *ws, (struct radeon_pipe_buffer*)buffer; int write = 0; - if (!(flags & PIPE_BUFFER_USAGE_DONTBLOCK)) { - radeon_bo_wait(radeon_buffer->bo); + if (flags & PIPE_BUFFER_USAGE_DONTBLOCK) { + uint32_t domain; + + if (radeon_bo_is_busy(radeon_buffer->bo, &domain)) + return NULL; } if (flags & PIPE_BUFFER_USAGE_CPU_WRITE) { write = 1;