diff options
| author | gingerBill <bill@gingerbill.org> | 2021-12-28 14:05:18 +0000 |
|---|---|---|
| committer | gingerBill <bill@gingerbill.org> | 2021-12-28 14:05:18 +0000 |
| commit | 5d653a9d8eee496089522e9f74986b808a123938 (patch) | |
| tree | 660d2405bed22bad6c34b19cef623023a3ab24bd /src/llvm_backend_proc.cpp | |
| parent | 7f61a90ea1be96c22cae87fdbfdc08b30f2421d6 (diff) | |
| parent | 6f370fdbf2811a82b09a8fe9afcd805cdf3477eb (diff) | |
Merge branch 'master' of https://github.com/odin-lang/Odin
Diffstat (limited to 'src/llvm_backend_proc.cpp')
| -rw-r--r-- | src/llvm_backend_proc.cpp | 4 |
1 files changed, 4 insertions, 0 deletions
diff --git a/src/llvm_backend_proc.cpp b/src/llvm_backend_proc.cpp index 25b27ee47..84fddd9e2 100644 --- a/src/llvm_backend_proc.cpp +++ b/src/llvm_backend_proc.cpp @@ -736,6 +736,10 @@ lbValue lb_emit_call_internal(lbProcedure *p, lbValue value, lbValue return_ptr, LLVMValueRef ret = LLVMBuildCall2(p->builder, fnp, fn, args, arg_count, ""); + if (return_ptr.value != nullptr) { + LLVMAddCallSiteAttribute(ret, 1, lb_create_enum_attribute_with_type(p->module->ctx, "sret", LLVMTypeOf(args[0]))); + } + switch (inlining) { case ProcInlining_none: break; |