Fix the order of destructors in LibLTOCodeGenerator
authorSteven Wu <stevenwu@apple.com>
Wed, 9 Dec 2015 03:37:51 +0000 (03:37 +0000)
committerSteven Wu <stevenwu@apple.com>
Wed, 9 Dec 2015 03:37:51 +0000 (03:37 +0000)
Summary:
The order of destructors in LTOCodeGenerator gets changed in r254696.
It is possible for LTOCodeGenerator to have a MergedModule created in
the OwnedContext, in which case the module must be destructed before
the context.

Reviewers: rafael, dexonsmith

Subscribers: llvm-commits, joker.eph

Differential Revision: http://reviews.llvm.org/D15346

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

include/llvm/LTO/LTOCodeGenerator.h
tools/lto/lto.cpp

index 876defbdcd3f929f1d0238a1bd99c9eb12b95057..8a79e6044f5b294e77065eed3c343f5adefd8c50 100644 (file)
@@ -148,6 +148,8 @@ struct LTOCodeGenerator {
 
   LLVMContext &getContext() { return Context; }
 
+  void resetMergedModule() { MergedModule.reset(); }
+
 private:
   void initializeLTOPasses();
 
index d13de57e830c135c37de060b9f0d42620081e3e9..d8f99c050a34caf43bc1469394925b6f45b5eb61 100644 (file)
@@ -124,6 +124,10 @@ struct LibLTOCodeGenerator : LTOCodeGenerator {
       : LTOCodeGenerator(*Context), OwnedContext(std::move(Context)) {
     setDiagnosticHandler(handleLibLTODiagnostic, nullptr); }
 
+  // Reset the module first in case MergedModule is created in OwnedContext.
+  // Module must be destructed before its context gets destructed.
+  ~LibLTOCodeGenerator() { resetMergedModule(); }
+
   std::unique_ptr<MemoryBuffer> NativeObjectFile;
   std::unique_ptr<LLVMContext> OwnedContext;
 };