aboutsummaryrefslogtreecommitdiff
path: root/src/llvm_backend_general.cpp
diff options
context:
space:
mode:
authorgingerBill <bill@gingerbill.org>2022-11-13 22:55:32 +0000
committergingerBill <bill@gingerbill.org>2022-11-13 22:55:32 +0000
commita705a2e38bee035d6800999ba6eddd82792594f7 (patch)
tree9beece2552d41ad12489e7cfaf73df80bbf6fb95 /src/llvm_backend_general.cpp
parent7dfbda58d9c51932fa91a04727b821860358289d (diff)
Minor improvement to multi return value reducing stack usage
Diffstat (limited to 'src/llvm_backend_general.cpp')
-rw-r--r--src/llvm_backend_general.cpp24
1 files changed, 14 insertions, 10 deletions
diff --git a/src/llvm_backend_general.cpp b/src/llvm_backend_general.cpp
index f36dc1842..6f2253d01 100644
--- a/src/llvm_backend_general.cpp
+++ b/src/llvm_backend_general.cpp
@@ -936,23 +936,27 @@ void lb_emit_store(lbProcedure *p, lbValue ptr, lbValue value) {
LLVMValueRef src_ptr_original = LLVMGetOperand(value.value, 0);
LLVMValueRef src_ptr = LLVMBuildPointerCast(p->builder, src_ptr_original, LLVMTypeOf(dst_ptr), "");
- LLVMBuildMemMove(p->builder,
- dst_ptr, lb_try_get_alignment(dst_ptr, 1),
- src_ptr, lb_try_get_alignment(src_ptr_original, 1),
- LLVMConstInt(LLVMInt64TypeInContext(p->module->ctx), lb_sizeof(LLVMTypeOf(value.value)), false));
+ if (dst_ptr != src_ptr && dst_ptr != src_ptr_original) {
+ LLVMBuildMemMove(p->builder,
+ dst_ptr, lb_try_get_alignment(dst_ptr, 1),
+ src_ptr, lb_try_get_alignment(src_ptr_original, 1),
+ LLVMConstInt(LLVMInt64TypeInContext(p->module->ctx), lb_sizeof(LLVMTypeOf(value.value)), false));
+ }
return;
} else if (LLVMIsConstant(value.value)) {
lbAddr addr = lb_add_global_generated(p->module, value.type, value, nullptr);
lb_make_global_private_const(addr);
LLVMValueRef dst_ptr = ptr.value;
- LLVMValueRef src_ptr = addr.addr.value;
- src_ptr = LLVMBuildPointerCast(p->builder, src_ptr, LLVMTypeOf(dst_ptr), "");
+ LLVMValueRef src_ptr_original = addr.addr.value;
+ LLVMValueRef src_ptr = LLVMBuildPointerCast(p->builder, src_ptr_original, LLVMTypeOf(dst_ptr), "");
- LLVMBuildMemMove(p->builder,
- dst_ptr, lb_try_get_alignment(dst_ptr, 1),
- src_ptr, lb_try_get_alignment(src_ptr, 1),
- LLVMConstInt(LLVMInt64TypeInContext(p->module->ctx), lb_sizeof(LLVMTypeOf(value.value)), false));
+ if (dst_ptr != src_ptr && dst_ptr != src_ptr_original) {
+ LLVMBuildMemMove(p->builder,
+ dst_ptr, lb_try_get_alignment(dst_ptr, 1),
+ src_ptr, lb_try_get_alignment(src_ptr, 1),
+ LLVMConstInt(LLVMInt64TypeInContext(p->module->ctx), lb_sizeof(LLVMTypeOf(value.value)), false));
+ }
return;
}
}