aboutsummaryrefslogtreecommitdiff
path: root/lib/VMCore/ConstantFold.cpp
diff options
context:
space:
mode:
authorChris Lattner <sabre@nondot.org>2001-11-01 05:55:13 +0000
committerChris Lattner <sabre@nondot.org>2001-11-01 05:55:13 +0000
commit76ac1a45b40a96d1e583e2576c04d19b7d23a99e (patch)
tree51d4394be85d2c43a17c209361b260b823f4b011 /lib/VMCore/ConstantFold.cpp
parentd558426b0eee09fee17ed1a9ba771c654b878ba5 (diff)
Implement constant propogation of null pointer values.
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@1078 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'lib/VMCore/ConstantFold.cpp')
-rw-r--r--lib/VMCore/ConstantFold.cpp77
1 files changed, 76 insertions, 1 deletions
diff --git a/lib/VMCore/ConstantFold.cpp b/lib/VMCore/ConstantFold.cpp
index 67a598cf23..7438319000 100644
--- a/lib/VMCore/ConstantFold.cpp
+++ b/lib/VMCore/ConstantFold.cpp
@@ -89,6 +89,10 @@ class TemplateRules : public ConstRules {
virtual ConstPoolFP *castToDouble(const ConstPoolVal *V) const {
return SubClassName::CastToDouble((const ArgType*)V);
}
+ virtual ConstPoolPointer *castToPointer(const ConstPoolVal *V,
+ const PointerType *Ty) const {
+ return SubClassName::CastToPointer((const ArgType*)V, Ty);
+ }
//===--------------------------------------------------------------------===//
// Default "noop" implementations
@@ -121,6 +125,8 @@ class TemplateRules : public ConstRules {
inline static ConstPoolUInt *CastToULong (const ConstPoolVal *V) { return 0; }
inline static ConstPoolFP *CastToFloat (const ConstPoolVal *V) { return 0; }
inline static ConstPoolFP *CastToDouble(const ConstPoolVal *V) { return 0; }
+ inline static ConstPoolPointer *CastToPointer(const ConstPoolVal *,
+ const PointerType *) {return 0;}
};
@@ -161,6 +167,67 @@ struct BoolRules : public TemplateRules<ConstPoolBool, BoolRules> {
//===----------------------------------------------------------------------===//
+// PointerRules Class
+//===----------------------------------------------------------------------===//
+//
+// PointerRules provides a concrete base class of ConstRules for pointer types
+//
+struct PointerRules : public TemplateRules<ConstPoolPointer, PointerRules> {
+ inline static ConstPoolBool *CastToBool (const ConstPoolVal *V) {
+ if (V->isNullValue()) return ConstPoolBool::False;
+ return 0; // Can't const prop other types of pointers
+ }
+ inline static ConstPoolSInt *CastToSByte (const ConstPoolVal *V) {
+ if (V->isNullValue()) return ConstPoolSInt::get(Type::SByteTy, 0);
+ return 0; // Can't const prop other types of pointers
+ }
+ inline static ConstPoolUInt *CastToUByte (const ConstPoolVal *V) {
+ if (V->isNullValue()) return ConstPoolUInt::get(Type::UByteTy, 0);
+ return 0; // Can't const prop other types of pointers
+ }
+ inline static ConstPoolSInt *CastToShort (const ConstPoolVal *V) {
+ if (V->isNullValue()) return ConstPoolSInt::get(Type::ShortTy, 0);
+ return 0; // Can't const prop other types of pointers
+ }
+ inline static ConstPoolUInt *CastToUShort(const ConstPoolVal *V) {
+ if (V->isNullValue()) return ConstPoolUInt::get(Type::UShortTy, 0);
+ return 0; // Can't const prop other types of pointers
+ }
+ inline static ConstPoolSInt *CastToInt (const ConstPoolVal *V) {
+ if (V->isNullValue()) return ConstPoolSInt::get(Type::IntTy, 0);
+ return 0; // Can't const prop other types of pointers
+ }
+ inline static ConstPoolUInt *CastToUInt (const ConstPoolVal *V) {
+ if (V->isNullValue()) return ConstPoolUInt::get(Type::UIntTy, 0);
+ return 0; // Can't const prop other types of pointers
+ }
+ inline static ConstPoolSInt *CastToLong (const ConstPoolVal *V) {
+ if (V->isNullValue()) return ConstPoolSInt::get(Type::LongTy, 0);
+ return 0; // Can't const prop other types of pointers
+ }
+ inline static ConstPoolUInt *CastToULong (const ConstPoolVal *V) {
+ if (V->isNullValue()) return ConstPoolUInt::get(Type::ULongTy, 0);
+ return 0; // Can't const prop other types of pointers
+ }
+ inline static ConstPoolFP *CastToFloat (const ConstPoolVal *V) {
+ if (V->isNullValue()) return ConstPoolFP::get(Type::FloatTy, 0);
+ return 0; // Can't const prop other types of pointers
+ }
+ inline static ConstPoolFP *CastToDouble(const ConstPoolVal *V) {
+ if (V->isNullValue()) return ConstPoolFP::get(Type::DoubleTy, 0);
+ return 0; // Can't const prop other types of pointers
+ }
+
+ inline static ConstPoolPointer *CastToPointer(const ConstPoolPointer *V,
+ const PointerType *PTy) {
+ if (V->isNullValue())
+ return ConstPoolPointerNull::get(PTy);
+ return 0; // Can't const prop other types of pointers
+ }
+};
+
+
+//===----------------------------------------------------------------------===//
// DirectRules Class
//===----------------------------------------------------------------------===//
//
@@ -204,6 +271,13 @@ struct DirectRules
return ConstPoolBool::get(Result);
}
+ inline static ConstPoolPointer *CastToPointer(const ConstPoolClass *V,
+ const PointerType *PTy) {
+ if (V->isNullValue()) // Is it a FP or Integral null value?
+ return ConstPoolPointerNull::get(PTy);
+ return 0; // Can't const prop other types of pointers
+ }
+
// Casting operators. ick
#define DEF_CAST(TYPE, CLASS, CTYPE) \
inline static CLASS *CastTo##TYPE (const ConstPoolClass *V) { \
@@ -241,7 +315,8 @@ Annotation *ConstRules::find(AnnotationID AID, const Annotable *TyA, void *) {
const Type *Ty = cast<Type>((const Value*)TyA);
switch (Ty->getPrimitiveID()) {
- case Type::BoolTyID: return new BoolRules();
+ case Type::BoolTyID: return new BoolRules();
+ case Type::PointerTyID: return new PointerRules();
case Type::SByteTyID:
return new DirectRules<ConstPoolSInt, signed char , &Type::SByteTy>();
case Type::UByteTyID: