mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2025-01-15 07:34:33 +00:00
fold fp_round(fp_round(x)) -> fp_round(x).
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@46304 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
7323999b31
commit
0aa5e6f3fb
@ -3648,6 +3648,15 @@ SDOperand DAGCombiner::visitFP_ROUND(SDNode *N) {
|
|||||||
if (N0.getOpcode() == ISD::FP_EXTEND && VT == N0.getOperand(0).getValueType())
|
if (N0.getOpcode() == ISD::FP_EXTEND && VT == N0.getOperand(0).getValueType())
|
||||||
return N0.getOperand(0);
|
return N0.getOperand(0);
|
||||||
|
|
||||||
|
// fold (fp_round (fp_round x)) -> (fp_round x)
|
||||||
|
if (N0.getOpcode() == ISD::FP_ROUND) {
|
||||||
|
// This is a value preserving truncation if both round's are.
|
||||||
|
bool IsTrunc = N->getConstantOperandVal(1) == 1 &&
|
||||||
|
N0.Val->getConstantOperandVal(1) == 1;
|
||||||
|
return DAG.getNode(ISD::FP_ROUND, VT, N0.getOperand(0),
|
||||||
|
DAG.getIntPtrConstant(IsTrunc));
|
||||||
|
}
|
||||||
|
|
||||||
// fold (fp_round (copysign X, Y)) -> (copysign (fp_round X), Y)
|
// fold (fp_round (copysign X, Y)) -> (copysign (fp_round X), Y)
|
||||||
if (N0.getOpcode() == ISD::FCOPYSIGN && N0.Val->hasOneUse()) {
|
if (N0.getOpcode() == ISD::FCOPYSIGN && N0.Val->hasOneUse()) {
|
||||||
SDOperand Tmp = DAG.getNode(ISD::FP_ROUND, VT, N0.getOperand(0), N1);
|
SDOperand Tmp = DAG.getNode(ISD::FP_ROUND, VT, N0.getOperand(0), N1);
|
||||||
|
Loading…
x
Reference in New Issue
Block a user