diff options
Diffstat (limited to 'llvm/lib/Transforms/IPO/WholeProgramDevirt.cpp')
| -rw-r--r-- | llvm/lib/Transforms/IPO/WholeProgramDevirt.cpp | 31 | 
1 files changed, 16 insertions, 15 deletions
| diff --git a/llvm/lib/Transforms/IPO/WholeProgramDevirt.cpp b/llvm/lib/Transforms/IPO/WholeProgramDevirt.cpp index a0f7ec6..2dd0fde 100644 --- a/llvm/lib/Transforms/IPO/WholeProgramDevirt.cpp +++ b/llvm/lib/Transforms/IPO/WholeProgramDevirt.cpp @@ -948,17 +948,17 @@ void llvm::updateVCallVisibilityInIndex(      // linker, as we have no information on their eventual use.      if (DynamicExportSymbols.count(P.first))        continue; +    // With validation enabled, we want to exclude symbols visible to regular +    // objects. Local symbols will be in this group due to the current +    // implementation but those with VCallVisibilityTranslationUnit will have +    // already been marked in clang so are unaffected. +    if (VisibleToRegularObjSymbols.count(P.first)) +      continue;      for (auto &S : P.second.getSummaryList()) {        auto *GVar = dyn_cast<GlobalVarSummary>(S.get());        if (!GVar ||            GVar->getVCallVisibility() != GlobalObject::VCallVisibilityPublic)          continue; -      // With validation enabled, we want to exclude symbols visible to regular -      // objects. Local symbols will be in this group due to the current -      // implementation but those with VCallVisibilityTranslationUnit will have -      // already been marked in clang so are unaffected. -      if (VisibleToRegularObjSymbols.count(P.first)) -        continue;        GVar->setVCallVisibility(GlobalObject::VCallVisibilityLinkageUnit);      }    } @@ -1161,14 +1161,10 @@ bool DevirtIndex::tryFindVirtualCallTargets(      // and therefore the same GUID. This can happen if there isn't enough      // distinguishing path when compiling the source file. In that case we      // conservatively return false early. +    if (P.VTableVI.hasLocal() && P.VTableVI.getSummaryList().size() > 1) +      return false;      const GlobalVarSummary *VS = nullptr; -    bool LocalFound = false;      for (const auto &S : P.VTableVI.getSummaryList()) { -      if (GlobalValue::isLocalLinkage(S->linkage())) { -        if (LocalFound) -          return false; -        LocalFound = true; -      }        auto *CurVS = cast<GlobalVarSummary>(S->getBaseObject());        if (!CurVS->vTableFuncs().empty() ||            // Previously clang did not attach the necessary type metadata to @@ -1184,6 +1180,7 @@ bool DevirtIndex::tryFindVirtualCallTargets(          // with public LTO visibility.          if (VS->getVCallVisibility() == GlobalObject::VCallVisibilityPublic)            return false; +        break;        }      }      // There will be no VS if all copies are available_externally having no @@ -1411,9 +1408,8 @@ bool DevirtIndex::trySingleImplDevirt(MutableArrayRef<ValueInfo> TargetsForSlot,    // If the summary list contains multiple summaries where at least one is    // a local, give up, as we won't know which (possibly promoted) name to use. -  for (const auto &S : TheFn.getSummaryList()) -    if (GlobalValue::isLocalLinkage(S->linkage()) && Size > 1) -      return false; +  if (TheFn.hasLocal() && Size > 1) +    return false;    // Collect functions devirtualized at least for one call site for stats.    if (PrintSummaryDevirt || AreStatisticsEnabled()) @@ -2591,6 +2587,11 @@ void DevirtIndex::run() {    if (ExportSummary.typeIdCompatibleVtableMap().empty())      return; +  // Assert that we haven't made any changes that would affect the hasLocal() +  // flag on the GUID summary info. +  assert(!ExportSummary.withInternalizeAndPromote() && +         "Expect index-based WPD to run before internalization and promotion"); +    DenseMap<GlobalValue::GUID, std::vector<StringRef>> NameByGUID;    for (const auto &P : ExportSummary.typeIdCompatibleVtableMap()) {      NameByGUID[GlobalValue::getGUIDAssumingExternalLinkage(P.first)].push_back( | 
