[PATCH] D59202: [WIP] Fixpoint iteration system for IPO attribute deduction
Johannes Doerfert via Phabricator via llvm-commits
llvm-commits at lists.llvm.org
Sun Mar 10 22:20:16 PDT 2019
jdoerfert created this revision.
Herald added subscribers: llvm-commits, jfb, dexonsmith, steven_wu, bollu, eraman, mehdi_amini.
Herald added a project: LLVM.
NOTE: This is a prototype that needs a lot of cleanup but shows how the
overall system could look like! The actual code review will happen
on smaller chunks of this code, adding one feature at a time, first
without removing the existing code path.
In the end, this commit shows how we should replace the current
"inter-procedural function attribute deduction" with a fixpoint
iteration system. For some problems with the current implementation see
[1]. The new system allows to determine various properties, including
inter-procedural function attributes, through interlaced fixpoint
iterations. All "in-flight" attributes can query the optimistic and
known values of other attributes computed in the same fixpoint
iteration. This allows better interference if there is a mutual
dependence. Dedicated fixpoint propagations determine information
alternating through forward and backward deduction (wrt. the execution
flow) until neither yields new results (or we decide to give up).
This prototype implementation:
- determines all attributes we did with the existing code
- adds detection for multiple new attributes
- shows how local information, e.g. dereferenceability due to a load, can be propagated by the system to callees of the function (if applicable) and users of the loaded pointer alike.
- distinguishes six different kinds of attribute "positions", e.g., function attributes and return attributes (see the enum ManifestPosition), five of which can be manifested in IR.
To deduce new attributes, at a known position (see the enum
ManifestPosition), one only needs to inherit from the AbstractAttribute
class and implement all methods without a default implementation. All
but the "bool updateImpl(Attributor &A, Direction Dir)" method are often
one liners.
Comment and remarks welcome!
[1] https://lists.llvm.org/pipermail/llvm-dev/2018-August/125537.html
Repository:
rL LLVM
https://reviews.llvm.org/D59202
Files:
include/llvm/Transforms/IPO/FunctionAttrs.h
lib/Transforms/IPO/FunctionAttrs.cpp
lib/Transforms/IPO/PassManagerBuilder.cpp
test/Analysis/TypeBasedAliasAnalysis/functionattrs.ll
test/ThinLTO/X86/devirt-after-icp.ll
test/Transforms/FunctionAttrs/2009-01-02-LocalStores.ll
test/Transforms/FunctionAttrs/atomic.ll
test/Transforms/FunctionAttrs/attribute_propagation.ll
test/Transforms/FunctionAttrs/attribute_propagation_chain.ll
test/Transforms/FunctionAttrs/internal_callee.ll
test/Transforms/FunctionAttrs/internal_large-agg.ll
test/Transforms/FunctionAttrs/internal_malloc.ll
test/Transforms/FunctionAttrs/internal_noalias.ll
test/Transforms/FunctionAttrs/naked_functions.ll
test/Transforms/FunctionAttrs/noalias_phi.ll
test/Transforms/FunctionAttrs/nonnull-global.ll
test/Transforms/FunctionAttrs/nonnull.ll
test/Transforms/FunctionAttrs/readattrs.ll
test/Transforms/FunctionAttrs/recursion_and_phi.ll
test/Transforms/FunctionAttrs/sql_malloc.ll
test/Transforms/Inline/delete-call.ll
test/Transforms/Reassociate/reassociate-deadinst.ll
-------------- next part --------------
A non-text attachment was scrubbed...
Name: D59202.190044.patch
Type: text/x-patch
Size: 183414 bytes
Desc: not available
URL: <http://lists.llvm.org/pipermail/llvm-commits/attachments/20190311/81ebb991/attachment-0001.bin>
More information about the llvm-commits
mailing list