mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2025-01-14 16:33:28 +00:00
Constant fold int-to-long-double conversions;
use APFloat for int-to-float/double; use round-to-nearest for these (implementation-defined, seems to match gcc). git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@42484 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
cce23a4c35
commit
88216af3ea
@ -3220,7 +3220,7 @@ SDOperand SelectionDAGLegalize::LegalizeOp(SDOperand Op) {
|
|||||||
APFloat apf = APFloat(APInt(MVT::getSizeInBits(VT), 2, zero));
|
APFloat apf = APFloat(APInt(MVT::getSizeInBits(VT), 2, zero));
|
||||||
uint64_t x = 1ULL << ShiftAmt;
|
uint64_t x = 1ULL << ShiftAmt;
|
||||||
(void)apf.convertFromInteger(&x, MVT::getSizeInBits(NVT), false,
|
(void)apf.convertFromInteger(&x, MVT::getSizeInBits(NVT), false,
|
||||||
APFloat::rmTowardZero);
|
APFloat::rmNearestTiesToEven);
|
||||||
Tmp2 = DAG.getConstantFP(apf, VT);
|
Tmp2 = DAG.getConstantFP(apf, VT);
|
||||||
Tmp3 = DAG.getSetCC(TLI.getSetCCResultTy(),
|
Tmp3 = DAG.getSetCC(TLI.getSetCCResultTy(),
|
||||||
Node->getOperand(0), Tmp2, ISD::SETLT);
|
Node->getOperand(0), Tmp2, ISD::SETLT);
|
||||||
|
@ -1598,7 +1598,7 @@ SDOperand SelectionDAG::getNode(unsigned Opcode, MVT::ValueType VT,
|
|||||||
(void)apf.convertFromInteger(&Val,
|
(void)apf.convertFromInteger(&Val,
|
||||||
MVT::getSizeInBits(Operand.getValueType()),
|
MVT::getSizeInBits(Operand.getValueType()),
|
||||||
Opcode==ISD::SINT_TO_FP,
|
Opcode==ISD::SINT_TO_FP,
|
||||||
APFloat::rmTowardZero);
|
APFloat::rmNearestTiesToEven);
|
||||||
return getConstantFP(apf, VT);
|
return getConstantFP(apf, VT);
|
||||||
}
|
}
|
||||||
case ISD::BIT_CONVERT:
|
case ISD::BIT_CONVERT:
|
||||||
|
@ -398,7 +398,7 @@ GenericValue ExecutionEngine::getConstantValue(const Constant *C) {
|
|||||||
APFloat apf = APFloat(APInt(80, 2, zero));
|
APFloat apf = APFloat(APInt(80, 2, zero));
|
||||||
(void)apf.convertFromInteger(GV.IntVal.getRawData(),
|
(void)apf.convertFromInteger(GV.IntVal.getRawData(),
|
||||||
GV.IntVal.getBitWidth(), false,
|
GV.IntVal.getBitWidth(), false,
|
||||||
APFloat::rmTowardZero);
|
APFloat::rmNearestTiesToEven);
|
||||||
GV.IntVal = apf.convertToAPInt();
|
GV.IntVal = apf.convertToAPInt();
|
||||||
}
|
}
|
||||||
return GV;
|
return GV;
|
||||||
@ -414,7 +414,7 @@ GenericValue ExecutionEngine::getConstantValue(const Constant *C) {
|
|||||||
APFloat apf = APFloat(APInt(80, 2, zero));
|
APFloat apf = APFloat(APInt(80, 2, zero));
|
||||||
(void)apf.convertFromInteger(GV.IntVal.getRawData(),
|
(void)apf.convertFromInteger(GV.IntVal.getRawData(),
|
||||||
GV.IntVal.getBitWidth(), true,
|
GV.IntVal.getBitWidth(), true,
|
||||||
APFloat::rmTowardZero);
|
APFloat::rmNearestTiesToEven);
|
||||||
GV.IntVal = apf.convertToAPInt();
|
GV.IntVal = apf.convertToAPInt();
|
||||||
}
|
}
|
||||||
return GV;
|
return GV;
|
||||||
|
@ -209,25 +209,17 @@ Constant *llvm::ConstantFoldCastInstruction(unsigned opc, const Constant *V,
|
|||||||
return ConstantInt::get(DestTy, 0);
|
return ConstantInt::get(DestTy, 0);
|
||||||
return 0; // Other pointer types cannot be casted
|
return 0; // Other pointer types cannot be casted
|
||||||
case Instruction::UIToFP:
|
case Instruction::UIToFP:
|
||||||
if (const ConstantInt *CI = dyn_cast<ConstantInt>(V)) {
|
|
||||||
double d = CI->getValue().roundToDouble();
|
|
||||||
if (DestTy==Type::FloatTy)
|
|
||||||
return ConstantFP::get(DestTy, APFloat((float)d));
|
|
||||||
else if (DestTy==Type::DoubleTy)
|
|
||||||
return ConstantFP::get(DestTy, APFloat(d));
|
|
||||||
else
|
|
||||||
return 0; // FIXME do this for long double
|
|
||||||
}
|
|
||||||
return 0;
|
|
||||||
case Instruction::SIToFP:
|
case Instruction::SIToFP:
|
||||||
if (const ConstantInt *CI = dyn_cast<ConstantInt>(V)) {
|
if (const ConstantInt *CI = dyn_cast<ConstantInt>(V)) {
|
||||||
double d = CI->getValue().signedRoundToDouble();
|
APInt api = CI->getValue();
|
||||||
if (DestTy==Type::FloatTy)
|
const uint64_t zero[] = {0, 0};
|
||||||
return ConstantFP::get(DestTy, APFloat((float)d));
|
uint32_t BitWidth = cast<IntegerType>(SrcTy)->getBitWidth();
|
||||||
else if (DestTy==Type::DoubleTy)
|
APFloat apf = APFloat(APInt(DestTy->getPrimitiveSizeInBits(),
|
||||||
return ConstantFP::get(DestTy, APFloat(d));
|
2, zero));
|
||||||
else
|
(void)apf.convertFromInteger(api.getRawData(), BitWidth,
|
||||||
return 0; // FIXME do this for long double
|
opc==Instruction::SIToFP,
|
||||||
|
APFloat::rmNearestTiesToEven);
|
||||||
|
return ConstantFP::get(DestTy, apf);
|
||||||
}
|
}
|
||||||
return 0;
|
return 0;
|
||||||
case Instruction::ZExt:
|
case Instruction::ZExt:
|
||||||
|
Loading…
x
Reference in New Issue
Block a user