diff options
author | Eric Christopher <echristo@apple.com> | 2011-11-10 21:47:55 +0000 |
---|---|---|
committer | Eric Christopher <echristo@apple.com> | 2011-11-10 21:47:55 +0000 |
commit | 66b37db64158e3ddedfe7598582f29798ee07d08 (patch) | |
tree | 13ac9edd7bce55148082ca625374979d3fac42ff /llvm/lib/CodeGen/AsmPrinter/DwarfDebug.cpp | |
parent | 9d6055133b223d465da2555e06b50ee127ef4f4e (diff) | |
download | bcm5719-llvm-66b37db64158e3ddedfe7598582f29798ee07d08.tar.gz bcm5719-llvm-66b37db64158e3ddedfe7598582f29798ee07d08.zip |
Make types and namespaces take multiple DIEs for the accelerator tables
as well.
llvm-svn: 144319
Diffstat (limited to 'llvm/lib/CodeGen/AsmPrinter/DwarfDebug.cpp')
-rw-r--r-- | llvm/lib/CodeGen/AsmPrinter/DwarfDebug.cpp | 20 |
1 files changed, 12 insertions, 8 deletions
diff --git a/llvm/lib/CodeGen/AsmPrinter/DwarfDebug.cpp b/llvm/lib/CodeGen/AsmPrinter/DwarfDebug.cpp index 3ca23183a29..5d05a3cc3aa 100644 --- a/llvm/lib/CodeGen/AsmPrinter/DwarfDebug.cpp +++ b/llvm/lib/CodeGen/AsmPrinter/DwarfDebug.cpp @@ -1823,12 +1823,14 @@ void DwarfDebug::emitAccelNamespaces() { for (DenseMap<const MDNode *, CompileUnit *>::iterator I = CUMap.begin(), E = CUMap.end(); I != E; ++I) { CompileUnit *TheCU = I->second; - const StringMap<DIE*> &Names = TheCU->getAccelNamespace(); - for (StringMap<DIE*>::const_iterator + const StringMap<std::vector<DIE*> > &Names = TheCU->getAccelNamespace(); + for (StringMap<std::vector<DIE*> >::const_iterator GI = Names.begin(), GE = Names.end(); GI != GE; ++GI) { const char *Name = GI->getKeyData(); - DIE *Entity = GI->second; - AT.AddName(Name, Entity); + std::vector<DIE *> Entities = GI->second; + for (std::vector<DIE *>::const_iterator DI = Entities.begin(), + DE = Entities.end(); DI != DE; ++DI) + AT.AddName(Name, (*DI)); } } @@ -1849,12 +1851,14 @@ void DwarfDebug::emitAccelTypes() { for (DenseMap<const MDNode *, CompileUnit *>::iterator I = CUMap.begin(), E = CUMap.end(); I != E; ++I) { CompileUnit *TheCU = I->second; - const StringMap<DIE*> &Names = TheCU->getAccelTypes(); - for (StringMap<DIE*>::const_iterator + const StringMap<std::vector<DIE*> > &Names = TheCU->getAccelTypes(); + for (StringMap<std::vector<DIE*> >::const_iterator GI = Names.begin(), GE = Names.end(); GI != GE; ++GI) { const char *Name = GI->getKeyData(); - DIE *Entity = GI->second; - AT.AddName(Name, Entity); + std::vector<DIE *> Entities = GI->second; + for (std::vector<DIE *>::const_iterator DI = Entities.begin(), + DE= Entities.end(); DI !=DE; ++DI) + AT.AddName(Name, (*DI)); } } |