[PATCH] D36850: [ThinLTO] Add function attribute propagation
Teresa Johnson via Phabricator via llvm-commits
llvm-commits at lists.llvm.org
Fri Aug 18 09:26:07 PDT 2017
tejohnson added inline comments.
================
Comment at: lib/LTO/ThinLTOCodeGenerator.cpp:609
}
+ propagateFunctionAttrs(*CombinedIndex);
return CombinedIndex;
----------------
Adding the calls to this file only affects the legacy LTO implementation used by ld64 and llvm-lto. You'll definitely want the calls also where you had them in the new LTO API in your earlier version of this patch (which is used by lld, gold and llvm-lto2).
================
Comment at: lib/Transforms/IPO/FunctionImport.cpp:423
+void llvm::propagateFunctionAttrs(ModuleSummaryIndex &Index) {
+ auto addReadAttrs = [](std::vector<FunctionSummary *> &SCCNodes) {
+ bool ReadsMemory = false;
----------------
ncharlie wrote:
> I just realized this isn't going to ever change any attrs.
>
> I based it on the FunctionAttrs pass which does alias analysis first: http://llvm-cs.pcc.me.uk/lib/Transforms/IPO/FunctionAttrs.cpp#185
>
> That can't be done here, since at this point we can only access summaries.
>
> Maybe I need to include a flag in the function summary that marks if the function definitely writes memory and then propagate memory access information to any nodes that are unknown?
Hmm, I think there is a fundamental issue with the way we designed this support in the index (my fault, not yours). We do invoke the FunctionAttrs pass during the per-module compile step. However, with a traditional LTO, doing so after the combined module is created will enable this pass to be much more aggressive because calls that were previously opaque (because they were defined elsewhere), can now be analyzed by AA. I think we will need to have some richer information in the index. E.g. at http://llvm-cs.pcc.me.uk/lib/Transforms/IPO/FunctionAttrs.cpp#96 we skip calls in the same SCC when analyzing the memory accesses due to calls. In the compile step we have smaller SCCs and therefore treat more calls conservatively. Presumably we need to identify which calls caused the function to be marked as reading or writing memory, and then record whether the function otherwise read or wrote memory (based on it's non-call instructions), so that we can be more aggressive in the thin link attribute propagation.
While I think more about that why don't you remove this from the patch and make this first thin link patch just about propagating NoRecurse which is more straightforward? That way you can get it in much sooner.
================
Comment at: lib/Transforms/IPO/FunctionImport.cpp:601
+ if (!(GV =
+ Index.findSummaryInModule(F.getGUID(), F.getParent()->getName())))
+ continue; // skip functions that aren't in the index
----------------
To be more efficient, pass in DefinedGlobals instead of the full Index (see below thinLTOResolveWeakForLinkerModule for example).
================
Comment at: lib/Transforms/IPO/FunctionImport.cpp:459
+
+ if (F->getOriginalName() == 0 || F->fflags().NoRecurse)
+ return false;
----------------
I don't think you want/need the check on getOriginalName?
================
Comment at: test/ThinLTO/X86/functionattr-prop.ll:15
+
+declare i32 @c() norecurse
+; CHECK: define i32 @d() #0 {
----------------
Does declaring c to be norecurse here cause us to already mark d as norecurse even without the thin link? I.e we want to ensure that d is only marked norecurse after the thin link.
https://reviews.llvm.org/D36850
More information about the llvm-commits
mailing list