From: Rob Clark Date: Wed, 2 Jan 2019 16:04:16 +0000 (-0500) Subject: freedreno: try blitter for fd_resource_copy_region() X-Git-Url: https://git.libre-soc.org/?a=commitdiff_plain;h=53b8eb78d5491a448830ff4628086a592c6f4fe3;p=mesa.git freedreno: try blitter for fd_resource_copy_region() Signed-off-by: Rob Clark --- diff --git a/src/gallium/drivers/freedreno/freedreno_blitter.c b/src/gallium/drivers/freedreno/freedreno_blitter.c index 5c480757772..aaf39f4c4d2 100644 --- a/src/gallium/drivers/freedreno/freedreno_blitter.c +++ b/src/gallium/drivers/freedreno/freedreno_blitter.c @@ -173,6 +173,33 @@ fd_resource_copy_region(struct pipe_context *pctx, { struct fd_context *ctx = fd_context(pctx); + if (ctx->blit) { + struct pipe_blit_info info; + + memset(&info, 0, sizeof info); + info.dst.resource = dst; + info.dst.level = dst_level; + info.dst.box.x = dstx; + info.dst.box.y = dsty; + info.dst.box.z = dstz; + info.dst.box.width = src_box->width; + info.dst.box.height = src_box->height; + assert(info.dst.box.width >= 0); + assert(info.dst.box.height >= 0); + info.dst.box.depth = 1; + info.dst.format = dst->format; + info.src.resource = src; + info.src.level = src_level; + info.src.box = *src_box; + info.src.format = src->format; + info.mask = util_format_get_mask(src->format); + info.filter = PIPE_TEX_FILTER_NEAREST; + info.scissor_enable = 0; + + if (ctx->blit(ctx, &info)) + return; + } + /* TODO if we have 2d core, or other DMA engine that could be used * for simple copies and reasonably easily synchronized with the 3d * core, this is where we'd plug it in..