mirror of
https://github.com/RPCS3/llvm.git
synced 2025-02-03 09:14:30 +00:00
Add fcopysign instructions
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@79664 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
9085750d31
commit
162da3c7b4
@ -86,6 +86,13 @@ def FMOV64mry : Pseudo<(outs), (ins rriaddr:$dst, FP64:$src),
|
||||
"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
|
||||
|
||||
|
22
test/CodeGen/SystemZ/2009-08-22-FCopySign.ll
Normal file
22
test/CodeGen/SystemZ/2009-08-22-FCopySign.ll
Normal file
@ -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
|
Loading…
x
Reference in New Issue
Block a user