OSDN Git Service

radv/ac: implement txs for buffer textures.
authorDave Airlie <airlied@redhat.com>
Mon, 30 Jan 2017 19:19:56 +0000 (05:19 +1000)
committerEmil Velikov <emil.l.velikov@gmail.com>
Fri, 3 Feb 2017 11:08:58 +0000 (11:08 +0000)
This fixes a bunch of buffer related:
dEQP-VK.memory.pipeline_barrier.*
tests, that were crashing in LLVM due to this being missing.

Reviewed-by: Andres Rodriguez<andresx7@gmail.com>
Cc: "17.0" <mesa-stable@lists.freedesktop.org>
Signed-off-by: Dave Airlie <airlied@redhat.com>
(cherry picked from commit 0ecd426490b043aac6a5db0a6e0feaa39f6d9c54)

src/amd/common/ac_nir_to_llvm.c

index 18e3c39..68c2972 100644 (file)
@@ -3218,6 +3218,11 @@ static void visit_tex(struct nir_to_llvm_context *ctx, nir_tex_instr *instr)
                }
        }
 
+       if (instr->op == nir_texop_txs && instr->sampler_dim == GLSL_SAMPLER_DIM_BUF) {
+               result = get_buffer_size(ctx, res_ptr, false);
+               goto write_result;
+       }
+
        if (instr->op == nir_texop_texture_samples) {
                LLVMValueRef res, samples, is_msaa;
                res = LLVMBuildBitCast(ctx->builder, res_ptr, ctx->v8i32, "");