|
LLVM 23.0.0git
|
#include "llvm/ADT/APFloat.h"
Static Public Member Functions | |
| static APFloat | getZero (const fltSemantics &Sem, bool Negative=false) |
| Factory for Positive and Negative Zero. | |
| static APFloat | getOne (const fltSemantics &Sem, bool Negative=false) |
| Factory for Positive and Negative One. | |
| static APFloat | getInf (const fltSemantics &Sem, bool Negative=false) |
| Factory for Positive and Negative Infinity. | |
| static APFloat | getNaN (const fltSemantics &Sem, bool Negative=false, uint64_t payload=0) |
| Factory for NaN values. | |
| static APFloat | getQNaN (const fltSemantics &Sem, bool Negative=false, const APInt *payload=nullptr) |
| Factory for QNaN values. | |
| static APFloat | getSNaN (const fltSemantics &Sem, bool Negative=false, const APInt *payload=nullptr) |
| Factory for SNaN values. | |
| static APFloat | getLargest (const fltSemantics &Sem, bool Negative=false) |
| Returns the largest finite number in the given semantics. | |
| static APFloat | getSmallest (const fltSemantics &Sem, bool Negative=false) |
| Returns the smallest (by magnitude) finite number in the given semantics. | |
| static APFloat | getSmallestNormalized (const fltSemantics &Sem, bool Negative=false) |
| Returns the smallest (by magnitude) normalized finite number in the given semantics. | |
| static LLVM_ABI APFloat | getAllOnesValue (const fltSemantics &Semantics) |
| Returns a float which is bitcasted from an all one value int. | |
| static bool | hasSignificand (const fltSemantics &Sem) |
| Returns true if the given semantics has actual significand. | |
| static APFloat | copySign (APFloat Value, const APFloat &Sign) |
| A static helper to produce a copy of an APFloat value with its sign copied from some other APFloat. | |
| Static Public Member Functions inherited from llvm::APFloatBase | |
| static LLVM_ABI unsigned int | semanticsPrecision (const fltSemantics &) |
| static LLVM_ABI ExponentType | semanticsMinExponent (const fltSemantics &) |
| static LLVM_ABI ExponentType | semanticsMaxExponent (const fltSemantics &) |
| static LLVM_ABI unsigned int | semanticsSizeInBits (const fltSemantics &) |
| static LLVM_ABI unsigned int | semanticsIntSizeInBits (const fltSemantics &, bool) |
| static LLVM_ABI bool | semanticsHasZero (const fltSemantics &) |
| static LLVM_ABI bool | semanticsHasSignedRepr (const fltSemantics &) |
| static LLVM_ABI bool | semanticsHasInf (const fltSemantics &) |
| static LLVM_ABI bool | semanticsHasNaN (const fltSemantics &) |
| static LLVM_ABI bool | isIEEELikeFP (const fltSemantics &) |
| static LLVM_ABI bool | hasSignBitInMSB (const fltSemantics &) |
| static LLVM_ABI bool | isRepresentableAsNormalIn (const fltSemantics &Src, const fltSemantics &Dst) |
| static LLVM_ABI unsigned | getSizeInBits (const fltSemantics &Sem) |
| Returns the size of the floating point number (in bits) in the given semantics. | |
| static LLVM_ABI bool | isValidArbitraryFPFormat (StringRef Format) |
| Returns true if the given string is a valid arbitrary floating-point format interpretation for llvm.convert.to.arbitrary.fp and llvm.convert.from.arbitrary.fp intrinsics. | |
| static LLVM_ABI const fltSemantics * | getArbitraryFPSemantics (StringRef Format) |
| Returns the fltSemantics for a given arbitrary FP format string, or nullptr if invalid. | |
| static LLVM_ABI const llvm::fltSemantics & | EnumToSemantics (Semantics S) |
| static LLVM_ABI Semantics | SemanticsToEnum (const llvm::fltSemantics &Sem) |
| static const fltSemantics & | IEEEhalf () |
| static const fltSemantics & | BFloat () |
| static const fltSemantics & | IEEEsingle () |
| static const fltSemantics & | IEEEdouble () |
| static const fltSemantics & | IEEEquad () |
| static const fltSemantics & | PPCDoubleDouble () |
| static const fltSemantics & | PPCDoubleDoubleLegacy () |
| static const fltSemantics & | Float8E5M2 () |
| static const fltSemantics & | Float8E5M2FNUZ () |
| static const fltSemantics & | Float8E4M3 () |
| static const fltSemantics & | Float8E4M3FN () |
| static const fltSemantics & | Float8E4M3FNUZ () |
| static const fltSemantics & | Float8E4M3B11FNUZ () |
| static const fltSemantics & | Float8E3M4 () |
| static const fltSemantics & | FloatTF32 () |
| static const fltSemantics & | Float8E8M0FNU () |
| static const fltSemantics & | Float6E3M2FN () |
| static const fltSemantics & | Float6E2M3FN () |
| static const fltSemantics & | Float4E2M1FN () |
| static const fltSemantics & | x87DoubleExtended () |
| static const fltSemantics & | Bogus () |
| A Pseudo fltsemantic used to construct APFloats that cannot conflict with anything real. | |
| static LLVM_ABI bool | isRepresentableBy (const fltSemantics &A, const fltSemantics &B) |
Public Attributes | |
| friend | IEEEFloat |
| friend | DoubleAPFloat |
Friends | |
| LLVM_ABI friend hash_code | hash_value (const APFloat &Arg) |
| See friend declarations above. | |
| int | ilogb (const APFloat &Arg) |
| Returns the exponent of the internal representation of the APFloat. | |
| APFloat | scalbn (APFloat X, int Exp, roundingMode RM) |
| APFloat | frexp (const APFloat &X, int &Exp, roundingMode RM) |
|
inline |
| llvm::APFloat::APFloat | ( | const fltSemantics & | Semantics, |
| StringRef | S ) |
Definition at line 5821 of file APFloat.cpp.
References assert(), llvm::consumeError(), convertFromString(), and llvm::APFloatBase::rmNearestTiesToEven.
|
inline |
|
delete |
References T.
|
inline |
Definition at line 1123 of file APFloat.h.
References llvm::APFloatBase::uninitialized.
|
inline |
|
inlineexplicit |
Definition at line 1126 of file APFloat.h.
References llvm::APFloatBase::IEEEdouble().
|
inlineexplicit |
Definition at line 1127 of file APFloat.h.
References llvm::APFloatBase::IEEEsingle().
|
default |
|
inline |
Definition at line 1240 of file APFloat.h.
References assert(), getSemantics(), llvm_unreachable, and RHS.
Referenced by llvm::ConstantFoldBinaryInstruction(), llvm::ConstantFoldFPBinOp(), llvm::SelectionDAG::FoldConstantArithmetic(), llvm::SelectionDAG::foldConstantFPMath(), llvm::ExecutionEngine::getConstantValue(), llvm::detail::DoubleAPFloat::multiply(), llvm::AMDGPUTargetLowering::PerformDAGCombine(), and llvm::detail::DoubleAPFloat::roundToIntegral().
|
inline |
Definition at line 1430 of file APFloat.h.
References APFLOAT_DISPATCH_ON_SEMANTICS, and bitcastToAPInt().
Referenced by llvm::DwarfExpression::addConstantFP(), llvm::DwarfUnit::addConstantFPValue(), bitcastToAPInt(), llvm::detail::DoubleAPFloat::convertFromString(), convertIntToDoubleImm(), llvm::convertToNonDenormSingle(), llvm::SPIRVGlobalRegistry::createConstFP(), llvm::detail::DoubleAPFloat::divide(), emitGlobalConstantFP(), llvm::TargetLowering::expandIS_FPCLASS(), llvm::InstCombinerImpl::foldICmpAndConstConst(), foldLogOpOfMaskedICmps_NotAllZeros_BMask_Mixed(), llvm::detail::DoubleAPFloat::fusedMultiplyAdd(), llvm::generateSpecConstantInst(), llvm::ExecutionEngine::getConstantValue(), llvm::getExpressionForConstant(), llvm::AArch64_AM::getFP16Imm(), llvm::ARM_AM::getFP16Imm(), llvm::ARM_AM::getFP32FP16Imm(), llvm::AArch64_AM::getFP32Imm(), llvm::ARM_AM::getFP32Imm(), llvm::AArch64_AM::getFP64Imm(), llvm::ARM_AM::getFP64Imm(), llvm::RISCVLoadFPImm::getLoadFPImm(), llvm::HexagonLowerToMC(), llvm::GCNTTIImpl::instCombineIntrinsic(), llvm::AMDGPUTargetLowering::isInt64ImmLegal(), llvm::RISCVLegalizerInfo::legalizeCustom(), llvm::LegalizerHelper::lowerISFPCLASS(), llvm::CombinerHelper::matchCombineUnmergeConstant(), llvm::detail::DoubleAPFloat::mod(), llvm::NVPTXFloatMCExpr::printImpl(), Profile(), llvm::detail::DoubleAPFloat::remainder(), llvm::RISCVDAGToDAGISel::Select(), llvm::RISCVDAGToDAGISel::selectScalarFPAsInt(), llvm::stableHashValue(), llvm::LegalizerHelper::widenScalar(), and writeAPFloatInternal().
Definition at line 1503 of file APFloat.h.
References getSemantics(), llvm_unreachable, and RHS.
Referenced by llvm::ConstantFPRange::getSingleElement(), isExactlyValue(), isInv2Pi(), and isInv2Pi().
|
inline |
Definition at line 1356 of file APFloat.h.
References APFLOAT_DISPATCH_ON_SEMANTICS, and changeSign().
Referenced by changeSign(), clearSign(), copySign(), llvm::PPCInstrInfo::finalizeInsInstrs(), llvm::SelectionDAG::getIdentityElement(), llvm::TargetLowering::getNegatedExpression(), getOne(), llvm::SelectionDAG::isIdentityElement(), llvm::SPIRVCombinerHelper::matchSelectToFaceForward(), and llvm::X86TargetLowering::X86TargetLowering().
| FPClassTest llvm::APFloat::classify | ( | ) | const |
Return the FPClassTest which will return true for the value.
Definition at line 5828 of file APFloat.cpp.
References assert(), llvm::fcNegInf, llvm::fcNegNormal, llvm::fcNegSubnormal, llvm::fcNegZero, llvm::fcPosInf, llvm::fcPosNormal, llvm::fcPosSubnormal, llvm::fcPosZero, llvm::fcQNan, llvm::fcSNan, isDenormal(), isInfinity(), isNaN(), isNegative(), isNormal(), isSignaling(), and isZero().
Referenced by llvm::GenericFloatingPointPredicateUtils< SSAContext >::fcmpImpliesClass(), and llvm::InstCombinerImpl::foldICmpBitCast().
|
inline |
Definition at line 1357 of file APFloat.h.
References changeSign(), and isNegative().
Referenced by LowerFCOPYSIGN(), llvm::InstCombinerImpl::visitCallInst(), and llvm::InstCombinerImpl::visitFCmpInst().
Definition at line 1481 of file APFloat.h.
References assert(), getSemantics(), llvm_unreachable, and RHS.
Referenced by fmed3AMDGCN(), operator!=(), operator<(), operator<=(), operator==(), operator>(), and operator>=().
Definition at line 1493 of file APFloat.h.
References assert(), getSemantics(), llvm_unreachable, and RHS.
Referenced by llvm::KnownFPClass::fmul().
| APFloat::opStatus llvm::APFloat::convert | ( | const fltSemantics & | ToSemantics, |
| roundingMode | RM, | ||
| bool * | losesInfo ) |
Definition at line 5899 of file APFloat.cpp.
References llvm::APFloatBase::APFloat, assert(), getSemantics(), llvm_unreachable, and llvm::APFloatBase::opOK.
Referenced by canLosslesslyConvertToFPType(), canSafelyConvertTo16Bit(), llvm::ConstantFPRange::cast(), llvm::checkConvertToNonDenormSingle(), llvm::ConstantFoldCastInstruction(), convertToDouble(), llvm::APFixedPoint::convertToFloat(), convertToFloat(), llvm::convertToNonDenormSingle(), emitDebugValueComment(), llvm::SelectionDAG::FoldConstantArithmetic(), llvm::SelectionDAG::foldConstantFPMath(), foldFCmpFpTrunc(), llvm::ConstantFP::get(), llvm::getAPFloatFromSize(), llvm::SelectionDAG::getConstantFP(), llvm::APFixedPoint::getFromFloatValue(), llvm::RISCVLoadFPImm::getLoadFPImm(), llvm::GCNTTIImpl::instCombineIntrinsic(), isExactlyValue(), llvm::ConstantFP::isExactlyValue(), isFPExtFromF16OrConst(), llvm::ConstantFP::isValueValidForType(), llvm::ConstantFPSDNode::isValueValidForType(), LLVMConstRealGetDouble(), LowerFROUND(), llvm::ARMAsmPrinter::lowerOperand(), matchFPExtFromF16(), llvm::NVPTXFloatMCExpr::printImpl(), strictFPExtFromF16(), llvm::InstCombinerImpl::visitFCmpInst(), and llvm::X86TargetLowering::X86TargetLowering().
|
inline |
Definition at line 1406 of file APFloat.h.
References APFLOAT_DISPATCH_ON_SEMANTICS, and convertFromAPInt().
Referenced by llvm::ConstantFoldCastInstruction(), llvm::ConstantFoldIntToFloat(), convertFromAPInt(), llvm::APFixedPoint::convertToFloat(), llvm::TargetLowering::expandFP_TO_INT_SAT(), llvm::TargetLowering::expandFP_TO_UINT(), llvm::SelectionDAG::FoldConstantArithmetic(), foldFPToIntToFP(), llvm::ExecutionEngine::getConstantValue(), llvm::LegalizerHelper::lowerFPTOINT_SAT(), llvm::LegalizerHelper::lowerFPTOUI(), lowerFTRUNC_FCEIL_FFLOOR_FROUND(), lowerVectorFTRUNC_FCEIL_FFLOOR_FROUND(), and lowerVectorStrictFTRUNC_FCEIL_FFLOOR_FROUND().
| Expected< APFloat::opStatus > llvm::APFloat::convertFromString | ( | StringRef | Str, |
| roundingMode | RM ) |
Fill this APFloat with the result of a string conversion.
The following strings are accepted for conversion purposes:
If the input string is none of these forms, then an error is returned.
If a floating-point exception occurs during conversion, then no error is returned, and the exception is indicated via opStatus.
Definition at line 5808 of file APFloat.cpp.
References APFLOAT_DISPATCH_ON_SEMANTICS, and convertFromString().
Referenced by APFloat(), convertFromString(), and llvm::detail::DoubleAPFloat::convertFromString().
| double llvm::APFloat::convertToDouble | ( | ) | const |
Converts this APFloat to host double value.
Definition at line 5958 of file APFloat.cpp.
References assert(), convert(), llvm::detail::IEEEFloat::convertToDouble(), getSemantics(), llvm::APFloatBase::isRepresentableBy(), llvm::APFloatBase::opInexact, and llvm::APFloatBase::rmNearestTiesToEven.
Referenced by emitDebugValueComment(), llvm::ExecutionEngine::getConstantValue(), LLVMConstRealGetDouble(), and llvm::ARMAsmPrinter::lowerOperand().
| float llvm::APFloat::convertToFloat | ( | ) | const |
Converts this APFloat to host float value.
Definition at line 5986 of file APFloat.cpp.
References assert(), convert(), llvm::detail::IEEEFloat::convertToFloat(), getSemantics(), llvm::APFloatBase::isRepresentableBy(), llvm::APFloatBase::opInexact, and llvm::APFloatBase::rmNearestTiesToEven.
Referenced by llvm::ExecutionEngine::getConstantValue(), llvm::FPMathOperator::getFPAccuracy(), insertSpirvDecorations(), and llvm::SPIRVMCInstLower::lower().
|
inline |
Definition at line 1528 of file APFloat.h.
References APFLOAT_DISPATCH_ON_SEMANTICS, and convertToHexString().
Referenced by convertToHexString(), and llvm::detail::DoubleAPFloat::convertToHexString().
| APFloat::opStatus llvm::APFloat::convertToInteger | ( | APSInt & | Result, |
| roundingMode | RM, | ||
| bool * | IsExact ) const |
Definition at line 5946 of file APFloat.cpp.
References convertToInteger(), llvm::APInt::getBitWidth(), llvm::APInt::getNumWords(), and llvm::APSInt::isSigned().
|
inline |
Definition at line 1391 of file APFloat.h.
References APFLOAT_DISPATCH_ON_SEMANTICS, and convertToInteger().
Referenced by llvm::CheckFixedPointOperandConstant(), convertToInteger(), convertToInteger(), ConvertToSInt(), foldFPToIntToFP(), llvm::BuildVectorSDNode::getConstantFPSplatPow2ToLog2Int(), llvm::ExecutionEngine::getConstantValue(), getExactInteger(), isMinMaxCmpSelectEliminable(), and PerformVMulVCTPCombine().
Definition at line 1361 of file APFloat.h.
References changeSign(), isNegative(), and RHS.
Referenced by llvm::ConstantFoldFPBinOp(), and llvm::SelectionDAG::foldConstantFPMath().
|
inline |
Definition at line 1267 of file APFloat.h.
References assert(), getSemantics(), llvm_unreachable, and RHS.
Referenced by llvm::ConstantFoldBinaryInstruction(), llvm::ConstantFoldFPBinOp(), llvm::detail::DoubleAPFloat::divide(), llvm::SelectionDAG::foldConstantFPMath(), llvm::ExecutionEngine::getConstantValue(), and llvm::GCNTTIImpl::instCombineIntrinsic().
| LLVM_DUMP_METHOD void llvm::APFloat::dump | ( | ) | const |
Definition at line 5936 of file APFloat.cpp.
References llvm::dbgs(), LLVM_DUMP_METHOD, and print().
|
inline |
Definition at line 1294 of file APFloat.h.
References assert(), getSemantics(), and llvm_unreachable.
Referenced by llvm::SelectionDAG::FoldConstantArithmetic(), llvm::detail::DoubleAPFloat::fusedMultiplyAdd(), llvm::CombinerHelper::matchConstantFoldFMA(), and llvm::detail::DoubleAPFloat::multiply().
|
static |
Returns a float which is bitcasted from an all one value int.
| Semantics | - type float semantics |
Definition at line 5925 of file APFloat.cpp.
References llvm::APFloatBase::APFloat, and llvm::APInt::getAllOnes().
Referenced by llvm::Constant::getAllOnesValue(), and lowerShuffleAsBitMask().
|
inline |
Definition at line 1545 of file APFloat.h.
Referenced by isInfinity(), isNaN(), and isZero().
If this value is normal and has an exact, normal, multiplicative inverse, store it in inv and return true.
Definition at line 5841 of file APFloat.cpp.
References assert(), getExactLog2Abs(), getOne(), getSemantics(), isDenormal(), isFiniteNonZero(), isNegative(), llvm::APFloatBase::rmTowardZero, and scalbn.
Referenced by llvm::CheckFixedPointOperandConstant(), and PerformVMulVCTPCombine().
|
inline |
Definition at line 1601 of file APFloat.h.
References getExactLog2Abs(), and isNegative().
|
inline |
Definition at line 1594 of file APFloat.h.
References APFLOAT_DISPATCH_ON_SEMANTICS, and getExactLog2Abs().
Referenced by getExactInverse(), getExactLog2(), getExactLog2Abs(), and llvm::detail::DoubleAPFloat::getExactLog2Abs().
|
inlinestatic |
Factory for Positive and Negative Infinity.
| Negative | True iff the number should be negative. |
Definition at line 1157 of file APFloat.h.
References llvm::APFloatBase::uninitialized.
Referenced by llvm::ConstantFPRange::add(), llvm::KnownFPClass::bitcast(), canonicalizeRange(), computeKnownBitsFromOperator(), llvm::ConstantFPRange::div(), llvm::TargetLowering::expandIS_FPCLASS(), llvm::InstCombinerImpl::foldICmpAndConstConst(), foldLogOpOfMaskedICmps_NotAllZeros_BMask_Mixed(), llvm::SelectionDAG::getIdentityElement(), llvm::ConstantFP::getInfinity(), llvm::AMDGPUTargetLowering::getIsFinite(), llvm::ConstantFPRange::getNaNOnly(), llvm::ConstantFPRange::getNonNaN(), llvm::harrisonUlp(), llvm::SelectionDAG::isIdentityElement(), llvm::AMDGPULegalizerInfo::legalizeFExp(), llvm::AMDGPULegalizerInfo::legalizeFEXPF64(), llvm::AMDGPULegalizerInfo::legalizeFFREXP(), llvm::AMDGPULegalizerInfo::legalizeFlogCommon(), llvm::AMDGPUTargetLowering::lowerFEXP(), llvm::LegalizerHelper::lowerFMODF(), lowerFREM(), llvm::LegalizerHelper::lowerISFPCLASS(), llvm::ConstantFPRange::makeAllowedFCmpRegion(), llvm::fuzzerop::makeConstantsWithType(), makeGreaterThan(), makeLessThan(), and llvm::ConstantFPRange::mul().
|
inlinestatic |
Returns the largest finite number in the given semantics.
| Negative | - True iff the number should be negative |
Definition at line 1197 of file APFloat.h.
References llvm::APFloatBase::uninitialized.
Referenced by computeKnownFPClass(), llvm::TargetLowering::expandIS_FPCLASS(), llvm::InstCombinerImpl::foldFCmpIntToFPConst(), llvm::ConstantFPRange::getFinite(), llvm::SelectionDAG::getIdentityElement(), llvm::getReductionIdentity(), llvm::SelectionDAG::isIdentityElement(), llvm::AMDGPULegalizerInfo::legalizeRsqClampIntrinsic(), llvm::LegalizerHelper::lowerISFPCLASS(), llvm::ConstantFPRange::makeAllowedFCmpRegion(), llvm::fuzzerop::makeConstantsWithType(), removeInf(), and SameSignRange::SameSignRange().
|
inlinestatic |
Factory for NaN values.
| Negative | - True iff the NaN generated should be negative. |
| payload | - The unspecified fill bits for creating the NaN, 0 by default. The value is truncated as necessary. |
Definition at line 1168 of file APFloat.h.
References getQNaN().
Referenced by llvm::TargetLowering::expandFMINIMUM_FMAXIMUM(), llvm::SelectionDAG::foldConstantFPMath(), getIdentityValueForAtomicOp(), llvm::ConstantFP::getNaN(), llvm::LegalizerHelper::lowerFMinimumMaximum(), and llvm::fuzzerop::makeConstantsWithType().
|
inline |
If the value is a NaN value, return an integer containing the payload of this value.
This payload will include the quiet bit as part of the returned integer.
Definition at line 1564 of file APFloat.h.
References APFLOAT_DISPATCH_ON_SEMANTICS, assert(), getNaNPayload(), and isNaN().
Referenced by getNaNPayload(), and writeAPFloatInternal().
|
inlinestatic |
Factory for Positive and Negative One.
| Negative | True iff the number should be negative. |
Definition at line 1147 of file APFloat.h.
References changeSign().
Referenced by llvm::KnownFPClass::fmul(), foldFCmpFAbsFSubIntToFP(), getExactInverse(), getOneFP(), llvm::harrisonUlp(), llvm::isMathLibCallNoop(), llvm::detail::DoubleAPFloat::roundToIntegral(), llvm::InstCombinerImpl::SimplifyDemandedUseFPClass(), and llvm::InstCombinerImpl::visitCallInst().
|
inlinestatic |
Factory for QNaN values.
Definition at line 1179 of file APFloat.h.
References llvm::APFloatBase::uninitialized.
Referenced by llvm::SelectionDAG::getIdentityElement(), getNaN(), llvm::ConstantFP::getQNaN(), llvm::harrisonUlp(), llvm::GCNTTIImpl::instCombineIntrinsic(), llvm::SelectionDAG::isIdentityElement(), and toString().
|
inline |
Definition at line 1546 of file APFloat.h.
Referenced by add(), llvm::ConstantFPRange::add(), bitwiseIsEqual(), llvm::MachineIRBuilder::buildFConstant(), compare(), compareAbsoluteValue(), constantFoldFpUnary(), llvm::ConstantFPRange::contains(), convert(), convertToDouble(), convertToFloat(), divide(), flushDenormalConstant(), llvm::KnownFPClass::fmul(), fusedMultiplyAdd(), getExactInverse(), llvm::RISCVLoadFPImm::getLoadFPImm(), hash_value, ilogb, llvm::GCNTTIImpl::instCombineIntrinsic(), isExactlyValue(), isRepresentableAsExactInteger(), llvm::ConstantFP::isValueValidForType(), mod(), multiply(), llvm::AMDGPUTargetLowering::performRcpCombine(), printConstant(), remainder(), subtract(), llvm::SystemZVectorConstantInfo::SystemZVectorConstantInfo(), and writeAPFloatInternal().
|
inlinestatic |
Returns the smallest (by magnitude) finite number in the given semantics.
Might be denormalized, which implies a relative loss of precision.
| Negative | - True iff the number should be negative |
Definition at line 1207 of file APFloat.h.
References llvm::APFloatBase::uninitialized.
Referenced by llvm::ConstantFPRange::div(), llvm::harrisonUlp(), and llvm::fuzzerop::makeConstantsWithType().
|
inlinestatic |
Returns the smallest (by magnitude) normalized finite number in the given semantics.
| Negative | - True iff the number should be negative |
Definition at line 1217 of file APFloat.h.
References llvm::APFloatBase::uninitialized.
Referenced by emitRsqIEEE1ULP(), llvm::TargetLowering::expandIS_FPCLASS(), llvm::AMDGPUTargetLowering::getIsLtSmallestNormal(), llvm::AMDGPULegalizerInfo::getScaledLogInput(), llvm::AMDGPUTargetLowering::getScaledLogInput(), llvm::TargetLowering::getSqrtInputTest(), and llvm::InstCombinerImpl::visitFCmpInst().
|
inlinestatic |
Factory for SNaN values.
Definition at line 1187 of file APFloat.h.
References llvm::APFloatBase::uninitialized.
Referenced by llvm::ConstantFP::getSNaN().
|
inlinestatic |
Factory for Positive and Negative Zero.
| Negative | True iff the number should be negative. |
Definition at line 1138 of file APFloat.h.
References llvm::APFloatBase::uninitialized.
Referenced by llvm::ConstantFPRange::abs(), llvm::KnownFPClass::bitcast(), llvm::ConstantFPRange::div(), extendZeroIfEqual(), llvm::detail::fastTwoSum(), fixFuncEntryCount(), flushDenormalConstant(), llvm::ConstantFPRange::flushDenormals(), llvm::generateReadImageInst(), llvm::ExecutionEngine::getConstantValue(), getIdentityValueForAtomicOp(), llvm::Constant::getNullValue(), llvm::ConstantFP::getZero(), getZeroFP(), llvm::GCNTTIImpl::instCombineIntrinsic(), llvm::fuzzerop::makeConstantsWithType(), printConstant(), splitPosNeg(), llvm::pdb::Variant::toAPFloat(), and llvm::X86TargetLowering::X86TargetLowering().
|
inlinestatic |
Returns true if the given semantics has actual significand.
| Sem | - type float semantics |
Definition at line 1232 of file APFloat.h.
References llvm::APFloatBase::Float8E8M0FNU().
Referenced by llvm::detail::IEEEFloat::isLargest(), and llvm::detail::IEEEFloat::next().
|
inline |
Definition at line 1539 of file APFloat.h.
References APFLOAT_DISPATCH_ON_SEMANTICS, and isDenormal().
Referenced by llvm::checkConvertToNonDenormSingle(), classify(), llvm::convertToNonDenormSingle(), flushDenormalConstantFP(), llvm::FlushFPConstant(), getExactInverse(), isDenormal(), and isNormal().
|
inline |
We don't rely on operator== working on double values, as it returns true for things that are clearly not equal, like -0.0 and 0.0.
As such, this method can be used to do an exact bit-for-bit comparison of two floating point values.
We leave the version with the double argument here because it's just so convenient to write "2.0" and the like. Without this function we'd have to duplicate its logic everywhere it's called.
Definition at line 1521 of file APFloat.h.
References bitwiseIsEqual(), convert(), getSemantics(), and llvm::APFloatBase::rmNearestTiesToEven.
Referenced by llvm::SelectionDAG::simplifyFPBinop().
|
inline |
Definition at line 1543 of file APFloat.h.
References isInfinity(), and isNaN().
Referenced by llvm::SelectionDAG::getNode(), isFiniteNonZero(), and matchFastFloatClamp().
|
inline |
Definition at line 1548 of file APFloat.h.
References isFinite(), and isZero().
Referenced by getExactInverse(), and isNormal().
|
inline |
Definition at line 1535 of file APFloat.h.
References llvm::APFloatBase::fcInfinity, and getCategory().
Referenced by classify(), foldFCmpFpTrunc(), llvm::GCNTTIImpl::instCombineIntrinsic(), isFinite(), llvm::isMathLibCallNoop(), isNegInfinity(), isPosInfinity(), llvm::detail::DoubleAPFloat::next(), OptimizeConstMinMax(), and writeAPFloatInternal().
|
inline |
Definition at line 1555 of file APFloat.h.
References APFLOAT_DISPATCH_ON_SEMANTICS, and isInteger().
Referenced by isInteger(), and llvm::isKnownIntegral().
|
inline |
Definition at line 1554 of file APFloat.h.
References APFLOAT_DISPATCH_ON_SEMANTICS, and isLargest().
Referenced by isLargest(), and OptimizeConstMinMax().
|
inline |
Definition at line 1536 of file APFloat.h.
References llvm::APFloatBase::fcNaN, and getCategory().
Referenced by llvm::KnownFPClass::bitcast(), llvm::ConstantFPRange::cast(), classify(), llvm::ConstantFPRange::contains(), foldFCmpFpTrunc(), getNaNPayload(), llvm::GCNTTIImpl::instCombineIntrinsic(), isFinite(), llvm::isMathLibCallNoop(), llvm::CombinerHelper::matchCombineFMinMaxNaN(), OptimizeConstMinMax(), and writeAPFloatInternal().
|
inline |
Definition at line 1538 of file APFloat.h.
Referenced by classify(), clearSign(), copySign(), llvm::GenericFloatingPointPredicateUtils< SSAContext >::fcmpImpliesClass(), flushDenormalConstant(), llvm::detail::frexp(), getExactInverse(), getExactLog2(), llvm::RISCVLoadFPImm::getLoadFPImm(), isNegInfinity(), isNegZero(), isPosInfinity(), isPosZero(), OptimizeConstMinMax(), llvm::detail::DoubleAPFloat::roundToIntegral(), llvm::InstCombinerImpl::visitCallInst(), and writeAPFloatInternal().
|
inline |
Definition at line 1552 of file APFloat.h.
References isInfinity(), and isNegative().
Referenced by llvm::GCNTTIImpl::instCombineIntrinsic().
|
inline |
Definition at line 1550 of file APFloat.h.
References isNegative(), and isZero().
Referenced by llvm::RISCVDAGToDAGISel::Select(), llvm::RISCVDAGToDAGISel::selectScalarFPAsInt(), and llvm::SelectionDAG::simplifyFPBinop().
|
inline |
|
inline |
Definition at line 1542 of file APFloat.h.
References isDenormal(), and isFiniteNonZero().
Referenced by classify().
|
inline |
Definition at line 1551 of file APFloat.h.
References isInfinity(), and isNegative().
Referenced by llvm::GCNTTIImpl::instCombineIntrinsic().
|
inline |
Definition at line 1549 of file APFloat.h.
References isNegative(), and isZero().
Referenced by llvm::SPIRVGlobalRegistry::createConstFP(), llvm::RISCVDAGToDAGISel::Select(), llvm::RISCVDAGToDAGISel::selectScalarFPAsInt(), and llvm::SelectionDAG::simplifyFPBinop().
|
inline |
Definition at line 1540 of file APFloat.h.
Referenced by classify(), llvm::ConstantFPRange::contains(), llvm::GCNTTIImpl::instCombineIntrinsic(), OptimizeConstMinMax(), and writeAPFloatInternal().
|
inline |
Definition at line 1553 of file APFloat.h.
References APFLOAT_DISPATCH_ON_SEMANTICS, and isSmallest().
Referenced by isSmallest().
|
inline |
Definition at line 1557 of file APFloat.h.
References APFLOAT_DISPATCH_ON_SEMANTICS, and isSmallestNormalized().
Referenced by llvm::GenericFloatingPointPredicateUtils< SSAContext >::fcmpImpliesClass(), llvm::RISCVLoadFPImm::getLoadFPImm(), and isSmallestNormalized().
|
inline |
Definition at line 1534 of file APFloat.h.
References llvm::APFloatBase::fcZero, and getCategory().
Referenced by classify(), expandNormalizeIntrinsic(), llvm::detail::frexp(), isFiniteNonZero(), llvm::isMathLibCallNoop(), isNegZero(), isNonZero(), isPosZero(), llvm::detail::DoubleAPFloat::next(), llvm::RISCVDAGToDAGISel::Select(), llvm::SelectionDAG::simplifyFPBinop(), and llvm::InstCombinerImpl::visitFCmpInst().
|
inlinenodiscard |
Assuming this is an IEEE-754 NaN value, quiet its signaling bit.
This preserves the sign and payload bits.
Definition at line 1375 of file APFloat.h.
Referenced by llvm::GCNTTIImpl::instCombineIntrinsic(), and OptimizeConstMinMax().
Definition at line 1285 of file APFloat.h.
References assert(), getSemantics(), llvm_unreachable, and RHS.
Referenced by llvm::ConstantFoldBinaryInstruction(), llvm::ConstantFoldFPBinOp(), llvm::SelectionDAG::foldConstantFPMath(), llvm::ExecutionEngine::getConstantValue(), and llvm::detail::DoubleAPFloat::mod().
|
inline |
Definition at line 1258 of file APFloat.h.
References assert(), getSemantics(), llvm_unreachable, and RHS.
Referenced by llvm::ConstantFoldBinaryInstruction(), llvm::ConstantFoldFPBinOp(), llvm::APFixedPoint::convertToFloat(), llvm::SelectionDAG::FoldConstantArithmetic(), llvm::SelectionDAG::foldConstantFPMath(), llvm::ExecutionEngine::getConstantValue(), and llvm::AMDGPUTargetLowering::PerformDAGCombine().
|
inline |
Definition at line 1133 of file APFloat.h.
References APFLOAT_DISPATCH_ON_SEMANTICS, and needsCleanup().
Referenced by needsCleanup().
Definition at line 1313 of file APFloat.h.
References APFLOAT_DISPATCH_ON_SEMANTICS, and next().
Referenced by foldFCmpFpTrunc(), llvm::detail::frexp(), LowerFROUND(), next(), and llvm::detail::DoubleAPFloat::next().
Definition at line 1459 of file APFloat.h.
References llvm::APFloatBase::cmpEqual, compare(), and RHS.
Multiply two APFloats, rounding ties to the nearest even.
No error checking.
Definition at line 1342 of file APFloat.h.
References RHS, and llvm::APFloatBase::rmNearestTiesToEven.
Add two APFloats, rounding ties to the nearest even.
No error checking.
Definition at line 1326 of file APFloat.h.
References RHS, and llvm::APFloatBase::rmNearestTiesToEven.
|
inline |
Subtract two APFloats, rounding ties to the nearest even.
No error checking.
Definition at line 1334 of file APFloat.h.
References RHS, and llvm::APFloatBase::rmNearestTiesToEven.
Divide the first APFloat by the second, rounding ties to the nearest even.
No error checking.
Definition at line 1350 of file APFloat.h.
References RHS, and llvm::APFloatBase::rmNearestTiesToEven.
Definition at line 1461 of file APFloat.h.
References llvm::APFloatBase::cmpLessThan, compare(), and RHS.
Definition at line 1469 of file APFloat.h.
References llvm::APFloatBase::cmpEqual, llvm::APFloatBase::cmpLessThan, compare(), and RHS.
Definition at line 1457 of file APFloat.h.
References llvm::APFloatBase::cmpEqual, compare(), and RHS.
Definition at line 1465 of file APFloat.h.
References llvm::APFloatBase::cmpGreaterThan, compare(), and RHS.
Definition at line 1474 of file APFloat.h.
References llvm::APFloatBase::cmpEqual, llvm::APFloatBase::cmpGreaterThan, compare(), and RHS.
| void llvm::APFloat::print | ( | raw_ostream & | OS | ) | const |
| void llvm::APFloat::Profile | ( | FoldingSetNodeID & | NID | ) | const |
Used to insert APFloat objects, or objects that contain APFloat objects, into FoldingSets.
Definition at line 5942 of file APFloat.cpp.
References llvm::FoldingSetNodeID::Add(), and bitcastToAPInt().
Definition at line 1276 of file APFloat.h.
References assert(), getSemantics(), llvm_unreachable, and RHS.
Referenced by llvm::detail::DoubleAPFloat::remainder().
|
inline |
Definition at line 1307 of file APFloat.h.
References APFLOAT_DISPATCH_ON_SEMANTICS, and roundToIntegral().
Referenced by llvm::InstCombinerImpl::foldFCmpIntToFPConst(), roundToIntegral(), and llvm::detail::DoubleAPFloat::roundToIntegral().
|
inline |
Definition at line 1249 of file APFloat.h.
References assert(), getSemantics(), llvm_unreachable, and RHS.
Referenced by llvm::ConstantFoldBinaryInstruction(), llvm::ConstantFoldFPBinOp(), llvm::SelectionDAG::foldConstantFPMath(), and llvm::ExecutionEngine::getConstantValue().
|
inline |
Definition at line 1575 of file APFloat.h.
References APFLOAT_DISPATCH_ON_SEMANTICS, and toString().
Referenced by emitGlobalConstantFP(), print(), printConstant(), toString(), llvm::detail::DoubleAPFloat::toString(), and writeAPFloatInternal().
|
friend |
References X.
See friend declarations above.
These additional declarations are required in order to compile LLVM with IBM xlC compiler.
Definition at line 5813 of file APFloat.cpp.
References getSemantics(), hash_value, and llvm_unreachable.
Referenced by hash_value.
Returns the exponent of the internal representation of the APFloat.
Because the radix of APFloat is 2, this is equivalent to floor(log2(x)). For special APFloat values, this returns special error codes:
NaN -> IEK_NaN 0 -> IEK_Zero Inf -> IEK_Inf
Definition at line 1631 of file APFloat.h.
References getSemantics(), llvm::ilogb(), and llvm_unreachable.
|
friend |
References X.
Referenced by getExactInverse().
| friend llvm::APFloat::DoubleAPFloat |
| friend llvm::APFloat::IEEEFloat |