From: Samuel Pitoiset Date: Thu, 16 Jan 2020 13:37:11 +0000 (+0100) Subject: aco: do not use the vec3 variant for stores on GFX6 X-Git-Url: https://git.libre-soc.org/?a=commitdiff_plain;h=1b5bb204d9724e166b33dc03bb187499088f278d;p=mesa.git aco: do not use the vec3 variant for stores on GFX6 GFX6 only supports vec3 with load/store format. Signed-off-by: Samuel Pitoiset Reviewed-By: Timur Kristóf Reviewed-by: Daniel Schürmann Part-of: --- diff --git a/src/amd/compiler/aco_instruction_selection.cpp b/src/amd/compiler/aco_instruction_selection.cpp index 6d6d806a2d0..250f7011b04 100644 --- a/src/amd/compiler/aco_instruction_selection.cpp +++ b/src/amd/compiler/aco_instruction_selection.cpp @@ -4501,7 +4501,8 @@ void visit_store_ssbo(isel_context *ctx, nir_intrinsic_instr *instr) while (writemask) { int start, count; u_bit_scan_consecutive_range(&writemask, &start, &count); - if (count == 3 && smem) { + if (count == 3 && (smem || ctx->options->chip_class == GFX6)) { + /* GFX6 doesn't support storing vec3, split it. */ writemask |= 1u << (start + 2); count = 2; } @@ -4551,7 +4552,7 @@ void visit_store_ssbo(isel_context *ctx, nir_intrinsic_instr *instr) case 12: vmem_op = aco_opcode::buffer_store_dwordx3; smem_op = aco_opcode::last_opcode; - assert(!smem); + assert(!smem && ctx->options->chip_class > GFX6); break; case 16: vmem_op = aco_opcode::buffer_store_dwordx4;