<div dir="ltr">Yes, this is a much needed feature. I have and will continue to push back on trying to add it until we at least get a sane framework for our *existing* pass pipelines though. I'm just a bit worried about scope creep here is all. It's definitely something I want to see happen long-term.</div><div class="gmail_extra"><br><div class="gmail_quote">On Tue, Oct 14, 2014 at 1:45 PM, Robin Morisset <span dir="ltr"><<a href="mailto:morisset@google.com" target="_blank">morisset@google.com</a>></span> wrote:<br><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex"><div dir="ltr">For what it is worth, I agree with the usefulness of having a concept of "cleanup pass". Another example of a situation where it would be nice is in the fence elimination patch I sent for review recently: the pass is rather expensive because it relies on several analysis passes, and is only useful if AtomicExpand introduced fences. Being able to say "Only run this pass if the code was modified by this previous pass" would be awesome.<div>Yet another example is the EnableAtomicTidy flag on ARM that runs simplifyCFG after AtomicExpand to cleanup some of the load-linked/store-conditional loops: if no such loops have been introduced, the cleanup is unnecessary.</div></div><div class="HOEnZb"><div class="h5"><div class="gmail_extra"><br><div class="gmail_quote">On Tue, Oct 14, 2014 at 12:24 PM, Hal Finkel <span dir="ltr"><<a href="mailto:hfinkel@anl.gov" target="_blank">hfinkel@anl.gov</a>></span> wrote:<br><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex"><span>----- Original Message -----<br>
> From: "Andrew Trick" <<a href="mailto:atrick@apple.com" target="_blank">atrick@apple.com</a>><br>
> To: "Chandler Carruth" <<a href="mailto:chandlerc@google.com" target="_blank">chandlerc@google.com</a>><br>
> Cc: "James Molloy" <<a href="mailto:james@jamesmolloy.co.uk" target="_blank">james@jamesmolloy.co.uk</a>>, "LLVM Developers Mailing List" <<a href="mailto:llvmdev@cs.uiuc.edu" target="_blank">llvmdev@cs.uiuc.edu</a>><br>
</span><span>> Sent: Tuesday, October 14, 2014 1:21:21 PM<br>
> Subject: Re: [LLVMdev] RFC: Should we have (something like) -extra-vectorizer-passes in -O2?<br>
><br>
><br>
</span><span>> I’ll summarize your responses as: The new pipeline produces better<br>
> results than the old, and we currently have no good mechanism for<br>
> reducing the compile time overhead.<br>
><br>
><br>
> I’ll summarize my criticism as: In principle, there are better ways<br>
> to clean up after the vectorizer without turning it into a<br>
> complicated megapass, but no one has done the engineering. I don’t<br>
> think cleaning up after the vectorizer should incur any noticeable<br>
> overhead if the vectorizer never runs, and it would be avoidable<br>
> with a sensibly designed passes that aren’t locked into the current<br>
> pass manager design.<br>
><br>
> I don’t have the data right now to argue against enabling the new<br>
> pipeline under O2. Hopefully others who care about clang compile<br>
> time will jump in.<br>
><br>
> As for the long-term plan to improve compile-time, all I can do now<br>
> is to advocate for a better approach.<br>
<br>
</span>Sure, but we should also have a plan ;) -- I think this is important, and we should make sure this doesn't get dropped. I don't think that the vectorizers are the only thing for which the concept of 'cleanup' passes are relevant. The critical piece here is that, if we don't need to run a cleanup pass, we also don't need to compute any analysis passes on which the pass might depend.<br>
<br>
While I'm in favor of the new passes, I also want us to have a plan in this area. I understand that the pass manager is being rewritten, and maybe putting effort into the old one is not worthwhile now, but the new one should certainly have a design compatible with this requirement. Chandler?<br>
<span><font color="#888888"><br>
-Hal<br>
</font></span><div><div><br>
><br>
><br>
> -Andy<br>
><br>
><br>
><br>
><br>
><br>
> On Oct 14, 2014, at 10:56 AM, Chandler Carruth < <a href="mailto:chandlerc@google.com" target="_blank">chandlerc@google.com</a><br>
> > wrote:<br>
><br>
><br>
><br>
><br>
><br>
> On Tue, Oct 14, 2014 at 10:11 AM, Andrew Trick < <a href="mailto:atrick@apple.com" target="_blank">atrick@apple.com</a> ><br>
> wrote:<br>
><br>
><br>
><br>
> >> + correlated-propagation<br>
><br>
> A little worried about this.<br>
><br>
> >> + instcombine<br>
><br>
> I'm *very* concerned about rerunning instcombine, but understand it<br>
> may help cleanup the vectorized preheader.<br>
><br>
><br>
><br>
> Why are you concerned? Is instcombine that slow? I usually don't see<br>
> huge overhead from re-running it on nearly-canonical code. (Oh, I<br>
> see you just replied to Hal here, fair enough.<br>
><br>
><br>
><br>
><br>
> >> + licm<br>
> >> + loop-unswitch<br>
><br>
> These should limited to the relevant loop nest.<br>
><br>
><br>
><br>
> We have no way to do that currently. Do you think they will in<br>
> practice be too slow? If so, why? I would naively expect unswitch to<br>
> be essentially free unless it can do something, and LICM not much<br>
> more expensive.<br>
><br>
><br>
><br>
><br>
> >> + simplifycfg<br>
><br>
> OK if the CFG actually changed.<br>
><br>
><br>
><br>
> Again, we have no mechanism to gate this. Frustratingly, the only<br>
> thing I want here is to delete dead code formed by earlier passes.<br>
> We just don't have anything cheaper (and I don't have any<br>
> measurements indicating we need something cheaper).<br>
><br>
><br>
><br>
><br>
> >> + instcombine<br>
><br>
> instcombine again! This can’t be good.<br>
><br>
><br>
><br>
> I actually have no specific reason to think we need this other than<br>
> the fact that we run instcombine after simplifycfg in a bunch of<br>
> other places. If you're looking for one to rip out, this would be<br>
> the first one I would rip out because I'm doubtful of its value.<br>
><br>
><br>
><br>
> On a separate note:<br>
><br>
><br>
><br>
><br>
><br>
> >> + early-cse<br>
><br>
> Passes like loop-vectorize should be able to do their own CSE without<br>
> much engineering effort.<br>
><br>
> >> slp-vectorize<br>
> >> + early-cse<br>
><br>
> SLP should do its own CSE.<br>
><br>
> I actually agree with you in principle, but I would rather run the<br>
> pass now (and avoid hacks downstream to essentially do CSE in the<br>
> backend) than hold up progress on the hope of advanced on-demand CSE<br>
> layers being added to the vectorizers. I don't know of anyone<br>
> actually working on that, and so I'm somewhat concerned it will<br>
> never materialize.<br>
><br>
</div></div><div><div>> _______________________________________________<br>
> LLVM Developers mailing list<br>
> <a href="mailto:LLVMdev@cs.uiuc.edu" target="_blank">LLVMdev@cs.uiuc.edu</a> <a href="http://llvm.cs.uiuc.edu" target="_blank">http://llvm.cs.uiuc.edu</a><br>
> <a href="http://lists.cs.uiuc.edu/mailman/listinfo/llvmdev" target="_blank">http://lists.cs.uiuc.edu/mailman/listinfo/llvmdev</a><br>
><br>
<br>
--<br>
Hal Finkel<br>
Assistant Computational Scientist<br>
Leadership Computing Facility<br>
Argonne National Laboratory<br>
<br>
_______________________________________________<br>
LLVM Developers mailing list<br>
<a href="mailto:LLVMdev@cs.uiuc.edu" target="_blank">LLVMdev@cs.uiuc.edu</a> <a href="http://llvm.cs.uiuc.edu" target="_blank">http://llvm.cs.uiuc.edu</a><br>
<a href="http://lists.cs.uiuc.edu/mailman/listinfo/llvmdev" target="_blank">http://lists.cs.uiuc.edu/mailman/listinfo/llvmdev</a><br>
</div></div></blockquote></div><br></div>
</div></div><br>_______________________________________________<br>
LLVM Developers mailing list<br>
<a href="mailto:LLVMdev@cs.uiuc.edu">LLVMdev@cs.uiuc.edu</a> <a href="http://llvm.cs.uiuc.edu" target="_blank">http://llvm.cs.uiuc.edu</a><br>
<a href="http://lists.cs.uiuc.edu/mailman/listinfo/llvmdev" target="_blank">http://lists.cs.uiuc.edu/mailman/listinfo/llvmdev</a><br>
<br></blockquote></div><br></div>