From 14ac17e2dfa9cf66dec0da3618badf87163c9bf9 Mon Sep 17 00:00:00 2001 From: Ted Kremenek Date: Mon, 5 Nov 2007 20:47:27 +0000 Subject: [PATCH] Added default creation of root-level block by bitstream serializer. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@43732 91177308-0d34-0410-b5e6-96231b3b80d8 --- include/llvm/Bitcode/Serialize.h | 2 +- lib/Bitcode/Reader/Deserialize.cpp | 25 ++++++++++++++++++++++--- 2 files changed, 23 insertions(+), 4 deletions(-) diff --git a/include/llvm/Bitcode/Serialize.h b/include/llvm/Bitcode/Serialize.h index 197ab9f33d6..a465beca9d4 100644 --- a/include/llvm/Bitcode/Serialize.h +++ b/include/llvm/Bitcode/Serialize.h @@ -31,7 +31,7 @@ class Serializer { MapTy PtrMap; public: - Serializer(BitstreamWriter& stream, unsigned BlockID = 0); + Serializer(BitstreamWriter& stream, unsigned BlockID = 8); ~Serializer(); diff --git a/lib/Bitcode/Reader/Deserialize.cpp b/lib/Bitcode/Reader/Deserialize.cpp index 0482b1f7e99..31d180ff32e 100644 --- a/lib/Bitcode/Reader/Deserialize.cpp +++ b/lib/Bitcode/Reader/Deserialize.cpp @@ -47,9 +47,28 @@ void Deserializer::ReadRecord() { // FIXME: Check if we haven't run off the edge of the stream. // FIXME: Handle abbreviations. - // FIXME: Check for the correct code. - unsigned Code = Stream.ReadCode(); + unsigned Code; + while (true) { + + Code = Stream.ReadCode(); + + if (Code == bitc::ENTER_SUBBLOCK) { + // No known subblocks, always skip them. + unsigned id = Stream.ReadSubBlockID(); + Stream.EnterSubBlock(id); + continue; + } + + if (Code == bitc::END_BLOCK) { + bool x = Stream.ReadBlockEnd(); + assert (!x && "Error at block end."); + continue; + } + + break; + } + assert (Record.size() == 0); Stream.ReadRecord(Code,Record); assert (Record.size() > 0); @@ -141,7 +160,7 @@ uintptr_t Deserializer::ReadInternalRefPtr() { MapTy::value_type& E = BPatchMap.FindAndConstruct(BPKey(PtrId)); - assert (!HasFinalPtr(E) && + assert (HasFinalPtr(E) && "Cannot backpatch references. Object must be already deserialized."); return GetFinalPtr(E);