aco: fix encoding of certain s_setreg_imm32_b32 instructions
[mesa.git] / src / amd / compiler / aco_lower_to_hw_instr.cpp
index 5e93dc603e6b65a49d33c7f5e46eb989e80adefa..441e1b6b8e5e5ebc4f8f4c3dc5e7c94fb6d4343a 100644 (file)
@@ -1658,7 +1658,9 @@ void lower_to_hw_instr(Program* program)
          assert(block->kind & block_kind_top_level);
          uint32_t mode = block->fp_mode.val;
          /* "((size - 1) << 11) | register" (MODE is encoded as register 1) */
-         bld.sopk(aco_opcode::s_setreg_imm32_b32, Operand(mode), (7 << 11) | 1);
+         Instruction *instr = bld.sopk(aco_opcode::s_setreg_imm32_b32, Operand(mode), (7 << 11) | 1).instr;
+         /* has to be a literal */
+         instr->operands[0].setFixed(PhysReg{255});
       }
 
       for (size_t j = 0; j < block->instructions.size(); j++) {