diff options
author | Dan Gohman <gohman@apple.com> | 2009-07-17 17:16:59 +0000 |
---|---|---|
committer | Dan Gohman <gohman@apple.com> | 2009-07-17 17:16:59 +0000 |
commit | cc3d909c5fda84e7cf2562e1b1fcc9860449ac4c (patch) | |
tree | 9d11324dc2c7b002aeae1439c140e8831d4253ff | |
parent | 228de528ceb8c44747f6155dafc6dfebe8782470 (diff) | |
download | external_llvm-cc3d909c5fda84e7cf2562e1b1fcc9860449ac4c.zip external_llvm-cc3d909c5fda84e7cf2562e1b1fcc9860449ac4c.tar.gz external_llvm-cc3d909c5fda84e7cf2562e1b1fcc9860449ac4c.tar.bz2 |
Add a SubclassOptionalData field to Value. See the doxygen comment for
details.
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@76189 91177308-0d34-0410-b5e6-96231b3b80d8
-rw-r--r-- | include/llvm/Value.h | 6 | ||||
-rw-r--r-- | lib/VMCore/Value.cpp | 3 |
2 files changed, 8 insertions, 1 deletions
diff --git a/include/llvm/Value.h b/include/llvm/Value.h index a38d8cb..35a30a8 100644 --- a/include/llvm/Value.h +++ b/include/llvm/Value.h @@ -62,6 +62,12 @@ class Value { const unsigned char SubclassID; // Subclass identifier (for isa/dyn_cast) unsigned char HasValueHandle : 1; // Has a ValueHandle pointing to this? protected: + /// SubclassOptionalData - This member is similar to SubclassData, however it + /// is for holding information which may be used to aid optimization, but + /// which may be cleared to zero without affecting conservative + /// interpretation. + unsigned char SubclassOptionalData : 7; + /// SubclassData - This member is defined by this class, but is not used for /// anything. Subclasses can use it to hold whatever state they find useful. /// This field is initialized to zero by the ctor. diff --git a/lib/VMCore/Value.cpp b/lib/VMCore/Value.cpp index f3d561f..b35ad50 100644 --- a/lib/VMCore/Value.cpp +++ b/lib/VMCore/Value.cpp @@ -40,7 +40,8 @@ static inline const Type *checkType(const Type *Ty) { } Value::Value(const Type *ty, unsigned scid) - : SubclassID(scid), HasValueHandle(0), SubclassData(0), VTy(checkType(ty)), + : SubclassID(scid), HasValueHandle(0), SubclassOptionalData(0), + SubclassData(0), VTy(checkType(ty)), UseList(0), Name(0) { if (isa<CallInst>(this) || isa<InvokeInst>(this)) assert((VTy->isFirstClassType() || VTy == Type::VoidTy || |