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 | a83e6bc246410644cd17f34df93746d69abbfffc (patch) | |
| tree | a427be93f9ac16a512ae396fb67e4da0ec2a981c /llvm | |
| parent | 5a381083745cba01cdd49558d0f416989eb943d2 (diff) | |
| download | bcm5719-llvm-a83e6bc246410644cd17f34df93746d69abbfffc.tar.gz bcm5719-llvm-a83e6bc246410644cd17f34df93746d69abbfffc.zip | |
Added special treatment of serializing NULL pointers.
llvm-svn: 43357
Diffstat (limited to 'llvm')
| -rw-r--r-- | llvm/include/llvm/Bitcode/Deserialize.h | 4 | ||||
| -rw-r--r-- | llvm/include/llvm/Bitcode/Serialize.h | 2 | ||||
| -rw-r--r-- | llvm/lib/Bitcode/Reader/Deserialize.cpp | 5 | ||||
| -rw-r--r-- | llvm/lib/Bitcode/Writer/Serialize.cpp | 5 |
4 files changed, 14 insertions, 2 deletions
diff --git a/llvm/include/llvm/Bitcode/Deserialize.h b/llvm/include/llvm/Bitcode/Deserialize.h index f5adcffe25c..164c70a9af6 100644 --- a/llvm/include/llvm/Bitcode/Deserialize.h +++ b/llvm/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/llvm/include/llvm/Bitcode/Serialize.h b/llvm/include/llvm/Bitcode/Serialize.h index dc1fe646f22..72aac9d0ba4 100644 --- a/llvm/include/llvm/Bitcode/Serialize.h +++ b/llvm/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/llvm/lib/Bitcode/Reader/Deserialize.cpp b/llvm/lib/Bitcode/Reader/Deserialize.cpp index febb2d7cafc..d1d6ef098f7 100644 --- a/llvm/lib/Bitcode/Reader/Deserialize.cpp +++ b/llvm/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/llvm/lib/Bitcode/Writer/Serialize.cpp b/llvm/lib/Bitcode/Writer/Serialize.cpp index fbe1d1007c9..a1d732047a6 100644 --- a/llvm/lib/Bitcode/Writer/Serialize.cpp +++ b/llvm/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; } |

