aboutsummaryrefslogtreecommitdiffstats
path: root/lib/Bitcode/Writer
diff options
context:
space:
mode:
authorChris Lattner <sabre@nondot.org>2007-05-06 08:35:19 +0000
committerChris Lattner <sabre@nondot.org>2007-05-06 08:35:19 +0000
commit33f1d5b328813c986b8d083006a024e1a0c7d982 (patch)
tree8d9c7dd4924d95d33a69d769a225c2b8938487d8 /lib/Bitcode/Writer
parentb55a5803b2ebea65c1ab404af05c843599e2a7d3 (diff)
downloadexternal_llvm-33f1d5b328813c986b8d083006a024e1a0c7d982.zip
external_llvm-33f1d5b328813c986b8d083006a024e1a0c7d982.tar.gz
external_llvm-33f1d5b328813c986b8d083006a024e1a0c7d982.tar.bz2
Fix a nasty problem where we would miss enumeration of some types. This fixes
issues with CE_CAST etc. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@36864 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'lib/Bitcode/Writer')
-rw-r--r--lib/Bitcode/Writer/ValueEnumerator.cpp18
-rw-r--r--lib/Bitcode/Writer/ValueEnumerator.h1
2 files changed, 18 insertions, 1 deletions
diff --git a/lib/Bitcode/Writer/ValueEnumerator.cpp b/lib/Bitcode/Writer/ValueEnumerator.cpp
index f5224d2..6b3885e 100644
--- a/lib/Bitcode/Writer/ValueEnumerator.cpp
+++ b/lib/Bitcode/Writer/ValueEnumerator.cpp
@@ -84,7 +84,7 @@ ValueEnumerator::ValueEnumerator(const Module *M) {
for (BasicBlock::const_iterator I = BB->begin(), E = BB->end(); I!=E;++I){
for (User::const_op_iterator OI = I->op_begin(), E = I->op_end();
OI != E; ++OI)
- EnumerateType((*OI)->getType());
+ EnumerateOperandType(*OI);
EnumerateType(I->getType());
}
}
@@ -226,6 +226,22 @@ void ValueEnumerator::EnumerateType(const Type *Ty) {
EnumerateParamAttrs(FTy->getParamAttrs());
}
+// Enumerate the types for the specified value. If the value is a constant,
+// walk through it, enumerating the types of the constant.
+void ValueEnumerator::EnumerateOperandType(const Value *V) {
+ EnumerateType(V->getType());
+ if (const Constant *C = dyn_cast<Constant>(V)) {
+ // If this constant is already enumerated, ignore it, we know its type must
+ // be enumerated.
+ if (ValueMap.count(V)) return;
+
+ // This constant may have operands, make sure to enumerate the types in
+ // them.
+ for (unsigned i = 0, e = C->getNumOperands(); i != e; ++i)
+ EnumerateOperandType(C->getOperand(i));
+ }
+}
+
void ValueEnumerator::EnumerateParamAttrs(const ParamAttrsList *PAL) {
if (PAL == 0) return; // null is always 0.
// Do a lookup.
diff --git a/lib/Bitcode/Writer/ValueEnumerator.h b/lib/Bitcode/Writer/ValueEnumerator.h
index 1e8e8e8..e255411 100644
--- a/lib/Bitcode/Writer/ValueEnumerator.h
+++ b/lib/Bitcode/Writer/ValueEnumerator.h
@@ -114,6 +114,7 @@ private:
void EnumerateValue(const Value *V);
void EnumerateType(const Type *T);
+ void EnumerateOperandType(const Value *V);
void EnumerateParamAttrs(const ParamAttrsList *PAL);
void EnumerateTypeSymbolTable(const TypeSymbolTable &ST);