zig

fork of https://codeberg.org/ziglang/zig
Log | Files | Refs | README | LICENSE

commit 8de5e8bcd1528d4cd0a468fedb8cd735f83069b6 (tree)
parent 7ef85468265ecbc53efa18f67a5bd5ef46b8c7fb
Author: Martin Wickham <spexguy070@gmail.com>
Date:   Sun, 11 Jul 2021 22:24:33 -0500

Merge pull request #9358 from SpexGuy/remove-owner-bb

Remove Stage1AirInst::owner_bb, use zir owner instead.
Diffstat:
Msrc/stage1/all_types.hpp | 1-
Msrc/stage1/ir.cpp | 4+---
2 files changed, 1 insertion(+), 4 deletions(-)

diff --git a/src/stage1/all_types.hpp b/src/stage1/all_types.hpp @@ -2744,7 +2744,6 @@ struct Stage1AirInst { LLVMValueRef llvm_value; ZigValue *value; - Stage1AirBasicBlock *owner_bb; // Nearly any instruction can have to be stored as a local variable before suspending // and then loaded after resuming, in case there is an expression with a suspend point // in it, such as: x + await y diff --git a/src/stage1/ir.cpp b/src/stage1/ir.cpp @@ -1116,7 +1116,6 @@ static T *ir_create_inst_gen(IrBuilderGen *irb, Scope *scope, AstNode *source_no special_instruction->base.scope = scope; special_instruction->base.source_node = source_node; special_instruction->base.debug_id = exec_next_debug_id_gen(irb->exec); - special_instruction->base.owner_bb = irb->current_basic_block; special_instruction->base.value = irb->codegen->pass1_arena->create<ZigValue>(); return special_instruction; } @@ -1128,7 +1127,6 @@ static T *ir_create_inst_noval(IrBuilderGen *irb, Scope *scope, AstNode *source_ special_instruction->base.scope = scope; special_instruction->base.source_node = source_node; special_instruction->base.debug_id = exec_next_debug_id_gen(irb->exec); - special_instruction->base.owner_bb = irb->current_basic_block; return special_instruction; } @@ -14024,7 +14022,7 @@ static Stage1AirInst *ir_analyze_instruction_phi(IrAnalyze *ira, Stage1ZirInstPh instrs_to_move.append(ira->new_irb.current_basic_block->instruction_list.pop()); } if (instrs_to_move.length != 0) { - Stage1AirBasicBlock *predecessor = peer_parent->base.source_instruction->child->owner_bb; + Stage1AirBasicBlock *predecessor = peer_parent->base.source_instruction->owner_bb->child; Stage1AirInst *branch_instruction = predecessor->instruction_list.pop(); src_assert(branch_instruction->value->type->id == ZigTypeIdUnreachable, phi_instruction->base.source_node);