[PATCH] D33513: [ThinLTO] Fix ThinLTO crash while destroying context
Charles Saternos via Phabricator via llvm-commits
llvm-commits at lists.llvm.org
Sat Jun 10 08:08:31 PDT 2017
ncharlie updated this revision to Diff 102117.
ncharlie added a comment.
Removed extraneous formatting.
https://reviews.llvm.org/D33513
Files:
include/llvm/IR/Metadata.h
test/ThinLTO/X86/Inputs/lazy-load-temporaries-cleanup.b.ll
test/ThinLTO/X86/lazy-load-temporaries-cleanup.ll
tools/llvm-dis/llvm-dis.cpp
Index: tools/llvm-dis/llvm-dis.cpp
===================================================================
--- tools/llvm-dis/llvm-dis.cpp
+++ tools/llvm-dis/llvm-dis.cpp
@@ -51,6 +51,9 @@
DontPrint("disable-output", cl::desc("Don't output the .ll file"), cl::Hidden);
static cl::opt<bool>
+SetImporting("set-importing", cl::desc("Set lazy loading to pretend to import a module"), cl::Hidden);
+
+static cl::opt<bool>
ShowAnnotations("show-annotations",
cl::desc("Add informational comments to the .ll file"));
@@ -144,7 +147,7 @@
ExitOnErr(errorOrToExpected(MemoryBuffer::getFileOrSTDIN(InputFilename)));
std::unique_ptr<Module> M =
ExitOnErr(getOwningLazyBitcodeModule(std::move(MB), Context,
- /*ShouldLazyLoadMetadata=*/true));
+ /*ShouldLazyLoadMetadata=*/true, SetImporting));
if (MaterializeMetadata)
ExitOnErr(M->materializeMetadata());
else
Index: test/ThinLTO/X86/lazy-load-temporaries-cleanup.ll
===================================================================
--- /dev/null
+++ test/ThinLTO/X86/lazy-load-temporaries-cleanup.ll
@@ -0,0 +1,3 @@
+; This test ensures that metadata temporaries are properly tracked, then cleaned up
+
+; RUN: opt -module-summary -bitcode-mdindex-threshold=0 %S/Inputs/lazy-load-temporaries-cleanup.b.ll | llvm-dis -materialize-metadata -set-importing
Index: test/ThinLTO/X86/Inputs/lazy-load-temporaries-cleanup.b.ll
===================================================================
--- /dev/null
+++ test/ThinLTO/X86/Inputs/lazy-load-temporaries-cleanup.b.ll
@@ -0,0 +1,11 @@
+target datalayout = "e-m:e-i64:64-f80:128-n8:16:32:64-S128"
+target triple = "x86_64-unknown-linux-gnu"
+
+define void @patatino() {
+ ret void
+}
+
+!named = !{!0}
+
+!0 = distinct !{!1, i8 0}
+!1 = !{i8 1}
Index: include/llvm/IR/Metadata.h
===================================================================
--- include/llvm/IR/Metadata.h
+++ include/llvm/IR/Metadata.h
@@ -1278,6 +1278,11 @@
if (!Use)
return;
*Use = MD;
+
+ if (*Use)
+ MetadataTracking::track(*Use);
+
+ // Equivalent to MetadataTracking::untrack
Use = nullptr;
}
};
-------------- next part --------------
A non-text attachment was scrubbed...
Name: D33513.102117.patch
Type: text/x-patch
Size: 2237 bytes
Desc: not available
URL: <http://lists.llvm.org/pipermail/llvm-commits/attachments/20170610/053a93a2/attachment.bin>
More information about the llvm-commits
mailing list