diff options
| author | gingerBill <gingerBill@users.noreply.github.com> | 2023-10-30 15:00:55 +0000 |
|---|---|---|
| committer | GitHub <noreply@github.com> | 2023-10-30 15:00:55 +0000 |
| commit | 51caa930caa903ecbf7926374cd129a7f64acf23 (patch) | |
| tree | ac247a12015dc09d18d8c5c02ebe81f343176f6f /src/llvm_backend_general.cpp | |
| parent | 82cd30a14568814dfa70d383cf43c8d0d0bd6b16 (diff) | |
| parent | b7af4e7f6b3f8f96ca6d3efa492098293bfa4109 (diff) | |
Merge pull request #2905 from odin-lang/llvm-17-custom-passes
Explicit Optimization Passes for LLVM-17 Passes
Diffstat (limited to 'src/llvm_backend_general.cpp')
| -rw-r--r-- | src/llvm_backend_general.cpp | 6 |
1 files changed, 5 insertions, 1 deletions
diff --git a/src/llvm_backend_general.cpp b/src/llvm_backend_general.cpp index 0f0df7ca5..fdcf94f29 100644 --- a/src/llvm_backend_general.cpp +++ b/src/llvm_backend_general.cpp @@ -962,8 +962,12 @@ gb_internal bool lb_is_type_proc_recursive(Type *t) { gb_internal void lb_emit_store(lbProcedure *p, lbValue ptr, lbValue value) { GB_ASSERT(value.value != nullptr); - Type *a = type_deref(ptr.type); + if (LLVMIsUndef(value.value)) { + return; + } + + Type *a = type_deref(ptr.type); if (LLVMIsNull(value.value)) { LLVMTypeRef src_t = llvm_addr_type(p->module, ptr); if (is_type_proc(a)) { |