From c098a8f5223855b410895b5396948e3e2b3aacba Mon Sep 17 00:00:00 2001 From: Andrew Kelley Date: Fri, 6 May 2016 23:10:14 -0700 Subject: add frame_address and return_address builtins --- src/codegen.cpp | 27 +++++++++++++++++++++++++++ 1 file changed, 27 insertions(+) (limited to 'src/codegen.cpp') diff --git a/src/codegen.cpp b/src/codegen.cpp index 9e2f2bc91f..8ecdd36358 100644 --- a/src/codegen.cpp +++ b/src/codegen.cpp @@ -634,6 +634,13 @@ static LLVMValueRef gen_builtin_fn_call_expr(CodeGen *g, AstNode *node) { case BuiltinFnIdBreakpoint: set_debug_source_node(g, node); return LLVMBuildCall(g->builder, g->trap_fn_val, nullptr, 0, ""); + case BuiltinFnIdFrameAddress: + case BuiltinFnIdReturnAddress: + { + LLVMValueRef zero = LLVMConstNull(g->builtin_types.entry_i32->type_ref); + set_debug_source_node(g, node); + return LLVMBuildCall(g->builder, builtin_fn->fn_val, &zero, 1, ""); + } case BuiltinFnIdCmpExchange: return gen_cmp_exchange(g, node); case BuiltinFnIdFence: @@ -4330,6 +4337,26 @@ static void define_builtin_fns(CodeGen *g) { g->trap_fn_val = builtin_fn->fn_val; } + { + BuiltinFnEntry *builtin_fn = create_builtin_fn_with_arg_count(g, BuiltinFnIdReturnAddress, + "return_address", 0); + builtin_fn->return_type = get_pointer_to_type(g, g->builtin_types.entry_u8, true); + + LLVMTypeRef fn_type = LLVMFunctionType(builtin_fn->return_type->type_ref, + &g->builtin_types.entry_i32->type_ref, 1, false); + builtin_fn->fn_val = LLVMAddFunction(g->module, "llvm.returnaddress", fn_type); + assert(LLVMGetIntrinsicID(builtin_fn->fn_val)); + } + { + BuiltinFnEntry *builtin_fn = create_builtin_fn_with_arg_count(g, BuiltinFnIdFrameAddress, + "frame_address", 0); + builtin_fn->return_type = get_pointer_to_type(g, g->builtin_types.entry_u8, true); + + LLVMTypeRef fn_type = LLVMFunctionType(builtin_fn->return_type->type_ref, + &g->builtin_types.entry_i32->type_ref, 1, false); + builtin_fn->fn_val = LLVMAddFunction(g->module, "llvm.frameaddress", fn_type); + assert(LLVMGetIntrinsicID(builtin_fn->fn_val)); + } { BuiltinFnEntry *builtin_fn = create_builtin_fn(g, BuiltinFnIdMemcpy, "memcpy"); builtin_fn->return_type = g->builtin_types.entry_void; -- cgit v1.2.3