summaryrefslogtreecommitdiffstats
path: root/llvm/lib/VMCore
diff options
context:
space:
mode:
authorDevang Patel <dpatel@apple.com>2009-07-29 22:04:47 +0000
committerDevang Patel <dpatel@apple.com>2009-07-29 22:04:47 +0000
commit23e68308b52d128d6c1115eb2571c64e3b25dc2b (patch)
treef943bf3d321538c385e47b33faa52319576fea92 /llvm/lib/VMCore
parent98ddd164d8fc754a37454f1cbb8ea04051149690 (diff)
downloadbcm5719-llvm-23e68308b52d128d6c1115eb2571c64e3b25dc2b.tar.gz
bcm5719-llvm-23e68308b52d128d6c1115eb2571c64e3b25dc2b.zip
Print named metadata.
llvm-svn: 77513
Diffstat (limited to 'llvm/lib/VMCore')
-rw-r--r--llvm/lib/VMCore/AsmWriter.cpp25
1 files changed, 25 insertions, 0 deletions
diff --git a/llvm/lib/VMCore/AsmWriter.cpp b/llvm/lib/VMCore/AsmWriter.cpp
index f813d851d88..28cc56e6b4e 100644
--- a/llvm/lib/VMCore/AsmWriter.cpp
+++ b/llvm/lib/VMCore/AsmWriter.cpp
@@ -623,6 +623,17 @@ void SlotTracker::processModule() {
}
}
+ // Add metadata used by named metadata.
+ for (Module::const_named_metadata_iterator
+ I = TheModule->named_metadata_begin(),
+ E = TheModule->named_metadata_end(); I != E; ++I) {
+ const NamedMDNode *NMD = I;
+ for (unsigned i = 0, e = NMD->getNumElements(); i != e; ++i) {
+ MDNode *MD = dyn_cast_or_null<MDNode>(NMD->getElement(i));
+ CreateMetadataSlot(MD);
+ }
+ }
+
// Add all the unnamed functions to the table.
for (Module::const_iterator I = TheModule->begin(), E = TheModule->end();
I != E; ++I)
@@ -1344,6 +1355,20 @@ void AssemblyWriter::printModule(const Module *M) {
for (Module::const_iterator I = M->begin(), E = M->end(); I != E; ++I)
printFunction(I);
+ // Output named metadata.
+ for (Module::const_named_metadata_iterator I = M->named_metadata_begin(),
+ E = M->named_metadata_end(); I != E; ++I) {
+ const NamedMDNode *NMD = I;
+ Out << "!" << NMD->getName() << " = !{";
+ for (unsigned i = 0, e = NMD->getNumElements(); i != e; ++i) {
+ if (i) Out << ", ";
+ MDNode *MD = cast<MDNode>(NMD->getElement(i));
+ Out << '!' << Machine.getMetadataSlot(MD);
+ }
+ Out << "}\n";
+ }
+
+ // Output metadata.
WriteMDNodes(Out, TypePrinter, Machine);
}
OpenPOWER on IntegriCloud