diff options
Diffstat (limited to 'lib/Bytecode/Writer')
-rw-r--r-- | lib/Bytecode/Writer/SlotCalculator.cpp | 13 | ||||
-rw-r--r-- | lib/Bytecode/Writer/Writer.cpp | 11 |
2 files changed, 19 insertions, 5 deletions
diff --git a/lib/Bytecode/Writer/SlotCalculator.cpp b/lib/Bytecode/Writer/SlotCalculator.cpp index 85ccad58c5..3a038cd449 100644 --- a/lib/Bytecode/Writer/SlotCalculator.cpp +++ b/lib/Bytecode/Writer/SlotCalculator.cpp @@ -89,6 +89,12 @@ void SlotCalculator::processModule() { I != E; ++I) CreateSlotIfNeeded(I); + // Add all of the global aliases to the value table... + // + for (Module::const_alias_iterator I = TheModule->alias_begin(), + E = TheModule->alias_end(); I != E; ++I) + CreateSlotIfNeeded(I); + // Add all of the module level constants used as initializers // for (Module::const_global_iterator I = TheModule->global_begin(), @@ -96,6 +102,13 @@ void SlotCalculator::processModule() { if (I->hasInitializer()) CreateSlotIfNeeded(I->getInitializer()); + // Add all of the module level constants used as aliasees + // + for (Module::const_alias_iterator I = TheModule->alias_begin(), + E = TheModule->alias_end(); I != E; ++I) + if (I->getAliasee()) + CreateSlotIfNeeded(I->getAliasee()); + // Now that all global constants have been added, rearrange constant planes // that contain constant strings so that the strings occur at the start of the // plane, not somewhere in the middle. diff --git a/lib/Bytecode/Writer/Writer.cpp b/lib/Bytecode/Writer/Writer.cpp index 7295239fdd..f1c6f6c561 100644 --- a/lib/Bytecode/Writer/Writer.cpp +++ b/lib/Bytecode/Writer/Writer.cpp @@ -1095,9 +1095,11 @@ void BytecodeWriter::outputModuleInfoBlock(const Module *M) { // Output aliases for (Module::const_alias_iterator I = M->alias_begin(), E = M->alias_end(); I != E; ++I) { - unsigned Slot = Table.getTypeSlot(I->getType()); - assert(((Slot << 2) >> 2) == Slot && "Slot # too big!"); + unsigned TypeSlotNo = Table.getTypeSlot(I->getType()); + unsigned AliaseeSlotNo = Table.getSlot(I->getAliasee()); + assert(((TypeSlotNo << 3) >> 3) == TypeSlotNo && "Slot # too big!"); unsigned aliasLinkage = 0; + unsigned isConstantAliasee = ((!isa<GlobalValue>(I->getAliasee())) << 2); switch (I->getLinkage()) { case GlobalValue::ExternalLinkage: aliasLinkage = 0; @@ -1111,9 +1113,8 @@ void BytecodeWriter::outputModuleInfoBlock(const Module *M) { default: assert(0 && "Invalid alias linkage"); } - output_vbr((Slot << 2) | aliasLinkage); - output_vbr(Table.getTypeSlot(I->getAliasee()->getType())); - output_vbr(Table.getSlot(I->getAliasee())); + output_vbr((TypeSlotNo << 3) | isConstantAliasee | aliasLinkage); + output_vbr(AliaseeSlotNo); } output_typeid(Table.getTypeSlot(Type::VoidTy)); } |