aco: do not use the vec3 variant for stores on GFX6
GFX6 only supports vec3 with load/store format. Signed-off-by: Samuel Pitoiset <samuel.pitoiset@gmail.com> Reviewed-By: Timur Kristóf <timur.kristof@gmail.com> Reviewed-by: Daniel Schürmann <daniel@schuermann.dev> Part-of: <https://gitlab.freedesktop.org/mesa/mesa/merge_requests/3432>
This commit is contained in:

committed by
Marge Bot

parent
b8abfafe86
commit
1b5bb204d9
@@ -4501,7 +4501,8 @@ void visit_store_ssbo(isel_context *ctx, nir_intrinsic_instr *instr)
|
|||||||
while (writemask) {
|
while (writemask) {
|
||||||
int start, count;
|
int start, count;
|
||||||
u_bit_scan_consecutive_range(&writemask, &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);
|
writemask |= 1u << (start + 2);
|
||||||
count = 2;
|
count = 2;
|
||||||
}
|
}
|
||||||
@@ -4551,7 +4552,7 @@ void visit_store_ssbo(isel_context *ctx, nir_intrinsic_instr *instr)
|
|||||||
case 12:
|
case 12:
|
||||||
vmem_op = aco_opcode::buffer_store_dwordx3;
|
vmem_op = aco_opcode::buffer_store_dwordx3;
|
||||||
smem_op = aco_opcode::last_opcode;
|
smem_op = aco_opcode::last_opcode;
|
||||||
assert(!smem);
|
assert(!smem && ctx->options->chip_class > GFX6);
|
||||||
break;
|
break;
|
||||||
case 16:
|
case 16:
|
||||||
vmem_op = aco_opcode::buffer_store_dwordx4;
|
vmem_op = aco_opcode::buffer_store_dwordx4;
|
||||||
|
Reference in New Issue
Block a user