Skip to content

Commit 5b6c96c

Browse files
authored
Merge pull request #3466 from laytan/fix-proc-args-debug-info
fix direct proc args debug info
2 parents 75fcd50 + 90369b6 commit 5b6c96c

File tree

2 files changed

+4
-21
lines changed

2 files changed

+4
-21
lines changed

src/llvm_backend_debug.cpp

Lines changed: 2 additions & 10 deletions
Original file line numberDiff line numberDiff line change
@@ -1027,7 +1027,7 @@ gb_internal void lb_add_debug_local_variable(lbProcedure *p, LLVMValueRef ptr, T
10271027
LLVMDIBuilderInsertDeclareAtEnd(m->debug_builder, storage, var_info, llvm_expr, llvm_debug_loc, block);
10281028
}
10291029

1030-
gb_internal void lb_add_debug_param_variable(lbProcedure *p, LLVMValueRef ptr, Type *type, Token const &token, unsigned arg_number, lbBlock *block, lbArgKind arg_kind) {
1030+
gb_internal void lb_add_debug_param_variable(lbProcedure *p, LLVMValueRef ptr, Type *type, Token const &token, unsigned arg_number, lbBlock *block) {
10311031
if (p->debug_info == nullptr) {
10321032
return;
10331033
}
@@ -1088,15 +1088,7 @@ gb_internal void lb_add_debug_param_variable(lbProcedure *p, LLVMValueRef ptr, T
10881088
// NOTE(bill, 2022-02-01): For parameter values, you must insert them at the end of the decl block
10891089
// The reason is that if the parameter is at index 0 and a pointer, there is not such things as an
10901090
// instruction "before" it.
1091-
switch (arg_kind) {
1092-
case lbArg_Direct:
1093-
LLVMDIBuilderInsertDbgValueAtEnd(m->debug_builder, storage, var_info, llvm_expr, llvm_debug_loc, block->block);
1094-
break;
1095-
case lbArg_Indirect:
1096-
LLVMDIBuilderInsertDeclareAtEnd(m->debug_builder, storage, var_info, llvm_expr, llvm_debug_loc, block->block);
1097-
break;
1098-
}
1099-
1091+
LLVMDIBuilderInsertDeclareAtEnd(m->debug_builder, storage, var_info, llvm_expr, llvm_debug_loc, block->block);
11001092
}
11011093

11021094

src/llvm_backend_proc.cpp

Lines changed: 2 additions & 11 deletions
Original file line numberDiff line numberDiff line change
@@ -597,24 +597,15 @@ gb_internal void lb_begin_procedure_body(lbProcedure *p) {
597597
lbValue ptr = lb_address_from_load_or_generate_local(p, param);
598598
GB_ASSERT(LLVMIsAAllocaInst(ptr.value));
599599
lb_add_entity(p->module, e, ptr);
600-
601-
lbBlock *block = p->decl_block;
602-
if (original_value != value) {
603-
block = p->curr_block;
604-
}
605-
LLVMValueRef debug_storage_value = value;
606-
if (original_value != value && LLVMIsALoadInst(value)) {
607-
debug_storage_value = LLVMGetOperand(value, 0);
608-
}
609-
lb_add_debug_param_variable(p, debug_storage_value, e->type, e->token, param_index+1, block, arg_type->kind);
600+
lb_add_debug_param_variable(p, ptr.value, e->type, e->token, param_index+1, p->curr_block);
610601
}
611602
} else if (arg_type->kind == lbArg_Indirect) {
612603
if (e->token.string.len != 0 && !is_blank_ident(e->token.string)) {
613604
lbValue ptr = {};
614605
ptr.value = LLVMGetParam(p->value, param_offset+param_index);
615606
ptr.type = alloc_type_pointer(e->type);
616607
lb_add_entity(p->module, e, ptr);
617-
lb_add_debug_param_variable(p, ptr.value, e->type, e->token, param_index+1, p->decl_block, arg_type->kind);
608+
lb_add_debug_param_variable(p, ptr.value, e->type, e->token, param_index+1, p->decl_block);
618609
}
619610
}
620611
}

0 commit comments

Comments
 (0)