mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2025-06-13 04:38:24 +00:00
Fold (fpext (load x)) -> (extload x)
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@28130 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
@ -2413,6 +2413,20 @@ SDOperand DAGCombiner::visitFP_EXTEND(SDNode *N) {
|
|||||||
// fold (fp_extend c1fp) -> c1fp
|
// fold (fp_extend c1fp) -> c1fp
|
||||||
if (N0CFP)
|
if (N0CFP)
|
||||||
return DAG.getNode(ISD::FP_EXTEND, VT, N0);
|
return DAG.getNode(ISD::FP_EXTEND, VT, N0);
|
||||||
|
|
||||||
|
// fold (fpext (load x)) -> (fpext (fpround (extload x)))
|
||||||
|
if (N0.getOpcode() == ISD::LOAD && N0.hasOneUse() &&
|
||||||
|
(!AfterLegalize||TLI.isOperationLegal(ISD::EXTLOAD, N0.getValueType()))) {
|
||||||
|
SDOperand ExtLoad = DAG.getExtLoad(ISD::EXTLOAD, VT, N0.getOperand(0),
|
||||||
|
N0.getOperand(1), N0.getOperand(2),
|
||||||
|
N0.getValueType());
|
||||||
|
CombineTo(N, ExtLoad);
|
||||||
|
CombineTo(N0.Val, DAG.getNode(ISD::FP_ROUND, N0.getValueType(), ExtLoad),
|
||||||
|
ExtLoad.getValue(1));
|
||||||
|
return SDOperand(N, 0); // Return N so it doesn't get rechecked!
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
return SDOperand();
|
return SDOperand();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Reference in New Issue
Block a user