Mesa (staging/19.3): aco: fix 64-bit fsign with 0
GitLab Mirror
gitlab-mirror at kemper.freedesktop.org
Mon Nov 18 18:10:46 UTC 2019
Module: Mesa
Branch: staging/19.3
Commit: 72585a6e5aaff66adf92aa86d59559ce06617f3b
URL: http://cgit.freedesktop.org/mesa/mesa/commit/?id=72585a6e5aaff66adf92aa86d59559ce06617f3b
Author: Rhys Perry <pendingchaos02 at gmail.com>
Date: Mon Nov 11 14:19:51 2019 +0000
aco: fix 64-bit fsign with 0
Signed-off-by: Rhys Perry <pendingchaos02 at gmail.com>
Fixes: 93c8ebfa ('aco: Initial commit of independent AMD compiler')
Reviewed-by: Daniel Schürmann <daniel at schuermann.dev>
(cherry picked from commit be1d11249bde1e041f6eb9c0acedb041ab450c4b)
---
src/amd/compiler/aco_instruction_selection.cpp | 2 +-
1 file changed, 1 insertion(+), 1 deletion(-)
diff --git a/src/amd/compiler/aco_instruction_selection.cpp b/src/amd/compiler/aco_instruction_selection.cpp
index d32ee580613..ed6ece3e6f2 100644
--- a/src/amd/compiler/aco_instruction_selection.cpp
+++ b/src/amd/compiler/aco_instruction_selection.cpp
@@ -1647,7 +1647,7 @@ void visit_alu_instr(isel_context *ctx, nir_alu_instr *instr)
} else if (dst.size() == 2) {
Temp cond = bld.vopc(aco_opcode::v_cmp_nlt_f64, bld.hint_vcc(bld.def(s2)), Operand(0u), src);
Temp tmp = bld.vop1(aco_opcode::v_mov_b32, bld.def(v1), Operand(0x3FF00000u));
- Temp upper = bld.vop2_e64(aco_opcode::v_cndmask_b32, bld.def(v1), tmp, src, cond);
+ Temp upper = bld.vop2_e64(aco_opcode::v_cndmask_b32, bld.def(v1), tmp, emit_extract_vector(ctx, src, 1, v1), cond);
cond = bld.vopc(aco_opcode::v_cmp_le_f64, bld.hint_vcc(bld.def(s2)), Operand(0u), src);
tmp = bld.vop1(aco_opcode::v_mov_b32, bld.def(v1), Operand(0xBFF00000u));
More information about the mesa-commit
mailing list