mirror of
https://github.com/RPCSX/llvm.git
synced 2025-04-03 00:31:49 +00:00
Materialize metadata in IRLinker before value mapping
Summary: Unless we plan to do later postpass metadata linking (ThinLTO special mode), always invoke metadata materialization at the start of IRLinker::run(). This avoids the need for clients who use lazy metadata loading to explicitly invoke materializeMetadata before the IRMover, which in turn invokes IRLinker::run and needs materialized metadata for mapping. Came up in the context of an LLD issue (D17982). Reviewers: rafael Subscribers: silvas, llvm-commits Differential Revision: http://reviews.llvm.org/D17992 git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@263143 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
07f1262d8a
commit
b738b28f97
@ -1492,6 +1492,11 @@ static std::string mergeTriples(const Triple &SrcTriple,
|
||||
}
|
||||
|
||||
bool IRLinker::run() {
|
||||
// Ensure metadata materialized before value mapping.
|
||||
if (shouldLinkMetadata() && SrcM->getMaterializer())
|
||||
if (SrcM->getMaterializer()->materializeMetadata())
|
||||
return true;
|
||||
|
||||
// Inherit the target data from the source module if the destination module
|
||||
// doesn't have one already.
|
||||
if (DstM.getDataLayout().isDefault())
|
||||
@ -1559,13 +1564,9 @@ bool IRLinker::run() {
|
||||
// Even if just linking metadata we should link decls above in case
|
||||
// any are referenced by metadata. IRLinker::shouldLink ensures that
|
||||
// we don't actually link anything from source.
|
||||
if (IsMetadataLinkingPostpass) {
|
||||
// Ensure metadata materialized
|
||||
if (SrcM->getMaterializer()->materializeMetadata())
|
||||
return true;
|
||||
if (IsMetadataLinkingPostpass)
|
||||
SrcM->getMaterializer()->saveMetadataList(MetadataToIDs,
|
||||
/* OnlyTempMD = */ false);
|
||||
}
|
||||
|
||||
linkNamedMDNodes();
|
||||
|
||||
|
Loading…
x
Reference in New Issue
Block a user