Revert "Compact InputSectionData from 64 to 48 bytes. NFC."
authorRafael Espindola <rafael.espindola@gmail.com>
Fri, 9 Sep 2016 21:20:30 +0000 (21:20 +0000)
committerRafael Espindola <rafael.espindola@gmail.com>
Fri, 9 Sep 2016 21:20:30 +0000 (21:20 +0000)
This reverts commit r281084.

The link was failing on some bots. No idea why. I will try to
reproduce it on Monday.

llvm-svn: 281096

lld/ELF/InputSection.cpp
lld/ELF/InputSection.h

index 55a3905..01d97ed 100644 (file)
@@ -50,8 +50,8 @@ template <class ELFT> size_t InputSectionBase<ELFT>::getSize() const {
 template <class ELFT>
 ArrayRef<uint8_t> InputSectionBase<ELFT>::getSectionData() const {
   if (Compressed)
-    return ArrayRef<uint8_t>((const uint8_t *)UncompressedData.get(),
-                             UncompressedDataSize);
+    return ArrayRef<uint8_t>((const uint8_t *)Uncompressed.data(),
+                             Uncompressed.size());
   return check(this->File->getObj().getSectionContents(this->Header));
 }
 
@@ -106,10 +106,7 @@ template <class ELFT> void InputSectionBase<ELFT>::uncompress() {
     fatal(getName(this) + ": unsupported compression type");
 
   StringRef Buf((const char *)Data.data(), Data.size());
-  UncompressedDataSize = Hdr->ch_size;
-  UncompressedData.reset(new char[UncompressedDataSize]);
-  if (zlib::uncompress(Buf, UncompressedData.get(), UncompressedDataSize) !=
-      zlib::StatusOK)
+  if (zlib::uncompress(Buf, Uncompressed, Hdr->ch_size) != zlib::StatusOK)
     fatal(getName(this) + ": error uncompressing section");
 }
 
index 23e3a54..f11dc67 100644 (file)
@@ -61,9 +61,8 @@ public:
 
   StringRef Name;
 
-  // If a section is compressed, this has the uncompressed section data.
-  std::unique_ptr<char[]> UncompressedData;
-  size_t UncompressedDataSize = 0;
+  // If a section is compressed, this vector has uncompressed section data.
+  SmallVector<char, 0> Uncompressed;
 
   std::vector<Relocation> Relocations;
 };