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:
Dale Johannesen 2007-09-30 18:19:03 +00:00
parent cce23a4c35
commit 88216af3ea
4 changed files with 13 additions and 21 deletions

View File

@ -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);

View File

@ -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:

View File

@ -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;

View File

@ -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: