aboutsummaryrefslogtreecommitdiff
path: root/lib/Bytecode/Reader
diff options
context:
space:
mode:
authorChris Lattner <sabre@nondot.org>2004-01-20 00:54:06 +0000
committerChris Lattner <sabre@nondot.org>2004-01-20 00:54:06 +0000
commit52f86d624722a0ecedf0556a58460111bc1cccf2 (patch)
treeacd4993787e23e1e845a28e1585386eb25de8f42 /lib/Bytecode/Reader
parent54111c49bf0552a5c598b60dda0835ef4a73646b (diff)
Bugfixes for dealing with partially compactified functions
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@10920 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'lib/Bytecode/Reader')
-rw-r--r--lib/Bytecode/Reader/Reader.cpp25
1 files changed, 19 insertions, 6 deletions
diff --git a/lib/Bytecode/Reader/Reader.cpp b/lib/Bytecode/Reader/Reader.cpp
index f4b620ed19..dca8890205 100644
--- a/lib/Bytecode/Reader/Reader.cpp
+++ b/lib/Bytecode/Reader/Reader.cpp
@@ -120,17 +120,29 @@ Value *BytecodeParser::getValue(unsigned type, unsigned oNum, bool Create) {
return CompactionTable[type][Num];
Num -= CompactionTable[type].size();
} else {
+ // If the type plane was compactified, figure out the global type ID.
+ unsigned GlobalTyID = type;
+ if (CompactionTable.size() > Type::TypeTyID &&
+ !CompactionTable[Type::TypeTyID].empty() &&
+ type >= Type::FirstDerivedTyID) {
+ std::vector<Value*> &TypePlane = CompactionTable[Type::TypeTyID];
+ const Type *Ty = cast<Type>(TypePlane[type-Type::FirstDerivedTyID]);
+ TypeValuesListTy::iterator I =
+ find(ModuleTypeValues.begin(), ModuleTypeValues.end(), Ty);
+ assert(I != ModuleTypeValues.end());
+ GlobalTyID = Type::FirstDerivedTyID + (&*I - &ModuleTypeValues[0]);
+ }
- if (hasImplicitNull(type, hasExplicitPrimitiveZeros)) {
+ if (hasImplicitNull(GlobalTyID, hasExplicitPrimitiveZeros)) {
if (Num == 0)
return Constant::getNullValue(getType(type));
--Num;
}
- if (type < ModuleValues.size() && ModuleValues[type]) {
- if (Num < ModuleValues[type]->size())
- return ModuleValues[type]->getOperand(Num);
- Num -= ModuleValues[type]->size();
+ if (GlobalTyID < ModuleValues.size() && ModuleValues[GlobalTyID]) {
+ if (Num < ModuleValues[GlobalTyID]->size())
+ return ModuleValues[GlobalTyID]->getOperand(Num);
+ Num -= ModuleValues[GlobalTyID]->size();
}
}
@@ -290,7 +302,8 @@ void BytecodeParser::ParseSymbolTable(const unsigned char *&Buf,
} else {
V = getValue(Typ, slot, false); // Find mapping...
}
- if (V == 0) throw std::string("Failed value look-up.");
+ if (V == 0)
+ throw std::string("Failed value look-up.");
BCR_TRACE(4, "Map: '" << Name << "' to #" << slot << ":" << *V;
if (!isa<Instruction>(V)) std::cerr << "\n");