[PATCH] D59918: [Attributor] Pass infrastructure and fixpoint framework

Johannes Doerfert via Phabricator via llvm-commits llvm-commits at lists.llvm.org
Mon Jun 3 18:27:18 PDT 2019


jdoerfert added a comment.

In D59918#1527639 <https://reviews.llvm.org/D59918#1527639>, @fhahn wrote:

> I think it is still overly aggressive with analysis invalidation, but I agree it would be good to iterate on those things once the basics are in. Maybe it's worth a FIXME comment. Otherwise, looks good, thanks for the patience.


I added the FIXME and I verified that at the new point in the (old PM) pipeline there is no pass that is destroyed because of the Attributor. It is not part of the new PM pipeline right now.



================
Comment at: llvm/lib/Transforms/IPO/Attributor.cpp:365
+  // re-initialization of the arguments. This re-run should not result in an IR
+  // change. Though, the (virtual) state of attributes at the end of the re-run
+  // might be more optimistic than the known state or the IR state if the better
----------------
hfinkel wrote:
> jdoerfert wrote:
> > hfinkel wrote:
> > > This is true even if we did't reach the fixpoint and has to reset some attributes to their pessimistic state?
> > [I read it as "Is this true...".]
> > 
> > No it is not. If we do not reach an optimistic fixpoint we force a pessimistic one. If we modify the IR, we can, in the re-run, again find a better stable state (which could be an optimistic or pessimistic fixpoint) that allows again to enhance the IR. 
> > 
> > After thinking about the use of utility functions a bit more, I guess this can actually also happen if we have a fixpoint based on pessimistic information. Maybe we have to weaken the "llvm_unreachable" at some point, or we have to avoid/extend utility functions. For now, and with up to 32 iterations, I haven't seen a single non-optimistic fixpoint in all the test runs on LLVM-TS and SPEC2006.
> Okay. I don't like theoretically-unsound checks (that aren't explicitly labeled as such), however, and the fact that this is enabled by default when EXPENSIVE_CHECKS is defined isn't good if this isn't sound. Please update the comment in the cl::opt to indicate that this might spuriously fail for pessimistic fixed points, and don't enable this by default with EXPENSIVE_CHECKS.
You are right. I did that now.

I did not before because for the first few attributes this should be sound. They do use utility functions but such that they should be able to get the best possible result even if the assumed information is not manifested in IR. The first attribute, `returned` on arguments, is one of them. I will find a way to run this such that only attributes with this property are verified and then I'll go back to "auto-verify" it when expensive checks are enabled.


================
Comment at: llvm/lib/Transforms/IPO/Attributor.cpp:399
+    default:
+      break;
+    }
----------------
hfinkel wrote:
> Please add a comment here explaining what gets added here (so that it's clear why it's here and empty).
Done


Repository:
  rG LLVM Github Monorepo

CHANGES SINCE LAST ACTION
  https://reviews.llvm.org/D59918/new/

https://reviews.llvm.org/D59918





More information about the llvm-commits mailing list