Mesa (master): u_blitter: port radv 3D blit coords logic.
GitLab Mirror
gitlab-mirror at kemper.freedesktop.org
Wed Nov 11 08:35:16 UTC 2020
Module: Mesa
Branch: master
Commit: ea034c981b9649c4999e3b7f4164f27213e736b3
URL: http://cgit.freedesktop.org/mesa/mesa/commit/?id=ea034c981b9649c4999e3b7f4164f27213e736b3
Author: Dave Airlie <airlied at redhat.com>
Date: Mon Nov 9 11:06:27 2020 +1000
u_blitter: port radv 3D blit coords logic.
The current code fails a lot of VK CTS tests, this fixes them all:
dEQP-VK*blit_image*3d*
Cc: 20.3 <mesa-stable>
Reviewed-by: Roland Scheidegger <sroland at vmware.com>
Part-of: <https://gitlab.freedesktop.org/mesa/mesa/-/merge_requests/7499>
---
src/gallium/auxiliary/util/u_blitter.c | 20 ++++++++++++++------
1 file changed, 14 insertions(+), 6 deletions(-)
diff --git a/src/gallium/auxiliary/util/u_blitter.c b/src/gallium/auxiliary/util/u_blitter.c
index 92a180a2c04..0019eb13730 100644
--- a/src/gallium/auxiliary/util/u_blitter.c
+++ b/src/gallium/auxiliary/util/u_blitter.c
@@ -1819,7 +1819,10 @@ static void do_blits(struct blitter_context_priv *ctx,
int dst_z;
for (dst_z = 0; dst_z < dstbox->depth; dst_z++) {
struct pipe_surface *old;
- float dst2src_scale = srcbox->depth / (float)dstbox->depth;
+ bool flipped = (srcbox->depth < 0);
+ float depth_center_offset = 0.0;
+ int src_depth = abs(srcbox->depth);
+ float src_z_step = src_depth / (float)dstbox->depth;
/* Scale Z properly if the blit is scaled.
*
@@ -1835,12 +1838,17 @@ static void do_blits(struct blitter_context_priv *ctx,
* src Z: 0 1 2 3 4 5 6 7
* dst Z: 0 1 2 3
*
- * dst_offset defines the offset needed for centering the pixels and
- * it works with any scaling (not just 2x).
+ * This calculation is taken from the radv driver.
*/
- float dst_offset = ((srcbox->depth - 1) -
- (dstbox->depth - 1) * dst2src_scale) * 0.5;
- float src_z = (dst_z + dst_offset) * dst2src_scale;
+ if (src_target == PIPE_TEXTURE_3D)
+ depth_center_offset = 0.5 / dstbox->depth * src_depth;
+
+ if (flipped) {
+ src_z_step *= - 1;
+ depth_center_offset *= -1;
+ }
+
+ float src_z = dst_z * src_z_step + depth_center_offset;
/* Set framebuffer state. */
if (is_zsbuf) {
More information about the mesa-commit
mailing list