[Mesa-dev] [PATCH 3/5] ac: pass ac_nir_context to visit_var_atomic()
Timothy Arceri
tarceri at itsqueeze.com
Fri Feb 9 01:48:03 UTC 2018
Thsi will enable us to use it with the radeonsi backend.
---
src/amd/common/ac_nir_to_llvm.c | 15 ++++++++-------
1 file changed, 8 insertions(+), 7 deletions(-)
diff --git a/src/amd/common/ac_nir_to_llvm.c b/src/amd/common/ac_nir_to_llvm.c
index 72105c21e4..e7352cc7d2 100644
--- a/src/amd/common/ac_nir_to_llvm.c
+++ b/src/amd/common/ac_nir_to_llvm.c
@@ -3908,16 +3908,16 @@ visit_load_local_invocation_index(struct nir_to_llvm_context *ctx)
return LLVMBuildAdd(ctx->builder, result, thread_id, "");
}
-static LLVMValueRef visit_var_atomic(struct nir_to_llvm_context *ctx,
+static LLVMValueRef visit_var_atomic(struct ac_nir_context *ctx,
const nir_intrinsic_instr *instr)
{
LLVMValueRef ptr, result;
- LLVMValueRef src = get_src(ctx->nir, instr->src[0]);
- ptr = build_gep_for_deref(ctx->nir, instr->variables[0]);
+ LLVMValueRef src = get_src(ctx, instr->src[0]);
+ ptr = build_gep_for_deref(ctx, instr->variables[0]);
if (instr->intrinsic == nir_intrinsic_var_atomic_comp_swap) {
- LLVMValueRef src1 = get_src(ctx->nir, instr->src[1]);
- result = LLVMBuildAtomicCmpXchg(ctx->builder,
+ LLVMValueRef src1 = get_src(ctx, instr->src[1]);
+ result = LLVMBuildAtomicCmpXchg(ctx->ac.builder,
ptr, src, src1,
LLVMAtomicOrderingSequentiallyConsistent,
LLVMAtomicOrderingSequentiallyConsistent,
@@ -3956,7 +3956,8 @@ static LLVMValueRef visit_var_atomic(struct nir_to_llvm_context *ctx,
return NULL;
}
- result = LLVMBuildAtomicRMW(ctx->builder, op, ptr, ac_to_integer(&ctx->ac, src),
+ result = LLVMBuildAtomicRMW(ctx->ac.builder, op, ptr,
+ ac_to_integer(&ctx->ac, src),
LLVMAtomicOrderingSequentiallyConsistent,
false);
}
@@ -4466,7 +4467,7 @@ static void visit_intrinsic(struct ac_nir_context *ctx,
case nir_intrinsic_var_atomic_xor:
case nir_intrinsic_var_atomic_exchange:
case nir_intrinsic_var_atomic_comp_swap:
- result = visit_var_atomic(ctx->nctx, instr);
+ result = visit_var_atomic(ctx, instr);
break;
case nir_intrinsic_interp_var_at_centroid:
case nir_intrinsic_interp_var_at_sample:
--
2.14.3
More information about the mesa-dev
mailing list