IR: phi instruction handles unreachable values correctly
This commit is contained in:
parent
b59841a80f
commit
a76b048354
@ -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;
|
||||
}
|
||||
}
|
||||
|
||||
|
@ -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);
|
||||
|
Loading…
x
Reference in New Issue
Block a user