aboutsummaryrefslogtreecommitdiffstats
path: root/test/CodeGen/PowerPC/pr15632.ll
diff options
context:
space:
mode:
authorBill Schmidt <wschmidt@linux.vnet.ibm.com>2013-04-03 13:05:44 +0000
committerBill Schmidt <wschmidt@linux.vnet.ibm.com>2013-04-03 13:05:44 +0000
commitcd7a1558edd0bdae770c57b82b32291e54e014b2 (patch)
treeb42192cf9793615364fae850b77f3a642ce25bae /test/CodeGen/PowerPC/pr15632.ll
parent4385f5dfced4e14bc59dfedb1f75116c0aabbc36 (diff)
downloadexternal_llvm-cd7a1558edd0bdae770c57b82b32291e54e014b2.zip
external_llvm-cd7a1558edd0bdae770c57b82b32291e54e014b2.tar.gz
external_llvm-cd7a1558edd0bdae770c57b82b32291e54e014b2.tar.bz2
Fix PR15632: No support for ppcf128 floating-point remainder on PowerPC.
For this we need to use a libcall. Previously LLVM didn't implement libcall support for frem, so I've added it in the usual straightforward manner. A test case from the bug report is included. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@178639 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'test/CodeGen/PowerPC/pr15632.ll')
-rw-r--r--test/CodeGen/PowerPC/pr15632.ll15
1 files changed, 15 insertions, 0 deletions
diff --git a/test/CodeGen/PowerPC/pr15632.ll b/test/CodeGen/PowerPC/pr15632.ll
new file mode 100644
index 0000000..3ea8346
--- /dev/null
+++ b/test/CodeGen/PowerPC/pr15632.ll
@@ -0,0 +1,15 @@
+; RUN: llc -mcpu=pwr7 -O0 < %s | FileCheck %s
+
+target datalayout = "E-p:64:64:64-i1:8:8-i8:8:8-i16:16:16-i32:32:32-i64:64:64-f32:32:32-f64:64:64-v128:128:128-n32:64"
+target triple = "powerpc64-unknown-linux-gnu"
+
+declare void @other(ppc_fp128 %tmp70)
+
+define void @bug() {
+entry:
+ %tmp70 = frem ppc_fp128 0xM00000000000000000000000000000000, undef
+ call void @other(ppc_fp128 %tmp70)
+ unreachable
+}
+
+; CHECK: bl fmodl