diff options
| author | Ted Kremenek <kremenek@apple.com> | 2007-10-25 18:42:52 +0000 |
|---|---|---|
| committer | Ted Kremenek <kremenek@apple.com> | 2007-10-25 18:42:52 +0000 |
| commit | 2423e03ca804e64998df1b65f58e62b867283c92 (patch) | |
| tree | e1972402ad068ba4e4afdadc92bcf991e4901669 | |
| parent | 2c8ca5c415b876ef816286202621b1cf2c30fcad (diff) | |
| download | external_llvm-2423e03ca804e64998df1b65f58e62b867283c92.zip external_llvm-2423e03ca804e64998df1b65f58e62b867283c92.tar.gz external_llvm-2423e03ca804e64998df1b65f58e62b867283c92.tar.bz2 | |
Added special treatment of serializing NULL pointers.
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@43357 91177308-0d34-0410-b5e6-96231b3b80d8
| -rw-r--r-- | include/llvm/Bitcode/Deserialize.h | 4 | ||||
| -rw-r--r-- | include/llvm/Bitcode/Serialize.h | 2 | ||||
| -rw-r--r-- | lib/Bitcode/Reader/Deserialize.cpp | 5 | ||||
| -rw-r--r-- | lib/Bitcode/Writer/Serialize.cpp | 5 |
4 files changed, 14 insertions, 2 deletions
diff --git a/include/llvm/Bitcode/Deserialize.h b/include/llvm/Bitcode/Deserialize.h index f5adcff..164c70a 100644 --- a/include/llvm/Bitcode/Deserialize.h +++ b/include/llvm/Bitcode/Deserialize.h @@ -86,6 +86,10 @@ public: template <typename T> inline T* ReadOwnedPtr() { unsigned PtrId = ReadInt(); + + if (PtrId == 0) + return NULL; + T* x = SerializeTrait<T>::Materialize(*this); RegisterPtr(PtrId,x); return x; diff --git a/include/llvm/Bitcode/Serialize.h b/include/llvm/Bitcode/Serialize.h index dc1fe64..72aac9d 100644 --- a/include/llvm/Bitcode/Serialize.h +++ b/include/llvm/Bitcode/Serialize.h @@ -47,7 +47,7 @@ public: template <typename T> void EmitOwnedPtr(T* ptr) { EmitPtr(ptr); - SerializeTrait<T>::Emit(*this,*ptr); + if (ptr) SerializeTrait<T>::Emit(*this,*ptr); } void Flush() { if (inRecord()) EmitRecord(); } diff --git a/lib/Bitcode/Reader/Deserialize.cpp b/lib/Bitcode/Reader/Deserialize.cpp index febb2d7..d1d6ef0 100644 --- a/lib/Bitcode/Reader/Deserialize.cpp +++ b/lib/Bitcode/Reader/Deserialize.cpp @@ -103,6 +103,11 @@ void Deserializer::RegisterPtr(unsigned PtrId,void* Ptr) { void Deserializer::ReadPtr(void*& PtrRef) { unsigned PtrId = ReadInt(); + if (PtrId == 0) { + PtrRef = NULL; + return; + } + BPatchEntry& E = BPatchMap[PtrId]; if (E.Ptr == NULL) { diff --git a/lib/Bitcode/Writer/Serialize.cpp b/lib/Bitcode/Writer/Serialize.cpp index fbe1d10..a1d7320 100644 --- a/lib/Bitcode/Writer/Serialize.cpp +++ b/lib/Bitcode/Writer/Serialize.cpp @@ -58,10 +58,13 @@ void Serializer::EmitCStr(const char* s) { } unsigned Serializer::getPtrId(void* ptr) { + if (!ptr) + return 0; + MapTy::iterator I = PtrMap.find(ptr); if (I == PtrMap.end()) { - unsigned id = PtrMap.size(); + unsigned id = PtrMap.size()+1; PtrMap[ptr] = id; return id; } |
