Skip to content
Snippets Groups Projects
Commit ac7732b7 authored by Paul Robinson's avatar Paul Robinson
Browse files

FileCheck-ize test and make sure more things don't happen.

Attribute 'nodebug' means no llvm.dbg.* intrinsics, no !dbg
annotations, and no DISubprogram for the function.

Differential Revision: http://reviews.llvm.org/D10747


git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@240747 91177308-0d34-0410-b5e6-96231b3b80d8
parent a244576a
No related branches found
No related tags found
No related merge requests found
// RUN: %clang_cc1 -g -emit-llvm -o %t %s
// RUN: not grep 'call void @llvm.dbg.func.start' %t
// RUN: %clang_cc1 -g -emit-llvm -o - %s | FileCheck %s
void t1() __attribute__((nodebug));
void t1()
{
int a = 10;
a++;
}
void t2()
{
int b = 10;
b++;
}
// With nodebug, IR should have no llvm.dbg.* calls, or !dbg annotations.
// CHECK-LABEL: @t1
// CHECK-NOT: dbg
// CHECK: }
// For sanity, check those things do occur normally.
// CHECK-LABEL: @t2
// CHECK: call{{.*}}llvm.dbg
// CHECK: !dbg
// CHECK: }
// We should see a function description for t2 but not t1.
// CHECK-NOT: DISubprogram(name: "t1"
// CHECK: DISubprogram(name: "t2"
// CHECK-NOT: DISubprogram(name: "t1"
0% Loading or .
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment