GlobalISel: Add G_FCOPYSIGN

llvm-svn: 360850
This commit is contained in:
Matt Arsenault 2019-05-16 04:08:39 +00:00
parent 2006f936ef
commit 55146d3139
5 changed files with 29 additions and 0 deletions

View File

@ -481,6 +481,12 @@ HANDLE_TARGET_OPCODE(G_UITOFP)
/// Generic FP absolute value. /// Generic FP absolute value.
HANDLE_TARGET_OPCODE(G_FABS) HANDLE_TARGET_OPCODE(G_FABS)
/// FCOPYSIGN(X, Y) - Return the value of X with the sign of Y. NOTE: This does
/// not require that X and Y have the same type, just that they are both
/// floating point. X and the result must have the same type. FCOPYSIGN(f32,
/// f64) is allowed.
HANDLE_TARGET_OPCODE(G_FCOPYSIGN)
/// Generic FP canonicalize value. /// Generic FP canonicalize value.
HANDLE_TARGET_OPCODE(G_FCANONICALIZE) HANDLE_TARGET_OPCODE(G_FCANONICALIZE)

View File

@ -455,6 +455,12 @@ def G_FABS : GenericInstruction {
let hasSideEffects = 0; let hasSideEffects = 0;
} }
def G_FCOPYSIGN : GenericInstruction {
let OutOperandList = (outs type0:$dst);
let InOperandList = (ins type0:$src0, type1:$src1);
let hasSideEffects = 0;
}
def G_FCANONICALIZE : GenericInstruction { def G_FCANONICALIZE : GenericInstruction {
let OutOperandList = (outs type0:$dst); let OutOperandList = (outs type0:$dst);
let InOperandList = (ins type0:$src); let InOperandList = (ins type0:$src);

View File

@ -782,6 +782,8 @@ unsigned IRTranslator::getSimpleIntrinsicOpcode(Intrinsic::ID ID) {
return TargetOpcode::G_FEXP2; return TargetOpcode::G_FEXP2;
case Intrinsic::fabs: case Intrinsic::fabs:
return TargetOpcode::G_FABS; return TargetOpcode::G_FABS;
case Intrinsic::copysign:
return TargetOpcode::G_FCOPYSIGN;
case Intrinsic::canonicalize: case Intrinsic::canonicalize:
return TargetOpcode::G_FCANONICALIZE; return TargetOpcode::G_FCANONICALIZE;
case Intrinsic::floor: case Intrinsic::floor:

View File

@ -1418,6 +1418,18 @@ define float @test_fabs_intrin(float %a) {
ret float %res ret float %res
} }
declare float @llvm.copysign.f32(float, float)
define float @test_fcopysign_intrin(float %a, float %b) {
; CHECK-LABEL: name: test_fcopysign_intrin
; CHECK: [[A:%[0-9]+]]:_(s32) = COPY $s0
; CHECK: [[B:%[0-9]+]]:_(s32) = COPY $s1
; CHECK: [[RES:%[0-9]+]]:_(s32) = nnan ninf nsz arcp contract afn reassoc G_FCOPYSIGN [[A]], [[B]]
; CHECK: $s0 = COPY [[RES]]
%res = call nnan ninf nsz arcp contract afn reassoc float @llvm.copysign.f32(float %a, float %b)
ret float %res
}
declare float @llvm.canonicalize.f32(float) declare float @llvm.canonicalize.f32(float)
define float @test_fcanonicalize_intrin(float %a) { define float @test_fcanonicalize_intrin(float %a) {
; CHECK-LABEL: name: test_fcanonicalize_intrin ; CHECK-LABEL: name: test_fcanonicalize_intrin

View File

@ -294,6 +294,9 @@
# DEBUG-NEXT: G_FABS (opcode {{[0-9]+}}): 1 type index # DEBUG-NEXT: G_FABS (opcode {{[0-9]+}}): 1 type index
# DEBUG: .. type index coverage check SKIPPED: user-defined predicate detected # DEBUG: .. type index coverage check SKIPPED: user-defined predicate detected
# #
# DEBUG-NEXT: G_FCOPYSIGN (opcode {{[0-9]+}}): 2 type indices
# DEBUG: .. type index coverage check SKIPPED: no rules defined
#
# DEBUG-NEXT: G_FCANONICALIZE (opcode {{[0-9]+}}): 1 type index # DEBUG-NEXT: G_FCANONICALIZE (opcode {{[0-9]+}}): 1 type index
# DEBUG: .. type index coverage check SKIPPED: no rules defined # DEBUG: .. type index coverage check SKIPPED: no rules defined
# #