Be lazy about loading metadata in IRObjectFile.
authorRafael Espindola <rafael.espindola@gmail.com>
Fri, 13 Mar 2015 21:54:20 +0000 (21:54 +0000)
committerRafael Espindola <rafael.espindola@gmail.com>
Fri, 13 Mar 2015 21:54:20 +0000 (21:54 +0000)
This speeds up llvm-ar building lib64/libclangSema.a with debug IR files
from 8.658015807 seconds to just 0.351036519 seconds :-)

git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@232221 91177308-0d34-0410-b5e6-96231b3b80d8

include/llvm/IR/GVMaterializer.h
include/llvm/IR/Module.h
lib/Bitcode/Reader/BitcodeReader.h
lib/IR/Module.cpp
lib/Object/IRObjectFile.cpp
tools/gold/gold-plugin.cpp

index 6f57dc2a98a6abf2722cb51e2515dac3a165b3bf..ae2f2e1aefbed5f4e26e4e711baf053812c6e237 100644 (file)
@@ -53,6 +53,8 @@ public:
   ///
   virtual std::error_code MaterializeModule(Module *M) = 0;
 
+  virtual std::error_code materializeMetadata() = 0;
+
   virtual std::vector<StructType *> getIdentifiedStructTypes() const = 0;
 };
 
index 698e8747495d74035415edd9d1ad5102480d60b0..ac60c8e885e28dbcd59df6b7963410bcb6a7bbc4 100644 (file)
@@ -502,6 +502,8 @@ public:
   /// Materializer.
   std::error_code materializeAllPermanently();
 
+  std::error_code materializeMetadata();
+
 /// @}
 /// @name Direct access to the globals list, functions list, and symbol table
 /// @{
index 0a69148d84da92f6dcb776eb29cd98fbfbb61a7f..27e8b2e2111df96d05490ee73fa4a90311818a09 100644 (file)
@@ -255,7 +255,7 @@ public:
   static uint64_t decodeSignRotatedValue(uint64_t V);
 
   /// Materialize any deferred Metadata block.
-  std::error_code materializeMetadata();
+  std::error_code materializeMetadata() override;
 
 private:
   std::vector<StructType *> IdentifiedStructTypes;
index 3a88db9754af26aa511cd3e4ea6d74eda3d351d4..3e8f91fee743a94ac001bf05ee4839598bb9b8e1 100644 (file)
@@ -413,6 +413,12 @@ std::error_code Module::materializeAllPermanently() {
   return std::error_code();
 }
 
+std::error_code Module::materializeMetadata() {
+  if (!Materializer)
+    return std::error_code();
+  return Materializer->materializeMetadata();
+}
+
 //===----------------------------------------------------------------------===//
 // Other module related stuff.
 //
index 6369d8befd1e2ebed54e5d6cfa6e5eaf05aae986..58c4ca312e89e6ffa099bc5d6f00a5e6dd932598 100644 (file)
@@ -300,7 +300,9 @@ llvm::object::IRObjectFile::create(MemoryBufferRef Object,
   std::unique_ptr<MemoryBuffer> Buff(
       MemoryBuffer::getMemBuffer(BCOrErr.get(), false));
 
-  ErrorOr<Module *> MOrErr = getLazyBitcodeModule(std::move(Buff), Context);
+  ErrorOr<Module *> MOrErr =
+      getLazyBitcodeModule(std::move(Buff), Context, nullptr,
+                           /*ShouldLazyLoadMetadata*/ true);
   if (std::error_code EC = MOrErr.getError())
     return EC;
 
index f7379ea314abd600b634a22ef82412d8faaae691..8decc8ea6d549832cbd048ba7478844d4eac305e 100644 (file)
@@ -598,6 +598,7 @@ getModuleForFile(LLVMContext &Context, claimed_file &F,
 
   Module &M = Obj.getModule();
 
+  M.materializeMetadata();
   UpgradeDebugInfo(M);
 
   SmallPtrSet<GlobalValue *, 8> Used;