diff options
| author | Artur Pilipenko <apilipenko@azulsystems.com> | 2019-08-28 21:27:50 +0000 | 
|---|---|---|
| committer | Artur Pilipenko <apilipenko@azulsystems.com> | 2019-08-28 21:27:50 +0000 | 
| commit | 925afc1ce70ab4117073d52bf519ea7cf05ed03f (patch) | |
| tree | 5348ad743af4bfb73cf552a001eb3c13dcdabcd1 /llvm/lib/Transforms/Utils/CloneFunction.cpp | |
| parent | 5970076466cf9722b7b5bd08f50e6479c352baf3 (diff) | |
| download | bcm5719-llvm-925afc1ce70ab4117073d52bf519ea7cf05ed03f.tar.gz bcm5719-llvm-925afc1ce70ab4117073d52bf519ea7cf05ed03f.zip | |
Fix for "DICompileUnit not listed in llvm.dbg.cu" verification error after ...
...cloning a function from a different module
Currently when a function with debug info is cloned from a different module, the 
cloned function may have hanging DICompileUnits, so that the module with the 
cloned function fails debug info verification.
The proposed fix inserts all DICompileUnits reachable from the cloned function 
to "llvm.dbg.cu" metadata operands of the cloned function module. 
Reviewed By: aprantl, efriedma
Differential Revision: https://reviews.llvm.org/D66510
Patch by Oleg Pliss (Oleg.Pliss@azul.com)
llvm-svn: 370265
Diffstat (limited to 'llvm/lib/Transforms/Utils/CloneFunction.cpp')
| -rw-r--r-- | llvm/lib/Transforms/Utils/CloneFunction.cpp | 15 | 
1 files changed, 15 insertions, 0 deletions
| diff --git a/llvm/lib/Transforms/Utils/CloneFunction.cpp b/llvm/lib/Transforms/Utils/CloneFunction.cpp index 1026c9d3703..75e8963303c 100644 --- a/llvm/lib/Transforms/Utils/CloneFunction.cpp +++ b/llvm/lib/Transforms/Utils/CloneFunction.cpp @@ -210,6 +210,21 @@ void llvm::CloneFunctionInto(Function *NewFunc, const Function *OldFunc,        RemapInstruction(&II, VMap,                         ModuleLevelChanges ? RF_None : RF_NoModuleLevelChanges,                         TypeMapper, Materializer); + +  // Register all DICompileUnits of the old parent module in the new parent module +  auto* OldModule = OldFunc->getParent(); +  auto* NewModule = NewFunc->getParent(); +  if (OldModule && NewModule && OldModule != NewModule && DIFinder.compile_unit_count()) { +    auto* NMD = NewModule->getOrInsertNamedMetadata("llvm.dbg.cu"); +    // Avoid multiple insertions of the same DICompileUnit to NMD. +    SmallPtrSet<const void*, 8> Visited; +    for (auto* Operand : NMD->operands()) +      Visited.insert(Operand); +    for (auto* Unit : DIFinder.compile_units()) +      // VMap.MD()[Unit] == Unit +      if (Visited.insert(Unit).second) +        NMD->addOperand(Unit); +  }  }  /// Return a copy of the specified function and add it to that function's | 

