summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--.pick_status.json2
-rw-r--r--src/gallium/auxiliary/gallivm/lp_bld_nir_soa.c20
2 files changed, 5 insertions, 17 deletions
diff --git a/.pick_status.json b/.pick_status.json
index c51207a20cd..3f20413e2c4 100644
--- a/.pick_status.json
+++ b/.pick_status.json
@@ -9652,7 +9652,7 @@
"description": "gallivm: Fix atomic_global types",
"nominated": true,
"nomination_type": 0,
- "resolution": 0,
+ "resolution": 1,
"main_sha": null,
"because_sha": null
},
diff --git a/src/gallium/auxiliary/gallivm/lp_bld_nir_soa.c b/src/gallium/auxiliary/gallivm/lp_bld_nir_soa.c
index b656891a9af..262643e3234 100644
--- a/src/gallium/auxiliary/gallivm/lp_bld_nir_soa.c
+++ b/src/gallium/auxiliary/gallivm/lp_bld_nir_soa.c
@@ -1034,6 +1034,7 @@ static void emit_atomic_global(struct lp_build_nir_context *bld_base,
LLVMValueRef value_ptr = LLVMBuildExtractElement(gallivm->builder, val,
loop_state.counter, "");
+ value_ptr = LLVMBuildBitCast(gallivm->builder, value_ptr, atom_bld->elem_type, "");
LLVMValueRef addr_ptr = LLVMBuildExtractElement(gallivm->builder, addr,
loop_state.counter, "");
@@ -1107,25 +1108,12 @@ static void emit_atomic_global(struct lp_build_nir_context *bld_base,
LLVMAtomicOrderingSequentiallyConsistent,
false);
}
- temp_res = LLVMBuildLoad2(builder, LLVMTypeOf(val), atom_res, "");
+ temp_res = LLVMBuildLoad2(builder, atom_bld->vec_type, atom_res, "");
temp_res = LLVMBuildInsertElement(builder, temp_res, scalar, loop_state.counter, "");
LLVMBuildStore(builder, temp_res, atom_res);
lp_build_else(&ifthen);
- temp_res = LLVMBuildLoad2(builder, LLVMTypeOf(val), atom_res, "");
- bool is_float = LLVMTypeOf(val) == bld_base->base.vec_type;
- LLVMValueRef zero_val;
- if (is_float) {
- if (val_bit_size == 64)
- zero_val = lp_build_const_double(gallivm, 0);
- else
- zero_val = lp_build_const_float(gallivm, 0);
- } else {
- if (val_bit_size == 64)
- zero_val = lp_build_const_int64(gallivm, 0);
- else
- zero_val = lp_build_const_int32(gallivm, 0);
- }
-
+ temp_res = LLVMBuildLoad2(builder, atom_bld->vec_type, atom_res, "");
+ LLVMValueRef zero_val = lp_build_zero_bits(gallivm, val_bit_size, is_flt);
temp_res = LLVMBuildInsertElement(builder, temp_res, zero_val, loop_state.counter, "");
LLVMBuildStore(builder, temp_res, atom_res);
lp_build_endif(&ifthen);