Commit 6053ca4f69

Andrew Kelley <andrew@ziglang.org>
2019-07-21 23:10:16
fix not jumping to entry
1 parent 27a5f2c
Changed files (2)
src/codegen.cpp
@@ -6413,6 +6413,7 @@ static void do_code_gen(CodeGen *g) {
                 ZigLLVMSetCurrentDebugLocation(g->builder, (int)source_node->line + 1,
                         (int)source_node->column + 1, get_di_scope(g, fn_table_entry->child_scope));
             }
+            IrExecutable *executable = &fn_table_entry->analyzed_executable;
             LLVMTypeRef usize_type_ref = g->builtin_types.entry_usize->llvm_type;
             LLVMBasicBlockRef bad_resume_block = LLVMAppendBasicBlock(g->cur_fn_val, "BadResume");
             LLVMPositionBuilderAtEnd(g->builder, bad_resume_block);
@@ -6429,15 +6430,19 @@ static void do_code_gen(CodeGen *g) {
             LLVMValueRef resume_index_ptr = LLVMBuildStructGEP(g->builder, g->cur_ret_ptr,
                     coro_resume_index_index, "");
             LLVMValueRef resume_index = LLVMBuildLoad(g->builder, resume_index_ptr, "");
-            // The +1 is because index 0 is reserved for getting the size.
+            // +1 - index 0 is reserved for the entry block
+            // +1 - index 1 is reserved for getting the size.
             LLVMValueRef switch_instr = LLVMBuildSwitch(g->builder, resume_index, bad_resume_block,
-                    fn_table_entry->resume_blocks.length + 1);
+                    fn_table_entry->resume_blocks.length + 2);
 
             LLVMValueRef zero = LLVMConstNull(usize_type_ref);
-            LLVMAddCase(switch_instr, zero, get_size_block);
+            LLVMAddCase(switch_instr, zero, executable->basic_block_list.at(0)->llvm_block);
+
+            LLVMValueRef one = LLVMConstInt(usize_type_ref, 1, false);
+            LLVMAddCase(switch_instr, one, get_size_block);
 
             for (size_t resume_i = 0; resume_i < fn_table_entry->resume_blocks.length; resume_i += 1) {
-                LLVMValueRef case_value = LLVMConstInt(usize_type_ref, resume_i + 1, false);
+                LLVMValueRef case_value = LLVMConstInt(usize_type_ref, resume_i + 2, false);
                 LLVMAddCase(switch_instr, case_value, fn_table_entry->resume_blocks.at(resume_i)->llvm_block);
             }
         }
src/ir.cpp
@@ -24121,9 +24121,11 @@ static IrInstruction *ir_analyze_instruction_suspend_br(IrAnalyze *ira, IrInstru
 
     ZigFn *fn_entry = exec_fn_entry(ira->new_irb.exec);
     ir_assert(fn_entry != nullptr, &instruction->base);
+
+    // +2 - one for the GetSize block, one for the Entry block, resume blocks are indexed after that.
+    new_bb->resume_index = fn_entry->resume_blocks.length + 2;
+
     fn_entry->resume_blocks.append(new_bb);
-    // This is done after appending the block because resume_index 0 is reserved for querying the size.
-    new_bb->resume_index = fn_entry->resume_blocks.length;
 
     ir_push_resume_block(ira, old_dest_block);