diff options
author | Marek Olšák <[email protected]> | 2018-10-06 20:56:32 -0400 |
---|---|---|
committer | Marek Olšák <[email protected]> | 2018-10-16 17:23:25 -0400 |
commit | 5030adcbe05f2ae97826f645f43c612f774411e8 (patch) | |
tree | c6659395397bde594c9d883c04db4a8fda1b7281 | |
parent | 0b40fbc8796b8e204e7af45b3d39b67d20fb3da7 (diff) |
radeonsi: use copy_buffer in buffer_do_flush_region directly
-rw-r--r-- | src/gallium/drivers/radeonsi/si_buffer.c | 15 |
1 files changed, 4 insertions, 11 deletions
diff --git a/src/gallium/drivers/radeonsi/si_buffer.c b/src/gallium/drivers/radeonsi/si_buffer.c index a03a94453a4..c7260e06ccf 100644 --- a/src/gallium/drivers/radeonsi/si_buffer.c +++ b/src/gallium/drivers/radeonsi/si_buffer.c @@ -521,18 +521,11 @@ static void si_buffer_do_flush_region(struct pipe_context *ctx, struct r600_resource *rbuffer = r600_resource(transfer->resource); if (stransfer->staging) { - struct pipe_resource *dst, *src; - unsigned soffset; - struct pipe_box dma_box; - - dst = transfer->resource; - src = &stransfer->staging->b.b; - soffset = stransfer->offset + box->x % SI_MAP_BUFFER_ALIGNMENT; - - u_box_1d(soffset, box->width, &dma_box); - /* Copy the staging buffer into the original one. */ - ctx->resource_copy_region(ctx, dst, 0, box->x, 0, 0, src, 0, &dma_box); + si_copy_buffer((struct si_context*)ctx, transfer->resource, + &stransfer->staging->b.b, box->x, + stransfer->offset + box->x % SI_MAP_BUFFER_ALIGNMENT, + box->width); } util_range_add(&rbuffer->valid_buffer_range, box->x, |