aboutsummaryrefslogtreecommitdiff
path: root/src/llvm_backend.cpp
diff options
context:
space:
mode:
Diffstat (limited to 'src/llvm_backend.cpp')
-rw-r--r--src/llvm_backend.cpp13
1 files changed, 11 insertions, 2 deletions
diff --git a/src/llvm_backend.cpp b/src/llvm_backend.cpp
index 8052bf759..65586d3a6 100644
--- a/src/llvm_backend.cpp
+++ b/src/llvm_backend.cpp
@@ -7835,8 +7835,17 @@ lbValue lb_build_builtin_proc(lbProcedure *p, Ast *expr, TypeAndValue const &tv,
}
case BuiltinProc_cpu_relax:
- // TODO(bill): BuiltinProc_cpu_relax
- // ir_write_str_lit(f, "call void asm sideeffect \"pause\", \"\"()");
+ {
+ LLVMTypeRef func_type = LLVMFunctionType(LLVMVoidTypeInContext(p->module->ctx), nullptr, 0, false);
+ LLVMValueRef the_asm = LLVMGetInlineAsm(func_type,
+ "pause", 5,
+ "", 0,
+ /*HasSideEffects*/true, /*IsAlignStack*/false,
+ LLVMInlineAsmDialectATT
+ );
+ GB_ASSERT(the_asm != nullptr);
+ LLVMBuildCall2(p->builder, func_type, the_asm, nullptr, 0, "");
+ }
return {};
case BuiltinProc_atomic_fence: