mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2025-01-14 00:32:55 +00:00
Upgrade ConstantFP's negative zero and infinity getters to handle vector types.
Will be used soon. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@199552 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
4bd80f02d6
commit
bedf842b78
@ -255,8 +255,8 @@ public:
|
||||
static Constant *get(Type* Ty, double V);
|
||||
static Constant *get(Type* Ty, StringRef Str);
|
||||
static ConstantFP *get(LLVMContext &Context, const APFloat &V);
|
||||
static ConstantFP *getNegativeZero(Type* Ty);
|
||||
static ConstantFP *getInfinity(Type *Ty, bool Negative = false);
|
||||
static Constant *getNegativeZero(Type *Ty);
|
||||
static Constant *getInfinity(Type *Ty, bool Negative = false);
|
||||
|
||||
/// isValueValidForType - return true if Ty is big enough to represent V.
|
||||
static bool isValueValidForType(Type *Ty, const APFloat &V);
|
||||
|
@ -584,23 +584,21 @@ Constant *ConstantFP::get(Type *Ty, StringRef Str) {
|
||||
return C;
|
||||
}
|
||||
|
||||
Constant *ConstantFP::getNegativeZero(Type *Ty) {
|
||||
const fltSemantics &Semantics = *TypeToFloatSemantics(Ty->getScalarType());
|
||||
APFloat NegZero = APFloat::getZero(Semantics, /*Negative=*/true);
|
||||
Constant *C = get(Ty->getContext(), NegZero);
|
||||
|
||||
ConstantFP *ConstantFP::getNegativeZero(Type *Ty) {
|
||||
LLVMContext &Context = Ty->getContext();
|
||||
APFloat apf = cast<ConstantFP>(Constant::getNullValue(Ty))->getValueAPF();
|
||||
apf.changeSign();
|
||||
return get(Context, apf);
|
||||
if (VectorType *VTy = dyn_cast<VectorType>(Ty))
|
||||
return ConstantVector::getSplat(VTy->getNumElements(), C);
|
||||
|
||||
return C;
|
||||
}
|
||||
|
||||
|
||||
Constant *ConstantFP::getZeroValueForNegation(Type *Ty) {
|
||||
Type *ScalarTy = Ty->getScalarType();
|
||||
if (ScalarTy->isFloatingPointTy()) {
|
||||
Constant *C = getNegativeZero(ScalarTy);
|
||||
if (VectorType *VTy = dyn_cast<VectorType>(Ty))
|
||||
return ConstantVector::getSplat(VTy->getNumElements(), C);
|
||||
return C;
|
||||
}
|
||||
if (Ty->isFPOrFPVectorTy())
|
||||
return getNegativeZero(Ty);
|
||||
|
||||
return Constant::getNullValue(Ty);
|
||||
}
|
||||
@ -635,10 +633,14 @@ ConstantFP* ConstantFP::get(LLVMContext &Context, const APFloat& V) {
|
||||
return Slot;
|
||||
}
|
||||
|
||||
ConstantFP *ConstantFP::getInfinity(Type *Ty, bool Negative) {
|
||||
const fltSemantics &Semantics = *TypeToFloatSemantics(Ty);
|
||||
return ConstantFP::get(Ty->getContext(),
|
||||
APFloat::getInf(Semantics, Negative));
|
||||
Constant *ConstantFP::getInfinity(Type *Ty, bool Negative) {
|
||||
const fltSemantics &Semantics = *TypeToFloatSemantics(Ty->getScalarType());
|
||||
Constant *C = get(Ty->getContext(), APFloat::getInf(Semantics, Negative));
|
||||
|
||||
if (VectorType *VTy = dyn_cast<VectorType>(Ty))
|
||||
return ConstantVector::getSplat(VTy->getNumElements(), C);
|
||||
|
||||
return C;
|
||||
}
|
||||
|
||||
ConstantFP::ConstantFP(Type *Ty, const APFloat& V)
|
||||
|
Loading…
x
Reference in New Issue
Block a user