diff options
author | Chris Lattner <sabre@nondot.org> | 2004-01-17 23:25:43 +0000 |
---|---|---|
committer | Chris Lattner <sabre@nondot.org> | 2004-01-17 23:25:43 +0000 |
commit | 80b97343ec4f99644ffebdf812b79133aa38d3bd (patch) | |
tree | 2387c0edb9a33d33a9eb071cfbbe564ca4b0d767 /lib/Bytecode | |
parent | a55e040623daf71d81854dd404447f36ea1a59e7 (diff) | |
download | external_llvm-80b97343ec4f99644ffebdf812b79133aa38d3bd.zip external_llvm-80b97343ec4f99644ffebdf812b79133aa38d3bd.tar.gz external_llvm-80b97343ec4f99644ffebdf812b79133aa38d3bd.tar.bz2 |
Bytecode format for LLVM 1.2 no longer explicitly encodes zeros in primitive
type planes. This saves about 5k on 176.gcc, and is needed for a subsequent
patch of mine I'm working on.
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@10908 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'lib/Bytecode')
-rw-r--r-- | lib/Bytecode/Reader/Reader.cpp | 22 | ||||
-rw-r--r-- | lib/Bytecode/Reader/ReaderInternals.h | 10 | ||||
-rw-r--r-- | lib/Bytecode/Writer/SlotCalculator.cpp | 6 | ||||
-rw-r--r-- | lib/Bytecode/Writer/Writer.cpp | 7 |
4 files changed, 33 insertions, 12 deletions
diff --git a/lib/Bytecode/Reader/Reader.cpp b/lib/Bytecode/Reader/Reader.cpp index 9cc24b3..16b4ee0 100644 --- a/lib/Bytecode/Reader/Reader.cpp +++ b/lib/Bytecode/Reader/Reader.cpp @@ -66,10 +66,17 @@ const Type *BytecodeParser::getType(unsigned ID) { throw std::string("Illegal type reference!"); } +static inline bool hasImplicitNull(unsigned TyID, bool EncodesPrimitiveZeros) { + if (!EncodesPrimitiveZeros) + return TyID != Type::LabelTyID && TyID != Type::TypeTyID && + TyID != Type::VoidTyID; + return TyID >= Type::FirstDerivedTyID; +} + unsigned BytecodeParser::insertValue(Value *Val, unsigned type, ValueTable &ValueTab) { - assert((!isa<Constant>(Val) || Val->getType()->isPrimitiveType() || - !cast<Constant>(Val)->isNullValue()) && + assert((!isa<Constant>(Val) || !cast<Constant>(Val)->isNullValue()) || + !hasImplicitNull(type, hasExplicitPrimitiveZeros) && "Cannot read null values from bytecode!"); assert(type != Type::TypeTyID && "Types should never be insertValue'd!"); @@ -88,13 +95,12 @@ unsigned BytecodeParser::insertValue(Value *Val, unsigned type, return ValueTab[type]->size()-1 + HasOffset; } - Value *BytecodeParser::getValue(unsigned type, unsigned oNum, bool Create) { assert(type != Type::TypeTyID && "getValue() cannot get types!"); assert(type != Type::LabelTyID && "getValue() cannot get blocks!"); unsigned Num = oNum; - if (type >= FirstDerivedTyID) { + if (hasImplicitNull(type, hasExplicitPrimitiveZeros)) { if (Num == 0) return Constant::getNullValue(getType(type)); --Num; @@ -536,6 +542,7 @@ void BytecodeParser::ParseVersionInfo(const unsigned char *&Buf, hasOldStyleVarargs = false; hasVarArgCallPadding = false; hasInconsistentModuleGlobalInfo = false; + hasExplicitPrimitiveZeros = false; FirstDerivedTyID = 14; switch (RevisionNum) { @@ -545,16 +552,15 @@ void BytecodeParser::ParseVersionInfo(const unsigned char *&Buf, hasExtendedLinkageSpecs = false; hasOldStyleVarargs = true; hasVarArgCallPadding = true; - hasInconsistentModuleGlobalInfo = true; - - break; + // FALL THROUGH case 0: // LLVM 1.0, 1.1 release version // Compared to rev #2, we added support for weak linkage, a more dense // encoding, and better varargs support. // Base LLVM 1.0 bytecode format. hasInconsistentModuleGlobalInfo = true; - break; + hasExplicitPrimitiveZeros = true; + // FALL THROUGH case 1: // LLVM 1.2 release version // LLVM 1.2 added explicit support for emitting strings efficiently. diff --git a/lib/Bytecode/Reader/ReaderInternals.h b/lib/Bytecode/Reader/ReaderInternals.h index d6a934d..4c0b310 100644 --- a/lib/Bytecode/Reader/ReaderInternals.h +++ b/lib/Bytecode/Reader/ReaderInternals.h @@ -97,10 +97,16 @@ private: bool usesOldStyleVarargs; // Does this module USE old style varargs? - // LLVM 1.0 & 1.1 had an explicit alignment of data only for the - // ModuleGlobalInfo block. This was fixed to be like all other blocks in 1.2 + // Flags to distinguish LLVM 1.0 & 1.1 bytecode formats (revision #0) + + // Revision #0 had an explicit alignment of data only for the ModuleGlobalInfo + // block. This was fixed to be like all other blocks in 1.2 bool hasInconsistentModuleGlobalInfo; + // Revision #0 also explicitly encoded zero values for primitive types like + // int/sbyte/etc. + bool hasExplicitPrimitiveZeros; + typedef std::vector<ValueList*> ValueTable; ValueTable Values; ValueTable ModuleValues; diff --git a/lib/Bytecode/Writer/SlotCalculator.cpp b/lib/Bytecode/Writer/SlotCalculator.cpp index 766b000..2c6dd5e 100644 --- a/lib/Bytecode/Writer/SlotCalculator.cpp +++ b/lib/Bytecode/Writer/SlotCalculator.cpp @@ -406,6 +406,10 @@ int SlotCalculator::insertValue(const Value *D, bool dontIgnore) { return doInsertValue(D); } +static inline bool hasNullValue(unsigned TyID) { + return TyID != Type::LabelTyID && TyID != Type::TypeTyID && + TyID != Type::VoidTyID; +} // doInsertValue - This is a small helper function to be called only // be insertValue. @@ -435,7 +439,7 @@ int SlotCalculator::doInsertValue(const Value *D) { // If this is the first value to get inserted into the type plane, make sure // to insert the implicit null value... - if (Table[Ty].empty() && Ty >= Type::FirstDerivedTyID && BuildBytecodeInfo) { + if (Table[Ty].empty() && BuildBytecodeInfo && hasNullValue(Ty)) { Value *ZeroInitializer = Constant::getNullValue(Typ); // If we are pushing zeroinit, it will be handled below. diff --git a/lib/Bytecode/Writer/Writer.cpp b/lib/Bytecode/Writer/Writer.cpp index 6467921..ff9e8a9 100644 --- a/lib/Bytecode/Writer/Writer.cpp +++ b/lib/Bytecode/Writer/Writer.cpp @@ -161,6 +161,11 @@ void BytecodeWriter::outputConstantsInPlane(const std::vector<const Value*> } } +static inline bool hasNullValue(unsigned TyID) { + return TyID != Type::LabelTyID && TyID != Type::TypeTyID && + TyID != Type::VoidTyID; +} + void BytecodeWriter::outputConstants(bool isFunction) { ConstantTotalBytes -= Out.size(); if (isFunction) FunctionConstantTotalBytes -= Out.size(); @@ -190,7 +195,7 @@ void BytecodeWriter::outputConstants(bool isFunction) { if (isFunction) // Don't re-emit module constants ValNo += Table.getModuleLevel(pno); - if (pno >= Type::FirstDerivedTyID) { + if (hasNullValue(pno)) { // Skip zero initializer if (ValNo == 0) ValNo = 1; |