[PATCH] D95929: [CSSPGO][llvm-profgen] Add brackets for context id to support extended binary format
    Hongtao Yu via Phabricator via llvm-commits 
    llvm-commits at lists.llvm.org
       
    Fri Apr  2 10:03:32 PDT 2021
    
    
  
hoy added inline comments.
================
Comment at: llvm/tools/llvm-profgen/ProfileGenerator.cpp:392
+  for (const auto &Item : ProfileMap) {
+    std::string ContextWithBracket = "[" + Item.first().str() + "]";
+    auto Ret = CxtWithBracketPMap.try_emplace(ContextWithBracket, Item.second);
----------------
wenlei wrote:
> hoy wrote:
> > wenlei wrote:
> > > This seems problematic, the string could get destructed while we still keep the StringRef for it in FunctionSamples's name and context..
> > Does the try_emplace below copy construct a new one?
> CxtWithBracketPMap is a StringMap, so key is StringRef not std::string.
Oh right, this is a problem. Good catch! How did you find it out?
Repository:
  rG LLVM Github Monorepo
CHANGES SINCE LAST ACTION
  https://reviews.llvm.org/D95929/new/
https://reviews.llvm.org/D95929
    
    
More information about the llvm-commits
mailing list