gallium/radeon: don't use temporary buffers for persistent mappings
Cc: 11.1 11.2 <mesa-stable@lists.freedesktop.org> Reviewed-by: Michel Dänzer <michel.daenzer@amd.com>
This commit is contained in:
parent
14b18aba89
commit
3146014d5f
|
@ -314,7 +314,8 @@ static void *r600_buffer_transfer_map(struct pipe_context *ctx,
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
else if ((usage & PIPE_TRANSFER_DISCARD_RANGE) &&
|
else if ((usage & PIPE_TRANSFER_DISCARD_RANGE) &&
|
||||||
!(usage & PIPE_TRANSFER_UNSYNCHRONIZED) &&
|
!(usage & (PIPE_TRANSFER_UNSYNCHRONIZED |
|
||||||
|
PIPE_TRANSFER_PERSISTENT)) &&
|
||||||
!(rscreen->debug_flags & DBG_NO_DISCARD_RANGE) &&
|
!(rscreen->debug_flags & DBG_NO_DISCARD_RANGE) &&
|
||||||
r600_can_dma_copy_buffer(rctx, box->x, 0, box->width)) {
|
r600_can_dma_copy_buffer(rctx, box->x, 0, box->width)) {
|
||||||
assert(usage & PIPE_TRANSFER_WRITE);
|
assert(usage & PIPE_TRANSFER_WRITE);
|
||||||
|
@ -341,7 +342,8 @@ static void *r600_buffer_transfer_map(struct pipe_context *ctx,
|
||||||
}
|
}
|
||||||
/* Using a staging buffer in GTT for larger reads is much faster. */
|
/* Using a staging buffer in GTT for larger reads is much faster. */
|
||||||
else if ((usage & PIPE_TRANSFER_READ) &&
|
else if ((usage & PIPE_TRANSFER_READ) &&
|
||||||
!(usage & PIPE_TRANSFER_WRITE) &&
|
!(usage & (PIPE_TRANSFER_WRITE |
|
||||||
|
PIPE_TRANSFER_PERSISTENT)) &&
|
||||||
rbuffer->domains == RADEON_DOMAIN_VRAM &&
|
rbuffer->domains == RADEON_DOMAIN_VRAM &&
|
||||||
r600_can_dma_copy_buffer(rctx, 0, box->x, box->width)) {
|
r600_can_dma_copy_buffer(rctx, 0, box->x, box->width)) {
|
||||||
struct r600_resource *staging;
|
struct r600_resource *staging;
|
||||||
|
|
Loading…
Reference in New Issue