diff options
author | Kenneth Graunke <[email protected]> | 2019-01-16 02:02:19 -0800 |
---|---|---|
committer | Kenneth Graunke <[email protected]> | 2019-02-21 10:26:11 -0800 |
commit | c81941f1e7d72b80450e2250dcc1537177fd82c8 (patch) | |
tree | a82092129d0647b170ca34b04f359c295d5c196c /src/gallium | |
parent | 7837fec740f93745174f1d4a6071a7d14fb07820 (diff) |
iris: Pay attention to blit masks
For combined depth/stencil formats, we may want to only blit one half.
If PIPE_BLIT_Z is set, blit depth; if PIPE_BLIT_S is set, blit stencil.
Diffstat (limited to 'src/gallium')
-rw-r--r-- | src/gallium/drivers/iris/iris_blit.c | 33 |
1 files changed, 22 insertions, 11 deletions
diff --git a/src/gallium/drivers/iris/iris_blit.c b/src/gallium/drivers/iris/iris_blit.c index c386da298de..d36b998bef4 100644 --- a/src/gallium/drivers/iris/iris_blit.c +++ b/src/gallium/drivers/iris/iris_blit.c @@ -353,20 +353,31 @@ iris_blit(struct pipe_context *ctx, const struct pipe_blit_info *info) struct blorp_batch blorp_batch; blorp_batch_init(&ice->blorp, &blorp_batch, batch, blorp_flags); - for (int slice = 0; slice < info->dst.box.depth; slice++) { - iris_batch_maybe_flush(batch, 1500); + unsigned main_mask; + if (info->dst.format == PIPE_FORMAT_S8_UINT) + main_mask = PIPE_MASK_S; + else if (util_format_is_depth_or_stencil(info->dst.format)) + main_mask = PIPE_MASK_Z; + else + main_mask = PIPE_MASK_RGBA; + + if (info->mask & main_mask) { + for (int slice = 0; slice < info->dst.box.depth; slice++) { + iris_batch_maybe_flush(batch, 1500); - blorp_blit(&blorp_batch, - &src_surf, info->src.level, info->src.box.z + slice, - src_fmt.fmt, src_fmt.swizzle, - &dst_surf, info->dst.level, info->dst.box.z + slice, - dst_fmt.fmt, ISL_SWIZZLE_IDENTITY, - src_x0, src_y0, src_x1, src_y1, - dst_x0, dst_y0, dst_x1, dst_y1, - filter, mirror_x, mirror_y); + blorp_blit(&blorp_batch, + &src_surf, info->src.level, info->src.box.z + slice, + src_fmt.fmt, src_fmt.swizzle, + &dst_surf, info->dst.level, info->dst.box.z + slice, + dst_fmt.fmt, ISL_SWIZZLE_IDENTITY, + src_x0, src_y0, src_x1, src_y1, + dst_x0, dst_y0, dst_x1, dst_y1, + filter, mirror_x, mirror_y); + } } - if (util_format_is_depth_and_stencil(info->dst.format) && + if ((info->mask & PIPE_MASK_S) && + util_format_is_depth_and_stencil(info->dst.format) && util_format_has_stencil(util_format_description(info->src.format))) { struct iris_resource *src_res, *dst_res, *junk; iris_get_depth_stencil_resources(info->src.resource, &junk, &src_res); |