diff options
Diffstat (limited to 'clang/test/CodeGen')
-rw-r--r-- | clang/test/CodeGen/2007-06-15-AnnotateAttribute.c | 1 | ||||
-rw-r--r-- | clang/test/CodeGen/annotate.c | 10 | ||||
-rw-r--r-- | clang/test/CodeGen/annotations-builtin.c | 52 | ||||
-rw-r--r-- | clang/test/CodeGen/annotations-field.c | 27 | ||||
-rw-r--r-- | clang/test/CodeGen/annotations-global.c | 41 | ||||
-rw-r--r-- | clang/test/CodeGen/annotations-loc.c | 10 | ||||
-rw-r--r-- | clang/test/CodeGen/annotations-var.c | 43 |
7 files changed, 173 insertions, 11 deletions
diff --git a/clang/test/CodeGen/2007-06-15-AnnotateAttribute.c b/clang/test/CodeGen/2007-06-15-AnnotateAttribute.c index 324b9755755..a51400288c2 100644 --- a/clang/test/CodeGen/2007-06-15-AnnotateAttribute.c +++ b/clang/test/CodeGen/2007-06-15-AnnotateAttribute.c @@ -1,7 +1,6 @@ // RUN: %clang_cc1 -emit-llvm %s -o - | grep llvm.global.annotations // RUN: %clang_cc1 -emit-llvm %s -o - | grep llvm.var.annotation | count 3 -// XFAIL: * #include <stdio.h> /* Global variable with attribute */ diff --git a/clang/test/CodeGen/annotate.c b/clang/test/CodeGen/annotate.c deleted file mode 100644 index 9ed187d1d17..00000000000 --- a/clang/test/CodeGen/annotate.c +++ /dev/null @@ -1,10 +0,0 @@ -// RUN: %clang_cc1 %s -emit-llvm -o - | FileCheck %s - -__attribute((annotate("foo"))) char foo; -void a(char *a) { - __attribute__((annotate("bar"))) static char bar; -} - -// CHECK: private unnamed_addr global -// CHECK: private unnamed_addr global -// CHECK: @llvm.global.annotations = appending global [2 x { i8*, i8*, i8*, i32 }] diff --git a/clang/test/CodeGen/annotations-builtin.c b/clang/test/CodeGen/annotations-builtin.c new file mode 100644 index 00000000000..42421a0a520 --- /dev/null +++ b/clang/test/CodeGen/annotations-builtin.c @@ -0,0 +1,52 @@ +// RUN: %clang_cc1 -emit-llvm -o - %s | FileCheck %s +// END. + +static long long llfoo; +static int intfoo; +static short shortfoo; +static char charfoo; + +// CHECK: private unnamed_addr constant [13 x i8] {{.*}}annotation_a{{.*}} section "llvm.metadata" +// CHECK-NOT: {{.*}}annotation_a{{.*}} + +static int foo(int a) { + return a + 1; +} + +int main(int argc, char **argv) { + char barray[16]; + char *b = (char *) __builtin_annotation((int)barray, "annotation_a"); +// CHECK: ptrtoint i8* {{.*}} to i32 +// CHECK-NEXT: call i32 @llvm.annotation.i32 +// CHECK: inttoptr {{.*}} to i8* + + int call = __builtin_annotation(foo(argc), "annotation_a"); +// CHECK: call {{.*}} @foo +// CHECK: call i32 @llvm.annotation.i32 + + long long lla = __builtin_annotation(llfoo, "annotation_a"); +// CHECK: trunc i64 {{.*}} to i32 +// CHECK-NEXT: call i32 @llvm.annotation.i32 +// CHECK-NEXT: zext i32 {{.*}} to i64 + + int inta = __builtin_annotation(intfoo, "annotation_a"); +// CHECK: load i32* @intfoo +// CHECK-NEXT: call i32 @llvm.annotation.i32 +// CHECK-NEXT: store + + short shorta = __builtin_annotation(shortfoo, "annotation_a"); +// CHECK: sext i16 {{.*}} to i32 +// CHECK-NEXT: call i32 @llvm.annotation.i32 +// CHECK-NEXT: trunc i32 {{.*}} to i16 + + char chara = __builtin_annotation(charfoo, "annotation_a"); +// CHECK: sext i8 {{.*}} to i32 +// CHECK-NEXT: call i32 @llvm.annotation.i32 +// CHECK-NEXT: trunc i32 {{.*}} to i8 +// + char **arg = (char**) __builtin_annotation((int) argv, "annotation_a"); +// CHECK: ptrtoint i8** {{.*}} to +// CHECK: call i32 @llvm.annotation.i32 +// CHECK: inttoptr {{.*}} to i8** + return 0; +} diff --git a/clang/test/CodeGen/annotations-field.c b/clang/test/CodeGen/annotations-field.c new file mode 100644 index 00000000000..6b443675850 --- /dev/null +++ b/clang/test/CodeGen/annotations-field.c @@ -0,0 +1,27 @@ +// RUN: %clang_cc1 -emit-llvm -o - %s | FileCheck %s +// END. + +// CHECK: private unnamed_addr constant [8 x i8] c"v_ann_{{.}}\00", section "llvm.metadata" +// CHECK: private unnamed_addr constant [8 x i8] c"v_ann_{{.}}\00", section "llvm.metadata" + +struct foo { + int v __attribute__((annotate("v_ann_0"))) __attribute__((annotate("v_ann_1"))); +}; + +static struct foo gf; + +int main(int argc, char **argv) { + struct foo f; + f.v = argc; +// CHECK: getelementptr inbounds %struct.foo* %f, i32 0, i32 0 +// CHECK-NEXT: bitcast i32* {{.*}} to i8* +// CHECK-NEXT: call i8* @llvm.ptr.annotation.p0i8({{.*}}str{{.*}}str{{.*}}i32 8) +// CHECK-NEXT: bitcast i8* {{.*}} to i32* +// CHECK-NEXT: bitcast i32* {{.*}} to i8* +// CHECK-NEXT: call i8* @llvm.ptr.annotation.p0i8({{.*}}str{{.*}}str{{.*}}i32 8) +// CHECK-NEXT: bitcast i8* {{.*}} to i32* + gf.v = argc; +// CHECK: bitcast i32* getelementptr inbounds (%struct.foo* @gf, i32 0, i32 0) to i8* +// CHECK-NEXT: call i8* @llvm.ptr.annotation.p0i8({{.*}}str{{.*}}str{{.*}}i32 8) + return 0; +} diff --git a/clang/test/CodeGen/annotations-global.c b/clang/test/CodeGen/annotations-global.c new file mode 100644 index 00000000000..2782525ed91 --- /dev/null +++ b/clang/test/CodeGen/annotations-global.c @@ -0,0 +1,41 @@ +// RUN: %clang_cc1 %s -emit-llvm -o %t1 +// RUN: FileCheck --check-prefix=FOO %s < %t1 +// RUN: FileCheck --check-prefix=A %s < %t1 +// RUN: FileCheck --check-prefix=BAR %s < %t1 +// RUN: FileCheck --check-prefix=FOOS %s < %t1 +// END. + +static __attribute((annotate("sfoo_0"))) __attribute((annotate("sfoo_1"))) char sfoo; +__attribute((annotate("foo_0"))) __attribute((annotate("foo_1"))) char foo; + +void __attribute((annotate("ann_a_0"))) __attribute((annotate("ann_a_1"))) __attribute((annotate("ann_a_2"))) __attribute((annotate("ann_a_3"))) a(char *a); +void __attribute((annotate("ann_a_0"))) __attribute((annotate("ann_a_1"))) a(char *a) { + __attribute__((annotate("bar_0"))) __attribute__((annotate("bar_1"))) static char bar; + sfoo = 0; +} + +// FOOS: target triple +// FOOS: private unnamed_addr constant [7 x i8] c"sfoo_{{.}}\00", section "llvm.metadata" +// FOOS: private unnamed_addr constant [7 x i8] c"sfoo_{{.}}\00", section "llvm.metadata" +// FOOS-NOT: sfoo_ +// FOOS: @llvm.global.annotations = appending global [10 x { i8*, i8*, i8*, i32 }] {{.*}}i8* @sfoo{{.*}}i8* @sfoo{{.*}}, section "llvm.metadata" + +// FOO: target triple +// FOO: private unnamed_addr constant [6 x i8] c"foo_{{.}}\00", section "llvm.metadata" +// FOO: private unnamed_addr constant [6 x i8] c"foo_{{.}}\00", section "llvm.metadata" +// FOO-NOT: foo_ +// FOO: @llvm.global.annotations = appending global [10 x { i8*, i8*, i8*, i32 }] {{.*}}i8* @foo{{.*}}i8* @foo{{.*}}, section "llvm.metadata" + +// A: target triple +// A: private unnamed_addr constant [8 x i8] c"ann_a_{{.}}\00", section "llvm.metadata" +// A: private unnamed_addr constant [8 x i8] c"ann_a_{{.}}\00", section "llvm.metadata" +// A: private unnamed_addr constant [8 x i8] c"ann_a_{{.}}\00", section "llvm.metadata" +// A: private unnamed_addr constant [8 x i8] c"ann_a_{{.}}\00", section "llvm.metadata" +// A-NOT: ann_a_ +// A: @llvm.global.annotations = appending global [10 x { i8*, i8*, i8*, i32 }] {{.*}}i8* bitcast (void (i8*)* @a to i8*){{.*}}i8* bitcast (void (i8*)* @a to i8*){{.*}}i8* bitcast (void (i8*)* @a to i8*){{.*}}i8* bitcast (void (i8*)* @a to i8*){{.*}}, section "llvm.metadata" + +// BAR: target triple +// BAR: private unnamed_addr constant [6 x i8] c"bar_{{.}}\00", section "llvm.metadata" +// BAR: private unnamed_addr constant [6 x i8] c"bar_{{.}}\00", section "llvm.metadata" +// BAR-NOT: bar_ +// BAR: @llvm.global.annotations = appending global [10 x { i8*, i8*, i8*, i32 }] {{.*}}i8* @a.bar{{.*}}i8* @a.bar{{.*}}, section "llvm.metadata" diff --git a/clang/test/CodeGen/annotations-loc.c b/clang/test/CodeGen/annotations-loc.c new file mode 100644 index 00000000000..4644f0e1d2c --- /dev/null +++ b/clang/test/CodeGen/annotations-loc.c @@ -0,0 +1,10 @@ +// RUN: %clang_cc1 -emit-llvm -o - %s | FileCheck %s +// END. +# 1 "t.c" +# 1 "<built-in>" +# 1 "<command-line>" +# 1 "t.c" +int __attribute((annotate("foo"))) foo(void) { return 0; } + +// CHECK: private unnamed_addr constant [4 x i8] c"t.c\00" +// CHECK: @llvm.global.annotations = {{.*}}, i32 1 } diff --git a/clang/test/CodeGen/annotations-var.c b/clang/test/CodeGen/annotations-var.c new file mode 100644 index 00000000000..97a10ac3151 --- /dev/null +++ b/clang/test/CodeGen/annotations-var.c @@ -0,0 +1,43 @@ +// RUN: %clang_cc1 -emit-llvm -o %t1 %s +// RUN: FileCheck --check-prefix=LOCAL %s < %t1 +// RUN: FileCheck --check-prefix=UNDEF %s < %t1 +// RUN: FileCheck --check-prefix=PARAM %s < %t1 +// END. + +// LOCAL: private unnamed_addr constant [15 x i8] c"localvar_ann_{{.}}\00", section "llvm.metadata" +// LOCAL: private unnamed_addr constant [15 x i8] c"localvar_ann_{{.}}\00", section "llvm.metadata" + +// UNDEF: private unnamed_addr constant [15 x i8] c"undefvar_ann_0\00", section "llvm.metadata" + +// PARAM: private unnamed_addr constant [12 x i8] c"param_ann_{{.}}\00", section "llvm.metadata" +// PARAM: private unnamed_addr constant [12 x i8] c"param_ann_{{.}}\00", section "llvm.metadata" +// PARAM: private unnamed_addr constant [12 x i8] c"param_ann_{{.}}\00", section "llvm.metadata" +// PARAM: private unnamed_addr constant [12 x i8] c"param_ann_{{.}}\00", section "llvm.metadata" + +int foo(int v __attribute__((annotate("param_ann_2"))) __attribute__((annotate("param_ann_3")))); +int foo(int v __attribute__((annotate("param_ann_0"))) __attribute__((annotate("param_ann_1")))) { + return v + 1; +// PARAM: define {{.*}}@foo +// PARAM: bitcast i32* %v.addr to i8* +// PARAM-NEXT: call void @llvm.var.annotation( +// PARAM-NEXT: bitcast i32* %v.addr to i8* +// PARAM-NEXT: call void @llvm.var.annotation( +// PARAM-NEXT: bitcast i32* %v.addr to i8* +// PARAM-NEXT: call void @llvm.var.annotation( +// PARAM-NEXT: bitcast i32* %v.addr to i8* +// PARAM-NEXT: call void @llvm.var.annotation( +} + +int main(int argc, char **argv) { + int localvar __attribute__((annotate("localvar_ann_0"))) __attribute__((annotate("localvar_ann_1"))) = 3; +// LOCAL: %localvar1 = bitcast i32* %localvar to i8* +// LOCAL-NEXT: call void @llvm.var.annotation(i8* %localvar1, i8* getelementptr inbounds ([15 x i8]* @{{.*}}), i8* getelementptr inbounds ({{.*}}), i32 32) +// LOCAL-NEXT: %localvar2 = bitcast i32* %localvar to i8* +// LOCAL-NEXT: call void @llvm.var.annotation(i8* %localvar2, i8* getelementptr inbounds ([15 x i8]* @{{.*}}), i8* getelementptr inbounds ({{.*}}), i32 32) + int undefvar __attribute__((annotate("undefvar_ann_0"))); +// UNDEF: %undefvar3 = bitcast i32* %undefvar to i8* +// UNDEF-NEXT: call void @llvm.var.annotation(i8* %undefvar3, i8* getelementptr inbounds ([15 x i8]* @{{.*}}), i8* getelementptr inbounds ({{.*}}), i32 37) + localvar += argc; + undefvar = localvar; + return undefvar + localvar; +} |