diff options
Diffstat (limited to 'llvm/lib/LTO/LTO.cpp')
| -rw-r--r-- | llvm/lib/LTO/LTO.cpp | 45 | 
1 files changed, 30 insertions, 15 deletions
| diff --git a/llvm/lib/LTO/LTO.cpp b/llvm/lib/LTO/LTO.cpp index aec8891..4bc2a18 100644 --- a/llvm/lib/LTO/LTO.cpp +++ b/llvm/lib/LTO/LTO.cpp @@ -457,7 +457,7 @@ void llvm::thinLTOResolvePrevailingInIndex(    // when needed.    DenseSet<GlobalValueSummary *> GlobalInvolvedWithAlias;    for (auto &I : Index) -    for (auto &S : I.second.SummaryList) +    for (auto &S : I.second.getSummaryList())        if (auto AS = dyn_cast<AliasSummary>(S.get()))          GlobalInvolvedWithAlias.insert(&AS->getAliasee()); @@ -471,11 +471,13 @@ static void thinLTOInternalizeAndPromoteGUID(      ValueInfo VI, function_ref<bool(StringRef, ValueInfo)> isExported,      function_ref<bool(GlobalValue::GUID, const GlobalValueSummary *)>          isPrevailing) { -  auto ExternallyVisibleCopies = -      llvm::count_if(VI.getSummaryList(), -                     [](const std::unique_ptr<GlobalValueSummary> &Summary) { -                       return !GlobalValue::isLocalLinkage(Summary->linkage()); -                     }); +  // Before performing index-based internalization and promotion for this GUID, +  // the local flag should be consistent with the summary list linkage types. +  VI.verifyLocal(); + +  const bool SingleExternallyVisibleCopy = +      VI.getSummaryList().size() == 1 && +      !GlobalValue::isLocalLinkage(VI.getSummaryList().front()->linkage());    for (auto &S : VI.getSummaryList()) {      // First see if we need to promote an internal value because it is not @@ -539,7 +541,9 @@ static void thinLTOInternalizeAndPromoteGUID(          GlobalValue::isExternalWeakLinkage(S->linkage()))        continue; -    if (isPrevailing(VI.getGUID(), S.get()) && ExternallyVisibleCopies == 1) +    // We may have a single summary copy that is externally visible but not +    // prevailing if the prevailing copy is in a native object. +    if (SingleExternallyVisibleCopy && isPrevailing(VI.getGUID(), S.get()))        S->setLinkage(GlobalValue::InternalLinkage);    }  } @@ -551,9 +555,11 @@ void llvm::thinLTOInternalizeAndPromoteInIndex(      function_ref<bool(StringRef, ValueInfo)> isExported,      function_ref<bool(GlobalValue::GUID, const GlobalValueSummary *)>          isPrevailing) { +  assert(!Index.withInternalizeAndPromote());    for (auto &I : Index)      thinLTOInternalizeAndPromoteGUID(Index.getValueInfo(I), isExported,                                       isPrevailing); +  Index.setWithInternalizeAndPromote();  }  // Requires a destructor for std::vector<InputModule>. @@ -1080,15 +1086,15 @@ LTO::addThinLTO(BitcodeModule BM, ArrayRef<InputFile::Symbol> Syms,            GlobalValue::getGlobalIdentifier(Sym.getIRName(),                                             GlobalValue::ExternalLinkage, ""));        if (R.Prevailing) -        ThinLTO.PrevailingModuleForGUID[GUID] = BM.getModuleIdentifier(); +        ThinLTO.setPrevailingModuleForGUID(GUID, BM.getModuleIdentifier());      }    }    if (Error Err =            BM.readSummary(ThinLTO.CombinedIndex, BM.getModuleIdentifier(),                           [&](GlobalValue::GUID GUID) { -                           return ThinLTO.PrevailingModuleForGUID[GUID] == -                                  BM.getModuleIdentifier(); +                           return ThinLTO.isPrevailingModuleForGUID( +                               GUID, BM.getModuleIdentifier());                           }))      return Err;    LLVM_DEBUG(dbgs() << "Module " << BM.getModuleIdentifier() << "\n"); @@ -1102,8 +1108,8 @@ LTO::addThinLTO(BitcodeModule BM, ArrayRef<InputFile::Symbol> Syms,            GlobalValue::getGlobalIdentifier(Sym.getIRName(),                                             GlobalValue::ExternalLinkage, ""));        if (R.Prevailing) { -        assert(ThinLTO.PrevailingModuleForGUID[GUID] == -               BM.getModuleIdentifier()); +        assert( +            ThinLTO.isPrevailingModuleForGUID(GUID, BM.getModuleIdentifier()));          // For linker redefined symbols (via --wrap or --defsym) we want to          // switch the linkage to `weak` to prevent IPOs from happening. @@ -1182,7 +1188,7 @@ Error LTO::checkPartiallySplit() {    // Otherwise check if there are any recorded in the combined summary from the    // ThinLTO modules.    for (auto &P : ThinLTO.CombinedIndex) { -    for (auto &S : P.second.SummaryList) { +    for (auto &S : P.second.getSummaryList()) {        auto *FS = dyn_cast<FunctionSummary>(S.get());        if (!FS)          continue; @@ -1982,7 +1988,7 @@ Error LTO::runThinLTO(AddStreamFn AddStream, FileCache Cache,                                 LocalWPDTargetsMap);    auto isPrevailing = [&](GlobalValue::GUID GUID, const GlobalValueSummary *S) { -    return ThinLTO.PrevailingModuleForGUID[GUID] == S->modulePath(); +    return ThinLTO.isPrevailingModuleForGUID(GUID, S->modulePath());    };    if (EnableMemProfContextDisambiguation) {      MemProfContextDisambiguation ContextDisambiguation; @@ -2218,6 +2224,7 @@ class OutOfProcessThinBackend : public CGThinBackend {    ArrayRef<StringRef> DistributorArgs;    SString RemoteCompiler; +  ArrayRef<StringRef> RemoteCompilerPrependArgs;    ArrayRef<StringRef> RemoteCompilerArgs;    bool SaveTemps; @@ -2254,12 +2261,14 @@ public:        bool ShouldEmitIndexFiles, bool ShouldEmitImportsFiles,        StringRef LinkerOutputFile, StringRef Distributor,        ArrayRef<StringRef> DistributorArgs, StringRef RemoteCompiler, +      ArrayRef<StringRef> RemoteCompilerPrependArgs,        ArrayRef<StringRef> RemoteCompilerArgs, bool SaveTemps)        : CGThinBackend(Conf, CombinedIndex, ModuleToDefinedGVSummaries,                        AddStream, OnWrite, ShouldEmitIndexFiles,                        ShouldEmitImportsFiles, ThinLTOParallelism),          LinkerOutputFile(LinkerOutputFile), DistributorPath(Distributor),          DistributorArgs(DistributorArgs), RemoteCompiler(RemoteCompiler), +        RemoteCompilerPrependArgs(RemoteCompilerPrependArgs),          RemoteCompilerArgs(RemoteCompilerArgs), SaveTemps(SaveTemps) {}    virtual void setup(unsigned ThinLTONumTasks, unsigned ThinLTOTaskOffset, @@ -2381,6 +2390,11 @@ public:          JOS.attributeArray("args", [&]() {            JOS.value(RemoteCompiler); +          // Forward any supplied prepend options. +          if (!RemoteCompilerPrependArgs.empty()) +            for (auto &A : RemoteCompilerPrependArgs) +              JOS.value(A); +            JOS.value("-c");            JOS.value(Saver.save("--target=" + Triple.str())); @@ -2511,6 +2525,7 @@ ThinBackend lto::createOutOfProcessThinBackend(      bool ShouldEmitIndexFiles, bool ShouldEmitImportsFiles,      StringRef LinkerOutputFile, StringRef Distributor,      ArrayRef<StringRef> DistributorArgs, StringRef RemoteCompiler, +    ArrayRef<StringRef> RemoteCompilerPrependArgs,      ArrayRef<StringRef> RemoteCompilerArgs, bool SaveTemps) {    auto Func =        [=](const Config &Conf, ModuleSummaryIndex &CombinedIndex, @@ -2520,7 +2535,7 @@ ThinBackend lto::createOutOfProcessThinBackend(              Conf, CombinedIndex, Parallelism, ModuleToDefinedGVSummaries,              AddStream, OnWrite, ShouldEmitIndexFiles, ShouldEmitImportsFiles,              LinkerOutputFile, Distributor, DistributorArgs, RemoteCompiler, -            RemoteCompilerArgs, SaveTemps); +            RemoteCompilerPrependArgs, RemoteCompilerArgs, SaveTemps);        };    return ThinBackend(Func, Parallelism);  } | 
