forked from OSchip/llvm-project
parent
2006f936ef
commit
55146d3139
|
@ -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)
|
||||||
|
|
||||||
|
|
|
@ -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);
|
||||||
|
|
|
@ -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:
|
||||||
|
|
|
@ -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
|
||||||
|
|
|
@ -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
|
||||||
#
|
#
|
||||||
|
|
Loading…
Reference in New Issue