mirror of
https://gitlab.freedesktop.org/mesa/mesa.git
synced 2026-05-06 02:58:05 +02:00
r600/sfn: Fix ssbo/image atomic swap for Cayman
Signed-off-by: Gert Wollny <gert.wollny@collabora.com> Part-of: <https://gitlab.freedesktop.org/mesa/mesa/-/merge_requests/10608>
This commit is contained in:
parent
9898bc2915
commit
3b1f82c777
1 changed files with 2 additions and 3 deletions
|
|
@ -419,8 +419,7 @@ EmitSSBOInstruction::emit_ssbo_atomic_op(const nir_intrinsic_instr *intrin)
|
|||
if (intrin->intrinsic == nir_intrinsic_ssbo_atomic_comp_swap) {
|
||||
emit_instruction(new AluInstruction(op1_mov, m_rat_return_address.reg_i(0),
|
||||
from_nir(intrin->src[3], 0), {alu_write}));
|
||||
// TODO: cayman wants channel 2 here
|
||||
emit_instruction(new AluInstruction(op1_mov, m_rat_return_address.reg_i(3),
|
||||
emit_instruction(new AluInstruction(op1_mov, m_rat_return_address.reg_i(get_chip_class() == CAYMAN ? 2 : 3),
|
||||
from_nir(intrin->src[2], 0), {alu_last_instr, alu_write}));
|
||||
} else {
|
||||
emit_instruction(new AluInstruction(op1_mov, m_rat_return_address.reg_i(0),
|
||||
|
|
@ -491,7 +490,7 @@ EmitSSBOInstruction::emit_image_load(const nir_intrinsic_instr *intrin)
|
|||
if (intrin->intrinsic == nir_intrinsic_image_atomic_comp_swap) {
|
||||
emit_instruction(new AluInstruction(op1_mov, m_rat_return_address.reg_i(0),
|
||||
from_nir(intrin->src[4], 0), {alu_write}));
|
||||
emit_instruction(new AluInstruction(op1_mov, m_rat_return_address.reg_i(3),
|
||||
emit_instruction(new AluInstruction(op1_mov, m_rat_return_address.reg_i(get_chip_class() == CAYMAN ? 2 : 3),
|
||||
from_nir(intrin->src[3], 0), {alu_last_instr, alu_write}));
|
||||
} else {
|
||||
emit_instruction(new AluInstruction(op1_mov, m_rat_return_address.reg_i(0),
|
||||
|
|
|
|||
Loading…
Add table
Reference in a new issue