[llvm-commits] [llvm] r79664 - in /llvm/trunk: lib/Target/SystemZ/SystemZInstrFP.td test/CodeGen/SystemZ/2009-08-22-FCopySign.ll
Anton Korobeynikov
asl at math.spbu.ru
Fri Aug 21 13:02:37 PDT 2009
Author: asl
Date: Fri Aug 21 15:02:37 2009
New Revision: 79664
URL: http://llvm.org/viewvc/llvm-project?rev=79664&view=rev
Log:
Add fcopysign instructions
Added:
llvm/trunk/test/CodeGen/SystemZ/2009-08-22-FCopySign.ll
Modified:
llvm/trunk/lib/Target/SystemZ/SystemZInstrFP.td
Modified: llvm/trunk/lib/Target/SystemZ/SystemZInstrFP.td
URL: http://llvm.org/viewvc/llvm-project/llvm/trunk/lib/Target/SystemZ/SystemZInstrFP.td?rev=79664&r1=79663&r2=79664&view=diff
==============================================================================
--- llvm/trunk/lib/Target/SystemZ/SystemZInstrFP.td (original)
+++ llvm/trunk/lib/Target/SystemZ/SystemZInstrFP.td Fri Aug 21 15:02:37 2009
@@ -86,6 +86,13 @@
"stdy\t{$src, $dst}",
[(store FP64:$src, rriaddr:$dst)]>;
+def FCOPYSIGN32 : Pseudo<(outs FP32:$dst), (ins FP32:$src1, FP32:$src2),
+ "cpsdr\t{$dst, $src2, $src1}",
+ [(set FP32:$dst, (fcopysign FP32:$src1, FP32:$src2))]>;
+def FCOPYSIGN64 : Pseudo<(outs FP64:$dst), (ins FP64:$src1, FP64:$src2),
+ "cpsdr\t{$dst, $src2, $src1}",
+ [(set FP64:$dst, (fcopysign FP64:$src1, FP64:$src2))]>;
+
//===----------------------------------------------------------------------===//
// Arithmetic Instructions
Added: llvm/trunk/test/CodeGen/SystemZ/2009-08-22-FCopySign.ll
URL: http://llvm.org/viewvc/llvm-project/llvm/trunk/test/CodeGen/SystemZ/2009-08-22-FCopySign.ll?rev=79664&view=auto
==============================================================================
--- llvm/trunk/test/CodeGen/SystemZ/2009-08-22-FCopySign.ll (added)
+++ llvm/trunk/test/CodeGen/SystemZ/2009-08-22-FCopySign.ll Fri Aug 21 15:02:37 2009
@@ -0,0 +1,22 @@
+; RUN: llvm-as < %s | llc | FileCheck %s
+
+target datalayout = "E-p:64:64:64-i1:8:8-i8:8:16-i16:16:16-i32:32:32-i64:64:64-f32:32:32-f64:64:64-v64:64:64-v128:128:128-a0:16:16-f128:128:128"
+target triple = "s390x-ibm-linux-gnu"
+
+define double @foo(double %a, double %b) nounwind {
+entry:
+; CHECK: cpsdr %f0, %f2, %f0
+ %0 = tail call double @copysign(double %a, double %b) nounwind readnone
+ ret double %0
+}
+
+define float @bar(float %a, float %b) nounwind {
+entry:
+; CHECK: cpsdr %f0, %f2, %f0
+ %0 = tail call float @copysignf(float %a, float %b) nounwind readnone
+ ret float %0
+}
+
+
+declare double @copysign(double, double) nounwind readnone
+declare float @copysignf(float, float) nounwind readnone
More information about the llvm-commits
mailing list