From: Erik Faye-Lund Date: Fri, 8 Nov 2019 11:53:43 +0000 (+0100) Subject: zink: implement buffer-to-buffer copies X-Git-Url: https://git.libre-soc.org/?a=commitdiff_plain;h=e1c87bbb4bcaa9b5946bc88f9f5d7868372d8400;p=mesa.git zink: implement buffer-to-buffer copies --- diff --git a/src/gallium/drivers/zink/zink_context.c b/src/gallium/drivers/zink/zink_context.c index 30d19c6ffa2..2be6ce351be 100644 --- a/src/gallium/drivers/zink/zink_context.c +++ b/src/gallium/drivers/zink/zink_context.c @@ -1510,6 +1510,18 @@ zink_resource_copy_region(struct pipe_context *pctx, vkCmdCopyImage(batch->cmdbuf, src->image, src->layout, dst->image, dst->layout, 1, ®ion); + } else if (dst->base.target == PIPE_BUFFER && + src->base.target == PIPE_BUFFER) { + VkBufferCopy region; + region.srcOffset = src_box->x; + region.dstOffset = dstx; + region.size = src_box->width; + + struct zink_batch *batch = zink_batch_no_rp(ctx); + zink_batch_reference_resoure(batch, src); + zink_batch_reference_resoure(batch, dst); + + vkCmdCopyBuffer(batch->cmdbuf, src->buffer, dst->buffer, 1, ®ion); } else debug_printf("zink: TODO resource copy\n"); }