mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2025-01-10 02:36:06 +00:00
Don't convert store double C, Ptr to store long C, Ptr if i64 is not a legal type.
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@32434 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
bbf1e5e2e9
commit
25ece66ff3
@ -3035,17 +3035,20 @@ SDOperand DAGCombiner::visitSTORE(SDNode *N) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
// Turn 'store float 1.0, Ptr' -> 'store int 0x12345678, Ptr'
|
// Turn 'store float 1.0, Ptr' -> 'store int 0x12345678, Ptr'
|
||||||
// FIXME: We shouldn't do this for TargetConstantFP's.
|
|
||||||
if (ConstantFPSDNode *CFP = dyn_cast<ConstantFPSDNode>(Value)) {
|
if (ConstantFPSDNode *CFP = dyn_cast<ConstantFPSDNode>(Value)) {
|
||||||
|
if (Value.getOpcode() != ISD::TargetConstantFP) {
|
||||||
SDOperand Tmp;
|
SDOperand Tmp;
|
||||||
if (CFP->getValueType(0) == MVT::f32) {
|
if (CFP->getValueType(0) == MVT::f32) {
|
||||||
Tmp = DAG.getConstant(FloatToBits(CFP->getValue()), MVT::i32);
|
Tmp = DAG.getConstant(FloatToBits(CFP->getValue()), MVT::i32);
|
||||||
} else {
|
|
||||||
assert(CFP->getValueType(0) == MVT::f64 && "Unknown FP type!");
|
|
||||||
Tmp = DAG.getConstant(DoubleToBits(CFP->getValue()), MVT::i64);
|
|
||||||
}
|
|
||||||
return DAG.getStore(Chain, Tmp, Ptr, ST->getSrcValue(),
|
return DAG.getStore(Chain, Tmp, Ptr, ST->getSrcValue(),
|
||||||
ST->getSrcValueOffset());
|
ST->getSrcValueOffset());
|
||||||
|
} else if (TLI.isTypeLegal(MVT::i64)) {
|
||||||
|
assert(CFP->getValueType(0) == MVT::f64 && "Unknown FP type!");
|
||||||
|
Tmp = DAG.getConstant(DoubleToBits(CFP->getValue()), MVT::i64);
|
||||||
|
return DAG.getStore(Chain, Tmp, Ptr, ST->getSrcValue(),
|
||||||
|
ST->getSrcValueOffset());
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if (CombinerAA) {
|
if (CombinerAA) {
|
||||||
|
Loading…
x
Reference in New Issue
Block a user