aboutsummaryrefslogtreecommitdiffstats
path: root/test/FrontendC
diff options
context:
space:
mode:
authorDale Johannesen <dalej@apple.com>2008-09-04 18:44:20 +0000
committerDale Johannesen <dalej@apple.com>2008-09-04 18:44:20 +0000
commit480b2924c6f56e5bec0135cf0debe84b4f4e622b (patch)
tree44daa9c295fd4ab650dbd181d983de59867833a3 /test/FrontendC
parent668cd3654998bbc669c104eedde4e93b0dae9919 (diff)
downloadexternal_llvm-480b2924c6f56e5bec0135cf0debe84b4f4e622b.zip
external_llvm-480b2924c6f56e5bec0135cf0debe84b4f4e622b.tar.gz
external_llvm-480b2924c6f56e5bec0135cf0debe84b4f4e622b.tar.bz2
Adjust libcalls tests to expect intrinsic for exp2
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@55784 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'test/FrontendC')
-rw-r--r--test/FrontendC/libcalls-d.c12
-rw-r--r--test/FrontendC/libcalls-ld.c15
-rw-r--r--test/FrontendC/libcalls.c2
3 files changed, 28 insertions, 1 deletions
diff --git a/test/FrontendC/libcalls-d.c b/test/FrontendC/libcalls-d.c
new file mode 100644
index 0000000..e9e31db
--- /dev/null
+++ b/test/FrontendC/libcalls-d.c
@@ -0,0 +1,12 @@
+// llvm-gcc -O1+ should run simplify libcalls, O0 shouldn't
+// and -fno-builtins shouldn't.
+// RUN: %llvmgcc %s -S -emit-llvm -O0 -o - | grep {call.*exp2\\.f64}
+// RUN: %llvmgcc %s -S -emit-llvm -O1 -o - | grep {call.*ldexp}
+// RUN: %llvmgcc %s -S -emit-llvm -O3 -fno-builtin -o - | grep {call.*exp2}
+
+double exp2(double);
+
+double t4(unsigned char x) {
+ return exp2(x);
+}
+
diff --git a/test/FrontendC/libcalls-ld.c b/test/FrontendC/libcalls-ld.c
new file mode 100644
index 0000000..ce612e9
--- /dev/null
+++ b/test/FrontendC/libcalls-ld.c
@@ -0,0 +1,15 @@
+// llvm-gcc -O1+ should run simplify libcalls, O0 shouldn't
+// and -fno-builtins shouldn't.
+// RUN: %llvmgcc %s -S -emit-llvm -O0 -o - | grep {call.*exp2\\..*f}
+// RUN: %llvmgcc %s -S -emit-llvm -O1 -o - | grep {call.*ldexp}
+// RUN: %llvmgcc %s -S -emit-llvm -O3 -fno-builtin -o - | grep {call.*exp2l}
+
+// If this fails for you because your target doesn't support long double,
+// please xfail the test.
+
+long double exp2l(long double);
+
+long double t4(unsigned char x) {
+ return exp2l(x);
+}
+
diff --git a/test/FrontendC/libcalls.c b/test/FrontendC/libcalls.c
index 648dc6f..9bb8431 100644
--- a/test/FrontendC/libcalls.c
+++ b/test/FrontendC/libcalls.c
@@ -1,6 +1,6 @@
// llvm-gcc -O1+ should run simplify libcalls, O0 shouldn't
// and -fno-builtins shouldn't.
-// RUN: %llvmgcc %s -S -emit-llvm -O0 -o - | grep {call.*exp2f}
+// RUN: %llvmgcc %s -S -emit-llvm -O0 -o - | grep {call.*exp2\\.f32}
// RUN: %llvmgcc %s -S -emit-llvm -O1 -o - | grep {call.*ldexp}
// RUN: %llvmgcc %s -S -emit-llvm -O3 -fno-builtin -o - | grep {call.*exp2f}