aboutsummaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
authorgingerBill <bill@gingerbill.org>2020-12-01 00:40:54 +0000
committergingerBill <bill@gingerbill.org>2020-12-01 00:40:54 +0000
commit400816ebf71c94cbc1a4454e72c2d12ec93b847c (patch)
treebf2e6e2296226d75c193424a653b378535d94a67 /src
parentef417017f0e6ae061844cc4e0f5e050c6a7a4fc4 (diff)
Fix Pointer store in LLVM backend
Diffstat (limited to 'src')
-rw-r--r--src/llvm_backend.cpp4
1 files changed, 2 insertions, 2 deletions
diff --git a/src/llvm_backend.cpp b/src/llvm_backend.cpp
index d4e77ccc8..37702a4b2 100644
--- a/src/llvm_backend.cpp
+++ b/src/llvm_backend.cpp
@@ -493,7 +493,7 @@ void lb_emit_store(lbProcedure *p, lbValue ptr, lbValue value) {
GB_ASSERT_MSG(are_types_identical(ca, core_type(value.type)), "%s != %s", type_to_string(a), type_to_string(value.type));
}
- if (USE_LLVM_ABI && is_type_proc(a)) {
+ if (is_type_proc(a)) {
// NOTE(bill, 2020-11-11): Because of certain LLVM rules, a procedure value may be
// stored as regular pointer with no procedure information
@@ -502,7 +502,7 @@ void lb_emit_store(lbProcedure *p, lbValue ptr, lbValue value) {
LLVMBuildStore(p->builder, v, ptr.value);
} else {
Type *ca = core_type(a);
- if (ca->kind == Type_Basic) {
+ if (ca->kind == Type_Basic && ca->kind == Type_Proc) {
GB_ASSERT_MSG(are_types_identical(ca, core_type(value.type)), "%s != %s", type_to_string(a), type_to_string(value.type));
} else {
GB_ASSERT_MSG(are_types_identical(a, value.type), "%s != %s", type_to_string(a), type_to_string(value.type));