summaryrefslogtreecommitdiffstats
path: root/clang/test/CodeGen/builtin-assume.c
diff options
context:
space:
mode:
authorHal Finkel <hfinkel@anl.gov>2014-09-07 22:58:14 +0000
committerHal Finkel <hfinkel@anl.gov>2014-09-07 22:58:14 +0000
commitbcc06085a894aa52f094e12a8cfdd36ae1f175af (patch)
tree5d932a55113890c2447f77376b89f3e48f36c8b0 /clang/test/CodeGen/builtin-assume.c
parentcebf0cc210edeb839894b0e93da1c5787bd5b68b (diff)
downloadbcm5719-llvm-bcc06085a894aa52f094e12a8cfdd36ae1f175af.tar.gz
bcm5719-llvm-bcc06085a894aa52f094e12a8cfdd36ae1f175af.zip
Add __builtin_assume and __builtin_assume_aligned using @llvm.assume.
This makes use of the recently-added @llvm.assume intrinsic to implement a __builtin_assume(bool) intrinsic (to provide additional information to the optimizer). This hooks up __assume in MS-compatibility mode to mirror __builtin_assume (the semantics have been intentionally kept compatible), and implements GCC's __builtin_assume_aligned as assume((p - o) & mask == 0). LLVM now contains special logic to deal with assumptions of this form. llvm-svn: 217349
Diffstat (limited to 'clang/test/CodeGen/builtin-assume.c')
-rw-r--r--clang/test/CodeGen/builtin-assume.c22
1 files changed, 20 insertions, 2 deletions
diff --git a/clang/test/CodeGen/builtin-assume.c b/clang/test/CodeGen/builtin-assume.c
index a381a4c1dfb..041e9f48d0b 100644
--- a/clang/test/CodeGen/builtin-assume.c
+++ b/clang/test/CodeGen/builtin-assume.c
@@ -1,8 +1,26 @@
+// RUN: %clang_cc1 -triple x86_64-unknown-unknown -emit-llvm -o - %s | FileCheck %s
// RUN: %clang_cc1 -triple i386-mingw32 -fms-extensions -emit-llvm -o - %s | FileCheck %s
// CHECK-LABEL: @test1
-int test1(int *a) {
- __assume(a != 0);
+int test1(int *a, int i) {
+// CHECK: %0 = load i32** %a.addr
+// CHECK: %cmp = icmp ne i32* %0, null
+// CHECK: call void @llvm.assume(i1 %cmp)
+#ifdef _MSC_VER
+ __assume(a != 0)
+#else
+ __builtin_assume(a != 0);
+#endif
+
+// Nothing is generated for an assume with side effects...
+// CHECK-NOT: load i32** %i.addr
+// CHECK-NOT: call void @llvm.assume
+#ifdef _MSC_VER
+ __assume(++i != 0)
+#else
+ __builtin_assume(++i != 0);
+#endif
+
return a[0];
}
OpenPOWER on IntegriCloud