forked from OSchip/llvm-project
Teach the DAG combiner to turn sitofp/uitofp from i1 into a conditional move, since there are only two possible values.
Previously, this would become an integer extension operation, followed by a real integer->float conversion. llvm-svn: 159957
This commit is contained in:
parent
05d0d447c4
commit
d4b841f8f9
|
@ -5974,6 +5974,30 @@ SDValue DAGCombiner::visitSINT_TO_FP(SDNode *N) {
|
|||
return DAG.getNode(ISD::UINT_TO_FP, N->getDebugLoc(), VT, N0);
|
||||
}
|
||||
|
||||
// fold (sint_to_fp (setcc x, y, cc)) -> (select_cc x, y, -1.0, 0.0,, cc)
|
||||
if (N0.getOpcode() == ISD::SETCC && !VT.isVector() &&
|
||||
(!LegalOperations ||
|
||||
TLI.isOperationLegalOrCustom(llvm::ISD::ConstantFP, VT))) {
|
||||
SDValue Ops[] =
|
||||
{ N0.getOperand(0), N0.getOperand(1),
|
||||
DAG.getConstantFP(-1.0, VT) , DAG.getConstantFP(0.0, VT),
|
||||
N0.getOperand(2) };
|
||||
return DAG.getNode(ISD::SELECT_CC, N->getDebugLoc(), VT, Ops, 5);
|
||||
}
|
||||
|
||||
// fold (sint_to_fp (zext (setcc x, y, cc))) ->
|
||||
// (select_cc x, y, 1.0, 0.0,, cc)
|
||||
if (N0.getOpcode() == ISD::ZERO_EXTEND &&
|
||||
N0.getOperand(0).getOpcode() == ISD::SETCC &&!VT.isVector() &&
|
||||
(!LegalOperations ||
|
||||
TLI.isOperationLegalOrCustom(llvm::ISD::ConstantFP, VT))) {
|
||||
SDValue Ops[] =
|
||||
{ N0.getOperand(0).getOperand(0), N0.getOperand(0).getOperand(1),
|
||||
DAG.getConstantFP(1.0, VT) , DAG.getConstantFP(0.0, VT),
|
||||
N0.getOperand(0).getOperand(2) };
|
||||
return DAG.getNode(ISD::SELECT_CC, N->getDebugLoc(), VT, Ops, 5);
|
||||
}
|
||||
|
||||
return SDValue();
|
||||
}
|
||||
|
||||
|
@ -5999,6 +6023,18 @@ SDValue DAGCombiner::visitUINT_TO_FP(SDNode *N) {
|
|||
return DAG.getNode(ISD::SINT_TO_FP, N->getDebugLoc(), VT, N0);
|
||||
}
|
||||
|
||||
// fold (uint_to_fp (setcc x, y, cc)) -> (select_cc x, y, -1.0, 0.0,, cc)
|
||||
if (N0.getOpcode() == ISD::SETCC && !VT.isVector() &&
|
||||
(!LegalOperations ||
|
||||
TLI.isOperationLegalOrCustom(llvm::ISD::ConstantFP, VT))) {
|
||||
SDValue Ops[] =
|
||||
{ N0.getOperand(0), N0.getOperand(1),
|
||||
DAG.getConstantFP(1.0, VT), DAG.getConstantFP(0.0, VT),
|
||||
N0.getOperand(2) };
|
||||
return DAG.getNode(ISD::SELECT_CC, N->getDebugLoc(), VT, Ops, 5);
|
||||
}
|
||||
|
||||
|
||||
return SDValue();
|
||||
}
|
||||
|
||||
|
|
|
@ -113,3 +113,29 @@ entry:
|
|||
call void bitcast (i8* (i8*, i8*, ...)* @objc_msgSend to void (i8*, i8*, [2 x i32], i32, float)*)(i8* undef, i8* undef, [2 x i32] %tmp493, i32 0, float 1.000000e+00) optsize
|
||||
ret void
|
||||
}
|
||||
|
||||
; CHECK: f10
|
||||
define float @f10(i32 %a, i32 %b) nounwind uwtable readnone ssp {
|
||||
; CHECK-NOT: floatsisf
|
||||
%1 = icmp eq i32 %a, %b
|
||||
%2 = zext i1 %1 to i32
|
||||
%3 = sitofp i32 %2 to float
|
||||
ret float %3
|
||||
}
|
||||
|
||||
; CHECK: f11
|
||||
define float @f11(i32 %a, i32 %b) nounwind uwtable readnone ssp {
|
||||
; CHECK-NOT: floatsisf
|
||||
%1 = icmp eq i32 %a, %b
|
||||
%2 = sitofp i1 %1 to float
|
||||
ret float %2
|
||||
}
|
||||
|
||||
; CHECK: f12
|
||||
define float @f12(i32 %a, i32 %b) nounwind uwtable readnone ssp {
|
||||
; CHECK-NOT: floatunsisf
|
||||
%1 = icmp eq i32 %a, %b
|
||||
%2 = uitofp i1 %1 to float
|
||||
ret float %2
|
||||
}
|
||||
|
||||
|
|
Loading…
Reference in New Issue