Fixes:
2d6b0a4177b ("aco/optimizer: Optimize SOPC with literal to SOPK.")
Signed-off-by: Georg Lehmann <dadschoorse@gmail.com>
Reviewed-by: Daniel Schürmann <daniel@schuermann.dev>
Part-of: <https://gitlab.freedesktop.org/mesa/mesa/-/merge_requests/17407>
}
static aco_opcode
-sopc_32_inverse(aco_opcode opcode)
+sopc_32_swapped(aco_opcode opcode)
{
#define SOPC(op1, op2) \
case aco_opcode::s_cmp_##op1##_i32: return aco_opcode::s_cmp_##op2##_i32; \
switch (opcode) {
SOPC(eq, eq)
SOPC(lg, lg)
- SOPC(gt, le)
- SOPC(ge, lt)
- SOPC(lt, ge)
- SOPC(le, gt)
+ SOPC(gt, lt)
+ SOPC(ge, le)
+ SOPC(lt, gt)
+ SOPC(le, ge)
default: return aco_opcode::num_opcodes;
}
#undef SOPC
if (instr->operands[0].isLiteral()) {
std::swap(instr->operands[0], instr->operands[1]);
- instr->opcode = sopc_32_inverse(instr->opcode);
+ instr->opcode = sopc_32_swapped(instr->opcode);
}
if (!instr->operands[1].isLiteral())