[llvm-commits] CVS: llvm/lib/Bytecode/Reader/Reader.cpp ReaderInternals.h
Chris Lattner
lattner at cs.uiuc.edu
Thu Mar 6 11:56:01 PST 2003
Changes in directory llvm/lib/Bytecode/Reader:
Reader.cpp updated: 1.46 -> 1.47
ReaderInternals.h updated: 1.31 -> 1.32
---
Log message:
Infrastructure for more compact bytecode files and REAL support for versioning
---
Diffs of the changes:
Index: llvm/lib/Bytecode/Reader/Reader.cpp
diff -u llvm/lib/Bytecode/Reader/Reader.cpp:1.46 llvm/lib/Bytecode/Reader/Reader.cpp:1.47
--- llvm/lib/Bytecode/Reader/Reader.cpp:1.46 Thu Mar 6 11:18:14 2003
+++ llvm/lib/Bytecode/Reader/Reader.cpp Thu Mar 6 11:55:45 2003
@@ -60,8 +60,12 @@
if (getTypeSlot(Val->getType(), type)) return -1;
assert(type != Type::TypeTyID && "Types should never be insertValue'd!");
- if (ValueTab.size() <= type)
- ValueTab.resize(type+1, ValueList());
+ while (ValueTab.size() <= type) {
+ ValueTab.push_back(ValueList());
+ if (HasImplicitZeroInitializer) // add a zero initializer if appropriate
+ ValueTab.back().push_back(
+ Constant::getNullValue(getType(ValueTab.size()-1)));
+ }
//cerr << "insertValue Values[" << type << "][" << ValueTab[type].size()
// << "] = " << Val << "\n";
@@ -194,8 +198,7 @@
while (Buf < EndBuf) {
Instruction *Inst;
- if (ParseInstruction(Buf, EndBuf, Inst,
- /*HACK*/BB)) {
+ if (ParseInstruction(Buf, EndBuf, Inst, /*HACK*/BB)) {
delete BB;
return true;
}
@@ -490,6 +493,38 @@
return false;
}
+bool BytecodeParser::ParseVersionInfo(const uchar *&Buf, const uchar *EndBuf) {
+ unsigned Version;
+ if (read_vbr(Buf, EndBuf, Version)) return true;
+
+ // Unpack version number: low four bits are for flags, top bits = version
+ isBigEndian = Version & 1;
+ hasLongPointers = Version & 2;
+ RevisionNum = Version >> 4;
+ HasImplicitZeroInitializer = true;
+
+ switch (RevisionNum) {
+ case 0: // Initial revision
+ if (Version != 14) return true; // Unknown revision 0 flags?
+ FirstDerivedTyID = 14;
+ HasImplicitZeroInitializer = false;
+ isBigEndian = hasLongPointers = true;
+ break;
+ case 1:
+ FirstDerivedTyID = 14;
+ break;
+ default:
+ Error = "Unknown bytecode version number!";
+ return true;
+ }
+
+ BCR_TRACE(1, "Bytecode Rev = " << (unsigned)RevisionNum << "\n");
+ BCR_TRACE(1, "BigEndian/LongPointers = " << isBigEndian << ","
+ << hasLongPointers << "\n");
+ BCR_TRACE(1, "HasImplicitZeroInit = " << HasImplicitZeroInitializer << "\n");
+ return false;
+}
+
bool BytecodeParser::ParseModule(const uchar *Buf, const uchar *EndBuf) {
unsigned Type, Size;
if (readBlock(Buf, EndBuf, Type, Size)) return true;
@@ -502,9 +537,8 @@
FunctionSignatureList.clear(); // Just in case...
// Read into instance variables...
- if (read_vbr(Buf, EndBuf, FirstDerivedTyID)) return true;
+ if (ParseVersionInfo(Buf, EndBuf)) return true;
if (align32(Buf, EndBuf)) return true;
- BCR_TRACE(1, "FirstDerivedTyID = " << FirstDerivedTyID << "\n");
while (Buf < EndBuf) {
const unsigned char *OldBuf = Buf;
Index: llvm/lib/Bytecode/Reader/ReaderInternals.h
diff -u llvm/lib/Bytecode/Reader/ReaderInternals.h:1.31 llvm/lib/Bytecode/Reader/ReaderInternals.h:1.32
--- llvm/lib/Bytecode/Reader/ReaderInternals.h:1.31 Thu Mar 6 11:18:14 2003
+++ llvm/lib/Bytecode/Reader/ReaderInternals.h Thu Mar 6 11:55:45 2003
@@ -57,6 +57,12 @@
private: // All of this data is transient across calls to ParseBytecode
Module *TheModule; // Current Module being read into...
+ // Information about the module, extracted from the bytecode revision number.
+ unsigned char RevisionNum; // The rev # itself
+ unsigned char FirstDerivedTyID; // First variable index to use for type
+ bool HasImplicitZeroInitializer; // Is entry 0 of every slot implicity zeros?
+ bool isBigEndian, hasLongPointers;// Information about the target compiled for
+
typedef std::vector<Value *> ValueList;
typedef std::vector<ValueList> ValueTable;
ValueTable Values, LateResolveValues;
@@ -78,9 +84,6 @@
TypeValuesListTy ModuleTypeValues;
TypeValuesListTy FunctionTypeValues;
- // Information read from the ModuleGlobalInfo section of the file...
- unsigned FirstDerivedTyID;
-
// When the ModuleGlobalInfo section is read, we load the type of each
// function and the 'ModuleValues' slot that it lands in. We then load a
// placeholder into its slot to reserve it. When the function is loaded, this
@@ -90,6 +93,7 @@
private:
bool ParseModule (const uchar * Buf, const uchar *End);
+ bool ParseVersionInfo (const uchar *&Buf, const uchar *End);
bool ParseModuleGlobalInfo(const uchar *&Buf, const uchar *End);
bool ParseSymbolTable (const uchar *&Buf, const uchar *End, SymbolTable *);
bool ParseFunction (const uchar *&Buf, const uchar *End);
More information about the llvm-commits
mailing list