From: Ted Kremenek Date: Mon, 5 Nov 2007 21:36:35 +0000 (+0000) Subject: Added support in serializer and deserializer to create arbitrary blocks. X-Git-Url: http://plrg.eecs.uci.edu/git/?p=oota-llvm.git;a=commitdiff_plain;h=0a6d98e10e3b5080861bc1e06c2053d7941f319a Added support in serializer and deserializer to create arbitrary blocks. Added detection of end-of-stream in deserializer. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@43736 91177308-0d34-0410-b5e6-96231b3b80d8 --- diff --git a/include/llvm/Bitcode/Deserialize.h b/include/llvm/Bitcode/Deserialize.h index 2454dca565d..0398e434ca4 100644 --- a/include/llvm/Bitcode/Deserialize.h +++ b/include/llvm/Bitcode/Deserialize.h @@ -153,6 +153,8 @@ public: void RegisterPtr(const void* Ptr) { RegisterPtr(ReadInt(),Ptr); } + + bool AtEnd(); private: void ReadRecord(); diff --git a/include/llvm/Bitcode/Serialize.h b/include/llvm/Bitcode/Serialize.h index a465beca9d4..74637f5d87f 100644 --- a/include/llvm/Bitcode/Serialize.h +++ b/include/llvm/Bitcode/Serialize.h @@ -25,7 +25,7 @@ namespace llvm { class Serializer { BitstreamWriter& Stream; SmallVector Record; - bool inBlock; + unsigned BlockLevel; typedef DenseMap MapTy; MapTy PtrMap; @@ -56,6 +56,9 @@ public: void Flush() { if (inRecord()) EmitRecord(); } + void EnterBlock(unsigned BlockID = 8, unsigned CodeLen = 3); + void ExitBlock(); + private: void EmitRecord(); inline bool inRecord() { return Record.size() > 0; } diff --git a/lib/Bitcode/Reader/Deserialize.cpp b/lib/Bitcode/Reader/Deserialize.cpp index 31d180ff32e..ef4e4f7e000 100644 --- a/lib/Bitcode/Reader/Deserialize.cpp +++ b/lib/Bitcode/Reader/Deserialize.cpp @@ -47,10 +47,15 @@ void Deserializer::ReadRecord() { // FIXME: Check if we haven't run off the edge of the stream. // FIXME: Handle abbreviations. + assert (Record.size() == 0); + unsigned Code; while (true) { + if (Stream.AtEndOfStream()) + return; + Code = Stream.ReadCode(); if (Code == bitc::ENTER_SUBBLOCK) { @@ -71,7 +76,16 @@ void Deserializer::ReadRecord() { assert (Record.size() == 0); Stream.ReadRecord(Code,Record); - assert (Record.size() > 0); + assert (Record.size() > 0 || Stream.AtEndOfStream()); +} + +bool Deserializer::AtEnd() { + if (inRecord()) + return false; + + ReadRecord(); + + return Stream.AtEndOfStream(); } uint64_t Deserializer::ReadInt() { diff --git a/lib/Bitcode/Writer/Serialize.cpp b/lib/Bitcode/Writer/Serialize.cpp index 58baf104c7a..f25a1542d37 100644 --- a/lib/Bitcode/Writer/Serialize.cpp +++ b/lib/Bitcode/Writer/Serialize.cpp @@ -17,16 +17,17 @@ using namespace llvm; Serializer::Serializer(BitstreamWriter& stream, unsigned BlockID) - : Stream(stream), inBlock(BlockID >= 8) { + : Stream(stream), BlockLevel(0) { - if (inBlock) Stream.EnterSubblock(8,3); + if (BlockID >= 8) + EnterBlock(8,3); } Serializer::~Serializer() { if (inRecord()) EmitRecord(); - if (inBlock) + while (BlockLevel > 0) Stream.ExitBlock(); Stream.FlushToWord(); @@ -38,7 +39,21 @@ void Serializer::EmitRecord() { Record.clear(); } +void Serializer::EnterBlock(unsigned BlockID,unsigned CodeLen) { + Flush(); + Stream.EnterSubblock(BlockID,CodeLen); + ++BlockLevel; +} + +void Serializer::ExitBlock() { + assert (BlockLevel > 0); + --BlockLevel; + Flush(); + Stream.ExitBlock(); +} + void Serializer::EmitInt(unsigned X) { + assert (BlockLevel > 0); Record.push_back(X); } @@ -71,6 +86,7 @@ unsigned Serializer::getPtrId(const void* ptr) { else return I->second; } + #define INT_EMIT(TYPE)\ void SerializeTrait::Emit(Serializer&S, TYPE X) { S.EmitInt(X); }