amd/common: Fix tcCompatible degradation on Stoney.
authorBas Nieuwenhuizen <bas@basnieuwenhuizen.nl>
Wed, 11 Dec 2019 15:04:58 +0000 (16:04 +0100)
committerMarge Bot <eric+marge@anholt.net>
Sat, 14 Dec 2019 20:39:29 +0000 (20:39 +0000)
addrlib sometimes returns smaller sizes for tcCompat as it does
not seem to take into account the depth+stencil matching config
gymnastics with tcCompat.

This fixes
dEQP-VK.pipeline.render_to_image.core.2d_array.huge.height.r8g8b8a8_unorm_d32_sfloat_s8_uint

CC: <mesa-stable@lists.freedesktop.org>
Reviewed-by: Marek Olšák <marek.olsak@amd.com>
Part-of: <https://gitlab.freedesktop.org/mesa/mesa/merge_requests/3054>

src/amd/common/ac_surface.c

index c51c493775ed192e5b179b56261773f342dda158..0376f5d79c7e95ea7fd08875d48aec68537ba403 100644 (file)
@@ -344,7 +344,7 @@ static int gfx6_compute_level(ADDR_HANDLE addrlib,
            surf_level->mode == RADEON_SURF_MODE_2D &&
            level == 0 &&
            !(surf->flags & RADEON_SURF_NO_HTILE)) {
-               AddrHtileIn->flags.tcCompatible = AddrSurfInfoIn->flags.tcCompatible;
+               AddrHtileIn->flags.tcCompatible = AddrSurfInfoOut->tcCompatible;
                AddrHtileIn->pitch = AddrSurfInfoOut->pitch;
                AddrHtileIn->height = AddrSurfInfoOut->height;
                AddrHtileIn->numSlices = AddrSurfInfoOut->depth;