[llvm] r364253 - DataExtractor: use decodeSLEB128 to implement getSLEB128
David Blaikie via llvm-commits
llvm-commits at lists.llvm.org
Mon Jun 24 16:45:19 PDT 2019
Author: dblaikie
Date: Mon Jun 24 16:45:18 2019
New Revision: 364253
URL: http://llvm.org/viewvc/llvm-project?rev=364253&view=rev
Log:
DataExtractor: use decodeSLEB128 to implement getSLEB128
Should've been NFC, but turns out DataExtractor had better test coverage
for decoding SLEB128 than the decodeSLEB128 did - revealing a couple of
bugs (one in the error handling, another in sign extension). So fixed
those to get the DataExtractor tests passing again.
Modified:
llvm/trunk/include/llvm/Support/LEB128.h
llvm/trunk/lib/Support/DataExtractor.cpp
Modified: llvm/trunk/include/llvm/Support/LEB128.h
URL: http://llvm.org/viewvc/llvm-project/llvm/trunk/include/llvm/Support/LEB128.h?rev=364253&r1=364252&r2=364253&view=diff
==============================================================================
--- llvm/trunk/include/llvm/Support/LEB128.h (original)
+++ llvm/trunk/include/llvm/Support/LEB128.h Mon Jun 24 16:45:18 2019
@@ -165,6 +165,8 @@ inline int64_t decodeSLEB128(const uint8
int64_t Value = 0;
unsigned Shift = 0;
uint8_t Byte;
+ if (error)
+ *error = nullptr;
do {
if (end && p == end) {
if (error)
@@ -177,8 +179,8 @@ inline int64_t decodeSLEB128(const uint8
Value |= (int64_t(Byte & 0x7f) << Shift);
Shift += 7;
} while (Byte >= 128);
- // Sign extend negative numbers.
- if (Byte & 0x40)
+ // Sign extend negative numbers if needed.
+ if (Shift < 64 && (Byte & 0x40))
Value |= (-1ULL) << Shift;
if (n)
*n = (unsigned)(p - orig_p);
Modified: llvm/trunk/lib/Support/DataExtractor.cpp
URL: http://llvm.org/viewvc/llvm-project/llvm/trunk/lib/Support/DataExtractor.cpp?rev=364253&r1=364252&r2=364253&view=diff
==============================================================================
--- llvm/trunk/lib/Support/DataExtractor.cpp (original)
+++ llvm/trunk/lib/Support/DataExtractor.cpp Mon Jun 24 16:45:18 2019
@@ -160,26 +160,15 @@ uint64_t DataExtractor::getULEB128(uint3
}
int64_t DataExtractor::getSLEB128(uint32_t *offset_ptr) const {
- int64_t result = 0;
- if (Data.empty())
- return 0;
-
- unsigned shift = 0;
- uint32_t offset = *offset_ptr;
- uint8_t byte = 0;
+ assert(*offset_ptr <= Data.size());
- while (isValidOffset(offset)) {
- byte = Data[offset++];
- result |= uint64_t(byte & 0x7f) << shift;
- shift += 7;
- if ((byte & 0x80) == 0) {
- // Sign bit of byte is 2nd high order bit (0x40)
- if (shift < 64 && (byte & 0x40))
- result |= -(1ULL << shift);
-
- *offset_ptr = offset;
- return result;
- }
- }
- return 0;
+ const char *error;
+ unsigned bytes_read;
+ int64_t result = decodeSLEB128(
+ reinterpret_cast<const uint8_t *>(Data.data() + *offset_ptr), &bytes_read,
+ reinterpret_cast<const uint8_t *>(Data.data() + Data.size()), &error);
+ if (error)
+ return 0;
+ *offset_ptr += bytes_read;
+ return result;
}
More information about the llvm-commits
mailing list