From 2e6452ca0ce5b5e5612059cc13c7ec28cc30e6ec Mon Sep 17 00:00:00 2001 From: Ted Kremenek Date: Wed, 7 Nov 2007 18:24:34 +0000 Subject: [PATCH] Implemented serialization of signed integers. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@43828 91177308-0d34-0410-b5e6-96231b3b80d8 --- include/llvm/Bitcode/Deserialize.h | 2 ++ include/llvm/Bitcode/Serialization.h | 5 +++++ include/llvm/Bitcode/Serialize.h | 4 +++- lib/Bitcode/Reader/Deserialize.cpp | 15 +++++++++++++++ lib/Bitcode/Writer/Serialize.cpp | 17 ++++++++++++++++- 5 files changed, 41 insertions(+), 2 deletions(-) diff --git a/include/llvm/Bitcode/Deserialize.h b/include/llvm/Bitcode/Deserialize.h index 41347b5ca7f..9808a152c0b 100644 --- a/include/llvm/Bitcode/Deserialize.h +++ b/include/llvm/Bitcode/Deserialize.h @@ -95,6 +95,8 @@ public: ~Deserializer(); uint64_t ReadInt(); + int64_t ReadSInt(); + bool ReadBool() { return ReadInt() ? true : false; } diff --git a/include/llvm/Bitcode/Serialization.h b/include/llvm/Bitcode/Serialization.h index 2e738b0ed37..31220a6ec3d 100644 --- a/include/llvm/Bitcode/Serialization.h +++ b/include/llvm/Bitcode/Serialization.h @@ -50,6 +50,11 @@ SERIALIZE_INT_TRAIT(unsigned char) SERIALIZE_INT_TRAIT(unsigned short) SERIALIZE_INT_TRAIT(unsigned int) SERIALIZE_INT_TRAIT(unsigned long) + +SERIALIZE_INT_TRAIT(signed char) +SERIALIZE_INT_TRAIT(signed short) +SERIALIZE_INT_TRAIT(signed int) +SERIALIZE_INT_TRAIT(signed long) #undef SERIALIZE_INT_TRAIT diff --git a/include/llvm/Bitcode/Serialize.h b/include/llvm/Bitcode/Serialize.h index d73a92c59a0..8431898deb4 100644 --- a/include/llvm/Bitcode/Serialize.h +++ b/include/llvm/Bitcode/Serialize.h @@ -37,7 +37,9 @@ public: template inline void Emit(const T& X) { SerializeTrait::Emit(*this,X); } - void EmitInt(unsigned X); + void EmitInt(uint64_t X); + void EmitSInt(int64_t X); + void EmitBool(bool X) { EmitInt(X); } void EmitCStr(const char* beg, const char* end); void EmitCStr(const char* cstr); diff --git a/lib/Bitcode/Reader/Deserialize.cpp b/lib/Bitcode/Reader/Deserialize.cpp index d4ed26b380a..99cb5d2e3ab 100644 --- a/lib/Bitcode/Reader/Deserialize.cpp +++ b/lib/Bitcode/Reader/Deserialize.cpp @@ -105,6 +105,12 @@ uint64_t Deserializer::ReadInt() { return Record[RecIdx++]; } +int64_t Deserializer::ReadSInt() { + uint64_t x = ReadInt(); + int64_t magnitude = x >> 1; + return x & 0x1 ? -magnitude : magnitude; +} + char* Deserializer::ReadCStr(char* cstr, unsigned MaxLen, bool isNullTerm) { if (cstr == NULL) MaxLen = 0; // Zero this just in case someone does something funny. @@ -226,3 +232,12 @@ INT_READ(unsigned char) INT_READ(unsigned short) INT_READ(unsigned int) INT_READ(unsigned long) + +#define SINT_READ(TYPE)\ +void SerializeTrait::Read(Deserializer& D, TYPE& X) {\ + X = (TYPE) D.ReadSInt(); } + +INT_READ(signed char) +INT_READ(signed short) +INT_READ(signed int) +INT_READ(signed long) diff --git a/lib/Bitcode/Writer/Serialize.cpp b/lib/Bitcode/Writer/Serialize.cpp index 4395b90a89d..b97462b629e 100644 --- a/lib/Bitcode/Writer/Serialize.cpp +++ b/lib/Bitcode/Writer/Serialize.cpp @@ -48,11 +48,18 @@ void Serializer::ExitBlock() { Stream.ExitBlock(); } -void Serializer::EmitInt(unsigned X) { +void Serializer::EmitInt(uint64_t X) { assert (BlockLevel > 0); Record.push_back(X); } +void Serializer::EmitSInt(int64_t X) { + if (X >= 0) + EmitInt(X << 1); + else + EmitInt((-X << 1) | 1); +} + void Serializer::EmitCStr(const char* s, const char* end) { Record.push_back(end - s); @@ -91,3 +98,11 @@ INT_EMIT(unsigned char) INT_EMIT(unsigned short) INT_EMIT(unsigned int) INT_EMIT(unsigned long) + +#define SINT_EMIT(TYPE)\ +void SerializeTrait::Emit(Serializer&S, TYPE X) { S.EmitSInt(X); } + +SINT_EMIT(signed char) +SINT_EMIT(signed short) +SINT_EMIT(signed int) +SINT_EMIT(signed long)