From 5fa488f163fbaa049e213f4b1cabf885ab49816f Mon Sep 17 00:00:00 2001 From: gingerBill Date: Sat, 24 Oct 2020 15:08:35 +0100 Subject: Add intrinsics.cpu_relax for llvm-api --- src/llvm_backend.cpp | 13 +++++++++++-- 1 file changed, 11 insertions(+), 2 deletions(-) (limited to 'src/llvm_backend.cpp') 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: -- cgit v1.2.3