From: Adrian Prantl Date: Thu, 18 Jul 2013 00:28:05 +0000 (+0000) Subject: Don't generate bogus line table entries for __copy_helper_block_ and X-Git-Url: https://granicus.if.org/sourcecode?a=commitdiff_plain;h=b3f111bf631b2a306a4bd6eefce314418ad61e1c;p=clang Don't generate bogus line table entries for __copy_helper_block_ and __destroy_helper_block_, but do generate scope information. git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@186553 91177308-0d34-0410-b5e6-96231b3b80d8 --- diff --git a/lib/CodeGen/CGBlocks.cpp b/lib/CodeGen/CGBlocks.cpp index 3d825d3333..bd97b25555 100644 --- a/lib/CodeGen/CGBlocks.cpp +++ b/lib/CodeGen/CGBlocks.cpp @@ -1314,6 +1314,8 @@ CodeGenFunction::GenerateCopyHelperFunction(const CGBlockInfo &blockInfo) { false, false); StartFunction(FD, C.VoidTy, Fn, FI, args, SourceLocation()); + // Don't emit any line table entries for the body of this function. + BuiltinLocation BL(*this, Builder); llvm::Type *structPtrTy = blockInfo.StructureType->getPointerTo(); @@ -1487,6 +1489,8 @@ CodeGenFunction::GenerateDestroyHelperFunction(const CGBlockInfo &blockInfo) { SC_Static, false, false); StartFunction(FD, C.VoidTy, Fn, FI, args, SourceLocation()); + // Don't emit any line table entries for the body of this function. + BuiltinLocation BL(*this, Builder); llvm::Type *structPtrTy = blockInfo.StructureType->getPointerTo(); diff --git a/test/CodeGenObjC/debug-info-blocks.m b/test/CodeGenObjC/debug-info-blocks.m index 3d91c9ea5c..d9ac24edbb 100644 --- a/test/CodeGenObjC/debug-info-blocks.m +++ b/test/CodeGenObjC/debug-info-blocks.m @@ -2,16 +2,28 @@ // rdar://problem/9279956 // Test that we generate the proper debug location for a captured self. -// The second half of this patch is in llvm/tests/DebugInfo/debug-info-blocks.ll +// The second half of this test is in llvm/tests/DebugInfo/debug-info-blocks.ll // CHECK: define {{.*}}_block_invoke // CHECK: %[[BLOCK:.*]] = bitcast i8* %.block_descriptor to <{ i8*, i32, i32, i8*, %struct.__block_descriptor*, %0* }>*, !dbg // CHECK-NEXT: store <{ i8*, i32, i32, i8*, %struct.__block_descriptor*, %0* }>* %[[BLOCK]], <{ i8*, i32, i32, i8*, %struct.__block_descriptor*, %0* }>** %[[ALLOCA:.*]], align // CHECK-NEXT: call void @llvm.dbg.declare(metadata !{<{ i8*, i32, i32, i8*, %struct.__block_descriptor*, %0* }>** %[[ALLOCA]]}, metadata ![[SELF:[0-9]+]]) // CHECK-NEXT: call void @llvm.dbg.declare(metadata !{%1** %d}, metadata ![[D:[0-9]+]]) -// CHECK: ![[SELF]] = {{.*}} [ DW_TAG_auto_variable ] [self] [line 51] -// CHECK: ![[D]] = {{.*}} [d] [line 49] +// rdar://problem/14386148 +// Test that we don't emit bogus line numbers for the helper functions. +// Test that we do emit scope info for the helper functions. +// CHECK: define {{.*}} @__copy_helper_block_{{.*}}(i8*, i8*) +// CHECK-NOT: ret +// CHECK: load {{.*}}, !dbg ![[COPY_LINE:[0-9]+]] +// CHECK: define {{.*}} @__destroy_helper_block_{{.*}}(i8*) +// CHECK-NOT: ret +// CHECK: load {{.*}}, !dbg ![[DESTROY_LINE:[0-9]+]] + +// CHECK-DAG: [[COPY_LINE]] = metadata !{i32 0, i32 0, metadata ![[COPY_SP:[0-9]+]], null} +// CHECK-DAG: [[COPY_SP]] = {{.*}}[ DW_TAG_subprogram ]{{.*}}[__copy_helper_block_] +// CHECK-DAG: [[DESTROY_LINE]] = metadata !{i32 0, i32 0, metadata ![[DESTROY_SP:[0-9]+]], null} +// CHECK-DAG: [[DESTROY_SP]] = {{.*}}[ DW_TAG_subprogram ]{{.*}}[__destroy_helper_block_] typedef unsigned int NSUInteger; @protocol NSObject @@ -46,6 +58,8 @@ static void run(void (^block)(void)) { if ((self = [super init])) { run(^{ + // CHECK-DAG: ![[SELF]] = {{.*}} [ DW_TAG_auto_variable ] [self] [line [[@LINE+4]]] + // CHECK-DAG: ![[D]] = {{.*}} [d] [line [[@LINE+1]]] NSMutableDictionary *d = [[NSMutableDictionary alloc] init]; ivar = 42 + (int)[d count]; });