diff options
author | Devang Patel <dpatel@apple.com> | 2009-08-11 18:01:24 +0000 |
---|---|---|
committer | Devang Patel <dpatel@apple.com> | 2009-08-11 18:01:24 +0000 |
commit | 5c310be0ff7b5230b8672ad5b3a6c4eab01d0c8a (patch) | |
tree | bd151029d3117e50d7a09b7635336af3147721f5 | |
parent | 50c09d0ca314f7e1f78564f715237d8c4c00fbad (diff) | |
download | bcm5719-llvm-5c310be0ff7b5230b8672ad5b3a6c4eab01d0c8a.tar.gz bcm5719-llvm-5c310be0ff7b5230b8672ad5b3a6c4eab01d0c8a.zip |
Link NamedMDNodes.
llvm-svn: 78696
-rw-r--r-- | llvm/include/llvm/Metadata.h | 2 | ||||
-rw-r--r-- | llvm/lib/Linker/LinkModules.cpp | 19 | ||||
-rw-r--r-- | llvm/lib/VMCore/Metadata.cpp | 9 | ||||
-rw-r--r-- | llvm/test/Linker/linknamedmdnode.ll | 6 | ||||
-rw-r--r-- | llvm/test/Linker/linknamedmdnode2.ll | 6 |
5 files changed, 42 insertions, 0 deletions
diff --git a/llvm/include/llvm/Metadata.h b/llvm/include/llvm/Metadata.h index 3803b5a5f57..8533efddb0f 100644 --- a/llvm/include/llvm/Metadata.h +++ b/llvm/include/llvm/Metadata.h @@ -229,6 +229,8 @@ public: return new NamedMDNode(N, MDs, NumMDs, M); } + static NamedMDNode *Create(const NamedMDNode *NMD, Module *M = 0); + /// eraseFromParent - Drop all references and remove the node from parent /// module. void eraseFromParent(); diff --git a/llvm/lib/Linker/LinkModules.cpp b/llvm/lib/Linker/LinkModules.cpp index 3aec864c2d0..ca0bf73002b 100644 --- a/llvm/lib/Linker/LinkModules.cpp +++ b/llvm/lib/Linker/LinkModules.cpp @@ -538,6 +538,22 @@ static bool GetLinkageResult(GlobalValue *Dest, const GlobalValue *Src, return false; } +// Insert all of the named mdnoes in Src into the Dest module. +static void LinkNamedMDNodes(Module *Dest, Module *Src) { + for (Module::const_named_metadata_iterator I = Src->named_metadata_begin(), + E = Src->named_metadata_end(); I != E; ++I) { + const NamedMDNode *SrcNMD = I; + NamedMDNode *DestNMD = Dest->getNamedMetadata(SrcNMD->getName()); + if (!DestNMD) + NamedMDNode::Create(SrcNMD, Dest); + else { + // Add Src elements into Dest node. + for (unsigned i = 0, e = SrcNMD->getNumElements(); i != e; ++i) + DestNMD->addElement(SrcNMD->getElement(i)); + } + } +} + // LinkGlobals - Loop through the global variables in the src module and merge // them into the dest module. static bool LinkGlobals(Module *Dest, const Module *Src, @@ -1307,6 +1323,9 @@ Linker::LinkModules(Module *Dest, Module *Src, std::string *ErrorMsg) { AppendingVars.insert(std::make_pair(I->getName(), I)); } + // Insert all of the named mdnoes in Src into the Dest module. + LinkNamedMDNodes(Dest, Src); + // Insert all of the globals in src into the Dest module... without linking // initializers (which could refer to functions not yet mapped over). if (LinkGlobals(Dest, Src, ValueMap, AppendingVars, ErrorMsg)) diff --git a/llvm/lib/VMCore/Metadata.cpp b/llvm/lib/VMCore/Metadata.cpp index 3a61d0eefb7..4762a105550 100644 --- a/llvm/lib/VMCore/Metadata.cpp +++ b/llvm/lib/VMCore/Metadata.cpp @@ -104,6 +104,7 @@ MDNode::~MDNode() { dropAllReferences(); getType()->getContext().pImpl->MDNodes.remove(this); } + //===----------------------------------------------------------------------===// //NamedMDNode implementation // @@ -123,6 +124,14 @@ NamedMDNode::NamedMDNode(const Twine &N, MetadataBase*const* MDs, ParentModule->getNamedMDList().push_back(this); } +NamedMDNode *NamedMDNode::Create(const NamedMDNode *NMD, Module *M) { + assert (NMD && "Invalid source NamedMDNode!"); + SmallVector<MetadataBase *, 4> Elems; + for (unsigned i = 0, e = NMD->getNumElements(); i != e; ++i) + Elems.push_back(NMD->getElement(i)); + return new NamedMDNode(NMD->getName().data(), Elems.data(), Elems.size(), M); +} + /// eraseFromParent - Drop all references and remove the node from parent /// module. void NamedMDNode::eraseFromParent() { diff --git a/llvm/test/Linker/linknamedmdnode.ll b/llvm/test/Linker/linknamedmdnode.ll new file mode 100644 index 00000000000..455b3b807f8 --- /dev/null +++ b/llvm/test/Linker/linknamedmdnode.ll @@ -0,0 +1,6 @@ +; RUN: llvm-as < %s > %t.bc +; RUN: llvm-as < %p/linknamedmdnode2.ll > %t2.bc +; RUN: llvm-link %t.bc %t2.bc | llvm-dis | grep "!llvm.stuff = !{!0, !1}" + +!0 = metadata !{i32 42} +!llvm.stuff = !{!0} diff --git a/llvm/test/Linker/linknamedmdnode2.ll b/llvm/test/Linker/linknamedmdnode2.ll new file mode 100644 index 00000000000..d16f62abed3 --- /dev/null +++ b/llvm/test/Linker/linknamedmdnode2.ll @@ -0,0 +1,6 @@ +; This file is used by linknamedmdnode.ll, so it doesn't actually do anything itself +; +; RUN: true + +!0 = metadata !{i32 41} +!llvm.stuff = !{!0} |