From: Marek Olšák Date: Fri, 28 Jul 2017 23:18:02 +0000 (+0200) Subject: gallium/radeon: reallocate textures with non-zero tile_swizzle on export X-Git-Url: https://git.libre-soc.org/?a=commitdiff_plain;h=77260927951883e086ddec178a102c176a042505;p=mesa.git gallium/radeon: reallocate textures with non-zero tile_swizzle on export Reviewed-by: Dave Airlie Reviewed-by: Nicolai Hähnle --- diff --git a/src/gallium/drivers/radeon/r600_texture.c b/src/gallium/drivers/radeon/r600_texture.c index 2d58dc96499..07df2d43017 100644 --- a/src/gallium/drivers/radeon/r600_texture.c +++ b/src/gallium/drivers/radeon/r600_texture.c @@ -568,13 +568,15 @@ static boolean r600_texture_get_handle(struct pipe_screen* screen, return false; /* Move a suballocated texture into a non-suballocated allocation. */ - if (rscreen->ws->buffer_is_suballocated(res->buf)) { + if (rscreen->ws->buffer_is_suballocated(res->buf) || + rtex->surface.tile_swizzle) { assert(!res->b.is_shared); r600_reallocate_texture_inplace(rctx, rtex, PIPE_BIND_SHARED, false); rctx->b.flush(&rctx->b, NULL, 0); assert(res->b.b.bind & PIPE_BIND_SHARED); assert(res->flags & RADEON_FLAG_NO_SUBALLOC); + assert(rtex->surface.tile_swizzle == 0); } /* Since shader image stores don't support DCC on VI,