From 400816ebf71c94cbc1a4454e72c2d12ec93b847c Mon Sep 17 00:00:00 2001 From: gingerBill Date: Tue, 1 Dec 2020 00:40:54 +0000 Subject: Fix Pointer store in LLVM backend --- src/llvm_backend.cpp | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) (limited to 'src/llvm_backend.cpp') 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)); -- cgit v1.2.3