diff --git a/src/codegen.cpp b/src/codegen.cpp index 6dfa2520bc..dd734cbf63 100644 --- a/src/codegen.cpp +++ b/src/codegen.cpp @@ -401,10 +401,14 @@ static LLVMValueRef get_int_overflow_fn(CodeGen *g, TypeTableEntry *type_entry, } static LLVMValueRef get_handle_value(CodeGen *g, LLVMValueRef ptr, TypeTableEntry *type) { - if (handle_is_ptr(type)) { - return ptr; + if (type_has_bits(type)) { + if (handle_is_ptr(type)) { + return ptr; + } else { + return LLVMBuildLoad(g->builder, ptr, ""); + } } else { - return LLVMBuildLoad(g->builder, ptr, ""); + return nullptr; } } diff --git a/src/ir.cpp b/src/ir.cpp index c58b91f604..b215721acb 100644 --- a/src/ir.cpp +++ b/src/ir.cpp @@ -6493,14 +6493,18 @@ static TypeTableEntry *ir_analyze_instruction_phi(IrAnalyze *ira, IrInstructionP if (predecessor->ref_count == 0) continue; - assert(predecessor->other); - new_incoming_blocks.append(predecessor->other); IrInstruction *old_value = phi_instruction->incoming_values[i]; assert(old_value); IrInstruction *new_value = old_value->other; if (!new_value || new_value->type_entry->id == TypeTableEntryIdInvalid) return ira->codegen->builtin_types.entry_invalid; + + if (new_value->type_entry->id == TypeTableEntryIdUnreachable) + continue; + + assert(predecessor->other); + new_incoming_blocks.append(predecessor->other); new_incoming_values.append(new_value); } assert(new_incoming_blocks.length != 0);